Edge detection using sobel operator
古いコメントを表示
Can anyone point out what's causing the error in the code below?
Below is the code for detecting edge using sobel operator.
Thank you for your time and effort in advance.

function output = edgy(a)
a = double(a);
[row col] = size(a);
My = [-1 -2 -1;0 0 0;1 2 1];
Mx =[-1 0 1;-2 0 2;-1 0 1];
a3 =zeros(row,col);
for i =1:row-2
for j=1:col-2
Gx = sum(sum(Mx.*a(i:i+2, j:j+2)));
Gy = sum(sum(My.*a(i:i+2, j:j+2)));
filtered_image(i,j) = sqrt(Gx.^2 + Gy.^2);
end
end
filtered_image = uint8(filtered_image);
thresholdvalue =100;
output = max(filtered_image,thresholdvalue);
end

6 件のコメント
J. Alex Lee
2020 年 10 月 8 日
you need to deal with the edges: filtered_image offsets everything by 1, so your output image will be undefined (I guess zero?) along the top and left edges and have an extra row and column on the bottom and right. But the second error is confusing, why your output has 497 rows whereas the image has 351...
Milind Amga
2020 年 10 月 8 日
編集済み: Milind Amga
2020 年 10 月 8 日
J. Alex Lee
2020 年 10 月 8 日
then it may just be about your algorithm. have you searched TMW docs for "sobel edge detection"? matlab has very high level functions to achieve things like this - so it's not really clear to me how valuable this exercise is as a CODY challenge (is this a cody challenge?).
If you want to really learn about this method, I would look at the image processing toolbox, and do a deeper comparison of the results of your code versus what matlab canned edge detector returns. That is the more valuable feedback than "it's not right".
Milind Amga
2020 年 10 月 8 日
Image Analyst
2020 年 10 月 8 日
Try imfilter().
J. Alex Lee
2020 年 10 月 9 日
Ah ok. If you have access to full matlab (image processing toolbox), look into imfilter() as Image Analyst suggests, but also imgradientxy(). Then later you can look into conv2().
回答 (0 件)
カテゴリ
ヘルプ センター および File Exchange で Object Analysis についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!