max@0: // Copyright (C) 2008-2010 NICTA (www.nicta.com.au) max@0: // Copyright (C) 2008-2010 Conrad Sanderson max@0: // max@0: // This file is part of the Armadillo C++ library. max@0: // It is provided without any warranty of fitness max@0: // for any purpose. You can redistribute this file max@0: // and/or modify it under the terms of the GNU max@0: // Lesser General Public License (LGPL) as published max@0: // by the Free Software Foundation, either version 3 max@0: // of the License or (at your option) any later version. max@0: // (see http://www.opensource.org/licenses for more info) max@0: max@0: max@0: //! \addtogroup Glue max@0: //! @{ max@0: max@0: max@0: max@0: //! Class for storing data required for delayed binary operations, max@0: //! such as the operands (e.g. two matrices) and the binary operator (e.g. addition). max@0: //! The operands are stored as references (which can be optimised away), max@0: //! while the operator is "stored" through the template definition (glue_type). max@0: //! The operands can be 'Mat', 'Row', 'Col', 'Op', and 'Glue'. max@0: //! Note that as 'Glue' can be one of the operands, more than two matrices can be stored. max@0: //! max@0: //! For example, we could have: Glue max@0: //! max@0: //! Another example is: Glue< Op, Op, glue_times > max@0: max@0: max@0: max@0: template max@0: class Glue : public Base > max@0: { max@0: public: max@0: max@0: typedef typename T1::elem_type elem_type; max@0: typedef typename get_pod_type::result pod_type; max@0: max@0: arma_inline Glue(const T1& in_A, const T2& in_B); max@0: arma_inline Glue(const T1& in_A, const T2& in_B, const uword in_aux_uword); max@0: arma_inline ~Glue(); max@0: max@0: const T1& A; //!< first operand max@0: const T2& B; //!< second operand max@0: uword aux_uword; //!< storage of auxiliary data, uword format max@0: }; max@0: max@0: max@0: max@0: //! @}