Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v2.2.0 #1128

Merged
merged 615 commits into from
Jul 24, 2024
Merged

v2.2.0 #1128

Show file tree
Hide file tree
Changes from 250 commits
Commits
Show all changes
615 commits
Select commit Hold shift + click to select a range
acae71c
Fix ambiguous variable
benjamc Jul 7, 2022
92551bb
Del newlines
benjamc Jul 7, 2022
b028bd2
fix mypy
dengdifan Jul 7, 2022
1d47600
mypy and doc fix
dengdifan Jul 7, 2022
a34dd46
Removed int type checking
renesass Jul 7, 2022
efdd5c5
fix tests
dengdifan Jul 7, 2022
db4e020
Always return List of incs
benjamc Jul 7, 2022
165c844
fix path issue in example
dengdifan Jul 7, 2022
dc24106
maint boing facade
dengdifan Jul 7, 2022
04afc03
Better docstring
renesass Jul 7, 2022
06a4fca
Return values if no bounds passed
renesass Jul 7, 2022
4e3caed
Removed import
renesass Jul 7, 2022
100e2f3
Merge pull request #872 from automl/fix_mo_cache
renesass Jul 7, 2022
6b60582
Prepare BOinG (#730)
renesass Jul 7, 2022
563d36f
Return only one incumbent
benjamc Jul 7, 2022
ea8796b
Rename n_optimizers -> n_workers
benjamc Jul 7, 2022
a539e44
Update example
benjamc Jul 7, 2022
e576165
Update docstring
benjamc Jul 7, 2022
485f299
Remove legacy function
benjamc Jul 7, 2022
2e56e1c
Update to new signature
benjamc Jul 7, 2022
cc53b39
Update changelog.md
benjamc Jul 7, 2022
6b680bd
Format black
benjamc Jul 7, 2022
2623236
Update test
Jul 7, 2022
57ef2d9
Please pre-commit
Jul 7, 2022
9bf5ebd
Merge development
renesass Jul 7, 2022
6ab9ced
Merge pSMAC update (#821)
renesass Jul 7, 2022
59e271f
Fix tests
renesass Jul 7, 2022
7b91fde
Fix typos
benjamc Jul 11, 2022
91198d7
Format black
benjamc Jul 11, 2022
d9c608e
Updated text
renesass Jul 14, 2022
e83abee
Increased version
renesass Jul 14, 2022
64c5cbf
Merge branch 'main' into development
renesass Jul 14, 2022
033a5b1
Merge branch 'main' into development
renesass Oct 12, 2022
4a50949
Improved readme
renesass Oct 12, 2022
1729c65
SMAC logo 50%
renesass Oct 12, 2022
dc4124a
SMAC logo 50%
renesass Oct 12, 2022
65cfa97
Removed dev-2.0
renesass Oct 12, 2022
ef296ed
Added doc workflow for latest tag
renesass Oct 18, 2022
47fffc9
Fixing docs latest tag
renesass Oct 18, 2022
45d7465
Fixing docs latest tag
renesass Oct 18, 2022
813acf4
First steps new intensifier
renesass Oct 18, 2022
a659b13
Make it work again
renesass Oct 18, 2022
fd42b24
MOVE random weight initialization to smbo ask method
KEggensperger Oct 18, 2022
f6a540f
ADD enable parego in unittests
KEggensperger Oct 18, 2022
b53abc8
Test issues
renesass Oct 19, 2022
bc0019f
FIX formatting
KEggensperger Oct 19, 2022
330982d
Link to old documentation
renesass Oct 19, 2022
5ae6a7d
MOVE random weight initialization to smbo ask method
KEggensperger Oct 18, 2022
9222316
ADD enable parego in unittests
KEggensperger Oct 18, 2022
c4241a8
FIX formatting
KEggensperger Oct 19, 2022
aa82ac0
Fix unit tests
mfeurer Oct 25, 2022
74ce8a7
Add annotation
mfeurer Oct 25, 2022
7ed2369
corrected log prob for tophat prior
Oct 25, 2022
10968cd
Fixed mypy
renesass Oct 26, 2022
329360d
Removed configurations from callback
renesass Oct 26, 2022
dcd52a7
Fixed tests
renesass Oct 26, 2022
df7fe7b
Fix mypy
renesass Oct 26, 2022
11e86b3
Merge pull request #885 from automl/FIX_parego
renesass Oct 26, 2022
e4ec3c7
Merge pull request #887 from ekalosak/main
renesass Oct 26, 2022
ffefc4d
Save docs as latest version too
renesass Oct 26, 2022
9f0b3b4
Enabled all tests again
renesass Oct 26, 2022
bb7bef6
Make version an env
renesass Oct 26, 2022
614e508
Added last version to docs
renesass Oct 26, 2022
91ddf6b
Global variable fix
renesass Oct 26, 2022
5e43344
Added v before version number
renesass Oct 26, 2022
cec24d2
Merge branch 'main' into development
renesass Oct 26, 2022
d99074c
New Intensifier Implementation (#888)
renesass Dec 7, 2022
89a15b5
First benchmark steps
renesass Dec 7, 2022
10c7b4e
Added a warning
renesass Dec 7, 2022
3a66258
Set xi to 0.01
renesass Dec 12, 2022
6adeaa5
Incorporated walltime in trajectory
renesass Dec 12, 2022
760f67f
Working version of benchmark
renesass Dec 14, 2022
05be313
Changed requirements
renesass Dec 14, 2022
7005d4a
Changed xi back to 0.0 again
renesass Dec 15, 2022
b4c8124
No duplicate budgets
renesass Dec 15, 2022
a6f3837
Fixed bug which updated tracker wrongly
renesass Dec 15, 2022
35492d2
Bugfix: Delete correct bracket+stage
renesass Dec 19, 2022
cb63905
Fixed tests
renesass Dec 19, 2022
4ca0dcd
Added costs to the trajectory
renesass Dec 20, 2022
e2926da
Changed initial design max ratio to 0.25
renesass Dec 20, 2022
4cbf0a9
Make format
renesass Dec 20, 2022
22c5e73
Added more details to intensifier
renesass Dec 20, 2022
9c3efaf
Finished benchmark
renesass Dec 20, 2022
5c0dd76
Added benchmark source files
renesass Dec 20, 2022
4f5f6ef
Fixed tests because of initial design changes
renesass Dec 20, 2022
1a4d084
Improved runhistory API
renesass Dec 20, 2022
c66b8a6
Fixed typo (#894)
PascalIversen Dec 20, 2022
ef783e3
Merge doc fixes
renesass Dec 20, 2022
660b10d
Doc fixes (#893)
helegraf Dec 20, 2022
fddd98f
Make format
renesass Dec 20, 2022
15d9717
Satisfied mypy
renesass Dec 20, 2022
4413f6d
Enabled more tests
renesass Dec 20, 2022
92f025f
Increased version
renesass Dec 20, 2022
4dd5541
Mypy
renesass Dec 21, 2022
7fa26bb
Mypy
renesass Dec 21, 2022
b951d77
Mypy
renesass Dec 21, 2022
efcdabc
Fixed critical bug when using highest budget for inc selection
renesass Dec 21, 2022
b99c15c
Added SH+HB comparison
renesass Dec 21, 2022
3d869d1
Stuff
renesass Dec 22, 2022
b7aa793
Updated report
renesass Dec 22, 2022
b358d28
Fixed docstring
renesass Dec 22, 2022
8cd59c0
Fixed image path
renesass Dec 22, 2022
d681dd1
Removed vscode folder
renesass Dec 22, 2022
8c582b0
Bugfixes
renesass Dec 30, 2022
09f2d13
Doc fixes
renesass Dec 30, 2022
35e4f2d
Updated changelog
renesass Dec 30, 2022
0324b0e
Make isort
renesass Dec 30, 2022
58f0ea2
Fix typos
Jan 2, 2023
044beac
Removed new line
renesass Jan 7, 2023
69820e9
Added alpha2 to docs selection
renesass Jan 7, 2023
851e321
update description
dengdifan Jan 10, 2023
134c36f
Fix 531 correctly create integers in initial design
mfeurer Jan 11, 2023
8c2f1b2
Add contact paragraph to README.
alexandertornede Jan 19, 2023
469ca05
Increase days until stale issues are closed by stalebot (#904)
helegraf Jan 19, 2023
78488e7
Edit changelog
Jan 25, 2023
cd4ec30
Merge pull request #899 from automl/description
alexandertornede Jan 27, 2023
292e53d
Add issue number
Jan 27, 2023
9b98770
Merge pull request #900 from automl/fix_531
sarah-segel Jan 27, 2023
fc07e9b
Closes #907
renesass Jan 30, 2023
c247853
Clarify origin of configurations (#908)
helegraf Jan 30, 2023
2927921
Random forest speed up (#903)
jeroenrook Jan 30, 2023
a0a8fd1
Add: workflow to update pre-commit versions (#874)
eddiebergman Jan 30, 2023
4eb6528
Add Git-Flow Workflow Specification
helegraf Feb 2, 2023
da841e2
[DOC] acquisition function maximizers
Feb 2, 2023
f7209de
Add stale reminder email action
helegraf Feb 13, 2023
ef4653d
Merge pull request #919 from automl/hotfix/early_emails_stale_issues
helegraf Feb 13, 2023
871d656
Increase version number of ConfigSpace
benjamc Feb 16, 2023
e6c77a8
Merge branch 'feature/improve_documentation' into development
Feb 16, 2023
9207944
Add guideline for updating copyright notice years to CONTRIBUTING.md
helegraf Feb 16, 2023
cf6ee29
Merge pull request #911 from automl/feature/specify_git-flow_workflows
timruhkopf Feb 16, 2023
e5f9875
Update requirement for pyrfr (#920)
dengdifan Feb 16, 2023
83b3dc4
Update pre-commit: isort,flake8 version numbers
Feb 23, 2023
a6c60c8
Merge branch 'development' of https://github.com/automl/SMAC3 into de…
Feb 23, 2023
14ddf7a
Format black
Feb 23, 2023
c861ae4
Fix mypy
Feb 23, 2023
0bdb6fa
Ac bench (#929)
benjamc Mar 2, 2023
1addb24
[DOC] added documentation on the incumbent update
Mar 2, 2023
8564d5d
Feature/add version to make publish (#931)
sarah-segel Mar 2, 2023
981f32a
Transform integer feature names to strings (#930)
renesass Mar 2, 2023
302b8b3
Merge remote-tracking branch 'origin/development' into development
Mar 2, 2023
4dce9b6
Update version to 2.0.0
benjamc Mar 2, 2023
8407f21
Update version to 2.0.0
Mar 2, 2023
b91734f
Update CHANGELOG.md
benjamc Mar 2, 2023
9f3ba23
Add information on deepcave to the readme
Mar 2, 2023
cc94031
Merge branch 'main' into development
helegraf Mar 3, 2023
df0fd5c
Correct doc version
Mar 3, 2023
58a7d12
fix(runhistory): set id of the sampled config (#951)
aron-bram Mar 23, 2023
2b0419a
ci: Set dependabot to target development branch (#963)
eddiebergman Apr 11, 2023
719dcdd
Resolve merge conflict
Apr 11, 2023
5fb2000
feat: Option preventing SMAC setting up logging (#947)
eddiebergman Apr 11, 2023
628cb9d
Citation update (#961)
dengdifan Apr 12, 2023
6cf3f04
Adjust hyperband configuration distribution across brackets
helegraf Apr 15, 2023
c308062
Compute the actual differences between the isb keys. (#957)
jeroenrook Apr 17, 2023
af1f7c5
Adjust schedule for stale reminder
helegraf Apr 17, 2023
d0461c8
fix(logging): Prevent automatic logging setup at init (#970)
eddiebergman Apr 17, 2023
6cd50b7
Merge pull request #974 from automl/hotfix/adjust_stale_reminder_sche…
helegraf Apr 17, 2023
56b031c
Fix validate method of smbo, update docstring.
helegraf Apr 19, 2023
cc8a817
Merge pull request #981 from automl/fix/smbo_validate
helegraf Apr 19, 2023
970fe94
Merge branch 'development' into fix/hyperband_bracket_scaling
helegraf Apr 21, 2023
7965296
Allow callbacks to be added to a specific index, make callback regist…
helegraf Apr 25, 2023
2c58693
Update CHANGELOG.md
helegraf Apr 25, 2023
35197c2
Merge pull request #989 from automl/fix/callback_order
helegraf Apr 25, 2023
93b67d5
Merge pull request #980 from automl/fix/hyperband_bracket_scaling
helegraf Apr 25, 2023
3810c1c
Merge pull request #991 from automl/hotfix/update_stale_labels
helegraf Apr 25, 2023
36e97f2
Fix broken references (#988)
dengdifan May 4, 2023
093e749
Adapt developer install instructions to include pre-commit installati…
sarah-segel May 4, 2023
9875de0
[Feature] Initial Design now supports executing the default config pr…
May 4, 2023
488402a
Merge branch 'development' into feature/initial_design_defaults
timruhkopf May 4, 2023
d68d18f
Pipe dask_client through facade for exec on hpc (#983)
benjamc May 4, 2023
e11ade6
[Bug-fix] Pr was failing due to mutable additional configs default
May 4, 2023
0bdedd1
Merge remote-tracking branch 'origin/feature/initial_design_defaults'…
May 4, 2023
0ec392e
[doc-fix] the count of initial design configs is computed slightly di…
May 4, 2023
6687e4b
Feature/metadata callback (#999)
sarah-segel May 16, 2023
aacbcc2
Merge branch 'development' into feature/initial_design_defaults
timruhkopf May 16, 2023
89c2ba3
Merge pull request #995 from automl/feature/initial_design_defaults
timruhkopf May 16, 2023
486ea1a
Documentation/dask client example (#1001)
benjamc May 16, 2023
0d9b91e
Documentation/dask client example (#1001)
benjamc May 16, 2023
eacaa57
Feature/dask client (#1002)
benjamc May 16, 2023
dcf77ad
Update smac version (#1003)
sarah-segel May 16, 2023
486b3a9
Update copyright year
May 16, 2023
b5c16a1
check if config in rh when storing state (#997)
dengdifan May 16, 2023
162a5dd
Merge branch 'development' of github.com:automl/SMAC3 into development
May 16, 2023
ef3885b
Add a workaround to be able to pass a dataset via dask.scatter (#993)
nabenabe0928 May 16, 2023
03e1ca8
Adding Binder links for example (#976)
dengdifan May 16, 2023
6d68ac6
Remove commit message from dependabot PRs (#1009)
eddiebergman May 17, 2023
921883e
Solve merge conflict
May 17, 2023
d31c1d3
Bugfix/fix broken link (#1012)
sarah-segel May 22, 2023
3d1f249
Merge branch 'main' of github.com:automl/SMAC3 into development
May 22, 2023
df6659f
Merge branch 'main' of github.com:automl/SMAC3 into development
May 22, 2023
af60825
Drop torch requirements (#1015)
benjamc May 23, 2023
cc14039
Remove leftover CLI entry points (#1014)
BastianZim May 23, 2023
ab5f88f
Fix incumbent selection in case of SH+MO
helegraf Jun 1, 2023
12aa9b0
Update CHANGELOG.md
helegraf Jun 1, 2023
4e5b4d1
Merge pull request #1022 from automl/fix/sh_get_best_configs
helegraf Jun 1, 2023
7cbd360
Feature/GitHub actions pr draft (#1008)
timruhkopf Jun 1, 2023
da58c9c
Update stale report to include issues with recent interactions (#1025)
helegraf Jun 2, 2023
cb1cd2f
Raise error if resource limitation and parallelization is requested (…
benjamc Jun 6, 2023
787f5d6
Raise an error for invalid scatter data (#1018)
nabenabe0928 Jun 6, 2023
b1695f0
fix(configspace): shows all keys in print (#1043)
eddiebergman Jun 23, 2023
345d9f1
Fix callback order (#1040)
benjamc Jun 26, 2023
8b64d1e
fix: dtypes (#1044)
eddiebergman Jun 26, 2023
81d2f77
Fix(config_selector): Budget checking (#1039)
eddiebergman Jun 26, 2023
5aa921a
Fix: target runner with partial func (#1045)
eddiebergman Jun 26, 2023
83eaab5
Feature/improve documentation (#1028)
sarah-segel Jun 27, 2023
cbffa5f
Handle configspace as dictionary in mlp example (#1057)
sarah-segel Jul 20, 2023
bf02a23
Raise version number
Jul 31, 2023
0650ad5
Add missing period in docs.
Jul 31, 2023
064e133
Merge branch 'main' of github.com:automl/SMAC3 into development
Aug 1, 2023
a15c1b7
allow rf to impute OrdinalHyperparameter (#1065)
dengdifan Oct 5, 2023
d58d5b1
fix dask_scheduler_file path (#1055)
markwwen Oct 5, 2023
06d584f
Fix config rejection for #1068 (#1069)
PhilippBordne Oct 9, 2023
3852013
fix(RandomForest): Always cast `seed` to `int` (#1084)
eddiebergman Nov 21, 2023
6280104
Bump actions/checkout from 3 to 4 (#1072)
dependabot[bot] Nov 21, 2023
6d46430
chore: log warn on condition when custom dask client is provided (#1071)
SimonThormeyer Nov 27, 2023
3d09049
Bump conda-incubator/setup-miniconda from 2 to 3 (#1087)
dependabot[bot] Dec 4, 2023
a7ea4b5
Propagate the Scenario random seed to get_random_design (#1066)
bpkroth Jan 10, 2024
c0e77fa
[#1056] Add example on intensify for cross-validation. (#1061)
mfeurer Feb 8, 2024
29b8a01
Change stale-reminder to recent-reminder (#1096)
helegraf Feb 13, 2024
a2170f5
Change stale-reminder to recent-reminder (#1095) (#1099)
helegraf Mar 5, 2024
e1a525b
Dont use mutable lists as default args (#1097)
helegraf Mar 12, 2024
e808a00
Bump actions/setup-python from 4 to 5 (#1089)
dependabot[bot] Mar 12, 2024
658a6b3
Bump peter-evans/create-pull-request from 5 to 6 (#1093)
dependabot[bot] Mar 12, 2024
6da055b
test: Fix upper bounds for `test_transformer()` and no random in `tes…
eddiebergman Apr 17, 2024
5fd67a4
Change stale-reminder to recent-reminder (#1095) (#1107)
helegraf May 16, 2024
829cdde
Fix typo in docstring for `MultiFideltyFacade.get_initial_design` (#1…
fleonce May 16, 2024
a5ab119
Bug/acquisition maximizer sampling (#1106)
benjamc May 16, 2024
f754bf6
Update version number to 2.1.0
helegraf May 16, 2024
8ece46d
Add version 2.1.0 to docs drop-down
helegraf May 16, 2024
2674173
Fix dependencies (numpy + ConfigSpace) and docs (#1122)
benjamc Jul 16, 2024
c7a48f0
chore: fix URLs (#1114)
e-kwsm Jul 16, 2024
7ce2b24
[MF] Determine number of trials for a total optimization budget (#1121)
benjamc Jul 16, 2024
88bc2f7
Update CHANGELOG.md
benjamc Jul 16, 2024
73ff8d0
Revert 1023 (#1123)
dengdifan Jul 17, 2024
03a2701
Upgrade to ConfigSpace 1.x (#1124)
benjamc Jul 17, 2024
54cc71a
Update CHANGELOG.md
benjamc Jul 23, 2024
3a7e497
Update version
benjamc Jul 23, 2024
98a0bf9
Merge branch 'main' into development
benjamc Jul 23, 2024
4a343fb
Adapt to new ConfigSpace API
benjamc Jul 23, 2024
0550b7c
Fix merge errors
benjamc Jul 23, 2024
46d3863
refactor: remove notebook
benjamc Jul 24, 2024
89089fe
Fix merge errors
benjamc Jul 24, 2024
eb3b652
Make format
benjamc Jul 24, 2024
f0c3c99
Add test case for numpy encoder
benjamc Jul 24, 2024
ef93151
Make format
benjamc Jul 24, 2024
5409bc0
Fix calculation
benjamc Jul 24, 2024
29264c7
Add test for Hyperband calculation
benjamc Jul 24, 2024
f9f8df2
Update comment
benjamc Jul 24, 2024
59870f5
Update docstring
benjamc Jul 24, 2024
abfe86a
Fix pre-commit
benjamc Jul 24, 2024
7058b45
Fix pre-commit
benjamc Jul 24, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,12 @@
# 2.2.0

## Features
- Add example to specify total budget (fidelity units) instead of n_trials for multi-fidelity/Hyperband (#1121)

## Dependencies
- Update numpy NaN (#1122) and restrict numpy version
- Upgrade to ConfigSpace 1.x.x (#1124)

# 2.1.0

## Improvements
Expand Down
2 changes: 1 addition & 1 deletion CITATION.cff
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ date-released: "2016-08-17"
url: "https://automl.github.io/SMAC3/master/index.html"
repository-code: "https://github.com/automl/SMAC3"

version: "2.1.0"
version: "2.2.0"

type: "software"
keywords:
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ SHELL := /bin/bash

NAME := SMAC3
PACKAGE_NAME := smac
VERSION := 2.1.0
VERSION := 2.2.0

DIR := "${CURDIR}"
SOURCE_DIR := ${PACKAGE_NAME}
Expand Down
4 changes: 3 additions & 1 deletion benchmark/src/benchmark.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
from collections import defaultdict
from pathlib import Path

from smac.utils.numpyencoder import NumpyEncoder

import pandas as pd
from src.tasks import TASKS # noqa: E402
from src.utils.exceptions import NotSupportedError # noqa: E402
Expand Down Expand Up @@ -79,7 +81,7 @@ def _save_data(self) -> None:
"""Saves the internal data to the file."""
print("Saving data...")
with open(str(RAW_FILENAME), "w") as f:
json.dump(self._data, f, indent=4)
json.dump(self._data, f, indent=4, cls=NumpyEncoder)

def _fill_keys(self) -> None:
"""Fill data with keys based on computer name, tasks, and selected version."""
Expand Down
2 changes: 1 addition & 1 deletion benchmark/src/models/ac_branin.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def configspace(self) -> ConfigurationSpace:
x2 = Float("x2", (0, 15), default=7.5)

# Add hyperparameters and conditions to our configspace
cs.add_hyperparameters([x2])
cs.add([x2])

return cs

Expand Down
2 changes: 1 addition & 1 deletion benchmark/src/models/branin.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def configspace(self) -> ConfigurationSpace:
x2 = Float("x2", (0, 15), default=0)

# Add hyperparameters and conditions to our configspace
cs.add_hyperparameters([x1, x2])
cs.add([x1, x2])

return cs

Expand Down
2 changes: 1 addition & 1 deletion benchmark/src/models/himmelblau.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ def configspace(self) -> ConfigurationSpace:
y = Float("y", (-5, 5))

# Add hyperparameters and conditions to our configspace
cs.add_hyperparameters([x, y])
cs.add([x, y])

return cs

Expand Down
4 changes: 2 additions & 2 deletions benchmark/src/models/mlp.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ def configspace(self) -> ConfigurationSpace:
learning_rate_init = Float("learning_rate_init", (0.0001, 1.0), default=0.001, log=True)

# Add all hyperparameters at once:
cs.add_hyperparameters([n_layer, n_neurons, activation, solver, batch_size, learning_rate, learning_rate_init])
cs.add([n_layer, n_neurons, activation, solver, batch_size, learning_rate, learning_rate_init])

# Adding conditions to restrict the hyperparameter space...
# ... since learning rate is used when solver is 'sgd'.
Expand All @@ -44,7 +44,7 @@ def configspace(self) -> ConfigurationSpace:
use_batch_size = InCondition(child=batch_size, parent=solver, values=["sgd", "adam"])

# We can also add multiple conditions on hyperparameters at once:
cs.add_conditions([use_lr, use_batch_size, use_lr_init])
cs.add([use_lr, use_batch_size, use_lr_init])

return cs

Expand Down
4 changes: 2 additions & 2 deletions benchmark/src/models/svm.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ def configspace(self) -> ConfigurationSpace:
use_gamma_value = InCondition(child=gamma_value, parent=gamma, values=["value"])

# Add hyperparameters and conditions to our configspace
cs.add_hyperparameters([kernel, C, shrinking, degree, coef, gamma, gamma_value])
cs.add_conditions([use_degree, use_coef, use_gamma, use_gamma_value])
cs.add([kernel, C, shrinking, degree, coef, gamma, gamma_value])
cs.add([use_degree, use_coef, use_gamma, use_gamma_value])

return cs

Expand Down
2 changes: 1 addition & 1 deletion docs/3_getting_started.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ ranges and default values.
"species": ["mouse", "cat", "dog"], # Categorical
})

Please see the documentation of `ConfigSpace <https://automl.github.io/ConfigSpace/main/>`_ for more details.
Please see the documentation of `ConfigSpace <https://automl.github.io/ConfigSpace/latest/>`_ for more details.


Target Function
Expand Down
33 changes: 0 additions & 33 deletions docs/advanced_usage/9_parallelism.rst
Original file line number Diff line number Diff line change
Expand Up @@ -21,39 +21,6 @@ SMAC supports multiple workers natively via Dask. Just specify ``n_workers`` in
When using multiple workers, SMAC is not reproducible anymore.


.. warning ::

You cannot use resource limitation (pynisher, via the `scenario` arguments `trail_walltime_limit` and `trial_memory_limit`).
This is because pynisher works by running your function inside of a subprocess.
Once in the subprocess, the resources will be limited for that process before running your function.
This does not work together with pickling - which is required by dask to schedule jobs on the cluster, even on a local one.


.. warning ::

Start/run SMAC inside ``if __name__ == "__main__"`` in your script otherwise Dask is not able to correctly
spawn jobs and probably this runtime error will be raised:

.. code-block ::

RuntimeError:
An attempt has been made to start a new process before the
current process has finished its bootstrapping phase.

This probably means that you are not using fork to start your
child processes and you have forgotten to use the proper idiom
in the main module:

if __name__ == '__main__':
freeze_support()
...

The "freeze_support()" line can be omitted if the program
is not going to be frozen to produce an executable.




Running on a Cluster
--------------------
You can also pass a custom dask client, e.g. to run on a slurm cluster.
Expand Down
2 changes: 2 additions & 0 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
"version": version,
"versions": {
f"v{version}": "#",
"v2.2.0": "https://automl.github.io/SMAC3/v2.2.0/",
"v2.1.0": "https://automl.github.io/SMAC3/v2.1.0/",
"v2.0.1": "https://automl.github.io/SMAC3/v2.0.1/",
"v2.0.0": "https://automl.github.io/SMAC3/v2.0.0/",
"v2.0.0b1": "https://automl.github.io/SMAC3/v2.0.0b1/",
Expand Down
2 changes: 1 addition & 1 deletion examples/1_basics/1_quadratic_function.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ class QuadraticFunction:
def configspace(self) -> ConfigurationSpace:
cs = ConfigurationSpace(seed=0)
x = Float("x", (-5, 5), default=-5)
cs.add_hyperparameters([x])
cs.add([x])

return cs

Expand Down
4 changes: 2 additions & 2 deletions examples/1_basics/2_svm_cv.py
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,8 @@ def configspace(self) -> ConfigurationSpace:
use_gamma_value = InCondition(child=gamma_value, parent=gamma, values=["value"])

# Add hyperparameters and conditions to our configspace
cs.add_hyperparameters([kernel, C, shrinking, degree, coef, gamma, gamma_value])
cs.add_conditions([use_degree, use_coef, use_gamma, use_gamma_value])
cs.add([kernel, C, shrinking, degree, coef, gamma, gamma_value])
cs.add([use_degree, use_coef, use_gamma, use_gamma_value])

return cs

Expand Down
2 changes: 1 addition & 1 deletion examples/1_basics/3_ask_and_tell.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ def configspace(self) -> ConfigurationSpace:
cs = ConfigurationSpace(seed=0)
x0 = Float("x0", (-5, 10), default=-3)
x1 = Float("x1", (-5, 10), default=-4)
cs.add_hyperparameters([x0, x1])
cs.add([x0, x1])

return cs

Expand Down
2 changes: 1 addition & 1 deletion examples/1_basics/4_callback.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ def configspace(self) -> ConfigurationSpace:
cs = ConfigurationSpace(seed=0)
x0 = Float("x0", (-5, 10), default=-3)
x1 = Float("x1", (-5, 10), default=-4)
cs.add_hyperparameters([x0, x1])
cs.add([x0, x1])

return cs

Expand Down
2 changes: 1 addition & 1 deletion examples/1_basics/5_continue.py
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ class QuadraticFunction:
def configspace(self) -> ConfigurationSpace:
cs = ConfigurationSpace(seed=0)
x = Float("x", (-5, 5), default=-5)
cs.add_hyperparameters([x])
cs.add([x])

return cs

Expand Down
6 changes: 3 additions & 3 deletions examples/1_basics/6_priors.py
Original file line number Diff line number Diff line change
Expand Up @@ -95,13 +95,13 @@ def configspace(self) -> ConfigurationSpace:
"learning_rate_init",
lower=1e-5,
upper=1.0,
mu=np.log(1e-3),
sigma=np.log(10),
mu=1e-3, # will be transformed to log space later
sigma=10, # will be transformed to log space later
log=True,
)

# Add all hyperparameters at once:
cs.add_hyperparameters([n_layer, n_neurons, activation, optimizer, batch_size, learning_rate_init])
cs.add([n_layer, n_neurons, activation, optimizer, batch_size, learning_rate_init])

return cs

Expand Down
11 changes: 9 additions & 2 deletions examples/1_basics/7_parallelization_cluster.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,9 @@
SLURM cluster. If you do not want to use a cluster but your local machine, set dask_client
to `None` and pass `n_workers` to the `Scenario`.

Sometimes, the submitted jobs by the slurm client might be cancelled once it starts. In that
case, you could try to start your job from a computing node

:warning: On some clusters you cannot spawn new jobs when running a SLURMCluster inside a
job instead of on the login node. No obvious errors might be raised but it can hang silently.

Expand Down Expand Up @@ -41,7 +44,7 @@ def configspace(self) -> ConfigurationSpace:
cs = ConfigurationSpace(seed=0)
x0 = Float("x0", (-5, 10), default=-5, log=False)
x1 = Float("x1", (0, 15), default=2, log=False)
cs.add_hyperparameters([x0, x1])
cs.add([x0, x1])

return cs

Expand Down Expand Up @@ -77,7 +80,7 @@ def train(self, config: Configuration, seed: int = 0) -> float:
model = Branin()

# Scenario object specifying the optimization "environment"
scenario = Scenario(model.configspace, deterministic=True, n_trials=100)
scenario = Scenario(model.configspace, deterministic=True, n_trials=100, trial_walltime_limit=100)

# Create cluster
n_workers = 4 # Use 4 workers on the cluster
Expand All @@ -97,6 +100,10 @@ def train(self, config: Configuration, seed: int = 0) -> float:
walltime="00:10:00",
processes=1,
log_directory="tmp/smac_dask_slurm",
# if you would like to limit the resources consumption of each function evaluation with pynisher, you need to
# set nanny as False
# Otherwise, an error `daemonic processes are not allowed to have children` will raise!
nanny=False # if you do not use pynisher to limit the memory/time usage, feel free to set this one as True
)
cluster.scale(jobs=n_workers)

Expand Down
4 changes: 2 additions & 2 deletions examples/2_multi_fidelity/1_mlp_epochs.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ def configspace(self) -> ConfigurationSpace:
learning_rate_init = Float("learning_rate_init", (0.0001, 1.0), default=0.001, log=True)

# Add all hyperparameters at once:
cs.add_hyperparameters([n_layer, n_neurons, activation, solver, batch_size, learning_rate, learning_rate_init])
cs.add([n_layer, n_neurons, activation, solver, batch_size, learning_rate, learning_rate_init])

# Adding conditions to restrict the hyperparameter space...
# ... since learning rate is only used when solver is 'sgd'.
Expand All @@ -76,7 +76,7 @@ def configspace(self) -> ConfigurationSpace:
use_batch_size = InCondition(child=batch_size, parent=solver, values=["sgd", "adam"])

# We can also add multiple conditions on hyperparameters at once:
cs.add_conditions([use_lr, use_batch_size, use_lr_init])
cs.add([use_lr, use_batch_size, use_lr_init])

return cs

Expand Down
2 changes: 1 addition & 1 deletion examples/2_multi_fidelity/2_sgd_datasets.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ def configspace(self) -> ConfigurationSpace:
learning_rate = Categorical("learning_rate", ["constant", "invscaling", "adaptive"], default="constant")
eta0 = Float("eta0", (0.00001, 1), default=0.1, log=True)
# Add the parameters to configuration space
cs.add_hyperparameters([alpha, l1_ratio, learning_rate, eta0])
cs.add([alpha, l1_ratio, learning_rate, eta0])

return cs

Expand Down
Loading
Loading