git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@4634 f3b2605a-c512-4ea7-a41b-209d697bcdaa

This commit is contained in:
sjplimp
2010-09-01 00:13:30 +00:00
parent 9561f63b07
commit 45454edd0b
3 changed files with 1277 additions and 0 deletions

View File

@ -11,6 +11,7 @@ if (test $1 = 1) then
cp pair_eam.cpp ..
cp pair_eam_alloy.cpp ..
cp pair_eam_fs.cpp ..
cp pair_eim.cpp ..
cp pair_sw.cpp ..
cp pair_tersoff.cpp ..
cp pair_tersoff_zbl.cpp ..
@ -21,6 +22,7 @@ if (test $1 = 1) then
cp pair_eam.h ..
cp pair_eam_alloy.h ..
cp pair_eam_fs.h ..
cp pair_eim.h ..
cp pair_sw.h ..
cp pair_tersoff.h ..
cp pair_tersoff_zbl.h ..
@ -37,6 +39,7 @@ elif (test $1 = 0) then
rm ../pair_eam.cpp
rm ../pair_eam_alloy.cpp
rm ../pair_eam_fs.cpp
rm ../pair_eim.cpp
rm ../pair_sw.cpp
rm ../pair_tersoff.cpp
rm ../pair_tersoff_zbl.cpp
@ -47,6 +50,7 @@ elif (test $1 = 0) then
rm ../pair_eam.h
rm ../pair_eam_alloy.h
rm ../pair_eam_fs.h
rm ../pair_eim.h
rm ../pair_sw.h
rm ../pair_tersoff.h
rm ../pair_tersoff_zbl.h

1172
src/MANYBODY/pair_eim.cpp Normal file

File diff suppressed because it is too large Load Diff

101
src/MANYBODY/pair_eim.h Normal file
View File

@ -0,0 +1,101 @@
/* ----------------------------------------------------------------------
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
http://lammps.sandia.gov, Sandia National Laboratories
Steve Plimpton, sjplimp@sandia.gov
Copyright (2003) Sandia Corporation. Under the terms of Contract
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
certain rights in this software. This software is distributed under
the GNU General Public License.
See the README file in the top-level LAMMPS directory.
------------------------------------------------------------------------- */
#ifdef PAIR_CLASS
PairStyle(eim,PairEIM)
#else
#ifndef LMP_PAIR_EIM_H
#define LMP_PAIR_EIM_H
#include "stdio.h"
#include "pair.h"
namespace LAMMPS_NS {
class PairEIM : public Pair {
public:
PairEIM(class LAMMPS *);
~PairEIM();
void compute(int, int);
void settings(int, char **);
void coeff(int, char **);
void init_style();
double init_one(int, int);
int pack_comm(int, int *, double *, int, int *);
void unpack_comm(int, int, double *);
int pack_reverse_comm(int, int, double *);
void unpack_reverse_comm(int, int *, double *);
double memory_usage();
private:
double **cutforcesq,cutmax;
int nmax;
double *rho,*fp;
int rhofp;
int *map; // which element each atom type maps to
int nelements; // # of elements to read from potential file
char **elements; // element names
struct Setfl {
double division,rbig,rsmall;
int nr;
int *ielement,*tp;
double *mass,*negativity,*ra,*ri,*Ec,*q0;
double *rcutphiA,*rcutphiR,*Eb,*r0,*alpha,*beta,
*rcutq,*Asigma,*rq,*rcutsigma,*Ac,*zeta,
*rs;
double dr,cut;
double ***Fij,***Gij,***phiij;
double **cuts;
};
Setfl *setfl;
// potentials as array data
int nr;
int nFij,nGij,nphiij;
double **Fij,**Gij,**phiij;
int **type2Fij,**type2Gij,**type2phiij;
// potentials in spline form used for force computation
double dr,rdr;
double *negativity,*q0;
double ***Fij_spline,***Gij_spline,***phiij_spline;
void allocate();
void array2spline();
void interpolate(int, double, double *, double **, double);
int grabglobal(FILE *);
int grabsingle(FILE *, int);
int grabpair(FILE *, int, int);
double funccutoff(double, double, double);
double funcphi(int, int, double);
double funcsigma(int, int, double);
double funccoul(int, int, double);
void read_file(char *);
void deallocate_setfl();
void file2array();
};
}
#endif
#endif