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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
|
/* -*- c++ -*- */
/*
* Copyright 2002 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 2, 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.
*/
#include <atsci_equalizer_nop.h>
#include <atsci_sync_tag.h>
#include <assert.h>
atsci_equalizer_nop::atsci_equalizer_nop ()
{
}
atsci_equalizer_nop::~atsci_equalizer_nop ()
{
}
void
atsci_equalizer_nop::reset ()
{
atsci_equalizer::reset (); // invoke superclass
}
int
atsci_equalizer_nop::ntaps () const
{
return 1;
}
int
atsci_equalizer_nop::npretaps () const
{
return 0;
}
/*!
* Input range is known NOT TO CONTAIN data segment syncs
* or field syncs. This should be the fast path. In the
* non decicion directed case, this just runs the input
* through the filter without adapting it.
*
* \p input_samples has (nsamples + ntaps() - 1) valid entries.
* input_samples[0] .. input_samples[nsamples - 1 + ntaps() - 1] may be
* referenced to compute the output values.
*/
void
atsci_equalizer_nop::filter_normal (const float *input_samples,
float *output_samples,
int nsamples)
{
for (int i = 0; i < nsamples; i++){
output_samples[i] = scale (input_samples[i]);
}
}
/*!
* Input range is known to consist of only a data segment sync or a
* portion of a data segment sync. \p nsamples will be in [1,4].
* \p offset will be in [0,3]. \p offset is the offset of the input
* from the beginning of the data segment sync pattern.
*
* \p input_samples has (nsamples + ntaps() - 1) valid entries.
* input_samples[0] .. input_samples[nsamples - 1 + ntaps() - 1] may be
* referenced to compute the output values.
*/
void
atsci_equalizer_nop::filter_data_seg_sync (const float *input_samples,
float *output_samples,
int nsamples,
int offset)
{
for (int i = 0; i < nsamples; i++){
output_samples[i] = scale_and_train (input_samples[i]);
}
}
/*!
* Input range is known to consist of only a field sync segment or a
* portion of a field sync segment. \p nsamples will be in [1,832].
* \p offset will be in [0,831]. \p offset is the offset of the input
* from the beginning of the data segment sync pattern. We consider the
* 4 symbols of the immediately preceding data segment sync to be the
* first symbols of the field sync segment. \p which_field is in [0,1]
* and specifies which field (duh).
*
* \p input_samples has (nsamples + ntaps() - 1) valid entries.
* input_samples[0] .. input_samples[nsamples - 1 + ntaps() - 1] may be
* referenced to compute the output values.
*/
void
atsci_equalizer_nop::filter_field_sync (const float *input_samples,
float *output_samples,
int nsamples,
int offset,
int which_field)
{
int i = 0;
if (offset == 0 && nsamples > 0){
output_samples[0] = scale_and_train (input_samples[0]);
i++;
}
for (; i < nsamples; i++){
output_samples[i] = scale_and_train (input_samples[i]);
}
}
float
atsci_equalizer_nop::scale_and_train (float input)
{
return input;
}
|