阀值化 threshold

  • OpenCV中的阈值(threshold)函数: threshold 的运用。
  • C++: double threshold(InputArray src, OutputArray dst, double thresh, double maxVal, int threshold-
    Type)
    Python: cv2.threshold(src, thresh, maxval, type[, dst ])! retval, dst
    C: double cvThreshold(const CvArr* src, CvArr* dst, double threshold, double maxValue, int threshold-
    Type)
    Python: cv.Threshold(src, dst, threshold, maxValue, thresholdType) !None
    Parameters
    src – Source array (single-channel, 8-bit of 32-bit floating point).
    dst – Destination array of the same size and type as src .
    thresh – Threshold value.
    maxVal – Maximum value to use with the THRESH_BINARY and THRESH_BINARY_INV
    thresholding types.
    thresholdType – Thresholding type (see the details below).
  • 最简单的图像分割的方法。
  • 应用举例:从一副图像中利用阈值分割出我们需要的物体部分(当然这里的物体可以是一部分或者整体)。这样的图像分割方法是基于图像中物体与背景之间的灰度差异,而且此分割属于像素级的分割。
  • 为了从一副图像中提取出我们需要的部分,应该用图像中的每一个像素点的灰度值与选取的阈值进行比较,并作出相应的判断。(注意:阈值的选取依赖于具体的问题。即:物体在不同的图像中有可能会有不同的灰度值。
  • 一旦找到了需要分割的物体的像素点,我们可以对这些像素点设定一些特定的值来表示。(例如:可以将该物体的像素点的灰度值设定为:‘0’(黑色),其他的像素点的灰度值为:‘255’(白色);当然像素点的灰度值可以任意,但最好设定的两种颜色对比度较强,方便观察结果)。

阈值类型1:二进制阈值化(THRESH_BINARY)

  • 该阈值化类型如下式所示:

  • 解释:在运用该阈值类型的时候,先要选定一个特定的阈值量,比如:125,这样,新的阈值产生规则可以解释为大于125的像素点的灰度值设定为最大值(如8位灰度值最大为255),灰度值小于125的像素点的灰度值设定为0。

阈值类型2:反二进制阈值化(THRESH_BINARY_INV)

  • 该阈值类型如下式所示:

  • 解释:该阈值化与二进制阈值化相似,先选定一个特定的灰度值作为阈值,不过最后的设定值相反。(在8位灰度图中,例如大于阈值的设定为0,而小于该阈值的设定为255)。

阈值类型3:截断阈值化(THRESH_TRUNC)

  • 该阈值化类型如下式所示:

  • 解释:同样首先需要选定一个阈值,图像中大于该阈值的像素点被设定为该阈值,小于该阈值的保持不变。(例如:阈值选取为125,那小于125的阈值不改变,大于125的灰度值(230)的像素点就设定为该阈值)。

阈值类型4:阈值化为0(THRESH_TOZERO)

  • 该阈值类型如下式所示:

  • 解释:先选定一个阈值,然后对图像做如下处理:1 像素点的灰度值大于该阈值的不进行任何改变;2 像素点的灰度值小于该阈值的,其灰度值全部变为0。

阈值类型5:反阈值化为0(THRESH_TOZERO_INV)

  • 该阈值类型如下式所示:

  • 解释:原理类似于0阈值,但是在对图像做处理的时候相反,即:像素点的灰度值小于该阈值的不进行任何改变,而大于该阈值的部分,其灰度值全部变为0。

时间: 2024-08-29 07:26:31

阀值化 threshold的相关文章

cvThreshold与cvAdaptiveThreshold 阀值化操作与自动阀值化操作

核心函数:cvThreshold,cvAdaptiveThreshold 程序: 代码: #include "cv.h" #include "cxcore.h" #include "highgui.h" #include <iostream> int AdaptiveThreshold(int argc,char** argv) { IplImage* src=cvLoadImage("e:\\picture\\4.jpg&

图像阈值化-threshold、adaptivethreshold

在图像处理中阈值化操作,从一副图像中利用阈值分割出我们需要的物体部分(当然这里的物体可以是一部分或者整体).这样的图像分割方法是基于图像中物体与背景之间的灰度差异,而且此分割属于像素级的分割.opencv的二值化操作函数,如果你是一位经验丰富的专业人员,可以发现阈值化操作有很多小技巧,不只是单单调用二值化操作函数,就完成阈值化操作,往往还是结合形态学处理. 阈值化操作在图像处理中是一种常用的算法,比如图像的二值化就是一种最常见的一种阈值化操作.opencv2和opencv3中提供了直接阈值化操作

c#实现图片二值化例子(黑白效果)

C#将图片2值化示例代码,原图及二值化后的图片如下: 原图: 二值化后的图像: 实现代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 7

阈值化

一.固定阈值化Threshold()函数 double threshold( InputArray src, OutputArray dst, double thresh, double maxval, int type ); 二.自适应阈值操作:adaptiveThreshold()函数 void adaptiveThreshold( InputArray src, OutputArray dst, double maxValue, int adaptiveMethod, int thresh

图像的二值化

#include <opencv2/opencv.hpp> #include <iostream> #include <math.h> using namespace cv; using namespace std; Mat src, dst,dst2,gray_src; char* INPUT_WIN = "input image"; char* output_title = "binary image"; int thresh

角点检测方法

看了将近十来天的OPENCV了,无论是从官方文档,还是learning opencv,还是看各论坛,心里总有种感觉是:无法把自己看的知识联系在一起,感觉都是各有特色功能的函数,可是这些各有特色功能的函数怎么组合在一起,实现什么样的功能就不得而知了. 下面从角点的角度来讲讲吧  --(要说的是有些并非是本人所写,觉得别人有的地方写的经典就复制下来了) 使用函数 cornerHarris 通过 Harris-Stephens方法检测角点: 我们到底要角点干什么?????????????? 下面我来回

JVM实用参数——新生代垃圾回收

JVM实用参数目录 JVM实用参数——新生代垃圾回收 概述 第1部分  新生代垃圾回收介绍 第2部分 参数介绍 参考 第1部分  新生代垃圾回收介绍 本部分,我们将关注堆(heap) 中一个主要区域,新生代(young generation).首先我们会讨论为什么调整新生代的参数会对应用的性能如此重要,接着我们将学习新生代相关的JVM参数. 单纯从JVM的功能考虑,并不需要新生代,完全可以针对整个堆进行操作.新生代存在的唯一理由是优化垃圾回收(GC)的性能.更具体说,把堆划分为新生代和老年代有2

JVM实用参数(五)新生代垃圾回收

JVM实用参数(五)新生代垃圾回收 原文链接  作者: PATRICK PESCHLOW :译者:严亮 本部分,我们将关注堆(heap) 中一个主要区域,新生代(young generation).首先我们会讨论为什么调整新生代的参数会对应用的性能如此重要,接着我们将学习新生代相关的JVM参数. 单纯从JVM的功能考虑,并不需要新生代,完全可以针对整个堆进行操作.新生代存在的唯一理由是优化垃圾回收(GC)的性能.更具体说,把堆划分为新生代和老年代有2个好处:简化了新对象的分配(只在新生代分配内存

Anomaly Detection

这里我要强调一下什么叫做异常,机器到底要看到什么就是Anormaly.其实是取决你提供给机器什么样的训练数据 应用 1.若你有一个classifier,你希望这个classifier具有:看到不知道的数据会标上这是未知物的能力,这算是异常侦测的其中一种,又叫做Open-set Recognition 2.训练资料已经被混杂了一些异常的资料 用classifier 的confidence score c 进行anomoly detection 分类器的输出是一个几率分布(distribution)