使用直方图统计量增强图像

全局均值和方差
μn=∑i=0L−1(ri−m)np(ri)(3.24)\mu_{n} = \sum_{i=0}^{L-1} (r_{i} - m)^{n} p(r_{i}) \tag{3.24}μn=i=0L1(rim)np(ri)(3.24)
m=∑i=0L−1rip(ri)(3.25)m = \sum_{i=0}^{L-1} r_{i} p(r_{i}) \tag{3.25}m=i=0L1rip(ri)(3.25)
σ2=μ2=∑i=0L−1(ri−m)2p(ri)(3.26)\sigma^{2} = \mu_{2} = \sum_{i=0}^{L-1} (r_{i} - m)^{2} p(r_{i}) \tag{3.26}σ2=μ2=i=0L1(rim)2p(ri)(3.26)

邻域均值和方差
SxyS_{xy}Sxy是以(x,y)(x, y)(x,y)为中心的一个规定大小的邻域
mSxy=∑i=0L−1riPSxy(ri)(3.27)m_{S_{xy}} = \sum_{i=0}^{L-1}r_{i} P_{S_{xy}}(r_{i}) \tag{3.27}mSxy=i=0L1riPSxy(ri)(3.27)
σSxy2=∑i=0L−1(ri−mSxy)2PSxy(ri)(3.28)\sigma_{S_{xy}}^2 = \sum_{i=0}^{L-1} (r_{i} - m_{S_{xy}})^2 P_{S_{xy}}(r_{i}) \tag{3.28}σSxy2=i=0L1(rimSxy)2PSxy(ri)(3.28)

