AU2001230642A1 - Automatic request protocol based packet transmission using punctured codes - Google Patents

Automatic request protocol based packet transmission using punctured codes

Info

Publication number
AU2001230642A1
AU2001230642A1 AU2001230642A AU3064201A AU2001230642A1 AU 2001230642 A1 AU2001230642 A1 AU 2001230642A1 AU 2001230642 A AU2001230642 A AU 2001230642A AU 3064201 A AU3064201 A AU 3064201A AU 2001230642 A1 AU2001230642 A1 AU 2001230642A1
Authority
AU
Australia
Prior art keywords
block
encoded
request
blocks
previous
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
AU2001230642A
Inventor
Alexander V Garmonov
Jia Ming
Andrew Yu Savinkov
Rui R Wang (deceased)
Alexander E Zhdanov
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nortel Networks Ltd
Original Assignee
Nortel Networks Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nortel Networks Ltd filed Critical Nortel Networks Ltd
Publication of AU2001230642A1 publication Critical patent/AU2001230642A1/en
Abandoned legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1829Arrangements specially adapted for the receiver end
    • H04L1/1835Buffer management
    • H04L1/1845Combining techniques, e.g. code combining
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1812Hybrid protocols; Hybrid automatic repeat request [HARQ]
    • H04L1/1819Hybrid protocols; Hybrid automatic repeat request [HARQ] with retransmission of additional or different redundancy
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/1607Details of the supervisory signal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1867Arrangements specially adapted for the transmitter end
    • H04L1/1874Buffer management
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/12Arrangements for detecting or preventing errors in the information received by using return channel
    • H04L1/16Arrangements for detecting or preventing errors in the information received by using return channel in which the return channel carries supervisory signals, e.g. repetition request signals
    • H04L1/18Automatic repetition systems, e.g. Van Duuren systems
    • H04L1/1867Arrangements specially adapted for the transmitter end
    • H04L1/188Time-out mechanisms

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Detection And Prevention Of Errors In Transmission (AREA)
  • Communication Control (AREA)

Description

