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上…

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

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

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.…

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

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

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

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

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

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

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

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

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

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

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

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

which oracle linux,(总结)Linux下Oracle11gR2的ORA-00845错误解决方法

PS:前些时间一台演示环境的Oracle 11g for Linux不知什么原因,启动不起来,报错ORA-00845。搜索了下,这个问题是由于设置SGA的大小超过了操作系统/dev/shm的大小。当时解决了没空写总结,今天有点空,总结分享…

oracle存储过程深入,深入了解oracle存储过程的优缺点

定义:存储过程(Stored Procedure )是一组为了完成特定功能的SQL 语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程…

如何在Java 8中使用LocalDateTime格式化/解析日期-示例教程

Java项目中的常见任务之一是将日期格式化或解析为String,反之亦然。 解析日期表示您有一个表示日期的字符串,例如“ 2017-08-3”,并且要将其转换为表示Java中日期的对象,例如Java 8之前版本中的java.util.Date以及LocalDate或Loca…

如何获取当前刀具号_数控刀具的选用原则,如何使用数控刀具?一文全面介绍数控刀具...

数控刀具选用概述学习数控相关知识,最基础的是认识和了解刀具的材料以及选用原则,我们应当了解数控刀具的种类及特点、如何正确选择和使用数控加工刀具;学会根据被加工材料来合理选择数控刀具的材料和切削参数。选用原则:数控车床…

Java命令行界面(第27部分):cli-parser

CLI Parser最初托管在Google Code上,现在已存档在Google Code上 ,现在可以在GitHub上使用 。 归档的Google Code项目页面将CLI解析器描述为“使用非常简单,非常小的依赖项”,它使用注释“使非常简洁的主要方法不需要知道如何解析带…

使用2.26内核的linux,介绍linux 2.6.9-42内核升级到linux 2.6.26-42的方法

介绍linux 2.6.9-42内核升级到linux 2.6.26-42的方法来源:互联网作者:佚名时间:2013-04-10 13:32这篇升级Linux内容的文章,是基于Red Hat的Linux版本,从linux 2.6.9-42内核升级到linux 2.6.26-42的方法,对于…

Java命令行界面(第1部分):Apache Commons CLI

尽管我通常使用Groovy编写要从命令行运行的JVM托管脚本,但是有时候我需要解析Java应用程序中的命令行参数,并且有很多库可供Java开发人员用来解析命令行参数。 在本文中,我将介绍这些Java命令行解析库中最著名的一种: Apache Comm…

丙烯怎么做成流体丙烯_韧性好强度高的聚丙烯复合材料怎么做?让人工智能来帮忙...

01背景介绍聚丙烯(PP)是一种应用广泛的通用塑料,价格便宜、力学性能好、热稳定性高,在机械、汽车、电子电器、建筑、纺织、包装和食品工业等领域应用广泛。聚丙烯韧性和冲击强度不高,限制了它的应用。加入热塑性弹性体(TPE),如苯乙…

vivado安装_Vivado下载与安装指南

Vivado下载与安装指南目前,vivado已推出2019.1版本,实验室所安装的为2018.3版本,由于软件向下兼容的特性,建议安装2018版本,若安装2019版本,请自带笔记本,安装过程与之前没有差别,这…