[急]图像边缘提取时遇到的问题
要达到的目的:提取颗粒图像的边缘,然后将颗粒图像用椭圆拟合。在实现的代码如下:I1=imread('F:\automatic\pic\photo\particleOverlap1.bmp');
I2=im2bw(rgb2gray(I1));
ie=edge(I2,'canny');
figure,imshow(ie);
hold on;
=find(ie);
plot(x,y,'r.')
hold off;
运行的结果是find后的图像竟然与原图方向不同,倾斜了一定角度,所以拟合后的椭圆也倾斜了。
请高手们帮帮我。
[ 本帖最后由 qfwaterlily 于 2010-4-14 10:53 编辑 ] =find(ie'); 这样也不行,好像沿着x轴转了180度 LZ的程序运行后真的没有错误么?我这里有,I2是logical类型的,而edge不能处理这种类型,要转换一下,最后图形如下:
我运行的时候不报错,但是不出正确的结果。我刚接触matlab这个东西,搞太明白,哪个地方错了?你把代码给我贴出来吧!谢谢!!!
回复 5楼 qfwaterlily 的帖子
我用的是你在一楼发的JPG图片:clear;clc
I1=imread('particleOverlap2.jpg');
I2=im2bw(rgb2gray(I1));
ie=edge(double(I2),'canny');
figure,imshow(ie);
hold on;
=find(ie');
plot(x,y,'r.')
hold off;
页:
[1]