【图像处理】基于收缩系数的粒子群优化和引力搜索算法的多级图像阈值研究【CPSOGSA】(Matlab代码实现)

news/2024/11/29 22:43:23/

 

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码及文献


💥1 概述

文献来源:

图像分割(IS)是图像处理和计算机视觉中必不可少的过程。它将图像划分为许多区域和像素。换句话说,IS简化了图像的特征。多年来,已经提出了许多IS方法,包括边缘检测(ED;Papari & Petkov, 2011)、阈值(Otsu, 1979)等等。然而,由于其简单的设计和鲁棒性,阈值化被广泛使用IS技术(Oliva等人,2014)。

基本上,阈值处理图像的归一化,并根据灰度强度值将其分成更小的片段。实际上,阈值分为两级阈值和多级阈值(MT)。前者通过仅考虑一个阈值 (k) 值将图像分为两类。另一方面,机器翻译需要两个以上的阈值,并将图像的像素分成多个类。

图像分割是图像处理中的关键步骤之一。实际上,它处理根据像素强度将图像划分为不同的类。本工作介绍了一种新的基于收缩系数的粒子群优化和引力搜索算法(CPSOGSA)的图像分割方法。图像的随机样本充当CPSOGSA算法的搜索代理。最佳阈值数是使用 Kapur 熵法确定的。CPSOGSA在图像分割中的有效性和适用性是通过将其应用于USC-SIPI图像数据库中的五个标准图像来实现的,即飞机,摄影师,时钟,莉娜和海盗。采用各种性能指标来研究仿真结果,包括最佳阈值、标准差、MSE(均方误差)、运行时间分析、PSNR(峰值信噪比)、最佳适应度值计算、收敛图、分割图像图和箱形图分析。此外,图像精度是利用SSIM(结构相似性指数度量)和FSIM(特征相似性指数度量)指标进行基准测试的。此外,还利用成对非参数符号Wilcoxon秩和检验对仿真结果进行统计验证。 

本工作介绍了一种新的基于收缩系数的粒子群优化和引力搜索算法(CPSOGSA)的图像分割方法。图像的随机样本充当CPSOGSA算法的搜索代理。最佳阈值数是使用 Kapur 熵法确定的。CPSOGSA在图像分割中的有效性和适用性是通过将其应用于USC-SIPI图像数据库中的五个标准图像来实现的。

📚2 运行结果

 

 

 

  部分代码:

% Parameter initialization
     I = imread('Aeroplane.tiff');
%    I = imread('Cameraman.tiff');
 
  level = 5; %% Threshold = level-1 

 N_PAR = level;                          %number of thresholds (number of levels-1) (dimensiones)
 dim = N_PAR;  

 n = 15;                                  % Size of the swarm " no of objects " %%% Default (n = 15)
 Max_Iteration  = 300;                    % Maximum number of "iterations"      %%% Default (Max_Iteration  = 300)

if size(I,3) == 1 %grayscale image
[n_countR, x_valueR] = imhist(I(:,:,1));
end
Nt = size(I,1) * size(I,2); 
 
% % Lmax indicated color segments 0 - 256

Lmax = 256;   %256 different maximum levels are considered in an image (i.e., 0 to 255)

for i = 1:Lmax
    if size(I,3) == 1  
        %grayscale image
        probR(i) = n_countR(i) / Nt;
    end
end
if size(I,3) == 1
    up = ones(n,dim) * Lmax;
    low = ones(n,dim);
end
 tic
 RunNo  = 1;   
    for k = [ 1 : RunNo ]  
       [CPSOGSA_bestit,CPSOGSA_bestF,CPSOGSA_Fit_bests]= CPSOGSA(I, Lmax, n,Max_Iteration,low,up,dim, level, probR);
       BestSolutions1(k) = CPSOGSA_bestF; 
 disp(['Run # ' , num2str(k),'::' 'Best estimates =',num2str(CPSOGSA_bestit)]);         % CPSOGSA
    end  
