当前位置: 首页 > news >正文

MATLAB 实现图像边缘检测与轮廓提取(Canny、Sobel、Prewitt 算子对比)

MATLAB 实现图像边缘检测与轮廓提取(Canny、Sobel、Prewitt 算子对比)

  • Canny 算子:采用多阶段处理(高斯平滑、梯度计算、非极大值抑制、双阈值检测),边缘连续性好,抗噪声能力强;
  • Sobel 算子:基于一阶导数计算,对边缘的响应较强,但边缘较粗;
  • Prewitt 算子:与 Sobel 类似,但采用平均滤波,对噪声更敏感。

% 随机图像生成与边缘检测(纯程序生成,无需外部文件)
% 功能:生成包含几何形状和噪声的随机图像,使用多种算子进行边缘检测并对比clear; clc; close all;%% 1. 生成随机图像(512x512像素)
img_size = 512;
I = zeros(img_size);  % 初始化黑色背景% 随机生成3-5个矩形
num_rect = randi([3,5]);
for i = 1:num_rect% 随机位置和大小(避免超出边界)x1 = randi([50, img_size-100]);y1 = randi([50, img_size-100]);w = randi([30, 100]);h = randi([30, 100]);x2 = x1 + w;y2 = y1 + h;% 随机灰度值(100-200,区别于背景0)gray_val = randi([100, 200]);I(y1:y2, x1:x2) = gray_val;
end% 随机生成2-3个圆形
num_circle = randi([2,3]);
for i = 1:num_circle% 随机圆心和半径cx = randi([100, img_size-100]);cy = randi([100, img_size-100]);r = randi([20, 60]);% 生成圆形掩码[x, y] = meshgrid(1:img_size, 1:img_size);circle_mask = (x - cx).^2 + (y - cy).^2 <= r^2;% 随机灰度值(与矩形区分)gray_val = randi([50, 150]);I(circle_mask) = gray_val;
end% 添加随机噪声(模拟真实图像)
noise_strength = 10;  % 噪声强度
I = I + noise_strength * randn(size(I));
% 替换imclamp:用min和max限制像素值在0-255
I = max(min(I, 255), 0);  
I = uint8(I);  % 转为8位图像%% 2. 边缘检测(多种算子对比)
% Canny算子(抗噪声能力强)
edge_canny = edge(I, 'canny', [0.1, 0.3]);  % 双阈值设置% Sobel算子(水平+垂直)
edge_sobel = edge(I, 'sobel');% Laplacian算子(对噪声敏感,检测细节)
edge_laplacian = edge(I, 'log');  % 高斯-拉普拉斯%% 3. 结果可视化
figure('Position', [100, 100, 1200, 900]);% 原始随机图像
subplot(2, 2, 1);
imshow(I);
title('生成的随机图像(含矩形、圆形和噪声)');
set(gca, 'FontName', 'SimHei');% Canny边缘检测
subplot(2, 2, 2);
imshow(edge_canny);
title('Canny算子边缘检测结果');
set(gca, 'FontName', 'SimHei');% Sobel边缘检测
subplot(2, 2, 3);
imshow(edge_sobel);
title('Sobel算子边缘检测结果');
set(gca, 'FontName', 'SimHei');% Laplacian边缘检测
subplot(2, 2, 4);
imshow(edge_laplacian);
title('Laplacian算子边缘检测结果');
set(gca, 'FontName', 'SimHei');sgtitle('随机图像生成与边缘检测对比');%% 4. 轮廓提取(在原图上叠加Canny边缘)
figure('Position', [200, 200, 800, 800]);
imshow(I);
hold on;
% 提取边缘轮廓
[B, ~] = bwboundaries(edge_canny, 'noholes');
for k = 1:length(B)boundary = B{k};plot(boundary(:,2), boundary(:,1), 'r-', 'LineWidth', 1.2);  % 红色轮廓
end
title('原始图像叠加Canny边缘轮廓');
set(gca, 'FontName', 'SimHei');
hold off;

程序结果:

http://www.dtcms.com/a/525021.html

相关文章:

  • 个人网站建站的流程合肥网站建合肥网站建设找蓝领商务
  • 从golang从GMP模型到分布式架构:无锁化思想的高并发实践
  • 前端开发【工具函数】基于dayjs 封装的DateUtils工具函数,可以直接拿着使用
  • 【开源项目分享】JNSM1.2.0,支持批量管理的jar包安装成Windows服务可视化工具,基于Java实现的支持批量管理已经安装服务的可视化工具
  • 【Diffusion Model】IDDPM代码详解
  • 匿名网站建设系统重装后 怎么装wordpress
  • 建筑网站知名度字形分析网站
  • C++中的Aggregate initialization
  • 鸿蒙Harmony实战开发教学(No.8)-Hyperlink超链接组件基础到进阶篇
  • Ubuntu开启SSH
  • 郑州营销网站托管和淘宝同时做电商的网站
  • 删除网站备案百度搜索风云榜手机版
  • 枣庄市网站建设跨境电商亚马逊开店流程
  • 做网站还有市场吗苏州住建网站
  • 网站仿做软件wordpress 页面显示最新文章
  • C# 取消机制(CancellationTokenSource/CancellationToken)
  • 散列查找及性能分析的应用
  • 百日挑战之单词篇(第二天)
  • 香港首位范·克莱本国际钢琴大赛冠军 沈靖韬 签约环球音乐 即将推出全新独奏专辑
  • 网站托管工作室wordpress防止f12
  • 传播网站建设建筑涂料网站设计
  • 详解C++中的字符串流
  • 中建西部建设广通讯网站小程序制作需要多少钱一个
  • 石家庄有哪些公司可以做网站南通网站优化找哪家
  • 全面掌握PostgreSQL关系型数据库,pgAdmin 图形化客户端,笔记12
  • 怎么做地方门户网站桂林市区
  • (论文速读)开放词汇3D场景理解的掩蔽点-实体对比
  • 做网站是经典网站设计作品
  • C++进阶:继承
  • 网站 建设运行情况网站移动转换