24小时热门版块排行榜    

查看: 905  |  回复: 0

mh_chono

新虫 (初入文坛)

[求助] mean shift图像平滑算法bug求解

CODE:
function [ flt_img ] = msflt( img,sigma_s,sigma_r )
    k_constant = 1;%uniform kernel的常量
    sigma =0.1;%mean shift终止时的允许误差
    [r,c,p] = size(img);
    flt_img = zeros(r,c,p);
    %若输入图像是RGB彩色图像,将RGB图像转换成LAB颜色空间图像
    if p == 3
        if exist('applycform','file')
            img = applycform(img,makecform('srgb2lab'));
        else
            img = colorspace('Lab<-RGB',img);
        end
    end
   
    x = zeros(r*c,2+p);
    z = zeros(r*c,2+p);
    %将二维数据转换成一维数据
    if p == 3
        for i = 1:r
            for j = 1:c
                x((i-1)*c+j,:) = [i,j,img(i,j,1),img(i,j,2),img(i,j,3)];
            end
        end
    end
    if p == 1
        for i = 1:r
            for j = 1:c
                x((i-1)*c+j,:) = [i,j,img(i,j)];
            end
        end
    end
    %mean shift部分
    for i = 1:r*c
        
        pre_y = x(i,:);
        tmp_y = x(i,:);
        
        while 1 %计算某个点的收敛点
            pre_y = tmp_y;
            sum1 = zeros(1,p+2);
            sum2 = 0;
            axis_x = fix(tmp_y(1));
            axis_y = fix(tmp_y(2));
            for j = axis_x-sigma_s-1:axis_x+sigma_s+1        %计算偏移均值
                for k = axis_y-sigma_s-1:axis_y+sigma_s+1
                    if j > 0 && j <= r && k>0 && k <= c %&& j ~= fix((i-1)/c) + 1 && k ~= mod(i-1,c) + 1
                        m = (j-1)*c + k;
                        tmp1 = [pre_y(1)-x(m,1),pre_y(2)-x(m,2)]/sigma_s;
                        %tmp1 = [x(m,1),x(m,2)]/sigma_s;
                        %tmp1 = [x(i,1)-x(m,1),x(i,2)-x(m,2)]/sigma_s;
                        if p == 3
                            tmp2 = [pre_y(3)-x(m,3),pre_y(4)-x(m,4),pre_y(5)-x(m,5)]/sigma_r;
                        end
                        if p == 1
                            tmp2 = (pre_y(3)-x(m,3))/sigma_r;
                        end
                        tmp1 = tmp1.*tmp1;
                        tmp2 = tmp2.*tmp2;
                        if sum(tmp1(:)) <= 1 && sum(tmp2(:)) <= 1%采用uniform kernel
                            sum1 = sum1 + k_constant*x(m,:);
                            sum2 = sum2 + k_constant;
                        end
                    end
                end
            end
            tmp_y = sum1/sum2;
            tmp = tmp_y - pre_y;
            if abs(tmp) < sigma
                break;
            end
        end
        
        z(i,:) = tmp_y;
        a = fix((i-1)/c) + 1;
        b = rem(i-1,c) + 1;
        if p == 3
            flt_img(a,b,1) = tmp_y(3);
            flt_img(a,b,2) = tmp_y(4);
            flt_img(a,b,3) = tmp_y(5);
        end
        if p == 1
            flt_img(a,b) = tmp_y(3);
        end
        
    end
   
    if p == 3
        if exist('applycform','file')
            flt_img = applycform(flt_img,makecform('lab2srgb'));
        else
            flt_img = colorspace('RGB<-Lab',flt_img);
        end
    end
end

CODE:
%主函数
img = imread('cameraman.jpg');
T = img;
%img = img/255;
%flt_img = uint8(msflt(img,8,4));
flt_img = msflt(img,8,4);
figure;
imshow(img);
figure;
%imshow(flt_img);
imshow(mat2gray(flt_img));

回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 mh_chono 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料调剂 +6 匹克i 2026-03-23 6/300 2026-03-24 21:09 by greychen00
[考研] 材料与化工考研调剂 +7 孅華 2026-03-22 7/350 2026-03-24 21:04 by greychen00
[考研] 274求调剂 +5 顾九笙要谦虚 2026-03-24 5/250 2026-03-24 18:43 by jhhcooi
[考研] 材料学硕,求调剂 6+3 糖葫芦888ll 2026-03-22 7/350 2026-03-24 17:11 by hello七七
[考研] 291求调剂 +3 HanBeiNingZC 2026-03-24 3/150 2026-03-24 16:34 by barlinike
[考研] 305分求调剂(食品工程) +5 Sxy112 2026-03-21 7/350 2026-03-24 12:27 by 544594351
[考研] 一志愿哈工大,085400,320,求调剂 +3 gdlf9999 2026-03-24 3/150 2026-03-24 10:08 by 搏击518
[考研] 材料专硕英一数二306 +8 z1z2z3879 2026-03-18 8/400 2026-03-23 20:49 by baobaoye
[考研] 350求调剂 +6 weudhdk 2026-03-19 6/300 2026-03-23 15:47 by tangyuan0840221
[考研] 一志愿华中农业071010,总分320求调剂 +5 困困困困坤坤 2026-03-20 6/300 2026-03-22 17:41 by hxsm
[考研] 寻找调剂 +4 倔强芒? 2026-03-21 4/200 2026-03-22 16:14 by 木托莫露露
[考研] 275求调剂 +6 shansx 2026-03-22 8/400 2026-03-22 15:27 by barlinike
[考研] 求调剂 +7 Auroracx 2026-03-22 7/350 2026-03-22 12:38 by 素颜倾城1988
[基金申请] 山东省面上项目限额评审 +4 石瑞0426 2026-03-19 4/200 2026-03-22 08:50 by Wei_ren
[考研] 考研调剂 +3 呼呼?~+123456 2026-03-21 3/150 2026-03-21 20:04 by 无际的草原
[考研] 296求调剂 +4 www_q 2026-03-20 4/200 2026-03-21 17:26 by 学员8dgXkO
[考研] 材料学硕297已过四六级求调剂推荐 +11 adaie 2026-03-19 11/550 2026-03-20 21:30 by laoshidan
[考研] 求调剂 +3 @taotao 2026-03-20 3/150 2026-03-20 19:35 by JourneyLucky
[考研] 261求B区调剂,科研经历丰富 +3 牛奶很忙 2026-03-20 4/200 2026-03-20 19:34 by JourneyLucky
[考研] 【同济软件】软件(085405)考研求调剂 +3 2026eternal 2026-03-18 3/150 2026-03-18 19:09 by 搏击518
信息提示
请填处理意见