annotate armadillo-3.900.4/include/armadillo_bits/SpGlue_bones.hpp @ 76:a595de3e6f8d

Fix invalid call to parts.erase(parts.end()), which can crash and never does anything good. I think this is the intended behaviour.
author Chris Cannam
date Thu, 24 Jan 2019 15:07:04 +0000
parents 1ec0e2823891
children
rev   line source
Chris@49 1 // Copyright (C) 2012 Conrad Sanderson
Chris@49 2 //
Chris@49 3 // This Source Code Form is subject to the terms of the Mozilla Public
Chris@49 4 // License, v. 2.0. If a copy of the MPL was not distributed with this
Chris@49 5 // file, You can obtain one at http://mozilla.org/MPL/2.0/.
Chris@49 6
Chris@49 7
Chris@49 8 //! \addtogroup SpGlue
Chris@49 9 //! @{
Chris@49 10
Chris@49 11
Chris@49 12
Chris@49 13 template<typename T1, typename T2, typename spglue_type>
Chris@49 14 class SpGlue : public SpBase<typename T1::elem_type, SpGlue<T1, T2, spglue_type> >
Chris@49 15 {
Chris@49 16 public:
Chris@49 17
Chris@49 18 typedef typename T1::elem_type elem_type;
Chris@49 19 typedef typename get_pod_type<elem_type>::result pod_type;
Chris@49 20
Chris@49 21 static const bool is_row = ( (T1::is_row || T2::is_row) && is_spglue_elem<spglue_type>::value ) || ( (is_spglue_times<spglue_type>::value || is_spglue_times2<spglue_type>::value) ? T1::is_row : false );
Chris@49 22 static const bool is_col = ( (T1::is_col || T2::is_col) && is_spglue_elem<spglue_type>::value ) || ( (is_spglue_times<spglue_type>::value || is_spglue_times2<spglue_type>::value) ? T2::is_col : false );
Chris@49 23
Chris@49 24 arma_inline SpGlue(const T1& in_A, const T2& in_B);
Chris@49 25 arma_inline SpGlue(const T1& in_A, const T2& in_B, const elem_type in_aux);
Chris@49 26 arma_inline ~SpGlue();
Chris@49 27
Chris@49 28 const T1& A; //!< first operand
Chris@49 29 const T2& B; //!< second operand
Chris@49 30 elem_type aux;
Chris@49 31 };
Chris@49 32
Chris@49 33
Chris@49 34
Chris@49 35 //! @}