All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
IndexPairSet.h
1 // Copyright eeGeo Ltd (2012-2014), All Rights Reserved
2 
3 #pragma once
4 
5 #include "Labels.h"
6 #include "Types.h"
7 
8 #include <vector>
9 
10 namespace Eegeo
11 {
12  namespace Labels
13  {
15  {
16  public:
17  IndexPairSet();
18 
19  void Resize(int maxObjects);
20 
21  void Clear();
22 
23  void Shrink();
24 
25  bool Contains(int objectIndexA, int objectIndexB) const;
26 
27  void Set(int objectIndexA, int objectIndexB);
28 
29  bool SetAndReturnDidContain(int objectIndexA, int objectIndexB);
30 
31  private:
32 
33  int CalcBitIndex(int objectIndexA, int objectIndexB) const
34  {
35  Eegeo_ASSERT(objectIndexA != objectIndexB);
36  int minIndex = std::min(objectIndexA, objectIndexB);
37  int maxIndex = std::max(objectIndexA, objectIndexB);
38 
39  return (minIndex * (2 * m_maxObjects - minIndex - 3) / 2) + maxIndex - 1;
40  }
41 
42  u32 CalcMask(int bitIndex) const
43  {
44  return 1 << (bitIndex & 31);
45  }
46 
47  int CalcElementIndex(int bitIndex) const
48  {
49  return bitIndex >> 5;
50  }
51 
52  bool IsElementSet(int elementIndex, u32 elementMask) const
53  {
54  return (m_bitfield[elementIndex] & elementMask) != 0;
55  }
56 
57  void SetElement(int elementIndex, u32 elementMask)
58  {
59  m_bitfield[elementIndex] |= elementMask;
60  }
61 
62  int m_maxObjects;
63  std::vector<u32> m_bitfield;
64  };
65  }
66 }