1 /* -*- c++ -*- */ 2 /* 3 * Copyright 2014,2017-2018 Free Software Foundation, Inc. 4 * 5 * This file is part of GNU Radio 6 * 7 * GNU Radio is free software; you can redistribute it and/or modify 8 * it under the terms of the GNU General Public License as published by 9 * the Free Software Foundation; either version 3, or (at your option) 10 * any later version. 11 * 12 * GNU Radio is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * GNU General Public License for more details. 16 * 17 * You should have received a copy of the GNU General Public License 18 * along with GNU Radio; see the file COPYING. If not, write to 19 * the Free Software Foundation, Inc., 51 Franklin Street, 20 * Boston, MA 02110-1301, USA. 21 */ 22 23 #ifndef INCLUDED_BLOCKS_MULTIPLY_MATRIX_IMPL_H 24 #define INCLUDED_BLOCKS_MULTIPLY_MATRIX_IMPL_H 25 26 #include <gnuradio/blocks/multiply_matrix.h> 27 28 namespace gr { 29 namespace blocks { 30 31 template <class T> 32 class multiply_matrix_impl : public multiply_matrix<T> 33 { 34 private: 35 std::vector<std::vector<T>> d_A; 36 37 void 38 propagate_tags_by_A(int noutput_items, size_t ninput_ports, size_t noutput_ports); 39 40 void msg_handler_A(pmt::pmt_t A); 41 42 public: 43 multiply_matrix_impl(std::vector<std::vector<T>> A, 44 gr::block::tag_propagation_policy_t tag_propagation_policy); 45 ~multiply_matrix_impl(); 46 get_A()47 const std::vector<std::vector<T>>& get_A() const { return d_A; }; 48 bool set_A(const std::vector<std::vector<T>>& new_A); 49 50 int work(int noutput_items, 51 gr_vector_const_void_star& input_items, 52 gr_vector_void_star& output_items); 53 }; 54 55 } // namespace blocks 56 } // namespace gr 57 58 #endif /* INCLUDED_BLOCKS_MULTIPLY_MATRIX_IMPL_H */ 59