第3章 Python 數字圖像處理(DIP) - 灰度變換與空間濾波7 - 直方圖處理 - 直方圖、歸一化直方圖

目錄

  • 直方圖處理

直方圖處理

rk,k=0,1,2,…,L?1r_k, k=0, 1, 2, \dots, L-1rk?,k=0,1,2,,L?1表于一幅LLL級灰度數字圖像f(x,y)f(x,y)f(x,y)的灰度。fff的非歸一化直方圖定義為:

h(rk)=nk,k=0,1,2,…,L?1(3.6)h(r_{k}) = n_{k}, \quad k = 0, 1, 2, \dots, L-1 \tag{3.6}h(rk?)=nk?,k=0,1,2,,L?1(3.6)

nk是fn_{k}是fnk?f中灰度為rkr_{k}rk?的像素的數量,并且細分的灰度級稱為直方圖容器。

歸一化直方圖

p(rk)=h(rk)MN=nkMN(3.7)p(r_{k}) = \frac{h(r_{k})}{MN} = \frac{n_{k}}{MN} \tag{3.7} p(rk?)=MNh(rk?)?=MNnk??(3.7)

def my_hist(img, bins=256, normalized=False):"""create a hist of uint8 image value range[0, 255]param: input img: grayscale image range[0, 255]param: input bins: bins for the image, range[0, 255]return hist and bins for the image, hist -> counts for all the values"""# initializ a list for values and countslist1 = list([x, y] for x in np.arange(bins) for y in np.arange(bins) if y == 0)data = img.flatten()for i in range(img.size):list1[data[i]][1] += 1  dst = np.array(list1)bins, hist= dst[:, 0], dst[:, 1]if normalized:hist = hist / img.size  #nomalized histreturn hist, bins
# 直方圖
img_1st = cv2.imread('DIP_Figures/DIP3E_Original_Images_CH03/Fig0316(1)(top_left).tif', 0)
img_2nd = cv2.imread('DIP_Figures/DIP3E_Original_Images_CH03/Fig0316(2)(2nd_from_top).tif', 0)
img_3rd = cv2.imread('DIP_Figures/DIP3E_Original_Images_CH03/Fig0316(3)(third_from_top).tif', 0)
img_4th = cv2.imread('DIP_Figures/DIP3E_Original_Images_CH03/Fig0316(4)(bottom_left).tif', 0)img_list =['img_1st', 'img_2nd', 'img_3rd', 'img_4th']fig = plt.figure(figsize=(20, 15))
for i in range(len(img_list)):ax = fig.add_subplot(3, 4, i+1)ax.imshow(eval(img_list[i]), cmap='gray', vmin=0, vmax=255)ax1 = fig.add_subplot(3, 4, i+5)hist, bins = my_hist(eval(img_list[i]), bins=256)ax1.bar(bins, hist), ax1.set_title('My Hist')ax2 = fig.add_subplot(3, 4, i+9)hist, bins = np.histogram(eval(img_list[i]), bins=256, range=[0, 256])ax2.bar(bins[:-1], hist), ax2.set_title('Numpy Hist')  # numpy 的返回bins 比hist多一點數,需要去掉最后一個
#     ax2.hist(eval(img_list[i]).flatten(), bins=256, range=[0, 255]), ax2.set_title('Matplotlib Hist')
plt.tight_layout()
plt.show()

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/260818.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/260818.shtml
英文地址,請注明出處:http://en.pswp.cn/news/260818.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Xamarin Android提示找不到資源屬性定義

為什么80%的碼農都做不了架構師?>>> Xamarin Android提示找不到資源屬性定義 錯誤信息:”Resource.Attribute”未包含”actonBarSize”的定義 Xamarin Android經常會出現找不到資源屬性的錯誤。遇到這種問題,建議先清理解決方法和…

Google Chrome保存插件方法

1、拷貝下面地址到記事本 https://clients2.google.com/service/update2/crx?responseredirect&xid%3D~~~~%26uc 2、打開插件所在的頁面,拷貝插件地址到記事本 如:https://chrome.google.com/webstore/detail/axure-rp-extension-for-ch/dogkpdfckl…

java web項目_[適合初中級Java程序員修煉手冊從0搭建整個Web項目](二)

前言文本已收錄至我的GitHub倉庫,歡迎Star:https://github.com/bin392328206種一棵樹最好的時間是十年前,其次是現在six-finger-web一個Web后端框架的輪子從處理Http請求【基于Netty的請求級Web服務器】 到mvc【接口封裝轉發)】,再…

MapReduce操作HBase

運行HBase時常會遇到個錯誤,我就有這樣的經歷。 ERROR: org.apache.hadoop.hbase.MasterNotRunningException: Retried 7 times 檢查日志:org.apache.hadoop.ipc.RPC$VersionMismatch: Protocol org.apache.hadoop.hdfs.protocol.ClientProtocol versio…

轉 ABAP_ALV_Function方式與OO方式(較為簡單、普通的ALV)

ABAP_ALV_Function方式與OO方式(較為簡單、普通的ALV) 分類: SAP ABAP2013-01-31 09:58 1511人閱讀 評論(0) 收藏 舉報目錄 一、ALV簡介 1、簡介 2、ALV_GRID介紹 3、其它描述 二、開發ALV的基本流程 三、ALV相關開發細節 1、標準ALV與對象ALV的共同開發細節 2、標準…

MAC OS X 1.1 El Capitan安裝方法與步驟

2019獨角獸企業重金招聘Python工程師標準>>> 蘋果公司發布了最新的Mac系統El Capitan,我也跟風安裝了, 昨天試了一天終于算是安裝成功了. ###電腦配置: CPU: E3-1230 v2 主板: 技嘉B75M D3V 顯卡: 微星6850 聲卡: Realtek ALC887 鍵盤: Noppoo 84鍵機械鍵盤 ###下載…

vp與vs聯合開發-網口通信(socket)

Socket通信是一種在網絡中進行進程間通信的機制。它使用了一種稱為套接字(Socket)的編程接口,通過該接口可以創建、連接、發送和接收數據等操作。 Socket通信中,有兩個主要的角色:服務器和客戶端。服務器負責監聽指定…

第3章 Python 數字圖像處理(DIP) - 灰度變換與空間濾波8 - 直方圖處理 - 直方圖均衡化(全局直方圖均衡化)

直方圖均衡化 灰度映射函數: sT(r),0≤r≤L?1(3.8)s T(r), \quad 0\leq r \leq L -1 \tag{3.8}sT(r),0≤r≤L?1(3.8) 假設: (1) T(r)T(r)T(r)在區間0≤r≤L?10 \leq{r} \leq{L-1}0≤r≤L?1 上是一個單調遞增函數。 (2) 對于0≤r≤L?10 \leq{r} …

python 元組和列表區別_Python干貨整理:一分鐘了解元組與列表使用與區別

元組是 Python 對象的集合,跟列表十分相似。下面進行簡單的對比。列表與元組1、python中的列表list是變量,而元組tuple是常量。列表:是使用方括號[],元組:則是使用圓括號()2、兩者都可以使用索引讀取值列表1.列表中的a…

JS拖拽,移動與拉伸

上次做的簡單的拖拽:javascript簡單拖拽練習(鼠標事件 mousedown mousemove mouseup) 這次增加了一些相關的功能,增加四個角的拉伸改變寬度,主要還是用到一些簡單的坐標位置計算,沒有什么技術難度,熟練了一下自己對拖拽…

關于release后retainCount還是1的問題

轉自:http://www.cocoachina.com/bbs/read.php?tid175523 realse之后再調用還能調用的的問題,我做了這么多年也是經常遇到,也曾經試圖尋找原因, 就像6樓說的,很多時候都會出現realse過后還能調用的現象。而且對象不是…

