智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割 -附代码

本文主要是介绍智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割 -附代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割

文章目录

  • 智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割
    • 1.麻雀搜索算法
    • 2.PCNN网络
    • 3.实验结果
    • 4.参考文献
    • 5.Matlab代码

摘要:本文利用麻雀搜索算法对脉冲耦合神经网络的参数进行优化,以信息熵作为适应度函数,提高其图像分割的性能。

1.麻雀搜索算法

麻雀搜索算法的具体原理参考博客:https://blog.csdn.net/u011835903/article/details/108830958。

2.PCNN网络

在这里插入图片描述

图1.PCNN 模型结构

为了提高效率,减少参数间的相互作用,采用简化的 PCNN 模型。如图1所示,简化 PCNN 的结构分为接收部分、调制部分和脉冲发生器 3 部分。其数学表达式为:
F i j [ n ] = S i j (1) F_{ij}[n] = S_{ij} \tag{1} Fij[n]=Sij(1)

F i j [ n ] = ∑ W i j k l Y k l [ n − 1 ] (2) F_{ij}[n] = \sum W_{ijkl}Y_{kl}[n-1] \tag{2} Fij[n]=WijklYkl[n1](2)

θ i j [ n ] = e x p ( − α E ) θ i j [ n − 1 ] + V E Y i j [ n − 1 ] (3) \theta_{ij}[n] = exp(-\alpha_E)\theta_{ij}[n-1]+V_EY_{ij}[n-1] \tag{3} θij[n]=exp(αE)θij[n1]+VEYij[n1](3)

Y i j [ n ] = { 1 , U i j [ n ] ≥ θ i j [ n ] 0 , U i j [ n ] < θ i j [ n ] (4) Y_{ij}[n] = \begin{cases} 1,U_{ij}[n]\geq \theta_{ij}[n]\\ 0,U_{ij}[n]<\theta_{ij}[n] \end{cases} \tag{4} Yij[n]={1,Uij[n]θij[n]0,Uij[n]<θij[n](4)

式中: F i j [ n ] F_{ij}[n] Fij[n]表示 PCNN 的输入; S i j [ n ] S_{ij}[n] Sij[n]是外部输入,比如一幅图像的所有像素点; L i j [ n ] L_{ij}[n] Lij[n]是连接输入; U i j [ n ] U_{ij}[n] Uij[n]是内部活动项, θ i j [ n ] \theta_{ij}[n] θij[n]表示动态阈值, Y i j [ n ] Y_{ij}[n] Yij[n]是神经网络的输出; β \beta β是连接系数, W i j k l W_{ijkl} Wijkl是连接矩阵; α E \alpha_E αE是阈值衰减系数, V E V_E VE 是阈值放大系数。通常 W i j k l W_{ijkl} Wijkl可以设置为:
W i j k l = [ 0.707 1 0.707 1 0 1 0.707 1 0.707 ] (5) W_{ijkl} = [\begin{matrix}0.707&1&0.707\\ 1&0&1\\ 0.707&1&0.707 \end{matrix}] \tag{5} Wijkl=[0.70710.7071010.70710.707](5)
在这些参数中,对分割结果产生较大影响的主要有3个:连接系数 β \beta β、阈值衰减系数 α E \alpha_E αE 、阈值放大系数 V E V_E VE

3.麻雀适应度函数设计

适应度函数作为优化算法中重要的一部分,影响着分割结果。熵能够反映目标包含的信息量的大小,熵越大,说明包含的信息量越大。因此,本文选取分割后图像的熵作为适应度函数,其公式为:
H = − p 1 ∗ l o g 2 p 1 − p 0 ∗ l o g 2 p 0 (6) H =-p_1*log_2p_1 - p_0*log_2p_0 \tag{6} H=p1log2p1p0log2p0(6)
式中: p 1 p_1 p1是二值图像中 1 占整幅图像的比例; p 0 p_0 p0 是二值图像中 0 占整幅图像的比例。

由于麻雀优化算法为寻找最小值,于是添加负号,转换为选找最小值:
f i t n e s s = a r g m i n ( − H ) (7) fitness = argmin(-H) \tag{7} fitness=argmin(H)(7)

3.实验结果

麻雀参数设置如下:

3 个参数范围均设置为 0.001 ~200;

%% 麻雀算法优化脉冲耦合神经网络的图像自动分割
%读取图像
I = imread('lena.jpg');
%将图像转换为灰度图
if(size(I,3)~=1)Igray = rgb2gray(I);
elseIgray = I;
end
%对连接系数β、阈值衰减系数 αE 、阈值放大数 VE进行优化
%设置麻雀算法参数
%参数范围均设置为 0.001-200
dim = 3;%维度,3维即优化的3个参数
lb = 0.001.*ones(1,dim); %下边界
ub = 200.*ones(1,dim); %上边界
pop = 20;%种群数量
Max_iteration = 20;%最大迭代次数
fobj = @(x) fun(x,Igray);%适应度函数

在这里插入图片描述

优化的连接系数β、阈值衰减系数 αE 、阈值放大数 VE分别为:51.99388 0.001 155.0309

SSA-PCNN分割后的信息熵值0.99998

从结果图像和信息熵值来看,信息熵值接近1,表明优化取得了一个比较好的结果。

4.参考文献

[1]贾鹤鸣,康立飞,孙康健,彭晓旭,李瑶,姜子超.哈里斯鹰算法优化脉冲耦合神经网络的图像自动分割[J].应用科技,2019,46(04):16-20+25. (基本原理参考该文章)

5.Matlab代码

1.麻雀算法优化脉冲耦合神经网络的图像自动分割

2.哈里斯鹰算法优化脉冲耦合神经网络的图像自动分割
[1]贾鹤鸣,康立飞,孙康健,彭晓旭,李瑶,姜子超.哈里斯鹰算法优化脉冲耦合神经网络的图像自动分割[J].应用科技,2019,46(04):16-20+25.

个人资料介绍

这篇关于智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割 -附代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1071681

相关文章

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示