-
-
Notifications
You must be signed in to change notification settings - Fork 230
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #648 from automl/development
Release 0.12.1
- Loading branch information
Showing
61 changed files
with
2,147 additions
and
597 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,126 @@ | ||
""" | ||
================================ | ||
Optimizing an MLP with Hyperband | ||
================================ | ||
An example for the usage of a model-free Hyperband intensifier in SMAC. | ||
The configurations are randomly sampled | ||
In this example, we use a real-valued budget in hyperband (number of epochs to train the MLP) and | ||
optimize the average accuracy on a 5-fold cross validation. | ||
""" | ||
|
||
import logging | ||
import warnings | ||
|
||
import numpy as np | ||
from ConfigSpace.hyperparameters import CategoricalHyperparameter, \ | ||
UniformFloatHyperparameter, UniformIntegerHyperparameter | ||
from sklearn.datasets import load_digits | ||
from sklearn.exceptions import ConvergenceWarning | ||
from sklearn.model_selection import cross_val_score, StratifiedKFold | ||
from sklearn.neural_network import MLPClassifier | ||
|
||
from smac.configspace import ConfigurationSpace | ||
from smac.facade.hyperband_facade import HB4AC | ||
from smac.scenario.scenario import Scenario | ||
|
||
digits = load_digits() | ||
|
||
|
||
# Target Algorithm | ||
# The signature of the function determines what arguments are passed to it | ||
# i.e., budget is passed to the target algorithm if it is present in the signature | ||
def mlp_from_cfg(cfg, seed, instance, budget, **kwargs): | ||
""" | ||
Creates a MLP classifier from sklearn and fits the given data on it. | ||
This is the function-call we try to optimize. Chosen values are stored in | ||
the configuration (cfg). | ||
Parameters | ||
---------- | ||
cfg: Configuration | ||
configuration chosen by smac | ||
seed: int or RandomState | ||
used to initialize the rf's random generator | ||
instance: str | ||
used to represent the instance to use (just a placeholder for this example) | ||
budget: float | ||
used to set max iterations for the MLP | ||
Returns | ||
------- | ||
float | ||
""" | ||
|
||
with warnings.catch_warnings(): | ||
warnings.filterwarnings('ignore', category=ConvergenceWarning) | ||
|
||
mlp = MLPClassifier( | ||
hidden_layer_sizes=[cfg["n_neurons"]] * cfg["n_layer"], | ||
batch_size=cfg['batch_size'], | ||
activation=cfg['activation'], | ||
learning_rate_init=cfg['learning_rate_init'], | ||
max_iter=int(np.ceil(budget)), | ||
random_state=seed) | ||
|
||
# returns the cross validation accuracy | ||
cv = StratifiedKFold(n_splits=5, random_state=seed, shuffle=True) # to make CV splits consistent | ||
score = cross_val_score(mlp, digits.data, digits.target, cv=cv, error_score='raise') | ||
|
||
return 1 - np.mean(score) # Because minimize! | ||
|
||
|
||
logger = logging.getLogger("MLP-example") | ||
logging.basicConfig(level=logging.INFO) | ||
|
||
# Build Configuration Space which defines all parameters and their ranges. | ||
# To illustrate different parameter types, | ||
# we use continuous, integer and categorical parameters. | ||
cs = ConfigurationSpace() | ||
|
||
# We can add multiple hyperparameters at once: | ||
n_layer = UniformIntegerHyperparameter("n_layer", 1, 5, default_value=1) | ||
n_neurons = UniformIntegerHyperparameter("n_neurons", 8, 1024, log=True, default_value=10) | ||
activation = CategoricalHyperparameter("activation", ['logistic', 'tanh', 'relu'], | ||
default_value='tanh') | ||
batch_size = UniformIntegerHyperparameter('batch_size', 30, 300, default_value=200) | ||
learning_rate_init = UniformFloatHyperparameter('learning_rate_init', 0.0001, 1.0, default_value=0.001, log=True) | ||
cs.add_hyperparameters([n_layer, n_neurons, activation, batch_size, learning_rate_init]) | ||
|
||
# SMAC scenario object | ||
scenario = Scenario({"run_obj": "quality", # we optimize quality (alternative to runtime) | ||
"wallclock-limit": 100, # max duration to run the optimization (in seconds) | ||
"cs": cs, # configuration space | ||
"deterministic": "true", | ||
"limit_resources": True, # Uses pynisher to limit memory and runtime | ||
# Alternatively, you can also disable this. | ||
# Then you should handle runtime and memory yourself in the TA | ||
"cutoff": 30, # runtime limit for target algorithm | ||
"memory_limit": 3072, # adapt this to reasonable value for your hardware | ||
}) | ||
|
||
# max budget for hyperband can be anything. Here, we set it to maximum no. of epochs to train the MLP for | ||
max_iters = 50 | ||
# intensifier parameters | ||
intensifier_kwargs = {'initial_budget': 5, 'max_budget': max_iters, 'eta': 3} | ||
# To optimize, we pass the function to the SMAC-object | ||
smac = HB4AC(scenario=scenario, rng=np.random.RandomState(42), | ||
tae_runner=mlp_from_cfg, | ||
intensifier_kwargs=intensifier_kwargs) # all arguments related to intensifier can be passed like this | ||
|
||
# Example call of the function with default values | ||
# It returns: Status, Cost, Runtime, Additional Infos | ||
def_value = smac.get_tae_runner().run(config=cs.get_default_configuration(), | ||
instance='1', budget=max_iters, seed=0)[1] | ||
print("Value for default configuration: %.4f" % def_value) | ||
|
||
# Start optimization | ||
try: | ||
incumbent = smac.optimize() | ||
finally: | ||
incumbent = smac.solver.incumbent | ||
|
||
inc_value = smac.get_tae_runner().run(config=incumbent, instance='1', | ||
budget=max_iters, seed=0)[1] | ||
print("Optimized Value: %.4f" % inc_value) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
python3 ../../scripts/smac --scenario scenario.txt --verbose DEBUG | ||
python3 ../../scripts/smac --scenario scenario.txt --verbose DEBUG --mode ROAR |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
python3 ../../scripts/smac --scenario scenario.txt --verbose DEBUG --mode SMAC4AC |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,6 +9,6 @@ | |
"documentation": [ | ||
"sphinx", | ||
"sphinx_rtd_theme", | ||
"sphinx-gallery" | ||
"sphinx-gallery==0.5.0" | ||
] | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.