from joblib import Parallel, delayed
from itertools import product
import subprocess
import multiprocessing
import os
os.environ["MKL_SERVICE_FORCE_INTEL"] = "1"

def run_command(command):
    """
    Function to run a command.
    """
    subprocess.run(command, shell=True)

def create_all_commands():
    
    commands = [
    # 'python main_sl.py arch=mlp proj_name=no_al_save_grad wandb=true task=random_label_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0 agent.AL=false',
    # 'python main_sl.py arch=mlp proj_name=no_al_save_grad wandb=true task=shuffle_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0 agent.AL=false',
    # 'python main_sl.py arch=mlp proj_name=no_al_save_grad wandb=true task=random_label_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0',
    # 'python main_sl.py arch=mlp proj_name=no_al_save_grad wandb=true task=shuffle_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0',
    # 'python main_sl.py arch=mlp proj_name=no_img_abl wandb=true task=random_label_cifar10 agent=neuro_sync seed=1 agent.img_to_controller=false',
    # 'python main_sl.py arch=mlp proj_name=no_img_abl wandb=true task=shuffle_cifar10 agent=neuro_sync seed=1 agent.img_to_controller=false',
    'python main_sl.py arch=mlp proj_name=save_ema wandb=true task=random_label_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0 agent.save_ema=true',
    'python main_sl.py arch=mlp proj_name=save_ema wandb=true task=shuffle_cifar10 agent=neuro_sync seed=1 agent.alpha_bound=0 agent.alpha_uniform=0 agent.save_ema=true'
    ]
    
    return commands

if __name__ == "__main__":
    commands = create_all_commands()
    print("Num commands", len(commands))
    num_cores = 4
    Parallel(n_jobs=num_cores)(delayed(run_command)(command) for command in commands)