From c0d7098d1d62caad54b5f160d6ef1cd4e7321275 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 25 Nov 2024 23:44:36 +0000 Subject: [PATCH 1/2] [pre-commit.ci] pre-commit autoupdate MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit updates: - [github.com/astral-sh/ruff-pre-commit: v0.7.4 → v0.8.0](https://github.com/astral-sh/ruff-pre-commit/compare/v0.7.4...v0.8.0) --- .pre-commit-config.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index eebc7b06..0617a8ab 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -11,7 +11,7 @@ repos: exclude: ^example/AlN-LDA/ - repo: https://github.com/astral-sh/ruff-pre-commit - rev: v0.7.4 + rev: v0.8.0 hooks: - id: ruff args: [ "--fix", "--show-fixes" ] From 374b47499df335b503d0e6aec718e2b4ddb44e90 Mon Sep 17 00:00:00 2001 From: Atsushi Togo Date: Tue, 26 Nov 2024 10:27:32 +0900 Subject: [PATCH 2/2] Update document on installation --- doc/install.md | 70 +++++++++++++++++++++++++++++++------------------- 1 file changed, 44 insertions(+), 26 deletions(-) diff --git a/doc/install.md b/doc/install.md index 13c965f3..6ff25900 100644 --- a/doc/install.md +++ b/doc/install.md @@ -61,6 +61,7 @@ See an example at {ref}`install_an_example`. In the standard output, flags and libraries found by cmake are shown. Please carefully check if those configurations are expected ones or not. +(install_without_lapacke)= ### Building without linking LAPACKE **Experimental** @@ -118,7 +119,14 @@ wrong python libraries can be imported. For x86-64 system: ```bash - % conda install numpy scipy h5py pyyaml matplotlib-base c-compiler cxx-compiler "libblas=*=*mkl" spglib mkl-include cmake + % conda install numpy scipy h5py pyyaml matplotlib-base c-compiler cxx-compiler cmake spglib + ``` + + Unless {ref}`install_without_lapacke`, the following packages will be + necessary to compile phono3py: + + ```bash + % conda install "libblas=*=*mkl" mkl-include ``` A libblas library can be chosen among `[openblas, mkl, blis, netlib]`. If @@ -128,20 +136,21 @@ wrong python libraries can be imported. % conda install "libblas=*=*openblas" ``` - For macOS ARM64 system, currently only openblas can be chosen: + For macOS ARM64 system: ```bash - % conda install numpy scipy h5py pyyaml matplotlib-base c-compiler cxx-compiler spglib cmake openblas + % conda install numpy scipy h5py pyyaml matplotlib-base c-compiler cxx-compiler spglib cmake ``` - Note that using hdf5 files on NFS mounted file system, you may have to disable - file locking by setting + Unless {ref}`install_without_lapacke`, the following package will be + necessary to compile phono3py: ```bash - export HDF5_USE_FILE_LOCKING=FALSE + % conda install openblas ``` - Install the latest phonopy and phono3py from github sources: + The latest phonopy and phono3py are obtained from github, and they are + compiled and installed by: ```bash % mkdir dev @@ -154,20 +163,29 @@ wrong python libraries can be imported. % pip install . -vvv ``` - The editable install (`pip install -e`) may not work depending on the - computer environment. The conda packages dependency can often change and this - recipe may not work properly. So if you find this instruction doesn't work, - it is very appreciated if letting us know it in the phonopy mailing list. +## Dependent libraries + +### OpenMP + +#### GCC on Ubuntu + +With system provided gcc, `libgomp1` may be necessary to enable OpenMP +multithreading support. This library is probably installed already in your +system. If you don't have it and you use Ubuntu linux, it is installed by: + +```bash +% sudo apt-get install libgomp1 +``` (install_lapacke)= -## Installation of LAPACKE +### LAPACKE LAPACK library is used in a few parts of the code to diagonalize matrices. LAPACK*E* is the C-wrapper of LAPACK and LAPACK relies on BLAS. Both single-thread or multithread BLAS can be used in phono3py. In the following, multiple different ways of installation of LAPACKE are explained. -### OpenBLAS provided by conda +#### OpenBLAS provided by conda The installation of LAPACKE is easy by conda. It is: @@ -175,7 +193,7 @@ The installation of LAPACKE is easy by conda. It is: % conda install -c conda-forge openblas ``` -### Netlib LAPACKE provided by Ubuntu package manager (with single-thread BLAS) +#### Netlib LAPACKE provided by Ubuntu package manager (with single-thread BLAS) LAPACKE (http://www.netlib.org/lapack/lapacke.html) can be installed from the Ubuntu package manager (`liblapacke` and `liblapacke-dev`): @@ -184,7 +202,17 @@ Ubuntu package manager (`liblapacke` and `liblapacke-dev`): % sudo apt-get install liblapack-dev liblapacke-dev ``` -(install_openmp)= +## Using HDF5 files on NFS mounted file system + +If you are using HDF5 files on an NFS-mounted file system, you might need to +disable file locking. This can be done by setting the following environment +variable: + +```bash +export HDF5_USE_FILE_LOCKING=FALSE +``` + + ## Trouble shooting