📄 tuple.cpp
字号:
/* Context : Matrix and Vector Operation Author : Frank Hoeppner, see also AUTHORS file Description : implementation of class module Tuple History : matvec.nw 980630 fh: first noweb version of generic_matrix 980925 fh: inserted constructors with 1/2/3 field parameters from statmatrix 981007 fh: reorganization of refinements matvec.init-vec.nw: 981104 fh: moved constructors from matrix.nw because of DiagMatrix 990107 fh: reorganization of refinement chunks 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 Tuple_SOURCE#define Tuple_SOURCE/* configuration include */#ifdef HAVE_CONFIG_H/*//FILETREE_IFDEF HAVE_CONFIG_H*/#include "config.h"/*//FILETREE_ENDIF*/#endif// necessary includes#include "Tuple.hpp"// data// implementationtemplate <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( ) { memset(&m_field,0,sizeof(DATA)*ROWS); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const Tuple<ROWS,DATA>& ar_Copy ) { adjust(ar_Copy.rows(),ar_Copy.cols()); memcpy(&m_field,&ar_Copy.m_field,sizeof(DATA)*ROWS); }template <short ROWS, class DATA>void Tuple<ROWS,DATA>::operator= ( const Tuple& ar_Copy ) { adjust(ar_Copy.rows(),ar_Copy.cols()); memcpy(&m_field,&ar_Copy.m_field,sizeof(DATA)*ROWS); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::~Tuple ( ) { }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const value_type value0 ) { matrix_set_vector(*this,value0); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const value_type value0, const value_type value1 ) { matrix_set_vector(*this,value0,value1); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const value_type value0, const value_type value1, const value_type value2 ) { matrix_set_vector(*this,value0,value1,value2); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const value_type value0, const value_type value1, const value_type value2, const value_type value3 ) { matrix_set_vector(*this,value0,value1,value2,value3); }template <short ROWS, class DATA>Tuple<ROWS,DATA>::Tuple ( const value_type value0, const value_type value1, const value_type value2, const value_type value3, const value_type value4 ) { matrix_set_vector(*this,value0,value1,value2,value3,value4); }template <short ROWS, class DATA> voidTuple<ROWS,DATA>::adjust(int rows,int cols) { //#pragma set woff 1209 // SGI remark(1209): controlling expression is constant if (false) { invariant ( rows <= ROWS, "new size does not exceed static dimension", SOURCELOC ); invariant(false,"this line should never be executed",SOURCELOC); } //#pragma reset woff 1209 // SGI remark(1209): controlling expression is constant }template <short ROWS, class DATA>bool Tuple<ROWS,DATA>::operator< ( const Tuple& M ) const { return matrix_lexico_less(*this,M); }template <short ROWS, class DATA>bool Tuple<ROWS,DATA>::operator== ( const Tuple& M ) const { return matrix_numeric_equal(*this,M); }template <short ROWS, class DATA>voidTuple<ROWS,DATA>::write ( ostream& os ) const { write_matrix(os,*this); }template <short ROWS, class DATA>voidTuple<ROWS,DATA>::read ( istream& is ) { read_matrix(is,*this); }// template instantiation#endif // Tuple_SOURCE
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -