ivl 679
ivl/details/core/keyword_operators/matrix_based.hpp
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
 All Classes Namespaces Files Functions Variables Typedefs Enumerations