【信号处理】基于遗传算法的噪声图像的边缘检测(Matlab代码实现)

简介: 【信号处理】基于遗传算法的噪声图像的边缘检测(Matlab代码实现)

💥1 概述

     图像的边缘是指图像灰度急剧发生变化的不连续的地方,主要存在于目标和目标、背景和目标、不同色彩的区域之间,包含着图像的重要信息,在图像分析和理解中起着重要作用。


    图像的边缘检测就是检测图像中灰度不连续的地方,是数字图像处理领域重要的分支之一。检测边缘的难点在于如何精确地定义边缘,随着研究的深入,学者提出了不同的边缘模型,多数边缘检测器的设计都基于某一种固定的边缘模型。例如,基于梯度的边缘检测方法将边缘视为灰度变化速率快的像素点集合,Konishi依据“边缘”和“非边缘”滤波器的统计规律来定义物体边缘",Peli 则提出基于视觉模型的算法3,将视觉可接受范围作为滤波频段,其阈值为人眼的对比敏感度。

📚2 运行结果

🎉3 参考文献


[1]徐艳蕾,赵继印,焦玉斌.噪声图像边缘检测方法的研究[J].计算机应用研究,2009,26(1):387-389

[2]刘闻,别红霞.基于蚁群算法的噪声图像边缘检测[J].软件,2013,34(12):256-259.

👨‍💻4 Matlab代码

部分代码:

function setNoiseImages(GUI_figure)
    global noises;
    imageNum = ceil(sqrt((length(noises)+1)));
    positionBase = 1/imageNum;
    shareData = guidata(GUI_figure);
    testImg = shareData.testImg;
    axes('Parent', GUI_figure,...
        'Units', 'normalized',...
        'Position',[0 1/2 1 1/2]*positionBase,...
        'Visible', 'off');
    imshow(imread(char(testImg.inImg)));
    for I = 1:length(noises)
        axes('Parent', GUI_figure,...
            'Units', 'normalized',...
            'Position',[(mod(I, imageNum)) floor((I)/imageNum)+1/2 1 1/2]*positionBase,...
            'Visible','off');
        imshow(imread(char(testImg.inNoise(I+1,:))));
    end
    text=uicontrol('Style','text',...
            'Units', 'normalized',...
            'Position',[3/7 19/20 1/7 1/20]*positionBase,...
            'String',strcat('Noise: 0%'));
    set(text,'BackGroundColor','red');
    for I = 1:imageNum
        text=uicontrol('Style','text',...
            'Units', 'normalized',...
            'Position',[(mod(I, imageNum))+3/7 floor((I)/imageNum)+19/20 1/7 1/20]*positionBase,...
            'String',['Noise: ', int2str(noises(I)*100), '%']);
        set(text,'BackGroundColor','red');
    end
    drawnow;
end
function updateNGain2Slider(hObj,event,GUI_figure)
    global noiseWeights;
    val=get(hObj,'Value');
    noiseWeights(3)=val;
    updateNGain2Text();
end
function updateNGain2Text()
    global noises;
    global noiseWeights;
    imageNum = ceil(sqrt((length(noises)+1)));
    positionBase = 1/imageNum;
    uicontrol('Style','text',...
        'Units', 'normalized',...
        'Position',[(imageNum-1) (imageNum-1)+7/20 3/10 1/20]*positionBase,...
        'String',['Noise Gain 2: ',num2str(noiseWeights(3),2)]);
end
function updateGenerationsSlider(hObj,event)
    global generations;
    val=get(hObj,'Value');
    generations=round(val);
    updateGenerationsText();
end
function updateGenerationsText()
    global noises;
    global generations;
    imageNum = ceil(sqrt((length(noises)+1)));
    positionBase = 1/imageNum;
    uicontrol('Style','text',...
        'Units', 'normalized',...
        'Position',[(imageNum-1) (imageNum-1)+17/20 3/10 1/20]*positionBase,...
        'String',['Generations: ',int2str(generations)]);
end
function updatePopSizeSlider(hObj, event)
    global popSize;
    val=get(hObj,'Value');
    popSize=round(val);
    updatePopSizeText();
end
function updatePopSizeText()
    global noises;
    global popSize;
    imageNum = ceil(sqrt((length(noises)+1)));
    positionBase = 1/imageNum;
    uicontrol('Style','text',...
        'Units', 'normalized',...
        'Position',[(imageNum-1) (imageNum-1)+16/20 3/10 1/20]*positionBase,...
        'String',['Pop Size: ',int2str(popSize)]);
end
function updateBestMatrix(inMatrix)
    global noises;
    imageNum = ceil(sqrt((length(noises)+1)));
    positionBase = 1/imageNum;
    uitable('Units', 'normalized',...
        'Position', [(imageNum-1) (imageNum-1)+2/20 1 5/20]*positionBase,...
        'Data', inMatrix);
end
function initialiseImages(GUI_figure)
    global noises;
    shareData = guidata(GUI_figure);
    img = shareData.img;
    testImg = shareData.testImg;
    % Generate and write noise and training images.
    for I=1:length(noises)
        writeLocation=strcat(testImg.inNoise(1), int2str(I), '.png');
        testImg.inNoise(I+1,:)=writeLocation;
        for II=1:5
            writeLocation=strcat(img(II).inNoise(1), int2str(I), '.png');
            img(II).inNoise(I+1,:)=writeLocation;
        end
    end
    createNoiseImage(testImg, noises, 'gaussian');

完整代码:

链接:https://pan.baidu.com/s/1EaaNNZpD-eLt4OzUnSSGNg
提取码:22ns
--来自百度网盘超级会员V2的分享

相关文章
|
5月前
|
算法 定位技术 计算机视觉
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
【水下图像增强】基于波长补偿与去雾的水下图像增强研究(Matlab代码实现)
393 0
|
5月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
256 8
|
5月前
|
机器学习/深度学习 编解码 算法
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
基于OFDM技术的水下声学通信多径信道图像传输研究(Matlab代码实现)
262 8
|
5月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
497 0
|
5月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
325 2
|
6月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
307 3
|
6月前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
219 6
|
5月前
|
机器学习/深度学习 算法 自动驾驶
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
基于导向滤波的暗通道去雾算法在灰度与彩色图像可见度复原中的研究(Matlab代码实现)
291 8
|
5月前
|
机器学习/深度学习 算法 数据可视化
基于MVO多元宇宙优化的DBSCAN聚类算法matlab仿真
本程序基于MATLAB实现MVO优化的DBSCAN聚类算法,通过多元宇宙优化自动搜索最优参数Eps与MinPts,提升聚类精度。对比传统DBSCAN,MVO-DBSCAN有效克服参数依赖问题,适应复杂数据分布,增强鲁棒性,适用于非均匀密度数据集的高效聚类分析。
|
6月前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
341 14

热门文章

最新文章