
reset;                # Title: Product Usage under Aging Effects: Learning and Earning using Markov Chains

option randseed'';    # estimation good if either T or N are not large 
                      # estimation bad if N large and data contains only long step observations (skewed)

param T default 50;   # number of states
param N default 1+1; # number of nodes in the chain (max 14 bei T=50, A=5)
param A default 5;    # number of usage actions
param K := T-1;       # number of probs to estimate in main bandmatrix
param R := 1;         # number of sim runs

param gap default 0.0;   # parameter G
param KKK default 1000;  # number of data observations

param Ny{n in 1..N-1} := if n>gap*(N-1) then KKK/(N-1-gap*(N-1)); # number of n-step training observations 

param KK:= sum{n in 1..N-1} Ny[n];  

param fs {i in 1..T,j in 1..T,a in 1..A} := if i=j<T then 1-0.5*(a+i)/(A+T)/(N-1)^0.5    
                             else if i=j-1 then 1-fs[i,i,a]     # main transition probabilities to be found
							 else if i=j=T then 1 else 0;       
							 
param pp_true{i in 1..T,a in 1..A} := fs[i,i,a];

param Pn{i in 1..T,j in 1..T,n in 1..N-1,a in 1..A} := if n=1 then fs[i,j,a]  # n steps forward true transition matrix
                                 else sum{k in 1..T} Pn[i,k,n-1,a]*fs[k,j,a];


param x {n in 1..N-1,i in 1..Ny[n],k in 1..2} default if k=1 then round(Uniform(0.5,T-0.5))  # state feature data 1-step
                                                             else round(Uniform(0.5,A+0.5)); # used (average) action

param p_true {i in 1..K,j in 1..T,n in 1..N-1,a in 1..A} := Pn[i,j,n,a];   # unknown true impact 3-step of P3 needed for sim

param z{n in 1..N-1,i in 1..Ny[n]} default Uniform(0,1);
param y{n in 1..N-1,i in 1..Ny[n]} default if x[n,i,1]=T then T 
                                      else min{ii in 1..T:sum{j in 1..ii} p_true[x[n,i,1],j,n,x[n,i,2]] > z[n,i]} ii;
				  				  			  
###########    structure of n-step transition Matrices Pn as function of p_k

var b {k in 1..K,a in 1..A} <=500, := Uniform(0,1);			    # beta coefficients (for logit probs)
var p {k in 1..K,a in 1..A} = exp(b[k,a])/(1+exp(b[k,a]));      # probs for main bandmatrix

#################    Diagonalisierung     #####################

#var zv{i in 1..K,j in i..K  ,a in 1..A} = prod{k in i..j}  (p[k,a]-1);       # lambda
#var nv{i in 1..K,j in i+1..K,a in 1..A} = prod{k in i+1..j}(p[i,a]-p[k,a]);  # theta
#var nu{i in 2..K,j in 1..i-1,a in 1..A} = prod{k in j..i-1}(p[i,a]-p[k,a]);  # kappa
                                          
#var U {i in 1..T,j in 1..T,a in 1..A}   = if j=1   then 1                                    # 1. Spalte
#                             else if j=i+1 then 1
#                             else if i>=j  then 0
#							 else               zv[i,j-2,a]/(if nu[j-1,i,a]=0 then 10^-9 else nu[j-1,i,a]) * (-1)^(i+j-1);      # rest rechts oben
					
#var Dn{i in 1..T,j in 1..T,n in 1..N-1,a in 1..A}   = if i=j=1 then 1 else if i=j then p[i-1,a]^n else 0;

#var V {i in 1..T,j in 1..T,a in 1..A}   = if i=1   then (if j=T then 1 else 0)   # 1. Zeile
#                             else if i=j+1 then 1						 
#							 else if i>j   then 0
#							 else if i=j=T then -1
#							 else if j=T   then zv[i,K,a]    /(if nv[i-1,K,a]=0 then 10^-9 else nv[i-1,K,a]) * (-1)^(i+j-1)     # letzte Spalte
#							 else               zv[i-1,j-1,a]/(if nv[i-1,j,a]=0 then 10^-9 else nv[i-1,j,a]) * (-1)^(i+j-1);    # rest rechts oben

#var Pnn{i in 1..T,j in 1..T,n in 1..N-1,a in 1..A} = sum{k in 1..T} U[i,k,a]*(if k=1 then 1 else p[k-1,a]^n)*V[k,j,a];

var P  {i in 1..T,j in 1..T,a in 1..A} = if i<T  then (if i=j then p[i,a] else if j=i+1 then 1-p[i,a])    # 1-step main matrix
                                                 else (if j=T then 1 else 0);

