|
| 1 | +# import numpy as np |
| 2 | + |
| 3 | +# from bayes_opt import BayesianOptimization |
| 4 | +# from bayes_opt.util import ensure_rng |
| 5 | + |
| 6 | + |
| 7 | +# def test_simple_optimization(): |
| 8 | +# """ |
| 9 | +# ... |
| 10 | +# """ |
| 11 | +# def f(x, y): |
| 12 | +# return -x ** 2 - (y - 1) ** 2 + 1 |
| 13 | + |
| 14 | + |
| 15 | +# optimizer = BayesianOptimization( |
| 16 | +# f=f, |
| 17 | +# pbounds={"x": (-3, 3), "y": (-3, 3)}, |
| 18 | +# random_state=12356, |
| 19 | +# verbose=0, |
| 20 | +# ) |
| 21 | + |
| 22 | +# optimizer.maximize(init_points=0, n_iter=25) |
| 23 | + |
| 24 | +# max_target = optimizer.max["target"] |
| 25 | +# max_x = optimizer.max["params"]["x"] |
| 26 | +# max_y = optimizer.max["params"]["y"] |
| 27 | + |
| 28 | +# assert (1 - max_target) < 1e-3 |
| 29 | +# assert np.abs(max_x - 0) < 1e-1 |
| 30 | +# assert np.abs(max_y - 1) < 1e-1 |
| 31 | + |
| 32 | + |
| 33 | +# def test_intermediate_optimization(): |
| 34 | +# """ |
| 35 | +# ... |
| 36 | +# """ |
| 37 | +# def f(x, y, z): |
| 38 | +# x_factor = np.exp(-(x - 2) ** 2) + (1 / (x ** 2 + 1)) |
| 39 | +# y_factor = np.exp(-(y - 6) ** 2 / 10) |
| 40 | +# z_factor = (1 + 0.2 * np.cos(z)) / (1 + z ** 2) |
| 41 | +# return (x_factor + y_factor) * z_factor |
| 42 | + |
| 43 | +# optimizer = BayesianOptimization( |
| 44 | +# f=f, |
| 45 | +# pbounds={"x": (-7, 7), "y": (-7, 7), "z": (-7, 7)}, |
| 46 | +# random_state=56, |
| 47 | +# verbose=0, |
| 48 | +# ) |
| 49 | + |
| 50 | +# optimizer.maximize(init_points=0, n_iter=150) |
| 51 | + |
| 52 | +# max_target = optimizer.max["target"] |
| 53 | +# max_x = optimizer.max["params"]["x"] |
| 54 | +# max_y = optimizer.max["params"]["y"] |
| 55 | +# max_z = optimizer.max["params"]["z"] |
| 56 | + |
| 57 | +# assert (2.640 - max_target) < 0 |
| 58 | +# assert np.abs(2 - max_x) < 1e-1 |
| 59 | +# assert np.abs(6 - max_y) < 1e-1 |
| 60 | +# assert np.abs(0 - max_z) < 1e-1 |
| 61 | + |
| 62 | + |
| 63 | +# if __name__ == '__main__': |
| 64 | +# r""" |
| 65 | +# CommandLine: |
| 66 | +# python tests/test_bayesian_optimization.py |
| 67 | +# """ |
| 68 | +# import pytest |
| 69 | +# pytest.main([__file__]) |
0 commit comments