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

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

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

文章目录

  • 智能优化算法应用:麻雀算法优化脉冲耦合神经网络的图像自动分割
    • 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打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

C语言中位操作的实际应用举例

《C语言中位操作的实际应用举例》:本文主要介绍C语言中位操作的实际应用,总结了位操作的使用场景,并指出了需要注意的问题,如可读性、平台依赖性和溢出风险,文中通过代码介绍的非常详细,需要的朋友可以参... 目录1. 嵌入式系统与硬件寄存器操作2. 网络协议解析3. 图像处理与颜色编码4. 高效处理布尔标志集合

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分