source: src/Fragmentation/Summation/SortedVector.hpp@ 653cea

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator 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_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion GeometryObjects 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 PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps Ubuntu_1604_changes stable
Last change on this file since 653cea was 19c50e, checked in by Frederik Heber <heber@…>, 13 years ago

IndexSetContainer now treats super set specially.

  • The super set must not gather its subsets via the gatherSubsets() as by construction all other sets are its subsets! As the super set is very large the power set way is no good idea.
  • added default cstor for SortedVector
  • removed SubsetMap::getMaximumSubsetLevel() as is replaced by ::getMaximumSetLevel() which is the level to sum up to.
  • changed all uses of getMaximumSubsetLevel() to getMaximumSetLevel().
  • TESTFIX: Changed unit test function on getMaximumSubsetLevel() to check on getMaximumSetLevel()
  • removed OrthogonalFullSummator as is fully replacable by OrthogonalSummator.
  • changed IndexSetContainer::createSuperSet a bit.
  • IndexSetContainer::AllIndices is now no more static convenience entity but truely contains the super set (non-statically). ::createSuperSet() is for convenience to be called in cstor for AllIndices.
  • Property mode set to 100644
File size: 4.3 KB
Line 
1/*
2 * SortedVector.hpp
3 *
4 * Created on: Jul 3, 2012
5 * Author: heber
6 */
7
8#ifndef SORTEDVECTOR_HPP_
9#define SORTEDVECTOR_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
17#include <algorithm>
18#include <boost/lambda/lambda.hpp>
19#include <boost/shared_ptr.hpp>
20#include <boost/bind.hpp>
21#include <vector>
22
23/** Functor for transforming instance of type T to copies contained in shared_ptr.
24 *
25 */
26template <typename T>
27struct SharedPtrAllocator {
28 boost::shared_ptr<T> operator()(const T& a) {
29 return boost::shared_ptr<T>( new T(a) );
30 }
31};
32
33
34/** This class represents a general sorted container of instances, stored as shared_ptr.
35 *
36 * These instances are stored in order not by appearance memory due to shared_ptr but
37 * by the comparison operators of the underlying type.
38 *
39 * The sorted vector is truely a sorted vector. Hence, we must access often but change
40 * only seldomly. This is due to item#23 in [Meyers, "Effective STL"].
41 *
42 */
43template <typename T>
44struct SortedVector
45{
46 typedef typename T::ptr T_ptr;
47 typedef std::vector<T_ptr> Container_t;
48public:
49 /** Constructor from an unsorted vector of instances.
50 *
51 * @param _container unsorted vector of instances
52 */
53 SortedVector(const Container_t &_container) :
54 ContainerSorted(false),
55 container(_container)
56 {
57 sort();
58 }
59
60 /** Constructor from an unsorted vector of instances.
61 *
62 * @param _container unsorted vector of instances
63 */
64 SortedVector(const std::vector<T> &_container) :
65 ContainerSorted(false)
66 {
67 container.resize(_container.size());
68 SharedPtrAllocator<T> allocator;
69 std::transform(_container.begin(), _container.end(),
70 container.begin(), allocator);
71 sort();
72 }
73
74 /** Constructor from a single instance.
75 *
76 * A single instance is automatically sorted.
77 *
78 * @param _instance single instance
79 */
80 SortedVector(T_ptr &_instance) :
81 ContainerSorted(true)
82 {
83 container.push_back(_instance);
84 }
85
86 /** Default constructor.
87 *
88 * An empty vector is automatically sorted.
89 *
90 * @return
91 */
92 SortedVector() :
93 ContainerSorted(true)
94 {}
95
96 /** Getter to sorted container.
97 *
98 * This getter is made const only through the virtue of making the member
99 * variables mutable. This is however the only sensible way as to the outside
100 * the container must be treatable as const despite "lazy" resorting on this
101 * read-only access in the background.
102 *
103 * @return const ref to internal sorted container
104 */
105 const Container_t &getContainer() const {
106 if (!ContainerSorted)
107 sort();
108 return container;
109 }
110
111 /** Insert a shared_ptr instance
112 *
113 * We lazily set the container to not sorted, it is sorted on next access.
114 *
115 * @param a instance to insert
116 */
117 void insert(T_ptr &a) {
118 // check if present via binary_search
119 if (!std::binary_search(container.begin(), container.end(), a, Comparator)) {
120 // only insert if not present
121 container.push_back(a);
122 ContainerSorted = false;
123 }
124 }
125
126 /** Insert an instance not wrapped in shared_ptr.
127 *
128 * We lazily set the container to not sorted, it is sorted on next access.
129 *
130 * @param a instance to copy and insert
131 */
132 void insert(const T &a) {
133 T_ptr ptr(new IndexSet(a));
134 // check if present via binary_search
135 if (!std::binary_search(container.begin(), container.end(), ptr, Comparator)) {
136 // only insert if not present
137 container.push_back(ptr);
138 ContainerSorted = false;
139 }
140 }
141
142 /** Internal static Comparator function, passing the check on to comparison
143 * operator of underlying type.
144 * @param a First instance
145 * @param b Second instance
146 * @return pointee of a < pointee of b
147 */
148 struct Comparator_t {
149 bool operator()(const T_ptr &a, const T_ptr &b) const {
150 return *a < *b;
151 }
152 } Comparator;
153
154private:
155 /** Internal sort function.
156 *
157 */
158 void sort() const {
159 std::sort(container.begin(), container.end(), Comparator);
160 ContainerSorted = true;
161 }
162
163protected:
164 //!> internal flag that container is currently sorted, mutable to let getContainer() be const member function
165 mutable bool ContainerSorted;
166
167private:
168 //!> internal container that is always sorted, mutable to let getContainer() be const member function
169 mutable Container_t container;
170};
171
172
173
174#endif /* SORTEDVECTOR_HPP_ */
Note: See TracBrowser for help on using the repository browser.