特徴点を用いた、画像の比較方法について
9 ビュー (過去 30 日間)
古いコメントを表示
matlabを用いて、部品の検品を行いたいと考えております。
以下の画像のような、黒い板に穴が開いている部品を検品しようと考えております。
最終目標は、元画像と比較して、穴が開いていない部分や、多く空きすぎている部分を、赤い丸で囲って検出したいと考えております。
以下の画像には、穴が0個の板がありますが、穴が1個、2個の時にも判別したいと考えております。
円が小さいため、画像の穴を円と認識することはできませんでした。
今のところは、局所特徴の検出と抽出する関数を用いて、以下の写真のような特徴点を抽出することができました。
板の角4点がわかるため、これを組み合わせて、指定の場所に穴が開いているか否かを検出しようとしましたが、画像の大きさや写真を撮る角度が微妙に異なるためにうまく検出することができませんでした。
どのような関数を用いると、目標に近づくことができるでしょうか。
また、そもそもこの考え方より、もっと簡単な方法があればご教授いただければ幸いです。
どうかよろしくお願いします。
0 件のコメント
採用された回答
Hernia Baby
2021 年 8 月 24 日
やったことの概要
画像のサイズが違うので4隅を抽出して、サイズを合わせました。
穴が認識できないとのことだったので、画像を拡大して穴を認識してます。
コード
画像の読み込み&グレーに変換
I1 = imread('Sample1.png');
I2 = imread('Sample2.jpg');
I1_g = rgb2gray(I1);
I2_g = rgb2gray(I2);
montage({I1_g,I2_g});
4隅の抽出
corners1 = detectFASTFeatures(I1_g,'MinContrast',0.1);
corners2 = detectFASTFeatures(I2_g,'MinContrast',0.1);
edge1s = corners1(1).Location;
edge1f = corners1(end).Location - edge1s;
edge2s = corners2(1).Location;
edge2f = corners2(end).Location -edge2s;
I1_g_c = imcrop(I1_g,[edge1s edge1f]);
I2_g_c = imcrop(I2_g,[edge2s edge2f]);
抽出&画像の拡大(5倍にしてます)
numrow = max(size(I1_g_c,1),size(I2_g_c,1));
numcol = max(size(I1_g_c,2),size(I2_g_c,2));
I1_g_c = imresize(I1_g_c,[numrow numcol]*5);
I2_g_c = imresize(I2_g_c,[numrow numcol]*5);
穴の認識&空いていないほうに貼り付け
[centers, radii, metric] = imfindcircles(I1_g_c,[6 20]);
centersStrong3 = centers(1:3,:);
radiiStrong3 = radii(1:3);
metricStrong3 = metric(1:3);
穴の表示
imshow(I1_g_c)
viscircles(centersStrong3, radiiStrong3,'EdgeColor','b');
穴が開いていないものに丸を当てはめました
これでどこに穴を開ければいいかわかります
imshow(I2_g_c);
viscircles(centersStrong3, radiiStrong3,'EdgeColor','r');
4 件のコメント
その他の回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!