This disclosure relates to the field of telecommunications and in particular to a retransmission protocol and coding scheme for multicast broadcast service(s).
A multicast broadcast service is a point-to-multipoint communications method whereby identical data packets are transmitted simultaneously to multiple receiver nodes. As may be appreciated, receiver nodes may encounter packet losses—for example—due to channel impairments. As a result, retransmission of affected packets is oftentimes required.
A characteristic of such a retransmission scheme when used with a multicast service is that since each receiver generally experiences a different quantity of packet loss(es), a large number of retransmissions are required for each and every receiver to recover all lost packets. As is known in the art, the number of retransmissions can be reduced significantly if a coding scheme is employed which generates the retransmitted packets by an encoding across information packets. Advantageously such schemes enable each receiver to recover packets destined for that receiver based upon the received packets.
For example, in a paper entitled “ON THE MINIMUM NUMBER OF TRANSMISSIONS IN SINGLE-HOP WIRELESS CODING NETWORKS”, which appeared in PROC. IEEE INFORM. THEORY WORKSHOP, at Lake Tahoe, Calif. on September 2007, pp. 120-125, S.Y EL REOUAYHEB, M. A. R. CHAUDHRY, and A. SPRINTSON described a fundamental problem associated with finding an optimal encoding of broadcasted packets to minimize the overall number of retransmissions. Notably, the authors assumed in that a transmitter knows the indices of lost packets for every receiver, which unfortunately requires a large overhead on the uplink feedback channel. In “NETWORK CODING-BASED RETRANSMISSION SCHEMES FOR E-MBS WITH AND WITHOUT MS FEEDBACK”, which appeared in IEEE C802.16.m-090072r1, made available at URL http://wirelessman.org/tgmcontrib/C80216m-09.0072r1.ppt, H. XU, S. XU, N. ARULSELVAN, and S. KALYANASUNDARAM describe several network coding-based retransmission schemes for a broadcast service without requiring feedback from receive nodes.
Notwithstanding these developments, an improved retransmission and coding scheme for multicast broadcast services would represent a significant advance in the art.
An advance is made in the art according to an aspect of the present disclosure directed to a coding scheme and nested code structure for retransmissions in multicast broadcast service, where each packet is broadcast to multiple destination nodes within a certain area. According to an aspect of the present disclosure, an encoder operates across multiple broadcast packets thereby generating redundant packets such that lost packets may be recovered. And while different destination nodes encounter different amounts of packet loss, they are nevertheless able to recover lost packets that affect the particular destination node(s), as a result of the broadcast redundant packets sent during normal retransmission slots.
A more complete understanding of the disclosure may be realized by reference to the accompanying drawing in which:
The following merely illustrates the principles of the various embodiments. It will thus be appreciated that those skilled in the art will be able to devise various arrangements which, although not explicitly described or shown herein, embody the principles of the embodiments and are included within their spirit and scope.
Furthermore, all examples and conditional language recited herein are principally intended expressly to be only for pedagogical purposes to aid the reader in understanding the principles of the embodiments and the concepts contributed by the inventor(s) to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions.
Moreover, all statements herein reciting principles, aspects, and embodiments of the invention, as well as specific examples thereof, are intended to encompass both structural and functional equivalents thereof. Additionally, it is intended that such equivalents include both currently known equivalents as well as equivalents developed in the future, i.e., any elements developed that perform the same function, regardless of structure.
Thus, for example, it will be appreciated by those skilled in the art that the block diagrams herein represent conceptual views of illustrative circuitry embodying the principles of the invention. Similarly, it will be appreciated that any flow charts, flow diagrams, state transition diagrams, pseudocode, and the like represent various processes which may be substantially represented in computer readable medium and so executed by a computer or processor, whether or not such computer or processor is explicitly shown.
The functions of the various elements shown in the FIGs., including functional blocks labeled as “processors” may be provided through the use of dedicated hardware as well as hardware capable of executing software in association with appropriate software. When provided by a processor, the functions may be provided by a single dedicated processor, by a single shared processor, or by a plurality of individual processors, some of which may be shared. Moreover, explicit use of the term “processor” or “controller” should not be construed to refer exclusively to hardware capable of executing software, and may implicitly include, without limitation, digital signal processor (DSP) hardware, read-only memory (ROM) for storing software, random access memory (RAM), and non-volatile storage. Other hardware, conventional and/or custom, may also be included. Similarly, any switches shown in the FIGs. are conceptual only. Their function may be carried out through the operation of program logic, through dedicated logic, through the interaction of program control and dedicated logic, or even manually, the particular technique being selectable by the implementor as more specifically understood from the context.
In the claims hereof any element expressed as a means for performing a specified function is intended to encompass any way of performing that function including, for example, a) a combination of circuit elements which performs that function or b) software in any form, including, therefore, firmware, microcode or the like, combined with appropriate circuitry for executing that software to perform the function. The invention as defined by such claims resides in the fact that the functionalities provided by the various recited means are combined and brought together in the manner which the claims call for. Applicants thus regard any means which can provide those functionalities as equivalent as those shown herein.
Unless otherwise explicitly specified herein, the drawings are not drawn to scale.
By way of some additional background, we consider a wireless network comprising one server transmitter and K receiver nodes or mobile users that receive a broadcast service transmitted by the server. As shown in
We denote Uk as a set of lost packets for the kth receiver. For example, as shown in
If however, lost packets are known to the transmitter, we can retransmit the data packet which is binary coded from the original data packets {Pi}. For example, we obtain R1 by binary XORing the lost four packets, given by
R1=P1⊕P3⊕P4⊕P5 (1)
where ⊕ denotes the binary addition of every bit in the packet. With the retransmitted packet R1, each receiver node can recover a lost packet since the remaining three packets are received at this receiver node. Therefore, only one retransmission is required.
However, this retransmission coding scheme assumes that the set of lost packets Uk, k=1, . . . , K are known to the transmitting server. As may be appreciated, such informational knowledge incurs a large overhead on the uplink feedback channel. To fully eliminate the uplink feedback channel the following coding schemes were described by H. XU et al.
More particularly, a basic coding scheme that does not employ any feedback of lost packets is described as follows. The server first transmits L data packets. After the L packets are transmitted, there is a retransmission interval of Q packet-slots where Q<L. Based on the permuted order of original L data packets, resulting in the order of P1, . . . , PL, the retransmission packet Ri, i=1, . . . , Q, is obtained by
If one receiver node received
packets among
it can then recover the single lost packet by receiving Ri even if each receiver node has a different single lost packet from one another. Since the above coding scheme is fixed for the original transmitted L packets and it does not depend on the lost packet sets {Uk}, no feedback is required.
Two variations of the above basic coding scheme are also described by H. XU et al. namely, 1) a Truncated Sequence scheme and 2) a Random Linear Code scheme.
1. Truncated Sequence: In this scheme, d packets are dropped from the original L packets. With permuted packet sequence of the rest L-d packets, the above basic scheme is employed to obtain the retransmission sequence R1, . . . , RQ by encoding
packets at a time.
2. Random Linear Code: In this scheme, a linear combination (binary XOR) of L/Q packets that are randomly selected from the original L packets are sent over the broadcast channel for each retransmission. The receiver node may wait until all retransmissions are completed before starting to decode.
As we now know however, the above coding schemes do not perform particularly well with respect to packet recovery. Advantageously—and according to the present disclosure—a different low-complexity coding scheme is employed for retransmissions in the broadcast service without incurring much overhead.
More particularly, given L original data packets, we encode them according to the present disclosure to obtain M retransmission packets as follows. First, the original L data packets are grouped into 2M sets, i.e., Ω0, . . . , Ω2
Rm=Σ⊕P
where Σ⊕ denotes binary summation and jbin (m) denotes the mth bit of binary representation of j. Stated alternatively, Rm is obtained by binary XORing the data packet Pi if PiεΩj and the mth bit of binary representation of j is one. Packets in Ω0 are not encoded to any retransmission packet. Therefore, they are dropped for the retransmission.
As may be appreciated, a linear block code may be represented by a bipartite graph comprising two types of nodes —variable nodes representing code bits and check nodes representing parity check constraints. One example of a code graph representation for the above coding scheme is illustrated in
To recover lost packets, we consider the iterative message-passing decoding algorithm on the code graph similarly as the low-density parity-check (LDPC) decoder. As may be appreciated, such a scheme is a more general coding scheme. Since the encoding rules are based on the node sets {Ωj}, we need to design the code structure, i.e., to design the variable node sets {Ωj} to achieve good performance.
Code Design
With M redundant packets, the overall number of packets is N=L+M. We assume that when a number of erasures i>M, none of lost packet can be recovered. If all L packets are encoded to M redundant packet, i.e., Ω0=Ø, given the packet loss rate p, the packet error rate after decoding is given by the following relationship:
where E denotes a particular decoding error event, Pr(E|i) is then the probability of a particular decoding error event conditioned on the number of lost packets i, and na(E) denotes the number of unrecovered packets for that decoding error event. The probability of losing n packets, Pi(N), is given by the following relationship:
In contrast to the prior art techniques, we consider a more general case by assuming n−M (n≦N) packets among L packets are encoded to M redundant packets for retransmissions. Therefore, we have |Ω0|=N−n. The packet error rate is then given by the following relationship:
Before we consider the design of the code structure however, we first investigate the effect of Ω0.
Effect of Ω0
To fully understand the effect of Ω0—or more precisely—the size of Ω0, we assume that the ideal erasure code, i.e., maximum distance separable (MDS) code, is employed so that when the number of lost packets i≦M, all lost packets can be recovered. The packet error rate is then given by
Therefore the optimal n can be obtained by minimizing pb, given by
With the continuous relaxation of an integer optimization, we then obtain
n*|M=min{round(x*),N}, (9)
where x* is one of real and positive solutions of f′(x)=0 that maximizes f(x) and f′(x) is the derivative of f(x), given by
For small M, we can obtain the n*|M analytically. For example, when M=1, we have
We can then optimize n that minimizes pb, given by
With the continuous relaxation of an integer optimization, we then obtain
We can see from (13) that when
there should be some nodes in Ω0 which are not used for generating the redundant packets.
For M=2, under assumption of MDS code, we have
Similarly, we optimize n to obtain
With the continuous relaxation of the integer n, we obtain n*|M=2 given by (9) and x* is one of the real and positive solutions of
p log(1−p)x2+(2p+(1−2p)log(1−p))x+1−2p=0 (16)
And similarly, we can obtain the optimal n for M=3 given by (9), where x* is one of the real and positive solutions of
where
For M≧4, we can obtain the solutions of f′(x)=0 numerically.
Iterative Code Design Method
From the definition of code graph {Ωj}, we can see that the design of short codes can only be considered with a small M since the number of sets {Ωj} increases exponentially as M increases, which causes difficulty on the code design. We can see that the code structure is defined by the code graph. However, particular nodes or packets in the set Ωj are not important. Therefore, to design the code, we only need to find the size of Ωj and then group the nodes into these disjoint sets. Denote lj=|Ωj|. Therefore, we only need to design the set LM{l0, . . . , lj}. Based on the graph representation shown in
Ω′j=Ωj∪{Ri}, for j=2i−1,
Ω′j=Ωj, otherwise. (18)
If we let l′j=|Ω′j|, the code design then becomes the design of the set L′M={l′0, . . . , l′2
More particularly, for M=1, there is only two sets Ω′0 and Ω′1. We perform single parity-check (SPC) to all nodes in Ω′1 and retransmit it. The only thing we need to decide is how many nodes to put in Ω′1. Since the SPC code is a trivial MDS code, the packet error rate is the same as Pb|M−1 given in (11). Therefore, we have
For M=2, n−2 data packets are encoded to obtain 2 retransmission packets. The optimized code is
with Σj=13l′j=n. Based on the residue graph, the packet error rate is then given by
Therefore l′0=n*=round(x*), where x* is the solution of
For M=3, 4, 5, we first obtain all possible residue graphs for every error event and the corresponding probability Pr(E|i), as well as the number of residual graphs corresponding to the particular number of unrecoverable errors na. We then evaluate the performance Pb|M given in (6) for a given code graph L′M.
To design the code graph L′M for M=3, 4, 5, we apply the following iterative algorithm to consider the case of Ω0.
With L′* we then obtain L* by letting l2
Nested Code Structure
As previously discussed, the designed code with M redundant nodes provides M retransmissions. Since we can only design for a small M, for general cases with more than M transmissions, we can simply concatenate it with any other codes to generate more redundant packets for retransmission, or preferably employ a nested code structure as follows.
When we design the code to obtain M redundant packets, we do not fix the order of the packet sequence P1, . . . , PL. We can randomly group the nodes based on the design results L*. To obtain the redundant packets with nested code structure, we have to fix the order of the packet sequence first.
Without a loss of generality, we assume that the order packet sequence is P1, . . . , PL. Based on the designed graph L*M={l0, . . . l2M−1}, we first group L packets by
and then encode them to generate M redundant packets based on {Ωj}. To generate additional M redundant packets, we first cyclically shift the ordered packet sequence P1, . . . , PL by T times and obtain packet sequence P1(1), . , PL(1) with Pi(1)=Pi+T modL. We then perform the grouping based on the shifted packet sequence Pi(1) and encode them in the same way.
As shown in
As may be appreciated, a simple choice is letting T=1. However, since usually the number of retransmissions QLM and it is preferable to allow the nodes in ga0 to be protected by some redundant packets soon, we choose a large T. We can also choose different cyclic shift parameters for every shift stage, i.e., Ti for the ith stage of cyclic shifts. Moreover, a high rate precoder may be included to improve the performance, e.g., P1, . . . , PL are first encoded to P′1, . . . , P′1, . . . , P′L+Δ
Another variation is that in each stage of nested encoding, we can encode the original packets and the redundant packets that are already generated together, i.e., at the qth stage, we can encode the packets P1, . . . , PL, and R1, . . . , R(q−1)M together with designed codes of different lengths. Another improvement can be done by adding an interleaver for each stage—meaning that the order is changed at each coding stage. The interleaver may only cover the packets for the encoders, i.e., Pi in any set except Ω0.
Numerical Results
For the designed codes, the error rate thresholds p* are 0.0129, 0.0202, 0.0259, and 0.0302 for M=2, 3, 4, and 5, respectively. We find that within a large range of p, the resulting x* (p) is close to a linear function in the log domain. Therefore, we can apply the linear approximation (LA) to ln x* (or ln n*) with respect to ln p, i.e., ln x*=a ln p+b, where a, b are the LA parameters.
The results of (a, b) for the designed codes with various M are listed in Table 1. The performance of LA is shown in
With above method, we obtain so-called quasi-regular codes since the values of lj, j=1, . . . , 2M−1 are almost the same.
We now evaluate the packet recovery performance using the nested coding structure with designed code for the multicast broadcast service. We consider that one server services 10 users, i.e., there are K=10 receive nodes. The number of packets before retransmissions is L=100 and the number of retransmissions varies from Q=1 to 25. The packet loss rate is 0.05.
We can see from
As is now apparent to those skilled in the art, we have presented—according to the present disclosure a coding scheme and nested code structure for the retransmissions in multicast broadcast service.
A flow diagram showing the generation of packet Ri, i=1, . . . M for retransmissions in multicast broadcast service according to the present disclosure is presented in
According to the present disclosure, given L original data packets, P1, . . . , PL, we encode them to obtain M retransmission packets as follows. At Step 101, we group the original L data packets into 2M sets, i.e., Ω0, . . . . , Ω2M−1. At step 102, starting from the first retransmission i=1, we then at step 103 generate packet Ri for the ith retransmission by binary XORing the packets from the selected sets among the 2M sets. The encoding and selection rules are given by
Rm=Σ⊕P
where Σ⊕ denotes binary summation and jbin(m) denotes the mth bit of binary representation of j. Stated alternatively, Rm is obtained by binary XORing the data packet Pi if PiεΩj and the mth bit of binary representation of j is one. Packets in Ω0 are not encoded to any retransmission packet. Therefore, they are dropped for the retransmission. Finally, at step 104, we transmit packet Ri. One example of a graphical representation of encoding is shown in
The code design obtains the optimal the grouping for the sets Ω0, . . . , Ω2M−1 for a given packet loss rate p. The code design follows the following procedures to minimize error rate, given by:
For those situations where there are more than M retransmissions, a nested coding structure as depicted in
In so doing, we assume that the order packet sequence is P1, . . . , PL. Based on the designed graph M={l0 . . . l2M−1}, we first group L packets by
and then encode them to generate M redundant packets based on {Ωj}. To generate additional M redundant packets, we first cyclically shift the ordered packet sequence P1, . . . , PL by T times and obtain packet sequence P1(1), PL(1) with Pi(1)=Pi+T mod L.
We then perform the grouping based on the shifted packet sequence P1(1), . . . , PL(1) and encode them in the same way based on {Ωj}. As shown in
A flow diagram depicting nested encoding based on the cyclic shifts is shown in
At this point, while we have discussed and described the invention using some specific examples, those skilled in the art will recognize that our teachings are not so limited. Accordingly, the invention should be only limited by the scope of the claims attached hereto.
This application claims the benefit of U.S. Provisional Patent Application No. 61/237,820 filed Aug. 28, 2009 which is incorporated by reference as if set forth at length herein.
Number | Name | Date | Kind |
---|---|---|---|
7778978 | Chindapol et al. | Aug 2010 | B2 |
7940712 | Larsson | May 2011 | B2 |
7941724 | Chindapol et al. | May 2011 | B2 |
8024633 | Hafeez et al. | Sep 2011 | B2 |
20020144209 | Ariel et al. | Oct 2002 | A1 |
20020146074 | Ariel et al. | Oct 2002 | A1 |
20020157058 | Ariel et al. | Oct 2002 | A1 |
20070253423 | Chindapol et al. | Nov 2007 | A1 |
20080282125 | Hafeez et al. | Nov 2008 | A1 |
20080294959 | Chindapol et al. | Nov 2008 | A1 |
20090177954 | Takahashi et al. | Jul 2009 | A1 |
20090307559 | Wu et al. | Dec 2009 | A1 |
20100061287 | Josiam et al. | Mar 2010 | A1 |
20100128650 | Morimoto et al. | May 2010 | A1 |
20100290383 | Wu et al. | Nov 2010 | A1 |
Number | Date | Country | |
---|---|---|---|
20110064015 A1 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
61237820 | Aug 2009 | US |