import os
from multiprocessing import Pool

def run_command(params):
    trace, baye, LLM, alg = params
    cmd = f'python server.py {trace} {baye} {LLM} {alg}'
    os.system(cmd)

if __name__ == '__main__':
    algs = ['bb', 'bola', 'mpc', 'hyb', 'pitree']
    
    LLMs = [1, 2, 3]
    bayes = [0, 10, 20]
    traces = ['oboe', 'fcc', '3g', 'puffer-2110']


    tasks = []
    idx = 0
    for trace in traces:
        for baye in bayes:
            for LLM in LLMs:
                for alg in algs:
                    idx += 1
                    if idx != 1:
                        tasks.append((trace, baye, LLM, alg))
    

    with Pool(processes=8) as pool:
        pool.map(run_command, tasks)