var Pnn1{i in 1..T,j in 1..T,a in 1..A} = P[i,j,a];  # n steps forward transition matrix  # bis N-1
#var Pnn2{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn1[i,k,a]*P[k,j,a];
#var Pnn3{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn2[i,k,a]*P[k,j,a];
#var Pnn4{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn3[i,k,a]*P[k,j,a];
#var Pnn5{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn4[i,k,a]*P[k,j,a];
#var Pnn6{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn5[i,k,a]*P[k,j,a];
#var Pnn7{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn6[i,k,a]*P[k,j,a];
#var Pnn8{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn7[i,k,a]*P[k,j,a];
#var Pnn9{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn8[i,k,a]*P[k,j,a];
#var Pnn10{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn9[i,k,a]*P[k,j,a];
#var Pnn11{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn10[i,k,a]*P[k,j,a];
#var Pnn12{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn11[i,k,a]*P[k,j,a];
#var Pnn13{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn12[i,k,a]*P[k,j,a];
#var Pnn14{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn13[i,k,a]*P[k,j,a];
#var Pnn15{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn14[i,k,a]*P[k,j,a];
#var Pnn16{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn15[i,k,a]*P[k,j,a];
#var Pnn17{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn16[i,k,a]*P[k,j,a];
#var Pnn18{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn17[i,k,a]*P[k,j,a];
#var Pnn19{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn18[i,k,a]*P[k,j,a]; 
#var Pnn20{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn19[i,k,a]*P[k,j,a];
#var Pnn21{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn20[i,k,a]*P[k,j,a];
#var Pnn22{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn21[i,k,a]*P[k,j,a];
#var Pnn23{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn22[i,k,a]*P[k,j,a];
#var Pnn24{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn23[i,k,a]*P[k,j,a];
#var Pnn25{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn24[i,k,a]*P[k,j,a];
#var Pnn26{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn25[i,k,a]*P[k,j,a];
#var Pnn27{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn26[i,k,a]*P[k,j,a];
#var Pnn28{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn27[i,k,a]*P[k,j,a];
#var Pnn29{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn28[i,k,a]*P[k,j,a];
#var Pnn30{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn29[i,k,a]*P[k,j,a];
#var Pnn31{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn30[i,k,a]*P[k,j,a];
#var Pnn32{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn31[i,k,a]*P[k,j,a];
#var Pnn33{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn32[i,k,a]*P[k,j,a];
#var Pnn34{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn33[i,k,a]*P[k,j,a];
#var Pnn35{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn34[i,k,a]*P[k,j,a];
#var Pnn36{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn35[i,k,a]*P[k,j,a];
#var Pnn37{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn36[i,k,a]*P[k,j,a];
#var Pnn38{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn37[i,k,a]*P[k,j,a];
#var Pnn39{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn38[i,k,a]*P[k,j,a];
#var Pnn40{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn49[i,k,a]*P[k,j,a];
#var Pnn41{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn40[i,k,a]*P[k,j,a];
#var Pnn42{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn41[i,k,a]*P[k,j,a];
#var Pnn43{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn42[i,k,a]*P[k,j,a];
#var Pnn44{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn43[i,k,a]*P[k,j,a];
#var Pnn45{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn44[i,k,a]*P[k,j,a];
#var Pnn46{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn45[i,k,a]*P[k,j,a];
#var Pnn47{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn46[i,k,a]*P[k,j,a];
#var Pnn48{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn47[i,k,a]*P[k,j,a];
#var Pnn49{i in 1..T,j in 1..T,a in 1..A} = sum{k in 1..T} Pnn48[i,k,a]*P[k,j,a];
                                                              
