📄 dyntuple.hpp
字号:
/* Context : Matrix and Vector Operation Author : Frank Hoeppner, see also AUTHORS file Description : header of class DynTuple History : see source file Comment : This file was generated automatically. DO NOT EDIT. Copyright : Copyright (C) 1999-2000 Frank Hoeppner This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA*/#ifndef DynTuple_HEADER#define DynTuple_HEADER/* configuration include */#ifdef HAVE_CONFIG_H/*//FILETREE_IFDEF HAVE_CONFIG_H*/#include "config.h"/*//FILETREE_ENDIF*/#endif// necessary includes#include <iostream.h>#include "define.hpp" // TData#include "matvecop.hpp"#include "trace.hpp" // invariant//#define INLINE inline// global types, constants, definitions// class definitiontemplate <short ROWS, class DATA = TData>class DynTuple { public: typedef DATA value_type; DynTuple(); DynTuple(const DynTuple&); void operator=(const DynTuple&); ~DynTuple(); DynTuple(const value_type); DynTuple(const value_type,const value_type); DynTuple(const value_type,const value_type,const value_type); DynTuple(const value_type,const value_type,const value_type, const value_type); DynTuple(const value_type,const value_type,const value_type, const value_type,const value_type); inline value_type operator()(const int,const int c=0) const; inline value_type operator[](const int) const; inline value_type& operator()(const int,const int c=0); inline value_type& operator[](const int); inline int rows() const; inline int cols() const; void adjust(int, int c=1); bool operator<(const DynTuple&) const; bool operator==(const DynTuple&) const; void write(ostream&) const; void read(istream&); protected: index_type m_array_size; DATA *mp_field; int m_rows; int m_cols; private: };// class related functions and definitions/* inline implementation */template <short ROWS, class DATA> inline DATADynTuple<ROWS,DATA>::operator()(const int row,const int col) const { invariant ( (row < m_rows) && (col < m_cols), "matrix access out of range", SOURCELOC ); invariant(col==0,"tuple provides only single column",SOURCELOC); const int n = row; return mp_field[n]; }template <short ROWS, class DATA> inline DATA& DynTuple<ROWS,DATA>::operator()(const int row,const int col) { invariant ( (row < m_rows) && (col < m_cols), "matrix access out of range", SOURCELOC ); invariant(col==0,"tuple provides only single column",SOURCELOC); const int n = row; return mp_field[n]; }template <short ROWS, class DATA> inline DATADynTuple<ROWS,DATA>::operator[](const int row) const { invariant ( (row < m_rows) && (m_cols == 1), "vector access out of range", SOURCELOC ); const int n = row; return mp_field[n]; } template <short ROWS, class DATA> inline DATA& DynTuple<ROWS,DATA>::operator[](const int row) { invariant ( (row < m_rows) && (m_cols == 1), "vector access out of range", SOURCELOC ); const int n = row; return mp_field[n]; } template <short ROWS, class DATA> inline intDynTuple<ROWS,DATA>::rows() const { return m_rows; }template <short ROWS, class DATA> inline intDynTuple<ROWS,DATA>::cols() const { return m_cols; }template <short ROWS, class DATA>inline istream& operator>> ( istream &is, DynTuple<ROWS,DATA>& a_var ) { a_var.read(is); return is; }template <short ROWS, class DATA>inline ostream& operator<< ( ostream &os, const DynTuple<ROWS,DATA>& a_var ) { a_var.write(os); return os; }#endif // DynTuple_HEADER
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -