IFS=',' read -ra TASK_LIST <<< "$TASK_LIST_STR"

CPU_NUM=$(($(nproc) - 28))
cpu_per_task=$((CPU_NUM / ${#TASK_LIST[@]}))

cpu_list=()
for ((i=0; i<=CPU_NUM-cpu_per_task; i+=cpu_per_task)); do
    end=$((i+cpu_per_task-1))
    cpu_list+=("$i-$end")
done

cd envs/MLAgentBench

echo "========================================"
echo "Start to evaluate the generated results..."

for i in "${!TASK_LIST[@]}"; do
    TASK=${TASK_LIST[$i]}
    echo ">> Evaluate the generated results on task ${TASK}"
    GPU=$(($i % 4))
    taskset -c ${cpu_list[$i]} timeout $TIMEOUT_DURATION_EVA python eva.py --python $PYTHON --device ${GPU} --task $TASK --generator_name $GENERATOR_NAME --agent_max_steps $NUM_STEPS &
done
wait

echo "All evaluation processes have completed."