| 35 |  | * | 
| 36 |  | * [1]  Meineke, et al., J. Comp. Chem. 26, 252-271 (2005). | 
| 37 |  | * [2]  Fennell & Gezelter, J. Chem. Phys. 124, 234104 (2006). | 
| 38 | < | * [3]  Sun, Lin & Gezelter, J. Chem. Phys. 128, 24107 (2008). | 
| 38 | > | * [3]  Sun, Lin & Gezelter, J. Chem. Phys. 128, 234107 (2008). | 
| 39 |  | * [4]  Kuang & Gezelter,  J. Chem. Phys. 133, 164101 (2010). | 
| 40 |  | * [5]  Vardeman, Stocker & Gezelter, J. Chem. Theory Comput. 7, 834 (2011). | 
| 41 |  | */ | 
| 229 |  | Vector3d trq(0.0); | 
| 230 |  | Vector3d ef(0.0); | 
| 231 |  | Vector3d pos = this->getPos(); | 
| 232 | < |  | 
| 232 | > | AtomType* atype; | 
| 233 | > | int eCount = 0; | 
| 234 | > |  | 
| 235 |  | int sl = ((snapshotMan_->getCurrentSnapshot())->*storage_).getStorageLayout(); | 
| 236 | < |  | 
| 236 | > |  | 
| 237 |  | for (unsigned int i = 0; i < atoms_.size(); i++) { | 
| 238 |  |  | 
| 239 | + | atype = atoms_[i]->getAtomType(); | 
| 240 | + |  | 
| 241 |  | afrc = atoms_[i]->getFrc(); | 
| 242 |  | apos = atoms_[i]->getPos(); | 
| 243 |  | rpos = apos - pos; | 
| 256 |  | trq += atrq; | 
| 257 |  | } | 
| 258 |  |  | 
| 259 | < | if (sl & DataStorage::dslElectricField) { | 
| 259 | > | if ((sl & DataStorage::dslElectricField) && (atype->isElectrostatic())) { | 
| 260 |  | ef += atoms_[i]->getElectricField(); | 
| 261 | + | eCount++; | 
| 262 |  | } | 
| 263 |  | } | 
| 264 |  | addFrc(frc); | 
| 265 |  | addTrq(trq); | 
| 266 |  |  | 
| 267 | < | if (sl & DataStorage::dslElectricField) { | 
| 268 | < | ef /= atoms_.size(); | 
| 267 | > | if (sl & DataStorage::dslElectricField)  { | 
| 268 | > | ef /= eCount; | 
| 269 |  | setElectricField(ef); | 
| 270 |  | } | 
| 271 |  |  | 
| 280 |  | Vector3d frc(0.0); | 
| 281 |  | Vector3d trq(0.0); | 
| 282 |  | Vector3d ef(0.0); | 
| 283 | < |  | 
| 283 | > | AtomType* atype; | 
| 284 | > | int eCount = 0; | 
| 285 | > |  | 
| 286 |  | Vector3d pos = this->getPos(); | 
| 287 |  | Mat3x3d tau_(0.0); | 
| 288 |  |  | 
| 290 |  |  | 
| 291 |  | for (unsigned int i = 0; i < atoms_.size(); i++) { | 
| 292 |  |  | 
| 293 | + | atype = atoms_[i]->getAtomType(); | 
| 294 | + |  | 
| 295 |  | afrc = atoms_[i]->getFrc(); | 
| 296 |  | apos = atoms_[i]->getPos(); | 
| 297 |  | rpos = apos - pos; | 
| 309 |  | atrq = atoms_[i]->getTrq(); | 
| 310 |  | trq += atrq; | 
| 311 |  | } | 
| 312 | < | if (sl & DataStorage::dslElectricField) { | 
| 312 | > |  | 
| 313 | > | if ((sl & DataStorage::dslElectricField) && (atype->isElectrostatic())) { | 
| 314 |  | ef += atoms_[i]->getElectricField(); | 
| 315 | + | eCount++; | 
| 316 |  | } | 
| 317 |  |  | 
| 318 |  | tau_(0,0) -= rpos[0]*afrc[0]; | 
| 330 |  | addTrq(trq); | 
| 331 |  |  | 
| 332 |  | if (sl & DataStorage::dslElectricField) { | 
| 333 | < | ef /= atoms_.size(); | 
| 333 | > | ef /= eCount; | 
| 334 |  | setElectricField(ef); | 
| 335 |  | } | 
| 336 |  |  |