【图像边缘检测】基于matlab GUI Sobel+Prewitt+Canny算子图像边缘检测(带面板)【含Matlab源码 1045期】
一、获取代码方式
获取代码方式1:
完整代码已上传我的资源:【图像边缘检测】基于matlab GUI Sobel+Prewitt+Canny算子图像边缘检测【含Matlab源码 1045期】
获取代码方式2:
通过订阅紫极神光博客付费专栏,凭支付凭证,私信博主,可获得此代码。
备注:
订阅紫极神光博客付费专栏,可免费获得1份代码(有效期为订阅日起,三天内有效);
二、Sobel、Prewitt、Canny算子简介
1 Sobel算子边缘检测算法
传统Sobel算子是边缘检测中常用的梯度幅度检测算子,该算子首先使用3×3的卷积模板对检测图像进行加权平均或邻域平均,然后通过一阶微分计算来检测图像的边缘。假设f(x,y) 表示为一幅函数图像,它在点f(x,y)处的梯度是一个矢量,定义为:
其中ᐁf(x,y)表示梯度的模,其值可按下式计算:
Sobel算子包含水平和垂直两个方向的卷积模板,如图1所示。
图1 传统Sobel算子模板
Sobel算子的具体步骤如下:
1)将水平和垂直方向的模板从左到右、从上到下遍历图像,模板的中心点对应于图像中相应的像素点。
2)对图像所有像素点组成的每个模板进行离散卷积运算。
3)将两个模板卷积运算结果的最大值替换中心像素点的灰度值,用pmax表示。
4)取恰当的阈值T进行二值化处理,若pmax≥T,则判定该像素点为图像的边缘,反之判定该像素点为背景区域。
2 Prewitt算法
它属于一阶微分算法的边缘检测,所用的是像素点四周邻点的灰度值,当边缘处的数值最大时,对边缘进行检测,将不合格的部分删掉,有利于图像噪点更加滑顺。它通过对图像空间的两个模板和图像进行邻域卷积运算,两个模板分辨对水平和垂直边缘实施检测。
对数字图像f(x,y),Prewitt算法的定义如下:
经典Prewitt算法理论内容是:如果像素点的灰度新值不小于阈值,则这些像素点都属于边缘点。也就是说,选用合适的阈值T,如果P(i,j)≥T,可得(i,j)就是边缘点,P(i,j)边缘图像。以上判断缺乏科学的依据,导致不能正确判断边缘点。通常情况下,噪声点有较高的灰度值,尤其是边缘点的幅值很小,会导致边缘不复存在。
3 Canny边缘检测算法
Canny边缘检测算法是由国外学者John F. Canny在1986年提出的,创立了边缘检测计算理论,解释如何实现图像的边缘检测。Canny算法定义了最优边缘准则满足的3个条件:1) 最优检测。算法能够尽可能多地标识出图像中的实际边缘,漏检真实边缘的概率和误检非边缘的概率都尽可能小;2) 最优定位准则。检测到的边缘点的位置距离实际边缘点的位置最近,或者是由于噪声影响引起检测出的边缘偏离物体的真实边缘的程度最小;3) 检测点与边缘点一一对应。算子检测的边缘点与实际边缘点应该是一一对应。
Canny边缘检测算法分为5个基本步骤:1) 应用高斯滤波平滑图像,消除噪声对边缘检测的影响;2) 找寻图像的强度梯度,通常采用一阶有限差分计算图像的梯度幅值和方向;3) 应用非极大值抑制消除边缘误检;4) 采用双阈值算法决定潜在的边界;5) 利用滞后技术来跟踪边界。
三、部分源代码
function varargout = guipic(varargin)
% GUIPIC MATLAB code for guipic.fig
% GUIPIC, by itself, creates a new GUIPIC or raises the existing
% singleton*.
%
% H = GUIPIC returns the handle to a new GUIPIC or the handle to
% the existing singleton*.
%
% GUIPIC('CALLBACK',hObject,eventData,handles,...) calls the local
% function named CALLBACK in GUIPIC.M with the given input arguments.
%
% GUIPIC('Property','Value',...) creates a new GUIPIC or raises the
% existing singleton*. Starting from the left, property value pairs are
% applied to the GUI before guipic_OpeningFcn gets called. An
% unrecognized property name or invalid value makes property application
% stop. All inputs are passed to guipic_OpeningFcn via varargin.
%
% *See GUI Options on GUIDE's Tools menu. Choose "GUI allows only one
% instance to run (singleton)".
%
% See also: GUIDE, GUIDATA, GUIHANDLES% Edit the above text to modify the response to help guipic% Last Modified by GUIDE v2.5 13-Mar-2021 17:27:58% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name', mfilename, ...'gui_Singleton', gui_Singleton, ...'gui_OpeningFcn', @guipic_OpeningFcn, ...'gui_OutputFcn', @guipic_OutputFcn, ...'gui_LayoutFcn', [] , ...'gui_Callback', []);
if nargin && ischar(varargin{1})gui_State.gui_Callback = str2func(varargin{1});
endif nargout[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
elsegui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT% --- Executes just before guipic is made visible.
function guipic_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject handle to figure
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)
% varargin command line arguments to guipic (see VARARGIN)% Choose default command line output for guipic
handles.output = hObject;% Update handles structure
guidata(hObject, handles);% UIWAIT makes guipic wait for user response (see UIRESUME)
% uiwait(handles.figure1);% --- Outputs from this function are returned to the command line.
function varargout = guipic_OutputFcn(hObject, eventdata, handles)
% varargout cell array for returning output args (see VARARGOUT);
% hObject handle to figure
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)% Get default command line output from handles structure
varargout{1} = handles.output;% --- Executes on button press in ok.
function ok_Callback(hObject, eventdata, handles)
% hObject handle to ok (see GCBO)
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)
global im
%选择图片路径
[filename,pathname]=...uigetfile({'*.jpg';'*.bmp';'*.gif'},'选择图片');
%合成路径加文件名
str=[pathname filename];
%读取图片
im=imread(str);
%使用第一个AXES
axes(handles.axes1);
%显示图片
imshow(im);% --- Executes on button press in pushbutton2.
function pushbutton2_Callback(hObject, eventdata, handles)
% hObject handle to pushbutton2 (see GCBO)
% eventdata reserved - to be defined in a future version of MATLAB
% handles structure with handles and user data (see GUIDATA)
close(gcf)% --- Executes when selected object is changed in uipanel1.
function uipanel1_SelectionChangeFcn(hObject, eventdata, handles)
% hObject handle to the selected object in uipanel1
% eventdata structure with the following fields (see UIBUTTONGROUP)
% EventName: string 'SelectionChanged' (read only)
% OldValue: handle of the previously selected object or empty if none was selected
% NewValue: handle of the currently selected object
% handles structure with handles and user data (see GUIDATA)
global im
%拿到选择按钮的名称
str=get(hObject,'string');
axes=(handles.axes1);
四、运行结果
五、matlab版本及参考文献
1 matlab版本
2014a
2 参考文献
[1] 蔡利梅.MATLAB图像处理——理论、算法与实例分析[M].清华大学出版社,2020.
[2]杨丹,赵海滨,龙哲.MATLAB图像处理实例详解[M].清华大学出版社,2013.
[3]周品.MATLAB图像处理与图形用户界面设计[M].清华大学出版社,2013.
[4]刘成龙.精通MATLAB图像处理[M].清华大学出版社,2015.
[5]胡文文,周日贵,范萍,李尧翀.基于Canny算法的量子图像边缘检测[J].郑州大学学报(理学版). 2020,52(04)
[6]刘源,夏春蕾.一种基于Sobel算子的带钢表面缺陷图像边缘检测算法[J].电子测量技术. 2021,44(03)
[7]翁振斌.基于Prewitt算法的图像边缘检测技术在瓷砖生产中的应用[J].九江学院学报(自然科学版). 2019,34(03)
【图像边缘检测】基于matlab GUI Sobel+Prewitt+Canny算子图像边缘检测(带面板)【含Matlab源码 1045期】相关推荐
- Matlab图像边缘检测Roberts\Sobel\Prewitt\Canny算子
确定图像中的物体边界的一种方法是先检测每个像素和其直接淋雨的状态已决定该像素是否确实处于一个物体的边界上.具有这种特性的像素被标记为边缘点.当图像中各个像素的灰度级用来反映各像素要求的程度时,这种图像 ...
- 【图像去噪】基于matlab GUI butterworth+中值+维纳+小波图像去噪【含Matlab源码 520期】
⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[图像去噪]基于matlab GUI butterworth+中值+维纳+小波图像去噪[含Matlab源码 520期] 获取代码方式2: ...
- 【物理应用】基于matlab GUI气象参数计算综合指标和IAQI【含Matlab源码 2116期】
⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[物理应用]基于matlab GUI气象参数计算综合指标和IAQI[含Matlab源码 2116期] 点击上面蓝色字体,直接付费下载,即可 ...
- 【目标检测】基于matlab GUI背景差分算法视频运动物体跟踪【含Matlab源码 1915期】
一.背景差分法和帧间差分法的车辆运动目标检测简介 1 引言 运动目标检测是从图像序列中检测运动目标.通过运动目标检测可以得到图像中的运动目标,获取图像中的运动信息.运动目标检测在医学辅助诊断.航天航空 ...
- 【图像分割】基于matlab GUI医学图像均值聚类+OUST+区域生长法图像分割【含Matlab源码 2210期】
一.图像分割简介 1 图像分割技术 图像分割 : 根据灰度 , 颜色 , 纹理等,将图像进行分割. 2 常用的分割技术 2.1 边缘检测法 边缘是图像的最重要的特征.边缘是指周围像素灰度有阶跃变化或屋 ...
- 【语音处理】基于matlab GUI低通滤波器语音信号加噪与去噪【含Matlab源码 1708期】
⛄一.语音处理简介(附课程作业报告) 1 语音信号的特点 通过对大量语音信号的观察和分析发现,语音信号主要有下面两个特点: ①在频域内,语音信号的频谱分量主要集中在300-3400Hz的范围内.利用这 ...
- 基于JavaWeb Mybatis+MVC(JSP + servlet + javabean)的高校就业管理系统(含项目源码)
基于JavaWeb Mybatis+MVC的高校就业管理系统 项目简介 基本功能简介 项目要求 概要设计 数据模型(E-R图) 数据库结构设计 主要页面展示 项目实现 创建项目 项目结构展示 项目关键 ...
- 【口罩识别】基于matlab GUI RGB滤波+YCbCr+肤色标定口罩识别【含Matlab源码 1895期】
⛄一.口罩识别简介 口罩规范佩戴识别是基于人脸口罩检测结果进行的,该部分的输入是人脸口罩检测的输出且是有佩戴口罩的人脸.首先,将人脸部分的图像提取出来:然后映射到YCrCb颜色空间并进行非线性变换,经 ...
- 【目标跟踪】基于matlab GUI帧差法结合卡尔曼滤波行人姿态识别【含Matlab源码 1127期】
⛄一.基于人体特征识别和卡尔曼滤波的行人跟踪算法简介 1 基于体型和行为姿态特征的人体识别算法 从红外图像中可以得到目标与背景之间的灰度级差别,从而区分出有生命特征的运动物体,但仅从亮度特征无法区别出 ...
- 【ACO三维路径规划】基于matlab GUI蚁群算法无人机三维路径规划【含Matlab源码 254期】
一.无人机简介 0 引言 随着现代技术的发展,飞行器种类不断变多,应用也日趋专一化.完善化,如专门用作植保的大疆PS-X625无人机,用作街景拍摄与监控巡察的宝鸡行翼航空科技的X8无人机,以及用作水下 ...
最新文章
- 【2013年总结】 向着IT前进
- 微信小程序页面左右滑动事件+回到顶部
- 【拔刀吧少年】之awk文本和数据处理编程语言
- ImportError: No module named 'keras.utils.visualize_util'
- C++笔记-设置cout输出数据的宽度和填充
- mysql system_time_zone乱码_解决mysql设置时区时的错误Unknown or incorrect time zone: 'Asia/Shanghai'...
- 库,表,记录的相关操作
- 24-语言入门-24-cigarettes
- PHP压缩CSS文件
- wps自动插入文献_WPS参考文献自动生成方法教程
- Android开发通知栏的那些事
- ACM大量习题题库及建议培养计划
- 计算机绘图快捷键,计算机绘图常用软件快捷键大全
- Spring 官宣:换掉 JVM!
- 基因编辑新进展:利用CRISPR/Cas9和iPSC技术构建出首个急性髓系白血病进展模型
- FreeBSD的优缺点分析(转载)
- Ubuntu-Budgie折腾记
- lnk306dn引脚功能_LNK306DN LED卤素灯驱动器开关电源
- 联想服务器pxe安装系统,PXE下无人值守配置阵列及安装CentOS7
- ABP学习一(.Net6 API 整合 ABP)