前言
有時候在c/c++中得到了某一張圖片的直方圖,比如說在OpenCV中,計算出圖像的直方圖后一般是保存在Mat里面,其實通過數據查看,這個Mat就是一個列向量,即一個vector,本來也可以使用c/c++的方法來畫圖的,只是那樣有各種需要標注啊,箭頭啊,顏色啊等都不方便,特別是如果要寫paper的話,一般都不會選擇使用c/c++來畫,很多人都選擇在matlab中畫圖,首先是將c/c++中的數據以某種形式導出來,然后再使用matlab。本文中就是將OpenCV中的直方圖結果保存為圖片導出來,然后對這張圖片使用Matlab函數畫出它的直方圖分布。
開發環境:matlab2012a
實驗基礎
本實驗繪制直方圖是采用的plot函數,設定好x和y的值后,就可以直接使用了。最后用set函數來設置圖像的屬性,比如說顏色,粗細等。用xlabel和ylabel函數來設置坐標名稱。
實驗結果
原始圖像是一個列向量,但是由於在OpenCV中是以圖片的形式保存的,分別是某張圖的Cr和Cb通道直方圖,所以它們分別顯示如下(截的一部分,畢竟只有一列):
,
繪制后的直方圖如下所示:
Cr_hist:
Cb_hist:
實驗代碼:
% cr_image = double(imread('cr.tif')); cr_image = imread('cr.tif'); sum_val = sum(cr_image); cr_image = double(cr_image)/sum_val; x = 100:1:200; y = cr_image(x,1); crp = plot(x,y); xlabel('Cr Value');ylabel('Probability'); set(crp, 'Color', 'red','LineWidth',2); figure cr_image = imread('cb.tif'); sum_val = sum(cr_image); cr_image = double(cr_image)/sum_val; x = 80:1:180; y = cr_image(x,1); cbp = plot(x,y); xlabel('Cb Value');ylabel('Probability'); set(cbp, 'Color', 'blue','LineWidth',2);