ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/OpenMD/branches/development/src/brains/SimCreator.cpp
(Generate patch)

Comparing branches/development/src/brains/SimCreator.cpp (file contents):
Revision 1714 by gezelter, Sat May 19 18:12:46 2012 UTC vs.
Revision 1769 by gezelter, Mon Jul 9 14:15:52 2012 UTC

# Line 56 | Line 56
56   #include "brains/SimCreator.hpp"
57   #include "brains/SimSnapshotManager.hpp"
58   #include "io/DumpReader.hpp"
59 < #include "UseTheForce/ForceFieldFactory.hpp"
59 > #include "brains/ForceField.hpp"
60   #include "utils/simError.h"
61   #include "utils/StringUtils.hpp"
62   #include "math/SeqRandNumGen.hpp"
# Line 256 | Line 256 | namespace OpenMD {
256      int metaDataBlockStart = -1;
257      int metaDataBlockEnd = -1;
258      int i;
259 <    int mdOffset;
259 >    streamoff mdOffset;
260      int mdFileVersion;
261  
262   #ifdef IS_MPI            
# Line 371 | Line 371 | namespace OpenMD {
371                                     metaDataBlockStart + 1);
372      
373      //create the force field
374 <    ForceField * ff = ForceFieldFactory::getInstance()->createForceField(simParams->getForceField());
374 >    ForceField * ff = new ForceField(simParams->getForceField());
375  
376      if (ff == NULL) {
377        sprintf(painCave.errMsg,
# Line 426 | Line 426 | namespace OpenMD {
426  
427      int storageLayout = computeStorageLayout(info);
428  
429    cerr << "computed Storage Layout = " << storageLayout << "\n";
430
429      //allocate memory for DataStorage(circular reference, need to
430      //break it)
431      info->setSnapshotManager(new SimSnapshotManager(info, storageLayout));
# Line 752 | Line 750 | namespace OpenMD {
750  
751      if (simParams->getOutputParticlePotential()) {
752        storageLayout |= DataStorage::dslParticlePot;
753 +    }
754 +
755 +    if (simParams->havePrintHeatFlux()) {
756 +      if (simParams->getPrintHeatFlux()) {
757 +        storageLayout |= DataStorage::dslParticlePot;
758 +      }
759      }
760 +
761      if (simParams->getOutputElectricField()) {
762        storageLayout |= DataStorage::dslElectricField;
763      }
# Line 781 | Line 786 | namespace OpenMD {
786      int nGlobalAtoms = info->getNGlobalAtoms();
787      
788      beginAtomIndex = 0;
789 <    beginRigidBodyIndex = 0;
789 >    //rigidbody's index begins right after atom's
790 >    beginRigidBodyIndex = info->getNGlobalAtoms();
791      beginCutoffGroupIndex = 0;
792  
793      for(int i = 0; i < info->getNGlobalMolecules(); i++) {
# Line 899 | Line 905 | namespace OpenMD {
905      for (mol = info->beginMolecule(mi); mol != NULL; mol = info->nextMolecule(mi)) {
906        int myGlobalIndex = mol->getGlobalIndex();
907        int globalIO = startingIOIndexForMol[myGlobalIndex];
908 <      for (StuntDouble* integrableObject = mol->beginIntegrableObject(ioi); integrableObject != NULL;
909 <           integrableObject = mol->nextIntegrableObject(ioi)) {
910 <        integrableObject->setGlobalIntegrableObjectIndex(globalIO);
911 <        IOIndexToIntegrableObject[globalIO] = integrableObject;
908 >      for (StuntDouble* sd = mol->beginIntegrableObject(ioi); sd != NULL;
909 >           sd = mol->nextIntegrableObject(ioi)) {
910 >        sd->setGlobalIntegrableObjectIndex(globalIO);
911 >        IOIndexToIntegrableObject[globalIO] = sd;
912          globalIO++;
913        }
914      }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines