Metadata-Version: 2.4
Name: physbo
Version: 3.2.0
Summary: optimization tool for PHYSics based on Bayesian Optimization
Author-email: PHYSBO developers <physbo-dev@issp.u-tokyo.ac.jp>
License-Expression: MPL-2.0
Project-URL: homepage, https://www.pasums.issp.u-tokyo.ac.jp/physbo/en
Project-URL: source, https://github.com/issp-center-dev/PHYSBO
Project-URL: documentation, https://issp-center-dev.github.io/PHYSBO/
Project-URL: releasenotes, https://github.com/issp-center-dev/PHYSBO/releases
Requires-Python: >=3.9
Description-Content-Type: text/markdown
Requires-Dist: numpy
Requires-Dist: odat-se>=3.2.0
Requires-Dist: scipy
Provides-Extra: odat-se
Requires-Dist: odat-se; extra == "odat-se"
Provides-Extra: docs
Requires-Dist: gitpython>=3.1.45; extra == "docs"
Requires-Dist: jupyter>=1.1.1; extra == "docs"
Requires-Dist: matplotlib>=3.9.4; extra == "docs"
Requires-Dist: nbsphinx>=0.9.7; extra == "docs"
Requires-Dist: sphinx>=7.4.7; extra == "docs"
Requires-Dist: sphinx-rtd-theme>=3.0.2; extra == "docs"
Provides-Extra: tutorials
Requires-Dist: jupyter>=1.1.1; extra == "tutorials"
Requires-Dist: matplotlib>=3.9.4; extra == "tutorials"
Requires-Dist: odat-se>=3.2.0; extra == "tutorials"
Requires-Dist: pandas>=2.3.3; extra == "tutorials"
Provides-Extra: tests
Requires-Dist: pytest>=8.4.2; extra == "tests"
Requires-Dist: pytest-mock>=3.15.1; extra == "tests"

# optimization tools for PHYsics based on Bayesian Optimization ( PHYSBO )

Bayesian optimization has been proven as an effective tool in accelerating scientific discovery.
A standard implementation (e.g., scikit-learn), however, can accommodate only small training data.
PHYSBO is highly scalable due to an efficient protocol that employs Thompson sampling, random feature maps, one-rank Cholesky update and automatic hyperparameter tuning. Technical features are described in [COMBO's document](https://github.com/tsudalab/combo/blob/master/docs/combo_document.pdf) and [PHYSBO's report](https://doi.org/10.1016/j.cpc.2022.108405) (open access).
PHYSBO was developed based on [COMBO](https://github.com/tsudalab/combo) for academic use.

## Documentation

- Stable (master branch)
  - [English](https://issp-center-dev.github.io/PHYSBO/manual/master/en/index.html)
  - [日本語](https://issp-center-dev.github.io/PHYSBO/manual/master/ja/index.html)
- Latest (develop branch)
  - [English](https://issp-center-dev.github.io/PHYSBO/manual/develop/en/index.html)
  - [日本語](https://issp-center-dev.github.io/PHYSBO/manual/develop/ja/index.html)

## Dependencies

- Python >= 3.9
- NumPy
- SciPy

### Optional dependencies

- [ODAT-SE](https://github.com/issp-center-dev/ODAT-SE) (for continuous space optimization)

  ``` bash
  python3 -m pip install odat-se
  ```

## Install

- From PyPI (recommended)

  ```bash
  python3 -m pip install physbo
  ```

- From source (for developers)

    1. Download or clone the github repository

        ```bash
        git clone https://github.com/issp-center-dev/PHYSBO
        ```

    1. Install via pip

        ``` bash
        # ./PHYSBO is the root directory of PHYSBO
        # pip install options such as --user are avaiable

        python3 -m pip install ./PHYSBO
        ```

## Uninstall

```bash
python3 -m pip uninstall physbo
```

## Usage

For an introductory tutorial please consult the documentation. ([English](https://issp-center-dev.github.io/PHYSBO/manual/master/en/notebook/tutorial_basic.html) / [日本語](https://issp-center-dev.github.io/PHYSBO/manual/develop/ja/install.html#id2))

['examples/simple.py'](./examples/simple.py) is a simple example.

## Data repository

A tutorial and a dataset of a paper about PHYSBO can be found in [PHYSBO Gallery](https://isspns-gitlab.issp.u-tokyo.ac.jp/physbo-dev/physbo-gallery).

## For developers

[UV](https://docs.astral.sh/uv/) is recommended to make a virtual environment and install dependencies for development.

### Run tests

When using UV, the command `uv sync --extra tests` will install the dependencies to run tests like `pytest`.
Test files are in `tests/` directory, and use `pytest` to run tests.

``` bash
uv run pytest tests
```

### Build documentation

When using UV, the command `uv sync --extra docs` will install the dependencies for building the documentation like `sphinx`.

The command

```bash
uv run bash docs/make_docs.sh
```

will build the documentation into `docs/built`.

## License

PHYSBO was developed based on [COMBO](https://github.com/tsudalab/COMBO) for academic use.
PHYSBO is distributed under Mozilla Public License version 2.0 (MPL v2).
We hope that you cite the following reference when you publish the results using PHYSBO:

[“Bayesian optimization package: PHYSBO”, Yuichi Motoyama, Ryo Tamura, Kazuyoshi Yoshimi, Kei Terayama, Tsuyoshi Ueno, Koji Tsuda, Computer Physics Communications Volume 278, September 2022, 108405.](https://doi.org/10.1016/j.cpc.2022.108405)

Bibtex

```bibtex
@misc{@article{MOTOYAMA2022108405,
title = {Bayesian optimization package: PHYSBO},
journal = {Computer Physics Communications},
volume = {278},
pages = {108405},
year = {2022},
issn = {0010-4655},
doi = {https://doi.org/10.1016/j.cpc.2022.108405},
author = {Yuichi Motoyama and Ryo Tamura and Kazuyoshi Yoshimi and Kei Terayama and Tsuyoshi Ueno and Koji Tsuda},
keywords = {Bayesian optimization, Multi-objective optimization, Materials screening, Effective model estimation}
}
```

### Copyright

© *2020- The University of Tokyo. All rights reserved.*
This software was developed with the support of \"*Project for advancement of software usability in materials science*\" of The Institute for Solid State Physics, The University of Tokyo.
