【图像检测-边缘检测】基于遗传算法的边缘检测算法研究附matlab代码

简介: 【图像检测-边缘检测】基于遗传算法的边缘检测算法研究附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法  神经网络预测雷达通信 无线传感器

信号处理图像处理路径规划元胞自动机无人机 电力系统

⛄ 内容介绍

提出一种基于遗传算法的图像边缘检测方法——GA算法,目的是提高图像有效信息边缘检测提取.GA算法在图像内部像素点和图像内部局部信息关系的基础上,将图像有效信息边缘提取转化成一种优化问题,再采用遗传算法对这种问题求解,获得图像有效的边缘信息.MATLAB实验仿真结果表明,相对于传统的边缘检测算法检测边缘,GA算法不仅克服了传统算法缺陷,提高了图像边缘的边界连续性,且抗干扰能力更好,图像视觉效果更好.

⛄ 部分代码

function [ c, ceq ] = curve_constraints( cx, curti, curtj )

% constraints c(x) <= 0 or ceq(x) = 0

% 1 2 3

% 4 0 5

% 6 7 8

% edgemap numbering

px=zeros(size(cx,2),1);py=zeros(size(cx,2),1);pxl=zeros(size(cx,2),1);flag=0;

for i=1

   if cx(i)==0,flag=1;end

   if flag~=1

   if cx(i)==1,px(i)=curti-1;py(i)=curtj-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==2,px(i)=curti-1;py(i)=curtj;pxl(i)=px(i)*py(i);

   elseif cx(i)==3,px(i)=curti-1;py(i)=curtj+1;pxl(i)=px(i)*py(i);

   elseif cx(i)==4,px(i)=curti;py(i)=curtj-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==5,px(i)=curti;py(i)=curtj+1;pxl(i)=px(i)*py(i);

   elseif cx(i)==6,px(i)=curti+1;py(i)=curtj-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==7,px(i)=curti+1;py(i)=curtj;pxl(i)=px(i)*py(i);

   elseif cx(i)==8,px(i)=curti+1;py(i)=curtj+1;pxl(i)=px(i)*py(i);

   end

   end

end

for i=2:size(cx,2)

   if cx(i)==0,flag=1;end

   if flag~=1

   if cx(i)==1,px(i)=px(i-1)-1;py(i)=py(i-1)-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==2,px(i)=px(i-1)-1;py(i)=py(i-1);pxl(i)=px(i)*py(i);

   elseif cx(i)==3,px(i)=px(i-1)-1;py(i)=py(i-1)+1;pxl(i)=px(i)*py(i);

   elseif cx(i)==4,px(i)=px(i-1);py(i)=py(i-1)-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==5,px(i)=px(i-1);py(i)=py(i-1)+1;pxl(i)=px(i)*py(i);

   elseif cx(i)==6,px(i)=px(i-1)+1;py(i)=py(i-1)-1;pxl(i)=px(i)*py(i);

   elseif cx(i)==7,px(i)=px(i-1)+1;py(i)=py(i-1);pxl(i)=px(i)*py(i);

   elseif cx(i)==8,px(i)=px(i-1)+1;py(i)=py(i-1)+1;pxl(i)=px(i)*py(i);

   end

   end

end

cin1=size(unique(pxl(pxl>0)),1)-size(pxl(pxl>0),1);% avoid repeated same pixel select

% cin2=sum(unique(pxl(pxl>0))-pxl(1:size(unique(pxl(pxl>0)),1)));

c = [cin1;-cin1;];

ceq=[];

end

⛄ 运行结果

⛄ 参考文献

[1]陆怡. 图像边缘检测算法的研究和仿真[J]. 计算机仿真, 2012, 29(9):289-292.

[2]朱国武, 庄金雷, 王力超,等. 基于遗传算法的图像边缘检测研究[J]. 牡丹江师范学院学报:自然科学版, 2022(4):4.

⛄ 完整代码

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
7天前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
|
7天前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
87 14
|
7天前
|
机器学习/深度学习 边缘计算 运维
【电能质量扰动】基于ML和DWT的电能质量扰动分类方法研究(Matlab实现)
【电能质量扰动】基于ML和DWT的电能质量扰动分类方法研究(Matlab实现)
76 10
|
7天前
|
机器学习/深度学习 算法
【概率Copula分类器】实现d维阿基米德Copula相关的函数、HACs相关的函数研究(Matlab代码实现)
【概率Copula分类器】实现d维阿基米德Copula相关的函数、HACs相关的函数研究(Matlab代码实现)
|
9天前
|
算法 计算机视觉
【MPDR & SMI】失配广义夹角随输入信噪比变化趋势、输出信干噪比随输入信噪比变化趋势研究(Matlab代码实现)
【MPDR & SMI】失配广义夹角随输入信噪比变化趋势、输出信干噪比随输入信噪比变化趋势研究(Matlab代码实现)
|
9天前
|
编解码 人工智能 算法
【采用BPSK或GMSK的Turbo码】MSK、GMSK调制二比特差分解调、turbo+BPSK、turbo+GMSK研究(Matlab代码实现)
【采用BPSK或GMSK的Turbo码】MSK、GMSK调制二比特差分解调、turbo+BPSK、turbo+GMSK研究(Matlab代码实现)
|
9天前
|
机器学习/深度学习 编解码 并行计算
【改进引导滤波器】各向异性引导滤波器,利用加权平均来实现最大扩散,同时保持图像中的强边缘,实现强各向异性滤波,同时保持原始引导滤波器的低低计算成本(Matlab代码实现)
【改进引导滤波器】各向异性引导滤波器,利用加权平均来实现最大扩散,同时保持图像中的强边缘,实现强各向异性滤波,同时保持原始引导滤波器的低低计算成本(Matlab代码实现)
|
9天前
|
机器学习/深度学习 传感器 边缘计算
【故障诊断】基于时滞反馈随机共振的增强型旋转电机故障诊断(Matlab代码实现)
【故障诊断】基于时滞反馈随机共振的增强型旋转电机故障诊断(Matlab代码实现)
|
9天前
|
传感器 机器学习/深度学习 算法
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
|
9天前
|
运维 算法
【故障诊断】基于最小熵反卷积、最大相关峰度反卷积和最大二阶环平稳盲反卷积等盲反卷积方法在机械故障诊断中的应用研究(Matlab代码实现)
【故障诊断】基于最小熵反卷积、最大相关峰度反卷积和最大二阶环平稳盲反卷积等盲反卷积方法在机械故障诊断中的应用研究(Matlab代码实现)

热门文章

最新文章