文章目录 第一问官方提到的两个算子 第二问 第三问 第一问官方提到的两个算子 声明一下:代码仅供参考,不保证完全正确。 题目中提到了canny算子边缘检
文章目录
- 第一问官方提到的两个算子
- 第二问
- 第三问
第一问官方提到的两个算子
声明一下:代码仅供参考,不保证完全正确。
题目中提到了canny算子边缘检测,我们先不管它有没有用,我把python的代码先送给大家:python边缘检测
sobel算法也送大家:python sobel算法边缘检测
同时也提供了matlab版本:matlab 边缘检测的两种算法
再送大家一个新的代码:
=imread('Pic1_1.bmp');imshow(X1)
title('原始图')
imhist(X1)%图像数据的直方图
title('直方图')
XX1=imbinarize(X1);%通过阈值化将二维灰度图像或三维体二值化
imshow(XX1)
title('灰度图')
Ig=XX1;
%获取算子
s=GetStrelList();
%串联去噪
e=ErodeList(Ig,s);
%计算权重
f=GetRateList(Ig,e);
%并联
Igo=GetRemoveResult(f,e);
%计算PSNR值
psnr1=PSNR(XX1,e.eroded_co12);
psnr2=PSNR(XX1,e.eroded_co22);
psnr3=PSNR(XX1,e.eroded_co32);
psnr4=PSNR(XX1,e.eroded_co42);
psnr5=PSNR(XX1,Igo);
psnr_list=[psnr1 psnr2 psnr3 psnr4 psnr5];
M{1,1}=e.eroded_co12;
M{1,2}=e.eroded_co22;
M{1,3}=e.eroded_co32;
M{1,4}=e.eroded_co42;
M{1,5}=Igo;
figure
plot(1:5,psnr_list,'r+-');
set(gca,'XTick',0:6,'XTickLabel',{'','串联1','串联2','串联3','串联4','并联',''});
grid on;
title('PSNR曲线比较')
[~,b]=max(psnr_list);
result=M{1,b};
figure
result=imbinarize(result,'adaptive');
Y1=bwperim(result);%在二进制图像中查找对象的周长
imshow(Y1)
title('边缘检测')
结果:
后面又要对直线曲线检测,直线建议使用:Matlab实现Hough变换检测图像中的直线,参考代码:
或者代码:
close all;clear all;
I = imread('scratch.tif');
figure;
subplot(1,3,1);
imshow(I);
BW = edge(I,'canny');%Canny方法提取图像边界,返回二值图像(边界1,否则0)
[H,T,R] = hough(BW);%计算二值图像的标准霍夫变换,H为霍夫变换矩阵,I,R为计算霍夫变换的角度和半径值
subplot(1,3,2);
imshow(H,[],'XData',T,'YData',R,'InitialMagnification','fit');%hough变换的图像
xlabel('\theta'), ylabel('\rho');
axis on,axis square,hold on;
P = houghpeaks(H,3);%提取3个极值点
x = T(P(:,2));
y = R(P(:,1));
plot(x,y,'s','color','white');%标出极值点
lines=houghlines(BW,T,R,P);%提取线段
subplot(1,3,3);
imshow(I), hold on;
for k = 1:length(lines)
xy = [lines(k).point1; lines(k).point2];
plot(xy(:,1),xy(:,2),'LineWidth',2,'Color','green');%画出线段
plot(xy(1,1),xy(1,2),'x','LineWidth',2,'Color','yellow');%起点
plot(xy(2,1),xy(2,2),'x','LineWidth',2,'Color','red');%终点
end
不是要提取圆弧,直线轮廓嘛,找到一个还可以的链接,自己打开看看就知道了,具体怎么实现应该可以根据对应的函数百度,自己去实现:
http://blog.sina.com.cn/s/blog_c01c55220102ypsx.html第二问
图像校正简直如法炮制,直接参考链接:
轮廓长度…我也还不会,等更新哇
第三问
轮廓分割在第一问已经求出来了,如果你根据我的提示领悟好,你已经做出来了。
主要用到了什么?HALCON根据我的提示去领悟吧。(百度啊)
声明: 建议你不要把本篇文章内容传播给他人,仅订阅者观看,否则后果自负,我会要求官方读你发起律师函!