%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%% This script is used to obtain results for graph sparsity 
%%%% Junzhou Huang, Tong Zhang, Dimitris Metaxas "Learning with Structured Sparsity"
%%%% By Junzhou Huang, Rutgers University,jzhuang@cs.rutgers.edu
%%%% Jan., 2009    Updated  Dec. 20, 2009
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
clc;clear; close all;
%%% parameters
load ImgMask1;
[T, WI]=size(ImgMask1);
[H, W, P]=size(ImgMask1{1,1});
n=H*W;
Edge4=Edge4Index(H, W);
[B, Bm]=GetBlocksMatrix(H,W,1);
% [BC, BCm]=GetBlocksConnectionMatrix(Bm, Edge4);
mq=size(Bm, 1); clear B; clear BC;

% save BCm BCm; save Bm Bm;

load BCm; load Bm;

% m_num=[1.5 2 2.5 3 3.5 4];
m_num=[2];

for j=1:length(m_num),
      fprintf('j=%d\n', j);
    for bgb=1:1,
        fprintf('bgb=%d\n', bgb);

    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    %%% step 1: Get DG(K, q)-sparse 2D background substracted color images
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    bg=107;
    mask=ImgMask1{bg, 2}; bin=repmat(mask, [1, 1, P]);
    Img0=ImgMask1{bg, 1};
    x=double(Img0).*bin;
    figure; imshow(uint8(x), []); 
    
    K=length(find(x(:)>0))/P; 
    m=round(m_num(j)*K); q=4;
    m=600;
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    %%% step 2: Creating random projection matrix and measurements
    %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    x=reshape(x, [n, P]);
    for i=1:P
        A=randn(m,n);item=sqrt(sum(A.*A,2));A=A./repmat(item, [1,n]);
        AA{i}=A; e=randn(m,1); %e=e/norm(e(:));        
        y{i}=AA{i}*x(:,i)+0.01*e;
    end
    
%     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%     %%% step 3: Sparse recovery
%     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%    
  %%% method 1: OMP    
   tic;
   [xest, Rec1] = OMPlsc_mtCS(K,AA,y);
   xest1=reshape(xest, [H, W, 3]);
   time1=toc;

  %%%% step 2: group lasso
  AG=zeros(P*m, P*n);
  groups=[];
  for i=1:P,
      AG((i-1)*m+1:i*m,(i-1)*n+1:i*n)=AA{i};
      yg((i-1)*m+1:i*m,1)=y{i};
      groups=[groups, 1:n];
  end 
   
   tic;
   opts = spgSetParms('verbosity',0);
   xest    = spg_group(AG,yg,groups,0,opts);
   xest2=reshape(xest, [H, W, 3]);
   time2=toc;


 %%% method 1: StructOMP
    tic;
    lamada=1; cl0=lamada*q*log2(mq)+K;
    [xest, input1, norm_save1] = GraphOMP_mtCS(cl0,AA,y, Bm, BCm, lamada, []);
    xest3=reshape(xest, [H, W, 3]);
    time3=toc; 

%     %%%% Normalized Recovery Error
    diff1=norm(xest1(:)-x(:),2)/norm(x(:),2);
    diff2=norm(xest2(:)-x(:),2)/norm(x(:),2);
    diff3=norm(xest3(:)-x(:),2)/norm(x(:),2);
   
    result(:,bgb)=[diff1,diff2 diff3, time1, time2  time3];
%     result(:,bgb)=[diff1, diff3, time1,  time3];
    figure; imshow(uint8(reshape(x, [H,W,3])));
    figure; imshow(uint8(xest1));
    figure; imshow(uint8(xest2));
    figure; imshow(uint8(xest3));
end
CompareResults(:,j)=mean(result, 2)
CompareResultsStd(:,j)=std(result,0, 2);
end 
