function demo_bps_l1norm_smooth
% min_{c,s} A*s + B*c + C*s*s + D*c*s + lambda*norm(s*x + c*y,1), s.t. c*c + s*s = 1;

clc;clear all;close all;
for iter = 1:10000000000000
    seed = iter; rand('seed',seed); randn('seed',seed);
    n = 110; lambda = rand(1,1)*100; x = randn(n,1).*(sign(randn(n,1))-1); y = randn(n,1).*(sign(randn(n,1))-1); 
    A = randn(1); B = randn(1)*10; C= randn(1)*10; D = randn(1)*10;
%     A=0; B=0;lambda=0.000001;
%      A=0; C=0;lambda=0.000001;



    
    
    HandleObj = @(t)A*sin(t) + B*cos(t) + C*sin(t)^2 + D*sin(t)*cos(t) + lambda*norm(sin(t)*x + cos(t)*y,1);

    HandleObj2 = @(c,s)A*s + B*c + C*s^2 + D*s*c + lambda*norm(s*x + c*y,1);
    options.MaxFunEvals = 5000000;
    options.MaxIter = 5000000;
    options.TolX = 1e-200;
    t0 = fminbnd(HandleObj,-1000,1000,options);
    f0 = HandleObj(t0);
    [c,s] = bps_l1norm_quadratic_v2(A,B,C,D,lambda,x,y);
    f1 =  HandleObj2(c,s);
    fprintf('iter:%d, cs:%.10e %.10e, %f %f %e\n',iter,cos(t0),sin(t0),f0,f1,f0-f1);
    if(f0 <f1 && abs(f0 - f1) > 0.0001)
        ddd
        ddd
    end
end



