source: src/Fragmentation/Homology/HomologyGraph.cpp@ 7c1091

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments 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_BoundInBox_CenterInBox_MoleculeActions 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 FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation 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
Last change on this file since 7c1091 was 7c1091, checked in by Frederik Heber <heber@…>, 12 years ago

Extended CompoundPotential for multiple occurences of argument bunches.

  • added HomologyGraph::hasGreaterEqualTimesAtomicNumber() has model might have multiple matching arguments within a single fragment.
  • i.e. when there is more than one argument bunch for a given model. Hence, we check the stream whether upcoming arguments match current and next model. Note however that models are not necessarily sorted by particle_types' size. Hence, we must trick a little and need a specific map comparator.
  • Property mode set to 100644
File size: 3.9 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2012 University of Bonn. All rights reserved.
5 * Copyright (C) 2013 Frederik Heber. All rights reserved.
6 * Please see the COPYING file or "Copyright notice" in builder.cpp for details.
7 *
8 *
9 * This file is part of MoleCuilder.
10 *
11 * MoleCuilder is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation, either version 2 of the License, or
14 * (at your option) any later version.
15 *
16 * MoleCuilder is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
23 */
24
25/*
26 * HomologyGraph.cpp
27 *
28 * Created on: Sep 24, 2012
29 * Author: heber
30 */
31
32
33// include config.h
34#ifdef HAVE_CONFIG_H
35#include <config.h>
36#endif
37
38// include headers that implement a archive in simple text format
39// otherwise BOOST_CLASS_EXPORT_IMPLEMENT has no effect
40#include <boost/archive/text_oarchive.hpp>
41#include <boost/archive/text_iarchive.hpp>
42
43#include "CodePatterns/MemDebug.hpp"
44
45#include "HomologyGraph.hpp"
46
47#include <iostream>
48
49HomologyGraph::HomologyGraph(const KeySet &keyset) :
50 nodes(detail::getNodesFromKeySet(keyset)),
51 edges(detail::getEdgesFromKeySet(keyset))
52{}
53
54HomologyGraph::HomologyGraph(const IndexSet &index) :
55 nodes(detail::getNodesFromIndexSet(index)),
56 edges(detail::getEdgesFromIndexSet(index))
57{}
58
59bool HomologyGraph::operator<(const HomologyGraph &graph) const
60{
61 if (nodes < graph.nodes) {
62 return true;
63 } else if (nodes > graph.nodes) {
64 return false;
65 } else {
66 if (edges < graph.edges)
67 return true;
68 else
69 return false;
70 }
71}
72
73bool HomologyGraph::operator>(const HomologyGraph &graph) const
74{
75 if (nodes > graph.nodes) {
76 return true;
77 } else if (nodes < graph.nodes) {
78 return false;
79 } else {
80 if (edges > graph.edges)
81 return true;
82 else
83 return false;
84 }
85}
86
87bool HomologyGraph::operator==(const HomologyGraph &graph) const
88{
89 if (nodes != graph.nodes) {
90 return false;
91 } else {
92 return (edges == graph.edges);
93 }
94}
95
96HomologyGraph& HomologyGraph::operator=(const HomologyGraph &graph)
97{
98 // self-assignment check
99 if (this != &graph) {
100 const_cast<nodes_t &>(nodes) = graph.nodes;
101 const_cast<edges_t &>(edges) = graph.edges;
102 }
103 return *this;
104}
105
106bool HomologyGraph::hasTimesAtomicNumber(const size_t _number, const size_t _times) const
107{
108 size_t count = 0;
109 for (nodes_t::const_iterator iter = nodes.begin(); iter != nodes.end(); ++iter) {
110 if ((iter->first).getAtomicNumber() == _number)
111 count += iter->second;
112 }
113 return (count == _times);
114}
115
116bool HomologyGraph::hasGreaterEqualTimesAtomicNumber(const size_t _number, const size_t _times) const
117{
118 size_t count = 0;
119 for (nodes_t::const_iterator iter = nodes.begin(); iter != nodes.end(); ++iter) {
120 if ((iter->first).getAtomicNumber() == _number)
121 count += iter->second;
122 }
123 return (count >= _times);
124}
125
126std::ostream& operator<<(std::ostream& ost, const HomologyGraph &graph)
127{
128 for (HomologyGraph::nodes_t::const_iterator nodeiter = graph.nodes.begin();
129 nodeiter != graph.nodes.end();
130 ++nodeiter) {
131 if ( nodeiter != graph.nodes.begin())
132 ost << ", ";
133 ost << nodeiter->second << "x " << nodeiter->first;
134 }
135 for (HomologyGraph::edges_t::const_iterator edgeiter = graph.edges.begin();
136 edgeiter != graph.edges.end();
137 ++edgeiter) {
138 if ( edgeiter != graph.edges.begin())
139 ost << ", ";
140 ost << edgeiter->second << "x " << edgeiter->first;
141 }
142 return ost;
143}
144
145// we need to explicitly instantiate the serialization functions
146BOOST_CLASS_EXPORT_IMPLEMENT(HomologyGraph)
147
Note: See TracBrowser for help on using the repository browser.