GNU Radio Manual and C++ API Reference 3.7.14.0
The Free & Open Software Radio Ecosystem
viterbi_combined_fb.h
Go to the documentation of this file.
1/* -*- c++ -*- */
2/*
3 * Copyright 2004,2012 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// WARNING: this file is machine generated. Edits will be overwritten
24
25#ifndef INCLUDED_TRELLIS_VITERBI_COMBINED_FB_H
26#define INCLUDED_TRELLIS_VITERBI_COMBINED_FB_H
27
32#include <gnuradio/block.h>
33
34namespace gr {
35 namespace trellis {
36
37 /*!
38 * \ingroup trellis_coding_blk
39 */
40 class TRELLIS_API viterbi_combined_fb : virtual public block
41 {
42 public:
43 // gr::trellis::viterbi_combined_fb::sptr
44 typedef boost::shared_ptr<viterbi_combined_fb> sptr;
45
46 static sptr make(const fsm &FSM, int K,
47 int S0, int SK, int D,
48 const std::vector<float> &TABLE,
50
51 virtual fsm FSM() const = 0;
52 virtual int K() const = 0;
53 virtual int S0() const = 0;
54 virtual int SK() const = 0;
55 virtual int D() const = 0;
56 virtual std::vector<float> TABLE() const = 0;
58
59 virtual void set_FSM(const fsm &FSM) =0;
60 virtual void set_K(int K) =0;
61 virtual void set_S0(int S0) =0;
62 virtual void set_SK(int SK) =0;
63 virtual void set_D(int D) =0;
64 virtual void set_TABLE (const std::vector<float> &table) = 0;
66 };
67
68 } /* namespace trellis */
69} /* namespace gr */
70
71#endif /* INCLUDED_TRELLIS_VITERBI_COMBINED_FB_H */
The abstract base class for all 'terminal' processing blocks.
Definition: block.h:66
Finite State Machine Specification class.
Definition: fsm.h:44
Definition: viterbi_combined_fb.h:41
virtual std::vector< float > TABLE() const =0
virtual digital::trellis_metric_type_t TYPE() const =0
boost::shared_ptr< viterbi_combined_fb > sptr
Definition: viterbi_combined_fb.h:44
virtual int S0() const =0
virtual int K() const =0
virtual int SK() const =0
virtual void set_TABLE(const std::vector< float > &table)=0
virtual void set_FSM(const fsm &FSM)=0
virtual fsm FSM() const =0
virtual int D() const =0
virtual void set_TYPE(digital::trellis_metric_type_t type)=0
virtual void set_K(int K)=0
virtual void set_SK(int SK)=0
virtual void set_S0(int S0)=0
virtual void set_D(int D)=0
static sptr make(const fsm &FSM, int K, int S0, int SK, int D, const std::vector< float > &TABLE, digital::trellis_metric_type_t TYPE)
#define TRELLIS_API
Definition: gr-trellis/include/gnuradio/trellis/api.h:30
trellis_metric_type_t
Definition: metric_type.h:29
Include this header to use the message passing features.
Definition: basic_block.h:45