AUTOMATIC REQUEST PROTOCOL BASED PACKET TRANSMISSION USING PUNCTURED CODES
The invention relates to digital data transmission systems, and more particularly to automatic request protocol based packet transmission and reception methods and corresponding apparatus. Background of the Invention
The possibility exists that errors will occur in packet data received over a noisy transmission medium such as a wireless communications channel. Error correction coding can be used to reduce error rates at the expense of throughput. A packet can contain a certain number of errors, and still allow for the correct decoding of the packet's data content.
Convolutional coding is a convenient and widely used method of error correction coding. A decoding algorithm proposed by Niterbi and described in Andrew J. Niterbi "CDMA. Principles of Spread Spectrum Communication", Addison- Wesley Wireless Communications Series, 1995, pp. 132 - 138 is widely used in communication systems and allows the achievement of the highest coding gain. Unfortunately, Niterbi decoder complexity increases exponentially as a function of constraint length limiting practical block sizes which can be decoded. Another interference stable coding method is referred to as "turbo coding" taught in an article by C. Berrou, A. Glaviex, P. Thitimajshina "Near Shannon limit error - correcting coding and decoding", IEEE Transactions in Information Theory, 2/1993.
When using convolutional or turbo decoding, data symbols and check symbols are transmitted, and the puncturing or erasing of some check symbols is possible (see J. Clark, J. Kane "Error correction based coding in digital communication systems", Statistic
Communication Theory, edition 28, M., Radio and Communication, 1987). The effect of puncturing is to increase the rate of the code. An example of this is shown in Figure 1 in which an encoded block 10 is shown, and several symbols 12 are deleted or punctured prior to transmitting the block. The location of the punctured symbols is known at both the receiver and transmitter, and is factored into whatever decoding strategy is employed. Convolutional Niterbi decoding and turbo decoding allow for the performance of soft decision decoding. Typically, when a packet is received and decoded, and an identification of the existence of a non-correctable error is made, some portion of the packet needs to be retransmitted. Previously, the entire packet was retransmitted. It was then discovered that the retransmission of only a small part of the data packet after the occurrence of a non-correctable error is often sufficient to allow the packet to be correctly decoded. The portion of the packet which is retransmitted is combined with the originally transmitted packet, and the result is re-decoded.
Another known decoding method is described in the article "Rate Compatible Punctured Convolutional Codes (RCPC Codes) and their Applications" by J. Hagenauer, IEEE Trans. Cornmun., Vol. 36, Apr. 1988, pp. 389 - 400. This decoding method presents variable rate punctured convolutional codes which are able to adapt to changes in the interference conditions of the data transmission channel. In this method, certain symbols are punctured at source code transmission time, and the punctured symbols are the ones which are transmitted in a separate re-transmit packet in the event the packet is received in error. The transmitted punctured symbols are combined with the originally transmitted packet and the result is re-decoded. Similar approaches are described in "Rate Compatible Punctured Turbo (RCPT) Codes in a Hybrid FEC/ARQ Systems" by D.N. Rowitch and L.B. Milstein in Proc. Communications Theory Mini - Conference of GLOBECOM' 97, Phoenix, AZ, Nov. 1997, pp. 55 - 59, and in U.S. Patent No. 5,983,384 to John Anderson Fergus Ross entitled "Turbo-coding with staged data transmission and processing", Nov. 9, 1999.
Another existing method is described in German patent DE 19736676 to Friedbert et al, entitled "Automatic request protocol based packet transmission and transmission channel repetition method in digital system", October 12, 1998. This method involves the use of turbo coding at the transmission side and soft decision turbo decoding at the receiving side. The system is provided with a reverse channel by which the receiver requests erroneous packet retransmissions. An RCPTC (rate compatible punctured turbo code) code is used as the turbo code. When re-transmitting for the erroneously received packet, at least a part of the information punctured from the variable rate turbo code at the previous transmission is transmitted. This additional information is added to the available information at the receiving side, and the combined sequence is again decoded. This process is repeated until the packet is decoded correctly. More specifically, the method involves first defining the cyclic redundancy check sum and adding it to an information sequence. After this, turbo coding of the information sequence is performed. Re-request
(retransmission request) blocks are formed by dividing non-systematic code components into m blocks, N is the size of the non-systematic code components where P is the re- request block size, and where m= N/P. These re-request blocks are saved in memory. The initial encoded packet is transmitted containing a systematic code part and some re- request blocks. In the event proper decoding is not performed, the next non-transmitted re-request block is transmitted if an error is detected. This is repeated until the packet is correctly decoded, or until all re-request blocks have been transmitted. This method provides a reduced number of transmitted code symbols per information packet. Disadvantageously, most digital communication systems use fixed size packets for code symbols and the use of this method requires a significant change for the system.
In previous approaches which adopted a "send-and-wait" protocol, i.e. new data is not sent until the current packet is correctly decoded, system efficiency is reduced. In approaches providing variable packet size for different channel conditions, the retransmitted packet size is a design parameter, as is the average packet delay. The larger the retransmitted packet size, the less the number of re-requests, hence the less the average packet delay. However, a larger retransmitted packet size may reduce the system efficiency, as the receiver may not need such a large retransmitted packet to decode data correctly. The system capacity used for over-retransmitted data can be better used for transmitting useful new data. Summary of the Invention
Embodiments of the invention provide methods and systems for automatic request and repetition with interference stability, providing non-uniform and adaptive data protection from interference for fixed length packet communication systems.
from previous error correction encoded block is inserted into punctured symbol locations of at least one future encoded block. The future block thus generated is then transmitted.
A sequence of input blocks is encoded to produce respective encoded blocks. A component of each encoded block is punctured in punctured symbol locations, and this is the non-transmitted component. For each encoded block, re-request (retransmission request) blocks are defined each containing a respective subset of the symbols punctured from that encoded block. One of these re-request blocks is inserted into the punctured symbol locations of a future encoded block should the encoded block require additional redundancy at the receiver to decode. In some cases, transmission of a single re-request block is not sufficient to allow decoding of the associated encoded block at the receiver. In this case, in additional future blocks, further re-request blocks for the encoded block are inserted in further future encoded blocks.
A re-request queue may be maintained identifying any encoded blocks which have not been successfully received at a receiver, the re-request queue including an identification of an oldest encoded block which has not been successfully received at a receiver. The re-request blocks are then inserted, starting with the one associated with the oldest encoded block.
In one embodiment, after transmitting all of the re-request blocks for a given encoded block, the entire encoded block is retransmitted. In another embodiment, when the number of re-requests exceeds a certain number, an entire encoded block is retransmitted. In another embodiment, when the number of re-requests exceeds a certain number, re-request blocks for multiple encoded blocks are transmitted in a single block.
Re-requests may be added to the queue due to the reception of a request for retransmission of a particular previous encoded block, or due to the time-out for acknowledgement of a particular block.
After an acknowledgement has been received for a particular encoded block the identification of the particular encoded block is removed from the re-request queue.
In another embodiment, power control is performed as a function of a number of re-requests required. In another embodiment, the size of the inserted component is increased as a function of the number of re-requests until entire future encoded blocks are dedicated to retransmission. Further embodiments provide transmitters adapted to implement any of the above - methods, and a computer readable medium containing instructions for implementing any of the above methods.
The invention according to another broad aspect provides a data reception method for receiving blocks generated using the above discussed data transmission method. At a receiver, a received block is separated into symbols of a current block and symbols of a re- request block contained in punctured symbol locations of the received block, the re- request block containing symbols of a previous block. Next, the symbols of the current block are decoded. The symbols of the re-request block are combined with a previous version of the previous block to produce a combined block and this combined block is then decoded.
The combining is done at the receiver using soft-combining. When retransmission with soft combining (before the decoder) is involved, the blocks with retransmission get more protection than the blocks with no retransmission, which makes the protection "non- uniform" from block to block. Since the protection is provided based on needs (i.e. channel conditions), the protection is also adaptive.
In some embodiments, a re-request is sent in respect of the current block if not successfully decoded and a re-request is sent in respect of the combined block if it is not successfully decoded. Symbols of the current block are stored in memory for subsequent combination with further components which might be subsequently received, and the combined block may also- be stored in memory, particularly if not decoded correctly.
In some embodiments, an acknowledgement is sent each time a block is correctly decoded. Further embodiments provide receivers adapted to implement any of the above reception methods, and a computer readable medium containing instructions for implementing any of the above methods. Brief Description of the Drawings
Figure 1 is an illustration of an encoded block from which symbols have been punctured;
Figure 2 is a block diagram of a transmitter and receiver adapted to implement an automatic request (ARQ) protocol based packet transmission method provided by an embodiment of the invention;
Figures 3 A and 3B are flowcharts of transmitter ARQ functionality implemented by the transmitter of Figure 2;
Figure 4 is a flowchart of the receiver ARQ functionality implemented by the ■• 5 receiver of Figure 2;
Figures 5 A and 5B are data structures for implementing transmit re-request functionality; and
Figure 6 is a data structure for implementing receive re-request functionality. Detailed Description of Invention 10 Referring now to Figure 2, a packet communication system provided by an embodiment of the invention includes a transmitter 31 and a receiver 33.
The transmitter has a serial error detecting code encoder 30 a first input of which is a sequence of data blocks 31 to be transmitted. The error detecting code encoder 30 is connected to a first input of an error correcting code encoder 32. The error correcting 15 code encoder 32 output is connected to a first input of a switch 34 and to a first input of a memory unit 36. The output of the switch 34 is connected to an amplifier 40 the output of which is the output of the transmitter 31 transmitted over the air interface to the receiver 33. A controller 38 is provided for processing re-requests and acknowledgements 39. The controller has a first output connected to a second input to the error detecting code encoder 20 30, a second output connected to a second input of the error correcting code encoder 32, a third output connected to a second input to the memory unit 36, and a fourth output connected to a second input of the switch 34. The memory unit 36 has an output connected to the switch 34. The memory unit 36 includes a re-request queue memory structure 35, and also has an encoded blocks memory structure 37. Referring now to 25 Figure 5A, the encoded blocks memory structure 37 has records consisting of a sequence number field 70 which allows an identification of encoded blocks. Encoded blocks are stored in field 72. Also, re-request blocks are stored for each encoded block in field 74. Finally, a field 76 identifies how many re-request blocks have been transmitted if any. The re-request queue memory structure 37 simply identifies sequence numbers 78 for 30 which re-requests have been received from the receiver 33. Re-request blocks are described in detail further below.
The receiver 33 has a switch 42 a first output of which is connected with the first input of a memory unit 44 and the input of a first decoder 46. The switch 42 has a second output connected with a first input of a combiner 50. The memory unit 44 has a second input from a first output of the combiner 50. The combiner 50 has a second input from an output of the memory unit 44. The output of the first decoder 46 is connected to the input of a first packet error detector 54. A second outputof the combiner 50 is connected with the input of the second decoder 48. The output of the second decoder 48 is connected to an input of a second packet error detector 56. The outputs of the packet error detectors 54 and 56 are coupled with first and second inputs of a controller 52, respectively. A first output of the controller 52 is connected with a first input to a second memory unit 58, the second and third inputs of which are coupled with the outputs of the first and second decoders 46,48, respectively. The output of the second memory unit 58 is the receiver 33 output. A second output of the controller 52 is connected to a third input of the combiner 50. A third output of the controller 52 is connected to a second input of the switch 42. A fourth output of the controller 52 is a queue length output 51 and a fifth output is a re- request output 53. The memory unit 44 has a received and combined blocks memory structure 45 having a record structure which is illustrated in Figure 6 by way of example. Each record has a sequence number field 80, space for the received block 82 (or for subsequent combinations of received blocks with other re-request blocks), and has a field 84 indicating the number of re-request blocks received for a given sequence number. The operation of the transmitter 31 in the transmission of an input data block will now be described with further reference to Figure 2, and with reference to the flowcharts of Figure 3 A which details transmit block construction, and Figure 3B which details the maintenance of the re-request queue 35. To begin, the error detecting code encoder 30 defines an error correcting cyclic redundancy check (CRC) sum and adds this to the input data block (step 3A-1). Next, the block, including the CRC is encoded using the error correcting code encoder 32 (step 3 A-2). This can be any error correcting code, for example but not limited to a block code, convolutional code, turbo code, so long as the code can be decoded using soft decoding at the receiver. This is because only soft- decoding can employ partial retransmission and soft combining. The code may be a systematic code, or a non-systematic code. The encoded block thus generated is stored in the encoded blocks memory structure 37 in memory unit 36 along with the block's sequence number. Next, for each block, re-request blocks are formed from code components in punctured symbol locations to be made available for retransmissions of re- request blocks- of prior encoded blocks should this be necessary. For Turbo codes, it is usual to puncture non-systematic bits. But recently, there are some proposals to puncture some of systematic bits. For non-systematic codes, such as traditional convolutional code, no systematic bits are available for being punctured. For block codes, it is very likely that a systematic code will be used. In this case, to randomize the puncturing effect, some systematic bits must be punctured. More generally, re-request blocks may be formed of any selection of symbols. In one embodiment, these are formed by dividing the punctured code components into m re-request blocks of size P symbols each, where M is the number of punctured code components and m=M/P. Another more general way of viewing this is to start with an encoded block size N, and divide this into K sub-blocks of size P=N/K. Then, m of these are aside as re-request blocks, with the remaining K-m being transmitted. With this approach, it is possible to tibink of m as being variable. It is zero when there is no retransmission for previous blocks required. It can then be increased in any suitable fashion depending upon the number of retransmissions required. For example, it can jump to a fixed number ml. It may follow a sequence of values 0, mi, m2, ..., mMax where πiMax < K. Alternatively, m can be allowed to eventually equal K in which case an entire packet is devoted to retransmissions. These re-request blocks are saved to the encoded blocks memory structure 37 of memory unit 36 (step 3A-3) in association with the block sequence number. In the event controller 38 determines that the re-request queue 35 has no re-requests (no path step 3A-4), then controller 38 controls the switch 34 such that the entire code sequence output by the error correcting code encoder 32 is transmitted in step 3A-5. Alternatively, if a re-request transmission is required, then controller 38 signals switch 34 to puncture the current encoded block output by the error correcting code encoder 32 and insert in place of the punctured symbols a re-request block previously stored in memory unit 36 instead of the punctured symbols step 3A-6. More specifically, for the next encoded block identified in the re-request queue 35, the next untransmitted re-request block (determined from number of transmitted re-request blocks field 76 in encoded blocks table 37) for that encoded block is inserted in place of the punctured symbols. Up to m re-request blocks may be inserted in the encoded block. The number of transmitted re-request blocks field 76 for that encoded block is incremented. The block thus generated is then passed to amplifier 40 and transmitted in step 3A-7. Referring now to Figure 3B, a second input to the transmitter 31 consists of re- requests and acknowledgements 39 sent by the receiver 33 which identify sequence numbers of previously transmitted encoded blocks which have not been correctly received and have been received correctly respectively (step 3B-1). The controller 38 maintains the re-request queue 35 by adding sequence numbers of re-requests to the re-request queue (step 3B-2), and by de-queuing these on a first-in-first-out basis as described above (step 3B-3). In one embodiment, in the event the re-request queue becomes greater than a certain size, the transmission of the current block is suspended, and an unsuccessfully transmitted encoded block 72 in encoded blocks memory structure 37 is retransmitted in its entirety. In another embodiment, when the re-request queue 35 becomes a certain size, a single transmit block is generated containing re-request blocks for multiple encoded blocks identified in the re-request queue, and the transmit block is transmitted with no new data. At step 3B-4 an acknowledgement is received identifying the sequence number of a successfully received and decoded block. The re-request entry in the re-request queue 35 and the corresponding encoded block entry in the encoded blocks memory structure 37 are deleted when this occurs (or allowed to be overwritten).
The triggering of a retransmission can be done using any suitable mechanism. In the example being described in detail, retransmission is triggered by a specific request from the receiver for the retransmission of a particular encoded block. In addition to or alternative to the request based retransmission, a retransmission can be triggered in the event a previous encoded block written to memory 36 has not been acknowledged for some period of time in which case a re-request is added to the re-request queue 35 when such a time out occurs.
In one embodiment, in the event all of the re-request blocks for a given encoded block have been transmitted and the block can still not be decoded, the next encoded block is not sent, but rather the process is started afresh for that block by sending the entire data block.
In another embodiment, a power control threshold applied by amplifier 40 is selected depending on the number of re-requests in the re-request queue 35, so as to increase the transmitted signal power as a function of the increasing length of the queue. Power control provides additional protection to packets suffering severe interference, so that a real data transmission rate can be preserved. In another embodiment, for systems with fixed transmitting power which cannot benefit from the power control aspect described above, the retransmission portion of a new packet can be increased in size, until a full packet is dedicated to retransmission.
The operation of the receiver 33 in the reception of transmitted blocks will now be described with reference to the flowchart of Figure 4. The process starts with the reception of a block (step 4-1). Next, in the event there is a re-request block embedded within the current encoded block, this is separated out at step 4-2 by switch 42 which performs a demultiplexing function. In place of the punctured symbols removed from the current block, neutral values (nulls) are placed. Next, the extracted re-request block is combined with symbols previously transmitted for the respective block at step 4-3 with combiner 50. Ifthe re-request block has not been transmitted before, then there should be nulls in the place of the symbols in the primary encoded packet. The combined sequence and the current block are both written to the received and combined blocks memory structure 45 (step 4-4) in association with respective sequence numbers. Next, decoder 46 decodes the current block at step 4-5. Ifthe current encoded block is correctly decoded (yes path step 4-6), then it is deleted from the received and combined blocks memory structure 45 (step 4-7). Decoder 48 decodes the old block at step 4-8. The old block is removed from the received and combined blocks memory structure 45 (step 4-9) if it is decoded correctly (yes path, step 4-10). Memory unit 58 stores the correctly decoded block allowing for any necessary subsequent reordering of data.
Next, after completion of decoding, if either the current block or the combined block were decoded incorrectly then a re-request is transmitted to the receiver identifying the encoded block(s) which has not yet been correctly decoded (step 4-11). Alternatively, a time out mechanism at the transmitter may be employed. In addition, an acknowledgement may also be sent for correctly decoded encoded block(s).
It is to be understood that there are many suitable mechanisms of causing a re- request block to be transmitted which may be employed other than the specific methods exemplified above.
In the above described embodiment, the re-transmitted components are limited to sub-blocks which were not transmitted with the initial transmission for a given encoded block. More generally, these can be allowed to include components which were transmitted. For example, after all non-transmitted components have been transmitted, the method can return to transmitting previously transmitted components.
Now several examples will be provided using the following previously defined terms:
N = encoded block size T = fixed transmit block size
P = sub-block (and re-request) block size for K blocks = N/K m = number of sub-blocks of the current encoded block to be punctured and replaced with re-request blocks from previous encoded blocks
K-m = number of sub-blocks of the current encoded block transmitted. In a first example, N=T=1000, so the encoded block size = fixed transmit block size, and the entire encoded block can be sent when there is no requirement for any retransmission. Each encoded block is comprised of K=20 sub blocks of size P=50. When retransmission is required, a sub-block is punctured, and replaced with a non- transmitted sub-block of a previous encoded block. In one example, the number m available for puncturing is a fixed number, for example m=2. In another embodiment, m increases as a function of the number of re-requests pending. For example, m might follow a sequence m=2,4,6,... MMSK- In the event MMEK is allowed to increase to equal K, an entire block can be dedicated to retransmissions.
In another example, N=10005 and T=800 so the encoded block size N is greater than the fixed transmit block size T, meaning that the entire encoded block cannot be sent even when there is no requirement for any retransmission. Again, each encoded block is comprised of K=20 sub-blocks of size P=50. When no retransmission is required, 200 symbols, or four sub-blocks are punctured to reduce the block size from 1000 to 800. These sub-blocks are not replaced with anything. When retransmission is required, a further sub-block is punctured, and replaced with a non-transmitted sub-block of a previous packet.
In one embodiment the fixed transmit block size is equal to the encoded block size so that in the event no retransmission is required, the entire encoded block is transmitted. In another embodiment, the fixed transmit block size is smaller than the encoded size meaning there will always be some puncturing.
Numerous modifications and variations of the present invention are possible in light of the above teachings. It is therefore to be understood that within the scope of the appended claims, the invention may be practised otherwise than as specifically described herein.

Claims (46)

WE CLAIM:
1. A fixed block size data transmission method comprising inserting encoded symbols punctured from a previous error correction encoded block into punctured symbol locations of at least one future encoded block and transmitting the at least one future encoded block.
2. A method according to claim 1 further comprising: encoding input data blocks to produce a sequence of respective encoded blocks; for each encoded block, defining a respective plurality of re-request (retransmission request) blocks each containing a respective subset of a set of encoded symbols in punctured symbol locations of the encoded block; wherein inserting encoded symbols punctured from a previous encoded block into punctured symbol locations of at least one future encoded block comprises inserting at least one of the re-request blocks of a previous encoded block into punctured symbol locations of at least one future encoded block.
3. A method according to claim 1 further comprising: inserting some encoded symbols punctured from the previous encoded block into punctured symbol locations of a plurality of future encoded blocks.
4. A method according to claim 2 further comprising: inserting a plurality of the re-request blocks of the previous encoded block into punctured symbol locations of a respective plurality of future encoded blocks.
5. A method according to claim 1 further comprising: maintaining a re-request queue identifying any encoded blocks which have not been successfully received at a receiver, the re-request queue including an identification of a sequence in which the encoded blocks were not successfully received at a receiver.
6. A method according to claim 5 further comprising: inserting symbols of previous encoded blocks identified in said re-request queue, on the basis of the sequence.
7. A method according to claim 2 further comprising after transmitting all of the re- request blocks for a given previous encoded block, retransmitting previously transmitted components for the previous encoded block in punctured symbol locations of the at least one future encoded block.
8. A method according to claim 2 further comprising: after transmitting all of the re-request blocks for a given encoded block, retransmitting the encoded block.
9. A method according to claim 1 wherein the fixed block size for transmission is the same as the encoded block size, and in the event there are no symbols of a previous encoded block which require insertion, the entire future encoded block is transmitted.
10. A method according to claim 1 wherein the fixed block size for transmission is smaller than the encoded block size, and the encoded blocks are always punctured in at least as many symbol locations as required to reduce block size to the fixed block size for transmission, and in further locations in which encoded symbols punctured from a previous error correction block are to be inserted.
11. A method according to claim 1 wherein a number of symbols from previous blocks inserted into a future block is increased as a function of a number of previous blocks for which retransmission is required.
12. A method according to claim 1 further comprising, after inserting all the symbols punctured from a particular previous encoded block in one or more future blocks, inserting symbols which were transmitted for the previous block in one or more future blocks.
13. A method according to claim 11 wherein the number of symbols from previous blocks inserted into a future block can be increased to occupy the entire future block.
14. A method according to claim 1 further comprising: receiving a request for retransmission in respect of a particular previous encoded block; wherein inserting encoded symbols punctured from a previous error correction encoded block comprises inserting encoded symbols punctured from the particular previous encoded block.
15. A method according to claim 1 further comprising: maintaining a re-request queue identifying encoded blocks which have not been successfully transmitted; wherein inserting encoded symbols punctured from a previous error correction encoded block into punctured symbol locations of at least one future encoded block is sequentially done for previous encoded blocks identified in the re-request queue.
16. A method according to claim 15 wherein an identification of a particular encoded block is added to the re-request queue upon receipt of a re-request for the particular encoded block.
17. A method according to claim 15 wherein an identification of a particular encoded block is added to the re-request queue after an acknowledgement has not been received for the particular encoded block for a predetermined period of time.
18. A method according to claim 15 wherein anidentification of a particular encoded block is removed from the re-request queue after an acknowledgement has been received for the particular encoded block.
19. A method according to claim 15 further comprising: performing power control as a function of a number of re-requests in the re-request queue.
20. A method according to claim 1 further comprising: prior to performing the error correction encoding, performing an error detection encoding.
21. A method according to claim 21 wherein performing an error detection encoding comprises adding a CRC (cyclic redundancy check) field.
22. A method according to claim 15 further comprising: as a function of a number of re-requests in the re-request queue, increasing a number of symbols inserted into the future encoded block until entire future encoded blocks are dedicated to retransmission.
23. A data reception method comprising: separating a received block into symbols of a current block and symbols of at least one re-request block contained in punctured symbol locations of the received block, the re-request block(s) containing symbols of at least one previous block; decoding the symbols of the current block; for each previous block for which there is a respective at least one re-request block: combining the symbols of the respective at least one re-request block with a previous version of the previous block to produce a combined block and decoding the symbols of the combined block.
24. A method according to claim 23 further comprising: sending a re-request in respect of the current block if not successfully decoded; and for each combined block, sending a re-request in respect of the combined block if the combined block is not successfully decoded.
25. A method according to claim 23 further comprising: storing the symbols of the current block and each combined block in a memory structure; in the event the current block and/or combined block is successfully decoded, deleting the respective block from the memory structure.
26. A method according to claim 23 further comprising: sending an acknowledgement each time a block is correctly decoded.
27. A transmitter comprising: an error correction encoder adapted to encode a sequence of input data blocks to produce a corresponding sequence of encoded blocks having fixed length; a puncturing circuit adapted to insert encoded symbols punctured from a previous encoded block into punctured symbol locations of at least one future encoded block.
28. A transmitter according to claim 27 further comprising: a memory structure adapted to contain, for each encoded block, a respective plurality of re-request blocks each containing a respective subset of the respective set of encoded symbols punctured from the encoded block; wherein the puncturing circuit is adapted to insert one of the re-request blocks of a previous encoded block into punctured symbol locations of a future encoded block.
29. A transmitter according to claim 27 wherein the puncturing circuit is adapted to insert a plurality of subsets of the set of encoded symbols punctured from the previous encoded block into punctured symbol locations of a respective plurality of future encoded blocks.
30. A transmitter according to claim 27 further comprising: a re-request queue identifying a sequence of encoded blocks which have not been successfully received at a receiver; wherein the puncturing circuit is adapted to insert symbols punctured from encoded blocks identified in the re-request queue on the basis of the sequence.
31. A transmitter according to claim 27 further adapted to, after encoding each input data block to produce the respective encoded block, store the respective plurality of re- request blocks in the memory structure together with the encoded block.
32. A transmitter according to claim 29 adapted to retransmit a given encoded block after all of the re-request blocks for the given encoded block have been transmitted.
33. A transmitter according to claim 27 further comprising: an input adapted to receive a request for retransmission of a particular previous encoded block; wherein the puncturing circuit is adapted to insert symbols punctured from the particular previous encoded block.
34. A transmitter according to claim 27 wherein the puncturing circuit is adaptive to insert encoded symbols punctured from a previous error correction encoded block into punctured symbol locations of at least one future encoded block sequentially for previous encoded blocks identified in the re-request queue.
35. A transmitter according to claim 34 further adapted to add an identification of a particular encoded block to the re-request queue upon receipt of a re-request for that encoded block.
36. A transmitter according to claim 34 further adapted to add an identification of a particular encoded block to the re-request queue after an acknowledgement has not been received for the particular encoded block for a predetermined period of time.
37. A transmitter according to claim 34 further adapted to remove the identification of a particular encoded block from the re-request queue after an acknowledgement has been received for the particular encoded block.
38. A transmitter according to claim 27 further adapted to perform power control as a function of a number of re-requests required.
39. A transmitter according to claim 27 further comprising an error detection encoder which performs error detection encoding prior to performing the error correction encoding.
40. A receiver comprising: a demultiplexer adapted to separate a received block into symbols of a current block and symbols of at least one re-request block contained in punctured symbol locations of the received block, the at least one re-request block containing symbols of at least one previous block; first decoding circuitry adapted to decode the symbols of the current block; a combiner adapted to combine the symbols of the at least one re-request block with a previous version of each said at least one previous block to produce a combined block in respect of each said at least one previous block; and second decoding circuitry adapted to decode the combined blocks.
41. A receiver according to claim 40 further comprising: retransmission request means adapted to send a re-request in respect of the current block if not successfully decoded, and for each combined block, to send a re-request in respect of the combined block ifthe combined block is not successfully decoded.
42. A receiver according to claim 40 further comprising: acknowledgement means adapted to send an acknowledgement each time a block is correctly decoded.
43. A computer readable medium having stored thereon instructions causing a computer to execute the method of claim 1.
44. A circuit adapted to implement the method of claim 1.
45. A computer readable medium having stored thereon instructions causing a computer to execute the method of claim 22.
46. A circuit adapted to implement the method of claim 22.
AU2001230642A 2000-10-30 2000-10-30 Automatic request protocol based packet transmission using punctured codes Abandoned AU2001230642A1 (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/RU2000/000430 WO2002037743A1 (en) 2000-10-30 2000-10-30 Automatic request protocol based packet transmission using punctured codes

Publications (1)

Publication Number Publication Date
AU2001230642A1 true AU2001230642A1 (en) 2002-05-15

Family

ID=20129561

Family Applications (1)

Application Number Title Priority Date Filing Date
AU2001230642A Abandoned AU2001230642A1 (en) 2000-10-30 2000-10-30 Automatic request protocol based packet transmission using punctured codes

Country Status (5)

Country Link
EP (1) EP1334581B1 (en)
AU (1) AU2001230642A1 (en)
CA (1) CA2427491A1 (en)
DE (1) DE60033577T2 (en)
WO (1) WO2002037743A1 (en)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1770895A1 (en) * 2005-09-28 2007-04-04 Koninklijke Philips Electronics N.V. Transmission rate adaptation with incremental redundancy
DE102008024255A1 (en) * 2008-05-20 2009-12-10 Siemens Enterprise Communications Gmbh & Co. Kg Devices and methods for processing data packets of a data stream, as well as a use of the devices
EP2451107B1 (en) * 2010-11-08 2013-06-12 Alcatel Lucent Method and arrangement for extracting information from signals in receivers
RU2460217C1 (en) * 2011-07-26 2012-08-27 Государственное образовательное учреждение высшего профессионального образования Академия Федеральной службы охраны Российской Федерации (Академия ФСО России) Method for synchronous data transmission with decision feedback and apparatus for realising said method
RU2700398C1 (en) * 2018-12-29 2019-09-16 Акционерное общество "Концерн "Созвездие" Method of transmitting data in a digital radio communication system based on codes with low density of parity checks and a method of interleaving code symbols
RU2713573C1 (en) * 2019-06-03 2020-02-05 Акционерное общество "Концерн "Созвездие" Data transmission device based on codes with low density of checks on parity
RU2708349C1 (en) * 2019-06-03 2019-12-05 Акционерное общество "Концерн "Созвездие" Data transmission method based on codes with low density of checks on parity

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5954839A (en) * 1997-01-14 1999-09-21 Samsung Electronics Co., Ltd. Error protection method for multimedia data
DE19736676C1 (en) * 1997-08-22 1998-12-10 Siemens Ag Data packet transmission method in digital transmission system

Also Published As

Publication number Publication date
WO2002037743A9 (en) 2004-12-02
EP1334581B1 (en) 2007-02-21
DE60033577D1 (en) 2007-04-05
CA2427491A1 (en) 2002-05-10
WO2002037743A1 (en) 2002-05-10
EP1334581A1 (en) 2003-08-13
DE60033577T2 (en) 2007-10-31

Similar Documents

Publication Publication Date Title
AU2006226953B2 (en) Method and apparatus for improving data transmission reliability in a wireless communications system
US6977888B1 (en) Hybrid ARQ for packet data transmission
US8156407B2 (en) Method and system for memory management in a HARQ communications system
KR100525384B1 (en) Method for controlling packet retransmission in mobile communication system
EP1994669B1 (en) Method and apparatus for transmitting and receiving a data block in a wireless communication system
US20090177852A1 (en) Data block receiver and method for decoding data block
KR20070053504A (en) Apparatus and method for decoding code requiring iteration decoding in system using harq
KR20020003526A (en) Hybrid automatic repeat request method and apparatus for improving mobile communication systems
US8271860B2 (en) Retransmission method and device based on low density parity check codes
EP2210360B1 (en) Apparatus and method for decoding in mobile communication system
Kallel et al. Throughput performance of memory ARQ schemes
EP1334581B1 (en) Automatic request protocol based packet transmission using punctured codes
US20220069949A1 (en) Communication transmitter for retransmitting medium access control (mac) protocol data unit (mpdu)
CN101282202A (en) Mixed automatic repeat request method and data transmission system
KR100392641B1 (en) An adaptation coding method at MAC layer to support hybrid ARQ in 3 Generation W-CDMA system
EP1482670A1 (en) A method and receiver for buffering data employing HARQ and two stage matching algorithm with iterative decoding
Jagath-Kumara A new HARQ scheme using BCH codes with unequal data and parity frames
Ur-Rehman et al. Iterative cross-layer decoder for wimax using hybrid-arq
KR20020045076A (en) A transmission method to support soft combining at transmitting side in W-CDMA system