"Fossies" - the Fresh Open Source Software Archive

Member "armadillo-9.800.3/include/armadillo_bits/op_trimat_bones.hpp" (16 Jun 2016, 2174 Bytes) of package /linux/misc/armadillo-9.800.3.tar.xz:


As a special service "Fossies" has tried to format the requested source page into HTML format using (guessed) C and C++ source code syntax highlighting (style: standard) with prefixed line numbers and code folding option. Alternatively you can here view or download the uninterpreted source code file. For more information about "op_trimat_bones.hpp" see the Fossies "Dox" file reference documentation.

    1 // Copyright 2008-2016 Conrad Sanderson (http://conradsanderson.id.au)
    2 // Copyright 2008-2016 National ICT Australia (NICTA)
    3 // 
    4 // Licensed under the Apache License, Version 2.0 (the "License");
    5 // you may not use this file except in compliance with the License.
    6 // You may obtain a copy of the License at
    7 // http://www.apache.org/licenses/LICENSE-2.0
    8 // 
    9 // Unless required by applicable law or agreed to in writing, software
   10 // distributed under the License is distributed on an "AS IS" BASIS,
   11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   12 // See the License for the specific language governing permissions and
   13 // limitations under the License.
   14 // ------------------------------------------------------------------------
   15 
   16 
   17 //! \addtogroup op_trimat
   18 //! @{
   19 
   20 
   21 
   22 class op_trimat
   23   : public traits_op_default
   24   {
   25   public:
   26   
   27   template<typename eT>
   28   inline static void fill_zeros(Mat<eT>& A, const bool upper);
   29   
   30   //
   31   
   32   template<typename T1>
   33   inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_trimat>& in);
   34   
   35   template<typename T1>
   36   inline static void apply(Mat<typename T1::elem_type>& out, const Op<Op<T1,op_htrans>, op_trimat>& in);
   37   
   38   //
   39   
   40   template<typename eT>
   41   inline static void apply_htrans(Mat<eT>& out, const Mat<eT>& A, const bool upper, const typename arma_not_cx<eT>::result* junk = 0);
   42   
   43   template<typename eT>
   44   inline static void apply_htrans(Mat<eT>& out, const Mat<eT>& A, const bool upper, const typename arma_cx_only<eT>::result* junk = 0);
   45   };
   46 
   47 
   48 
   49 class op_trimatu_ext
   50   : public traits_op_default
   51   {
   52   public:
   53   
   54   template<typename T1>
   55   inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_trimatu_ext>& in);
   56   
   57   template<typename eT>
   58   inline static void fill_zeros(Mat<eT>& A, const uword row_offset, const uword col_offset);
   59   };
   60 
   61 
   62 
   63 class op_trimatl_ext
   64   : public traits_op_default
   65   {
   66   public:
   67   
   68   template<typename T1>
   69   inline static void apply(Mat<typename T1::elem_type>& out, const Op<T1,op_trimatl_ext>& in);
   70   
   71   template<typename eT>
   72   inline static void fill_zeros(Mat<eT>& A, const uword row_offset, const uword col_offset);
   73   };
   74 
   75 
   76 
   77 //! @}