GNU Radio's SATNOGS Package
reed_muller.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) 2021, 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 INCLUDED_SATNOGS_REED_MULLER_H
22#define INCLUDED_SATNOGS_REED_MULLER_H
23
25#include <array>
26#include <bitset>
27#include <cstdint>
28
29namespace gr {
30namespace satnogs {
31
32/*!
33 * \brief A binary Reed-Muller(1, 6) encoder and decoder.
34 *
35 */
37{
38public:
41
42 uint64_t encode(const uint8_t in);
43
44 uint8_t decode(const uint64_t in);
45
46private:
47 const size_t d_r;
48 const size_t d_m;
49 std::array<std::bitset<64>, 7> d_G;
50};
51
52} // namespace satnogs
53} // namespace gr
54
55#endif /* INCLUDED_SATNOGS_REED_MULLER_H */
#define SATNOGS_API
Definition: api.h:19
A binary Reed-Muller(1, 6) encoder and decoder.
Definition: reed_muller.h:37
uint64_t encode(const uint8_t in)
uint8_t decode(const uint64_t in)
Definition: amsat_duv_decoder.h:29