forked from automl/NASLib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdemo.py
67 lines (54 loc) · 1.79 KB
/
demo.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
import logging
import sys
from naslib.defaults.trainer import Trainer
from naslib.optimizers import (
DARTSOptimizer,
GDASOptimizer,
DrNASOptimizer,
RandomSearch,
RegularizedEvolution,
LocalSearch,
Bananas,
BasePredictor,
)
from naslib.search_spaces import (
DartsSearchSpace,
SimpleCellSearchSpace,
NasBench201SearchSpace,
HierarchicalSearchSpace,
)
# from naslib.search_spaces.nasbench101 import graph
from naslib.utils import utils, setup_logger
# Read args and config, setup logger
config = utils.get_config_from_args()
utils.set_seed(config.seed)
logger = setup_logger(config.save + "/log.log")
# logger.setLevel(logging.INFO) # default DEBUG is very verbose
utils.log_args(config)
supported_optimizers = {
"darts": DARTSOptimizer(config),
"gdas": GDASOptimizer(config),
"drnas": DrNASOptimizer(config),
"rs": RandomSearch(config),
"re": RegularizedEvolution(config),
"ls": LocalSearch(config),
"bananas": Bananas(config),
"bp": BasePredictor(config),
}
# Changing the search space is one line of code
search_space = SimpleCellSearchSpace()
# search_space = graph.NasBench101SearchSpace()
# search_space = HierarchicalSearchSpace()
# search_space = DartsSearchSpace()
# search_space = NasBench201SearchSpace()
# Changing the optimizer is one line of code
# optimizer = supported_optimizers[config.optimizer]
optimizer = supported_optimizers["drnas"]
optimizer.adapt_search_space(search_space)
# Start the search and evaluation
trainer = Trainer(optimizer, config)
if not config.eval_only:
checkpoint = utils.get_last_checkpoint(config) if config.resume else ""
trainer.search(resume_from=checkpoint)
checkpoint = utils.get_last_checkpoint(config, search=False) if config.resume else ""
trainer.evaluate(resume_from=checkpoint)