function V = nonconvex_orth2d_quad_L1(Q,P,lambda,Z)
HandleObj = @(V)0.5*vec(V)'*Q*vec(V) + mdot(V,P) + lambda* L1Norm(V*Z);
% Q = norm(Q)*eye(4);
% min_{V} HandleObj(V), s.t. V'V = I
eps = 2.2204e-16;
ZZ = abs(Z); norm1 = sqrt(sum(ZZ,1)); Z = Z(:, find(norm1>eps));
[V1,f1] = nonconvex_orth2d_quad_L1_R(Q,P,lambda,Z);
[V2,f2] = nonconvex_orth2d_quad_L1_F(Q,P,lambda,Z);
if(f1<f2)
    fprintf('1');
    V = V1;
else
    fprintf('2');
    V = V2;
end

function [V,fobj_best] = nonconvex_orth2d_quad_L1_R(Q,P,lambda,Z)
% 0.5*vec(V)'*Q*vec(V) + mdot(V,P) + lambda* L2Norm(V*Z)
% s.t. V = [c s;
%          -s c];
cof_r = Z(1,:)';
cof_s = Z(2,:)';
cof_p = Z(2,:)';
cof_u = -Z(1,:)';
cof_x = [cof_r;cof_p];
cof_y = [cof_s;cof_u];
cof_a = P(1,1) + P(2,2);
cof_b = P(1,2) - P(2,1);
cof_c =  0.5*Q(1,1)+ Q(1,4) + 0.5*Q(4,4);
cof_d =  - Q(1,2) + Q(1,3) -Q(2,4) + Q(3,4);
cof_e =  0.5*Q(2,2) - Q(2,3) + 0.5*Q(3,3);
%  [c,s,fobj_best] = nonconvex_quadratic_trigonometry_L1(cof_a,cof_b,cof_c,cof_d,cof_e,lambda,cof_x,cof_y);

  [c,s,fobj_best] =  nonconvex_quadratic_trigonometry_L1_cc(cof_a,cof_b,cof_c,cof_d,cof_e,lambda,cof_x,cof_y,length(cof_x));

%  HandleObj = @(c,s) cof_a*c + cof_b*s + cof_c*c*c + cof_d*c*s + cof_e*s*s + lambda*norm(c*cof_x + s*cof_y,1);
%  HandleObj(c,s) - fobj_best
%  '-------------'
% err = HandleObj(c,s) - HandleObj(c2,s2);
% if(abs(err)>1e-10)
%     HandleObj(c,s)
%     HandleObj(c2,s2)
%     ddd
%     end

 V = [c s;
    -s c];







function [V,fobj_best] = nonconvex_orth2d_quad_L1_F(Q,P,lambda,Z)
% 0.5*vec(V)'*Q*vec(V) + mdot(V,P) + lambda* L1Norm(V*Z)
% V \in V = [ -c s;
%             s c];
cof_r  = -Z(1,:)';
cof_s  =  Z(2,:)';
cof_p  =  Z(2,:)';
cof_u  =  Z(1,:)';
cof_x  = [cof_r;cof_p];
cof_y  = [cof_s;cof_u];
cof_c = 0.5*Q(1,1) - Q(1,4) + 0.5*Q(4,4);
cof_e = 0.5*Q(2,2) + Q(2,3) + 0.5*Q(3,3);
cof_d = - Q(1,2) - Q(1,3) +  Q(2,4) + Q(3,4);
cof_a  = -P(1) + P(4);
cof_b  =  P(2) + P(3);
 [c,s,fobj_best] =  nonconvex_quadratic_trigonometry_L1(cof_a,cof_b,cof_c,cof_d,cof_e,lambda,cof_x,cof_y);

% HandleObj = @(c,s) cof_a*c + cof_b*s + cof_c*c*c + cof_d*c*s + cof_e*s*s + lambda*norm(c*cof_x + s*cof_y,1);
% err = HandleObj(c,s) - HandleObj(c2,s2);
% if(abs(err)>1e-10)
%     HandleObj(c,s)
%     HandleObj(c2,s2)
%     ddd
%     end

V = [-c s;
    s c];