Maven for Eclipse 第二章 ——安裝 m2eclipse插件

m2eclipse 是一個提供了 Maven 與 Eclipse 整合的插件。它的意圖是橋接上 Maven 和 Eclipse 之間的缺口。通過 Maven 原型提供的簡單直白的接口創建項目,它使 Maven 在 IDE 中非常容易使用。下面是m2eclipse 提供的一些特性。 創建和導入 Maven 項目在 Eclipse 運行…

第3章 Python 數字圖像處理(DIP) - 灰度變換與空間濾波9 - 直方圖處理 - 直方圖匹配(規定化)灰度圖像,彩色圖像都適用

直方圖匹配(規定化) 連續灰度 sT(r)(L?1)∫0rpr(w)dw(3.17)s T(r) (L-1) \int_{0}^{r} p_r(w) \text{d} w \tag{3.17} sT(r)(L?1)∫0r?pr?(w)dw(3.17) 定義關于變量zzz的一個函數GGG,它具有如下性質: G(z)(L?1)∫0zpz(v)d…

C#委托之就是跟委托過不去…

在上一篇博文當中,我們例舉了一個機房自動化系統的邏輯控制程序,其中用到了Lambda表達式,因此方便了我們程序功能的實現.然而,我們不能僅僅為實現功能,完成任務而奮斗,應該知其然,知其所以然,也就是說,知道了Lambda表達式能夠帶來這樣的方便,也應該知道為什么能夠帶來這樣的方便…

closewait一直不釋放_機床為什么要釋放應力?怎么釋放應力才好?

在機床行業內一直有種說法,就是機床需要釋放應力,而且越是高精密的機床就越要注意應力的釋放,最近就有機床粉向小編詢問應力是什么?為什么要釋放應力?如果釋放要釋放多久?怎么釋放應力才好等一系列關于機床…

HDU 1025 Constructing Roads In JGShining's Kingdom(DP+二分)

點我看題目 題意 :兩條平行線上分別有兩種城市的生存,一條線上是貧窮城市,他們每一座城市都剛好只缺乏一種物資,而另一條線上是富有城市,他們每一座城市剛好只富有一種物資,所以要從富有城市出口到貧窮城市…

表單元素選擇器

無論是提交還是傳遞數據,表單元素在動態交互頁面的作用是非常重要的。jQuery中專門加入了表單選擇器,從而能夠極其方便地獲取到某個類型的表單元素 表單選擇器的具體方法描述: 注意事項: 除了input篩選選擇器,幾乎每個…

怎樣在excel表格中畫斜線并打字_一日一技丨Excel斜線表頭如何制作?標題、表頭的4個技巧...

來源 | 迅捷PDF轉換器 (ID:xjpdf6)作者丨小小迅「一日一技」是每天的知識分享專欄,一是分享一些PDF、Office、辦公小技巧;二是抽取小可愛們在留言中的疑問并解決。希望對大家有所幫助!表頭的標題是Excel中的第一道大門,精致好看的…

Retina時代的前端視覺優化

隨著New iPad的發布,平板也將逐漸進入Retina時代,在高分辨率設備里圖片的顯示效果通常不盡人意,為了達到最佳的顯示效果就需要對圖片進行優化,這里介紹一些優化方法: 一、用CSS替代圖片 這一點在任何時候都適用&#x…

第3章 Python 數字圖像處理(DIP) - 灰度變換與空間濾波10 - 直方圖處理 - 局部直方圖處理

這里寫目錄標題局部直方圖處理局部直方圖處理 因為像素是由基于整個圖像的灰度的變換函數修改的。這種全局性方法適合于整體增強,但當目的是增強圖像中幾個小區域的細節時,通常就會失敗。這是因為在這些小區域中,像素的數量對計算全局變換的…