import os
import subprocess

# Define models and their paths

ModelDir = "Path/To/Your/Merged/Models/From/Checkpoints"

models = {
'''
Model names: Backbone Models, DAPO/GRPO Models, HAMMER Models
'''
}

DataDir = "Path/To/Your/Data"

# Define datasets and their paths
datasets = {
    "AIME24": f"{DataDir}/aime.parquet",
    "AIME25": f"{DataDir}/aime25.parquet",
    "AMC": f"{DataDir}/amc.parquet",
    "Olympiad": f"{DataDir}/olympiad_bench.parquet"
}

# Base output folder
output_base = "/Path/To/MainResults"

# Number of k
k = 100
gpu_per_node = 8

for dataset_name, data_path in datasets.items():
    for model_name, model_path in models.items():
        output_dir = os.path.join(output_base, dataset_name)
        os.makedirs(output_dir, exist_ok=True)
        output_path = os.path.join(output_dir, f"{model_name}.json")
        actual_k = k if dataset_name != "Olympiad" else 32
        cmd = [
            "python", "scripts/MainExperiment/pass_k.py",
            "--k", str(actual_k),
            "--vllm_model_path", model_path,
            "--data_path", data_path,
            "--output_path", output_path,
            "--gpu_per_node", str(gpu_per_node)
        ]
        print(f"Running: {' '.join(cmd)}")
        subprocess.run(cmd, check=True)
