【图像分割】基于各向异性热扩散方程的图像分割附matlab代码

1 简介

提出了一种基于各向异性扩散的图像分割算法.对现有的各向异性扩散的正则化方法进行了分析.根据微分几何中共形映射的有关理论,把原扩散方程分解为关于表面曲率的二阶方程,给出了分解式的正则化条件,保证了解的稳定性.通过对扩散系数的调节,提高了对各向异性扩散过程的控制能力.在形态学分割的基础上,通过能量函数最小化实现非线性尺度空间中的区域合并,消除了分水岭算法造成的严重过分割现象.实验结果表明,该算法的分割结果可为后续识别和理解提供较理想的方式.

2 部分代码

function [Normalized,X,Y] = AffineIm1(im, a, b, c, d, point1, point2)%分别对wndim的四个角进行仿射变换%f1,f2,f3,f4分别是目标图像的四个顶点Mysize = size(im);f1 = [a,0;0,a]*([cos(pi/b),-sin(pi/b);sin(pi/b),cos(pi/b)]*[1-point1,1-point2]');f2 = [a,0;0,a]*([cos(pi/b),-sin(pi/b);sin(pi/b),cos(pi/b)]*[1-point1,Mysize(1,2)-point2]');f3 = [a,0;0,a]*([cos(pi/b),-sin(pi/b);sin(pi/b),cos(pi/b)]*[Mysize(1,1)-point1,1-point2]');f4 = [a,0;0,a]*([cos(pi/b),-sin(pi/b);sin(pi/b),cos(pi/b)]*[Mysize(1,1)-point1,Mysize(1,2)-point2]');f1(1,1) = round(f1(1,1)+c);f1(2,1) = round(f1(2,1)+d);f2(1,1) = round(f2(1,1)+c);f2(2,1) = round(f2(2,1)+d);f3(1,1) = round(f3(1,1)+c);f3(2,1) = round(f3(2,1)+d);f4(1,1) = round(f4(1,1)+c);f4(2,1) = round(f4(2,1)+d);%找出被仿射后图像的外接矩形minx = min([f1(1,1),f2(1,1),f3(1,1),f4(1,1)]);maxx = max([f1(1,1),f2(1,1),f3(1,1),f4(1,1)]);miny = min([f1(2,1),f2(2,1),f3(2,1),f4(2,1)]);maxy = max([f1(2,1),f2(2,1),f3(2,1),f4(2,1)]);flagx = 1;flagy = 1;for i = minx:maxx    flagy = 1;    for j = miny:maxy        orco = inv([cos(pi/b),-sin(pi/b);sin(pi/b),cos(pi/b)])*([1/a,0;0,1/a]*([i,j]'-[c,d]'))+[point1,point2]';        if orco(1,1)<1 | orco(1,1)>Mysize(1,1) | orco(2,1)<1 | orco(2,1)>Mysize(1,2)            Normalized(flagx,flagy) = 0;        else            m = floor(orco(1,1));            n = floor(orco(2,1));            u = orco(1,1)-m;            v = orco(2,1)-n;%             if u>0.5 & v>0.5%                 Normalized(flagx,flagy) = wndim(m+1,n+1);%             elseif u>0.5 & v<0.5%                 Normalized(flagx,flagy) = wndim(m+1,n);%             elseif u<0.5 & v>0.5%                 Normalized(flagx,flagy) = wndim(m,n+1);%             elseif u<0.5 & v<0.5%                 Normalized(flagx,flagy) = wndim(m,n);%             end            Normalized(flagx,flagy) = round((1-u)*(1-v)*im(m,n) + (1-u)*v*im(m,n+1) + u*(1-v)*im(m+1,n) + u*v*im(m+1,n+1));        end        flagy = flagy+1;    end    flagx = flagx+1;endX = abs(minx);Y = abs(miny);% mysize = min([maxx-minx,maxy-miny]);% hlfsize = floor((mysize+1)/2)-5;% hlfsize = 30;% Normalized = Normalized(Xw(1,1)-hlfsize:Xw(1,1)+hlfsize,Xw(2,1)-hlfsize:Xw(2,1)+hlfsize);% % Temp = Temp(Xw(1,1)-hlfsize:Xw(1,1)+hlfsize,Xw(2,1)-hlfsize:Xw(2,1)+hlfsize);% [w,h] = size(Normalized);% Xw = [floor(w/2)+1,floor(w/2)+1]';

3 仿真结果

4 参考文献

[1]彭启民, 贾云得. 基于各向异性扩散的图像分割算法[J]. 北京理工大学学报, 2005, 25(4):4.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

matlab科研助手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值