24小时热门版块排行榜    

查看: 906  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +6 @taotao 2026-03-19 6/300 2026-03-25 08:37 by 木托莫露露
[考研] 考研调剂 +4 呼呼?~+123456 2026-03-24 4/200 2026-03-24 23:16 by barlinike
[考研] 0854AI CV方向招收调剂 +3 章小鱼567 2026-03-23 3/150 2026-03-24 20:25 by 汪!?!
[考研] 【考研调剂】化学专业 281分,一志愿四川大学,诚心求调剂 +15 吃吃吃才有意义 2026-03-19 16/800 2026-03-24 19:51 by 了了了了。。
[考研] 0854人工智能方向招收调剂 +3 章小鱼567 2026-03-24 3/150 2026-03-24 19:46 by zhouxuan..
[考研] 0854 考研调剂 招生了!AI 方向 +5 pk3725069 2026-03-19 17/850 2026-03-24 17:30 by zhouxuan..
[考研] 306求0703调剂一志愿华中师范 +10 纸鱼ly 2026-03-21 11/550 2026-03-24 17:22 by qingfeng258
[考研] 材料专业求调剂 +11 hanamiko 2026-03-18 11/550 2026-03-23 23:12 by peike
[论文投稿] 急发核心期刊论文 +3 贤达问津 2026-03-23 5/250 2026-03-23 17:13 by 妹子不好惹
[考研] 求老师收我 +3 zzh16938784 2026-03-23 3/150 2026-03-23 12:56 by ztnimte
[考研] 352求调剂 +3 大米饭! 2026-03-22 3/150 2026-03-22 23:28 by king123!
[考研] 材料与化工085600,总分304,本科有两篇sci参与,求调剂 +4 幸运的酱酱 2026-03-22 5/250 2026-03-22 20:15 by edmund7
[考研] 289求调剂 +7 怀瑾握瑜l 2026-03-20 7/350 2026-03-22 15:57 by ColorlessPI
[考研] 280求调剂 +11 咕噜晓晓 2026-03-18 12/600 2026-03-21 22:40 by ACS Nano——
[考研] 材料学硕301分求调剂 +7 Liyouyumairs 2026-03-21 7/350 2026-03-21 22:31 by peike
[基金申请] 学校已经提交到NSFC,还能修改吗? 40+4 babangida 2026-03-19 9/450 2026-03-21 16:12 by babangida
[考研] 332求调剂 +3 凤凰院丁真 2026-03-20 3/150 2026-03-21 10:27 by luoyongfeng
[考研] 求调剂 +6 Mqqqqqq 2026-03-19 6/300 2026-03-21 08:04 by JourneyLucky
[考研] 329求调剂 +9 想上学吖吖 2026-03-19 9/450 2026-03-20 22:01 by luoyongfeng
[考研] 295复试调剂 +8 简木ChuFront 2026-03-19 8/400 2026-03-20 20:44 by zhukairuo
信息提示
请填处理意见