function [x, histroy,iter,NumEvaFun,hist,NumEvaPro]=SpectralGradient_Monotone(x,HandleObj,HandlePro,opts)
opts.xtol = 1e-14;
opts.gtol = 1e-14;
opts.ftol = 1e-15;
% opts.maxIter=1000;

% opts.xtol = 1e-5;
% opts.gtol = 1e-5;
% opts.ftol = 1e-6;

[n,k]=size(x);
NumEvaFun=0;
NumEvaPro=0;
ftol=opts.ftol;
gtol=opts.gtol;
xtol=opts.xtol;
% opts.maxIter=min(opts.maxIter,1000);

memory=5;
stop_seq_x=1e10*ones(memory,1); % store |X_k-X_k+1|_F / sqrt(n)
stop_seq_f=1e10*ones(memory,1); % store (abs(histroy(iter-1) - histroy(iter)) / (1+ abs((histroy(iter-1))))        

M = 1 ;
alpha_min = 1e-2;
alpha_max = 1e4;
gama = 1e-3;
sita1=0.2;
sita2=0.8;

% alpha_min = 1e-15;
% alpha_max = 1e15;

hist=[];histroy=[];
timebegin=cputime;

[F,G]=HandleObj(x);
histroy(1)=F;
hist(1)=cputime-timebegin;
NumEvaFun=NumEvaFun+1;
%    alpha = 0.5 / norm(G,'fro');
   alpha = 1;

%% The main program
    for iter=1:opts.maxIter,  
        
      D = HandlePro(x-alpha*G) - x; NumEvaPro=NumEvaPro+1;
       
      %%%%%%%% Line Search to find optimal step lambda %%%%%%%%
      tend=(iter);
      tbegin =max(1,iter - M +1);
 %      fprintf('iter:%d, begin:%d->end:%d\n',iter,tbegin,tend);
      f_max = max(histroy(tbegin : tend));

      x_plus = x + D;
      yita = sum(dot(G,D,1)); lambda =1;
      inner=0;
       while 1
            inner=inner+1;
            [F_plus,G_plus]=HandleObj(x_plus);NumEvaFun=NumEvaFun+1;
            out = F_plus - f_max - gama * lambda*yita;
            if(out<=0 || inner>=50),break;end
            lambda_temp = (-0.5 * lambda*lambda*yita) / (F_plus - f_max -  lambda*yita);
            if(lambda_temp>=sita1 && lambda_temp <= sita2*lambda)
                lambda=lambda_temp;
            else
                lambda=lambda/2;
            end
           x_plus = x + lambda*D;
       end
 
      %%%%%%%% Line Search to find optimal step lambda %%%%%%%%
        x = x_plus;
        s = lambda*D;  
        s_norm = norm(s,'fro');% s_norm=diff_norm, s_norm = sqrt(tr(s's)) 
        y = G_plus - G;
        G = G_plus;
        F_plus
        histroy(iter+1)=F_plus;
        hist(iter+1)=cputime-timebegin;
         b = sum(dot(s,y,1));
        if(b<=0)
            alpha=alpha_max;
        else
%             alpha_temp = trace (s'*s);
            alpha_temp = s_norm^2;
            alpha = min(alpha_max,max(alpha_min,alpha_temp/b));
        end
        
 FDiff = abs(histroy(iter) - histroy(iter+1)) / (1+ abs((histroy(iter))));
 XDiff = s_norm / sqrt(n);      
   if iter <= memory
                stop_seq_f(iter) = FDiff;        
                stop_seq_x(iter) = XDiff;        
   else
                stop_seq_f  = [stop_seq_f(2:end); FDiff];        
                stop_seq_x  = [stop_seq_x(2:end); XDiff];      
   end
% sqrt(lambda)
% norm(D,'fro')-(s_norm/sqrt(lambda))
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
last_k_xtol=mean(stop_seq_x);
last_k_ftol=mean(stop_seq_f);
if ( XDiff < xtol && FDiff < ftol ) || s_norm < gtol || all( [last_k_xtol,last_k_ftol] < 10*[xtol, ftol])  
if(histroy(end)<histroy(1)),break;end
end 
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
  
    end
  if(~checkdec(histroy)),
       error('NonDesc');
  end
   if(histroy(end)>histroy(1))
       histroy
       plot(histroy)
       error('NonDesc');
  end
 