% /* Boxplot Analysis */
   figure
   boxplot([BestSolutions1'],{'CPSOGSA'});
   color = [([1 0 0])];
   h = findobj(gca,'Tag','Box'); 
   for j=1:length(h) 
   patch(get(h(j),'XData'),get(h(j),'YData'),color(j));
   end 
   title ('\fontsize{15}\bf Aeroplane (k=2)');
   % %  title ('\fontsize{15}\bf  Cameraman (k=2)');
   xlabel('\fontsize{15}\bf Algorithms');
   ylabel('\fontsize{15}\bf Best Fitness Values');
   box on
% % % 

% /* Graphical Analysis*/
figure
 plot(CPSOGSA_Fit_bests,'DisplayName','CPSOGSA','Color','b','LineStyle','-','LineWidth',3);
 disp( ['Time_CPSOGSA =', num2str(toc)]); 
 title ('\fontsize{15}\bf Aeroplane (k=2)'); % k=2,4,6,8,10
 % %  title ('\fontsize{15}\bf Cameraman (k=2)');
 xlabel('\fontsize{15}\bf Iterations');
 ylabel('\fontsize{15}\bf Fitness values');
 legend('\fontsize{12}\bf CPSOGSA');
 %
 %
 gBestR = sort(CPSOGSA_bestit);
 Iout = imageGRAY(I,gBestR);
 Iout2 = mat2gray(Iout); 
 
% % Show results on images  

figure
imshow(Iout)
    
figure
imshow(I)
    
% % Show results

intensity = gBestR(1:dim-1);  
STDR  = std(CPSOGSA_Fit_bests)              %Standard deviation of fitness values       
MSEV = MSE(I, Iout)                         %Mean Square Error
PSNRV = PSNR(I, Iout)                       %PSNR between original image I and the segmented image Iout
SSIMV = ssim (I, Iout)                      %SSIM Quality Measure
FSIMV = FeatureSIM (I, Iout)                %FSIM Quality Measure
Best_Fitness_Value= CPSOGSA_Fit_bests(k)    %Best fitness
    

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

🌈4 Matlab代码及文献


http://www.ppmy.cn/news/348731.html

相关文章

LeetCode!! 3. Longest Substring Without Repeating Characters

参考资料:左程云算法课 3. Longest Substring Without Repeating Characters Given a string s, find the length of the longest substring without repeating characters.Example 1:Input: s "abcabcbb" Output: 3 Explanation: The answer is "…

Geeks3D FurMark v1.26 显卡压力测试工具中文便携版带GPU-Z

前言 Geeks3D FurMark 是一款显卡压力测试工具,显卡性能测试软件,由oZone3D.net网站开发,通过皮毛渲染算法来衡量显卡的性能,同时还能借此考验显卡的稳定性,最低要求NVIDIA GeForce FX系列、ATI Radeon 9600系列、S3 …

furmark烤机工具设置中文教程

furmark是一款非常专业的显卡测试工具,但是不少用户下载打开发现竟然是英文版的,有什么办法可以设置中文,方便使用吗?针对这个问题,下面小编就给大家讲讲furmark设置中文的方法。 FurMark软件安装后打开程序&#xff0…

UG\NX二次开发 头文件及描述

文章作者:里海 来源网站:https://blog.csdn.net/WangPaiFeiXingYuan UG\NX二次开发 头文件及描述 头文件描述uf.hUG OPEN API的公共类型和函数定义

如何在ubuntu上写一个类似sl跑火车指令,“跑甜甜圈”

如何在ubuntu上写一个类似sl跑火车指令&#xff0c;“跑甜甜圈” 首先创建.c文件 #include <stdio.h> #include <math.h> #include <string.h> #include <unistd.h>int main() {float A 0, B 0;float i, j;int k;float z[1760]; //array to store…

3dmark压力测试 linux,拷机还用Furmark? 瞧瞧3DMark压力测试怎样玩

在以前我们对于硬件的稳定性都相当的重视&#xff0c;特别是DIY组装的电脑或多或少都有些兼容性的问题&#xff0c;所以我们都会用一些拷机软件来检验一下平台的稳定性。而随着电脑硬件性能以及兼容性不断提升&#xff0c;硬件兼容性已经不是问题&#xff0c;但追求高性能的玩家…

显卡烤机软件furmark详细烤机教程

furmark是一款出名的显卡烤机软件&#xff0c;提供了多种测试选项&#xff0c;通过皮毛渲染算法来衡量显卡的性能。还有很多用户不清楚furmark怎么烤机&#xff0c;下面小编就带来详细的烤机设置教程。 furmark怎么烤机&#xff1f; 1、单卡烤机模式&#xff1a;运行软件&#…

oZone3D FurMark(甜甜圈furmark显卡压力测试软件)绿色单文件版V1.9.2 | 电脑烤机测试软件

FurMark是来自oZone3D开发的一款OpenGL基准测试工具&#xff0c;通过皮毛渲染算法来衡量显卡的性能&#xff0c;可以对显卡进行地狱一般的折磨&#xff0c;借此考验显卡的稳定性&#xff0c;就是大家常说的显卡压力测试软件&#xff0c;俗称甜甜圈furmark&#xff0c;甜甜圈fur…