- 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:
- ed0f88
- Parents:
- c1ec8e
- git-author:
- Frederik Heber <heber@…> (03/07/16 21:46:11)
- git-committer:
- Frederik Heber <heber@…> (05/18/16 22:02:54)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Actions/PotentialAction/FitPartialChargesAction.cpp
rc1ec8e r91f907 45 45 46 46 #include <boost/bimap.hpp> 47 #include <boost/bimap/multiset_of.hpp> 47 48 #include <boost/bind.hpp> 48 49 #include <boost/filesystem.hpp> … … 78 79 #include "Action_impl_pre.hpp" 79 80 /** =========== define the function ====================== */ 81 82 namespace detail { 83 typedef std::map<KeySet, HomologyGraph> KeysetsToGraph_t; 84 85 typedef std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t> GraphFittedChargeMap_t; 86 87 typedef std::map<atomId_t, double> fitted_charges_t; 88 89 typedef std::map<HomologyGraph, size_t> GraphIndex_t; 90 91 typedef std::set<size_t> AtomsGraphIndices_t; 92 typedef boost::bimaps::bimap< 93 AtomsGraphIndices_t, 94 boost::bimaps::multiset_of<atomId_t> > GraphIndices_t; 95 96 typedef std::map<atomId_t, std::string> AtomParticleNames_t; 97 98 typedef std::map<std::set<size_t>, std::string> GraphToNameMap_t; 99 }; 80 100 81 101 static void enforceZeroTotalCharge( … … 199 219 static 200 220 void getKeySetsToGraphMapping( 201 std::map<KeySet, HomologyGraph>&_keyset_graphs,202 std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t>&_fittedcharges_per_fragment,221 detail::KeysetsToGraph_t &_keyset_graphs, 222 detail::GraphFittedChargeMap_t &_fittedcharges_per_fragment, 203 223 const std::set<KeySet> &_fragments, 204 224 const AtomFragmentsMap &_atomfragments) … … 222 242 static 223 243 bool getPartialChargesForAllGraphs( 224 std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t>&_fittedcharges_per_fragment,244 detail::GraphFittedChargeMap_t &_fittedcharges_per_fragment, 225 245 const HomologyContainer &_homologies, 226 246 const double _mask_radius, 227 247 const bool enforceZeroCharge) 228 248 { 229 typedef std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t> GraphFittedChargeMap_t; 230 for (GraphFittedChargeMap_t::iterator graphiter = _fittedcharges_per_fragment.begin(); 249 for (detail::GraphFittedChargeMap_t::iterator graphiter = _fittedcharges_per_fragment.begin(); 231 250 graphiter != _fittedcharges_per_fragment.end(); ++graphiter) { 232 251 const HomologyGraph &graph = graphiter->first; … … 261 280 const atom * const _walker, 262 281 const AtomFragmentsMap &_atomfragments, 263 const std::map<KeySet, HomologyGraph> &_keyset_graphs, 264 const std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t> &_fittedcharges_per_fragment) 265 { 266 typedef std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t> GraphFittedChargeMap_t; 282 const detail::KeysetsToGraph_t &_keyset_graphs, 283 const detail::GraphFittedChargeMap_t &_fittedcharges_per_fragment) 284 { 267 285 const atom * surrogate = _walker; 268 286 if (surrogate->getElementNo() == 1) { … … 297 315 298 316 // find the associated charge in the charge vector 299 std::map<KeySet, HomologyGraph>::const_iterator keysetgraphiter =317 const std::map<KeySet, HomologyGraph>::const_iterator keysetgraphiter = 300 318 _keyset_graphs.find(keyset); 301 319 ASSERT( keysetgraphiter != _keyset_graphs.end(), … … 303 321 +" not contained in keyset_graphs."); 304 322 const HomologyGraph &graph = keysetgraphiter->second; 305 const GraphFittedChargeMap_t::const_iterator chargesiter =323 const detail::GraphFittedChargeMap_t::const_iterator chargesiter = 306 324 _fittedcharges_per_fragment.find(graph); 307 325 ASSERT(chargesiter != _fittedcharges_per_fragment.end(), … … 335 353 const ParticleFactory &factory, 336 354 const periodentafel &periode, 337 const std::map<atomId_t, double> &_fitted_charges) 338 { 339 typedef std::map<atomId_t, double> fitted_charges_t; 340 for (fitted_charges_t::const_iterator chargeiter = _fitted_charges.begin(); 355 const detail::fitted_charges_t &_fitted_charges, 356 const detail::GraphIndices_t &_GraphIndices, 357 detail::AtomParticleNames_t &_atom_particlenames) 358 { 359 detail::GraphToNameMap_t GraphToNameMap; 360 for (detail::fitted_charges_t::const_iterator chargeiter = _fitted_charges.begin(); 341 361 chargeiter != _fitted_charges.end(); ++chargeiter) { 342 const atom * const walker = World::getInstance().getAtom(AtomById(chargeiter->first)); 343 ASSERT( walker != NULL, 344 "PotentialFitPartialChargesAction::performCall() - atom " 345 +toString(chargeiter->first)+" not present in the World?"); 346 const double &charge = chargeiter->second; 347 const atomicNumber_t elementno = walker->getElementNo(); 348 const std::string name = Particle::findFreeName(periode, elementno); 349 LOG(1, "INFO: Adding particle " << name << " for atom " 350 << *walker << " with element " << elementno << ", charge " << charge); 351 factory.createInstance(name, elementno, charge); 362 const atomId_t &atomid = chargeiter->first; 363 const detail::GraphIndices_t::right_const_iterator graphiter = _GraphIndices.right.find(atomid); 364 const detail::GraphToNameMap_t::const_iterator nameiter = GraphToNameMap.find(graphiter->second); 365 std::string name; 366 if (nameiter != GraphToNameMap.end()) { 367 name = nameiter->second; 368 } else { 369 const atom * const walker = World::getInstance().getAtom(AtomById(atomid)); 370 ASSERT( walker != NULL, 371 "addToParticleRegistry() - atom "+toString(atomid)+" not present in the World?"); 372 const double &charge = chargeiter->second; 373 const atomicNumber_t elementno = walker->getElementNo(); 374 name = Particle::findFreeName(periode, elementno); 375 GraphToNameMap[graphiter->second] = name; 376 LOG(1, "INFO: Adding particle " << name << " for atom " 377 << *walker << " with element " << elementno << ", charge " << charge); 378 factory.createInstance(name, elementno, charge); 379 } 380 _atom_particlenames.insert( std::make_pair(atomid, name) ); 352 381 } 353 382 } … … 372 401 373 402 // reduce given fragments to homologous graphs to avoid multiple fittings 374 typedef std::map<KeySet, HomologyGraph> KeysetsToGraph_t; 375 KeysetsToGraph_t keyset_graphs; 376 typedef std::map<HomologyGraph, PartialNucleiChargeFitter::charges_t> GraphFittedChargeMap_t; 377 GraphFittedChargeMap_t fittedcharges_per_fragment; 403 detail::KeysetsToGraph_t keyset_graphs; 404 detail::GraphFittedChargeMap_t fittedcharges_per_fragment; 378 405 getKeySetsToGraphMapping(keyset_graphs, fittedcharges_per_fragment, fragments, atomfragments); 379 406 380 407 /// then go through all fragments and get partial charges for each 408 const HomologyContainer &homologies = World::getInstance().getHomologies(); 381 409 const bool status = getPartialChargesForAllGraphs( 382 410 fittedcharges_per_fragment, 383 World::getInstance().getHomologies(),411 homologies, 384 412 params.radius.get(), 385 413 params.enforceZeroCharge.get()); … … 388 416 389 417 /// obtain average charge for each atom the fitted charges over all its fragments 390 typedef std::map<atomId_t, double> fitted_charges_t; 391 fitted_charges_t fitted_charges; 418 detail::fitted_charges_t fitted_charges; 392 419 for (World::AtomSelectionConstIterator atomiter = world.beginAtomSelection(); 393 420 atomiter != world.endAtomSelection(); ++atomiter) { … … 403 430 } 404 431 432 /// make Particles be used for every atom that was fitted on the same number of graphs 433 detail::GraphIndex_t GraphIndex; 434 size_t index = 0; 435 for (HomologyContainer::const_key_iterator iter = homologies.key_begin(); 436 iter != homologies.key_end(); iter = homologies.getNextKey(iter)) { 437 GraphIndex.insert( std::make_pair( *iter, index++)); 438 } 439 LOG(2, "DEBUG: There are " << index << " unique graphs in the homology container."); 440 441 // go through every atom, get all graphs, convert to GraphIndex and store 442 443 detail::GraphIndices_t GraphIndices; 444 const AtomFragmentsMap::AtomFragmentsMap_t &atommap = atomfragments.getMap(); 445 for (World::AtomSelectionConstIterator atomiter = world.beginAtomSelection(); 446 atomiter != world.endAtomSelection(); ++atomiter) { 447 const atomId_t walkerid = atomiter->first; 448 const AtomFragmentsMap::AtomFragmentsMap_t::const_iterator keysetsiter = 449 atommap.find(walkerid); 450 ASSERT(keysetsiter != atommap.end(), 451 "PotentialFitPartialChargesAction::performCall() - we checked already that " 452 +toString(walkerid)+" should be present!"); 453 const AtomFragmentsMap::keysets_t & keysets = keysetsiter->second; 454 455 detail::AtomsGraphIndices_t AtomsGraphIndices; 456 457 // go over all fragments associated to this atom 458 for (AtomFragmentsMap::keysets_t::const_iterator keysetsiter = keysets.begin(); 459 keysetsiter != keysets.end(); ++keysetsiter) { 460 const KeySet &keyset = *keysetsiter; 461 const std::map<KeySet, HomologyGraph>::const_iterator keysetgraphiter = 462 keyset_graphs.find(keyset); 463 ASSERT( keysetgraphiter != keyset_graphs.end(), 464 "PotentialFitPartialChargesAction::performCall() - keyset "+toString(keyset) 465 +" not contained in keyset_graphs."); 466 const HomologyGraph &graph = keysetgraphiter->second; 467 const detail::GraphIndex_t::const_iterator indexiter = GraphIndex.find(graph); 468 ASSERT( indexiter != GraphIndex.end(), 469 "PotentialFitPartialChargesAction::performCall() - graph "+toString(graph) 470 +" not contained in GraphIndex."); 471 AtomsGraphIndices.insert( indexiter->second ); 472 } 473 GraphIndices.left.insert( std::make_pair(AtomsGraphIndices, walkerid) ); 474 LOG(2, "DEBUG: Atom " << *atomiter->second << " has graph indices " << AtomsGraphIndices); 475 } 476 405 477 /// place all fitted charges into ParticleRegistry 478 detail::AtomParticleNames_t atom_particlenames; 406 479 addToParticleRegistry( 407 480 ParticleFactory::getConstInstance(), 408 481 *World::getInstance().getPeriode(), 409 fitted_charges); 482 fitted_charges, 483 GraphIndices, 484 atom_particlenames); 485 LOG(1, "INFO: The atoms received the following particles " << atom_particlenames); 410 486 411 487 return Action::success;
Note:
See TracChangeset
for help on using the changeset viewer.