I_iteration=1000;
O_iteration=10;
a=0.01;

performance=zeros(I_iteration,O_iteration);
performance_2=zeros(I_iteration,O_iteration);
for o=1:O_iteration
    x=-5+10*rand;
    y=-5+10*rand;
    x_s=x;
    y_s=y;
    for i=1:I_iteration
        x0=x;
        y0=y;
        for j=1:1000
            x0=x0-a*(2*(x0-2)+4*(1-0.1*sin(x0))*y);
        end
        x_best=x0;
        for j=1:1000
            y0=y0-a*(2*(1+0.1*cos(y0))*(y0+0.1*sin(y0))+4*(x+0.1*cos(x)));
        end
        y_best=y0;
        dfx=2*(x-2)+4*(1-0.1*sin(x))*y;
        dgx=0.5*(2*(x-2)+4*(1-0.1*sin(x))*y_best);
        dfy=2*(1+0.1*cos(y))*(y+0.1*sin(y))+4*(x+0.1*cos(x));
        dgy=0.5*(2*(1+0.1*cos(y))*(y+0.1*sin(y))+4*(x_best+0.1*cos(x_best)));
        if dfx*dgx+dfy*dgy<0.9*(dfx^2+dfy^2)
            kt=0;
        elseif (dgx^2+dgy^2-dfx*dgx-dfy*dgy)^2/(dfx*dgx+dfy*dgy)^2>0.01
            kt=-2+(dfx*dgx+dfy*dgy)/(dgx^2+dgy^2);
        else
            kt=-1;
        end
        if rand<0.5
            x=x-a*(dfx+kt*dgx);
        else
            y=y-a*(dfy+kt*dgy);
        end
        performance(i,o)=dfx^2+dfy^2;
    end
    x=x_s;
    y=y_s;
    for i=1:I_iteration
        dfx=2*(x-2)+4*(1-0.1*sin(x))*y;
        dfy=2*(1+0.1*cos(y))*(y+0.1*sin(y))+4*(x+0.1*cos(x));
        if rand<0.5
            x=x-a*(dfx);
        else
            y=y-a*(dfy);
        end
        performance_2(i,o)=dfx^2+dfy^2;
    end
end


p1=varplot(performance);

set(gca, 'YScale', 'log')
hold on
p2=varplot(performance_2);
legend([p1,p2],{'IA-RBCD','BCD'})

xlabel('t')
ylabel('$$f-G_f$$','Interpreter','latex')