2012-08-12 03:05:13 +08:00
|
|
|
This directory has a simple C, C++, and Fortran code that shows how
|
|
|
|
LAMMPS can be linked to a driver application as a library. The purpose
|
|
|
|
is to illustrate how another code could perform computations while
|
|
|
|
using LAMMPS to perform MD on all or a subset of the processors, or
|
|
|
|
how an umbrella code or script could call both LAMMPS and some other
|
|
|
|
code to perform a coupled calculation.
|
|
|
|
|
|
|
|
simple.cpp is the C++ driver
|
|
|
|
simple.c is the C driver
|
|
|
|
simple.f90 is the Fortran driver
|
|
|
|
libfwrapper.c is the Fortran-to-C wrapper
|
|
|
|
|
|
|
|
The 3 codes do the same thing, so you can compare them to see how to
|
2015-09-25 06:48:28 +08:00
|
|
|
drive LAMMPS from each language. See lammps/python/example/simple.py
|
|
|
|
to do something similar from Python. The Fortran driver requires an
|
|
|
|
additional wrapper library that interfaces the C interface of the
|
|
|
|
LAMMPS library to Fortran and also translates the MPI communicator
|
|
|
|
from Fortran to C.
|
|
|
|
|
|
|
|
Once you have built LAMMPS as a library (see examples/COUPLE/README),
|
|
|
|
you can then build any of the driver codes with compile lines like
|
|
|
|
these, which include paths to the LAMMPS library interface, MPI (an
|
|
|
|
installed MPICH in this case), and FFTW (assuming you built LAMMPS as
|
|
|
|
a library with its PPPM solver).
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
This builds the C++ driver with the LAMMPS library using a C++ compiler:
|
|
|
|
|
|
|
|
g++ -I/home/sjplimp/lammps/src -c simple.cpp
|
|
|
|
g++ -L/home/sjplimp/lammps/src simple.o \
|
2015-09-25 06:48:28 +08:00
|
|
|
-llammps -lfftw -lmpich -lmpl -lpthread -o simpleCC
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
This builds the C driver with the LAMMPS library using a C compiler:
|
|
|
|
|
|
|
|
gcc -I/home/sjplimp/lammps/src -c simple.c
|
|
|
|
gcc -L/home/sjplimp/lammps/src simple.o \
|
2015-09-25 06:48:28 +08:00
|
|
|
-llammps -lfftw -lmpich -lmpl -lpthread -lstdc++ -o simpleC
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
This builds the Fortran wrapper and driver with the LAMMPS library
|
2012-08-14 07:49:26 +08:00
|
|
|
using a Fortran and C compiler, using the wrapper in the fortran
|
|
|
|
directory:
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
cp ../fortran/libfwrapper.c .
|
|
|
|
gcc -I/home/sjplimp/lammps/src -c libfwrapper.c
|
|
|
|
gfortran -I/home/sjplimp/lammps/src -c simple.f90
|
|
|
|
gfortran -L/home/sjplimp/lammps/src simple.o libfwrapper.o \
|
2015-09-25 06:48:28 +08:00
|
|
|
-llammps -lfftw -lfmpich -lmpich -lpthread -lstdc++ -o simpleF
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
You then run simpleCC, simpleC, or simpleF on a parallel machine
|
|
|
|
on some number of processors Q with 2 arguments:
|
|
|
|
|
2015-09-25 06:48:28 +08:00
|
|
|
% mpirun -np Q simpleCC P in.lj
|
2012-08-12 03:05:13 +08:00
|
|
|
|
|
|
|
P is the number of procs you want LAMMPS to run on (must be <= Q) and
|
|
|
|
in.lj is a LAMMPS input script.
|
|
|
|
|
|
|
|
The driver will launch LAMMPS on P procs, read the input script a line
|
|
|
|
at a time, and pass each command line to LAMMPS. The final line of
|
|
|
|
the script is a "run" command, so LAMMPS will run the problem.
|
|
|
|
|
|
|
|
The driver then requests all the atom coordinates from LAMMPS, moves
|
|
|
|
one of the atoms a small amount "epsilon", passes the coordinates back
|
|
|
|
to LAMMPS, and runs LAMMPS again. If you look at the output, you
|
|
|
|
should see a small energy change between runs, due to the moved atom.
|
|
|
|
|
|
|
|
The C driver is calling C-style routines in the src/library.cpp file
|
|
|
|
of LAMMPS. You could add any functions you wish to this file to
|
|
|
|
manipulate LAMMPS data however you wish.
|
|
|
|
|
|
|
|
The Fortran driver is using the same C-style routines, but requires an
|
|
|
|
additional wrapper to make them Fortran callable. Only a subset of the
|
|
|
|
library functions are currently wrapped, but it should be clear how to
|
|
|
|
extend the wrapper if desired.
|
|
|
|
|
|
|
|
The C++ driver does the same thing, except that it instantiates LAMMPS
|
|
|
|
as an object first. Some of the functions in src/library.cpp can be
|
2015-09-25 06:48:28 +08:00
|
|
|
by-passed and invoked directly as methods within appropriate LAMMPS
|
|
|
|
classes, which is what the driver does. Any public LAMMPS class
|
|
|
|
method could be called from the driver this way. However the get/put
|
|
|
|
functions are only implemented in src/library.cpp, so the C++ driver
|
|
|
|
calls them as C-style functions.
|