N=40 
seeds=(0 1 2 3 4 5 6 7)
envs=("HalfCheetahGrad-v1" "HopperGrad-v1" "Walker2dGrad-v1")
tasks=()

# oracle
BASE_CMD="conda activate corl && python run_all.py --run-name ppo --exploration none --weight-type simplev2 --start-with-oracle"

for seed in "${seeds[@]}"; do
    device=$(( seed % 4+4 ))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done

# easy

BASE_CMD="conda activate corl && python run_all.py --run-name gradient --exploration none --use-gradient --weight-type simplev1 "

for seed in "${seeds[@]}"; do
    device=$(( seed % 4+4 ))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done

BASE_CMD="conda activate corl && python run_all.py --run-name morse --exploration single --use-gradient --weight-type simplev1 "

for seed in "${seeds[@]}"; do
    device=$(( seed % 4 +4))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done

# hard

BASE_CMD="conda activate corl && python run_all.py --run-name gradient --exploration none --use-gradient --weight-type simplev2 "

for seed in "${seeds[@]}"; do
    device=$(( seed % 4+4 ))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done

BASE_CMD="conda activate corl && python run_all.py --run-name morse --exploration single --use-gradient --weight-type simplev2 "

for seed in "${seeds[@]}"; do
    device=$(( seed % 4 +4))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done

# ablation

BASE_CMD="conda activate corl && python run_all.py --run-name morse-random --exploration random --use-gradient --weight-type simplev2 "

for seed in "${seeds[@]}"; do
    device=$(( seed % 4 +4))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done


BASE_CMD="conda activate corl && python run_all.py --run-name morse-no-early-stop --exploration single --use-gradient --weight-type simplev2 --condition none"

for seed in "${seeds[@]}"; do
    device=$(( seed % 4 +4))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done


BASE_CMD="conda activate corl && python run_all.py --run-name morse-no-reset-actor --exploration single --use-gradient --weight-type simplev2 --reset-method none"

for seed in "${seeds[@]}"; do
    device=$(( seed % 4 +4))
    for env in "${envs[@]}"; do
        cmd="$BASE_CMD --seed $seed --device cuda:$device --env $env"
        tasks+=("$cmd")
    done
done


total_tasks=${#tasks[@]}
tasks_per_window=$(( (total_tasks + N - 1) / N ))
SESSION_NAME="run"

tmux new-session -d -s $SESSION_NAME

for ((i = 0; i < N; i++)); do
  start=$((i * tasks_per_window))
  end=$((start + tasks_per_window - 1))
  [ $end -ge $total_tasks ] && end=$((total_tasks - 1))

  [ $start -gt $end ] && continue

  script=""
  for ((j = start; j <= end; j++)); do
    script+="${tasks[$j]}; "
  done

  if [ $i -eq 0 ]; then
    tmux send-keys -t $SESSION_NAME "$script" C-m
  else
    tmux new-window -t $SESSION_NAME
    tmux send-keys -t $SESSION_NAME:$i "$script" C-m
  fi
done

echo "send all commands to '$SESSION_NAME'"
tmux list-windows -t $SESSION_NAME
