function [output] = FFDNet(img,imageNoiseSigma)
% This is the testing demo of FFDNet for denoising noisy color images corrupted by
% AWGN.
%
% To run the code, you should install Matconvnet first. Alternatively, you can use the
% function `vl_ffdnet_matlab` to perform denoising without Matconvnet.
%
% "FFDNet: Toward a Fast and Flexible Solution for CNN based Image
% Denoising" 2018/03/23
% If you have any question, please feel free to contact with me.
% Kai Zhang (e-mail: cskaizhang@gmail.com)

% clear; clc;

format compact;
global sigmas; % input noise level or input noise level map


folderModel = 'models';
folderTest  = 'testsets';
folderResult= 'results';


showResult  = 1;
useGPU      = 1;
pauseTime   = 0;

inputNoiseSigma = imageNoiseSigma;  % input noise level

load(fullfile('models','FFDNet_gray.mat'));%

net = vl_simplenn_tidy(net);

if useGPU
    net = vl_simplenn_move(net, 'gpu') ;%vl_simplenn_move ½«CNNÔÚCPUºÍGPUÖ®¼äÒÆ¶¯
end


label   = img;
    [w,h,c] = size(label); % 481*321*3

    
    if c == 3 %²ÊÉ«Í¼
        % add noise
%        randn('seed',0);
        %noise = bsxfun(@times,randn(size(label)),permute(imageNoiseSigma/255,[3 4 1 2]));
        input = single(label);
       
        
        if mod(w,2)==1 %¶ÔÐÐÈ¡Ä££¬Èç¹ûÐÐÊý²»ÄÜ±»2Õû³ý£¬¾Í°Ñ×îºóÒ»ÐÐµÄÇÐÆ¬ÖØ¸´¼ÓÔÚinputµÄÄ©Î²
            input = cat(1,input, input(end,:,:)) ;
        end
        if mod(h,2)==1%¶ÔÁÐÈ¡Ä£
            input = cat(2,input, input(:,end,:)) ;
        end
        
        % tic;
        if useGPU
            input = gpuArray(input); %ÀûÓÃgpuArray()º¯Êý½«Êý¾Ý´ÓCPU´«ÈëGPUÖÐ
        end

        
        % set noise level map
        sigmas = inputNoiseSigma/255; % see "vl_simplenn.m".
        
        % perform denoising
        res    = vl_simplenn(net,input,[],[],'conserveMemory',true,'mode','test'); % matconvnet default
        % res    = vl_ffdnet_concise(net, input);    % concise version of vl_simplenn for testing FFDNet
        %res    = vl_ffdnet_matlab(net, input); % use this if you did  not install matconvnet; very slow
        
        % output = input -res(end).x; % for 'model_color.mat'
        output = res(end).x;
        
        
        if mod(w,2)==1 %ÔÙ°Ñ¸Õ²Å¼ÓµÄ×îºóÒ»ÐÐºÍÒ»ÁÐÉáÈ¥
            output = output(1:end-1,:,:);
            input  = input(1:end-1,:,:);
        end
        if mod(h,2)==1
            output = output(:,1:end-1,:);
            input  = input(:,1:end-1,:);
        end
        
        if useGPU
            output = gather(output); %Èç¹ûÐèÒªµÄ»°£¬ÓÃgather()º¯Êý½«Êý¾Ý´ÓGPU´«»ØCPU
            input  = gather(input);
        end
        %toc;
             
    end
end



