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)
option display_round 3;
param T default 10;   # number of states
param N default 4+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;  # number of data observations
                 167;
				 
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 y{n in 1..KKK} :=                       T-round((yr[n]-min_state)/fein);

display T,x,y; #end;

###########    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 P1{i in 1..T,j in 1..T} = Pnn[i,j,1,1]; 

###########    logit optimality conditions    ###########

maximize LL: 1/KKK * sum{n in 1..KKK}
                     ( log(  max(Pnn[x[n,1],y[n],nr[n],x[n,2]],0) + 10^-19) );	 
#                    ( log(  max(sum{k in 1..T} U[x[n,i,1],k,x[n,i,2]]*(if k=1 then 1 else p[k-1,x[n,i,2]]^n)*V[k,y[n,i],x[n,i,2]],0) + 10^-19) );	 
					 

option solver minos; #solve; 


#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;


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_out.txt;

end;




param:  xr  nr  yr  :=
	1	14	4	3
	2	13	1	3
	3	12	5	6
	4	18	2	10
	5	13	4	3
	6	14	1	7
	7	15	5	8
	8	17	2	10
	9	12	1	15
	10	12	1	3
	11	12	6	6
	12	18	4	10
	13	11	5	3
	14	 3	2	3
	15	16	7	9
	16	19	2	3
;





