for i=0:20
    error=0;
    for k=1:100
        error=error+testfig2(0.005*i,0);
    end
    i
    pass(i+1)=error/100;
end
for i=0:20
    error=0;
    for k=1:100
        error=error+testfig2(0.005*i,1);
    end
    i
    ac(i+1)=error/100;
end

x=0:0.005:0.1;
plot(x,ac,'r','LineWidth',1.7,'LineStyle','-')
hold on
plot(x,pass,'b','LineWidth',1.7,'LineStyle','--')
h=legend('active','passive');
x1=xlabel('noise margin \Delta');
y1=ylabel('average error');
set(h,'FontName','Times New Roman','FontSize',23,'FontWeight','normal')
set(x1,'FontName','Times New Roman','FontSize',23,'FontWeight','bold')
set(y1,'FontName','Times New Roman','FontSize',23,'FontWeight','bold')


function loss=testfig2(nr,option)
num_states=20;
num_actions=10;
num_actions2=3;
Noise_rate=nr;
dim_R=5;
[P]=randfixedsum(num_states,num_actions,1,0,1)';
w_imp=spheredist(1,dim_R)'; % underlying reward;
w_imp=w_imp/norm(w_imp,2);
Phi=zeros(dim_R,num_states*num_actions2);
for i=1:num_states
    for j=1:num_actions2
        R1=spheredist(1,dim_R)';
        while R1' * w_imp < 6 * Noise_rate && R1' * w_imp > - 6 * Noise_rate
             R1=spheredist(1,dim_R)';  
        end
        R1=R1*inv((discretesample(ones(1,3),1)));
        Phi(:,num_actions2*(i-1)+j)=R1;
    end
end
loss=testtt(2000,100,P,w_imp,Phi,option); 
end