matlab评估边缘检测性能,【模糊推理】模糊逻辑图像边缘检测,原理+matlab代码~...

这篇博客是接着上一篇来哒,https://blog.csdn.net/luolan9611/article/details/94285158

本篇博客及上篇博客搜集的资料、实验代码、实验报告、PPT均已上传至百度网盘:

f7174a0d0d108e05fbedcf1650c4bb41.png

链接:https://pan.baidu.com/s/1AmT4TtBAxj1FKf4KUFcsBw    提取码:kcfe

先上结果~

3ccc84a19a1cf079091c9e61986607e9.png

再上代码~

唔,要说明的是我使用的是matlabR2018a,如果用matlab2019的话,代码要有些变化,因为函数接口什么的会变...

%读取原始图像,并将之转换为灰度图

Irgb = imread('zx_in_xidian.jpg');

Igray=rgb2gray(Irgb);

%绘制原始图像和灰度图

figure

image(Irgb,'CDataMapping','scaled')

title('Input Image in Rgbscale');

figure

image(Igray,'CDataMapping','scaled')

colormap('gray')

title('Input Image in Grayscale');

%将灰度图转换为双精度表示

I=im2double(Igray);

%定义Gx和Gy,将之与I卷积

Gx=[-1 1];

Gy=Gx';

%Ix=mapminmax(conv2(I,Gx,'same'));

%Iy=mapminmax(conv2(I,Gy,'same'));

Ix=conv2(I,Gx,'same');

Iy=conv2(I,Gy,'same');

%绘制Ix和Iy

figure

image(Ix,'CDataMapping','scaled')

colormap('gray')

title('Ix')

figure

image(Iy,'CDataMapping','scaled')

colormap('gray')

title('Iy')

%定义图像边缘检测的模糊推理系统

edgeFIS=newfis('edgeDetection');

%定义模糊推理系统的输入

edgeFIS = addvar(edgeFIS,'input','Ix',[-1 1]);

edgeFIS = addvar(edgeFIS,'input','Iy',[-1 1]);

%sx和sy分别作为高斯隶属函数中相应的sigma标准差

sx=0.1;

sy=0.1;

edgeFIS = addmf(edgeFIS,'input',1,'zero','gaussmf',[sx 0]);

edgeFIS = addmf(edgeFIS,'input',2,'zero','gaussmf',[sy 0]);

%定义模糊推理系统的输出

edgeFIS = addvar(edgeFIS,'output','Iout',[0 1]);

%三角隶属函数

wa = 0.1;

wb = 1;

wc = 1;

ba = 0;

bb = 0;

bc = 0.7;

%参数说明 fis = addmf(fis,varType,varIndex,mfName,mfType,mfParams)

edgeFIS = addmf(edgeFIS,'output',1,'white','trimf',[wa wb wc]);

edgeFIS = addmf(edgeFIS,'output',1,'black','trimf',[ba bb bc]);

%绘制Ix,Iy和Iout隶属函数图像

figure

subplot(2,2,1)

plotmf(edgeFIS,'input',1)

title('Ix')

subplot(2,2,2)

plotmf(edgeFIS,'input',2)

title('Iy')

subplot(2,2,[3 4])

plotmf(edgeFIS,'output',1)

title('Iout')

%定义两个规则:如果Ix为0,Iy也为0,那么输出是白色,即非边缘区域;如果Ix不为0或者Iy不为0,则输出黑色,为边缘区域。

r1 = 'If Ix is zero and Iy is zero then Iout is white';

r2 = 'If Ix is not zero or Iy is not zero then Iout is black';

r = char(r1,r2);

edgeFIS = parsrule(edgeFIS,r);

showrule(edgeFIS)

%将每一行像素送入模糊系统进行评估,得到输出

Ieval = zeros(size(I));

for ii = 1:size(I,1)

