The present application relates to networks in general and in particular, to an application-layer method for automatic repeat request (ARQ) retransmission of real-time data streaming.
In multicast or broadcast applications, data are transmitted from a server to multiple receivers over wired and/or wireless networks. A multicast system as used herein is a system in which a server transmits the same data to multiple receivers simultaneously, where the receivers form a subset of all the receivers up to and including all of the receivers. A broadcast system is a system in which a server transmits the same data to all of the receivers simultaneously. That is, a multicast system by definition can include a broadcast system.
Data is usually formatted into packets and or frames for transmission. That is, packets and frames are data formatting schemes. As used herein data can be formatted into any convenient format for transmission including packets and/or frames.
Video transmission or distribution in wireless networks normally involves packet loss caused by channel error conditions such as interference, channel fading, collision, etc. When such channel error conditions occur, the wireless link layer of the protocol stack tries to retransmit packets for a fixed number of times within a fixed time period. If these retransmissions are not successful, the packets are dropped by the wireless link layer. Internet Protocol (IP) network based video transmission typically delivers video packets to the destination (receiver) using Real-time Transport Protocol (RTP) protocol that, in turn, uses either a reliable Transmission Control Protocol (TCP) transport protocol or a less reliable User Datagram Protocol (UDP) transport protocol. When the less reliable UDP protocol is used, the protocol does not provide a means to detect out of order packets or recover lost packets and leaves the responsibility to the application to recover packet delivery errors. In contrast, when TCP protocol is used, end to end acknowledgements are provided so that the protocol tries to send and/or recover media (audio, video, multimedia, . . . ) packets (data) strictly in the order in which the packets are to be handled by the application. When packet errors are detected, TCP's sliding window mechanism activates the flow control and reduces the packet transmission rate. TCP keeps retransmitting the lost packets until they are recovered. Since the video transmission has to occur in real time and has user viewing experience associated with the receipt and rendering of the data, there is a latency or time constraint within which the packets have to be delivered or recovered so as to not impact the end user's viewing experience. Therefore, it is apparent that packet errors have to be recovered within a limited time otherwise the data is not useful to the end user. With TCP there is no way for an application to control the packet recovery based on a time constraint. Using TCP as the transport protocol for wireless networks could lead to a poor user viewing experience. Furthermore, TCP requires positive acknowledgement for all the transmitted data packets. The TCP uplink acknowledgements (from data receiver to data transmitter (sender)) will compete for the wireless bandwidth with downlink data traffic (from transmitter (sender) to receiver). If collisions occur among downlink and uplink transmissions, the collisions could lead to further throughput reduction.
In one prior art scheme, a block-based application-layer Forward Error Correction (FEC) mechanism was proposed. Application-layer FEC mechanism works on packet levels such as RTP or UDP packets. It is different from the physical layer FEC and applies FEC codes across multiple data packets to generate redundant parity packets on the server (transmitter, sender) side. The transmitter sends out both data packets and FEC packets to the target receivers. On the receiver side, the FEC decoder tries to reconstruct missing packets by using received data packets and FEC packets. For this scheme to be efficient it is essential that it adapts to time varying channel conditions. However, the challenge is how to predict the channel conditions in advance and to adapt the FEC code to the varying channel conditions efficiently and reliably. If underestimation occurs, lost packets cannot be recovered. However, if overestimation occurs, bandwidth is wasted. Therefore, this method is difficult to fine tune without compromising either reliability or bandwidth.
In other prior art schemes, variations of Automatic Repeat Request (ARQ) have been proposed for packet loss recovery. Automatic Repeat Request is an error control method for data transmission. In one approach, a positive acknowledgment with timeouts is used in the ARQ scheme to achieve reliable data transmission. A positive acknowledgment (ACK) is sent by the receiver to the transmitter to indicate that the receiver has correctly received a data frame or packet. The transmitter also maintains a timeout timer that is a reasonable point in time after the transmitter sends the data frame or packet. If the transmitter does not receive an acknowledgment before the timeout, the transmitter usually re-transmits the data frame or packet until the transmitter receives an acknowledgment or exceeds a predefined number of re-transmissions. In this approach, the amount of acknowledgement data packet or frame traffic from the receiver and transmitter is high when the packet loss rate is low (most of data packets/frames are correctly received and need to be acknowledged). The acknowledgement data packets or frames will compete for the wireless bandwidth with data packets or frames. In addition, collisions may occur between the transmissions of data packets and acknowledgement packets.
In yet another prior art approach, the negative acknowledgement (NACK) is sent by the receiver to the transmitter to indicate that it has not correctly received a data frame or packet. Once the transmitter receives the NACK, the transmitter retransmits the lost data packet or frame to the receiver. The amount of NACK traffic from the receiver and transmitter is low when the packet loss rate is low, leading a more efficient utilization of network resources including bandwidth. However, the NACK data packets or frames themselves may be lost. If this occurs, the transmitter would not retransmit the lost data packets or frames, causing low reliability.
It would be advantageous to have an efficient method to provide reliability to UDP based video transmission by requesting only the lost packets from the original transmitter (sender) and trying to recover packets within a time constraint acceptable to the application thus enhancing the reliability and system throughput, and improving the overall user viewing experience of real-time applications.
This present invention is directed to a method at the transport or application layer to increase the reliability of real time video streaming in networks. Video streaming is used here as a specific example of real-time data streaming. Real-time data streaming may include any type of data including audio, video, multimedia or any combination thereof. The method of the present invention is not specific to wireless networks or wireless local area networks. It can be deployed for wired line or wireless networks. Wireless networks are used as an exemplary deployment. The method of the present invention provides an efficient means to recover lost packets in networks that are characterized by packet losses caused by various channel errors, thus enhancing the reliability and quality of video transmissions. The method of the present invention provides an efficient method to provide reliability to UDP based video transmission by requesting only the lost packets from the original transmitter (sender) and trying to recover packets within a time constraint acceptable to the application thus enhancing the reliability and system throughput, and improving the overall user viewing experience of real-time applications.
The present invention provides a method, which combines the advantages of a positive ACK with timeouts and negative acknowledgements. The NACK is used for initial transmissions. But the NACK packets or frames and the retransmitted data packets or frames are sent using an ACK with timeout on a separate TCP channel. The present invention uses TCP to provide a reliable error recovery path and also take the application's real-time constraints into consideration by enforcing an upper bound on the recovery time window.
A method and apparatus are described including buffering data to be transmitted, transmitting data retrieved from a buffer via a datagram protocol, receiving a request for retransmission of data, determining if the requested data is in the buffer and retransmitting the requested data via a protocol that provides end-to-end acknowledgement of data and error recovery.
The present invention is best understood from the following detailed description when read in conjunction with the accompanying drawings. The drawings include the following figures briefly described below:
Video transmission or distribution in wireless networks typically use RTP, motion picture expert group 2 transport stream (MPEG2TS) over UDP and could be distributed from a single source to a single destination (unicast mode) or from a single source to multiple destinations (multicast mode). Since channel conditions vary in wireless networks, packet transmissions, when the channel conditions are not good, result in dropped packets if the link layer error recovery is not successful. In these situations there is a gap in the packet sequence resulting in poor viewing quality for the end user. The present invention provides an efficient application-layer based retransmission scheme, called reliable media protocol (RMP) herein, to recover packet losses to aid in reliable real-time streaming applications.
In the reliable media protocol (RMP) method of the present invention, the regular unicast and multicast data or packet transmissions make use of UDP. Apart from this, an additional reliable TCP-based control channel is established between the source (transmitter, sender) and the destination (receiver, sink) to request and receive the retransmission of lost packets. For this mechanism to work properly, the transmitter (sender) maintains a cache of the most recent packets that were sent to its receivers. One or more receivers receive the data packets from the transmitter and detect sequence gaps in the received data packets using the sequence number field present in the RTP or MPEG transport stream (TS) header. If the receiver detects a sequence gap, the receiver sends a request on the TCP-based control channel for selective retransmission of the missing data packets. When the transmitter receives a retransmission request from one or more of its receivers, it looks in its local cache of most recent packets. If the requested packet(s) is/are found in the local cache, the sender retransmits in unicast a copy of the packet to the receiver on the TCP-based control channel. If the requested packet was not found in its local cache, the sender continues servicing the rest of the retransmission requests. The receiver maintains a delivery queue (buffer) to hold all of the received data packets from both data and control channels and reorders the retransmitted packet into the correct sequence (position) within this queue and delivers the packets to the application in the proper order at the correct time. The receiver maintains a configurable time window to wait for any retransmissions rather than waiting forever so that the packet delay and delay jitter can be kept within the application bounds. This implies that the receiver passes the rest of the received packets from the delivery queue to the application if some of the retransmission replies for the lost packets are not received in time. If some of the retransmitted packets are received beyond the acceptable recovery time window they are discarded by the receiver. It should be noted that the video application can tolerate some data packet loss using error concealment technology in video decoding.
The flowcharts for the sender side and receiver side operations in accordance with the present invention are depicted in
Referring again to
Referring again to
Referring again to
Referring again to
Referring again to
The RMP method of the present invention may be implemented in a flexible software library, hardware, firmware, any computer or processor, an application specific integrated circuit (ASIC), a reduced instruction set computer (RISC), a filed programmable gate array (FPGA) or an combination thereof. The RMP method of the present invention uses socket-like user-space APIs and underlying transport means for easy integration with streaming server and player applications. The RMP method of the present invention is transparent to the streaming applications that it supports. The UDP data channel and the TCP control channel are internally maintained. The RMP method of the present invention is extensible to support other error recovery schemes such as FEC and hybrid ARQ.
The exemplary format of the messages exchanged for retransmission request and reply is shown in
In the RMP scheme of the present invention described above, no alterations are made to the packets sent on the data channel. Thus, backward compatibility is maintained. Also the RMP scheme of the present invention makes efficient use of the bandwidth since only the lost media packets are requested and retransmitted on the control channel with low overhead. The lost packet requests serve as NACKs (Negative Acknowledgements) and also provide feedback to the sender. It can provide high reliability under widely different channel conditions because a lost packet can be retransmitted multiple times within the recovery time window. Also the RMP scheme of the present invention enforces the application's latency constraint by having a maximum wait time, i.e. recovery window, for retransmissions and thus operates on the best effort delivery model within the given time constraint.
Note that the above embodiment is explained using video transmission. The present invention can also be applied to transmission of audio and other real-time multimedia streaming applications.
Though the above scheme of the present invention has been described with respect to wireless networks, the scheme could be used in any kind of network that involves packet losses.
It is to be understood that the present invention may be implemented in various forms of hardware, software, firmware, special purpose processors, or a combination thereof. Preferably, the present invention is implemented as a combination of hardware and software. Moreover, the software is preferably implemented as an application program tangibly embodied on a program storage device. The application program may be uploaded to, and executed by, a machine comprising any suitable architecture. Preferably, the machine is implemented on a computer platform having hardware such as one or more central processing units (CPU), a random access memory (RAM), and input/output (I/O) interface(s). The computer platform also includes an operating system and microinstruction code. The various processes and functions described herein may either be part of the microinstruction code or part of the application program (or a combination thereof), which is executed via the operating system. In addition, various other peripheral devices may be connected to the computer platform such as an additional data storage device and a printing device.
It is to be further understood that, because some of the constituent system components and method steps depicted in the accompanying figures are preferably implemented in software, the actual connections between the system components (or the process steps) may differ depending upon the manner in which the present invention is programmed. Given the teachings herein, one of ordinary skill in the related art will be able to contemplate these and similar implementations or configurations of the present invention.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US09/05499 | 10/7/2009 | WO | 00 | 3/13/2012 |