// Copyright 2008-2016 Conrad Sanderson (http://conradsanderson.id.au) // Copyright 2008-2016 National ICT Australia (NICTA) // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ------------------------------------------------------------------------ using std::cout; using std::cerr; using std::endl; using std::ios; using std::size_t; template struct Base; template struct BaseCube; template class Mat; template class Col; template class Row; template class Cube; template class xvec_htrans; template class field; template class xtrans_mat; template class subview; template class subview_col; template class subview_row; template class subview_row_strans; template class subview_row_htrans; template class subview_cube; template class subview_field; template class SpValProxy; template class SpMat; template class SpCol; template class SpRow; template class SpSubview; template class SpSubview_col; template class SpSubview_row; template class diagview; template class spdiagview; template class MapMat; template class MapMat_val; template class SpMat_MapMat_val; template class SpSubview_MapMat_val; template class subview_elem1; template class subview_elem2; template class subview_each1; template class subview_each2; template class subview_cube_each1; template class subview_cube_each2; template class subview_cube_slices; class SizeMat; class SizeCube; class arma_empty_class {}; class diskio; class op_strans; class op_htrans; class op_htrans2; class op_inv; class op_inv_sympd; class op_diagmat; class op_trimat; class op_vectorise_row; class op_vectorise_col; class glue_times; class glue_times_diag; class glue_rel_lt; class glue_rel_gt; class glue_rel_lteq; class glue_rel_gteq; class glue_rel_eq; class glue_rel_noteq; class glue_rel_and; class glue_rel_or; class op_rel_lt_pre; class op_rel_lt_post; class op_rel_gt_pre; class op_rel_gt_post; class op_rel_lteq_pre; class op_rel_lteq_post; class op_rel_gteq_pre; class op_rel_gteq_post; class op_rel_eq; class op_rel_noteq; class gen_eye; class gen_ones; class gen_zeros; class gen_randu; class gen_randn; class spop_strans; class spop_htrans; class spop_vectorise_row; class spop_vectorise_col; class spglue_plus; class spglue_minus; class spglue_schur; class spglue_times; class spglue_max; class spglue_min; class spglue_rel_lt; class spglue_rel_gt; class op_internal_equ; class op_internal_plus; class op_internal_minus; class op_internal_schur; class op_internal_div; struct traits_op_default { template struct traits { static const bool is_row = false; static const bool is_col = false; static const bool is_xvec = false; }; }; struct traits_op_xvec { template struct traits { static const bool is_row = false; static const bool is_col = false; static const bool is_xvec = true; }; }; struct traits_op_col { template struct traits { static const bool is_row = false; static const bool is_col = true; static const bool is_xvec = false; }; }; struct traits_op_row { template struct traits { static const bool is_row = true; static const bool is_col = false; static const bool is_xvec = false; }; }; struct traits_op_passthru { template struct traits { static const bool is_row = T1::is_row; static const bool is_col = T1::is_col; static const bool is_xvec = T1::is_xvec; }; }; struct traits_glue_default { template struct traits { static const bool is_row = false; static const bool is_col = false; static const bool is_xvec = false; }; }; struct traits_glue_or { template struct traits { static const bool is_row = (T1::is_row || T2::is_row ); static const bool is_col = (T1::is_col || T2::is_col ); static const bool is_xvec = (T1::is_xvec || T2::is_xvec); }; }; template class gemm; template class gemv; template< typename eT, typename gen_type> class Gen; template< typename T1, typename op_type> class Op; template< typename T1, typename eop_type> class eOp; template< typename T1, typename op_type> class SpToDOp; template< typename T1, typename op_type> class CubeToMatOp; template class mtOp; template< typename T1, typename T2, typename glue_type> class Glue; template< typename T1, typename T2, typename eglue_type> class eGlue; template class mtGlue; template< typename eT, typename gen_type> class GenCube; template< typename T1, typename op_type> class OpCube; template< typename T1, typename eop_type> class eOpCube; template class mtOpCube; template< typename T1, typename T2, typename glue_type> class GlueCube; template< typename T1, typename T2, typename eglue_type> class eGlueCube; template class mtGlueCube; template class Proxy; template class ProxyCube; template class diagmat_proxy; template struct unwrap; template struct unwrap_cube; template struct unwrap_spmat; struct state_type { #if defined(ARMA_USE_OPENMP) int state; #elif (defined(ARMA_USE_CXX11) && !defined(ARMA_DONT_USE_CXX11_MUTEX)) std::atomic state; #else int state; #endif arma_inline state_type() : state(int(0)) {} // openmp: "omp atomic" does an implicit flush on the affected variable // C++11: std::atomic<>::load() and std::atomic<>::store() use std::memory_order_seq_cst by default, which has an implied fence arma_inline operator int () const { int out; #if defined(ARMA_USE_OPENMP) #pragma omp atomic read out = state; #elif (defined(ARMA_USE_CXX11) && !defined(ARMA_DONT_USE_CXX11_MUTEX)) out = state.load(); #else out = state; #endif return out; } arma_inline void operator= (const int in_state) { #if defined(ARMA_USE_OPENMP) #pragma omp atomic write state = in_state; #elif (defined(ARMA_USE_CXX11) && !defined(ARMA_DONT_USE_CXX11_MUTEX)) state.store(in_state); #else state = in_state; #endif } }; template< typename T1, typename spop_type> class SpOp; template class mtSpOp; template< typename T1, typename T2, typename spglue_type> class SpGlue; template class mtSpGlue; template class SpProxy; struct arma_vec_indicator {}; struct arma_fixed_indicator {}; struct arma_reserve_indicator {}; struct arma_layout_indicator {}; //! \addtogroup injector //! @{ template struct injector_end_of_row {}; static const injector_end_of_row<> endr = injector_end_of_row<>(); //!< endr indicates "end of row" when using the << operator; //!< similar conceptual meaning to std::endl //! @} //! \addtogroup diskio //! @{ enum file_type { file_type_unknown, auto_detect, //!< attempt to automatically detect the file type raw_ascii, //!< raw text (ASCII), without a header arma_ascii, //!< Armadillo text format, with a header specifying matrix type and size csv_ascii, //!< comma separated values (CSV), without a header raw_binary, //!< raw binary format (machine dependent), without a header arma_binary, //!< Armadillo binary format (machine dependent), with a header specifying matrix type and size pgm_binary, //!< Portable Grey Map (greyscale image) ppm_binary, //!< Portable Pixel Map (colour image), used by the field and cube classes hdf5_binary, //!< HDF5: open binary format, not specific to Armadillo, which can store arbitrary data hdf5_binary_trans, //!< [DO NOT USE - deprecated] as per hdf5_binary, but save/load the data with columns transposed to rows coord_ascii //!< simple co-ordinate format for sparse matrices (indices start at zero) }; struct hdf5_name; struct csv_name; //! @} //! \addtogroup fill //! @{ namespace fill { struct fill_none {}; struct fill_zeros {}; struct fill_ones {}; struct fill_eye {}; struct fill_randu {}; struct fill_randn {}; template struct fill_class { inline fill_class() {} }; static const fill_class none; static const fill_class zeros; static const fill_class ones; static const fill_class eye; static const fill_class randu; static const fill_class randn; } //! @} //! \addtogroup fn_spsolve //! @{ struct spsolve_opts_base { const unsigned int id; inline spsolve_opts_base(const unsigned int in_id) : id(in_id) {} }; struct spsolve_opts_none : public spsolve_opts_base { inline spsolve_opts_none() : spsolve_opts_base(0) {} }; struct superlu_opts : public spsolve_opts_base { typedef enum {NATURAL, MMD_ATA, MMD_AT_PLUS_A, COLAMD} permutation_type; typedef enum {REF_NONE, REF_SINGLE, REF_DOUBLE, REF_EXTRA} refine_type; bool allow_ugly; bool equilibrate; bool symmetric; double pivot_thresh; permutation_type permutation; refine_type refine; inline superlu_opts() : spsolve_opts_base(1) { allow_ugly = false; equilibrate = false; symmetric = false; pivot_thresh = 1.0; permutation = COLAMD; refine = REF_NONE; } }; //! @}