from ml_collections import config_dict


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

    config.name = algorithm_name
    config.hidden_layers = [512, 256]
    config.lr = 1e-4
    config.disc_lr = 8e-5
    config.num_steps = 20
    config.total_timesteps = 400e6
    config.update_epochs = 5
    config.disc_minibatch_size = 512
    config.proportion_env_reward = 0.0  # 0.0 means the policy receives no environment reward, just used for evaluation!
    config.n_disc_epochs = 20
    config.num_minibatches = 64
    config.gamma = 0.99
    config.gae_lambda = 0.95
    config.clip_eps = 0.2
    config.init_std = 0.4
    config.learnable_std = True
    config.ent_coef = 0.0001
    config.disc_ent_coef = 0.001
    config.vf_coef = 1.0
    config.max_grad_norm = 1.0
    config.activation = "tanh"
    config.anneal_lr = False
    config.weight_decay = 0.0
    config.normalize_env = True
    config.debug = False
    config.n_seeds = 1  # while automatically take seeds from 1 to n_seeds
    config.vmap_across_seeds = True
    config.data_path = "../expert_data/expert_dataset_MjxUnitreeGo2_30_PPO.npz"
    config.mocap_data_path = "../expert_data/mocap_cache/"

    config.validation_active = False
    config.validation_num_steps = 100
    config.validation_num_envs = 100
    config.validation_num = 10  # set to 0 to disable validation


    config.handle_absorbing_states = True
    config.gp_lambda = 0.04
    
    config.reward_type = 'state-based' # options: state-action, state-based, shaped, shaped-sa, uncorrelated
    config.reward_approximator_type = 'state-based' # options: state-action, state-based, shaped, shaped-sa
    config.epsilon = 0.6
    config.disc_buffer_capacity = 150
    config.init_eta = 100.0
    config.const_eta = False
    config.beta = float(1/config.ent_coef)
    config.chunk_size = 5

    config.n_reward_approximator_epochs = 30
    config.reward_approximator_lr = 5e-5
    config.reward_fn_approximator = False
    # config.global_rew_experiment = False

    return config
