-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMain.java
More file actions
127 lines (107 loc) · 5.01 KB
/
Main.java
File metadata and controls
127 lines (107 loc) · 5.01 KB
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
import com.sun.xml.internal.ws.util.StringUtils;
import java.util.*;
public class Main {
ArrayList<String> cosetLeaders = new ArrayList<>(); // stores all the coset leaders
TreeMap<String, String> syndromeMap = new TreeMap<>(); // stores the syndrome map
// parity check matrix
int[][] pcMatrix =
{
{1, 1, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0},
{1, 1, 1, 1, 0, 1, 0, 1, 0, 0, 0, 0},
{1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0},
{0, 1, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0},
{0, 0, 1, 0, 1, 1, 0, 0, 0, 0, 1, 0},
{0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 1}
};
public static void main(String[] args) {
Main main = new Main();
// find the syndrome table
main.generateCosetLeaders(12);
main.calcSyndrome();
// execute syndrome decoding for the given values
main.syndromeDecode("111111111111");
main.syndromeDecode("000011100000");
main.syndromeDecode("001100110000");
}
private void generateCosetLeaders(int pow) {
int total = (int) Math.pow(2, pow);
for (int i = 0; i < total; i++) { // generates all the coset leaders from 1 to the given power 12
String result = Integer.toBinaryString(i);
String resultFormatted = String.format("%12s", result).replaceAll(" ", "0");
cosetLeaders.add(resultFormatted);
}
}
private void calcSyndrome() {
int weight = 0;
ArrayList<String> syndromeList = new ArrayList<>();
// iterate for all 12 weights
for (int i = 0; i <= 12; i++) {
ArrayList<String> filteredCosetLeaders = new ArrayList<>();
// filter coset leaders starting weight 0
for (String bnry : cosetLeaders) {
if (bnry.chars().filter(ch -> ch == '1').count() == weight) {
filteredCosetLeaders.add(bnry);
}
}
// iterate for each coset leader in the filtered list
for (String cosetLeader : filteredCosetLeaders) {
StringBuilder syndrome = new StringBuilder(" ");
// take each vector in pc matrix
for (int[] matrix : pcMatrix) {
int vectorMultSum = 0;
// multiply bits of the vector with the bits in current coset leader in order
for (int k = 0; k < matrix.length; k++) {
char chr = cosetLeader.charAt(k);
vectorMultSum += matrix[k] * Integer.parseInt(String.valueOf(chr));
}
syndrome.append(String.valueOf(vectorMultSum % 2));
}
// save the calculated syndrome with coset leader if the syndrome does not exist
if (!syndromeList.contains(syndrome.toString())) {
syndromeList.add(syndrome.toString());
syndromeMap.put(cosetLeader, String.valueOf(syndrome));
}
}
weight++;
}
// print syndrome table
System.out.println(" Coset Leader | Syndrome ");
System.out.println("---------------------------");
for (Map.Entry<String, String> entry : syndromeMap.entrySet()) {
System.out.println(" " + entry.getKey() + " | " + entry.getValue());
}
System.out.println("Table size: " + syndromeMap.size());
}
private void syndromeDecode(String received) {
StringBuilder syn = new StringBuilder(" ");
String cosetLeaderE = "";
StringBuilder decodedResult = new StringBuilder(" ");
// find the syn of received vector
for (int[] matrix : pcMatrix) {
int vectorMultSum = 0;
// multiply bits of the vector with the bits in received word in order
for (int k = 0; k < matrix.length; k++) {
char chr = received.charAt(k);
vectorMultSum += matrix[k] * Integer.parseInt(String.valueOf(chr));
}
syn.append(String.valueOf(vectorMultSum % 2));
}
// find the matching coset leader 'e' from syndrome table map
for(Map.Entry<String, String> entry: syndromeMap.entrySet()) {
if(Objects.equals(entry.getValue(), String.valueOf(syn))) {
cosetLeaderE = entry.getKey();
break;
}
}
//find the decoding result by subtracting coset leader from received word
for (int i = 0; i < cosetLeaderE.length(); i++) {
int y = Integer.parseInt(String.valueOf(received.charAt(i)));
int e = Integer.parseInt(String.valueOf(cosetLeaderE.charAt(i)));
decodedResult.append(String.valueOf(Math.abs(y - e)));
}
// print the decoding result summary
System.out.println();
System.out.println("Y = " + received + " | E = " + cosetLeaderE + " | Syndrome = " + syn);
System.out.println("Decoded " + received + " = " + decodedResult);
}
}