-
Notifications
You must be signed in to change notification settings - Fork 31
/
schifra_reed_solomon_example04.cpp
141 lines (115 loc) · 6.21 KB
/
schifra_reed_solomon_example04.cpp
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
134
135
136
137
138
139
140
141
/*
(**************************************************************************)
(* *)
(* Schifra *)
(* Reed-Solomon Error Correcting Code Library *)
(* *)
(* Release Version 0.0.1 *)
(* http://www.schifra.com *)
(* Copyright (c) 2000-2020 Arash Partow, All Rights Reserved. *)
(* *)
(* The Schifra Reed-Solomon error correcting code library and all its *)
(* components are supplied under the terms of the General Schifra License *)
(* agreement. The contents of the Schifra Reed-Solomon error correcting *)
(* code library and all its components may not be copied or disclosed *)
(* except in accordance with the terms of that agreement. *)
(* *)
(* URL: http://www.schifra.com/license.html *)
(* *)
(**************************************************************************)
*/
/*
Description: This example will demonstrate how to instantiate a 4-bit per
symbol Reed-Solomon encoder and decoder, add the full amount
of possible errors, correct the errors, and output the various
pieces of relevant information.
*/
#include <iostream>
#include <string>
#include "schifra_galois_field.hpp"
#include "schifra_galois_field_polynomial.hpp"
#include "schifra_sequential_root_generator_polynomial_creator.hpp"
#include "schifra_reed_solomon_encoder.hpp"
#include "schifra_reed_solomon_decoder.hpp"
#include "schifra_reed_solomon_block.hpp"
#include "schifra_error_processes.hpp"
#include "schifra_reed_solomon_bitio.hpp"
int main(void)
{
/* Finite Field Parameters */
const std::size_t field_descriptor = 4;
const std::size_t generator_polynomial_index = 0;
const std::size_t generator_polynomial_root_count = 7;
/* Reed Solomon Code Parameters */
const std::size_t code_length = 15; //(2^4 - 1)
const std::size_t fec_length = 7;
const std::size_t data_length = code_length - fec_length;
/* 10-bit Symbol Parameter */
const int mask = 0x0000000F;
/*
Note: One must make sure to be using primitive polynomials
of correct degree for generating elements in the specified
field ie: a primitive polynomial of degree 4 for GF(2^4).
*/
/* Instantiate Finite Field and Generator Polynomials */
const schifra::galois::field field(field_descriptor,
schifra::galois::primitive_polynomial_size01,
schifra::galois::primitive_polynomial01);
schifra::galois::field_polynomial generator_polynomial(field);
if (
!schifra::make_sequential_root_generator_polynomial(field,
generator_polynomial_index,
generator_polynomial_root_count,
generator_polynomial)
)
{
std::cout << "Error - Failed to create sequential root generator!" << std::endl;
return 1;
}
/* Instantiate Encoder and Decoder (Codec) */
typedef schifra::reed_solomon::encoder<code_length,fec_length> encoder_t;
typedef schifra::reed_solomon::decoder<code_length,fec_length> decoder_t;
const encoder_t encoder(field,generator_polynomial);
const decoder_t decoder(field,generator_polynomial_index);
/*
Note: The data length represents the number of code symbols that will be used.
The effective data length is then the number of code symbols multipled
by the number of bits per symbol, in this case it is 4-bits per code
symbol.
*/
std::string message(data_length >> 1,0x00);
for (std::size_t i = 0; i < message.size(); ++i) message[i] = static_cast<char>(0x33);
/* Instantiate RS Block For Codec */
schifra::reed_solomon::block<code_length,fec_length> block;
schifra::reed_solomon::block<code_length,fec_length> original_block;
/* Copy data from 1 Byte per element message block into 5-bit RS Block */
schifra::reed_solomon::bitio::convert_data_to_symbol<field_descriptor>(message.c_str(), message.size(), block.data);
schifra::reed_solomon::bitio::convert_data_to_symbol<field_descriptor>(message.c_str(), message.size(), original_block.data);
/* Transform message into Reed-Solomon encoded codeword */
if (!encoder.encode(block))
{
std::cout << "Error - Critical encoding failure! "
<< "Msg: " << block.error_as_string() << std::endl;
return 1;
}
/* Add errors at every 3rd location starting at position zero */
schifra::corrupt_message_all_errors_wth_mask(block, 0, mask, 3);
if (!decoder.decode(block))
{
std::cout << "Error - Critical decoding failure! "
<< "Msg: " << block.error_as_string() << std::endl;
return 1;
}
else if (!schifra::are_blocks_equivelent(block,original_block, data_length))
{
std::cout << "Error - Error correction failed!" << std::endl;
return 1;
}
std::cout << "Encoder Parameters [" << schifra::reed_solomon::encoder<code_length,fec_length>::trait::code_length << ","
<< schifra::reed_solomon::encoder<code_length,fec_length>::trait::data_length << ","
<< schifra::reed_solomon::encoder<code_length,fec_length>::trait::fec_length << "]" << std::endl;
std::cout << "Decoder Parameters [" << schifra::reed_solomon::decoder<code_length,fec_length>::trait::code_length << ","
<< schifra::reed_solomon::decoder<code_length,fec_length>::trait::data_length << ","
<< schifra::reed_solomon::decoder<code_length,fec_length>::trait::fec_length << "]" << std::endl;
return 0;
}