DoubleMatrix.cpp
Go to the documentation of this file.
00001 // ****************************************************************************
00002 // This file is part of the Integrating Vision Toolkit (IVT).
00003 //
00004 // The IVT is maintained by the Karlsruhe Institute of Technology (KIT)
00005 // (www.kit.edu) in cooperation with the company Keyetech (www.keyetech.de).
00006 //
00007 // Copyright (C) 2014 Karlsruhe Institute of Technology (KIT).
00008 // All rights reserved.
00009 //
00010 // Redistribution and use in source and binary forms, with or without
00011 // modification, are permitted provided that the following conditions are met:
00012 //
00013 // 1. Redistributions of source code must retain the above copyright
00014 //    notice, this list of conditions and the following disclaimer.
00015 //
00016 // 2. Redistributions in binary form must reproduce the above copyright
00017 //    notice, this list of conditions and the following disclaimer in the
00018 //    documentation and/or other materials provided with the distribution.
00019 //
00020 // 3. Neither the name of the KIT nor the names of its contributors may be
00021 //    used to endorse or promote products derived from this software
00022 //    without specific prior written permission.
00023 //
00024 // THIS SOFTWARE IS PROVIDED BY THE KIT AND CONTRIBUTORS “AS IS” AND ANY
00025 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00026 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00027 // DISCLAIMED. IN NO EVENT SHALL THE KIT OR CONTRIBUTORS BE LIABLE FOR ANY
00028 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00029 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00030 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00031 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00032 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
00033 // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00034 // ****************************************************************************
00035 // ****************************************************************************
00036 // Filename:  DoubleMatrix.cpp
00037 // Author:    Pedram Azad
00038 // Date:      2005
00039 // ****************************************************************************
00040 
00041 
00042 // ****************************************************************************
00043 // Includes
00044 // ****************************************************************************
00045 
00046 #include <new> // for explicitly using correct new/delete operators on VC DSPs
00047 
00048 #include "DoubleMatrix.h"
00049 
00050 #include "Helpers/helpers.h"
00051 
00052 #include <stdio.h>
00053 #include <string>
00054 
00055 
00056 
00057 // ****************************************************************************
00058 // Constructors / Destructor
00059 // ****************************************************************************
00060 
00061 CDoubleMatrix::CDoubleMatrix()
00062 {
00063         columns = 0;
00064         rows = 0;
00065         data = 0;
00066         m_bOwnMemory = false;
00067 }
00068 
00069 CDoubleMatrix::CDoubleMatrix(int nColumns, int nRows, bool bHeaderOnly)
00070 {
00071         columns = nColumns;
00072         rows = nRows;
00073 
00074         if (bHeaderOnly)
00075         {
00076                 data = 0;
00077                 m_bOwnMemory = false;
00078         }
00079         else
00080         {
00081         data = new double[columns * rows];
00082                 m_bOwnMemory = true;
00083         }
00084 }
00085 
00086 CDoubleMatrix::CDoubleMatrix(const CDoubleMatrix &matrix, bool bHeaderOnly)
00087 {
00088         columns = matrix.columns;
00089         rows = matrix.rows;
00090         
00091         if (bHeaderOnly)
00092         {
00093                 data = 0;
00094                 m_bOwnMemory = false;
00095         }
00096         else
00097         {
00098                 data = new double[columns * rows];
00099                 m_bOwnMemory = true;
00100         }
00101 }
00102 
00103 
00104 CDoubleMatrix::CDoubleMatrix(const CDoubleMatrix *pMatrix, bool bHeaderOnly)
00105 {
00106         columns = pMatrix->columns;
00107         rows = pMatrix->rows;
00108         
00109         if (bHeaderOnly)
00110         {
00111                 data = 0;
00112                 m_bOwnMemory = false;
00113         }
00114         else
00115         {
00116                 data = new double[columns * rows];
00117                 m_bOwnMemory = true;
00118         }
00119 }
00120 
00121 CDoubleMatrix::~CDoubleMatrix()
00122 {
00123     FreeMemory();
00124 }
00125 
00126 
00127 // ****************************************************************************
00128 // Methods
00129 // ****************************************************************************
00130 
00131 void CDoubleMatrix::FreeMemory()
00132 {
00133         if (data)
00134         {
00135                 if (m_bOwnMemory)
00136             delete [] data;
00137 
00138                 data = 0;
00139                 m_bOwnMemory = false;
00140         }
00141 }


asr_ivt
Author(s): Allgeyer Tobias, Hutmacher Robin, Kleinert Daniel, Meißner Pascal, Scholz Jonas, Stöckle Patrick
autogenerated on Thu Jun 6 2019 21:46:57