function Reward=WhittleOracle1(N, M, P0, P0next, P0prev, P1, P1next, P1prev, H, gamma, R, T)
Reward=zeros(1,T);
Whittle=zeros(N, length(R));
for t=1:T
    state=ones(1, N);
    for i=1:N
    Whittle(i,:)=WhittleIndex1(R, P0(i, t), P0next(i, t), P0prev(i, t), 0, P1(i, t), P1next(i, t), P1prev(i, t), 0,  gamma);
    end
    for h=1:H
        a=zeros(1, N);
        for i=1:N
           W(i)=Whittle(i,state(i));
        end
        [~, index]=maxk(W, M);
        a(index)=1;
        for i=1:N
            s=state(i);
            randnumber=rand;
            if a(i)==1
                if randnumber<=P1(i, t)
                    state(i)=state(i);
                elseif randnumber>P1(i, t) && randnumber<=P1(i, t)+P1next(i, t) 
                    if s<length(R)
                       state(i)=state(i)+1;
                    else
                        state(i)=state(i);
                    end
                else
                    if s>1
                       state(i)=state(i)-1;
                    else
                        state(i)=state(i);
                    end
                end
            else
                if randnumber<=P0(i, t)
                    state(i)=state(i);
                elseif randnumber>P0(i, t) && randnumber<=P0(i,t)+P0next(i, t)
                    
                    if s<length(R)
                       state(i)=state(i)+1;
                    else
                        state(i)=state(i);
                    end
                else
                    
                    if s>1
                       state(i)=state(i)-1;
                    else
                       state(i)=state(i);
                    end
                end
            end
        end
        for i=1:N
        Reward(t)=Reward(t)+gamma^(h-1)*R(state(i));
        end
    end
end 