summaryrefslogtreecommitdiff
path: root/gr-dtv/lib/atsc/atsc_basic_trellis_encoder.cc
blob: 477a994d0d06dc48efa3244ed5db40cb844f1dbb (plain)
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
/* -*- c++ -*- */
/*
 * Copyright 2015 Free Software Foundation, Inc.
 *
 * SPDX-License-Identifier: GPL-3.0-or-later
 *
 */

#include "atsc_basic_trellis_encoder.h"
#include <cassert>

namespace gr {
namespace dtv {

const unsigned char atsc_basic_trellis_encoder::next_state[32] = {
    0, 1, 4, 5, 2, 3, 6, 7, 1, 0, 5, 4, 3, 2, 7, 6,
    4, 5, 0, 1, 6, 7, 2, 3, 5, 4, 1, 0, 7, 6, 3, 2
};

const unsigned char atsc_basic_trellis_encoder::out_symbol[32] = {
    0, 2, 4, 6, 1, 3, 5, 7, 0, 2, 4, 6, 1, 3, 5, 7,
    4, 6, 0, 2, 5, 7, 1, 3, 4, 6, 0, 2, 5, 7, 1, 3
};

/*!
 * Encode two bit INPUT into 3 bit return value. Domain is [0,3],
 * Range is [0,7]. The mapping to bipolar levels is not done.
 */

int atsc_basic_trellis_encoder::encode(unsigned int input)
{
    assert(input < 4);
    int index = (state << 2) + input;
    state = next_state[index];
    return out_symbol[index];
}

} /* namespace dtv */
} /* namespace gr */