from ml_collections import config_dict


def get_config(algorithm_name):
    config = config_dict.ConfigDict()

    config.name = algorithm_name
    
    config.device = "gpu"  # cpu, gpu
    config.total_timesteps = 20e6
    config.learning_rate = 7.758124695869614e-05
    config.anneal_learning_rate = False
    config.nr_steps = 10
    config.nr_epochs = 20
    config.minibatch_size = 512
    config.gamma = 0.99
    config.gae_lambda = 0.95
    config.clip_range = 0.2
    config.entropy_coef = 0.004730379416510563
    config.critic_coef = 1.0
    config.max_grad_norm = 10.0
    config.std_dev = 1.0
    config.nr_hidden_units = 256
    config.evaluation_frequency =  -1 # -1 to disable
    config.evaluation_episodes = 10

    config.nr_hidden_units_disc = 256
    config.learning_rate_disc = 1.6482616689714173e-05
    config.nr_epochs_disc = 10 # Number of disc epochs
    config.env_reward_frac = 0.0
    config.handle_absorbing_states = True
    config.gp_lambda = 0.1
    config.gp_alpha = 0.5
    config.data_path = "../expert_data/expert_dataset_Ant-v5_30_PPO.npz"

    config.subsampling_cutoff = 1

    return config