当前位置 : 主页 > 编程语言 > java >

2021亚太杯A题

来源:互联网 收集:自由互联 发布时间:2022-07-17
文章目录 ​​第一问官方提到的两个算子​​ ​​第二问​​ ​​第三问​​ 第一问官方提到的两个算子 声明一下:代码仅供参考,不保证完全正确。 题目中提到了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('边缘检测')

结果:

2021亚太杯A题_边缘检测


2021亚太杯A题_后端_02


后面又要对直线曲线检测,直线建议使用:Matlab实现Hough变换检测图像中的直线,参考代码:

https://ww2.mathworks.cn/help/images/ref/houghlines.html?s_tid=doc_ta

或者代码:

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

2021亚太杯A题_后端_03

第二问

图像校正简直如法炮制,直接参考链接:

2021亚太杯A题_后端_04


轮廓长度…我也还不会,等更新哇

第三问

轮廓分割在第一问已经求出来了,如果你根据我的提示领悟好,你已经做出来了。

主要用到了什么?HALCON根据我的提示去领悟吧。(百度啊)

声明: 建议你不要把本篇文章内容传播给他人,仅订阅者观看,否则后果自负,我会要求官方读你发起律师函!


上一篇:2022华东杯A题核酸检测问题思路讲解
下一篇:没有了
网友评论