The present invention relates to a method for generating a feedback message and reducing overheads in a wireless portable communication system, and more particularly, it relates to a repeat request algorithm for reducing overhead by using an automatic repeat request (ARQ) feedback message in a newly defined ACK MAP.
In a wireless portable Internet system, an automatic repeat request (ARQ) algorithm has been developed to minimize an error rate and enhance error correction in data transmission.
The ARQ algorithm is used as a method for retransmitting a damaged data packet with reference to a feedback message (ACK and NACK) of each transmitted data packet or in consideration of timeout when the corresponding feedback message is not received.
A transmitter 10 transmits a protocol data unit (PDU) to a receiver according to an ARQ mechanism. The PDU is generated from a service data unit (SDU) that is generated from an upper layer 11 and stored in a buffer 12.
An ARQ receiver 23 transmits a feedback message for ARQ to the transmitter 10. The feedback message for ARQ includes an ACK message or a NACK message according to success or failure of the PDU transmission and is used for error correction in the mobile Internet system.
An ARQ transmitter 13 retransmits the corresponding PDU or transmits a discard message to the ARQ receiver 23 in response to the ACK message or the NACK message.
Hence, the result of ARQ that indicates success or failure of transmission is available for transmitter 10 to analyze data transmission efficiency according to the receiver or a channel quality. QoS analysis and scheduling can be achieved by referring to the data transmission efficiency.
When the transmitter 10 transmits a data packet to the receiver, the receiver sends an ACK message as the feed back message for ARQ to the transmitter after receiving the data packet. The ACK message includes a cumulative ACK message and a selective ACK message, which will be stated later.
The ARQ receiver 23 sends the ACK message to the ARQ transmitter 13 when the ARQ receiver 23 successfully receives the data packet, but the ARQ receiver may fail to receive the data packet when the data packet is lost because of a bad channel quality.
The transmitter may not also receive an ACK message from the ARQ receiver 23 when the ACK message is lost due to the bad channel quality. Once the data packet or the ACK message is lost, it is preferable for the ARQ receiver to discard the corresponding data packet after a predetermined lifetime so that the ARQ transmitter may not infinitely wait for a response or retransmit the data packet.
Conventionally, the ARQ transmitter 13 sends a discard message to the ARQ receiver when the data packet or the ACK message is lost on the channel and therefore the transmitter 10 receives no ACK message for a predetermined lifetime, in step S1.
The ARQ receiver 23 sends a discard response message in response to the discard message, and discards the transmitted data packet in step S2.
In
When errors occur in the sequence block numbers (BSNs) 4, 7, 8, and 12 of the MAC PDU as shown in
The ARQ receiver then sends an ACK to inform that the ARQ receiver successfully received the BSNs 1, 2, and 3, and the ARQ transmitter retransmits the blocks from the BSN 4 to BSN 12 of the MAC PDU as shown in
Although the selective ACK message of
In
However, the foregoing feedback message for ARQ is not efficient in the wireless portable Internet system since a sequence of successive blocks forms a PDU, and success or failure of data transmission occurs in each PDU.
In other words, the conventional bitmap-type ACK MAP maps success and failure of each BSN, thereby increasing an overhead.
Therefore, an efficient method for transmitting the feedback message for ARQ without increasing the overhead is needed in the wireless portable Internet system.
It is an object of the present invention to provide a method for generating a feedback message and reducing overheads in a wireless portable Internet system.
In one aspect of the present invention, there is provided a method for generating a feedback message for auto repeat request (ARQ). In the method, a) an ACK type is recorded in a first field; b) the last block sequence number of cumulative ACK blocks is estimated and recorded in a second field, c) the number of group of successive ACK blocks after the block sequence number estimated in b) is recorded in a third field as the number of ACK MAPs, d) start block sequence number of the respective ACK MAPs is recorded in a fourth field, e) lengths of the respective ACK MAPs are recorded in a fifth field by corresponding the lengths to the start block sequence number in d).
In another aspect of the present invention, there is provided a method for generating a feedback message for auto repeat request (ARQ). In the method, a) an ACK type is recorded in a first field, b) the last block sequence number of successive ACK blocks is estimated and recorded in a second field, c) the number of groups of the successive ACK blocks or NACK blocks after the block sequence number estimated in b) is recorded as the number of bulks in a third field, d) types of the respective bulks are set and recorded, e) lengths of the types of the respective bulks are estimated and recorded in a fourth field.
In c), the number of bulks is set by selecting a group from among groups having a predetermined number of bulks.
Bits assigned to bulk lengths of the groups respectively having the predetermined number of bulks are different per group.
According to the present invention, overhead of a conventional ARQ feedback message is reduced while performing an efficient packet retransmission request.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate an embodiment of the invention, and, together with the description, serve to explain the principles of the invention, wherein:
In the following detailed description, only preferred embodiments of the invention have been shown and described, simply by way of illustration of the best mode contemplated by the inventor(s) of carrying out the invention. As will be realized, the invention is capable of modification in various obvious respects, all without departing from the invention. Accordingly, the drawings and description are to be regarded as illustrative in nature, and not restrictive. To clarify the present invention, parts which are not described in the specification are omitted, and parts for which similar descriptions are provided have the same reference numerals.
A method for generating a feedback message for automatic repeat request (ARQ) according to an embodiment of the present invention will be described.
A service data unit (SDU) transmitted from an upper layer of a medium access control (MAC) layer is stored in a buffer and the same is transmitted in a format of a protocol data unit (PDU) having a plurality of sequence blocks. Herein, each of the sequence blocks is identified by a block sequence number (BSN). The number of sequence blocks in the PDU varies with respect to time by control of an ARQ receiver. As shown in
For example, three sequence blocks included in PDU 1 are found to be successfully received, but four sequence blocks in PDU 2 failed to be received.
In the pattern, ‘1’ denotes an ACKed sequence block, ‘0’ denotes a NACKed sequence block, ‘1’ denotes the first cumulative ACK end block, and ‘[1]’ denotes the second cumulative ACK start block.
In other words, similar to a typical cumulative ACK message, a first cumulative ACK message indicates successfully received BSNs, and a second cumulative ACK message indicates the second cumulative ACK start block when PDUs after the first cumulative ACK end block is NACKed. In addition, the length of the second cumulative ACK message displays successfully received data.
Therefore, the first BSN and the length of the sequence blocks in the second cumulative ACK message are defined as an ACK MAP according to the embodiment of the present invention.
To distinguish the ACK MAP from a conventional ACK MAP in
The BITMAP requires 4 bytes to patternize the ACK/NACK of each block as shown in
A connection is defined as a mapping relationship between MAC peers in the wireless portable Internet system. Therefore, the CID includes reference information addressing that a connection is dedicated for a feedback message for ARQ. However, the CID is not needed when a channel is dedicated for the feedback message for ARQ.
The LAST is set to be ‘0’ when the corresponding feedback message for ARQ is not the last one, and set to be ‘1’ when the feedback message for ARQ is the last one.
The ACK Type determines the type of ACK of the feedback message for ARQ. For example, ‘0’ indicates a selective ACK, ‘1’ indicates a cumulative ACK, ‘2’ indicates a cumulative-selective ACK, and ‘3’ indicates a cumulative-bulk ACK. The cumulative-bulk ACK corresponds to the ACK according to the embodiment of the present invention.
The last BSN in the first sequence of blocks that is successfully received is recorded in a BSN field of
The number of ACK MAPs is recorded in the Number of ACK MAPs. The Number of ACK MAPs may be set to be 1 to 4. When the ACK Type is set to be 1 (that is, a cumulative ACK), the number of ACK MAPs is set to be 0 because no ACK MAP is required.
Information on the ACK MAP is recorded in a unit of 16 bits in the corresponding ACK MAP field.
The ACK MAP field includes 11-bit BSN information and 5-bit Length information. The BSN field of the ACK MAP corresponds to the start BSN of the corresponding successive ACKs with the size indicated by Length. The Length field indicates the number of blocks counted from the BSN of the ACK MAP to the last BSN of successive ACKed blocks.
Meanwhile, a Bit MAP field indicates Bit MAP information of an ACK and NACK message when the ACK type is set to be 0 (selective ACK) or 2 (cumulative-selective ACK).
Therefore, the first cumulative ACK and successive ACKs after the first cumulative ACK may be efficiently transmitted by using the ACK MAP. The ACK MAP includes a start BSN and Length information to thereby reduce overheads of the feedback message for ARQ compared to a conventional ACK using the BIT MAP.
The ACKed blocks are transmitted by using the ACK MAP according to the foregoing embodiment of the present invention, but successive ACKs and NACKs are respectively defined by using different ACK MAPs according to another embodiment of the present invention.
An ACK MAP field includes a 3-bit Bulk Type field, a 5-bit Length field of the first bulk, a 4-bit Length field of the second bulk, and a 4-bit Length field of the third bulk.
Herein, a Bulk Type field defines whether the first, second, and third bulks are ACKed or NACKed, respectively. For example, when the Bulk Type field is set to be ‘010’, it informs that the first bulk is NACKed, the second bulk is ACKed, and the third bulk is NACKed.
The respective Length fields of the first to third bulks indicate the number of blocks included in the respective bulks.
The configuration of the third embodiment is similar to the second embodiment shown in
The BULK Configuration field is used to indicate the number of bulks in the ACK MAP.
For example, when the number of the bulks is 2, the Bulk Configuration field is set to be and the Length fields of the first and second bulks are equally assigned 6 bits.
When the number of the bulks is 3, the Bulk Configuration is set to be 1 and the Length fields of the first, second, and third bulks are equally assigned 4 bits.
Accordingly, the numbers and lengths of bulks may vary depending on various ACK/NACK patterns, thereby efficiently configuring the ACK MAPs.
According to the fifth embodiment of the present invention, a NACK bulk and an ACK bulk are alternately set in case that a group of sequential ACK blocks and a group of sequential NACK blocks are alternated with each other.
The Length fields of the ACK bulk and the NACK bulk are respectively assigned 4 bits, and they are alternately set to thereby efficiently configure successive ACKs and NACKs.
As shown therein, the Bulk Configuration field indicates the number of bulks.
Regardless of the Bulk Configuration field, the first bulk is NACKed because a cumulative ACK is already addressed by the BSN in the syntax of the ARQ feedback message as
The Next Bulk Flag field is assigned 1 bit to thereby indicate whether the following bulk is the ACK or NACK. Herein, ‘0’ indicates a NACKed bulk, and ‘1’ indicates an ACKed bulk.
The configurations of the ACK MAPs illustrated in
The cumulative-bulk ACK type is defined as a new ACK type according to the embodiments of the present invention, but an existing cumulative ACK type (ACK Type=1) may be defined as similar to the cumulative-bulk ACK type according to the embodiment of the present invention.
When the receiver receives PDUs corresponding to a MAC ARQ window and stores the PDUs in a receipt buffer, an ARQ transmitter sets ACK types for the respective PDUs to send corresponding ARQ feedback messages, in step S100.
When the ACK type is set to be a cumulative Bulk ACK in step S110, a value of the first ACKed BSN among the received blocks is estimated in step S120. When the first ACKed BSN is not the cumulative Bulk ACK, a conventional ACK process is preformed. The first ACKed BSN corresponds to the last BSN of the first successive ACKed blocks.
When a BSN of the first ACKed block is defined, the number of ACK MAPs to be generated in the ARQ window is estimated in step S130. The number of ACK MAPs corresponds to the number of bulks of successive ACKed blocks in the ARQ window.
The ARQ transmitter estimates a start BSN of the ACK MAPs in step 140. The start BSN is estimated by sequentially detecting BSNs corresponding to ACKs after the first cumulative ACK.
The ARQ transmitter estimates the length of the respective ACK MAPs in step S150. Lengths of the respective ACK MAPs indicate a total number of blocks counted from the first BSN to the last BSN in the respective ACK MAPs. Each length is mapped in a binary code.
The ACK MAP is generated on the basis of the estimated values, and is mapped in a feedback message in step S160. Information on ACKed blocks is included in the feedback message, and blocks which are not successfully received are defined as NACKed blocks.
The ARQ transmitter transmits the feedback message including the ACK MAP and the cumulative ACK to the transmitter for data retransmission in step S170.
A process (not shown) may be included in the method for generating the feedback message of
Descriptions for steps S100 to S120 will be omitted since they are similar to those in
In step S200, the number of bulks to be used in the bulk ACK MAP is set. The number of bulks may be addressed in bits for mapping, or selected by using various options.
As to setting the number of the bulks, the respective bulks may have different bit values for the lengths of the respective bulks.
The number of the bulks may be set to be more than two, but it is set to be a first bulk and a second bulk for ease of description.
In steps S210 and S220, bulk types of the first and second bulks are set. The bulk type determines whether the bulk is ACKed or NACKed. The bulk type may be set corresponding to a plurality of bulks by using an additional field, or may be set to be alternately ACKed and NACKed according to a predefined order. In addition, a Bulk Flag may be used to determine the bulk type of each bulk.
The bulk type of the first bulk is set to be NACK, and the bulk types of from the second bulk are defined by using the Bulk Flag.
The lengths of the first and second bulks are estimated and mapped. The number of bits assigned to respectively indicate the lengths of the first and second bulks may be varied depending on the number of the bulks, in steps S230 and S240.
A bulk ACK MAP is generated, and the bulk ACK MAP includes information on the number of the bulks, the bulk type, and the length of the bulks, in step S250.
When the bulk ACK MAP is generated, the bulk ACK MAP is sent as a feedback message together with the ACKed BSN estimated in step S120, in step S250.
As described, the method for transmitting a feedback message for ARQ is realized by using the ARQ transmitter and the buffer. In other words, the ACK MAP and the bulk ACK MAP are generated by using conventional cumulative ACK messages for the blocks stored in the buffer and checking bitmaps after the last BSN of the ACKed blocks according to the embodiments of the present invention. A configuration of the conventional cumulative and selective ACK-enabled receiver may be applied to realize the ACK MAP and the bulk ACK MAP, and this application will be appreciated by those skilled in the art.
A program including the foregoing functions is recorded in a readable recording medium for controlling the ARQ receiver.
According to the foregoing configurations of the present invention, overhead of a conventional ARQ feedback message is reduced while performing an efficient packet retransmission request.
While this invention has been described in connection with what is presently considered to be the most practical and preferred embodiments, it is to be understood that the invention is not limited to the disclosed embodiments, but, on the contrary, is intended to cover various modifications and equivalent arrangements included within the spirit and scope of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2003-0099026 | Dec 2003 | KR | national |
10-2004-0113343 | Dec 2004 | KR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/KR04/03510 | 12/29/2004 | WO | 5/30/2007 |