update instructions for in qmmm README to cover both build systems and include more details

This commit is contained in:
Axel Kohlmeyer 2020-02-20 16:59:06 +01:00
parent febb381880
commit 0db0d5408a
No known key found for this signature in database
GPG Key ID: D9B44E93BF0C375A
2 changed files with 205 additions and 25 deletions

View File

@ -0,0 +1,82 @@
# -*- Makefile -*- for coupling LAMMPS to PWscf for QM/MM molecular dynamics
# adapted for the case of compiling LAMMPS with CMake. This assumes that
# LAMMPS was configured to build a shared library and installed with "make install"
# as it used the PKG config configuration file. You may need to extend
# the PKG_CONFIG_PATH environment variable to have pkgconf find the liblammps.pc file.
# This is set up for using GNU Fortran and OpenMPI to compile both LAMMPS and QE
# this file will be copied to Makefile.lammps
EXTRAMAKE = Makefile.lammps.empty
# top level directory of Quantum ESPRESSO 6.3 or later (tested up to QE 6.5)
QETOPDIR=$(HOME)/compile/espresso
# import compiler settings from Quantum ESPRESSO
sinclude $(QETOPDIR)/make.inc
# FLAGS for compiling and linking the pwqmmm.x executable
MPICXX=mpicxx
MPICXXFLAGS=-DOMPI_SKIP_MPICXX=1 -O2 -Wall -g -fPIC\
-I../../src -I$(QETOPDIR)/COUPLE/include
# location of required libraries
# part 1: hi-level libraries for building pw.x
PWOBJS = \
$(QETOPDIR)/COUPLE/src/libqecouple.a \
$(QETOPDIR)/PW/src/libpw.a \
$(QETOPDIR)/Modules/libqemod.a
# part 2: lo-level libraries for all of Q-E
LIBOBJS = \
$(QETOPDIR)/FFTXlib/libqefft.a \
$(QETOPDIR)/dft-d3/libdftd3qe.a \
$(QETOPDIR)/KS_Solvers/PPCG/libppcg.a \
$(QETOPDIR)/KS_Solvers/CG/libcg.a \
$(QETOPDIR)/KS_Solvers/Davidson/libdavid.a \
$(QETOPDIR)/UtilXlib/libutil.a \
$(QETOPDIR)/LAXlib/libqela.a \
$(QETOPDIR)/clib/clib.a \
$(QETOPDIR)/iotk/src/libiotk.a
# add support for fortran runtimes for compiler and MPI library
# those are automatically included when linking QE executables,
# since they use mpifort/mpif90 to link, but we are using the
# C++ MPI compiler wrapper instead, so those need to be added
# as a dependency for QE objects and libraries
QELIBS += -lgfortran -lmpi_mpifh
# part 3: add-on libraries and main library for LAMMPS
sinclude ../../src/Makefile.package
LAMMPSFLAGS = $(shell pkgconf liblammps --cflags)
LAMMPSLIB = $(shell pkgconf liblammps --libs)
# part 4: local QM/MM library and progams
SRC=pwqmmm.c libqmmm.c
OBJ=$(SRC:%.c=%.o)
default: libqmmm.a
all : tldeps libqmmm.a pwqmmm.x
pwqmmm.x : pwqmmm.o $(PWOBJS) $(LIBOBJS)
$(MPICXX) $(LDFLAGS) -o $@ $^ $(LAMMPSLIB) $(QELIBS) $(LIBS)
libqmmm.a: libqmmm.o
$(AR) $(ARFLAGS) $@ $^
@cp $(EXTRAMAKE) Makefile.lammps
%.o: %.c
$(MPICXX) -c $(LAMMPSFLAGS) $(MPICXXFLAGS) $< -o $@
tldeps:
( cd $(QETOPDIR) ; $(MAKE) $(MFLAGS) couple || exit 1)
$(MAKE) -C ../../src $(MFLAGS) $(LAMMPSCFG)
$(MAKE) -C ../../src $(MFLAGS) mode=lib $(LAMMPSCFG)
clean :
-rm -f *.x *.o *.a *~ *.F90 *.d *.mod *.i *.L
# explicit dependencies
pwqmmm.o: pwqmmm.c libqmmm.h
libqmmm.o: libqmmm.c libqmmm.h

