forked from lijiext/lammps
git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@5302 f3b2605a-c512-4ea7-a41b-209d697bcdaa
This commit is contained in:
parent
0d9d109d49
commit
2de8e4d51d
|
@ -1240,6 +1240,87 @@ void Group::angmom(int igroup, double *cm, double *lmom, int iregion)
|
||||||
MPI_Allreduce(p,lmom,3,MPI_DOUBLE,MPI_SUM,world);
|
MPI_Allreduce(p,lmom,3,MPI_DOUBLE,MPI_SUM,world);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------
|
||||||
|
compute the torque T (tq) on group
|
||||||
|
around center-of-mass cm
|
||||||
|
must unwrap atoms to compute T correctly
|
||||||
|
------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void Group::torque(int igroup, double *cm, double *tq)
|
||||||
|
{
|
||||||
|
int groupbit = bitmask[igroup];
|
||||||
|
|
||||||
|
double **x = atom->x;
|
||||||
|
double **f = atom->f;
|
||||||
|
int *mask = atom->mask;
|
||||||
|
int *image = atom->image;
|
||||||
|
int nlocal = atom->nlocal;
|
||||||
|
|
||||||
|
int xbox,ybox,zbox;
|
||||||
|
double dx,dy,dz;
|
||||||
|
double xprd = domain->xprd;
|
||||||
|
double yprd = domain->yprd;
|
||||||
|
double zprd = domain->zprd;
|
||||||
|
double tlocal[3];
|
||||||
|
tlocal[0] = tlocal[1] = tlocal[2] = 0.0;
|
||||||
|
|
||||||
|
for (int i = 0; i < nlocal; i++)
|
||||||
|
if (mask[i] & groupbit) {
|
||||||
|
xbox = (image[i] & 1023) - 512;
|
||||||
|
ybox = (image[i] >> 10 & 1023) - 512;
|
||||||
|
zbox = (image[i] >> 20) - 512;
|
||||||
|
dx = (x[i][0] + xbox*xprd) - cm[0];
|
||||||
|
dy = (x[i][1] + ybox*yprd) - cm[1];
|
||||||
|
dz = (x[i][2] + zbox*zprd) - cm[2];
|
||||||
|
tlocal[0] += dy*f[i][2] - dz*f[i][1];
|
||||||
|
tlocal[1] += dz*f[i][0] - dx*f[i][2];
|
||||||
|
tlocal[2] += dx*f[i][1] - dy*f[i][0];
|
||||||
|
}
|
||||||
|
|
||||||
|
MPI_Allreduce(tlocal,tq,3,MPI_DOUBLE,MPI_SUM,world);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------
|
||||||
|
compute the torque T (tq) on group of atoms in region
|
||||||
|
around center-of-mass cm
|
||||||
|
must unwrap atoms to compute T correctly
|
||||||
|
------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void Group::torque(int igroup, double *cm, double *tq, int iregion)
|
||||||
|
{
|
||||||
|
int groupbit = bitmask[igroup];
|
||||||
|
Region *region = domain->regions[iregion];
|
||||||
|
|
||||||
|
double **x = atom->x;
|
||||||
|
double **f = atom->f;
|
||||||
|
int *mask = atom->mask;
|
||||||
|
int *image = atom->image;
|
||||||
|
int nlocal = atom->nlocal;
|
||||||
|
|
||||||
|
int xbox,ybox,zbox;
|
||||||
|
double dx,dy,dz;
|
||||||
|
double xprd = domain->xprd;
|
||||||
|
double yprd = domain->yprd;
|
||||||
|
double zprd = domain->zprd;
|
||||||
|
double tlocal[3];
|
||||||
|
tlocal[0] = tlocal[1] = tlocal[2] = 0.0;
|
||||||
|
|
||||||
|
for (int i = 0; i < nlocal; i++)
|
||||||
|
if (mask[i] & groupbit && region->match(x[i][0],x[i][1],x[i][2])) {
|
||||||
|
xbox = (image[i] & 1023) - 512;
|
||||||
|
ybox = (image[i] >> 10 & 1023) - 512;
|
||||||
|
zbox = (image[i] >> 20) - 512;
|
||||||
|
dx = (x[i][0] + xbox*xprd) - cm[0];
|
||||||
|
dy = (x[i][1] + ybox*yprd) - cm[1];
|
||||||
|
dz = (x[i][2] + zbox*zprd) - cm[2];
|
||||||
|
tlocal[0] += dy*f[i][2] - dz*f[i][1];
|
||||||
|
tlocal[1] += dz*f[i][0] - dx*f[i][2];
|
||||||
|
tlocal[2] += dx*f[i][1] - dy*f[i][0];
|
||||||
|
}
|
||||||
|
|
||||||
|
MPI_Allreduce(tlocal,tq,3,MPI_DOUBLE,MPI_SUM,world);
|
||||||
|
}
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------
|
/* ----------------------------------------------------------------------
|
||||||
compute moment of inertia tensor around center-of-mass cm of group
|
compute moment of inertia tensor around center-of-mass cm of group
|
||||||
must unwrap atoms to compute itensor correctly
|
must unwrap atoms to compute itensor correctly
|
||||||
|
|
|
@ -54,6 +54,8 @@ class Group : protected Pointers {
|
||||||
double gyration(int, double, double *, int);
|
double gyration(int, double, double *, int);
|
||||||
void angmom(int, double *, double *); // angular momentum of group
|
void angmom(int, double *, double *); // angular momentum of group
|
||||||
void angmom(int, double *, double *, int);
|
void angmom(int, double *, double *, int);
|
||||||
|
void torque(int, double *, double *); // torque on group
|
||||||
|
void torque(int, double *, double *, int);
|
||||||
void inertia(int, double *, double [3][3]); // inertia tensor
|
void inertia(int, double *, double [3][3]); // inertia tensor
|
||||||
void inertia(int, double *, double [3][3], int);
|
void inertia(int, double *, double [3][3], int);
|
||||||
void omega(double *, double [3][3], double *); // angular velocity
|
void omega(double *, double [3][3], double *); // angular velocity
|
||||||
|
|
|
@ -2423,8 +2423,8 @@ int Variable::math_function(char *word, char *contents, Tree **tree,
|
||||||
customize by adding a group function with optional region arg:
|
customize by adding a group function with optional region arg:
|
||||||
count(group),mass(group),charge(group),
|
count(group),mass(group),charge(group),
|
||||||
xcm(group,dim),vcm(group,dim),fcm(group,dim),
|
xcm(group,dim),vcm(group,dim),fcm(group,dim),
|
||||||
bound(group,xmin),gyration(group),ke(group),angmom(group),
|
bound(group,xmin),gyration(group),ke(group),angmom(group,dim),
|
||||||
inertia(group,dim),omega(group,dim)
|
torque(group,dim),inertia(group,dim),omega(group,dim)
|
||||||
------------------------------------------------------------------------- */
|
------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int Variable::group_function(char *word, char *contents, Tree **tree,
|
int Variable::group_function(char *word, char *contents, Tree **tree,
|
||||||
|
@ -2438,7 +2438,8 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
|
||||||
strcmp(word,"vcm") && strcmp(word,"fcm") &&
|
strcmp(word,"vcm") && strcmp(word,"fcm") &&
|
||||||
strcmp(word,"bound") && strcmp(word,"gyration") &&
|
strcmp(word,"bound") && strcmp(word,"gyration") &&
|
||||||
strcmp(word,"ke") && strcmp(word,"angmom") &&
|
strcmp(word,"ke") && strcmp(word,"angmom") &&
|
||||||
strcmp(word,"inertia") && strcmp(word,"omega"))
|
strcmp(word,"torque") && strcmp(word,"inertia") &&
|
||||||
|
strcmp(word,"omega"))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
// parse contents for arg1,arg2,arg3 separated by commas
|
// parse contents for arg1,arg2,arg3 separated by commas
|
||||||
|
@ -2588,6 +2589,24 @@ int Variable::group_function(char *word, char *contents, Tree **tree,
|
||||||
else if (strcmp(arg2,"z") == 0) value = lmom[2];
|
else if (strcmp(arg2,"z") == 0) value = lmom[2];
|
||||||
else error->all("Invalid group function in variable formula");
|
else error->all("Invalid group function in variable formula");
|
||||||
|
|
||||||
|
} else if (strcmp(word,"torque") == 0) {
|
||||||
|
atom->check_mass();
|
||||||
|
double xcm[3],tq[3];
|
||||||
|
if (narg == 2) {
|
||||||
|
double masstotal = group->mass(igroup);
|
||||||
|
group->xcm(igroup,masstotal,xcm);
|
||||||
|
group->torque(igroup,xcm,tq);
|
||||||
|
} else if (narg == 3) {
|
||||||
|
int iregion = region_function(arg3);
|
||||||
|
double masstotal = group->mass(igroup,iregion);
|
||||||
|
group->xcm(igroup,masstotal,xcm,iregion);
|
||||||
|
group->torque(igroup,xcm,tq,iregion);
|
||||||
|
} else error->all("Invalid group function in variable formula");
|
||||||
|
if (strcmp(arg2,"x") == 0) value = tq[0];
|
||||||
|
else if (strcmp(arg2,"y") == 0) value = tq[1];
|
||||||
|
else if (strcmp(arg2,"z") == 0) value = tq[2];
|
||||||
|
else error->all("Invalid group function in variable formula");
|
||||||
|
|
||||||
} else if (strcmp(word,"inertia") == 0) {
|
} else if (strcmp(word,"inertia") == 0) {
|
||||||
atom->check_mass();
|
atom->check_mass();
|
||||||
double xcm[3],inertia[3][3];
|
double xcm[3],inertia[3][3];
|
||||||
|
|
Loading…
Reference in New Issue