forked from hqm/rscode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample.c
173 lines (143 loc) · 4.81 KB
/
example.c
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
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
/* Example use of Reed-Solomon library
*
* (C) Universal Access Inc. 1996
*
* This same code demonstrates the use of the encodier and
* decoder/error-correction routines.
*
* We are assuming we have at least four bytes of parity (NPAR >= 4).
*
* This gives us the ability to correct up to two errors, or
* four erasures.
*
* In general, with E errors, and K erasures, you will need
* 2E + K bytes of parity to be able to correct the codeword
* back to recover the original message data.
*
* You could say that each error 'consumes' two bytes of the parity,
* whereas each erasure 'consumes' one byte.
*
* Thus, as demonstrated below, we can inject one error (location unknown)
* and two erasures (with their locations specified) and the
* error-correction routine will be able to correct the codeword
* back to the original message.
* */
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <stdlib.h>
#include "ecc.h"
unsigned char msg[] = {0x00, 0x01, 0x02, 0x03, 0x04,
0x05, 0x06, 0x07, 0x08, 0x09,
0x0A, 0x0B, 0x0C, 0x0D, 0x0E,
0x0F, 0x10, 0x11, 0x12, 0x13,
0x14, 0x15, 0x16, 0x17, 0x18,
0x19, 0x1A, 0x1B};
unsigned char codeword[256];
/* Some debugging routines to introduce errors or erasures
into a codeword.
*/
/* Introduce a byte error at LOC */
void
byte_err (int err, int loc, unsigned char *dst)
{
printf("Adding Error at loc %d, data %#x\n", loc, dst[loc-1]);
dst[loc-1] ^= err;
}
/* Pass in location of error (first byte position is
labeled starting at 1, not 0), and the codeword.
*/
void
byte_erasure (int loc, unsigned char dst[], int cwsize, int erasures[])
{
printf("Erasure at loc %d, data %#x\n", loc, dst[loc-1]);
dst[loc-1] = 0;
}
void
print_word (int n, unsigned char *data) {
int i;
for (i=0; i < n; i++) {
printf ("%02X ", data[i]);
}
printf("\n");
}
int
main (int argc, char *argv[])
{
int erasures[16];
int nerasures = 0;
/* Initialization the ECC library */
initialize_ecc ();
/* ************** */
#define ML (sizeof (msg) + NPAR)
/* Add one error and two erasures */
/* We need to indicate the position of the erasures. Eraseure
positions are indexed (1 based) from the end of the message... */
/*
erasures[nerasures++] = ML-17;
erasures[nerasures++] = ML-19;
*/
/* Now decode -- encoded codeword size must be passed */
decode_data(codeword, ML);
srand(time(NULL)); // Initialization, should only be called once.
int fails = 0;
for (int i = 0; i < 10; i++) {
int j;
// make random msg data
for (j=0; j<sizeof(msg); j++) {
msg[j] = rand() % 256;
}
printf("msg =");
print_word(28, msg);
encode_data(msg, sizeof(msg), codeword);
printf("encoded data:\n");
print_word(ML, codeword);
// add two random errors to codeword
unsigned char r = rand() % 256;
int rloc = rand() % ML;
codeword[rloc] = r;
unsigned char r2 = rand() % 256;
int rloc2 = rand() % ML;
codeword[rloc2] = r2;
printf("encoded data with two errors: %d @ loc %d, %d @ loc %d\n", r, rloc, r2, rloc2);
print_word(ML, codeword);
/* Now decode -- encoded codeword size must be passed */
decode_data(codeword, ML);
{
int syndrome = check_syndrome ();
printf("syndrome = %d\n",syndrome);
/* check if syndrome is all zeros */
if (syndrome == 0) {
// no errs detected, codeword payload should match message
for (int k=0; k < sizeof(msg); k++) {
if (msg[k] != codeword[k]) {
printf("#### FAILURE TO DETECT ERROR @ %d: %d != %d\n", k, msg[k], codeword[k]);
fails++;
}
}
} else {
printf("nonzero syndrome, attempting correcting errors\n");
int result = 0;
result =correct_errors_erasures (codeword,
ML,
nerasures,
erasures);
printf("correct_errors_erasures = %d\n", result);
print_word(28, codeword);
int k;
for (k=0; k < sizeof(msg); k++) {
if (msg[k] != codeword[k]) {
printf("##### FAILURE TO CORRECT ERROR @ %d: %d != %d\n", k, msg[k], codeword[k]);
fails++;
}
}
}
}
}
if (fails == 0) {
printf("\n\n All Tests Passed: No failures to correct codeword\n");
} else {
printf("### ERROR Algorithm failed to correct codeword %d times!!!\n", fails);
}
exit(0);
}