Epistemic Nearest Neighbors
Project description
Epistemic Nearest Neighbors
A fast, alternative surrogate for Bayesian optimization
ENN estimates a function's value and associated epistemic uncertainty using a K-Nearest Neighbors model. Queries take $O(N lnK)$ time, where $N$ is the number of observations available for KNN lookups. Compare to an exact GP, which takes $O(N^2)$ time. Additionally, measured running times are very small compared to GPs and other alternative surrogates. [1]
Contents
- ENN model,
EpistemicNearestNeighbors[1] - TuRBO-ENN optimizer, class
TurboOptimizerhas four modesTURBO_ONE- A clone of the TuRBO [2] reference code, reworked to have anask()/tell()interface.TURBO_ENN- Same as TURBO_ONE, except uses ENN instead of GP and Pareto(mu, se) instead of Thompson sampling.TURBO_ZERO- Same as TURBO_ONE, except randomly-chosen RAASP [3] candidates are picked to be proposals. There is no surrogate.LHD_ONLY- Just creates an LHD design for everyask(). Good for a baseline and for testing.
[1] Sweet, D., & Jadhav, S. A. (2025). Taking the GP Out of the Loop. arXiv preprint arXiv:2506.12818. https://arxiv.org/abs/2506.12818 [2] Eriksson, D., Pearce, M., Gardner, J. R., Turner, R., & Poloczek, M. (2020). Scalable Global Optimization via Local Bayesian Optimization. Advances in Neural Information Processing Systems, 32. https://arxiv.org/abs/1910.01739 [3] Rashidi, B., Johnstonbaugh, K., & Gao, C. (2024). Cylindrical Thompson Sampling for High-Dimensional Bayesian Optimization. Proceedings of The 27th International Conference on Artificial Intelligence and Statistics (pp. 3502–3510). PMLR. https://proceedings.mlr.press/v238/rashidi24a.html
Installation
pip install ennbo
Demonstration
demo_enn.ipynb - Shows how to use EpistemicNearestNeighbors to build and query an ENN model.
demo_turbo_enn.ipynb - Shows how to use TurboOptimizer to optimize the Ackley function.
Installation, MacOS
On my MacBook I can run into problems with dependencies and compatibilities.
On MacOS try:
micromamba env create -n ennbo -f admin/conda-macos.yml
micromamba activate ennbo
pip install --no-deps ennbo
pytest -sv tests
You may replace micromamba with conda and this will probably still work.
The commands above make sure
- You use the MacOS-specific PyTorch (with
mps). - You avoid having multiple, competing OpenMPs installed PyTorch issue faiss issue.
- You use old enough versions of NumPy and PyTorch to be compatible with faiss faiss issue.
- Prevent matplotlib's installation from upgrading your NumPy to an incompatible version.
ennbo's listed dependencies do not undo any of the above (which is fine b/c the above commands set the up correctly).
Run tests with
pytest -x -sv tests
and they should all pass fairly quickly (~10s-30s).
If your code still crashes or hangs your, try this hack:
export KMP_DUPLICATE_LIB_OK=TRUE
export OMP_NUM_THREADS=1
I don't recommend this, however, as it will slow things down.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ennbo-0.1.2.tar.gz.
File metadata
- Download URL: ennbo-0.1.2.tar.gz
- Upload date:
- Size: 38.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b8e7eb78ab6ae6c24bff67dc72fc99dc81500f42414f06a71576b3db9f03527a
|
|
| MD5 |
ed49253db3622f6d84ab98a2b1665d55
|
|
| BLAKE2b-256 |
af6194f65f3e01b932195b16969fd0f3b8486ec324e86389d193c03d029a222c
|
File details
Details for the file ennbo-0.1.2-py3-none-any.whl.
File metadata
- Download URL: ennbo-0.1.2-py3-none-any.whl
- Upload date:
- Size: 34.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
87bfbbe1712a7490d8655776f85d58416f57cddbbb95146d22238c55b6f451f3
|
|
| MD5 |
bb1a443925d7ed3bb52d2fd6470f0805
|
|
| BLAKE2b-256 |
4143961767eaa4261ca412e268db3224dc5ad236263e4e1732357d90ce1318d7
|