import numpy as np
import os
#if 'DISPLAY' in os.environ:
#    del os.environ['DISPLAY']
import argparse
from simulation.experiment import Exp
from simulation.helper import save_results_with_files, save_f_to_pickle, load_g_syn

def parse_args():
    parser = argparse.ArgumentParser(description="Parse synaptic and leak parameters.")

    # Define arguments
    parser.add_argument("--num_g_syn", type=int, required=True, help="Number of synaptic conductance values")
    parser.add_argument("--num_v_rest", type=int, required=True, help="Number of resting potential values")
    parser.add_argument("--num_g_leak", type=int, required=True, help="Number of leak conductance values")

    parser.add_argument("--num_loops", type=int, required=True, help="Number of iterations")


    parser.add_argument("--g_syn_idx", type=int, required=False, default=None, help="Index for synaptic conductance")
    parser.add_argument("--v_rest_idx", type=int, required=False, default=None, help="Index for resting potential")
    parser.add_argument("--g_leak_idx", type=int, required=False, default=None, help="Index for leak conductance")

    parser.add_argument("--job_id", type=str, required=False, default=None, help="SLURM job ID")
    parser.add_argument("--task_id", type=str, required=False, default=None, help="SLURM array task ID")

    # Parse arguments
    args = parser.parse_args()

    if all(arg is None for arg in [args.job_id, args.task_id, args.g_syn_idx, args.v_rest_idx, args.g_leak_idx]):
        raise ValueError("Error: At least one of --job_id, --task_id, --g_syn_idx, --v_rest_idx, or --g_leak_idx must be provided.")
    if args.task_id is not None: # If task_id is provided, it will be used to generate the indices
        args.task_id = int(args.task_id)
        index = np.unravel_index(args.task_id, (args.num_g_syn, args.num_v_rest, args.num_g_leak))
        args.g_syn_idx = index[0]
        args.v_rest_idx = index[1]
        args.g_leak_idx = index[2]


    return args

if __name__ == "__main__":

    args = parse_args()

    # Print parsed arguments
    num_g_syn = args.num_g_syn
    num_v_rest = args.num_v_rest
    num_g_leak = args.num_g_leak
    g_syn_idx = args.g_syn_idx
    v_rest_idx = args.v_rest_idx
    g_leak_idx = args.g_leak_idx
    num_loops = args.num_loops
    job_id = args.job_id

    # Define parameter space
    all_synaptic_conductance = np.linspace(0.9, 1.1, num=num_g_syn) # H <--> F 
    all_resting_potential = np.linspace(-65, -75, num=num_v_rest) # H <--> F
    all_leak_conductance = np.linspace(0.7, 1.2, num=num_g_leak) # H <--> F

    # take specific parameter set from the script
    all_synaptic_conductance = np.array(all_synaptic_conductance[[g_syn_idx]])
    all_resting_potential = np.array(all_resting_potential[[v_rest_idx]])
    all_leak_conductance = np.array(all_leak_conductance[[g_leak_idx]])
    params_temp = {
        "mode": {"if_search_g_syn": False},
        "membrane": {"cm": 1, "gl_ctr": 0.1, "ErL": -75, "gl_scale": 1, "action_potential_thres": -50},
        "ion_ch": {
            "det_ch_file": "ch_carter_subtchan.ses",
            "stch_ch_file": "stch_carter_subtchan.ses",
            "ena": 55, "ek": -90,
            "na": {"gx": 35, "g_single": 20, "if_stch": False},
            "kdr": {"gx": 4, "g_single": 20, "if_stch": False},
            "subchan": {"gx": 0.18, "g_single": 20, "if_stch": True},
        },
        "soma": {"diam": 8, "L": 8}, # both in um
        "synapse": {"input_type": "gsyn", "tau_rise": 1, "tau_decay": 10, "Er": 0, "weight": 8, "noise_strenth": 0.10},
        "stim": {"stim_delay": 0, "rate": 0.2, "NetCon_delay": 0, "if_single_spike":True, "noise": 0},
        "run": {"E0": -75, "sim_length": 2000, "if_select_seed": False, "dt": 0.1, "seeds": []},
        "misc": {"g_syn_search_range": [0.01, 10], "g_syn_search_firing_rate": 1,
                 "g_syn_search_precision": 1e-3, "path_for_active":"g_syn_on.pkl",
                 "path_for_seeds": "seeds.pkl", # this seed selection is for controlling the stochastic behavior of the ion channels
                 "path_for_saturate": "g_syn_saturation.pkl"
                 },
    }

    params_temp['mode']['if_search_g_syn'] = True
    experiment = Exp(params_temp, num_loops, if_parallel=False, if_plot=False, if_select_seed=params_temp['run']['if_select_seed'])

    # we prerun the g_syn search to get the g_syn_active and g_syn_saturate
    g_syn_active = load_g_syn(params_temp['misc']['path_for_active'])
    g_syn_saturate = load_g_syn(params_temp['misc']['path_for_saturate'])

    # following code is only for simulation, not for searching
    params_temp['mode']['if_search_g_syn'] = False # turn off the g_syn search
    all_params = experiment.generate_all_params_dynamic(all_resting_potential, all_leak_conductance, num_g_syn, g_syn_idx, compensate_list=[g_syn_active, g_syn_saturate])
    results = experiment.run(all_params)



