# --- QMIX specific parameters ---

# use epsilon greedy action selector
action_selector: "epsilon_greedy"
epsilon_start: 1.0
epsilon_finish: 0.05
epsilon_anneal_time: 100000 # 500000 for 6h_vs_8z

runner: "parallel"
batch_size_run: 8 # batch_size_run=4, buffer_size = 2500, batch_size=64  for 3s5z_vs_3s6z
buffer_size: 5000 
batch_size: 128
t_max: 10100000

# update the target network every {} episodes
target_update_interval: 200

# use the Q_Learner to train
mac: "basic_mac"
agent: "rnn"
agent_output_type: q

learner: "q_learner"
mixer: "qmix"
mixing_embed_dim: 64
hypernet_embed: 256
rnn_hidden_dim: 256
lr: 0.001 # Learning rate for agents
td_lambda: 0.3 # 0.3 for 6h_vs_8z
optimizer: 'adam'
q_lambda: False
double_q: False

# rnn layer normalization
use_layer_norm: False

# orthogonal init for DNN
use_orthogonal: False
gain: 0.01

# Priority experience replay
use_per: False
per_alpha: 0.6
per_beta: 0.4
return_priority: False

name: "losi"

encoder_lr: 5e-4
z_dim: 16
ctx_window: 10
ctx_hid: 64
ctx_reward: True
use_contrastive: True
nce_negatives: 64
nce_queue_size: 4096
nce_momentum: 0.9
nce_temperature: 0.07
mixer_use_z: True
use_z_film: False
nce_loss_weight: 1.0         # strong early influence
nce_loss_weight_final: 1.0   # disable after convergence
nce_loss_decay_steps: 10e6    # over 1M environment steps
