Matlab成長之路_3(將1維向量顯示成直方圖)


 

  前言

  有時候在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);

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM