-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_experiments_benchmarks_NeurIPS.py
70 lines (62 loc) · 2.29 KB
/
run_experiments_benchmarks_NeurIPS.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
"""
File to run the catenets experiments for
"Really Doing Great at Estimating CATE? A Critical Look at ML Benchmarking Practices in
Treatment Effect Estimation" (Curth & vdS, NeurIPS21)
from shell
"""
# Author: Alicia Curth
import argparse
import sys
from typing import Any
from continuous.utils.common_utils import set_seed
set_seed(42)
import catenets.logger as log
from experiments.experiments_benchmarks_NeurIPS21.acic_experiments_catenets import (
do_acic_experiments,
)
from experiments.experiments_benchmarks_NeurIPS21.ihdp_experiments_catenets import (
do_ihdp_experiments,
)
from experiments.experiments_benchmarks_NeurIPS21.twins_experiments_catenets import (
do_twins_experiment_loop,
)
log.add(sink=sys.stderr, level="DEBUG")
def init_arg() -> Any:
# arg parser
parser = argparse.ArgumentParser()
parser.add_argument("--setting", default="C", type=str)
parser.add_argument("--experiment", default="acic", type=str)
parser.add_argument("--file_name", default="results", type=str)
parser.add_argument("--n_exp", default=10, type=int) # number of seeds
parser.add_argument(
"--n_reps", default=1, type=int
) # number of times to repeat for each seed
parser.add_argument("--pre_trans", type=bool, default=False)
parser.add_argument("--simu_num", type=int, default=2) # relevant for acic
return parser.parse_args()
if __name__ == "__main__":
args = init_arg()
if (args.experiment == "ihdp") or (args.experiment == "IHDP"):
do_ihdp_experiments(
file_name=args.file_name,
n_exp=args.n_exp,
setting=args.setting,
n_reps=args.n_reps,
save_reps=True,
)
elif (args.experiment == "acic") or (args.experiment == "ACIC"):
do_acic_experiments(
file_name=args.file_name,
n_reps=args.n_reps,
simu_num=args.simu_num,
n_exp=args.n_exp,
pre_trans=args.pre_trans,
save_reps=True,
)
elif (args.experiment == "twins") or (args.experiment == "Twins"):
do_twins_experiment_loop(file_name=args.file_name, n_exp=args.n_reps)
else:
raise ValueError(
f"Experiment should be one of ihdp/IHDP, acic/ACIC and twins/Twins. You "
f"passed {args.experiment}"
)