g(x,y)={Cf(x,y),k0mG≤mSxy≤k1mGANDk2σG≤σSxy≤k3σGf(x,y),others(3.29)g(x, y) =\begin{cases} Cf(x,y), & k_0 m_G \leq m_{S_{xy}} \leq k_1 m_G \;\text{AND}\; k_2 \sigma_G \leq \sigma_{S_{xy}} \leq k_3 \sigma_G \\ f(x,y), & \text{others}\end{cases} \tag{3.29}g(x,y)={Cf(x,y),f(x,y),k0mGmSxyk1mGANDk2σGσSxyk3σGothers(3.29)

k0,k1,k2,k3,Ck_0, k_1, k_2, k_3, Ck0,k1,k2,k3,C选择的一些方法:
如果 我们的关注点是比平均灰度的1/4更暗的区域,那么选择k0=0,k1=0.25k_0=0, k_1=0.25k0=0,k1=0.25。如果我们的兴趣是增强那么对比度比较低的区域,则k2=0,k3=0.1k_2=0, k_3=0.1k2=0,k3=0.1
满足条件的乘以一个规定常数CCC,增大(或减小)其相对于图像剩下部分的灰度。

下图像中mG=161,σG=103m_G = 161, \sigma_G = 103mG=161,σG=103,图像和待增强区域的最大灰度值分别是是228和10,最小值是为。我们希望增强后的特征的最大值与图像的最大值相同,因此选择C=22.8C=22.8C=22.8

def histogram_statistic(img_ori, grid_size = (3, 3), k0 = 0., k1 = 0.1, k2 = 0., k3 = 0.1, C = 22.8):"""Histogram statistic enhance local imageparam: input img_ori: uint8[0, 255] grayscal imageparam: grid size : size of the sliding window, default is [3, 3]"""m_G = np.round(np.mean(img_ori)).astype(int)sigma_G = np.round(np.std(img_ori)).astype(int)
#     max_img = img_ori.max()
#     min_img = img_ori.min()
#     img_roi = img_ori[12:120, 12:120]
#     max_roi = img_roi.max()
#     print(f'Global mean -> {m_G}, Global sigma -> {sigma_G}, Max -> {max_img}, Min -> {min_img}, ROI Max -> {max_roi}')img_dst = img_ori.copy()height, width = img_ori.shapem = grid_size[0]n = grid_size[1]for h in range(height):for w in range(width):temp = img_ori[h:h+m, w:w+n]temp_mean = np.round(np.mean(temp)).astype(int)temp_sigma = np.round(np.std(temp)).astype(int)if k0 * m_G <= temp_mean <= k1 * m_G and k2 * sigma_G <= temp_sigma <= k3 * sigma_G:temp = (C * temp)img_dst[h:h+m, w:w+n] = tempreturn img_dst
# 使用直方图统计增强局部图像
img_ori = cv2.imread('DIP_Figures/DIP3E_Original_Images_CH03/Fig0326(a)(embedded_square_noisy_512).tif', 0)
m_G = np.round(np.mean(img_ori)).astype(int)
sigma_G = np.round(np.std(img_ori)).astype(int)
max_img = img_ori.max()
min_img = img_ori.min()
img_roi = img_ori[12:120, 12:120]
max_roi = img_roi.max()
print(f'Global mean -> {m_G}, Global sigma -> {sigma_G}, Max -> {max_img}, Min -> {min_img}, ROI Max -> {max_roi}')# ROI 区域的最小值是11, 228/11=20.72,即20.8,实现看起来效果也不错
img_dst = histogram_statistic(img_ori, C=20.8)plt.figure(figsize=(15, 6))
plt.subplot(1, 3, 1), plt.imshow(img_ori, cmap='gray', vmin=0, vmax=255), plt.title('Original')
plt.subplot(1, 3, 2), plt.imshow(img_dst, cmap='gray', vmin=0, vmax=255), plt.title(f'Histogram statistic')
plt.tight_layout()
plt.show()
Global mean -> 161, Global sigma -> 103, Max -> 228, Min -> 0, ROI Max -> 11

第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波11 - 直方图处理 - 使用直方图统计量增强图像相关推荐

  1. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波1 - 灰度变换和空间滤波基础、Sigmoid激活函数

    这里写目录标题 本节的目标 背景 灰度变换和空间滤波基础 本节的目标 了解空间域图像处理的意义,以及它与变换域图像处理的区别 熟悉灰度变换所有的主要技术 了解直方图的意义以及如何操作直方图来增强图像 ...

  2. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波8 - 直方图处理 - 直方图均衡化(全局直方图均衡化)

    直方图均衡化 灰度映射函数: s=T(r),0≤r≤L−1(3.8)s = T(r), \quad 0\leq r \leq L -1 \tag{3.8}s=T(r),0≤r≤L−1(3.8) 假设: ...

  3. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波18 - 低通、高通、带阻和带通滤波器、组合使用空间增强方法

    低通.高通.带阻和带通滤波器 得到空间滤波器的第三种方法,生成一维滤波器函数,然后要么使用式(3.42)w=vvTw = vv^Tw=vvT生成二维可分离的滤波器函数,要么旋转这些一维函数来生成二维核 ...

  4. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波17 - 锐化高通滤波器 - 梯度图像(罗伯特,Sobel算子)

    目录 锐化(高通)空间滤波器 使用一阶导数锐化图像-梯度 锐化(高通)空间滤波器 平滑通过称为低通滤波 类似于积分运算 锐化通常称为高通滤波 微分运算 高过(负责细节的)高频,衰减或抑制低频 使用一阶 ...

  5. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波15 - 锐化高通滤波器 -拉普拉斯核(二阶导数)

    目录 锐化(高通)空间滤波器 基础 - 一阶导数和二阶导数的锐化滤波器 二阶导数锐化图像--拉普拉斯 锐化(高通)空间滤波器 平滑通过称为低通滤波 类似于积分运算 锐化通常称为高通滤波 微分运算 高过 ...

  6. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波16 - 锐化高通滤波器 - 钝化掩蔽和高提升滤波

    目录 锐化(高通)空间滤波器 钝化掩蔽和高提升滤波 锐化(高通)空间滤波器 平滑通过称为低通滤波 类似于积分运算 锐化通常称为高通滤波 微分运算 高过(负责细节的)高频,衰减或抑制低频 钝化掩蔽和高提 ...

  7. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波13 - 平滑低通滤波器 -盒式滤波器核

    这里写目录标题 平滑(低通)空间滤波器 盒式滤波器核 平滑(低通)空间滤波器 平滑(也称平均)空间滤波器用于降低灰度的急剧过渡 在图像重取样之前平滑图像以减少混淆 用于减少图像中无关细节 平滑因灰度级 ...

  8. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波10 - 直方图处理 - 局部直方图处理

    这里写目录标题 局部直方图处理 局部直方图处理 因为像素是由基于整个图像的灰度的变换函数修改的.这种全局性方法适合于整体增强,但当目的是增强图像中几个小区域的细节时,通常就会失败.这是因为在这些小区域 ...

  9. 第3章 Python 数字图像处理(DIP) - 灰度变换与空间滤波9 - 直方图处理 - 直方图匹配(规定化)灰度图像,彩色图像都适用

    直方图匹配(规定化) 连续灰度 s=T(r)=(L−1)∫0rpr(w)dw(3.17)s = T(r) = (L-1) \int_{0}^{r} p_r(w) \text{d} w \tag{3.1 ...

最新文章

  1. python 应声虫怎么做_职场人士如何处理好人际关系:要服从,但不要做毫无主见的应声虫...
  2. Git-remote Incorrect username or password ( access token )
  3. Git和Github的区别与操作简介
  4. SQL查询语句基础构成
  5. javaserver_什么是JavaServer Faces(JSF)
  6. SpringBoot 集成 MyBatisPlus 模板
  7. CentOS6.4x64_安装Qt5
  8. Laravel使用EasyWechat 进行微信支付
  9. C语言实现电子音乐相册---粤嵌GEC6818嵌入式系统实训
  10. ERP库存管理 华夏
  11. 计算机视觉教程3-1:全面详解图像边缘检测算法(附Python实战)
  12. java音频剪辑_Java混剪音频
  13. 分散染料对涤纶织物染色步骤
  14. java与英语词汇_Java英语词汇表
  15. iphone mac平台下破解微信的语音
  16. 怎样使用计算机的桌面助手,360安全卫士如何整理电脑桌面?360桌面助手使用说明...
  17. 百度AI人脸识别的学习总结
  18. 使用谷歌高级搜索需要_什么是Google高级保护?谁应该使用它?
  19. mysql 常见面试题
  20. 速达服务器套账维护,速达软件日常数据维护方法汇总107

热门文章

  1. 前端换行显示,后端返回br
  2. python---线程与进程
  3. 【K8S学习笔记】Part1:使用端口转发访问集群内的应用
  4. Springboot分模块开发详解(2):建立子工程
  5. HTTP响应报文与工作原理详解
  6. Codeforces 258B Little Elephant and Elections
  7. Windows Shell 编程 第六章 【来源:http://blog.csdn.net/wangqiulin123456/article/details/7987951】...
  8. 算法 --- 快慢指针判断链表是否有环
  9. 201671010117 2016-2017-2 《Java程序设计》Java第十七周学习心得
  10. 【转载】ASP.NET应用程序与页面生命周期