ivl 679
|
00001 /* This file is part of the ivl C++ library <http://image.ntua.gr/ivl>. 00002 A C++ template library extending syntax towards mathematical notation. 00003 00004 Copyright (C) 2012 Yannis Avrithis <iavr@image.ntua.gr> 00005 Copyright (C) 2012 Kimon Kontosis <kimonas@image.ntua.gr> 00006 00007 ivl is free software; you can redistribute it and/or modify 00008 it under the terms of the GNU Lesser General Public License 00009 version 3 as published by the Free Software Foundation. 00010 00011 Alternatively, you can redistribute it and/or modify it under the terms 00012 of the GNU General Public License version 2 as published by the Free 00013 Software Foundation. 00014 00015 ivl is distributed in the hope that it will be useful, 00016 but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. 00018 See the GNU General Public License for more details. 00019 00020 You should have received a copy of the GNU General Public License 00021 and a copy of the GNU Lesser General Public License along 00022 with ivl. If not, see <http://www.gnu.org/licenses/>. */ 00023 00024 #ifndef IVL_CORE_DETAILS_MATRIX_BASED_HPP 00025 #define IVL_CORE_DETAILS_MATRIX_BASED_HPP 00026 00027 namespace ivl { 00028 00029 namespace core_details { 00030 00031 template<class T> 00032 struct matrix_based 00033 { 00034 T t; 00035 typedef typename types::bare_type<T>::type B; 00036 typedef typename types::bare_type<T>::type base_class; 00037 typedef typename types::bare_type<T>::type::elem_type elem_type; 00038 matrix_based(const typename types::bare_type<T>::type& x) : t(x) { } 00039 00040 typename types::bare_type<T>::type& base() { return t; } 00041 const typename types::bare_type<T>::type& base() const { return t; } 00042 00043 // awful 00044 template<class U> 00045 typename B::create_new operator*(const U& u) const 00046 { 00047 return mtimes(t, u); 00048 } 00049 00050 template<class U> 00051 matrix_based<typename B::create_new> operator*(const matrix_based<U>& u) const 00052 { 00053 return mtimes(t, u.t); 00054 } 00055 00056 // 00057 // 00058 typename B::create_new operator!() const 00059 { 00060 return transpose(t); 00061 } 00062 00063 }; 00064 00065 } /* namespace core_details */ 00066 00067 } /* namespace ivl */ 00068 00069 #endif // IVL_CORE_DETAILS_MATRIX_BASED_HPP