import torch import torch.multiprocessing as mp import bprocess import argparse tasks = [  ("AIME24", 32),  ("AMC23", 32),  ("BigCodeBench", 16),  ("GPQADiamond", 32),  # ("veBench", 8),  # ("veCodeBench", 32),  ("MATH500", 32),  ("AIME25", 32),  # ("vecodebench", 8) ] def launch_job(model_id, gpu_id, task_name, batch_size):  """Launch a separate training process on a specific GPU."""  command = f"CUDA_VISIBLE_DEVICES={gpu_id} python -m eval.eval --model vllm --tasks {task_name} --model_id {model_id} --batch_size {batch_size} --output_path logs --use_database --annotator_model gpt-4o-mini-2024-07-18 --wandb_args project=dcft-eval"  bprocess.Popen(command, shell=True) if __name__ == "__main__":  parser = argparse.ArgumentParser()  parser.add_argument("--model_id", type=str)  parser.add_argument("--model_ids_vecodebench", type=str)  args = parser.parse_args()  assert args.model_id or args.model_ids_vecodebench  # Spawn 8 training processes (one per GPU)  processes = []  if args.model_id:  for gpu_id, (task_name, batch_size) in enumerate(  tasks  ): # Adjust if using fewer GPUs  p = mp.Process(  target=launch_job, args=(args.model_id, gpu_id, task_name, batch_size)  )  p.start()  processes.append(p)  ef args.model_ids_vecodebench:  model_ids = args.model_ids_vecodebench.spt(",")  for gpu_id, model_id in enumerate(model_ids): # Adjust if using fewer GPUs  p = mp.Process(  target=launch_job, args=(model_id, gpu_id, "veCodeBench", 32)  )  p.start()  processes.append(p)  else:  raise ValueError("Need args.model_id or args.model_ids_vecodebench")  # Wait for all processes to finish  for p in processes:  p.join() 