- Timestamp:
- May 18, 2016, 10:02:54 PM (9 years ago)
- Branches:
- Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
- Children:
- 1ab6fc
- Parents:
- 8eafd6
- git-author:
- Frederik Heber <heber@…> (03/10/16 13:06:47)
- git-committer:
- Frederik Heber <heber@…> (05/18/16 22:02:54)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/PotentialAction/FitPartialChargesAction.cpp
r8eafd6 rf33ef9 395 395 } 396 396 397 bool isNotHydrogen(const atom * const _atom) 398 { 399 return (_atom->getElementNo() != (atomicNumber_t) 1); 400 } 401 397 402 ActionState::ptr PotentialFitPartialChargesAction::performCall() 398 403 { 399 404 // check for selected atoms 400 405 const World &world = const_cast<const World &>(World::getInstance()); 401 if (world.beginAtomSelection() == world.endAtomSelection()) { 406 const std::vector<const atom *> selected_atoms = world.getSelectedAtoms(); 407 if (selected_atoms.empty()) { 402 408 STATUS("There are no atoms selected for fitting partial charges to."); 403 409 return Action::failure; … … 407 413 const AtomFragmentsMap &atomfragments = AtomFragmentsMap::getConstInstance(); 408 414 if (!atomfragments.checkCompleteness()) { 409 STATUS("AtomFragmentsMap failed internal consistency check, missing forcekeysets?");415 ELOG(0, "AtomFragmentsMap failed internal consistency check, missing forcekeysets?"); 410 416 return Action::failure; 411 417 } 412 std::set<KeySet> fragments = 413 accumulateKeySetsForAtoms( atomfragments.getMap(), world.getSelectedAtoms()); 418 const std::set<KeySet> fragments = 419 accumulateKeySetsForAtoms( atomfragments.getMap(), selected_atoms); 420 const size_t NoNonHydrogens = 421 std::count_if(selected_atoms.begin(), selected_atoms.end(), isNotHydrogen); 422 if (fragments.size() < NoNonHydrogens) { 423 ELOG(0, "Obtained fewer fragments than there are atoms, has AtomFragments been loaded?"); 424 return Action::failure; 425 } 414 426 415 427 // reduce given fragments to homologous graphs to avoid multiple fittings … … 430 442 /// obtain average charge for each atom the fitted charges over all its fragments 431 443 detail::fitted_charges_t fitted_charges; 432 for (World::AtomSelectionConstIterator atomiter = world.beginAtomSelection(); 433 atomiter != world.endAtomSelection(); ++atomiter) { 444 for (std::vector<const atom *>::const_iterator atomiter = selected_atoms.begin(); 445 atomiter != selected_atoms.end(); ++atomiter) { 446 const atomId_t walkerid = (*atomiter)->getId(); 434 447 const double average_charge = fitAverageChargeToAtom( 435 atomiter->second, atomfragments, keyset_graphs, fittedcharges_per_fragment);448 *atomiter, atomfragments, keyset_graphs, fittedcharges_per_fragment); 436 449 437 450 if (average_charge != 0.) { 438 LOG(2, "DEBUG: For atom " << atomiter->first<< " we have an average charge of "451 LOG(2, "DEBUG: For atom " << *atomiter << " we have an average charge of " 439 452 << average_charge); 440 453 441 fitted_charges.insert( std::make_pair( atomiter->first, average_charge) );454 fitted_charges.insert( std::make_pair(walkerid, average_charge) ); 442 455 } 443 456 } … … 455 468 detail::GraphIndices_t GraphIndices; 456 469 const AtomFragmentsMap::AtomFragmentsMap_t &atommap = atomfragments.getMap(); 457 for ( World::AtomSelectionConstIterator atomiter = world.beginAtomSelection();458 atomiter != world.endAtomSelection(); ++atomiter) {470 for (std::vector<const atom *>::const_iterator atomiter = selected_atoms.begin(); 471 atomiter != selected_atoms.end(); ++atomiter) { 459 472 // use the non-hydrogen here 460 const atomId_t walkerid = getNonHydrogenSurrogate(atomiter->second)->getId(); 461 if (walkerid != atomiter->first) 473 const atomId_t walkerid = (*atomiter)->getId(); 474 const atomId_t surrogateid = getNonHydrogenSurrogate(*atomiter)->getId(); 475 if (surrogateid != walkerid) 462 476 continue; 463 477 const AtomFragmentsMap::AtomFragmentsMap_t::const_iterator keysetsiter = 464 atommap.find( atomiter->first);478 atommap.find(walkerid); 465 479 ASSERT(keysetsiter != atommap.end(), 466 480 "PotentialFitPartialChargesAction::performCall() - we checked already that " 467 +toString( walkerid)+" should be present!");481 +toString(surrogateid)+" should be present!"); 468 482 const AtomFragmentsMap::keysets_t & keysets = keysetsiter->second; 469 483 … … 486 500 } 487 501 488 GraphIndices.insert( detail::GraphIndices_t::value_type(AtomsGraphIndices, atomiter->first) );489 490 LOG(2, "DEBUG: Atom #" << atomiter->first << "," << *atomiter->second491 << ". has graph indices " <<AtomsGraphIndices);502 GraphIndices.insert( detail::GraphIndices_t::value_type(AtomsGraphIndices, walkerid) ); 503 504 LOG(2, "DEBUG: Atom #" << walkerid << "," << *atomiter << ". has graph indices " 505 << AtomsGraphIndices); 492 506 } 493 507 // then graphs from non-hydrogen bond partner for all hydrogens 494 for ( World::AtomSelectionConstIterator atomiter = world.beginAtomSelection();495 atomiter != world.endAtomSelection(); ++atomiter) {508 for (std::vector<const atom *>::const_iterator atomiter = selected_atoms.begin(); 509 atomiter != selected_atoms.end(); ++atomiter) { 496 510 // use the non-hydrogen here 497 const atomId_t walkerid = getNonHydrogenSurrogate(atomiter->second)->getId(); 498 if (walkerid == atomiter->first) 511 const atomId_t walkerid = (*atomiter)->getId(); 512 const atomId_t surrogateid = getNonHydrogenSurrogate((*atomiter))->getId(); 513 if (surrogateid == walkerid) 499 514 continue; 500 detail::GraphIndices_t::right_const_iterator graphiter = GraphIndices.right.find( walkerid);515 detail::GraphIndices_t::right_const_iterator graphiter = GraphIndices.right.find(surrogateid); 501 516 ASSERT( graphiter != GraphIndices.right.end(), 502 "PotentialFitPartialChargesAction::performCall() - atom #"+toString( walkerid)517 "PotentialFitPartialChargesAction::performCall() - atom #"+toString(surrogateid) 503 518 +" not contained in GraphIndices."); 504 519 const detail::AtomsGraphIndices_t &AtomsGraphIndices = graphiter->second; 505 GraphIndices.insert( detail::GraphIndices_t::value_type(AtomsGraphIndices, atomiter->first) );506 LOG(2, "DEBUG: Hydrogen #" << atomiter->first << ", " << *atomiter->second520 GraphIndices.insert( detail::GraphIndices_t::value_type(AtomsGraphIndices, walkerid) ); 521 LOG(2, "DEBUG: Hydrogen #" << walkerid << ", " << *atomiter 507 522 << ", has graph indices " << AtomsGraphIndices); 508 523 } … … 516 531 GraphIndices, 517 532 atom_particlenames); 518 for (World::AtomSelectionConstIterator atomiter = world.beginAtomSelection(); 519 atomiter != world.endAtomSelection(); ++atomiter) { 520 const atom * const walker = atomiter->second; 533 for (std::vector<const atom *>::const_iterator atomiter = selected_atoms.begin(); 534 atomiter != selected_atoms.end(); ++atomiter) { 535 const atom * const walker = *atomiter; 536 const atomId_t walkerid = walker->getId(); 521 537 const detail::GraphIndices_t::right_const_iterator graphiter = 522 GraphIndices.right.find( atomiter->first);538 GraphIndices.right.find(walkerid); 523 539 ASSERT( graphiter != GraphIndices.right.end(), 524 "PotentialFitPartialChargesAction::performCall() - "); 540 "PotentialFitPartialChargesAction::performCall() - cannot find " 541 +toString(walkerid)+" in GraphIndices."); 525 542 const detail::AtomsGraphIndices_t &graphindex = graphiter->second; 526 543 const detail::AtomParticleNames_t::const_iterator particlesetiter = 527 544 atom_particlenames.find(graphindex); 528 545 ASSERT( particlesetiter != atom_particlenames.end(), 529 "PotentialFitPartialChargesAction::performCall() - "); 546 "PotentialFitPartialChargesAction::performCall() - cannot find " 547 +toString(graphindex)+" in atom_particlenames."); 530 548 const std::map<atomicNumber_t, std::string>::const_iterator nameiter = 531 549 particlesetiter->second.find(walker->getElementNo()); 532 550 ASSERT( nameiter != particlesetiter->second.end(), 533 551 "PotentialFitPartialChargesAction::performCall() - "); 534 LOG(1, "INFO: atom " << *walker << " received the following particle " << nameiter->second); 552 LOG(1, "INFO: atom " << *walker << " received the following particle " 553 << nameiter->second); 535 554 } 536 555
Note:
See TracChangeset
for help on using the changeset viewer.