ATLAS Offline Software
CombinatoricsOdometer.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2021 CERN for the benefit of the ATLAS collaboration
3 */
4 
25 
27 FlexDigit::FlexDigit( int digitMax, FlexDigit* nextDigit )
28 {
29  m_digit=0;
30  m_digitMax=digitMax-1;
31  m_nextDigit=nextDigit;
32 }
33 
34 
36 {
37  if(this->isAtMax())
38  {
39  this->setDigit( 0 );
40  if(!this->isFirstDigit()) (*(this->next()))++;
41  }
42  else
43  {
44  this->setDigit( this->digit()+1 );
45  }
46  return *this;
47 }
48 
49 
51 FlexDigits::FlexDigits( std::vector<std::string>& labels, std::map<std::string, int>& digitMax ) :
53 {
54  m_started=false;
55  this->reserve(labels.size());
56  for (const std::string& label : labels)
57  {
58  FlexDigit* temp = new FlexDigit(digitMax[label]);
59  this->push_back(temp);
60  }
61 }
62 
63 
64 FlexDigits::FlexDigits( int numDigits, int digitMax ) :
66 {
67  m_started=false;
68  this->reserve(numDigits);
69  for( int i=0; i<numDigits; i++ )
70  {
71  FlexDigit* temp = new FlexDigit(digitMax);
72  this->push_back(temp);
73  }
74 }
75 
76 
78 {
79 }
80 
81 
82 //overloaded vector method, need to tell each digit which one
83 //is next to it
85 {
86  if(this->size())
87  {
88  aDigit->setNext(this->back());
89  }
91 }
92 
93 //just increment by one, no uniqueness check etc (overloaded in OdoMeter)
95 {
96  if(m_started && this->isZero())
97  {
98  return false;
99  }
100  else
101  {
102  m_started = true;
103  }
104  (*this)++;
105  return true;
106 }
107 
108 
109 //for debugging
111 {
112  std::cout<<"current State of digits: ";
113  for (const FlexDigit* digit : *this)
114  {
115  std::cout<<"|"<<digit->digit()<<"|";
116  }
117  std::cout<<std::endl;
118 }
119 
120 
121 //if the whole digits are 0
123 {
124  bool isZero=true;
125  for (const FlexDigit* digit : *this)
126  {
127  isZero = isZero && !digit->digit();
128  }
129  return isZero;
130 }
131 
132 
133 //only ++ operaor defined (only thing needed for now)
135 {
136  if( this->size() )
137  {
138  (*(this->back()))++;
139  }
140  return *this;
141 }
142 
143 
145 //somewhat specific constructor for label and number of paritlces
146 //in each container with the label
147 OdoMeter::OdoMeter( std::vector<std::string>& labels, std::map<std::string, int>& digitMax )
148  : FlexDigits( labels, digitMax ),
149  m_pairMeter(0)
150 {
151  m_onlyUnique = true;
152  m_onlySingleEntry = true;
153  m_numLabels = labels.size();
154  int counter = 0;
155  for( ;counter < m_numLabels; counter++ )
156  {
158  m_labels.insert(labels[counter]);
159  }
160 }
161 
162 
163 //this constructor is for the case when you want to combine
164 //M objects (numDigits) from one single list of n (digitMax)
165 OdoMeter::OdoMeter( int numDigits, int digitMax )
166  : FlexDigits( numDigits, digitMax ),
167  m_pairMeter(0)
168 {
169  m_onlyUnique = true;
170  m_onlySingleEntry = true;
171  m_numLabels = numDigits;
172  int counter = 0;
173  for( ;counter < m_numLabels; counter++ )
174  {
175  m_digitAssoc["dummy"].insert(counter);
176  m_labels.insert("dummy");
177  }
178 }
179 
180 
182 {
183  delete m_pairMeter;
184  m_pairMeter = NULL;
185 }
186 
187 
188 
189 //this function make sure that there's no double counting, should be used in combination
190 //with hasOnlySingleEntry as isUnique will pass the ones with same entries from one container
191 bool OdoMeter::isUnique( bool doCheck )
192 {
193  if(!doCheck)
194  {
195  return true;
196  }
197  for (const std::string& label : m_labels)
198  {
199  int leftDigit = -1;
200  for (int digit : m_digitAssoc[label])
201  {
202  if(leftDigit <= (*this)[digit]->digit())
203  {
204  leftDigit=(*this)[digit]->digit();
205  }
206  else
207  {
208  return false;
209  }
210  }
211  }
212  return true;
213 }
214 
215 
216 //this function make sure that two same entries from single container do not exist
217 //the method uses the notion of std::set which does not allow two same entries.
218 bool OdoMeter::hasOnlySingleEntry( bool doCheck )
219 {
220  if(!doCheck)
221  {
222  return true;
223  }
224  for (const std::string& label : m_labels)
225  {
226  std::set<int> digitsForLabel;
227  for (int digit : m_digitAssoc[label])
228  {
229  digitsForLabel.insert((*this)[digit]->digit());
230  }
231  if (digitsForLabel.size()!=m_digitAssoc[label].size())
232  {
233  return false;
234  }
235  }
236  return true;
237 }
238 
239 
240 //increment the meter by one and check uniqueness. if not unique,
241 //call itself again (recursive)
243 {
244  if(this->hasStarted() && this->isZero())
245  {
246  return false;
247  }
248  else if(!this->hasStarted())
249  {
250  this->setStarted() ;
251  }
252  (*this)++;
253  bool found = true;
254  if(!isUnique(m_onlyUnique))
255  {
256  found=false;
257  }
259  {
260  found=false;
261  }
262  if(!found)
263  {
264  return this->increment();
265  }
266  else
267  {
268  delete m_pairMeter;
270  return true;
271  }
272 }
273 
274 
275 //output the digit in the form of vector<int>
276 std::vector<int> OdoMeter::getVector()
277 {
278  std::vector<int> digitsVector;
279  for (const FlexDigit* digit : *this)
280  {
281  digitsVector.push_back(digit->digit());
282  }
283  return digitsVector;
284 }
285 
286 
287 //increment() for pairMeter
289 {
290  if(m_pairMeter)
291  {
292  if( m_pairMeter->increment())
293  {
294  return true;
295  }
296  else
297  {
298  delete m_pairMeter;
299  m_pairMeter = NULL;
300  }
301  }
302  return false;
303 }
304 
305 
306 //get unique pairs out of the combined particles (useful for overlap check
307 std::pair<int,int> OdoMeter::getPair()
308 {
309  if(m_pairMeter)
310  {
311  return std::make_pair( (*m_pairMeter)[0]->digit(), (*m_pairMeter)[1]->digit() );
312  }
313  else
314  {
315  return std::make_pair( 0,0 );
316  }
317 }
318 
319 
321 PairMeter::PairMeter( int digitMax )
322  :OdoMeter( 2, digitMax )
323 {
324 }
325 
326 
328 {
329 }
330 
331 
333 {
334  if(this->hasStarted() && this->isZero())
335  {
336  return false;
337  }
338  else if(!this->hasStarted())
339  {
340  this->setStarted() ;
341  }
342  (*this)++;
343  bool found = true;
344  if(!isUnique(true))
345  {
346  found=false;
347  }
348  if(!hasOnlySingleEntry(true))
349  {
350  found=false;
351  }
352  if(!found)
353  {
354  return this->increment();
355  }
356  else
357  {
358  return true;
359  }
360 }
DataVector< FlexDigit >::reserve
void reserve(size_type n)
Attempt to preallocate enough memory for a specified number of elements.
FlexDigit::m_nextDigit
FlexDigit * m_nextDigit
Definition: CombinatoricsOdometer.h:120
FlexDigit::digit
int digit() const
Definition: CombinatoricsOdometer.h:83
OdoMeter::m_digitAssoc
std::map< std::string, std::set< int > > m_digitAssoc
Definition: CombinatoricsOdometer.h:128
OdoMeter::m_onlyUnique
bool m_onlyUnique
Definition: CombinatoricsOdometer.h:124
FlexDigits::increment
virtual bool increment()
Definition: CombinatoricsOdometer.cxx:94
SG
Forward declaration.
Definition: CaloCellPacker_400_500.h:32
FlexDigit::FlexDigit
FlexDigit(int, FlexDigit *=0)
Definition: CombinatoricsOdometer.cxx:27
FlexDigits::print
virtual void print()
Definition: CombinatoricsOdometer.cxx:110
CombinatoricsOdometer.h
FlexDigits::hasStarted
bool hasStarted()
Definition: CombinatoricsOdometer.h:107
OdoMeter::increment
virtual bool increment()
Definition: CombinatoricsOdometer.cxx:242
FlexDigits::~FlexDigits
virtual ~FlexDigits()
Definition: CombinatoricsOdometer.cxx:77
OdoMeter::getPair
std::pair< int, int > getPair()
Definition: CombinatoricsOdometer.cxx:307
checkRpcDigits.digit
digit
Definition: checkRpcDigits.py:186
FlexDigits
Definition: CombinatoricsOdometer.h:90
OdoMeter::isUnique
bool isUnique(bool doCheck)
Definition: CombinatoricsOdometer.cxx:191
FlexDigit::setNext
void setNext(FlexDigit *next)
Definition: CombinatoricsOdometer.h:81
beamspotnt.labels
list labels
Definition: bin/beamspotnt.py:1447
lumiFormat.i
int i
Definition: lumiFormat.py:85
SG::OWN_ELEMENTS
@ OWN_ELEMENTS
this data object owns its elements
Definition: OwnershipPolicy.h:17
FlexDigit
Definition: CombinatoricsOdometer.h:63
add-xsec-uncert-quadrature-N.label
label
Definition: add-xsec-uncert-quadrature-N.py:104
OdoMeter::OdoMeter
OdoMeter(std::vector< std::string > &labels, std::map< std::string, int > &numObj)
Definition: CombinatoricsOdometer.cxx:147
PairMeter::PairMeter
PairMeter(int numDigits)
Definition: CombinatoricsOdometer.cxx:321
FlexDigits::FlexDigits
FlexDigits(std::vector< std::string > &labels, std::map< std::string, int > &digitMax)
Definition: CombinatoricsOdometer.cxx:51
OdoMeter::hasOnlySingleEntry
bool hasOnlySingleEntry(bool doCheck)
Definition: CombinatoricsOdometer.cxx:218
DataVector< FlexDigit >::back
const FlexDigit * back() const
Access the last element in the collection as an rvalue.
DataVector
Derived DataVector<T>.
Definition: DataVector.h:794
OdoMeter::m_labels
std::set< std::string > m_labels
Definition: CombinatoricsOdometer.h:129
FlexDigits::operator++
virtual FlexDigits & operator++(int)
Definition: CombinatoricsOdometer.cxx:134
OdoMeter::nextPair
bool nextPair()
Definition: CombinatoricsOdometer.cxx:288
PairMeter::~PairMeter
virtual ~PairMeter()
Definition: CombinatoricsOdometer.cxx:327
FlexDigit::m_digitMax
int m_digitMax
Definition: CombinatoricsOdometer.h:119
FlexDigit::next
FlexDigit * next()
Definition: CombinatoricsOdometer.h:82
FlexDigits::setStarted
void setStarted()
Definition: CombinatoricsOdometer.h:108
FlexDigit::isAtMax
bool isAtMax()
Definition: CombinatoricsOdometer.h:85
DataVector::push_back
value_type push_back(value_type pElem)
Add an element to the end of the collection.
FlexDigits::push_back
virtual void push_back(FlexDigit *)
Definition: CombinatoricsOdometer.cxx:84
FlexDigit::isFirstDigit
bool isFirstDigit()
Definition: CombinatoricsOdometer.h:86
FlexDigit::setDigit
void setDigit(int digit)
Definition: CombinatoricsOdometer.h:84
OdoMeter::m_onlySingleEntry
bool m_onlySingleEntry
Definition: CombinatoricsOdometer.h:125
FlexDigits::m_started
bool m_started
Definition: CombinatoricsOdometer.h:104
CondAlgsOpts.found
int found
Definition: CondAlgsOpts.py:101
PairMeter::increment
virtual bool increment()
Definition: CombinatoricsOdometer.cxx:332
FlexDigits::isZero
bool isZero()
Definition: CombinatoricsOdometer.cxx:122
OdoMeter::m_pairMeter
OdoMeter * m_pairMeter
Definition: CombinatoricsOdometer.h:127
OdoMeter::m_numLabels
int m_numLabels
Definition: CombinatoricsOdometer.h:126
FlexDigit::m_digit
int m_digit
Definition: CombinatoricsOdometer.h:118
FlexDigit::operator++
FlexDigit operator++(int)
Definition: CombinatoricsOdometer.cxx:35
test_pyathena.counter
counter
Definition: test_pyathena.py:15
OdoMeter::getVector
std::vector< int > getVector()
Definition: CombinatoricsOdometer.cxx:276
DataVector< FlexDigit >::size
size_type size() const noexcept
Returns the number of elements in the collection.
OdoMeter::~OdoMeter
virtual ~OdoMeter()
Definition: CombinatoricsOdometer.cxx:181
PairMeter
Definition: CombinatoricsOdometer.h:134
OdoMeter
Definition: CombinatoricsOdometer.h:112