1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
/* -*- c++ -*- */
/*
* Copyright 2004-2006,2011 Free Software Foundation, Inc.
*
* This file is part of GNU Radio
*
* GNU Radio is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3, or (at your option)
* any later version.
*
* GNU Radio is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with GNU Radio; see the file COPYING. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street,
* Boston, MA 02110-1301, USA.
*/
#ifndef INCLUDED_DIGITAL_OFDM_CYCLIC_PREFIXER_H
#define INCLUDED_DIGITAL_OFDM_CYCLIC_PREFIXER_H
#include <digital_api.h>
#include <gr_tagged_stream_block.h>
class digital_ofdm_cyclic_prefixer;
typedef boost::shared_ptr<digital_ofdm_cyclic_prefixer> digital_ofdm_cyclic_prefixer_sptr;
/*!
* \param input_size FFT length (i.e. length of the OFDM symbols)
* \param output_size FFT length + cyclic prefix length (in samples)
* \param rolloff_len Length of the rolloff flank in samples
* \param len_tag_key For framed processing the key of the length tag
*/
DIGITAL_API digital_ofdm_cyclic_prefixer_sptr
digital_make_ofdm_cyclic_prefixer (size_t input_size,
size_t output_size,
int rolloff_len=0,
const std::string &len_tag_key="");
/*!
* \brief Adds a cyclic prefix and performs pulse shaping on OFDM symbols.
* \ingroup ofdm_blk
*
* Input: OFDM symbols (in the time domain, i.e. after the IFFT). Optionally,
* entire frames can be processed. In this case, \p len_tag_key must be
* specified which holds the key of the tag that denotes how
* many OFDM symbols are in a frame.
* Output: A stream of (scalar) complex symbols, which include the cyclic prefix
* and the pulse shaping.
* Note: If complete frames are processed, and \p rolloff_len is greater
* than zero, the final OFDM symbol is followed by the delay line of
* the pulse shaping.
*
* The pulse shape is a raised cosine in the time domain.
*/
class DIGITAL_API digital_ofdm_cyclic_prefixer : public gr_tagged_stream_block
{
friend DIGITAL_API digital_ofdm_cyclic_prefixer_sptr
digital_make_ofdm_cyclic_prefixer (size_t input_size, size_t output_size, int rolloff_len, const std::string &len_tag_key);
protected:
digital_ofdm_cyclic_prefixer (size_t input_size, size_t output_size, int rolloff_len, const std::string &len_tag_key);
//! Return the number of complex samples from the number of OFDM symbols (includes rolloff)
int calculate_output_stream_length(const gr_vector_int &ninput_items);
public:
int work(int noutput_items,
gr_vector_int &ninput_items,
gr_vector_const_void_star &input_items,
gr_vector_void_star &output_items);
private:
size_t d_fft_len;
//! FFT length + CP length in samples
size_t d_output_size;
//! Length of the cyclic prefix in samples
int d_cp_size;
//! Length of pulse rolloff in samples
int d_rolloff_len;
//! Buffers the up-flank (at the beginning of the cyclic prefix)
std::vector<float> d_up_flank;
//! Buffers the down-flank (which trails the symbol)
std::vector<float> d_down_flank;
std::vector<gr_complex> d_delay_line; // We do this explicitly to avoid outputting zeroes (i.e. no history!)
};
#endif /* INCLUDED_DIGITAL_OFDM_CYCLIC_PREFIXER_H */
|