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

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

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

文章目录

  • 智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割
    • 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

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill