import subprocess
from concurrent.futures import ThreadPoolExecutor, as_completed

n_cpu = 8

# Function to run the command for a given para_seed_num
def run_preprocess(para_seed_num):
    command = f"python preprocess.py --data_type drugs --para_seed_num {para_seed_num} --para_batch_num {n_cpu}"
    subprocess.run(command, shell=True)

# Define the range of para_seed_num
para_seeds = range(0, n_cpu)  

# Create a ThreadPoolExecutor with 16 workers (processes)
with ThreadPoolExecutor(max_workers=16) as executor:
    # Submit all tasks to the executor
    future_to_id = {executor.submit(run_preprocess, para_seed_num): para_seed_num for para_seed_num in para_seeds }
    
    # Process the tasks as they complete
    for future in as_completed(future_to_id):
        para_seed_num = future_to_id[future]
        try:
            future.result()  # This will raise an exception if subprocess failed
            print(f"para_seed_num {para_seed_num} completed.")
        except Exception as exc:
            print(f"para_seed_num {para_seed_num} generated an exception: {exc}")
