【OpenCV 例程200篇】46. 直方图均衡化
【OpenCV 例程200篇】46. 直方圖均衡化
歡迎關注 『OpenCV 例程200篇』 系列,持續更新中
歡迎關注 『Python小白的OpenCV學習課』 系列,持續更新中
圖像直方圖是反映圖像像素分布的統計表,橫坐標代表像素值的取值區間,縱坐標代表每一像素值在圖像中的像素總數或者所占的百分比。 灰度直方圖是圖像灰度級的函數,用來描述每個灰度級在圖像矩陣中的像素個數。
直方圖均衡化是一種簡單有效的圖像增強技術。根據直方圖的形態可以判斷圖像的質量,通過調控直方圖的形態可以改善圖像的質量。
直方圖均衡化是將原始圖像通過函數變換,調控圖像的灰度分布,得到直方圖分布合理的新圖像,以此來調節圖像亮度、增強動態范圍偏小的圖像的對比度。
由于人眼視覺特性,直方圖均勻分布的圖像視覺效果較好。直方圖均衡化的基本思想是對圖像中占比大的灰度級進行展寬,而對占比小的灰度級進行壓縮,使圖像的直方圖分布較為均勻,擴大灰度值差別的動態范圍,從而增強圖像整體的對比度。
因此,直方圖均衡化就是對圖像進行非線性拉伸,重新分配圖像像素值,本質上是根據直方圖對圖像進行線性或非線性灰度變換。
例如,直方圖均衡化可以把原始圖像的直方圖調整到均勻分布,增加像素之間灰度值差別的動態范圍,從而增強圖像整體的對比度。
通過累積分布函數(cumulative distribution function, CDF)可以實現將原圖像 r 的分布轉換成 s 的均勻分布,累計分布函數(CDF)就是是概率密度函數(probability density function, PDF)的積分。
若 pr(r)p_r(r)pr?(r) 和 $p_s(s) $表示原圖像 r 和新圖像 s 的概率密度函數,則:
s=T(r)=(L?1)∫0rpr(r)drs=T(r)= (L-1) \int _0 ^r p_r(r) dr s=T(r)=(L?1)∫0r?pr?(r)dr
其離散形式為:
sk=T(rk)=(L?1)∑j=0kpr(rj)=(L?1)∑j=0knjNs_k = T(r_k) = (L-1) \sum_{j=0}^k p_r(r_j) = (L-1) \sum_{j=0}^k \frac{n_j}{N} sk?=T(rk?)=(L?1)j=0∑k?pr?(rj?)=(L?1)j=0∑k?Nnj??
于是,可以通過原圖像的直方圖直接求出均衡化后各像素的灰度級 sks_ksk?,得到實現直方圖均衡的轉換函數:
(1)計算原始灰度圖像的直方圖;
(2)通過直方圖累加計算原始圖像的累計分布函數 CDF;
(3)基于累計分布函數 CDF,通過插值計算得到新的灰度值。
OpenCV 提供了函數 cv2. equalizeHist 可以實現直方圖均衡化。
函數說明:
cv2.qualizeHist(src[, dst]) → dst參數說明:
- src:輸入圖像
- 返回值 dst:輸出圖像,直方圖均衡化
例程:1.58 直方圖均衡
# 1.58 直方圖均衡img = cv2.imread("../images/Fig0310b.tif", flags=0) # flags=0 讀取為灰度圖像imgEqu = cv2.equalizeHist(img) # 使用 cv2.qualizeHist 完成直方圖均衡化變換# histogram equalization image# histImg, bins = np.histogram(img.flatten(), 256) # 計算原始圖像直方圖# cdf = histImg.cumsum() # 計算累積分布函數 CDF# cdf = cdf * 255 / cdf[-1] # 累計函數 CDF 歸一化: [0,1]->[0,255]# imgEqu = np.interp(img.flatten(), bins[:256], cdf) # 線性插值,計算新的灰度值# imgEqu = imgEqu.reshape(img.shape) # 將壓平的圖像數組重新變成二維數組fig = plt.figure(figsize=(7,7))plt.subplot(221), plt.title("Original image (youcans)"), plt.axis('off')plt.imshow(img, cmap='gray', vmin=0, vmax=255) # 原始圖像plt.subplot(222),plt.title("Hist-equalized image"), plt.axis('off')plt.imshow(imgEqu, cmap='gray', vmin=0, vmax=255) # 轉換圖像histImg, bins = np.histogram(img.flatten(), 256) # 計算原始圖像直方圖plt.subplot(223, yticks=[]), plt.bar(bins[:-1], histImg) # 原始圖像直方圖plt.title("Histogram of original image"), plt.axis([0,255,0,np.max(histImg)])histEqu, bins = np.histogram(imgEqu.flatten(), 256) # 計算原始圖像直方圖plt.subplot(224, yticks=[]), plt.bar(bins[:-1], histEqu) # 轉換圖像直方圖plt.title("Histogram of equalized image"), plt.axis([0,255,0,np.max(histImg)])plt.show()(本節完)
版權聲明:
youcans@xupt 原創作品,轉載必須標注原文鏈接
Copyright 2021 youcans, XUPT
Crated:2021-11-22
歡迎關注 『OpenCV 例程200篇』 系列,持續更新中
歡迎關注 『Python小白的OpenCV學習課』 系列,持續更新中
【OpenCV 例程200篇】01. 圖像的讀取(cv2.imread)
【OpenCV 例程200篇】02. 圖像的保存(cv2.imwrite)
【OpenCV 例程200篇】03. 圖像的顯示(cv2.imshow)
【OpenCV 例程200篇】04. 用 matplotlib 顯示圖像(plt.imshow)
【OpenCV 例程200篇】05. 圖像的屬性(np.shape)
【OpenCV 例程200篇】06. 像素的編輯(img.itemset)
【OpenCV 例程200篇】07. 圖像的創建(np.zeros)
【OpenCV 例程200篇】08. 圖像的復制(np.copy)
【OpenCV 例程200篇】09. 圖像的裁剪(cv2.selectROI)
【OpenCV 例程200篇】10. 圖像的拼接(np.hstack)
【OpenCV 例程200篇】11. 圖像通道的拆分(cv2.split)
【OpenCV 例程200篇】12. 圖像通道的合并(cv2.merge)
【OpenCV 例程200篇】13. 圖像的加法運算(cv2.add)
【OpenCV 例程200篇】14. 圖像與標量相加(cv2.add)
【OpenCV 例程200篇】15. 圖像的加權加法(cv2.addWeight)
【OpenCV 例程200篇】16. 不同尺寸的圖像加法
【OpenCV 例程200篇】17. 兩張圖像的漸變切換
【OpenCV 例程200篇】18. 圖像的掩模加法
【OpenCV 例程200篇】19. 圖像的圓形遮罩
【OpenCV 例程200篇】20. 圖像的按位運算
【OpenCV 例程200篇】21. 圖像的疊加
【OpenCV 例程200篇】22. 圖像添加非中文文字
【OpenCV 例程200篇】23. 圖像添加中文文字
【OpenCV 例程200篇】23. 圖像添加中文文字
【OpenCV 例程200篇】24. 圖像的仿射變換
【OpenCV 例程200篇】25. 圖像的平移
【OpenCV 例程200篇】26. 圖像的旋轉(以原點為中心)
【OpenCV 例程200篇】27. 圖像的旋轉(以任意點為中心)
【OpenCV 例程200篇】28. 圖像的旋轉(直角旋轉)
【OpenCV 例程200篇】29. 圖像的翻轉(cv2.flip)
【OpenCV 例程200篇】30. 圖像的縮放(cv2.resize)
【OpenCV 例程200篇】31. 圖像金字塔(cv2.pyrDown)
【OpenCV 例程200篇】32. 圖像的扭變(錯切)
【OpenCV 例程200篇】33. 圖像的復合變換
【OpenCV 例程200篇】34. 圖像的投影變換
【OpenCV 例程200篇】35. 圖像的投影變換(邊界填充)
【OpenCV 例程200篇】36. 直角坐標與極坐標的轉換
【OpenCV 例程200篇】37. 圖像的灰度化處理和二值化處理
【OpenCV 例程200篇】38. 圖像的反色變換(圖像反轉)
【OpenCV 例程200篇】39. 圖像灰度的線性變換
【OpenCV 例程200篇】40. 圖像分段線性灰度變換
【OpenCV 例程200篇】41. 圖像的灰度變換(灰度級分層)
【OpenCV 例程200篇】42. 圖像的灰度變換(比特平面分層)
【OpenCV 例程200篇】43. 圖像的灰度變換(對數變換)
【OpenCV 例程200篇】44. 圖像的灰度變換(伽馬變換)
【OpenCV 例程200篇】45. 圖像的灰度直方圖
【OpenCV 例程200篇】46. 直方圖均衡化
【OpenCV 例程200篇】47. 圖像增強—直方圖匹配
【OpenCV 例程200篇】48. 圖像增強—彩色直方圖匹配
【OpenCV 例程200篇】49. 圖像增強—局部直方圖處理
【OpenCV 例程200篇】50. 圖像增強—直方圖統計量圖像增強
【OpenCV 例程200篇】51. 圖像增強—直方圖反向追蹤
【OpenCV 例程200篇】52. 圖像的相關與卷積運算
【OpenCV 例程200篇】53. Scipy 實現圖像二維卷積
【OpenCV 例程200篇】54. OpenCV 實現圖像二維卷積
【OpenCV 例程200篇】55. 可分離卷積核
【OpenCV 例程200篇】56. 低通盒式濾波器
【OpenCV 例程200篇】57. 低通高斯濾波器
【OpenCV 例程200篇】58. 非線性濾波—中值濾波
【OpenCV 例程200篇】59. 非線性濾波—雙邊濾波
【OpenCV 例程200篇】60. 非線性濾波—聯合雙邊濾波
【OpenCV 例程200篇】61. 導向濾波(Guided filter)
【OpenCV 例程200篇】62. 圖像銳化——鈍化掩蔽
【OpenCV 例程200篇】63. 圖像銳化——Laplacian 算子
【OpenCV 例程200篇】64. 圖像銳化——Sobel 算子
【OpenCV 例程200篇】65. 圖像銳化——Scharr 算子
【OpenCV 例程200篇】66. 圖像濾波之低通/高通/帶阻/帶通
【OpenCV 例程200篇】67. 空間域圖像增強的綜合應用
【OpenCV 例程200篇】68. 空間域圖像增強的綜合應用
【OpenCV 例程200篇】69. 連續非周期信號的傅立葉系數
【OpenCV 例程200篇】70. 一維連續函數的傅里葉變換
【OpenCV 例程200篇】71. 連續函數的取樣
【OpenCV 例程200篇】72. 一維離散傅里葉變換
【OpenCV 例程200篇】73. 二維連續傅里葉變換
【OpenCV 例程200篇】74. 圖像的抗混疊
【OpenCV 例程200篇】75. Numpy 實現圖像傅里葉變換
【OpenCV 例程200篇】76. OpenCV 實現圖像傅里葉變換
【OpenCV 例程200篇】77. OpenCV 實現快速傅里葉變換
【OpenCV 例程200篇】78. 頻率域圖像濾波基礎
【OpenCV 例程200篇】79. 頻率域圖像濾波的基本步驟
【OpenCV 例程200篇】80. 頻率域圖像濾波詳細步驟
【OpenCV 例程200篇】81. 頻率域高斯低通濾波器
【OpenCV 例程200篇】82. 頻率域巴特沃斯低通濾波器
【OpenCV 例程200篇】83. 頻率域低通濾波:印刷文本字符修復
【OpenCV 例程200篇】84. 由低通濾波器得到高通濾波器
【OpenCV 例程200篇】85. 頻率域高通濾波器的應用
【OpenCV 例程200篇】86. 頻率域濾波應用:指紋圖像處理
【OpenCV 例程200篇】87. 頻率域鈍化掩蔽
【OpenCV 例程200篇】88. 頻率域拉普拉斯高通濾波
【OpenCV 例程200篇】89. 帶阻濾波器的傳遞函數
【OpenCV 例程200篇】90. 頻率域陷波濾波器
【OpenCV 例程200篇】91. 高斯噪聲、瑞利噪聲、愛爾蘭噪聲
【OpenCV 例程200篇】92. 指數噪聲、均勻噪聲、椒鹽噪聲
【OpenCV 例程200篇】93. 噪聲模型的直方圖
【OpenCV 例程200篇】94. 算術平均濾波器
【OpenCV 例程200篇】95. 幾何均值濾波器
【OpenCV 例程200篇】96. 諧波平均濾波器
【OpenCV 例程200篇】97. 反諧波平均濾波器
【OpenCV 例程200篇】98. 統計排序濾波器
【OpenCV 例程200篇】99. 修正阿爾法均值濾波器
【OpenCV 例程200篇】100. 自適應局部降噪濾波器
總結
以上是生活随笔為你收集整理的【OpenCV 例程200篇】46. 直方图均衡化的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【OpenCV 例程200篇】66. 图
- 下一篇: html5程序自动登录,Jtro的技术分