%% Sampling for upper bound
clear fval
clc
 
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=3/255;


% fileID = fopen('img_data.txt', 'r');
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

    x=X(Img_index,:);
    x0=x(:);
    W=A; 
    bias=b;
    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,:);

    [fval(Img_index),x]=Sampling_For_UB(W,bias,x0,f,eps_tol,inf);
    fval(Img_index)=Robust_bound+fval(Img_index);
    fval

end


