您好,登錄后才能下訂單哦!
這篇文章主要介紹“matlab如何實現形態學圖像處理”,在日常操作中,相信很多人在matlab如何實現形態學圖像處理問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”matlab如何實現形態學圖像處理”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
A=imread('D:\pic\DIP3E_CH04\Fig0419(a)(text_gaps_of_1_and_2_pixels).tif'); figure, imshow(A) B=[0 1 0;1 1 1;0 1 0]; A2=imdilate(A,B); figure,imshow(A2)
使用 strel 函數分解結構元素的說明
se=strel('diamond',5) decomp=getsequence(se); whos decomp(1) decomp(2) decomp(3) decomp(4)
腐蝕的說明
A=imread('D:\pic\DIP3E_CH09\Fig0905(a)(wirebond-mask).tif'); figure, imshow(A)%原圖像 se=strel('disk',10) A2=imerode(A,se) figure, imshow(A2)%半徑為10 的圓盤腐蝕后的圖像 se=strel('disk',5) A3=imerode(A,se) figure, imshow(A3)%半徑為5 的圓盤腐蝕后的圖像 A4=imerode(A,strel('disk',20)) figure, imshow(A4)%半徑為20 的圓盤腐蝕后的圖像
f=imread('D:\pic\DIP3E_CH09\Fig0905(a)(wirebond-mask).tif'); figure, imshow(f)%原圖像 se=strel('square',20); fo=imopen(f,se); figure, imshow(fo)%開運算后的圖像 fc=imclose(f,se); figure, imshow(fc)%閉運算后的圖像 foc=imclose(fo,se); figure, imshow(foc)%圖像A2 經閉運算后的圖像
使用 IPT 函數bwhitmiss
f=imread('D:\pic\DIP3E_CH09\FigP0918(left).tif') figure,imshow(f) B1=strel([0 0 0;0 1 1;0 1 0]); B2=strel([1 1 1;1 0 0;1 0 0]); g=bwhitmiss(f,B1,B2); figure,imshow(g)
%%%%%%%%%使用開運算和閉運算做形態學平滑%%%%%%%%%%%%%%%%% clear all clc f=imread('D:\pic\DIP3E_CH09\Fig0941(a)(wood_dowels).tif'); figure, imshow(f)%原圖像 se=strel('disk',5); fo=imopen(f,se); figure, imshow(fo)%開運算后的圖像 foc=imclose(fo,se); figure, imshow(foc)%圖像A2 經閉運算后的圖像 fasf=f; for k=2:5 se=strel('disk',k); fasf=imclose(imopen(fasf,se),se); end figure,imshow(fasf) %%%%%% 交替順序濾波后的圖像 %%%%%%%%%%使用頂帽變換%%%%%%%%%%%%%% clear all clc f=imread('D:\pic\DIP3E_CH09\Fig0940(a)(rice_image_with_intensity_gradient).tif'); figure, imshow(f)%原圖像 se=strel('disk',10); fo=imopen(f,se); figure, imshow(fo)%經開運算處理后的圖像 f2=imsubtract(f,fo); figure, imshow(f2) f2=imtophat(f,se); figure, imshow(f2) se=strel('disk',3); g=imsubtract(imadd(f,imtophat(f,se)),imbothat(f,se));%低帽、頂帽 figure, imshow(g) %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% %%%%%%%%%%%顆粒分析%%%%%%%%%%%%%% clear all clc f=imread('D:\pic\DIP3E_CH09\Fig0940(a)(rice_image_with_intensity_gradient).tif'); sumpixels=zeros(1,36); for k=0:35 se=strel('disk',k); fo=imopen(f,se); sumpixels(k+1)=sum(fo(:)); end figure,plot(0:35,sumpixels); xlabel('k'); ylabel('surface area') figure, plot(-diff(sumpixels)) xlabel('k'); ylabel('surface area reduction') %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%灰度圖像形態學使用重構刪除復雜圖像的背景 clear all clc f=imread('D:\pic\DIP3E_CH09\Fig0944(a)(calculator).tif'); figure, imshow(f)%原圖像 f_obr=imreconstruct(imerode(f,ones(1,71)),f); figure, imshow(f_obr) f_o=imopen(f,ones(1,71));%for comparison figure, imshow(f_o) f_thr=imsubtract(f,f_obr); figure, imshow(f_thr) f_th=imsubtract(f,f_o);%or imtophat(f,ones(1,71)) figure, imshow(f_th) g_obr=imreconstruct(imerode(f_thr,ones(1,11)),f_thr); figure, imshow(g_obr) g_obrd=imdilate(g_obr,ones(1,21)); figure, imshow(g_obrd) f2=imreconstruct(min(g_obrd,f_thr),f_thr); figure, imshow(f2)
到此,關于“matlab如何實現形態學圖像處理”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。