-
Notifications
You must be signed in to change notification settings - Fork 26
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Feature / refresh History dtype upon encountering a new field (#1203)
* initial commit, first approach at adding new fields to history array if an unexpected one is returned from a user function * adjust ibcdfo branch * slight refactoring of passing safe_mode attribute around - its an immmutable attribute usable by both the manager and history throughout runtime * can only check if its appropiate to append new fields if we actually got a returned_H back * gen can send back "unexpected" fields too - test this with adjust to test_persistent_uniform_sampling_running_mean.py * from-file bugfix
- Loading branch information
Showing
9 changed files
with
111 additions
and
33 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
""" | ||
Runs libEnsemble with Latin hypercube sampling on a simple 1D problem | ||
Execute via one of the following commands (e.g. 3 workers): | ||
mpiexec -np 4 python test_1d_sampling.py | ||
python test_1d_sampling.py --nworkers 3 --comms local | ||
python test_1d_sampling.py --nworkers 3 --comms tcp | ||
The number of concurrent evaluations of the objective function will be 4-1=3. | ||
""" | ||
|
||
# Do not change these lines - they are parsed by run-tests.sh | ||
# TESTSUITE_COMMS: mpi local | ||
# TESTSUITE_NPROCS: 2 4 | ||
|
||
import numpy as np | ||
|
||
from libensemble.gen_funcs.sampling import latin_hypercube_sample as gen_f | ||
|
||
# Import libEnsemble items for this test | ||
from libensemble.libE import libE | ||
from libensemble.tools import add_unique_random_streams, parse_args, save_libE_output | ||
|
||
|
||
def sim_f(In): | ||
Out = np.zeros(1, dtype=[("f", float), ("N", int)]) | ||
Out["f"] = np.linalg.norm(In) | ||
Out["N"] = 123 | ||
return Out | ||
|
||
|
||
if __name__ == "__main__": | ||
nworkers, is_manager, libE_specs, _ = parse_args() | ||
|
||
sim_specs = { | ||
"sim_f": sim_f, | ||
"in": ["x"], | ||
"out": [("f", float)], | ||
} | ||
|
||
gen_specs = { | ||
"gen_f": gen_f, | ||
"out": [("x", float, (1,))], | ||
"user": { | ||
"gen_batch_size": 500, | ||
"lb": np.array([-3]), | ||
"ub": np.array([3]), | ||
}, | ||
} | ||
|
||
persis_info = add_unique_random_streams({}, nworkers + 1, seed=1234) | ||
|
||
exit_criteria = {"gen_max": 501} | ||
|
||
H, persis_info, flag = libE(sim_specs, gen_specs, exit_criteria, persis_info, libE_specs=libE_specs) | ||
|
||
if is_manager: | ||
assert len(H) >= 501 | ||
assert "N" in H.dtype.names, "New datatype not added to history" | ||
print("\nlibEnsemble with random sampling has generated enough points") | ||
save_libE_output(H, persis_info, __file__, nworkers) |
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