目录

1. OTSU 介绍

2. 代码实现


1. OTSU 介绍

OTSU 大津法,也是最大类间方差算法

OTSU 算法的思想通过不同的阈值K,将图像的分为两个区域,一个是灰度值 0 <= k <= K 的子区域G1;另一个是灰度值 K+1 <= k <= L-1 的子区域G2 。通过计算两个子区域的方差,将区域间的方差最大化的过程。

这里不做具体的数学推导:

这里没有严格按照书上的来

首先通过阈值K,将图像分为G1和G2两个子区域,然后目的是求出下面的公式:

  • 这里的分母是全局图像的灰度方差:

方差 σ = ( 像素点灰度值 - mG )^2 / 像素点总个数 (就是数学上方差的定义)

  • 分子是区域间的类间方差,定义为:

  • P1 是像素点在G1区域的概率,P1 = G1 区域像素点个数 / 总像素个数
  • m1 是G1 区域的像素平均灰度:m1 = G1中像素灰度值总和 / G1 区域像素点的个数
  • mG 是整个图像的平均灰度

接下来,让我们重新回到这个公式:

分母是整幅图像的方差,因此是个常数,也就是说分母是不变的。

分子是两个区域间的类间方差,也就是说两个均值m1和m2隔得远,类间方差就越大,图像分割的就越好

因此 η(k) 越大就说明分子类间方差越大,就说明两个区域隔得越远,图像分割的越好

所以只需要迭代k,找到最大的那个η即可

2. 代码实现

code:

import cv2
import numpy as np# 全局阈值处理
def global_threshold_processing(x):   # x 为传入的图像hist = cv2.calcHist([x], [0], None, [256], [0, 256])  # 图像的灰度直方图  shape = (256,1)grayScale = np.arange(256).reshape(1, -1)             # 灰度级 [0,255]  shape =(1,256)sum_pixels = x.shape[0] * x.shape[1]                  # 图像总共像素点的个数sum_gray = np.dot(grayScale, hist)                    # 每个灰度值像素的个数 * 对应灰度值 = 所有的像素灰度值的和T = np.around(sum_gray / sum_pixels).astype(np.uint).item()         # 初始阈值T,设定为整幅图像的平均灰度值theta = 1while True:         # 迭代算法gray_c1 = grayScale[:, :T + 1]                     # 灰度值 <= T 的子区域 G1 的灰度级 (0,T)hist_c1 = hist[:T + 1, :]                          # 子区域G1 的直方图 (0,T),对应每个灰度值的像素点sum_gray_G1 = np.dot(gray_c1, hist_c1)             # G1 区域所有像素点灰度值总和 = (0,T)的灰度值 * 对应像素点的个数sum_pixels_G1 = np.sum(hist_c1)                    # G1 区域所有像素点的个数m1 = sum_gray_G1 / sum_pixels_G1                   # G1 区域平均灰度值sum_pixels_G2 = sum_pixels - sum_pixels_G1         # G2 区域所有像素点的个数 : 所有像素点 - G1 区域像素点个数sum_gray_G2 = sum_gray - sum_gray_G1               # G2 区域所有像素点的灰度值总和 :所有灰度值 - G1 灰度值m2 = sum_gray_G2 / sum_pixels_G2                   # G2 区域平均灰度值T_new = np.around((m1 + m2) / 2).astype(np.uint).item()  # 计算新的阈值if abs(T - T_new) < theta:T = T_newbreakelse:T = T_newx[x >= T] = 255         # 阈值处理x[x < T] = 0return T,ximg = cv2.imread("img.tif",0)#ret,dst = global_threshold_processing(img.copy())                          # 全局阈值处理
ret,dst = cv2.threshold(img,0,255,cv2.THRESH_BINARY+cv2.THRESH_OTSU)        # OTSU 算法print(ret)
cv2.imshow('img',np.hstack((img,dst)))
cv2.waitKey(0)
cv2.destroyAllWindows()

全局阈值处理:返回的阈值为 T = 171

OTSU算法:返回的阈值 T = 181

