DEVICE=$1
MODEL_PATH=$2

NUM_GPUS=$(echo $DEVICE | tr ',' '\n' | wc -l)

echo "CUDA_DEVICE_IDX: $DEVICE"
echo "NUM_GPUS: $NUM_GPUS"

GPU_UTIL=0.85

# Uncomment the lines below if you encounter an CUDA OOM error.
# if [[ $MODEL_PATH == *"gemma"* ]]; then
#     GPU_UTIL=0.65
# elif [[ $MODEL_PATH == *"Mistral"* ]]; then
#     GPU_UTIL=0.5
# else
#     GPU_UTIL=0.85
# fi

echo "RUN advbench"
CUDA_VISIBLE_DEVICES=$DEVICE python -m eval.advbench.run_eval \
    --model $MODEL_PATH \
    --use_chat_format \
    --evaluator meta-llama/Llama-3.3-70B-Instruct \
    --evaluator_engine_backend vllm-openai \
    --model_num_gpus $NUM_GPUS \
    --gpu_memory_utilization $GPU_UTIL

echo "RUN malicious_instruct"
CUDA_VISIBLE_DEVICES=$DEVICE python -m eval.malicious_instruct.run_eval \
    --model $MODEL_PATH \
    --use_chat_format \
    --evaluator meta-llama/Llama-3.3-70B-Instruct \
    --evaluator_engine_backend vllm-openai \
    --model_num_gpus $NUM_GPUS \
    --gpu_memory_utilization $GPU_UTIL

echo "RUN oktest"
CUDA_VISIBLE_DEVICES=$DEVICE python -m eval.oktest.run_eval \
    --model $MODEL_PATH \
    --use_chat_format \
    --evaluator meta-llama/Llama-3.3-70B-Instruct \
    --evaluator_engine_backend vllm-openai \
    --model_num_gpus $NUM_GPUS \
    --gpu_memory_utilization $GPU_UTIL

echo "RUN xstest"
CUDA_VISIBLE_DEVICES=$DEVICE python -m eval.xstest.run_eval \
    --model $MODEL_PATH \
    --use_chat_format \
    --evaluator meta-llama/Llama-3.3-70B-Instruct \
    --evaluator_engine_backend vllm-openai \
    --model_num_gpus $NUM_GPUS \
    --gpu_memory_utilization $GPU_UTIL