%% Compute bounds from Grb with input bound
clear
clc

NetDataPath=[pwd '\data\net_data__19.07.txt'];
NetDataPath=[pwd '\data\net_data_2x500.txt'];
fileID = fopen( NetDataPath, 'r');
json_text = fread(fileID, '*char').';
fclose(fileID);
% decoding JSON
data = jsondecode(json_text);
A=data.A;

b=data.b;

eps_tol=5/255;
% When eps_tol is too small, all of the nodes may be deterministic, implying that the network is robust. 

fileID = fopen('img_test_data.txt', 'r');
json_text = fread(fileID, '*char').';
fclose(fileID);
Img_data = jsondecode(json_text);
X=Img_data.img;
Train_Label=Img_data.img_lb;




for i=1:length(A)
    A_nv=A{i};
    A_nv=vecnorm(A_nv,inf,2);
    A_nv=1./A_nv;
    A{i}=diag(A_nv)*A{i};
    b{i}=diag(A_nv)*b{i};
end


for Img_index= [ 1:100]
    disp(Img_index)
    x=X(Img_index,:);
    x0=x(:);


    bias=b;

    W=A;
    W(end)=[];
    bias(end)=[];
    [~,o]=RunBNN(W,bias,x0);
    y=A{end}*o{end}+b{end};


    [~,y_order]=sort(y,'descend');
    T_label=y_order(1);
    Att_label=y_order(2);
    f=A{end}(T_label,:)-A{end}(Att_label,:);
    Robust_bound=b{end}(T_label)-b{end}(Att_label,:);


    f=double(f);





    Lb=-1+0*x0;
    Ub= 1+0*x0;
    [As,bs,fs,cs,Index_pos,Index_neg,bound_L,bound_U]=Prob2std_prob_l2_with_bound(W,bias,x0, eps_tol,f,Lb,Ub);

    for i=1:length(As)
        Ap{i}=double(As{i});

    end


    for i=1:length(bs)
        bp{i}=double(bs{i});
    end

    obj_F=fs;
    obj_F=double(obj_F);


    imshow(reshape(x0,[28,28]))
    disp('T_label=')
    disp(T_label)



    if ((1+Train_Label(Img_index))~=T_label)
        disp('Wrong Classification')
        continue
    end
    pause(1e-5);


    % Ap


    % disp([cs+Robust_bound])   % cs: deterministic nodes from the Last hidden layer that are added to the bias from the obj_f



    [fval(Img_index),xp,fp,intcon,Mp,vp,time(Img_index),output{Img_index}]=Grb_sof_Fesiable_L2(Ap,bp,obj_F,1e-7,cs+Robust_bound,bound_L,bound_U);
    % fval

    % time
end
