00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025 #ifndef INCLUDED_TRELLIS_METRICS_F_H
00026 #define INCLUDED_TRELLIS_METRICS_F_H
00027
00028 #include <gr_block.h>
00029 #include "trellis_calc_metric.h"
00030
00031 class trellis_metrics_f;
00032 typedef boost::shared_ptr<trellis_metrics_f> trellis_metrics_f_sptr;
00033
00034 trellis_metrics_f_sptr trellis_make_metrics_f (int O, int D, const std::vector<float> &TABLE, trellis_metric_type_t TYPE);
00035
00036
00037
00038
00039
00040 class trellis_metrics_f : public gr_block
00041 {
00042 int d_O;
00043 int d_D;
00044 trellis_metric_type_t d_TYPE;
00045 std::vector<float> d_TABLE;
00046
00047 friend trellis_metrics_f_sptr trellis_make_metrics_f (int O, int D, const std::vector<float> &TABLE, trellis_metric_type_t TYPE);
00048 trellis_metrics_f (int O, int D, const std::vector<float> &TABLE, trellis_metric_type_t TYPE);
00049
00050 public:
00051 int O () const { return d_O; }
00052 int D () const { return d_D; }
00053 trellis_metric_type_t TYPE () const { return d_TYPE; }
00054 std::vector<float> TABLE () const { return d_TABLE; }
00055 void set_TABLE (const std::vector<float> &table);
00056 void forecast (int noutput_items,
00057 gr_vector_int &ninput_items_required);
00058 int general_work (int noutput_items,
00059 gr_vector_int &ninput_items,
00060 gr_vector_const_void_star &input_items,
00061 gr_vector_void_star &output_items);
00062 };
00063
00064
00065 #endif