function [fval,xp,fp,intcon,Mp,vp]=Grb_sof(A,b,obj_f,Bound_L,Bound_U,soft_tol)
if nargin==6
soft_tol=0;
end
n(1)=size(A{1},2);
for i=1:length(A)
    n(i+1)=size(A{i},1);
end

x=sym('x',[n(1),1]);
y=sym('y',[sum(n(2:end)),1]);
var=[x;y];
V{1}=x;
k=1;
for i=1:length(A)
    Y{i}=y(k:(k+n(i+1)-1));
    Y{i}=2*Y{i}-1;
    k=k+n(i+1);
end

S={V{:},Y{:}};


S_vec=[];
for i=1:length(S)
    S_vec=[S_vec;S{i}];
end

M_mat=[];
v_mat=[];


for i=1:length(A)
    disp(i)
    % z{i}=A{i}*S{i}+b{i};
    A_nv=A{i};
    A_nv=vecnorm(A_nv,1,2);
    % if not soft:
    % M=[S{i+1}-((2./(A_nv+b{i})).*(A{i}*S{i}+b{i})-1)==0;((2./(A_nv-b{i})).*(A{i}*S{i}+b{i})+1)-S{i+1}==0]; %M>=0
    % if soft:
    M=[S{i+1}-((2./(A_nv+b{i})).*(A{i}*S{i}+b{i})-1-soft_tol)==0;((2./(A_nv-b{i})).*(A{i}*S{i}+b{i})+1+soft_tol)-S{i+1}==0]; %M>=0
    M_sym{i}=M;
    [Mp,vp]=equationsToMatrix(M,var);
    M_mat=[M_mat;Mp];
    v_mat=[v_mat;vp];
end
 
Mp=double(M_mat);

vp=double(v_mat);
    
f=dot(obj_f,S{end});
[fp,cs]=equationsToMatrix(f==0,var);
fp=double(fp);
[xpt,fval_Lp]=linprog(fp,-Mp,-vp,[],[],Bound_L,Bound_U);
fval_Lp=fval_Lp-double(cs);
intcon=1:length(fp);

intcon(1:n(1))=[];


Bound_L_mod=Bound_L;


Bound_L_mod(intcon)=-0.1;
Bound_U_mod=Bound_U;
Bound_U_mod(intcon)=1.1;

disp('grb const:')

disp(double(cs));


 [fval,x,exitflag,output]=Groubi_MILP(fp,intcon,-Mp,-vp,[],[],Bound_L_mod,Bound_U_mod);
xp=x;
xp(intcon)=2*xp(intcon)-1;
fval=fval-double(cs);

end 