Monday, December 25, 2017

Thermostatting Regions in LAMMPS


Thermostatting only a portion of a LAMMPS simulation box is straightforward, but is done in a way which isn’t at all intuitive to me. In fairness, both the manual and mailing list archives make the approach relatively clear. Having said that, I rather suspect that it might be something that most people have to see to believe.

Let’s say we have a tetragonal simulation box, a = b < c, α = β = γ = 90°, and we want to set up a temperature gradient along the long side. We can do this by heating one part of the box to a temperature TH, and cooling another part to TC. For the sake of a simple example, we’ll do this with simple velocity rescaling. The relevant LAMMPS command is fix temp/rescale. The following commands adjust the temperature by velocity rescaling every 10 timesteps, to TH = 3.0 and TC = 1.5. The remaining parameters, window and scale are explained on the linked manual page.

fix hot_rescale all temp/rescale 10 3.0 3.0 0.0001 1.0
fix cold_rescale all temp/rescale 10 1.5 1.5 0.0001 1.0

Of course, we need to limit the effect of these fixes to particular regions. Let’s assume a box of a = 20, b = 20, c = 100, with a “hot region” from (0, 0, 0) to (10, 20, 20), and a “cold region” from (50, 0, 0) to (60, 20, 20). Placing the cold region in the middle of the box allows us to make all three boundaries periodic.
Diagram of the simulation box.
Diagram of the simulation box showing the position of the thermostatted regions.
We first have to define the regions to be thermostatted using the regioncommand:

region hot block 0 10 0 20 0 20 units box
region cold block 50 60 0 20 0 20 units box

We define computes which calculate the temperature of our regions:

compute hot_temp all temp/region hot
compute cold_temp all temp/region cold

Finally, we must modify our thermostatting fixes to only adjust the temperature in the two defined regions. This is done by using a fix_modify command to change the way each of the thermostat fixes calculates the current temperature:

fix_modify hot_rescale temp hot_temp
fix_modify cold_rescale temp cold_temp
And that’s all there is to it. Don’t believe me? Try it!
Source: https://goo.gl/6YfQPt

Wednesday, May 10, 2017

Linux Command References

http://www.rationallyparanoid.com/articles/Linux%20command%20reference.pdf

http://www.linuxdevcenter.com/excerpt/LinuxPG_quickref/linux.pdf



1. Linux Command Line

2. Linux Security

3. Linux Administration

4. Gnome/KDE

5. sed/awk/vim and other tools

6. Distro Specific

7. Everything Else

  • Online Man Pages - The ultimate cheat sheet repository. Also use the ‘man’ command.

Source: https://www.nixtutor.com/linux/all-the-best-linux-cheat-sheets

Monday, May 8, 2017

Compiling NAMD-2.12 With Intel compiler 2013, iMPI 4.1.0 and FFTW-2.1.5

Downloand NAMD Source Code

Step 1: Prepare for Environment Setup

source /opt/IntelClusterStudioXE2013/composer_xe_2013.1.117/mkl/bin/mklvars.sh intel64
source /opt/IntelClusterStudioXE2013/composer_xe_2013.1.117/bin/compilervars.sh intel64
source /opt/IntelClusterStudioXE2013/impi/4.1.0.024/intel64/bin/mpivars.sh intel64
source /opt/IntelClusterStudioXE2013/composer_xe_2013.1.117/tbb/bin/tbbvars.sh intel64
source /opt/IntelClusterStudioXE2013/itac/8.1.0.024/intel64/bin/itacvars.sh

export CC=icc
export CXX=icpc
export F77=ifort
export F90=ifort
Step 2: Building FFTW-2.1.5 with Intel
$ wget http://www.fftw.org/fftw-2.1.5.tar.gz
$ tar -zxvf fftw-2.1.5.tar.gz
$ cd fftw-2.1.5
$ ./configure F77=ifort CC=icc CFLAGS=-O3 FFLAGS=-O3 --enable-threads --enable-float --enable-type-prefix --prefix=/usr/local/fftw-2.1.5_intel-4.1.0
$ make -j 16
$ make install

Step 3: Building CHARM-6.7.1
$ cd NAMD_2.12_Source          
$ tar -xvf charm-6.7.1.tar
$ cd charm-6.7.1
./build charm++ {arch} {C compiler} {Fortran compiler} {other options} 
$ MPICXX=mpiicpc CXX=icpc ./build charm++  mpi-linux-x86_64 mpicxx ifort --with-production --no-shared -O3 -DCMK_OPTIMIZE=1
$ cd $NAMD_SRC
Step 4: Building TCL-8.5.9 with Intel
wget http://www.ks.uiuc.edu/Research/namd/libraries/tcl8.5.9-linux-x86_64.tar.gz 
wget http://www.ks.uiuc.edu/Research/namd/libraries/tcl8.5.9-linux-x86_64-threaded.tar.gz 
tar -xvf tcl8.5.9-linux-x86_64.tar.gz 
tar -xvf tcl8.5.9-linux-x86_64-threaded.tar.gz 
mv tcl8.5.9-linux-x86_64 tcl 
mv tcl8.5.9-linux-x86_64-threaded tcl-threaded
Step 5: Modify architecture files
Setup the CHARMBASE in $NAMD_SRC for Make.charm
# Set CHARMBASE to the top level charm directory.
# The config script will override this setting if there is a directory
# called charm-6.7.1 or charm in the NAMD base directory.

CHARMBASE = /usr/local/NAMD_2.12/charm-6.7.1


Setup the FFTW architecture files in $NAMD_SRC/arch/Linux-x86_64.fftw

FFTDIR=/usr/local/fftw-2.1.5_intel-4.1.0
FFTINCL=-I$(FFTDIR)/include
FFTLIB=-L$(FFTDIR)/lib -lsrfftw -lsfftw
FFTFLAGS=-DNAMD_FFTW
FFT=$(FFTINCL) $(FFTFLAGS)
Create file  $NAMD_SRC/Linux-x86_64-ics-2013.arch
NAMD_ARCH = Linux-x86_64
CHARMARCH = mpi-linux-x86_64-ifort-mpicxx
FLOATOPTS = -O2
CXX = icpc -std=c++11
CXXOPTS = -static-intel -O2 $(FLOATOPTS)
CXXNOALIASOPTS = -O3 -fno-alias $(FLOATOPTS)
CC = icc
COPTS = -static-intel -O2 $(FLOATOPTS)

Step 6: Compile NAMD.
Make sure you're in the main NAMD directory, then configure and run make:
$ ./config Linux-x86_64-ics-2013 --charm-base ./charm-6.7.1 --charm-arch mpi-linux-x86_64-ifort-mpicxx
$ cd Linux-x86_64-ics-2013
$ make -j 16
You should see the namd2 executable
Step 7: mpirun
$ mpirun -np 32 -machinefile $MACHINEFILE namd2  something.conf > job$LSB_JOBID.log