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

This commit is contained in:
sjplimp 2013-07-25 19:47:41 +00:00
parent 856f78e50a
commit 48510d047b
4 changed files with 166 additions and 26 deletions

View File

@ -106,6 +106,13 @@ Atom::Atom(LAMMPS *lmp) : Pointers(lmp)
improper_type = improper_atom1 = improper_atom2 = NULL; improper_type = improper_atom1 = improper_atom2 = NULL;
improper_atom3 = improper_atom4 = NULL; improper_atom3 = improper_atom4 = NULL;
// custom atom arrays
nivector = ndvector = 0;
ivector = NULL;
dvector = NULL;
iname = dname = NULL;
// initialize atom style and array existence flags // initialize atom style and array existence flags
// customize by adding new flag // customize by adding new flag
@ -223,6 +230,17 @@ Atom::~Atom()
memory->destroy(improper_atom3); memory->destroy(improper_atom3);
memory->destroy(improper_atom4); memory->destroy(improper_atom4);
// delete custom atom arrays
for (int i = 0; i < nivector; i++) {
memory->destroy(ivector[i]);
delete [] iname[i];
}
for (int i = 0; i < ndvector; i++) {
memory->destroy(dvector[i]);
delete [] dname[i];
}
// delete per-type arrays // delete per-type arrays
delete [] mass; delete [] mass;
@ -1439,6 +1457,87 @@ void Atom::update_callback(int ifix)
if (extra_border[i] > ifix) extra_border[i]--; if (extra_border[i] > ifix) extra_border[i]--;
} }
/* ----------------------------------------------------------------------
find custom per-atom vector with name
return index if found, and flag = 0/1 for int/double
return -1 if not found
------------------------------------------------------------------------- */
int Atom::find_custom(char *name, int &flag)
{
for (int i = 0; i < nivector; i++)
if (iname[i] && strcmp(iname[i],name) == 0) {
flag = 0;
return i;
}
for (int i = 0; i < ndvector; i++)
if (dname[i] && strcmp(dname[i],name) == 0) {
flag = 1;
return i;
}
return -1;
}
/* ----------------------------------------------------------------------
add a custom variable with name of type flag = 0/1 for int/double
assumes name does not already exist
return index in ivector or dvector of its location
------------------------------------------------------------------------- */
int Atom::add_custom(char *name, int flag)
{
int index;
if (flag == 0) {
index = nivector;
nivector++;
iname = (char **) memory->srealloc(iname,nivector*sizeof(char *),
"atom:iname");
int n = strlen(name) + 1;
iname[index] = new char[n];
strcpy(iname[index],name);
ivector = (int **) memory->srealloc(ivector,nivector*sizeof(int *),
"atom:ivector");
memory->create(ivector[index],nmax,"atom:ivector");
} else {
index = ndvector;
ndvector++;
dname = (char **) memory->srealloc(dname,ndvector*sizeof(char *),
"atom:dname");
int n = strlen(name) + 1;
dname[index] = new char[n];
strcpy(dname[index],name);
dvector = (double **) memory->srealloc(dvector,ndvector*sizeof(double *),
"atom:dvector");
memory->create(dvector[index],nmax,"atom:dvector");
}
return index;
}
/* ----------------------------------------------------------------------
remove a custom variable of type flag = 0/1 for int/double at index
free memory for vector and name and set ptrs to NULL
ivector/dvector and iname/dname lists never shrink
------------------------------------------------------------------------- */
void Atom::remove_custom(int flag, int index)
{
if (flag == 0) {
memory->destroy(ivector[index]);
ivector[index] = NULL;
delete [] iname[index];
iname[index] = NULL;
} else {
memory->destroy(dvector[index]);
dvector[index] = NULL;
delete [] dname[index];
dname[index] = NULL;
}
}
/* ---------------------------------------------------------------------- /* ----------------------------------------------------------------------
return a pointer to a named internal variable return a pointer to a named internal variable
if don't recognize name, return NULL if don't recognize name, return NULL

View File

@ -83,6 +83,15 @@ class Atom : protected Pointers {
int **improper_type; int **improper_type;
int **improper_atom1,**improper_atom2,**improper_atom3,**improper_atom4; int **improper_atom1,**improper_atom2,**improper_atom3,**improper_atom4;
// custom arrays used by fix property/atom
int **ivector;
double **dvector;
char **iname,**dname;
int nivector,ndvector;
// used by USER-CUDA to flag used per-atom arrays
unsigned int datamask; unsigned int datamask;
unsigned int datamask_ext; unsigned int datamask_ext;
@ -176,6 +185,10 @@ class Atom : protected Pointers {
void delete_callback(const char *, int); void delete_callback(const char *, int);
void update_callback(int); void update_callback(int);
int find_custom(char *, int &);
int add_custom(char *, int);
void remove_custom(int, int);
void *extract(char *); void *extract(char *);
inline int* get_map_array() {return map_array;}; inline int* get_map_array() {return map_array;};

View File

@ -25,11 +25,6 @@ using namespace FixConst;
enum{MOLECULE,INTEGER,DOUBLE}; enum{MOLECULE,INTEGER,DOUBLE};
// NOTE: how to prevent atom style being changed after this fix defined?
// e.g. what if replicate happens, will it wipe out molecule_flag
// will it copy ivectors in atom.h ??
// maybe setting of atom->mol_flag should happen in fix init
/* ---------------------------------------------------------------------- */ /* ---------------------------------------------------------------------- */
FixPropertyAtom::FixPropertyAtom(LAMMPS *lmp, int narg, char **arg) : FixPropertyAtom::FixPropertyAtom(LAMMPS *lmp, int narg, char **arg) :
@ -42,6 +37,7 @@ FixPropertyAtom::FixPropertyAtom(LAMMPS *lmp, int narg, char **arg) :
int iarg = 3; int iarg = 3;
nvalue = narg-iarg; nvalue = narg-iarg;
style = new int[nvalue]; style = new int[nvalue];
index = new int[nvalue];
molecule_flag = 0; molecule_flag = 0;
@ -58,9 +54,19 @@ FixPropertyAtom::FixPropertyAtom(LAMMPS *lmp, int narg, char **arg) :
nvalue++; nvalue++;
} else if (strstr(arg[iarg],"i_") == arg[iarg]) { } else if (strstr(arg[iarg],"i_") == arg[iarg]) {
style[nvalue] = INTEGER; style[nvalue] = INTEGER;
int tmp;
index[nvalue] = atom->find_custom(&arg[iarg][2],tmp);
if (index[nvalue] >= 0)
error->all(FLERR,"Fix property/atom vector name already exists");
index[nvalue] = atom->add_custom(&arg[iarg][2],0);
nvalue++; nvalue++;
} else if (strstr(arg[iarg],"d_") == arg[iarg]) { } else if (strstr(arg[iarg],"d_") == arg[iarg]) {
style[nvalue] = DOUBLE; style[nvalue] = DOUBLE;
int tmp;
index[nvalue] = atom->find_custom(&arg[iarg][2],tmp);
if (index[nvalue] >= 0)
error->all(FLERR,"Fix property/atom vector name already exists");
index[nvalue] = atom->add_custom(&arg[iarg][2],1);
nvalue++; nvalue++;
} else break; } else break;
@ -111,11 +117,14 @@ FixPropertyAtom::~FixPropertyAtom()
memory->destroy(atom->molecule); memory->destroy(atom->molecule);
atom->molecule = NULL; atom->molecule = NULL;
} else if (style[m] == INTEGER) { } else if (style[m] == INTEGER) {
atom->remove_custom(0,index[m]);
} else if (style[m] == DOUBLE) { } else if (style[m] == DOUBLE) {
atom->remove_custom(1,index[m]);
} }
} }
delete [] style; delete [] style;
delete [] index;
} }
/* ---------------------------------------------------------------------- */ /* ---------------------------------------------------------------------- */
@ -187,8 +196,10 @@ void FixPropertyAtom::read_data_section(char *keyword, int n, char *buf)
if ((m = atom->map(tagdata)) >= 0) { if ((m = atom->map(tagdata)) >= 0) {
for (j = 0; j < nvalue; j++) { for (j = 0; j < nvalue; j++) {
if (style[j] == MOLECULE) atom->molecule[m] = atoi(values[j+1]); if (style[j] == MOLECULE) atom->molecule[m] = atoi(values[j+1]);
else if (style[j] == INTEGER) atom->molecule[m] = atoi(values[j+1]); else if (style[j] == INTEGER)
else if (style[j] == DOUBLE) atom->molecule[m] = atof(values[j+1]); atom->ivector[index[j]][m] = atoi(values[j+1]);
else if (style[j] == DOUBLE)
atom->dvector[index[j]][m] = atof(values[j+1]);
} }
} }
@ -235,13 +246,13 @@ void FixPropertyAtom::grow_arrays(int nmax)
size_t nbytes = (nmax-nmax_old) * sizeof(int); size_t nbytes = (nmax-nmax_old) * sizeof(int);
memset(&atom->molecule[nmax_old],0,nbytes); memset(&atom->molecule[nmax_old],0,nbytes);
} else if (style[m] == INTEGER) { } else if (style[m] == INTEGER) {
memory->grow(atom->molecule,nmax,"atom:molecule"); memory->grow(atom->ivector[index[m]],nmax,"atom:ivector");
size_t nbytes = (nmax-nmax_old) * sizeof(int); size_t nbytes = (nmax-nmax_old) * sizeof(int);
memset(&atom->molecule[nmax_old],0,nbytes); memset(&atom->ivector[index[m]][nmax_old],0,nbytes);
} else if (style[m] == DOUBLE) { } else if (style[m] == DOUBLE) {
memory->grow(atom->molecule,nmax,"atom:molecule"); memory->grow(atom->dvector[index[m]],nmax,"atom:dvector");
size_t nbytes = (nmax-nmax_old) * sizeof(double); size_t nbytes = (nmax-nmax_old) * sizeof(double);
memset(&atom->molecule[nmax_old],0,nbytes); memset(&atom->dvector[index[m]][nmax_old],0,nbytes);
} }
} }
@ -258,9 +269,9 @@ void FixPropertyAtom::copy_arrays(int i, int j, int delflag)
if (style[m] == MOLECULE) if (style[m] == MOLECULE)
atom->molecule[j] = atom->molecule[i]; atom->molecule[j] = atom->molecule[i];
else if (style[m] == INTEGER) else if (style[m] == INTEGER)
atom->molecule[j] = atom->molecule[i]; atom->ivector[index[m]][j] = atom->ivector[index[m]][i];
else if (style[m] == DOUBLE) else if (style[m] == DOUBLE)
atom->molecule[j] = atom->molecule[i]; atom->dvector[index[m]][j] = atom->dvector[index[m]][i];
} }
} }
@ -281,11 +292,20 @@ int FixPropertyAtom::pack_border(int n, int *list, double *buf)
buf[m++] = molecule[j]; buf[m++] = molecule[j];
} }
} else if (style[j] == INTEGER) { } else if (style[j] == INTEGER) {
int *ivector = atom->ivector[index[k]];
for (i = 0; i < n; i++) {
j = list[i];
buf[m++] = ivector[j];
}
} else if (style[j] == DOUBLE) { } else if (style[j] == DOUBLE) {
double *dvector = atom->dvector[index[k]];
for (i = 0; i < n; i++) {
j = list[i];
buf[m++] = dvector[j];
}
} }
} }
printf("PBORDER %ld %d\n",update->ntimestep,m);
return m; return m;
} }
@ -305,7 +325,15 @@ int FixPropertyAtom::unpack_border(int n, int first, double *buf)
for (i = first; i < last; i++) for (i = first; i < last; i++)
molecule[i] = static_cast<int> (buf[m++]); molecule[i] = static_cast<int> (buf[m++]);
} else if (style[k] == INTEGER) { } else if (style[k] == INTEGER) {
int *ivector = atom->ivector[index[k]];
last = first + n;
for (i = first; i < last; i++)
ivector[i] = static_cast<int> (buf[m++]);
} else if (style[k] == DOUBLE) { } else if (style[k] == DOUBLE) {
double *dvector = atom->dvector[index[k]];
last = first + n;
for (i = first; i < last; i++)
dvector[i] = buf[m++];
} }
} }
@ -320,8 +348,8 @@ int FixPropertyAtom::pack_exchange(int i, double *buf)
{ {
for (int m = 0; m < nvalue; m++) { for (int m = 0; m < nvalue; m++) {
if (style[m] == MOLECULE) buf[m] = atom->molecule[i]; if (style[m] == MOLECULE) buf[m] = atom->molecule[i];
else if (style[m] == INTEGER) buf[m] = atom->molecule[i]; else if (style[m] == INTEGER) buf[m] = atom->ivector[index[m]][i];
else if (style[m] == DOUBLE) buf[m] = atom->molecule[i]; else if (style[m] == DOUBLE) buf[m] = atom->dvector[index[m]][i];
} }
return nvalue; return nvalue;
} }
@ -336,9 +364,9 @@ int FixPropertyAtom::unpack_exchange(int nlocal, double *buf)
if (style[m] == MOLECULE) if (style[m] == MOLECULE)
atom->molecule[nlocal] = static_cast<int> (buf[m]); atom->molecule[nlocal] = static_cast<int> (buf[m]);
else if (style[m] == INTEGER) else if (style[m] == INTEGER)
atom->molecule[nlocal] = static_cast<int> (buf[m]); atom->ivector[index[m]][nlocal] = static_cast<int> (buf[m]);
else if (style[m] == DOUBLE) else if (style[m] == DOUBLE)
atom->molecule[nlocal] = buf[m]; atom->dvector[index[m]][nlocal] = buf[m];
} }
return nvalue; return nvalue;
} }
@ -352,8 +380,8 @@ int FixPropertyAtom::pack_restart(int i, double *buf)
buf[0] = nvalue+1; buf[0] = nvalue+1;
for (int m = 1; m <= nvalue; m++) { for (int m = 1; m <= nvalue; m++) {
if (style[m] == MOLECULE) buf[m] = atom->molecule[i]; if (style[m] == MOLECULE) buf[m] = atom->molecule[i];
else if (style[m] == INTEGER) buf[m] = atom->molecule[i]; else if (style[m] == INTEGER) buf[m] = atom->ivector[index[m]][i];
else if (style[m] == DOUBLE) buf[m] = atom->molecule[i]; else if (style[m] == DOUBLE) buf[m] = atom->dvector[index[m]][i];
} }
return nvalue+1; return nvalue+1;
} }
@ -376,9 +404,9 @@ void FixPropertyAtom::unpack_restart(int nlocal, int nth)
if (style[i] == MOLECULE) if (style[i] == MOLECULE)
atom->molecule[nlocal] = static_cast<int> (extra[nlocal][m++]); atom->molecule[nlocal] = static_cast<int> (extra[nlocal][m++]);
else if (style[m] == INTEGER) else if (style[m] == INTEGER)
atom->molecule[nlocal] = static_cast<int> (extra[nlocal][m++]); atom->ivector[index[m]][nlocal] = static_cast<int> (extra[nlocal][m++]);
else if (style[m] == DOUBLE) else if (style[m] == DOUBLE)
atom->molecule[nlocal] = extra[nlocal][m++]; atom->dvector[index[m]][nlocal] = extra[nlocal][m++];
} }
} }

View File

@ -48,7 +48,7 @@ class FixPropertyAtom : public Fix {
private: private:
int nvalue,border,molecule_flag; int nvalue,border,molecule_flag;
int *style; int *style,*index;
int nmax_old; // length of peratom arrays the last time they grew int nmax_old; // length of peratom arrays the last time they grew
}; };