View File

@ -1,4 +1,5 @@
QM/MM support library QM/MM support library
=====================
Axel Kohlmeyer, akohlmey@gmail.com Axel Kohlmeyer, akohlmey@gmail.com
Temple University, Philadelphia and ICTP, Trieste Temple University, Philadelphia and ICTP, Trieste
@ -13,25 +14,26 @@ performing QM/MM molecular dynamics simulations. More information on
Quantum ESPRESSO can be found at: http://www.quantum-espresso.org Quantum ESPRESSO can be found at: http://www.quantum-espresso.org
The interface code itself is designed so it can also be combined with The interface code itself is designed so it can also be combined with
other QM codes, however only support for Quantum ESPRESSO is currently other QM codes, however coupling to Quantum ESPRESSO is currently the
the only option. Adding support for a different QM code will require only available option. Adding support for a different QM code will
to write a new version of the top-level wrapper code, pwqmmm.c, and require to write a new version of the top-level wrapper code, pwqmmm.c,
also an interface layer into the QM code similar to the one in QE. and also an interface layer into the QM code similar to the one in QE.
You can type "make lib-qmmm" from the src directory to see help on how LAMMPS has support for two build systems, the traditional make based
to build this library (steps 1 and 2 below) via make commands, or you one and a newer one based on CMake. You have to build LAMMPS as a
can do the same thing by typing "python Install.py" from within this library with the USER-QMMM package included and for that you need to
directory, or you can do it manually by following the instructions also build the libqmmm.a library in this folder.
below.
However you perform steps 1 and 2, you will need to perform steps 3 Below you will find some description of the steps needed in either case.
and 4 manually, as outlined below. However you build LAMMPS and the liblammps and libqmmm libraries, you
will need to perform the remaining steps manually, as outlined below.
------------------------------------------------- -------------------------------------------------
WARNING: This is experimental code under developement and is provided WARNING: This is code depending on two software packages that are
at this early stage to encourage others to write interfaces to other independently maitained and are under continuous active developement.
QM codes. Please test *very* carefully before using this software for It is thus much easier to break the QM/MM interface without noticing.
Thus please test *very* carefully before using this software for
production calculations. production calculations.
At this point, both mechanical and multipole based electrostatic At this point, both mechanical and multipole based electrostatic
@ -40,17 +42,92 @@ molecules as included in the two example folders.
------------------------------------------------- -------------------------------------------------
Building the QM/MM executable has to be done in multiple stages. Building the QM/MM executable has to be done in multiple stages
Building with CMake for LAMMPS
==============================
Step 1) Step 1)
Build the qmmm coupling library in this directory using one of the
provided Makefile.<compiler> files or create your own, specific to
your compiler and system. For example with:
make -f Makefile.gfortran Go to the top-level folder of the LAMMPS source code and create
a custom build folder (e.g. build-qmmm) and create a suitable
build configuration with CMake:
mkdir build-qmmm
cd build-qmmm
cmake -C ../cmake/presets/minimal.cmake -D PKG_USER-QMMM=yes \
-D BUILD_LIB=yes -DBUILD_SHARED_LIBS=yes ../cmake
make
make install
This will build a LAMMPS executable "lmp" and a shared library
"liblammps.so" and install them and additional configuration and
supporting files into the ${HOME}/.local directory tree (unless
you set -D CMAKE_INSTALL_PREFIX to a different location). If the
installation is not into a system folder, you need to update
the LD_LIBRARY_PATH and PKG_CONFIG_PATH environment variables.
LD_LIBRARY_PATH=${LD_LIBRARY_PATH-/usr/lib64}:${HOME}/.local/lib64
PKG_CONFIG_PATH=${PKG_CONFIG_PATH-/usr/lib64/pkgconfig}:${HOME}/.local/lib64/pkgconfig
export LD_LIBRARY_PATH PKG_CONFIG_PATH
The standalone LAMMPS executable is not capable of doing QM/MM
calculations itself, but it will be needed to run all MM calculations
for equilibration and testing and also to confirm that the classical
part of the code is set up correctly.
Step 2)
Build a standalone pw.x executable from source code in the Quantum
ESPRESSO directory and also make the "couple" target. This is typically
done with:
./configure
make pw couple
You may need to review and edit the make.inc file created by configure.
Make certain, that both LAMMPS and QE use the same MPI library and
compatible compilers. In the examples here we assume GNU compilers
(gfortran, gcc, g++) and OpenMPI.
Building the standalone pw.x binary is needed to confirm that
corresponding QM input is working correctly and to run test calculations
on the QM atoms only.
Step 3)
Go back to this folder (lib/qmmm) and now review the file
Makefile.gfortran-cmake and make adjustments to the makefile variables
according to the comments in the file. You probably need to adjust
the QETOPDIR variable to point to the location of your QE
compilation/installation.
Please also check that the command "pkgconf liblammps --libs" works.
Then you should be able to compile the QM/MM executable with:
make -f Makefile.gfortran-cmake pwqmmm.x
If this is successful, you should be able to run a QM/MM calculation
and can try the examples in the example-mc and example-ec folders:
mpirun -np 4 ../pwqmmm.x qmmm.inp 2
Building with traditional make for LAMMPS
=========================================
Step 1)
Go to src folder under the top-level folder of the LAMMPS source code
and build the qmmm coupling library in this directory using one of
the provided Makefile.<compiler> files. E.g. for use with GNU fortran:
make lib-qmmm args="-m gfortran"
This file is specific to your compiler and system. You may need to
create a specific one for your choice of compilers, MPI, and OS.
When you are done building this library, two new files should When you are done building this library, two new files should
exist in this directory: exist in this directory (lib/qmmm):
libqmmm.a the library LAMMPS will link against libqmmm.a the library LAMMPS will link against
Makefile.lammps settings the LAMMPS Makefile will import Makefile.lammps settings the LAMMPS Makefile will import
@ -60,21 +137,42 @@ Makefile.lammps.empty file. Currently no additional dependencies for
this library exist. this library exist.
Step 2) Step 2)
Build a standalone LAMMPS executable as described in the LAMMPS Build a standalone LAMMPS executable as described in the LAMMPS
documentation and include the USER-QMMM package. This executable documentation and include the USER-QMMM package. This executable
is not functional for QM/MM, but it will usually be needed to is not functional for QM/MM, but it will usually be needed to
run all MM calculations for equilibration and testing and also run all MM calculations for equilibration and testing and also
to confirm that the classical part of the code is set up correctly. to confirm that the classical part of the code is set up correctly.
Also build a the LAMMPS library. This can be a static library
or a shared library. For example for a static library with the
minimum set of packages required for the examples here:
make yes-molecule yes-kspace yes-rigid yes-user-qmmm
make mpi
make mode=lib mpi
Step 3) Step 3)
Build a standalone pw.x executable in the Quantum ESPRESSO directory
and also make the "couple" target. Building the standalone pw.x Build a standalone pw.x executable from source code in the Quantum
binary is also needed to confirm that corresponding QM input is ESPRESSO directory and also make the "couple" target. This is typically
working correctly and to run test calculations on QM atoms only. done with:
./configure
make pw couple
You may need to review and edit the make.inc file created by configure.
Make certain, that both LAMMPS and QE use the same MPI library and
compatible compilers. In the examples here we assume GNU compilers
(gfortran, gcc, g++) and OpenMPI.
Building the standalone pw.x binary is needed to confirm that
corresponding QM input is working correctly and to run test calculations
on the QM atoms only.
Step 4) Step 4)
To compile and link the final QM/MM executable, which combines the To compile and link the final QM/MM executable, which combines the
compiled sources from both packages, you have to return to the lib/qmmm compiled code from both packages, you have to return to the lib/qmmm
directory and now edit the Makefile.<compiler> for the Makefile directory and now edit the Makefile.<compiler> for the Makefile
configuration used to compile LAMMPS and also update the directory configuration used to compile LAMMPS and also update the directory
and library settings for the Quantum ESPRESSO installation. and library settings for the Quantum ESPRESSO installation.