reset;                # Title: Product Usage under Aging Effects: Learning and Earning using Markov Chains
# B0006 bisher am besten
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)
option display_round 4;

param T default 10;   # number of states
param N default 20+1; # number of nodes in the chain (max 4000 bei T=20, 8 sec)
param A default 1;    # 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 3150;
                  #167;  # number of data observations
param K1 default 1;

param xr {i in 1..KKK};
param nr {i in 1..KKK};
param yr {i in 1..KKK};

data;

include data_real_1-20step.txt;
#include data_real_1step.txt;

model;

display xr,nr,yr;

#end;
param max_step := max{n in 1..KKK} nr[n]; let N:=max_step + 1;

param max_state := max{n in 1..KKK} xr[n];
param min_state := min{n in 1..KKK} yr[n];
param fein := (max_state-min_state)/(T-1);

param x{n in 1..KKK,k in 1..2} := if k=1 then T-round((xr[n]-min_state)/fein)  # state feature data 1-step
                                         else 1; # used (average) action
param x2{n in K1..KKK} := x[n,1]; #display x2; end;
param y{n in 1..KKK} :=                       T-round((yr[n]-min_state)/fein);

param rh {i in 1..T,j in 1..T} := card({n in K1..KKK: x[n,1]=i and y[n]=j});
param rh2{i in 1..T,j in 1..T} :=   sum{n in K1..KKK: x[n,1]=i and y[n]=j} nr[n]/rh[i,j];

display rh;  #end;
display rh2; #end;
display T,x,y; #end;
						  
###########    structure of n-step transition Matrices Pn as function of p_k

var b {k in 1..T,j in 1..T,a in 1..A} <=500, := Uniform(0,0);			    # beta coefficients (for logit probs)
var p {k in 1..T,j in 1..T,a in 1..A} = exp(b[k,j,a])/(1+exp(b[k,j,a]));      # probs for main bandmatrix

#################    Diagonalisierung     #####################

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
         p[i,j,a];                       #if i<=j then p[i,j,a] else 0;        #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];  # k in i..min(i+1,T) im band case
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 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]
                                      ;
									  
var P1{i in 1..T,j in 1..T} = Pnn[i,j,1,1]; 
								  
###########    logit optimality conditions    ###########

maximize LL: 1/KKK * sum{n in K1..KKK}
                     ( log(  max(Pnn[x[n,1],y[n],nr[n],x[n,2]],0) + 10^-19) );	 
					 
subject to nb {k in 1..T}: sum{j in 1..T} p[k,j,1] = 1;
subject to nb2{k in 1..T}: sum{j in 1..T} P[k,j,1] = 1;

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,j in i..T,a in 1..A} = Pnn[i,j,1,a] - fs[i,j,a];
#var mape = 1/A/card({ii in 1..T,jj in ii..T}) * sum{i in 1..T,j in i..T,a in 1..A} abs(Pnn[i,j,1,a] - fs[i,j,a])/fs[i,j,a];
#var mae  = 1/A/card({ii in 1..T,jj in ii..T}) * sum{i in 1..T,j in i..T,a in 1..A} abs(Pnn[i,j,1,a] - fs[i,j,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;


solve; display _solve_elapsed_time;
display LL,KKK; #mape,mae,LL,KK,gap; 

#display p;

#let results[1,1]:=mape;
#let results[1,2]:=mae;
#let results[1,3]:=_solve_elapsed_time;

display P1;

display P1 > P1_real_full_out.txt;

end;







