This application is a U.S. National Stage Application of and claims priority to International Patent Application No. PCT/US2011/055223, filed on Oct. 7, 2011, and entitled “COMMUNICATION OVER A WIRELESS CONNECTION”.
Wireless network communication technologies enable users to travel to various places (e.g., meeting rooms, classrooms) and still have access to the Internet. As wireless technologies gain popularity, more and more time sensitive data (e.g., real-time audio/video streams) are transmitted over wireless connections.
The present subject matter is now described more fully with reference to the accompanying figures, in which several embodiments of the subject matter are shown. The present subject matter may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Rather these embodiments are provided so that this disclosure will be complete and will fully convey principles of the subject matter.
It is often desirable for receiving devices (also called “receivers”) of time sensitive data such as real-time audio/video streams to receive a group of data packets without delay. For example, a receiver decodes a frame in a video stream typically after receiving all packets containing data of that frame. Sending devices (also called “senders”) typically arrange data transmission to optimize average throughput of wireless networks and cannot ensure that packets in a time sensitive packet group (e.g., packets of a same frame) are sent together through a wireless connection, and therefore may cause undesirable transmission delays in between the packets. Thus, a way to transmit time sensitive data over wireless connections that reduces transmission delay is desirable.
The application module 110 packetizes framed data into packets and sends the packets to the wireless module 120 for transmission. Framed data are data that include multiple data frames, each of which can be processed relatively independently. Example framed data are audio/video streams that include audio/video frames. Packets containing data of a data frame form a time sensitive packet group. A wireless connection is a communication channel established between two devices in a wireless network (e.g., a WiFi network, a WiMAX network, a mobile telephone network).
In one example, the application module 110 receives a live video stream (e.g., from an on-device video camera), packetizes frames in the video stream (the data frames) into packets, and sends the packets to the wireless module 120 for transmission. The application module 110 also provides the wireless module 120 with signals about information such as whether a packet contains a data frame boundary (e.g., the packet contains an end section of a data frame, also called an “end-of-frame packet”), and whether the data in the packet are time sensitive. To signal the presence of a data frame boundary in a packet, the application module 110 may generate and send an out-of-band “end-of-frame” signal (e.g., by calling a dedicated function supported by the wireless module 120) to the wireless module 120 indicating that an end-of-frame packet has just been sent to the wireless module 120. Alternatively or additionally, the application module 110 may send the signal in-band by marking an “end-of-frame” flag (or field, bit(s)) of the packet. Similarly, the application module 110 may send an out-of-band “time sensitive” signal and/or set an in-band “time sensitive” flag to signal the wireless module 120 that a packet contains time sensitive data. The application module 110 also depacketizes packets received by the wireless module 120 and reconstructs data from these packets.
The application module 110 may generate parity packets for packets containing framed time sensitive data. A parity packet is a packet generated for a set of packets to detect and/or correct transmission errors of the set (e.g., compensating for lost packets). The parity packets can be generated using techniques such as the Forward Error Correction (FEC). Because retransmitting lost packets in a wireless network often involves regaining a right-to-transmit, which is a resource expensive operation, and the cost of generating and transmitting parity packets once the right-to-transmit has been acquired is often negligible, it may be desirable to generate and transmit parity packets to avoid retransmitting lost packets. The wireless module 120 may generate one or more parity packets for a time sensitive packet group, and include the parity packets in the group. The application module 110 may identify the parity packets to the wireless module 120 using an in-band “parity” flag and/or an out-of-band “parity packet” signal similar to end-of-frame packets. Additionally or alternatively, the application module 110 may send a signal to the wireless module 120 regarding a parity ratio for a time sensitive packet group (e.g., the ratio between the number of parity packets in the group and the group size).
The wireless module 120 receives packets from the application module 110 and transmits the packets to the intended receiver(s) over a wireless connection. In one example, the wireless module 120 implements a wireless media access control (“MAC”) layer (e.g., a sub-layer of the data-link layer in the Open Systems Interconnection (“OSI”) model) that implements one or more wireless protocols such as IEEE 802.11.
To reduce transmission delays of framed time sensitive data, the wireless module 120 aggregates packets as they are received from the application module 110 and transmits outstanding packets (e.g., packets received from the application module 110 and not yet transmitted out) together over a wireless connection based on factors such as the size of the outstanding packets and whether data frame boundaries exist in the outstanding packets. The wireless module 120 detects the presence of data frame boundaries in outstanding packets by determining whether any of the packets contains an end section of a data frame (e.g., according to the end-of-frame signal(s)/flag(s)). In one example, the wireless module 120 detects data frame boundaries in packets containing time sensitive data. Whether a packet contains time sensitive data can be determined by the wireless module 120 according to the time sensitive signal/flag. If the outstanding packets are determined to include data frame boundaries and/or the size of the outstanding packets exceeds a threshold value (e.g., to satisfy throughputs), the wireless module 120 transmits the outstanding packets together (e.g., in a single transmission frame such as a MAC frame) over a wireless connection. The threshold value can be determined based on factors such as the transmission rate of the wireless connection (e.g., a higher threshold value for a faster transmission rate), and can be within the range of 2 to 22. By transmitting outstanding packets including a data frame boundary without waiting for packets of subsequent data frames, the wireless module 120 may beneficially lowers communication delay for the framed time sensitive data.
To further reduce transmission delays, the wireless module 120 may generate parity packets to packets containing framed time sensitive data. As described above, the application module 110 may also generate and send parity packets to the wireless module 120. The wireless module 120 may identify parity packets in the outstanding packets based on “parity packet” signals/flags, or determine parity ratios for time sensitive packet groups. When a block acknowledgement message indicates that one or more data packets in a time sensitive packet group were lost, the wireless module 120 determines whether the parity packets are sufficient for the receiver to recover the lost packets, and retransmits those lost packets if the parity packets are insufficient for recovery. For example, if the number of lost packets for a time sensitive packet group exceeds the number of parity packets in the group, or the ratio of lost packets for the group exceeds the parity ratio of the group, then the wireless module 120 determines that the parity packets are insufficient and retransmits the lost packets.
In one example, the wireless module 120 adds parity packets if there is no backlog of outstanding packets (e.g., the size of the outstanding packets exceeds the threshold value). If the size of the outstanding packets exceeds the threshold value, then the wireless module 120 does not transmit parity packets since a right-to-transmit will be requested for transmitting the remaining backlog packets anyway, and the cost of adding retransmission of lost packets to the backlog is insignificant. The wireless module 120 (and the application module 110) can be configured to either always add parity packets or add parity packets when the size of the outstanding packets does not exceed the threshold value.
The wireless module 120 determines whether any packet for a data frame has been lost during transmission (e.g., by analyzing a block acknowledgement message) in step 340. If no packet has been lost, then the wireless module 120 repeats the method 300 for subsequently received packets. Otherwise, if at least one packet was lost, the wireless module 120 determines in step 350 whether the transmitted parity packets are sufficient for the receiver to recover the lost packets. Continuing with the above example, if 1 of the 7 packets in a time sensitive packet group was lost, because there is 1 parity packets in the group, and the receiver can recover the lost packet using the remaining 6 packets, the wireless module 120 determines that the parity packets are sufficient for recovery. However, if 2 or more packets in the group were lost, then the wireless module 120 determines that the parity packets are insufficient for recovery. If the transmitted parity packets are determined sufficient for recovery, then the wireless module 120 does not retransmit the lost packets and repeats the method 300 for subsequent received packets. Otherwise, if the transmitted parity packets are determined insufficient, the wireless module 120 retransmits the lost packets in step 360.
The described implementations beneficially reduces transmission delay of time-sensitive data in communications over wireless connections by aggregating and transmitting packets based on presence of data frame boundaries and determining whether to retransmit lost packets based on transmitted parity packets. Because the described implementations are compatible with receivers that implements standard wireless protocols, the receivers may enjoy the reduced transmission delay without making any change.
In one example, the entities shown in
The storage device 460 is a non-transitory computer-readable storage medium such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device. The memory 430 holds instructions and data used by the processor 410. The pointing device 480 is a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 470 to input data into the computer system 400. The graphics adapter 440 displays images and other information on the display 450. The network adapter 490 couples the computer system 400 to one or more computer networks.
The computer system 400 is adapted to execute computer program modules for providing functionality described herein. As used herein, the term “module” refers to computer program logic used to provide the specified functionality. Thus, a module can be implemented in hardware, firmware, and/or software. In one embodiment, program modules are stored on the storage device 460, loaded into the memory 430, and executed by the processor 410.
The types of computer systems 400 used by entities can vary depending upon the embodiment and the processing power required by the entity. For example, the wireless communicating system 100 might comprise a mobile telephone with limited processing power. A computer system 400 can lack some of the components described above, such as the keyboard 470, the graphics adapter 440, and the display 450.
One skilled in the art will recognize that the configurations and methods described above and illustrated in the figures are merely examples, and that the described subject matter may be practiced and implemented using many other configurations and methods. It should also be noted that the language used in the specification has been principally selected for readability and instructional purposes, and may not have been selected to delineate or circumscribe the inventive subject matter. Accordingly, the disclosure of the described subject matter is intended to be illustrative, but not limiting, of the scope of the subject matter, which is set forth in the following claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2011/055223 | 10/7/2011 | WO | 00 | 3/17/2014 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2013/052060 | 4/11/2013 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5151902 | Grallert | Sep 1992 | A |
5905756 | Lamkin et al. | May 1999 | A |
6357028 | Zhu | Mar 2002 | B1 |
6977888 | Frenger et al. | Dec 2005 | B1 |
6996083 | Balachandran et al. | Feb 2006 | B1 |
7016971 | Recio et al. | Mar 2006 | B1 |
7096400 | Lim et al. | Aug 2006 | B2 |
7443797 | Cheung et al. | Oct 2008 | B2 |
7554977 | Parizhsky et al. | Jun 2009 | B2 |
7564819 | Khan | Jul 2009 | B2 |
8392800 | Etkin | Mar 2013 | B2 |
9014744 | Chu et al. | Apr 2015 | B2 |
20020114283 | Lee | Aug 2002 | A1 |
20040072552 | Park et al. | Apr 2004 | A1 |
20040181618 | Dottling et al. | Sep 2004 | A1 |
20060215561 | Wang et al. | Sep 2006 | A1 |
20070029994 | Dembo | Feb 2007 | A1 |
20070064733 | Osawa et al. | Mar 2007 | A1 |
20070115894 | Herrmann et al. | May 2007 | A1 |
20090100309 | Zheng | Apr 2009 | A1 |
20090282309 | Yue et al. | Nov 2009 | A1 |
20090323547 | Caesar et al. | Dec 2009 | A1 |
20100017674 | Mo et al. | Jan 2010 | A1 |
20100039982 | Itagaki et al. | Feb 2010 | A1 |
20100094931 | Hosur et al. | Apr 2010 | A1 |
20100214970 | Brunner et al. | Aug 2010 | A1 |
20100296428 | Ho | Nov 2010 | A1 |
20110083035 | Liu et al. | Apr 2011 | A1 |
20110099446 | Murakami | Apr 2011 | A1 |
20120092443 | Mauchly | Apr 2012 | A1 |
20120163354 | Stacey et al. | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
10-2010-0064062 | Jun 2010 | KR |
WO-9915973 | Apr 1999 | WO |
WO-2009037113 | Mar 2009 | WO |
Entry |
---|
International Preliminary Report on Patentability, Apr. 17, 2014, The International Bureau of WIPO, PCT Patent Application No. PCT/US2011/055223. |
English Translation (machine-generated) of Abstract of Korean Patent Publication No. 10-2010-0064062A [retrieved on Feb. 27, 2014], Retrieved from the Internet: <http://worldwide.espacenet.com/publicationDetails/biblio?DB=worldwide.espacenet.com&II=0&ND=3&adjacent=true&locale=en—EP&FT=D&date=20100614&CC=KR&NR=20100064062A&KC=A>. |
International Search Report and Written Opinion, Apr. 18, 2012, PCT Application No. PCT/US2011/055223. |
Miu et al., Low-latency Wireless Video Over 802.11 Networks Using Path Diversity [online], IEEE ICME, Jul. 2003, Retrieved from the Internet: <http://www.google.co.in/url?sa=t&source=web&cd=3&ved=0CCcQFjAC&url=http%3A%2F%2Fciteseerx.ist.psu.edu%2Fviewdoc%2Fdownload%3Fdoi%3D10.1.1.3.3297%26rep%3Drep1%26type%3Dpdf&ei=y92—TfilOcqX8QO0mujVBQ&usg=AFQjCNHKsQPfnYjQpXiVZ—mhAtkhto1Whg> [retrieved on Feb. 27, 2014]. |
Number | Date | Country | |
---|---|---|---|
20140341202 A1 | Nov 2014 | US |