#!/usr/bin/env bash

set -euo pipefail

ENV_NAME=${ENV_NAME:-FetchPickAndPlace-v4}
GPU=${GPU:-0}
SEED=${SEED:-0}
ALGO=${ALGO:-S3_${ENV_NAME//-/_}_s${SEED}}
MAX_TS=${MAX_TS:-2e6}
MAN_REW=${MAN_REW:-0.25}
MAN_NOISE=${MAN_NOISE:-0.4}
MAN_NOISE_FINAL=${MAN_NOISE_FINAL:-0.25}
CTRL_NOISE=${CTRL_NOISE:-0.2}
CTRL_NOISE_FINAL=${CTRL_NOISE_FINAL:-0.1}
USE_ADJ=${USE_ADJ:-1}

run_cmd=(
  python main.py
    --env_name "$ENV_NAME"
    --algo "$ALGO"
    --seed "$SEED"
    --max_timesteps "$MAX_TS"
    --manager_propose_freq 10
    --train_manager_freq 10
    --man_rew_scale "$MAN_REW"
    --man_ctrl_rew_balance_start 0.0
    --man_ctrl_rew_balance_end 0.3
    --man_ctrl_rew_balance_steps 400000
    --candidate_goals 8
    --man_noise_sigma "$MAN_NOISE"
    --man_noise_sigma_final "$MAN_NOISE_FINAL"
    --ctrl_noise_sigma "$CTRL_NOISE"
    --ctrl_noise_sigma_final "$CTRL_NOISE_FINAL"
    --reach_warmup_samples 4000
    --reach_warmup_rounds 2
    --fast_mode
)

if [[ "$USE_ADJ" -eq 0 ]]; then
  run_cmd+=(--disable_adj_net)
fi

if [[ "${SAVE_MODELS:-0}" -eq 1 ]]; then
  run_cmd+=(--save_models)
fi

export CUDA_VISIBLE_DEVICES=$GPU
"${run_cmd[@]}"
