import subprocess

# +
#on-going experiments
# -


for dataset in ['cora']:
    for iid_beta in [0.1, 1, 10, 100, 1000, 10000]: 
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=0 -iid_b={iid_beta} -r=3 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=1 -iid_b={iid_beta} -r=3 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=2 -iid_b={iid_beta} -r=3 -n=10", shell = True)

'''
for dataset in ['cora']:
    for n_trainers in [150, 200, 250, 300]:
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=0 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=1 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=2 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
'''
'''
for dataset in ['cora']:
    for n_trainers in [2,3,4,5,6,7,8,9]:
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=0 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=1 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=2 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        
'''  

'''
for dataset in ['cora']:
    for n_trainers in [1, 10, 20,30, 40, 50, 60, 70,80,90, 100]:
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=0 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=1 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=2 -iid_b=100 -r=3 -n={n_trainers}", shell = True)
'''

# +
'''
for dataset in ['cora']:
    subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=0 -iid_b=100 -r=1 -n=100 -c=200 -g", shell = True)
    subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=1 -iid_b=100 -r=1 -n=100 -c=200 -g", shell = True)
    subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop=2 -iid_b=100 -r=1 -n=100 -c=200 -g", shell = True) 
'''



# +
'''
datasets = ["ogbn-products"]
for dataset in datasets:
    for iid_beta in [1, 100, 10000]:
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedsage+ -nl=2 -nhop=1 -iid_b={iid_beta} -r=10 -n=5 -c=150 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=bds-gcn -nl=2 -nhop=1 -iid_b={iid_beta} -r=10 -n=5 -c=150 -g", shell = True)
'''
'''
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nhop in [3]:
        for iid_beta in [10000]:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=600 -i=1 -g", shell = True)

datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for iid_beta in [1, 100, 10000]:
        for nhop in range(4):
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=200 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedsage+ -nl=3 -nhop=1 -iid_b={iid_beta} -r=10 -n=10 -c=200 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=bds-gcn -nl=3 -nhop=1 -iid_b={iid_beta} -r=10 -n=10 -c=200 -g", shell = True)

        
        
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nlayer in range(1, 11):
        #centralized
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=10000 -r=10 -n=10 -c=600 -i=1 -g", shell = True)

for dataset in datasets:
    for nlayer in range(1, 11):
        # federated
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=0 -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=1 -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)

'''

'''

# +
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nlayer in range(1, 11):
        #centralized
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=10000 -r=10 -n=5 -c=600 -i=1 -g", shell = True)

for dataset in datasets:
    for nlayer in range(1, 11):
        # federated
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=0 -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=1 -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)
        if nlayer>=2:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=2 -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)
        if nlayer>=3:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=100 -r=10 -n=10 -c=200 -g", shell = True)

'''


        


# +
#10-layer experiments

'''
datasets = ["cora"]
for dataset in datasets:
    for nlayer in range(1, 11):
        #centralized
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=10000 -r=10 -n=1", shell = True)

for dataset in datasets:
    for nlayer in range(1, 11):
        # federated
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=0 -iid_b=100 -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=1 -iid_b=100 -r=10 -n=10", shell = True)
        if nlayer>=2:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=2 -iid_b=100 -r=10 -n=10", shell = True)
        if nlayer>=3:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=100 -r=10 -n=10", shell = True)


datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nlayer in range(1, 11):
        #centralized
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=10000 -r=10 -n=1", shell = True)

for dataset in datasets:
    for nlayer in range(1, 11):
        # federated
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=0 -iid_b=100 -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=1 -iid_b=100 -r=10 -n=10", shell = True)
        if nlayer>=2:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop=2 -iid_b=100 -r=10 -n=10", shell = True)
        if nlayer>=3:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl={nlayer} -nhop={nlayer} -iid_b=100 -r=10 -n=10", shell = True)
'''
# -

'''    
datasets = ["ogbn-products"]
for dataset in datasets:
    for nhop in [2]:
        for iid_beta in [10000]:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=5 -c=450 -i=1 -g", shell = True)
            
            
datasets = ["ogbn-products"]
for dataset in datasets:
    for nhop in range(3):
        for iid_beta in [1, 100, 10000]:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=5 -c=150 -g", shell = True)

datasets = ["ogbn-products"]
for dataset in datasets:
    for nhop in [2]:
        for iid_beta in [10000]:
            #use repeat due to GPU memory
            for repeat in range(10):
                subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=1 -n=5 -c=450 -i=1 -g", shell = True)
            
datasets = ["ogbn-products"]
for dataset in datasets:
    for nhop in [2]:
        for iid_beta in [1, 100, 10000]:
            #use repeat due to GPU memory
            for repeat in range(10):
                subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=1 -n=5 -c=150 -g", shell = True)
                
datasets = ["ogbn-products"]
for dataset in datasets:
    for iid_beta in [1, 100, 10000]:
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=bds-gcn -nl=2 -nhop=1 -iid_b=10000 -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedsage+ -nl=2 -nhop=1 -iid_b=10000 -r=10 -n=10", shell = True)
'''    


'''      
#centralized
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nhop in [3]:
        for iid_beta in [10000]:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=600 -i=1 -g", shell = True)
            
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for iid_beta in [1, 100, 10000]:
        for nhop in range(4):
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=200 -g", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedsage+ -nl=3 -nhop=1 -iid_b={iid_beta} -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=bds-gcn -nl=3 -nhop=1 -iid_b={iid_beta} -r=10 -n=10", shell = True)
'''


'''

datasets = ["cora", "citeseer", "pubmed"]
for dataset in datasets:
    
    for iid_beta in [1, 100, 10000]:
        for nhop in range(3):
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=bds-gcn -nl=2 -nhop=1 -iid_b={iid_beta} -r=10 -n=10", shell = True)
        subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedsage+ -nl=2 -nhop=1 -iid_b={iid_beta} -r=10 -n=10", shell = True)


datasets = ["cora", "citeseer", "pubmed"]
for dataset in datasets:
    for nhop in range(1):
        for iid_beta in [10000]:
            subprocess.run(f"python fedgcn_gpu.py -d={dataset} -f=fedgcn -nl=2 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=1", shell = True)
'''

'''

datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nhop in range(4):
        for iid_beta in [1, 100, 10000]:
            subprocess.run(f"ray submit config_gpu.yaml fedgcn_gpu.py -- -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=200 -g", shell = True)
            
            
datasets = ["ogbn-arxiv"]
for dataset in datasets:
    for nhop in [3]:
        for iid_beta in [10000]:
            subprocess.run(f"ray submit config_gpu.yaml fedgcn_gpu.py -- -d={dataset} -f=fedgcn -nl=3 -nhop={nhop} -iid_b={iid_beta} -r=10 -n=10 -c=600 -i=1 -g", shell = True)
'''

