..
: PyBEST: Pythonic Black-box Electronic Structure Tool
: Copyright (C) 2016-- The PyBEST Development Team
:
: This file is part of PyBEST.
:
: PyBEST is free software; you can redistribute it and/or
: modify it under the terms of the GNU General Public License
: as published by the Free Software Foundation; either version 3
: of the License, or (at your option) any later version.
:
: PyBEST is distributed in the hope that it will be useful,
: but WITHOUT ANY WARRANTY; without even the implied warranty of
: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
: GNU General Public License for more details.
:
: You should have received a copy of the GNU General Public License
: along with this program; if not, see
:
: --
Mac OS X (10.14 or higher)
##########################
Disclaimer
==========
PyBEST has been tested on Mac OS X 10.14 (Mojave) and 10.15 (Catalina) using
MacPorts (exceptions are MKL, Libint2, and HighFive libraries). If you are
using an older version of OS X or other package managers, some of the
instructions below may not work.
.. note::
If you have already installed a Python distribution (with another package
manager than MacPorts, such as Anaconda or Canopy), it may interfere with the one
installed through MacPorts. The instructions below assume that no such other
installation of Python is present.
MacPorts
========
We strongly recommend that you install all of the packages required by PyBEST
through MacPorts. The latest version of MacPorts can be downloaded from the web:
https://www.macports.org/install.php. This guide has been tested using
MacPorts 2.6.3 but should also work with older versions.
A quick tour of MacPorts
------------------------
Here are some basic MacPorts commands:
* checking port version:
.. code-block:: bash
port version
* updating ports (recommended!):
.. code-block:: bash
sudo port -v selfupdate
* upgrading ports:
.. code-block:: bash
sudo port upgrade outdated
* finding ports (e.g, port_name = python38):
.. code-block:: bash
sudo port list python38
* searching ports (e.g, port_name = python38):
.. code-block:: bash
port search python38
* installing ports (e.g, port_name = python38):
.. code-block:: bash
sudo port install python38
* selecting ports (e.g, select python38 as python):
.. code-block:: bash
sudo port select --set python python38
Download PyBEST
===============
The latest stable source code release of PyBEST can be downloaded here:
* `version 1.0.0 `_
Choose a suitable directory, e.g. ``$HOME/my_pybest``, and download the above mentioned source and unpack:
.. code-block:: bash
mkdir -p $HOME/my_pybest; cd $HOME/my_pybest
wget http://www.fizyka.umk.pl/~pybest/downloads/pybest.v1.0.0.tar.gz
tar -xvf pybest.v1.0.0.tar.gz
Dependencies for building, installing, and testing PyBEST
=========================================================
To compile and test PyBEST, you need to install relatively recent
versions of the following programs/libraries:
.. note::
Some of the packages will install others.
* ``python38`` (>=3.8.2), https://github.com/macports/macports-ports/blob/master/lang/python38/Portfile
.. code-block:: bash
sudo port install python38
* ``python3_select`` (>=0.0), https://github.com/macports/macports-ports/blob/master/sysutils/python3_select/Portfile
.. code-block:: bash
sudo port install python3_select
sudo port select --set python python38
* ``cmake`` (>=3.16), https://github.com/macports/macports-ports/blob/master/devel/cmake/Portfile
.. code-block:: bash
sudo port install cmake
* ``git`` (>=2.25.1), https://github.com/macports/macports-ports/blob/master/devel/git/Portfile
.. code-block:: bash
sudo port install git
sudo port select --set python2 python27
* ``py38-numpy`` (>=1.18.1), https://github.com/macports/macports-ports/blob/master/python/py-numpy/Portfile
.. code-block:: bash
sudo port install py38-numpy
port select --set cython cython38
* ``py38-scipy`` (>=1.4.1), https://github.com/macports/macports-ports/blob/master/python/py-scipy/Portfile
.. code-block:: bash
sudo port install py38-scipy
* ``boost`` (>=1.71.0), https://github.com/macports/macports-ports/blob/master/devel/boost/Portfile
.. code-block:: bash
sudo port install boost
* ``py38-pip`` (>=20.0.2), https://github.com/macports/macports-ports/blob/master/python/py-pip/Portfile
.. code-block:: bash
sudo port install py38-pip
* ``py38-h5py`` (>=2.10.0), https://ports.macports.org/port/py38-h5py/summary
.. code-block:: bash
sudo port install py38-h5py
h5cc --showconfig
* ``pip_select`` (>=0.1), https://github.com/macports/macports-ports/blob/master/python/pip_select/Portfile
.. code-block:: bash
sudo port install pip_select
* ``py38-nose`` (>=1.3.7), https://github.com/macports/macports-ports/blob/master/python/py-nose/Portfile
.. code-block:: bash
sudo port install py38-nose
* ``py38-setuptools`` (>=43.0.0), https://github.com/macports/macports-ports/blob/master/python/py-setuptools/Portfile
.. code-block:: bash
sudo port install py38-setuptools
* ``eigen3`` (>=3.3.7), https://github.com/macports/macports-ports/blob/master/math/eigen3/Portfile
.. code-block:: bash
sudo port install eigen3
* ``gcc9`` (>=9.2.0), https://github.com/macports/macports-ports/blob/master/lang/gcc9/Portfile
.. code-block:: bash
sudo port install gcc9
* ``gcc_select`` (>=0.1), https://github.com/macports/macports-ports/blob/master/sysutils/gcc_select/Portfile
.. code-block:: bash
sudo port install gcc_select
sudo port select --set gcc gcc-nm-mp-9
* ``py38-pip`` (>=20.02), https://ports.macports.org/port/py38-pip/summary
.. code-block:: bash
sudo port install py38-pip
sudo port select --set pip pip38
* ``h5py`` (>=2.10), http://docs.h5py.org/en/stable/build.html
.. code-block:: bash
pip3 install h5py
* ``pytest`` (>=5.4.0), https://pypi.org/project/pytest/
.. code-block:: bash
pip3 install pytest
* ``HighFive`` (>=2.2), https://github.com/BlueBrain/HighFive.git
.. code-block:: bash
mkdir ~/HighFive
export HIGHFIVE_VER=2.2
cd ~/HighFive; mkdir ${HIGHFIVE_VER}
cd ${HIGHFIVE_VER};
git clone https://github.com/BlueBrain/HighFive.git
Installing MKL
--------------
* The installation of Intel MKL library is pretty straightforward and can be found here:
https://software.intel.com/en-us/mkl/choose-download/macos
Installing Libint2
------------------
There are two ways of installing the Libint2 library (>=2.6.0):
1. as a dependency within PyBEST (**highly recommended**):
.. code-block:: bash
cd $HOME/my_pybest/pybest.v1.0.0/depends
make libint
2. as a standalone package
* A recent version of Libint2 can be found here:
https://github.com/evaleev/libint
To properly work with PyBEST, Libint2 has to be compiled using a ``clang`` compiler
and with ``C++11`` standard. The maximum angular momentum should be set to 7.
Make sure that during the installation your ``MKL_ROOT`` is properly exported.
.. note::
PyBEST has been tested with ``libint-2.6`` and ``libint-2.7-beta``
using ``make``.
Installing Libchol (optional)
-----------------------------
The Libchol library allows you to make use of the Cholesky decomposition technique
in the evaluation of two-electron integrals. PyBEST will work without it, but
we strongly recommend it for large-scale calculations.
.. code-block:: bash
cd $HOME/my_pybest/pybest.v1.0.0/depends
make libchol
.. note::
You might need to set up some environmental variables at this point. Examples
are provided in the next section.
Building and installing PyBEST
==============================
Overriding default compiler/linker settings
-------------------------------------------
.. code-block:: bash
cd $HOME/my_pybest/pybest.v1.0.0/
cp setup.cfg.ini setup.cfg
Adopt the existing `setup.cfg` to your specific setup.
An example configuration file based on OS X Catalinia (10.15.3) is shown below:
.. code-block:: bash
[libint2]
# If both paths have not been exported, you need to define them
#include_dirs=/usr/include/
#library_dirs=/usr/lib/
#
# If enviroment variables are defined
include_dirs=${LIBINT2_ROOT}/include
library_dirs=${LIBINT2_ROOT}/lib
libraries=int2
[eigen]
# If the path to the include directory is not exported, you need to define it
#include_dirs=/usr/include/eigen3
#
# If enviroment variables are defined
include_dirs=${EIGEN_ROOT}/include/eigen3:${EIGEN_ROOT}/include
libraries=eigen3
[libchol]
# To link to the shared libraries, uncomment below. Do not forget to update
# the LD_LIBRARY_PATH
# For Mac OS and Clang, you also need to add the path to omp.h (e.g.,
# /opt/local/include/libomp or you build with additional
# CPPFLAGS='-I/opt/local/include/libomp -lomp')
# For intel and gnu compilers
#include_dirs=./depends/libchol-upstream/installdir/include
#library_dirs=./depends/libchol-upstream/installdir/lib
#libraries=chol
# For Clang
include_dirs=./depends/libchol-upstream/installdir/include:/opt/local/include/libomp
library_dirs=./depends/libchol-upstream/installdir/lib
libraries=chol:omp
[blas]
# If both paths have not been exported, you need to define them
#include_dirs=/usr/include/
#library_dirs=/usr/lib/
#
# If enviroment variables are defined
include_dirs=${MKL_ROOT}/include
library_dirs=${MKL_ROOT}/lib
libraries=mkl_rt
[boost]
# If the path to the include directory is not exported, you need to define it
#include_dirs=/usr/include/boost
#
# If enviroment variables are defined
include_dirs=${BOOST_ROOT}/include:${BOOST_ROOT}/include/boost
libraries=boost
[highfive]
# If both paths have not been exported, you need to define them
#include_dirs=/usr/include/
#
# If enviroment variables are defined
include_dirs=${HIGHFIVE_ROOT}/include
libraries=highfive
[hdf5]
# If both paths have not been exported, you need to define them
#include_dirs=/usr/include/
#library_dirs=/usr/lib/
#
# If enviroment variables are defined
include_dirs=${HDF5_ROOT}/include
library_dirs=${HDF5_ROOT}/lib
libraries=hdf5
where the evironmental variables are defined in, for instance, ``~/.profile``,
.. code-block:: bash
### PyBEST ##########
export LIBINT2_ROOT=/$HOME/my_pybest/pybest.v1.0.0/depends/libint-upstream/installdir
export EIGEN_ROOT=/opt/local
export HIGHFIVE_ROOT="path-to-your-HighFive"/highFive/HighFive
export MKL_ROOT=/opt/intel/compilers_and_libraries_2020.0.166/mac/mkl
export HDF5_ROOT=/opt/local
export BOOST_ROOT=/opt/local
export DYLD_LIBRARY_PATH=/opt/intel/mkl/lib:$DYLD_LIBRARY_PATH
Actual build and installation
-----------------------------
* Building extensions:
.. code-block:: bash
python setup.py build_ext -i
* Building extensions with the Libchol library (optional):
.. code-block:: bash
python setup.py build_ext -i --enable-cholesky=1
* Install PyBEST:
.. code-block:: bash
# using pip
pip install . --user
# OR using setup.py
python setup.py install --prefix=/path/to/your/installdir
If you do not install PyBEST as a local site package of python (using
``pip install . --user``, you need to set some environment variables to use PyBEST. Add the following to
your ``~/.profile``:
.. code-block:: bash
export PATH=/path/to/your/installdir/bin:$PATH
If need be, you have to update your ``PYTHONPATH`` as well. We thus recommend the
installation option using `pip`.
Running the tests
=================
To test that PyBEST was installed properly you can run:
.. code-block:: bash
cd $HOME/my_pybest/pybest.v1.0.0/src/
python -m pytest pybest -vs
Building the documentation
==========================
Installing the dependencies with MacPorts and PIP
-------------------------------------------------
Most can be installed directly with MacPorts. The following list of ports is recommended:
* ``doxygen`` (>=1.8.17), https://www.macports.org/ports.php?by=library&substr=doxygen
.. code-block:: bash
sudo port install doxygen
* ``py38-sphinx`` (>=2.4.3), https://github.com/macports/macports-ports/blob/master/python/py-sphinx/Portfile
.. code-block:: bash
sudo port install py38-sphinx
port select --set pygments py38-pygments
port select --set sphinx py38-sphinx
* ``texlive`` (>=2019), https://github.com/macports/macports-ports/blob/master/tex/texlive/Portfile
.. code-block:: bash
sudo port install texlive
The missing ``sphinx_rtd_theme`` should be installed through PIP:
.. code-block:: bash
pip install sphinx_rtd_theme
pip install --user --upgrade sphinx breath
An actual documentation build
-----------------------------
The documentation is compiled and viewed as follows:
.. code-block:: bash
cd doc; make html; open -a safari _build/html/index.html