图像分割 - 阈值处理 - 最大类间方差法(OTSU)相关推荐

  1. 基于OTSU最大类间方差法的ROI分割、提取图像中的形状特征--面积、周长、离心率、zernike矩

    分享一下最近学习的图像分类方面知识,整体的思路如下(之前的汇报ppt里截的) 把这个过程拆分几个部分共同学习一下吧 1.Otsu法原理 最大类间方差法OTSU是一种自适应的全局阈值确定的方法,根据灰度 ...

  2. 数字图像处理实验(六)|图像分割{阈值分割、直方图法、OTUS最大类间方差法(edge、im2dw、imfilter、imresize)、迭代阈值法、点检测}(附matlab实验代码和截图)

    文章目录 一.实验目的 二.实验原理 (一) 阈值分割 1. 直方图法 2.OTSU法(最大类间方差法)确定阈值 3. 迭代阈值法 4. 点检测 (二)边缘检测 三.实验内容 (一)阈值分割 1. 直 ...

  3. 基于遗传算法的二维最大类间方差法的图像分割优化

    一.背景 最大类间方差阈值分割法日本大津展之在1980年提出的,其基本思路是将图像的直方图以某一灰度为阈值,将图像分成两组并计算两组的方差,当被分成的两组之间的方差最大时,就以这个灰度值为國值分割图像 ...

  4. 【机器视觉学习笔记】大津法/Otsu最大类间方差法 最佳阈值处理(C++)

    目录 概念 C++源码 OtsuThreshold 主函数 效果 完整源码 平台:Windows 10 20H2 Visual Studio 2015 OpenCV 4.5.3 本文所用源码修改自C+ ...

  5. CUDA精进之路(五):图像处理——OTSU二值算法(最大类间方差法、大津法)

    引言 最近在做医疗设备相关的项目,故在项目中大量用到了各类图像分割的算法,为了在图像中分割出特定目标,用到的算法可以有很多,比如阈值分割,多通道分割,边缘分割以及一些前沿的组合分割.而对大多数图像来说 ...

  6. 图像二值化之最大类间方差法(大津法,OTSU)

    参考文章1:图像二值化与otsu算法介绍 参考文章2:python opencv cv2.threshold() (将固定级别的阈值应用于每个数组元素)ThresholdTypes 最大类间方差法(大 ...

  7. 最大类间方差法(大津法OTSU)原理

    算法介绍 最大类间方差法是1979年由日本学者大津提出的,是一种自适应阈值确定的方法,又叫大津法,简称OTSU,是一种基于全局的二值化算法,它是根据图像的灰度特性,将图像分为前景和背景两个部分.当取最 ...

  8. opencv与C++实现最大类间方差法(OTSU)进行图像二值化

    直接上代码,使用最大类间方差法进行二值化的函数 void threshold_otsu(Mat &mat, Mat &mat_thresh) //mat为输入图像,mat_thresh ...

  9. 自适应阈值分割(最大类间分割法 + OTSU)

    1.定义 最大类间方差法是由日本学者大津(Nobuyuki Otsu)于1979年提出的,是一种自适应的阈值确定的方法,又叫大津法,简称OTSU.它是按图像的灰度特性,将图像分成背景和目标两部分,或者 ...

最新文章

  1. IOS分享扩展使用JS脚本
  2. python 练习题-去重排序与字符串分割
  3. 大话目标检测经典模型(RCNN、Fast RCNN、Faster RCNN)
  4. 我是如何学习写一个操作系统(九):文件系统
  5. Django(part42)--跨站请求伪造
  6. 微信动态中的背景图更换
  7. r语言mfrow全程_R语言中的色彩_LearningR - SegmentFault 思否
  8. Linux:查看内存和CPU信息
  9. Android利用Thread或AsyncTask进行非UI操作
  10. Web3 – The Decentralized Web
  11. iOS从零开始学习socket编程——高并发多线程服务器
  12. fastlane二开java_iOS中使用Fastlane实现自动化打包和发布
  13. 微信App iOS客户端不同阶段的发展策略
  14. 安卓pdf阅读器_推荐一款手机PDF阅读器、编辑器-xodo docs安卓版
  15. 恭贺经纬恒润参股企业“挚途科技”实现L3级自动驾驶重卡商业化落地
  16. 8天掌握EF的Code First开发系列之动手写第一个Code First应用
  17. VScode中Paste Image插件无法使用
  18. mysql数据库表锁、行锁
  19. 《王者荣耀》等“爆款”游戏是如何诞生的?| 马晓轶青腾大学演讲
  20. 如何查看mac的电池损耗呢?

热门文章

  1. 在职读硕士、博士的五大优势
  2. bzoj1242: Zju1015 Fishing Net弦图判定
  3. 借钱消费/投资一时爽,会算借钱成本吗?
  4. LED灯关灯时微亮问题原因及解决办法
  5. 重庆轻工职业学院计算机考试,2016重庆轻工职业学院单招测试题(含答案解析)-20210506084723.pdf-原创力文档...
  6. Oracle调用JAVA接口
  7. php无限极,PHP实现无限极分类
  8. eclipse溢出解决
  9. Eclipse的调试技巧
  10. 分布式系统中的两阶段提交协议