3 * Copyright 2004 Free Software Foundation, Inc.
5 * This file is part of GNU Radio
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)
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.
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.
23 // WARNING: this file is machine generated. Edits will be over written
25 #ifndef INCLUDED_TRELLIS_VITERBI_COMBINED_IB_H
26 #define INCLUDED_TRELLIS_VITERBI_COMBINED_IB_H
30 #include "trellis_calc_metric.h"
32 class trellis_viterbi_combined_ib;
33 typedef boost::shared_ptr<trellis_viterbi_combined_ib> trellis_viterbi_combined_ib_sptr;
35 trellis_viterbi_combined_ib_sptr trellis_make_viterbi_combined_ib (
41 const std::vector<int> &TABLE,
42 trellis_metric_type_t TYPE);
48 class trellis_viterbi_combined_ib : public gr_block
55 std::vector<int> d_TABLE;
56 trellis_metric_type_t d_TYPE;
57 //std::vector<int> d_trace;
59 friend trellis_viterbi_combined_ib_sptr trellis_make_viterbi_combined_ib (
65 const std::vector<int> &TABLE,
66 trellis_metric_type_t TYPE);
69 trellis_viterbi_combined_ib (
75 const std::vector<int> &TABLE,
76 trellis_metric_type_t TYPE);
80 fsm FSM () const { return d_FSM; }
81 int K () const { return d_K; }
82 int S0 () const { return d_S0; }
83 int SK () const { return d_SK; }
84 int D () const { return d_D; }
85 std::vector<int> TABLE () const { return d_TABLE; }
86 trellis_metric_type_t TYPE () const { return d_TYPE; }
87 //std::vector<int> trace () const { return d_trace; }
88 void set_TABLE (const std::vector<int> &table);
89 void forecast (int noutput_items,
90 gr_vector_int &ninput_items_required);
91 int general_work (int noutput_items,
92 gr_vector_int &ninput_items,
93 gr_vector_const_void_star &input_items,
94 gr_vector_void_star &output_items);