IVT
DynamicArray.h
Go to the documentation of this file.
1 // ****************************************************************************
2 // This file is part of the Integrating Vision Toolkit (IVT).
3 //
4 // The IVT is maintained by the Karlsruhe Institute of Technology (KIT)
5 // (www.kit.edu) in cooperation with the company Keyetech (www.keyetech.de).
6 //
7 // Copyright (C) 2014 Karlsruhe Institute of Technology (KIT).
8 // All rights reserved.
9 //
10 // Redistribution and use in source and binary forms, with or without
11 // modification, are permitted provided that the following conditions are met:
12 //
13 // 1. Redistributions of source code must retain the above copyright
14 // notice, this list of conditions and the following disclaimer.
15 //
16 // 2. Redistributions in binary form must reproduce the above copyright
17 // notice, this list of conditions and the following disclaimer in the
18 // documentation and/or other materials provided with the distribution.
19 //
20 // 3. Neither the name of the KIT nor the names of its contributors may be
21 // used to endorse or promote products derived from this software
22 // without specific prior written permission.
23 //
24 // THIS SOFTWARE IS PROVIDED BY THE KIT AND CONTRIBUTORS “AS IS” AND ANY
25 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
26 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27 // DISCLAIMED. IN NO EVENT SHALL THE KIT OR CONTRIBUTORS BE LIABLE FOR ANY
28 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
29 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
31 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
33 // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 // ****************************************************************************
35 // ****************************************************************************
36 // Filename: DynamicArray.h
37 // Author: Pedram Azad
38 // Date: 2005
39 // ****************************************************************************
40 
41 #ifndef _DYNAMIC_ARRAY_H_
42 #define _DYNAMIC_ARRAY_H_
43 
44 
45 // ****************************************************************************
46 // Forward declarations
47 // ****************************************************************************
48 
49 class CByteImage;
50 
51 
52 
53 // ****************************************************************************
54 // CDynamicArrayElement
55 // ****************************************************************************
56 
58 {
59 public:
61  {
62  bDelete = true;
63  }
64 
65  virtual ~CDynamicArrayElement() { }
66 
67  virtual bool Equivalent(const CDynamicArrayElement *pElement) const { return true; }
68  virtual float Error(const CDynamicArrayElement *pElement) const { return 0; }
69 
70  bool bDelete;
71 };
72 
73 
74 // ****************************************************************************
75 // CDynamicArray
76 // ****************************************************************************
77 
79 {
80 public:
81  // constructor
82  CDynamicArray(int nInititalSize);
83 
84  // CDynamicArray
86 
87 
88  // public methods
89  bool AddElement(CDynamicArrayElement *pElement, bool bAddUniqueOnly = false, bool bManageMemory = true);
90  inline CDynamicArrayElement* GetElement(int nElement) { return (nElement < 0 || nElement >= m_nElements) ? 0 : m_ppElements[nElement]; }
91  inline const CDynamicArrayElement* GetElement(int nElement) const { return (nElement < 0 || nElement >= m_nElements) ? 0 : m_ppElements[nElement]; }
92  inline CDynamicArrayElement* GetElementNoCheck(int nElement) { return m_ppElements[nElement]; }
93  inline const CDynamicArrayElement* GetElementNoCheck(int nElement) const { return m_ppElements[nElement]; }
94  inline CDynamicArrayElement* operator[] (const int nElement) { return m_ppElements[nElement]; }
96  CDynamicArrayElement* FindBestMatch(const CDynamicArrayElement *pElement, float &fResultError);
97  bool DeleteElement(int nIndex);
98  int DeleteFirstMatch(const CDynamicArrayElement *pElement);
99  int DeleteAllMatches(const CDynamicArrayElement *pElement);
100  void DontManageMemory(int nElement);
101  void Clear();
102  int GetSize() const { return m_nElements; }
103 
104 
105 private:
106  // private methods
107  int _FindFirstMatch(const CDynamicArrayElement *pElement);
108  void SetSize(int nSize);
109 
110 
111  // private attribute
112  int m_nCurrentSize;
113  int m_nElements;
114  CDynamicArrayElement **m_ppElements;
115 };
116 
117 
118 
119 #endif /* _DYNAMIC_ARRAY_H_ */
bool AddElement(CDynamicArrayElement *pElement, bool bAddUniqueOnly=false, bool bManageMemory=true)
CDynamicArrayElement * FindBestMatch(const CDynamicArrayElement *pElement, float &fResultError)
CDynamicArray(int nInititalSize)
int DeleteAllMatches(const CDynamicArrayElement *pElement)
CDynamicArrayElement * FindFirstMatch(const CDynamicArrayElement *pElement)
const CDynamicArrayElement * GetElementNoCheck(int nElement) const
Definition: DynamicArray.h:93
void DontManageMemory(int nElement)
int DeleteFirstMatch(const CDynamicArrayElement *pElement)
CDynamicArrayElement * GetElement(int nElement)
Definition: DynamicArray.h:90
virtual bool Equivalent(const CDynamicArrayElement *pElement) const
Definition: DynamicArray.h:67
CDynamicArrayElement * GetElementNoCheck(int nElement)
Definition: DynamicArray.h:92
CDynamicArrayElement * operator[](const int nElement)
Definition: DynamicArray.h:94
bool DeleteElement(int nIndex)
const CDynamicArrayElement * GetElement(int nElement) const
Definition: DynamicArray.h:91
virtual ~CDynamicArrayElement()
Definition: DynamicArray.h:65
Data structure for the representation of 8-bit grayscale images and 24-bit RGB (or HSV) color images ...
Definition: ByteImage.h:80
virtual float Error(const CDynamicArrayElement *pElement) const
Definition: DynamicArray.h:68
int GetSize() const
Definition: DynamicArray.h:102