from data_generation.data_generation_alan_method import generate_x as generate_alan
import pickle
import os
import sys
from data_generation.data_generation import *
from data_generation.data_generation_cluster import *
from data_generation.synthetic_data_generation_PrefShap2 import *
import numpy as np


def save_files(job_name,l,r,predictors,y,y_block):
    with open(f'{job_name}/l_processed.npy', 'wb') as f:
        np.save(f, l)
    with open(f'{job_name}/r_processed.npy', 'wb') as f:
        np.save(f, r)
    with open(f'{job_name}/S.npy', 'wb') as f:
        np.save(f, predictors)
    with open(f'{job_name}/y.npy', 'wb') as f:
        np.save(f, y)
    with open(f'{job_name}/y_block.npy', 'wb') as f:
        np.save(f, y_block)


if __name__ == '__main__':
    n_pairs = 5000
    n_samples = 1000
    d = 4
    num_latent_states = 4
    d_imp = 2
   
    q1 = input("how many features do you want?")
    sys.argv.append(q1)
    dim = int(sys.argv[1])
    num_items = 100
    
    q2 = input("how many pairs you want to sample uniformly at random?")
    sys.argv.append(q2)
    plays = int(sys.argv[2]) #num_pairs
    num_pairs = plays 
    

    for t in range(1):

        random.seed(t)
        
        job_name =f'synthetic_data_{plays}_{t}'
        
        if not os.path.exists(job_name):
            os.makedirs(job_name)
        u, u_prime,S, y, y_block = generate_data(num_items, num_pairs, plays, dim, t)
        
        save_files(job_name,u,u_prime,S,y,y_block)
        

    

    l_load=np.load(job_name+'/l_processed.npy',allow_pickle=True)
    r_load=np.load(job_name+'/r_processed.npy',allow_pickle=True)
    S=np.load(job_name+'/S.npy',allow_pickle=True)
    y_load=np.load(job_name+'/y.npy',allow_pickle=True)
    y_block_load = np.load(job_name+'/y_block.npy',allow_pickle = True)

    
