close all; 
clear all;
clc; 

% measuring wall clock time

AoIBound=20; 
l=AoIBound;
d=0.1;
a=0.9;
gamma=0.9;
lambda=0.9;
transprob0=zeros(l,l);
transprob1=zeros(l,l);

%% Extended Value Iteration
for i=1:l
    for j=1:l
        if j==1
        prob1(i,j)=0.7;
        elseif j==i+1
        prob1(i,j)=0.3;
        prob0(i,j)=1;
        else
        prob0(i,j)=0;
        end
    end
end


V=zeros(1, l);

for iteration=1:1
for i=1:l
    [~, index]=sort(V, 'descend');
    for k=1:l
    transprob1(k,:)=estimateProb(V, index, prob1(k,:), d);
    transprob0(k,:)=estimateProb(V, index, prob0(k,:), d);
    end
    u=transprob1(i,:)';
    Q1=AoIfunction(i, a)+ gamma*(V*u)-lambda;
    u=transprob0(i,:)';
    Q0=AoIfunction(i, a)+ gamma*(V*u);
    V(i)=max(Q1, Q0);
end
end


%% With closed form eqn



V=zeros(1, l);

%% Extended Value Iteration
transprob1=prob1;
transprob0=prob0;
for i=1:l
    for j=1:l
        if j==1
        transprob1(i,j)=transprob1(i,j)+d/2;
        elseif j==i+1
        transprob1(i,j)=transprob1(i,j)-d/2;
        end
    end
end

tic
for iteration=1:1
for i=1:l
    u=transprob1(i,:)';
    Q1=AoIfunction(i, a)+ gamma*(V*u)-lambda;
    u=transprob0(i,:)';
    Q0=AoIfunction(i, a)+ gamma*(V*u);
    V(i)=max(Q1, Q0);
end
end
toc

% for iteration=1:20
% for i=1:l
%     u=transprob1(i,:)';
%     Q1=AoIfunction(i, a)+ gamma*(V*u)-lambda;
%     u=transprob0(i,:)';
%     Q0=AoIfunction(i, a)+ gamma*(V*u);
%     V(i)=max(Q1, Q0);
% end
% end

