eLynx SDK
v3.3.0 C++ image processing API reference |
00001 //============================================================================ 00002 // Vector.h Math.Component package 00003 //============================================================================ 00004 // Usage : linear algebra - vector implementation 00005 //---------------------------------------------------------------------------- 00006 // Copyright (C) 2006 by eLynx project 00007 // 00008 // This library is free software; you can redistribute it and/or 00009 // modify it under the terms of the GNU Library General Public 00010 // License as published by the Free Software Foundation; either 00011 // version 2 of the License, or (at your option) any later version. 00012 // 00013 // This library is distributed in the hope that it will be useful, 00014 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 00016 // See the GNU Library General Public License for more details. 00017 //---------------------------------------------------------------------------- 00018 #ifndef __Vector_h__ 00019 #define __Vector_h__ 00020 00021 #include "IVector.h" 00022 #include <boost/scoped_array.hpp> 00023 00024 namespace eLynx { 00025 namespace Math { 00026 00031 class ExportedByMath Vector : public IVector { 00032 00033 public: 00034 00038 Vector(uint32 iSize); 00039 00042 Vector(const IVector &iOther); 00043 00046 Vector(const Vector &iOther); 00047 00051 Vector& operator = (const Vector &iOther); 00052 00055 00056 virtual uint32 GetSize() const { return _Size; } 00057 virtual const double& operator () (uint32 iIndex) const; 00058 virtual double& operator () (uint32 iIndex); 00059 virtual void SwapValues(uint32 iIndex1, uint32 iIndex2); 00060 00062 00066 void Resize(uint32 iSize); 00067 00070 double GetLength() const; 00071 00072 private: 00073 00077 void CopyData(const Vector &iOther); 00078 00080 boost::scoped_array<double> _spVector; 00081 00083 uint32 _Size; 00084 00085 }; 00086 00087 } // namespace Math 00088 } // namespace eLynx 00089 00090 00091 #endif // __Vector_h__ 00092