ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/group/trunk/OOPSE/libmdtools/ZConstraint.cpp
(Generate patch)

Comparing trunk/OOPSE/libmdtools/ZConstraint.cpp (file contents):
Revision 660 by tim, Thu Jul 31 19:59:34 2003 UTC vs.
Revision 671 by mmeineke, Fri Aug 8 17:48:44 2003 UTC

# Line 491 | Line 491 | template<typename T> void ZConstraint<T>::resetZ()
491  
492   template<typename T> void ZConstraint<T>::resetZ()
493   {
494 +
495 +  double pos[3];
496    double deltaZ;
497    double mzOfZCons;   //total sum of m*z of z-constrain molecules
498    double mzOfUncons; //total sum of m*z of unconstrain molecuels;
# Line 525 | Line 527 | template<typename T> void ZConstraint<T>::resetZ()
527   #endif  
528    
529    zsys = (totalMZOfZCons + totalMZOfUncons) /totalMassOfUncons;
530 <
529 <  cout << "current time: " << info->getTime() <<endl;  
530 >
531    for(int i = 0; i < zconsMols.size(); i++){  
532    
533      zconsMols[i]->getCOM(COM);
534      
534    cout << "global index: " << zconsMols[i]->getGlobalIndex() << "\tZ: " << COM[2] << "\t";
535      deltaZ = zsys + refZ[i] - COM[2];
536    cout << "\tdistance: " << COM[2] +deltaZ - zsys;    
536      //update z coordinate    
537      zconsAtoms = zconsMols[i]->getMyAtoms();    
538      for(int j =0; j < zconsMols[i]->getNAtoms(); j++){
539 <      zconsAtoms[j]->setZ(zconsAtoms[j]->getZ() + deltaZ);  
539 >      zconsAtoms[j]->getPos(pos);
540 >      pos[2] += deltaZ;
541 >      zconsAtoms[j]->setPos(pos);  
542      }    
543      
544      //calculate z constrain force
545      fz[i] = massOfZConsMols[i]* deltaZ / dt2;
546      
546    cout << "\tforce: " << fz[i] << endl;
547    }
548  
549        

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines