⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 perform_thresholding.sci.svn-base

📁 signal procesing toolbox
💻 SVN-BASE
字号:
function y = perform_thresholding(x, t, thresh, options)// perform_thresholding - perform hard or soft thresholding////   y = perform_thresholding(x, t, thresh, options);////   t is the threshold//   thresh is either 'hard' or 'soft' or 'semisoft' or 'strict' or 'largest' or 'block'.////   works also for complex data, and for cell arrays.////   if thresh is 'strict' then it keeps the t largest entry in each//   column of x.////   for block thresholding, you can set options.block_size to determing the//   block size.////   Copyright (c) 2006 Gabriel Peyreoptions.null = 0;if argn(2)==3 & isstruct(thresh)    options = thresh;     thresh = getoptions(options, 'thresh', 'hard');endif argn(2)<3    thresh = 'hard';endif 0 // iscell(x)    // for cell arrays    for i=1:size(x,1)        for j=1:size(x,2)            y(i,j) = perform_thresholding(x(i,j),t, thresh);        end    end    return;endthresh = lower(thresh);if isempty(thresh)    thresh = 'hard';endif strcmp(thresh,'hard')        y = perform_hard_thresh(x,t);elseif strcmp(thresh,'soft')        y = perform_soft_thresh(x,t);elseif strcmp(thresh,'semisoft')        y = perform_semisoft_thresh(x,t);elseif strcmp(thresh,'strict')        y = perform_strict_thresh(x,t);elseif strcmp(thresh,'largest')        y = perform_largest_thresh(x,t);elseif ( strcmp(thresh,'block') | strcmp(thresh,'block-hard') | strcmp(thresh,'block-soft') )        if strcmp(thresh, 'block')            thresh = 'block-soft';        end        bs = getoptions(options, 'block_size', 4);        y = perform_block_thresh(x,t,bs, thresh);elseif strcmp(thresh,'quantize')        y = perform_quant_thresh(x,t);else        error('Unkwnown thresholding thresh.');endendfunction////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function X = perform_largest_thresh(X,s)//// keep only the s largest coefficientsv = sort(abs(X(:))); // v = v($:-1:1,:);v = v(round(s));X = X .* (abs(X)>=v);endfunction////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function X = perform_strict_thresh(X,s)//// keep only the s largest coefficients in each column of Xv = sort(abs(X)); v = v($:-1:1,:);v = v(round(s),:);v = repmat(v, [size(X,1) 1]);X = X .* (abs(X)>=v);endfunction////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function y = perform_hard_thresh(x,t)t = t(1);y = x .* (abs(x) > t);endfunction////function y = perform_quant_thresh(x,t)t = t(1);y = floor(abs(x/t)).*sign(x);y = sign(y) .* (abs(y)+.5) * t;endfunction////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function y = perform_soft_thresh(x,t)if not(isreal(x))    // complex threshold    d = abs(x);    d(d<1e-10) = 1;    y = x./d .* perform_soft_thresh(d,t);    return;endif size(t)~=size(x)    t = t(1);ends = abs(x) - t;s = (s + abs(s))/2;y = sign(x).*s;endfunction////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function y = perform_semisoft_thresh(x,t)if length(t)==1    t = [t 2*t];endt = sort(t);y = x;y(abs(x)<t(1)) = 0;I = find(abs(x)>=t(1) & abs(x)<t(2));y( I ) = sign(x(I)) .* t(2)/(t(2)-t(1)) .* (abs(x(I))-t(1));////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////function y = perform_block_thresh(x,t,bs, thresh)n = size(x,1);if nb_dims(x)==2    p = size(x,2);    if length(bs)==1        bs = [bs bs];    end    [dX,dY,X,Y] = ndgrid(0:bs(1)-1,0:bs(2)-1,1:bs(1):n-bs(1)+1,1:bs(2):p-bs(2)+1);    I = X+dX + (Y+dY-1)*n;    H = reshape(x(I(:)),size(I));    v = mean(mean(abs(H).^2,1),2);     u = max(v(:),1e-15);     if strcmp(thresh, 'block-soft')        u = max(1-t^2 * u.^(-1),0);    else        u = (u>t^2);    end    u = reshape(u,size(v));    H = repmat(u,[bs(1) bs(2) 1 1]) .* H;elseif nb_dims(x)==1    [dX,X] = meshgrid(0:bs-1,1:bs:n-bs+1);    I = X+dX;    // reshape as block    H = x(I);    // threshold    v = mean(H.^2,1);     v = max(v,1e-15);    if strcmp(thresh, 'block-soft')        H = repmat(max(1-t^2./v,0),[bs 1]) .* H;    else        H = double( repmat(v>t^2,[bs 1]) ) .* H;    endelseif nb_dims(x)==3    y = x;    for i=1:size(x,3)        y(:,:,i) = perform_block_thresh(x(:,:,i),t,bs, thresh);    end    return;else    error('Wrong size');end// reconstructy = x; y(I(:)) = H(:); y = reshape(y,size(x));endfunction

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -