Mercurial > hg > segmenter-vamp-plugin
annotate armadillo-2.4.4/include/armadillo_bits/op_inv_bones.hpp @ 0:8b6102e2a9b0
Armadillo Library
author | maxzanoni76 <max.zanoni@eecs.qmul.ac.uk> |
---|---|
date | Wed, 11 Apr 2012 09:27:06 +0100 |
parents | |
children |
rev | line source |
---|---|
max@0 | 1 // Copyright (C) 2008-2011 NICTA (www.nicta.com.au) |
max@0 | 2 // Copyright (C) 2008-2011 Conrad Sanderson |
max@0 | 3 // |
max@0 | 4 // This file is part of the Armadillo C++ library. |
max@0 | 5 // It is provided without any warranty of fitness |
max@0 | 6 // for any purpose. You can redistribute this file |
max@0 | 7 // and/or modify it under the terms of the GNU |
max@0 | 8 // Lesser General Public License (LGPL) as published |
max@0 | 9 // by the Free Software Foundation, either version 3 |
max@0 | 10 // of the License or (at your option) any later version. |
max@0 | 11 // (see http://www.opensource.org/licenses for more info) |
max@0 | 12 |
max@0 | 13 |
max@0 | 14 //! \addtogroup op_inv |
max@0 | 15 //! @{ |
max@0 | 16 |
max@0 | 17 |
max@0 | 18 |
max@0 | 19 //! 'invert matrix' operation (general matrices) |
max@0 | 20 class op_inv |
max@0 | 21 { |
max@0 | 22 public: |
max@0 | 23 |
max@0 | 24 template<typename eT> |
max@0 | 25 inline static void apply(Mat<eT>& out, const Mat<eT>& A, const bool slow = false); |
max@0 | 26 |
max@0 | 27 template<typename T1> |
max@0 | 28 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_inv>& in); |
max@0 | 29 |
max@0 | 30 template<typename T1> |
max@0 | 31 inline static void apply_diag(Mat<typename T1::elem_type>& out, const Base<typename T1::elem_type, T1>& X); |
max@0 | 32 }; |
max@0 | 33 |
max@0 | 34 |
max@0 | 35 |
max@0 | 36 //! 'invert matrix' operation (triangular matrices) |
max@0 | 37 class op_inv_tr |
max@0 | 38 { |
max@0 | 39 public: |
max@0 | 40 |
max@0 | 41 template<typename T1> |
max@0 | 42 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_inv_tr>& in); |
max@0 | 43 }; |
max@0 | 44 |
max@0 | 45 |
max@0 | 46 |
max@0 | 47 //! 'invert matrix' operation (symmetric positive definite matrices) |
max@0 | 48 class op_inv_sympd |
max@0 | 49 { |
max@0 | 50 public: |
max@0 | 51 |
max@0 | 52 template<typename T1> |
max@0 | 53 inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_inv_sympd>& in); |
max@0 | 54 }; |
max@0 | 55 |
max@0 | 56 |
max@0 | 57 |
max@0 | 58 //! @} |