GNU Radio's SATNOGS Package
ber_calculator_impl.h
Go to the documentation of this file.
1/* -*- c++ -*- */
2/*
3 * gr-satnogs: SatNOGS GNU Radio Out-Of-Tree Module
4 *
5 * Copyright (C) 2020,2022 Libre Space Foundation <http://libre.space/>
6 *
7 * This program 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 of the License, or
10 * (at your option) any later version.
11 *
12 * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#ifndef LIB_BER_CALCULATOR_IMPL_H_
22#define LIB_BER_CALCULATOR_IMPL_H_
23
25#include <cstdint>
26
27namespace gr {
28namespace satnogs {
29
31{
32public:
33 ber_calculator_impl(size_t frame_size = 64,
34 size_t nframes = 0,
35 size_t skip = 10,
36 size_t skip_end = 0);
37
39
40 /*int general_work(int noutput_items,
41 gr_vector_int& ninput_items,
42 gr_vector_const_void_star& input_items,
43 gr_vector_void_star& output_items) override;
44 */
45 bool stop() override;
46
47private:
48 const size_t m_frame_size;
49 const size_t m_nframes;
50 const size_t m_skip;
51 uint64_t m_cnt;
52 uint64_t m_inval_cnt;
53 uint64_t m_last_ack;
54 uint64_t m_dropped;
55 uint64_t m_received;
56 uint64_t m_last_valid;
57
58 void create_pdu(pmt::pmt_t msg);
59
60 void received_pdu(pmt::pmt_t msg);
61
62 double fer();
63
64 double ber();
65
66 void print_stats();
67};
68
69} /* namespace satnogs */
70} /* namespace gr */
71
72#endif /* LIB_BER_CALCULATOR_IMPL_H_ */
Definition: ber_calculator_impl.h:31
ber_calculator_impl(size_t frame_size=64, size_t nframes=0, size_t skip=10, size_t skip_end=0)
A block that calculates the BER of a packet passed system using the FER (Frame Error Rate)
Definition: ber_calculator.h:38
Definition: amsat_duv_decoder.h:29