forked from SMILELab-FL/FedPETuning
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cen_seed_run.py
85 lines (71 loc) · 2.59 KB
/
cen_seed_run.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
"""Grid Search for FedETuning"""
import os
import sys
import itertools as it
from loguru import logger
from multiprocessing import Pool
from configs.tuning import cen_best_hyperparameter
def run_process(proc):
os.system(proc)
run_dirs = sys.argv[1]
fl_algorithm = sys.argv[2]
task_name = sys.argv[3]
tuning_type = sys.argv[4]
port_start = int(sys.argv[5])
device = sys.argv[6]
device_idx_list = [idx for idx in device.split(",")]
n_gpu = len(device_idx_list)
world_size = 3
logger.info(f"world_size is {world_size}")
if task_name == "conll":
max_seq = 32
data_file = "fedner"
dataset_name = "ner"
metric_name = "conll"
model_output_mode = "token_classification"
else:
max_seq = 128
data_file = "fedglue"
dataset_name = "glue"
metric_name = "glue"
model_output_mode = "seq_classification"
logger.info(f"{task_name}'s max_seq is {max_seq}")
cmds = []
gpu_index = 0
hyper_parameter = cen_best_hyperparameter[task_name][tuning_type]
hyper_parameter["seed"] = []
for parameter in it.product(*list(hyper_parameter.values())):
specific_parameter_dict = {key: parameter[list(hyper_parameter.keys()).index(key)]
for key in list(hyper_parameter.keys())}
if "lora_r" in specific_parameter_dict:
specific_parameter_dict["lora_alpha"] = specific_parameter_dict["lora_r"]
port = port_start + gpu_index
device_index = gpu_index % n_gpu
cmd = f'CUDA_VISIBLE_DEVICES={device_idx_list[device_index]} python main.py '
options = [
"--model_name_or_path", f"{run_dirs}/pretrain/nlp/roberta-base/",
"--output_dir", f"{run_dirs}/output/{data_file}",
"--task_name", f"{task_name}",
"--fl_algorithm", f"{fl_algorithm}",
"--raw_dataset_path", f"{run_dirs}/data/{data_file}",
"--partition_dataset_path", f"{run_dirs}/data/{data_file}",
"--max_seq_length", f"{max_seq}",
"--world_size", f"{world_size}",
"--port", f"{port}",
"--dataset_name", dataset_name,
"--metric_name", metric_name,
"--model_output_mode", model_output_mode,
"--tuning_type", f"{tuning_type}_roberta-base",
"--do_grid", "True",
]
for key, value in specific_parameter_dict.items():
options.extend(["--" + key, str(value)])
cen_options = options + ["--rank", "-1"]
cen_cmd = cmd + " ".join(cen_options)
gpu_index += 1
cmds.append(cen_cmd)
run_process("sleep 3s")
logger.warning(f"run {len(cmds)} seed-ablation tasks for roberta_{task_name}_{tuning_type}")
# run_process(cmds[0]) # debug
pool = Pool(processes=n_gpu)
pool.map(run_process, cmds)