Installing Py-BOBYQA
====================
Requirements
------------
Py-BOBYQA requires the following software to be installed:
* Python 3.8 or higher (http://www.python.org/)
Additionally, the following python packages should be installed (these will be installed automatically if using `pip `_, see `Installation using pip`_):
* NumPy (http://www.numpy.org/)
* SciPy (http://www.scipy.org/)
* Pandas (http://pandas.pydata.org/)
**Optional package:** Py-BOBYQA versions 1.2 and higher also support the `trustregion `_ package for fast trust-region subproblem solutions. To install this, make sure you have a Fortran compiler (e.g. `gfortran `_) and NumPy installed, then run :code:`pip install trustregion`. You do not have to have trustregion installed for Py-BOBYQA to work, and it is not installed by default.
Installation using pip
----------------------
For easy installation, use `pip `_ as root:
.. code-block:: bash
$ [sudo] pip install Py-BOBYQA
If you do not have root privileges or you want to install Py-BOBYQA for your private use, you can use:
.. code-block:: bash
$ pip install --user Py-BOBYQA
which will install Py-BOBYQA in your home directory.
Note that if an older install of Py-BOBYQA is present on your system you can use:
.. code-block:: bash
$ [sudo] pip install --upgrade Py-BOBYQA
to upgrade Py-BOBYQA to the latest version.
Manual installation
-------------------
The source code for Py-BOBYQA is `available on Github `_:
.. code-block:: bash
$ git clone https://github.com/numericalalgorithmsgroup/pybobyqa
$ cd pybobyqa
Py-BOBYQA is written in pure Python and requires no compilation. It can be installed using:
.. code-block:: bash
$ [sudo] pip install .
If you do not have root privileges or you want to install Py-BOBYQA for your private use, you can use:
.. code-block:: bash
$ pip install --user .
instead.
To upgrade Py-BOBYQA to the latest version, navigate to the top-level directory (i.e. the one containing :code:`setup.py`) and rerun the installation using :code:`pip`, as above:
.. code-block:: bash
$ git pull
$ [sudo] pip install . # with admin privileges
Testing
-------
If you installed Py-BOBYQA manually, you can test your installation using the pytest package:
.. code-block:: bash
$ pip install pytest
$ python -m pytest --pyargs pybobyqa
Uninstallation
--------------
If Py-BOBYQA was installed using `pip `_ you can uninstall as follows:
.. code-block:: bash
$ [sudo] pip uninstall Py-BOBYQA
If Py-BOBYQA was installed manually you have to remove the installed files by hand (located in your python site-packages directory).