from generate import generate_time_series
import numpy as np
from matrix_detection  import matrix_detection
from MMD  import MMD_detection


from kde import detect_change_kde_cusum_l2

######model parameters
dim=3
N_train=1000
target=1200
N_total=1500 



######estimator

domains = [(0.0, 1.0), (0.0, 1.0), (0.0, 1.0)]


mu_before=[3,1]
mu_after=[3,1]
# Component 1: p^(1)_j
def p11(x): return  (np.sin(x)+1) 
def p12(x): return  (np.sin(x)+1) 
def p13(x): return  (np.sin(x)+1) 

# Component 2: p^(2)_j
def p21(x): return  (np.cos(x)+1) 
def p22(x): return  (np.cos(x)+1) 
def p23(x): return  (np.cos(x)+1) 


def p31(x): return   np.exp(-x**2) 
def p32(x): return   np.exp(-x**2) 
def p33(x): return   np.exp(-x**2) 

# Component 2: p^(2)_j
def p41(x): return  x
def p42(x): return  x
def p43(x): return  x 


ps1 = [p11, p12, p13]
ps2 = [p21, p22, p23]
ps3 = [p31, p32, p33]
ps4 = [p41, p42, p43]
#data=generate_time_series(ps1, ps2,ps3, ps4,domains , mu_before, mu_after, target, N_total).compute()
 
####tuning parameters
#max_len is maximum number of difference considered at every new instance
max_len=100
min_lag=  2*(max_len//3 )

#m is number of basis
if dim==1:
    m=3
else:
    m=2



index=[[],[]]
for j in range(dim):
    if j<dim//2:
        index[0].append(j)
    else:
        index[1].append(j)

shapes=[m for __ in range(dim)] 
rank = 3






RR=100

MMD_mul_fac=np.array([ii for ii in range(15)])/1  +2

MMD_record=[]

kde_mul_fac=np.array([ii for ii in range(15)])/10+0.5

kde_record=[]

mat_mul_fac=np.array([ii for ii in range(15)])/20+0.6

mat_record=[]

for rr in range(RR):
    print('rr',rr)
    
    
    data= generate_time_series(ps1, ps2,ps3, ps4,domains , mu_before, mu_after, target, N_total).compute()
    
    
    
    
    """
    kde_result = detect_change_kde_cusum_l2(
         data=data,
         N_train=N_train,
         factor=1*kde_mul_fac,
         num_mc=1024,
         s_step=5,
         s_window=500,          # restrict splits to last 500 time points
         t_step=2,              # compute every time; set to 5/10 for faster scans
         max_points_per_time=300 )
    print(kde_result)
    
    
    kde_record.append(kde_result)
    
    
    """
    """
    det = matrix_detection(dim, m, max_len, min_lag, rank, data[:N_train], index, factor=1.0)
    alarms = det.detect_alarm_times(
    data_stream=data[N_train:],   # post-train stream
    factors=mat_mul_fac,
    start_index=N_train,          # so alarms are returned in global time indices
    sentinel=len(data)   )
    print(alarms)
    mat_record.append(alarms)
    
    
    
    
    
    """
    
    
    det = MMD_detection(
    data, N_total, N_train,
    sigma=1, B=100, num_block=4, factor=MMD_mul_fac,
    max_points=400, threshold_quantile=0.995,train_step=5,
    detect_step=3,
    consecutive=1,              # set 1 if you want original behavior
    deterministic_subsample=True,
    stat_aggregation="mean",
    chunk_size=2048,)
    
    
    result = det.detect(return_time="start")   
    print(result) 
    MMD_record.append(result)
    #print(mmd_result)
    
    
    
        
        
        ############
        ############
        ############MMD
         
        
        
        
        
        
        ############
        ############
        ############ kde
        
np.savez("data_mat.npz", mat_record=mat_record)
np.savez("data_kde.npz", kde_record=kde_record)
np.savez("data_MMD.npz", MMD_record=MMD_record)

