import os
import subprocess


MODELS = [
    ("llama_v2_7b", "meta-llama/Llama-2-7b-chat-hf", 1),
    ("llama_v2_13b", "meta-llama/Llama-2-13b-chat-hf", 2),
    ("openchat", "openchat/openchat", 4),
    ("stable-vicuna", "TheBloke/stable-vicuna-13B-HF", 4),
    ("ultralm_13b", "TheBloke/UltraLM-13B-fp16", 4),
    (
        "vicuna7b",
        "data/ckpts/vicuna-7b",  # the Vicuna 7B v1.1 model is got by merge `lmsys/vicuna-7b-delta-v1.1` onto LLaMA v1
        1,
    ),
    ("vicuna7bv13", "lmsys/vicuna-7b-v1.3", 1),
    ("vicuna13bv13", "lmsys/vicuna-13b-v1.3", 4),
    ("vicuna33bv13", "lmsys/vicuna-33b-v1.3", 5),
]

OUTPUT_FOLDER = "results/wizardlm/wizardlm_{model_name}_outline"

COMMAND = (
    "python sot/main.py --model fastchat --scheduler outline "
    "--data-path data/wizardlm/data.csv --output-folder {output_folder} "
    "--model-path {model_path} --num-gpus {num_gpus} "
    "--prompt-file prompts/sot_opensource.json"
)


if __name__ == "__main__":
    for model_name, path, num_gpus in MODELS:
        output_folder = OUTPUT_FOLDER.format(model_name=model_name)
        if os.path.exists(output_folder):
            print(f"Skipping {model_name}")
        else:
            print(f"Running {model_name}")
            command = COMMAND.format(
                output_folder=output_folder, model_path=path, num_gpus=num_gpus
            )
            print(command)
            process = subprocess.Popen(command.split())
            process.wait()
