Erasure resilient MDS code with four redundant packets
Emin Gabrielyan
EPFL / Switzernet Sŕrl
2005-11-03
We are trying to build (11, 7), (10, 6) and (9, 5) MDS codes
Given are:
- 7, 6 or 5 information packets
- 4 redundant packets
- Packet sizes are identical and are divisible by 3, minimum 3 bits
- Information must be retrieved if number of losses does not exceed 4
We must check for which numbers of information packets we can build an MDS code.
Let (a,b,c) be a packet where a, b and c are its first, second and third portions.
Let f be a function which applied to a packet (a,b,c) forms another packet of the same size, whose first, second and third elements are XOR results of some subsets given from {a,b,c}. Example: f(x, y, z) = (x+y, z, x+z), where operation + is XOR.
We are interested in only invertible functions. There are 168 such functions producing 168 invertible packets. Each function can be represented by a binary 3 by 3 matrix.
Four redundant packets are constructed as follows
where k is the number of information packets, i.e. is equal to 7, 6 or 5.
f, g and h are vectors whose elements are from the list of 168 invertible functions
Restoring two information packets from (1, f), (1, g) and (1, h)
In case, two information packets i, j are lost
and we received the first and the second redundant packet (the other two are
also lost). Then if +
is
invertible for any pair of i and j we can restore
and
successively
. Similarly for the cases when
two information packets must be restored from the first and third (g-redundant)
packets or from the first and fourth (h-redundant) packets.
In the set of 168 invertible functions, there are 4032
subsets of the size of 5-functions, 1344 subsets of the size of 6-functions and
192 subsets of the size of 7-functions, for which the above condition ( + 1
is invertible) holds for any pair of the subset.
Restoring two information packets from (f, g)
Let us now examine valid combinations of f and g
vectors. For the sizes of 5, 6 and 7 functions there are 40324032
5!,
1344
1344
6! and 192
192
7! possible
pairs of f and g vectors. An (f, g) pair is valid
only if for any two i and j (the lost packets) the following
function:
+
is invertible
Restoring three information packets from (1, f, g)
Additionally, an (f, g)-pair is valid only if it can retrieve, together with the first redundant packet, any three lost information packets.
For that the following function must be invertible for any i, j and k:
(+1
(
+1) +
(
+1
(
+1)
Instead of examining all possible pairs of vectors
40324032
5! – for 5 information
packets (codeword length = 9)
13441344
6! – for 6 information
packets (codeword length = 10)
192192
7! – for 7 information
packets (codeword length = 11)
We fixed the f-vector on the first candidate
(11,73,140,167,198) – for 5 information packets
(11,73,140,167,198,292) – for 6
(11,73,140,167,198,292,323) – and for 7
Thus we limited our choice by the following number of pairs
40325! – for 5 information packets
13446! – for 6
1927! – and for 7
for 7 information packets we have found 1680 valid (f, g)-pairs
for 6 information packets we have found 1680 valid (f, g)-pairs as well
and for 5 information packets also we have found 1680 valid (f, g)-pairs
Thus (10, 7)-code exists, which is an MDS code.
Choosing h-redundant packet, restoring two information packets from (g, h) and three information packets from (1, g, h)
For any of 1680 valid (f, g)-pairs we must
examine a valid (f, h)-pair, thus there are 1680(1680–1)/2
possible (f, g, h) combinations to examine.
(g, h)-pair is valid only if:
+
is
invertible for any two i and j (the case when two information
packets must be retrieved from the g and h-redundant packets)
and if:
(+1
(
+1) +
(
+1
(
+1)
is also invertible for any three lost information packets i, j
and k (the case when three information packets must be retrieved from
the first redundant packets and from the g and h-redundant
packets).
there are 28224 valid (g, h)-pairs for 7 information packets
there are also 28224 valid (g, h)-pairs with 6 information packets
and there are 56448 valid (g, h)-pairs with 5 information packets
Restoring three information packets from (f, g, h) and four information packets from (1, f, g, h)
Three lost information packets can be retrieved from f, g and h-redundant packets if the following function is invertible
(+
(
+
) + (
+
(
+
)
for any three lost information packets i, j and k
Among 28224 (g, h)-pairs with 7 information packets and 28224 (g, h)-pairs with 6 information packets there were none, satisfying the above constraint, thus:
(11, 7) MDS code does not exist and
(10, 6) MDS code does not exist (at least with this method)
Additionally vector h is valid only if we can also restore
any four i, j, k and l lost information packets from
the four redundant packets. From the four redundant packets we can obtain these
three (by eliminating corposant)
(+1)
+
(+1)
+
(+1)
(+1)
+
(+1)
+
(+1)
(+1)
+
(+1)
+
(+1)
From them we can obtain these two by eliminating the composant:
((+1
(
+1) +
(
+1
(
+1))
+
((+1
(
+1) +
(
+1
(
+1))
((+1
(
+1) +
(
+1
(
+1))
((+1
(
+1) +
(
+1
(
+1))
From the above
two, we can eliminate and obtain the below function
applied to
. If this function is invertible
then we can retrieve
and consecutively all other
information packets.
( (+1
(
+1) +
(
+1
(
+1)
((+1
(
+1) +
(
+1
(
+1))
+
( (+1
(
+1) +
(
+1
(
+1)
((+1
(
+1) +
(
+1
(
+1))
Among 56448 (g, h)-pairs we have found 28224 valid (f, g, h)-triplets with 5 information packets.
Thus (9, 5) MDS code exists with four redundant packets
All valid (1, f, g, h) redundant packets are presented here.
AMPL programs:
Trying to find (11, 7)-code
- step 1
- step 2
- step 3
- step 4
- step 5 and conclusions
Trying to find (10, 6)-code
- step 1
- step 2
- step 3
- step 4
Finding (9, 5) MDS code
- step 1
- step 2
- step 3
- step 4
- step 5
* * *
© 2005, Switzernet (www.switzernet.com)
Relevant links: