GNU Radio 3.7.1-52 C++ API
additive_scrambler_bb.h
Go to the documentation of this file.
1
/* -*- c++ -*- */
2
/*
3
* Copyright 2008,2010,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
#ifndef INCLUDED_DIGITAL_ADDITIVE_SCRAMBLER_BB_H
24
#define INCLUDED_DIGITAL_ADDITIVE_SCRAMBLER_BB_H
25
26
#include <
gnuradio/digital/api.h
>
27
#include <
gnuradio/sync_block.h
>
28
29
namespace
gr {
30
namespace
digital {
31
32
/*!
33
* \ingroup coding_blk
34
*
35
* \brief
36
* Scramble an input stream using an LFSR.
37
*
38
* \details
39
* This block works on the LSB only of the input data stream,
40
* i.e., on an "unpacked binary" stream, and produces the same
41
* format on its output.
42
*
43
* The scrambler works by XORing the incoming bit stream by the
44
* output of the LFSR. Optionally, after 'count' bits have been
45
* processed, the shift register is reset to the seed value.
46
* This allows processing fixed length vectors of samples.
47
*/
48
class
DIGITAL_API
additive_scrambler_bb
:
virtual
public
sync_block
49
{
50
public
:
51
// gr::digital::additive_scrambler_bb::sptr
52
typedef
boost::shared_ptr<additive_scrambler_bb>
sptr
;
53
54
/*!
55
* \brief Create additive scrambler.
56
*
57
* \param mask Polynomial mask for LFSR
58
* \param seed Initial shift register contents
59
* \param len Shift register length
60
* \param count Number of bits after which shift register is reset, 0=never
61
*
62
*/
63
static
sptr
make(
int
mask,
int
seed,
int
len,
int
count=0);
64
65
virtual
int
mask()
const
= 0;
66
virtual
int
seed()
const
= 0;
67
virtual
int
len()
const
= 0;
68
virtual
int
count()
const
= 0;
69
};
70
71
}
/* namespace digital */
72
}
/* namespace gr */
73
74
#endif
/* INCLUDED_DIGITAL_ADDITIVE_SCRAMBLER_BB_H */
gnuradio
gr-digital
include
gnuradio
digital
additive_scrambler_bb.h
Generated by
1.8.1.1