--- trunk/OOPSE/libmdtools/SimInfo.cpp 2003/04/04 19:47:19 458 +++ trunk/OOPSE/libmdtools/SimInfo.cpp 2003/04/08 22:38:43 482 @@ -35,10 +35,56 @@ void SimInfo::setBox(double newBox[3]) { } void SimInfo::setBox(double newBox[3]) { + double smallestBox, maxCutoff; + int status; box_x = newBox[0]; box_y = newBox[1]; box_z = newBox[2]; setFortranBoxSize(newBox); + + smallestBox = box_x; + if (box_y < smallestBox) smallestBox = box_y; + if (box_z < smallestBox) smallestBox = box_z; + + maxCutoff = smallestBox / 2.0; + + if (rList > maxCutoff) { + sprintf( painCave.errMsg, + "New Box size is forcing neighborlist radius down to %lf\n", + maxCutoff ); + painCave.isFatal = 0; + simError(); + + rList = maxCutoff; + + sprintf( painCave.errMsg, + "New Box size is forcing cutoff radius down to %lf\n", + maxCutoff - 1.0 ); + painCave.isFatal = 0; + simError(); + + rCut = rList - 1.0; + + // list radius changed so we have to refresh the simulation structure. + refreshSim(); + } + + if (rCut > maxCutoff) { + sprintf( painCave.errMsg, + "New Box size is forcing cutoff radius down to %lf\n", + maxCutoff ); + painCave.isFatal = 0; + simError(); + + status = 0; + LJ_new_rcut(&rCut, &status); + if (status != 0) { + sprintf( painCave.errMsg, + "Error in recomputing LJ shifts based on new rcut\n"); + painCave.isFatal = 1; + simError(); + } + } } void SimInfo::getBox(double theBox[3]) { @@ -83,6 +129,10 @@ void SimInfo::refreshSim(){ simtype fInfo; int isError; int* excl; + + fInfo.rrf = 0.0; + fInfo.rt = 0.0; + fInfo.dielect = 0.0; fInfo.box[0] = box_x; fInfo.box[1] = box_y; @@ -90,10 +140,13 @@ void SimInfo::refreshSim(){ fInfo.rlist = rList; fInfo.rcut = rCut; - fInfo.rrf = ecr; - fInfo.rt = ecr - est; - fInfo.dielect = dielectric; + if( useDipole ){ + fInfo.rrf = ecr; + fInfo.rt = ecr - est; + if( useReactionField )fInfo.dielect = dielectric; + } + fInfo.SIM_uses_PBC = usePBC; //fInfo.SIM_uses_LJ = 0; fInfo.SIM_uses_LJ = useLJ; @@ -136,8 +189,8 @@ void SimInfo::refreshSim(){ MPIcheckPoint(); #endif // is_mpi - ndf = this->getNDF(); - ndfRaw = this->getNDFraw(); + this->ndf = this->getNDF(); + this->ndfRaw = this->getNDFraw(); }