51class beidou_b1i_telemetry_decoder_gs :
public telemetry_impl_interface
57 void reset()
override;
63 gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
override;
66 friend beidou_b1i_telemetry_decoder_gs_sptr beidou_b1i_make_telemetry_decoder_gs(
72 void decode_subframe(
float *symbols,
double cn0);
73 void decode_word(int32_t word_counter,
const float *enc_word_symbols, int32_t *dec_word_symbols);
74 void decode_bch15_11_01(
const int32_t *bits, std::array<int32_t, 15> &decbits);
77 std::array<int32_t, BEIDOU_DNAV_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
79 std::array<float, BEIDOU_DNAV_PREAMBLE_PERIOD_SYMBOLS> d_subframe_symbols{};
82 boost::circular_buffer<float> d_symbol_history;
85 Beidou_Dnav_Navigation_Message d_nav;
87 Nav_Message_Packet d_nav_msg_packet;
88 std::unique_ptr<Tlm_CRC_Stats> d_Tlm_CRC_Stats;
91 Gnss_Satellite d_satellite;
92 std::string d_dump_filename;
93 std::ofstream d_dump_file;
95 uint64_t d_sample_counter;
96 uint64_t d_preamble_index;
99 int32_t d_symbols_per_preamble;
100 int32_t d_samples_per_preamble;
101 int32_t d_preamble_period_samples;
102 int32_t d_CRC_error_counter;
103 uint32_t d_required_symbols;
107 uint64_t d_last_valid_preamble;
108 uint32_t d_symbol_duration_ms;
109 uint32_t d_TOW_at_Preamble_ms;
110 uint32_t d_TOW_at_current_symbol_ms;
113 bool d_flag_frame_sync;
114 bool d_flag_preamble;
116 bool d_flag_valid_word;
117 bool d_sent_tlm_failed_msg;
121 bool d_enable_navdata_monitor;
122 bool d_dump_crc_stats;
int general_work(int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items) override
This is where all signal processing takes place.