import os
import subprocess
import argparse
import itertools
import time

ALGORITHMS = [
    'dynamic_partition', 'fifo', 'sjf', 'round_robin', 
    'srtf', 'multilevel_feedback', 'fair_scheduling', 'tetris'
]

parser = argparse.ArgumentParser(description='Run optimization for algorithms serially')
parser.add_argument('--algorithms', nargs='+', choices=ALGORITHMS, default=ALGORITHMS,
                    help='Algorithms to optimize')
parser.add_argument('--exec_caps', nargs='+', type=int, default=[10],
                    help='Executor capacities to test')
parser.add_argument('--init_stream_configs', nargs='+', default=["1_0"],
                    help='Configurations of initial and streaming DAGs')
parser.add_argument('--config_idxs', nargs='+', type=int, default=list(range(10)),
                    help='Indices of query configurations to use (0-9)')
parser.add_argument('--query_size', type=str, default='2g',
                    help='Query size to use')
parser.add_argument('--llm_iterations', nargs='+', type=int, default=[1, 2, 3],
                    help='Numbers of LLM optimization iterations')
args = parser.parse_args()

def optimize_algorithm(algorithm):

    result_dir = f"results/{algorithm}"
    os.makedirs(result_dir, exist_ok=True)  


    all_configs = list(itertools.product(
        args.exec_caps,
        args.init_stream_configs,
        args.config_idxs,
        args.llm_iterations
    ))

    for exec_cap, init_stream_config, config_idx, llm_iters in all_configs:

        cmd = [
            "python", "server.py",
            "--algorithm", algorithm,
            "--exec_cap", str(exec_cap),
            "--init_stream_config", init_stream_config,
            "--config_idx", str(config_idx),
            "--iterations", str(llm_iters),
            "--query_size", args.query_size
        ]

        subprocess.run(cmd)

def main():

    if not os.path.exists("results"):
        os.makedirs("results")

    algorithms_to_run = [algo for algo in args.algorithms if algo in ALGORITHMS]

    for algorithm in algorithms_to_run:
        optimize_algorithm(algorithm)

if __name__ == "__main__":
    main()