var Pnn{i in 1..T,j in 1..T,n in 1..N-1,a in 1..A} = if n=1 then Pnn1[i,j,a]
#                                      else if n=2 then Pnn2[i,j,a]
#									  else if n=3 then Pnn3[i,j,a]
#									  else if n=4 then Pnn4[i,j,a]
#									  else if n=5 then Pnn5[i,j,a]
#                                     else if n=6 then Pnn6[i,j,a]
#									  else if n=7 then Pnn7[i,j,a]
#									  else if n=8 then Pnn8[i,j,a]
#									  else if n=9 then Pnn9[i,j,a]
#									  else if n=10 then Pnn10[i,j,a]
#									  else if n=11 then Pnn11[i,j,a]									  
#                                     else if n=12 then Pnn12[i,j,a]
#									  else if n=13 then Pnn13[i,j,a]
#									  else if n=14 then Pnn14[i,j,a]
#									  else if n=15 then Pnn15[i,j,a]
#                                     else if n=16 then Pnn16[i,j,a]
#									  else if n=17 then Pnn17[i,j,a]
#									  else if n=18 then Pnn18[i,j,a]
#									  else if n=19 then Pnn19[i,j,a]
#									  else if n=20 then Pnn20[i,j,a]
#									  else if n=21 then Pnn21[i,j,a]									  
#                                     else if n=22 then Pnn22[i,j,a]
#									  else if n=23 then Pnn23[i,j,a]
#									  else if n=24 then Pnn24[i,j,a]
#									  else if n=25 then Pnn25[i,j,a]
#                                     else if n=26 then Pnn26[i,j,a]
#									  else if n=27 then Pnn27[i,j,a]
#									  else if n=28 then Pnn28[i,j,a]
#									  else if n=29 then Pnn29[i,j,a]
#									  else if n=30 then Pnn30[i,j,a]
#									  else if n=31 then Pnn31[i,j,a]									  
#                                     else if n=32 then Pnn32[i,j,a]
#									  else if n=33 then Pnn33[i,j,a]
#									  else if n=34 then Pnn34[i,j,a]
#									  else if n=35 then Pnn35[i,j,a]
#                                     else if n=36 then Pnn36[i,j,a]
#									  else if n=37 then Pnn37[i,j,a]
#									  else if n=38 then Pnn38[i,j,a]
#									  else if n=39 then Pnn39[i,j,a]
#									  else if n=40 then Pnn40[i,j,a]
#									  else if n=41 then Pnn41[i,j,a]									  
#                                     else if n=42 then Pnn42[i,j,a]
#									  else if n=43 then Pnn43[i,j,a]
#									  else if n=44 then Pnn44[i,j,a]
#									  else if n=45 then Pnn45[i,j,a]
#                                     else if n=46 then Pnn46[i,j,a]
#									  else if n=47 then Pnn47[i,j,a]
#									  else if n=48 then Pnn48[i,j,a]
#									  else if n=49 then Pnn49[i,j,a]
                                      ;												 
#var Pnn{i in 1..T,j in 1..T,n in 1..N-1,a in 1..A} = if n=1 then P1[i,j,a]  # n steps forward true transition matrix
#                             else sum{k in 1..T} Pnn[i,k,n-1,a]*P1[k,j,a];
		 
###########    logit optimality conditions    ###########

maximize LL: 1/T/KK*sum{n in 1..N-1} sum{i in 1..Ny[n]}
                      ( log(  max(Pnn[x[n,i,1],y[n,i],n,x[n,i,2]],0) + 10^-19) );	 

option solver minos; #solve; 
option minos_options  ' \
   summary_file=6       \
   print_file=9         \
   print_level=0        \
   major_iterations=200 \
   iterations=100000   \
   optimality_tol=1e-6  \
   penalty=100.0        \
   completion=full      \
  *major_damp=0.1       \
   superbasics_limit=3000\
   LU_factor_tol=1.9    \
   LU_update_tol=1.9    \
   solution=yes         \
';

var diff {i in 1..T,a in 1..A} = Pnn[i,i,1,a] - fs[i,i,a];
var mape = 1/A/T * sum{i in 1..T,a in 1..A} abs(Pnn[i,i,1,a] - fs[i,i,a])/fs[i,i,a];
var mae  = 1/A/T * sum{i in 1..T,a in 1..A} abs(Pnn[i,i,1,a] - fs[i,i,a]);

param results {kkk in 1..R,1..3};
param muresults{i in 1..3} := 1/R*sum{kkk in 1..R} results[kkk,i];
param s2results{i in 1..3} :=(1/R*sum{kkk in 1..R}(results[kkk,i]-muresults[i])^2)^0.5;

for{kkk in 1..R} {
	option randseed 0;
	display kkk;
	for{n in 1..N-1,i in 1..Ny[n],k in 1..2} let x[n,i,k] := if k=1 then round(Uniform(0.5,T-0.5))  # state feature data 1-step
                                                        else round(Uniform(0.5,A+0.5)); # used (average) action
	for{n in 1..N-1,i in 1..Ny[n]} let z[n,i] := Uniform(0,1);
    for{n in 1..N-1,i in 1..Ny[n]} let y[n,i] := if x[n,i,1]=T then T 
                                      else min{ii in 1..T:sum{j in 1..ii} p_true[x[n,i,1],j,n,x[n,i,2]] > z[n,i]} ii;
	for {k in 1..K,a in 1..A} let b[k,a] := Uniform(0,1);
	solve;
	display mape,mae,LL,KK,gap; display _solve_elapsed_time;
	let results[kkk,1]:=mape;
	let results[kkk,2]:=mae;
	let results[kkk,3]:=_solve_elapsed_time;
                 };

display muresults;
display s2results;	
printf"%3i %6.3f %6.3f %6.3f %6.3f %6.2f %6.3f\n", N-1, 
muresults[1], s2results[1], muresults[2], s2results[2], muresults[3], s2results[3]  >> aging_observable_N_out.txt;

display p,pp_true;	

display _solve_elapsed_time,_ampl_time;
	
end;









