function [l,u,x_g,psi_g] = BisecBiO_initial(fun_f,fun_g,fun_h,grad_f,grad_g,x0,param)
% Initial bounds to get l,u

disp('Initial bounds start');
proxh = @(x) x;
opts.maxit = param.maxiter;
opts.tol = param.epsilonf;
opts.verbose = true;
opts.L_f = param.L_f;
opts.L_g = param.L_g;

opts.L0 = param.L_f;
[x_f, fval_f] = Greedy_FISTA(fun_f, fun_h, grad_f, proxh, x0, opts);
l = 0.001;
% l=max(fval_f-param.epsilonf,0.01);
% l = 0.01; %lower bound

opts.maxit = param.maxiter;
opts.tol = param.tol;
opts.verbose = true;
opts.L0 = param.L_g;
[x_g, psi_g] = Greedy_FISTA(fun_g, fun_h, grad_g, proxh, x0, opts);
u=fun_f(x_g)+1;% upper bound
disp('Initial bounds are solved!');
end