function [X, iter, min_cost,E] = DSP_Solving2(grad, proj,U_E, Xinit,Einit, L, opts, calc_F,X1)  


    ifplot = opts.ifplotLoss;
    min_cost = inf;
    ttemp = [];
    Linv = 1/L;    
    lambdaLiv = opts.lambda*Linv; % lambda/L;
    
        %% MAIN LOOP   
    opts_proj = opts;
    opts_proj.lambda = lambdaLiv;
    
    opts_proj2 = opts;
    opts_proj2.lambda = opts.mu;
    
    x_old = Xinit;
    y_old = Xinit;
    E_old = Einit; 
    t_old = 1;
    iter = 0;
   %%
   % proj = L1 solution------solving  X = argmin_X 0.5*||X - U|| + lambda||X||_1 
   % ------>                          X = feval(proj, U, lambda)  
   % grad = M'*M*X + M'*E;
   % U_E =  -M*X;
    while  iter < opts.max_iter
        iter = iter + 1;
        PL = y_old - Linv*feval(grad, y_old,E_old);
        x_new = feval(proj, PL, opts_proj);
        x_new = SphereProj(x_new);
        x_new= OrthProj(X1,x_new) ;
        DX    = feval(U_E, x_new); 
        
 %%
          E_new = feval(proj, DX, opts_proj2);           
   
% E_new = Einit;
         t_new = 0.5*(1 + sqrt(1 + 4*t_old^2));
        
         dx = (x_new - x_old);

         y_new = x_new + (t_old - 1)/t_new * dx;
         y_new = SphereProj(y_new);
         y_new = OrthProj(X1,y_new);
         
        %% check stop criteria
        
        e = norm1(dx)/numel(x_new);
%         e = norm2_cols(x_new - x_old);

          if iter> 50 && mod(iter,10) == 0 && opts_proj2.lambda >=0.02
            opts_proj2.lambda = opts_proj2.lambda.*0.98;           
            if e > 1e-4 
                opts_proj2.lambda = opts_proj2.lambda.*0.98;
            end            
         end

%        if ifplot ==1 && mod(iter,10) == 0 %|| iter==opts.max_iter ||e < opts.tol
%         aaaa0 = opts_proj2.lambda;
% %         opts_proj2.lambda = aaaa0.*0.95;
%        aaaa =  [DX,E_new,DX-E_new];
%         figure(33), plot(DX,'b.'), ylabel('MX'), hold on;
%          line([0,length(DX)],[-aaaa0,-aaaa0],'Color',[.8 .1 .1]); 
%         line([0,length(DX)],[aaaa0,aaaa0],'Color',[.8 .1 .1]); hold off
%         set(gcf,'position',[100 400 500 500]);  
%         drawnow; 
%         
%         figure (44),plot(DX-E_new,'b.'), ylabel('MX-E');
%         set(gcf,'position',[100 100 300 300]);  
%         drawnow; 
%         
%        end
  
        if e < opts.tol
            break;
        end
        
%   CC = feval(calc_F, x_old,E_old,opts.lambda,opts_proj2.lambda); % calc_F(X,E,lambda,mu)
  %% update
      ttemp = [ttemp,x_old];
        x_old = x_new; 
        t_old = t_new;
        y_old = y_new;
        E_old = E_new;
        %%

  
  X = x_old;
  E = E_old;
    

% min_cost = feval(calc_F, X, E, opts.lambda,opts_proj2.lambda);

% if ifplot==1
%    temp= [iter-1,iter]';
% figure(55),plot(temp, [CC,min_cost]','r-');  
% set(gcf,'position',[600 400 500 500]);  
% hold on;    drawnow;
% 
% figure(66),h1 = plot(ttemp'); 
% set(gcf,'position',[1100 400 500 500]);  
% end



    end
 min_cost = feval(calc_F, X, E, opts.lambda,opts_proj2.lambda);
%% plot results   
% if ifplot==2
%     aaaa0 = opts_proj2.lambda;
% %         opts_proj2.lambda = aaaa0.*0.95;
%        aaaa=  [DX,E_new,DX-E_new];
%         figure(333), plot(DX,'b.'), ylabel('MX'), hold on;
%          line([0,length(DX)],[-aaaa0,-aaaa0],'Color',[.8 .1 .1]); 
%         line([0,length(DX)],[aaaa0,aaaa0],'Color',[.8 .1 .1]); hold off
%         set(gcf,'position',[100 400 500 500]);  
%         drawnow; 
%         
%         figure (444),plot(DX-E_new,'b.'), ylabel('MX-E');
%         set(gcf,'position',[100 100 300 300]);  
%         drawnow; 
% end
        
end
