import subprocess
import pdb
import sys
import copy
import time

processes=[]
num_gpu = int(sys.argv[1])
total_clients = int(sys.argv[2])
num_exp = int(sys.argv[3])
gpu_list = [i for i in range(num_gpu)]
template_c = 'python3 main.py -w client --num-clients {} --host-port {} -g {}'
template_s = 'python3 main.py --host-port {} --num-clients {}'

print('num gpu:%d, num_clients:%d, num experiments:%d' %(num_gpu, total_clients, num_exp))
for e in range(num_exp):
    port = str(5023+e)
    command_s = template_s.format(port, total_clients)
    process = subprocess.Popen(command_s, shell=True)
    print(command_s)
    processes.append(process)
    time.sleep(3)
    for i in range(total_clients):
        command_c = template_c.format(total_clients, port, i%num_gpu)
        print(command_c)
        process = subprocess.Popen(command_c, shell=True)
        processes.append(process)
        time.sleep(3)
    output=[p.wait() for p in processes]