Ieval(ii,:) = evalfis([(Ix(ii,:));(Iy(ii,:));]',edgeFIS);

end

%绘制边缘检测后的图像

figure

colormap('gray')

image(Ieval,'CDataMapping','scaled')

colorbar

title('Edge Detection Using Fuzzy Logic')

%以坐标[2183,1463]上的像素点为例,它的Ix为0.0275,Iy为0.2196

%这一坐标点的Ix和Iy经过高斯隶属函数计算后得到的隶属度分别为([0.962893466491363,0.0897068632021378])

%不属于0的隶属度是它们的补([0.0371065335086372,0.910293136797862])

%根据高斯隶属函数得到的隶属度在三角隶属函数的图像上(white的函数图和black的函数图),分别进行蕴含操作(min)后,进行Aggregate操作

%将模糊集去模糊化得到单一输出值(使用质心的方法)

%绘制出该图像

[output,fuzzifiedInputs,ruleOutputs,aggregatedOut]=evalfis([0.0275,0.2196],edgeFIS);

outputRange=linspace(edgeFIS.output.range(1),edgeFIS.output.range(2),length(aggregatedOut))';

figure

plot(outputRange,aggregatedOut,[output output],[0 1])

xlabel('Iout')

ylabel('Output Memebership')

legend('Aggregated output fzzy set','Defuzzified output')

%绘制该模糊系统的图像

figure

plotfis(edgeFIS)

title('edgeFIS')

%绘制表面曲线图

figure

gensurf(edgeFIS)

title('surfaceplot')

原理讲解~

记得上篇博客讲的模糊推理过程吧~

模糊推理是使用模糊逻辑将给定输入映射到输出的过程。将输入变量进行模糊化得到模糊集,根据设定的规则描述(前件)进行模糊运算,将模糊运算的结果作用于后果(后件),将每个规则的输出模糊集聚合为指定输出,去模糊化后得到推理结果。

模糊推理过程主要分为五个部分:

1.输入变量的模糊化

通过隶属函数将前提条件中的所有模糊语句解析为0到1之间的隶属度。如果前提只有一个部分,那么这就是对规则的支持程度。

2.模糊算子(AND或OR)在先行词中的应用

如果前提条件不只一个,则应用模糊逻辑运算,将前提解析为0到1之间的隶属度值。

3.计算前提条件对后件的影响

使用整个规则的支持度来塑造输出模糊集。模糊规则的结果将整个模糊集分配给输出。该模糊集由隶属函数表示,该隶属函数被选择以指示后件的质量。如果先行词仅部分为真,(即赋值小于1),则根据蕴涵方法截断输出模糊集。

4.所有规则的结果汇总

然后将每个规则的输出模糊集合聚合为单个输出模糊集。

5.去模糊化

最后,对结果集进行去模糊化,得到最终的推理结果。

========

那怎么把这一推理过程用于图像边缘检测呢????

图像的边缘是两个均匀区域之间的边界,我们可以通过比较邻近像素的强度来检测边缘。但是,由于均匀区域没有明确定义,两个相邻像素之间的小强度差并不总是表示边缘。相反,强度的差异可能代表着阴影效果。图像处理的模糊逻辑方法允许我们使用隶属函数来定义像素属于边缘或均匀区域的程度。

如果把图像看成二维离散函数,那么图像梯度其实就是这个二维离散函数的求导:G(x,y) = dx(i,j) + dy(i,j);其中dx(i,j) = I(i+1,j) - I(i,j);dy(i,j) = I(i,j+1) - I(i,j);  I是图像像素的值(如:RGB值),(i,j)为像素的坐标。

先对图像预处理一下:原图-->灰度化-->灰度图归一化

然后,利用梯度滤波器Gx=[-1 1]和Gy(等于Gx的转置)和图像I分别卷积,可以获得图像沿水平方向和竖直方向的梯度矩阵Ix和Iy,梯度的值在[-1 1]之间变化。也可以使用其它的滤波器来获得图像的梯度。

98cdd816a6cbff108e3e5cf2aa7bda3c.png

得到的Ix和Iy你们能看出区别的对吧,Ix是水平方向的梯度,上面有树干的纹理,Iy上检测不到的。

============================

然后我们就要开始进行那五个步骤啦:

80d188da2461ea7c32a6188bfa920972.png

使用0均值高斯隶属函数定义像素点属于zero(非边缘像素点)的程度,其中sigma是标准偏差,我设置为0.1,c是均值为0。sigma值的改变可以调整边缘检测的性能。增加它们的值会使得算法对于图像中的边缘没那么敏感并且减少检测的边缘的强度。

定义两个规则:

ffdae7fd705848b8a753af969313c7d1.png

对于输出的像素点的值属于白色还是黑色分别定义white和black隶属函数,参数a和c定位的是三角形的脚点,b定位的是顶点。其中wa = 0.1;wb = 1;wc = 1;ba = 0;bb = 0;bc = 0.7; wa,wb,wc,ba,bb,bc可以更改以调整边缘检测器的性能。如下:

a6bb69ea70cb5777fc6cad4ce1ebfeae.png

下面这张图是该图像边缘检测模糊推理系统的示意图:

6ab23c4435f511061ef602008d58fffd.png

以本实验中的待检测图像中的一像素点为例进一步说明第3和第4步。以Ix,Iy=[0.0275,0.2196]的这个像素点(即书包上的那个点)为边缘检测模糊推理系统edgeFIS的输入,它们属于zero的隶属度分别为0.9629和0.0897,不属于zero的隶属度分别为0.0371(即1-0.9629)和0.9103(即1-0.0897)。

0b601f9b5a7de15eac7a500399147586.png

步骤2和步骤3.根据规则1的and运算,取小值0.0897对white进行截断。根据规则2的or运算,取大值0.9103对black进行截断。截断后的模糊集在原图中由黄线表示。

ffde8229b99e9320c065a137da140c1c.png

步骤4.所有规则的结果汇总

将white和black小图中黄线的部分Aggregation(取大值),即可得到所有规则的结果汇总后的模糊集,如手绘图中最右下角的黄线所示,其实也就是下图中的蓝色线条。

d33e445e341bf64302a32dcd4b01fe67.png

步骤5.去模糊化

对Aggeragation后的图像进行去模糊化,即可得到最终的输出值,如图橘黄色的线Defuzzified output所示。输出值约为0.28,是书包那点的输出值。

cbbf122c390cf5b73aec76e14d4ef6ae.png

===============================================================================

参考资料:

Matlab的官网Example~~

https://ww2.mathworks.cn/help/fuzzy/fuzzy-logic-image-processing.html?requestedDomain=zh

上一篇博客:

【模糊数学】模糊逻辑,隶属度,模糊逻辑应用,模糊推理过程

https://blog.csdn.net/luolan9611/article/details/94285158

765b3bd77c1d77f93f9136f8b8aa626b.png

好了,今天就分享这么多吧,可爱

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349258.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

qt中实现左右分割线_Qt项目中,实现屏幕截图并生成gif的详细示例(值得细读)...

总第50篇平时我们在工作和学习的过程中,有时需要将桌面的某些动作截图生成gif动图,以更生动地呈现出来。目前有很多这样的软件,并且方便易使用,比如我经常使用的GifCam,软件小巧,生成的图片文件也比较小&am…

构建Spring Boot RESTful服务+ Spring Boot执行器

总览 什么是REST? REST(代表状态转移)是Web构建的体系结构样式,已成为用于Web应用程序的标准软件设计模式 。 代表性国家转移一词最早由REST的发起人,HTTP规范的主要作者之一Roy Fielding在其博士论文中使用 。 REST上…

matlab 安装glpk,mac上安装GLPK

Obsolation note:Thanks to Dave Coleman’s comment I found out that glpk is available through homebrew now! So you just need these 2 steps to get glpk now:homebrewbrew install glpkIf you still want to read on, the old way is still here…So you want copy-pas…

tf调不到keras怎么 回事_格力变频空调快速维修方法及技巧 空调压缩机不到一分钟就停,怎么回事?...

格力变频空调快速维修方法及技巧一、 室内部分: 1、F1开路:制冷时不启动或启动一下就停机;制热正常,且一直高频运转。 2、F2开路:工作6—10分钟就停机,显示E2停止外机。 3、F2短路&#xff1…

php 档案,PHP 档案包 (PHAR)

PHP 档案包 (PHAR)要获取 PHPUnit,最简单的方法是下载 PHPUnit 的 PHP 档案包 (PHAR),它将 PHPUnit 所需要的所有必要组件(以及某些可选组件)捆绑在单个文件中:要使用 PHP档案包(PHAR)需要有 phar 扩展。要使用 PHAR 的 --self-update 功能需…

pycharm是不是python编程_使用PyCharm进行python开发的简介

使用PyCharm进行python开发的简介这个是很常见的一个问题,我想学习python,用什么编辑器呢?eclipsepydev?IDLE?vim?每个人有自己的习惯,可能是自己琢磨的,也可能是前辈指导的,这里只分享自己孤陋寡闻琢磨…

php自动释放mysql连接,php怎么关闭mysql连接

php怎么关闭mysql连接2021-03-17 07:45:43php中可使用mysqli_close()函数来关闭mysql连接,语法格式“mysqli_close(connection);”。mysqli_close()函数可关闭先前打开的数据库连接,如果成功返回TRUE,反之则返回FALSE。本教程操作环境&#x…

Java 8 –按值对HashMap进行升序和降序排序

在上一篇文章中,我向您展示了如何通过键对Java 8中的Map进行排序 ,今天,我将教您如何使用Java 8功能(例如,lambda表达式,方法引用,流和新方法) 按值对Map进行排序。添加到java.util.…

python处理wps表格数据匹配_WPS表格技巧—如何利用WPS表格实现数据分组

小伙伴们在工作中经常会遇到这种情况,密密麻麻的数据看着都让人眼晕,处理起来更是费劲,稍不留心,就看错了,为了使数据看起来更有条理性,有的小伙伴常常会用筛选的功能实现数据之间的互换和操作。但是却很少…

scrcpy投屏_scrcpy 使用教程:将安卓设备投屏到 PC 端

阿拉平平读完需要6分钟速读仅需 2 分钟scrcpy 是一款开源的安卓设备投屏工具,通过 USB 或 Wi-Fi 与设备连接后就可以在 PC 端操作安卓设备,无需 root 权限且支持多平台运行。本文将演示如何使用 scrcpy 进行投屏操作。1. 下载安装到 Releases 下载最新的…

javap的用途不断发展:您的Java类文件中隐藏了什么?

什么是Javap,如何使用它以及何时要反汇编类文件? 作为Java开发工具包(JDK)的一部分,我们可以使用许多工具,这些工具有助于更好地理解Java代码。 这些工具之一是javap命令,它为我们提供了对Java…

打砖块小游戏php程序,利用原生js实现html5打砖块小游戏(代码示例)

本篇文章给大家通过代码示例介绍一下利用原生js实现html5打砖块小游戏的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。前言PS:本次项目中使用了大量 es6 语法,故对于 es6 语法不太熟悉的小伙伴最好能先了…

si9000阻抗匹配计算_如何在设计之初计算出两层PCB板差分线的阻抗,线宽,间距...

最近在设计一款两层板PCB。板上一些高速信号线,分别是MIMP接口的差分线和USB2.0的差分线。既然是高速线,那么就需要设计成阻抗匹配走线。MIMP差分线需要做100ohm匹配,USB线需要做90ohm匹配。差分线阻抗的计算主要跟线宽,间距&…

oracle查询排序速度慢,Oracle-请问Oracle SQL排序查询慢如何解决

这个原因很简单&#xff1a;SELECT * FROM(SELECT T.*,ROWNUM RN FROM(SELECT * FROM INFO ORDER BY PDATE DESC) T WHERE ROWNUM<2001) WHERE RN>0算一下&#xff0c;如果使用定义在PDATE上的索引&#xff0c;那么拿到这2000个rowid后&#xff0c;还需要做2000次random …

jax-ws cxf_Apache CXF – JAX-WS –简单教程

jax-ws cxf许多Java开发人员都认为Web Service实现的任务艰巨-好吧&#xff0c;没有人能真正责怪他们&#xff0c;尤其是在企业应用程序开发的多年中&#xff0c;这给开发和设计带来了很多复杂性。 对于某些人来说&#xff0c;了解它是构建完整的企业应用程序的下一步-Web服务-…

oracle instance client 下载,安装Oracle Instance Client

不想再装客户端了&#xff0c;个太大了。1、去下载你想要的Instance Clent版本&#xff0c;解压&#xff1b;2、把以前备份的sqlnet.oratnsnames.ora放在解压后的目录&#xff1b;3、配置环境变量变量名:TNS_ADMIN变量值:X:\XXXXXXXX\instantclient_10_24、用记事本保存为XX.re…

写屏障是什么_面试官为什么问内存模型总离不开final关键字,该如何应对?

Java 语言的每个关键字都设计的很巧妙&#xff0c;金雕玉琢&#xff0c;只有深度钻研其中&#xff0c;才知其中懊悔&#xff0c;本文带领大家一起深入理解 Java 内存模型之 final。加我微信好友的不要着急&#xff0c;手机没电了&#xff0c;等我借个充电器之后&#xff0c;再一…

非静态方法可以访问Java中的静态变量/方法吗?

“非静态方法可以访问静态变量或调用静态方法”是Java中有关静态修饰符的常见问题之一&#xff0c;答案是&#xff0c; 是的 &#xff0c;非静态方法可以访问静态变量或调用静态方法。 Java中的方法。 这没有问题&#xff0c;因为有静态成员&#xff0c;即静态变量和静态方法都…

php中$_post怎么用,php – 如何在$_POST []中使用变量

我需要遍历一堆动态生成的字段,但这不起作用&#xff1a;$population_density $_POST[$current_location_id];我有一个页面列表,其人口在一页上;我需要这样做,这样你就可以立刻更新它们.所以我使字段名称动态地对应于location_id.提交帖子时,我需要像这样迭代它们,但似乎你不能…

python输入字母终止_将用户输入限制为字母

我是学python的技术作家。我想写一个验证姓名字段输入的程序&#xff0c;作为实践&#xff0c;将用户输入限制为字母。我在这里看到了一个类似的验证数字(年龄)字段的代码&#xff0c;并将其用于字母表&#xff0c;如下所示&#xff1a;import stringimport rer re.compile(r[…