import traceback
import numpy as np
from src.TSSI.trainer import TSSITrainer, exp_num
from config import Config
import matplotlib.pyplot as plt
import os
import sys

import random
import torch

def fix_all_seeds(seed: int):
    random.seed(seed)
    np.random.seed(seed)
    torch.manual_seed(seed)
    if torch.cuda.is_available():
        torch.cuda.manual_seed(seed)
        torch.cuda.manual_seed_all(seed)
        torch.backends.cudnn.deterministic = True
        torch.backends.cudnn.benchmark = False
    os.environ['PYTHONHASHSEED'] = str(seed)


if not os.path.exists('result'):
    os.makedirs('result')

os.environ['CUDA_VISIBLE_DEVICES'] = '0'

if __name__ == '__main__':
    try:
        res_list = []
        print("begin")
        fix_all_seeds(42)
        for idx in range(Config.experiment_num):
            my_config = Config()
            model = TSSITrainer(my_config.networks, Config.config['train_params'], True)
            res = model.train(rand_seed=42)
            res_list.append((res[0] + res[1]) / 2)

        res_list = np.array(res_list)
        bias = np.abs(np.mean(res_list, axis=0)).reshape(res_list.shape[0], 1)
        sd = np.std(res_list, axis=0).reshape(res_list.shape[0], 1)
        print("DDIV bias:", bias, " sd", sd)
        np.savetxt(f'result/result.txt', np.concatenate((bias, sd), 0))
        
    except Exception as e:
        print('Exception: ' + str(e))
        print()
        traceback.print_exc()


