Wireless communications with efficient retransmission operation
Automatic repeat request (ARQ) operations can be implemented in wireless communications by sending (2401) a plurality of data packets in a superpacket, and responding (2430) with an acknowledgement packet that indicates which packets of the superpacket require retransmission.
This application claims the priority under 35 U.S.C. 119(e)(1) of the following copending U.S. provisional applications: 60/210,851 filed on Jun. 9, 2000; Ser. No. 60/215,953 filed on Jul. 5, 2000; Ser. Nos. 60/216,290 60/216,436, 60/216,291, 60/216,292, 60/216,413 and 60/216,433 filed on Jul. 6, 2000; Ser. Nos. 60/217,269, 60/217,272 and 60/217,277 filed on Jul. 11, 2000; and Ser. No. 60/228,860 filed on Aug. 29, 2000. All of the aforementioned provisional applications are hereby incorporated herein by reference.
This application is related to the following copending applications filed contemporaneously herewith by the inventors of the present application: Docket Nos. TI-31284 and TI-31285 respectively entitled “Wireless Communications with Efficient Channel Coding” and “Wireless Communications with Frequency Band Selection”.
FIELD OF THE INVENTIONThe invention relates generally to wireless communications and, more particularly, to wireless communications that utilize: channel coding; multiple data rates; multiple modulation and channel coding schemes; or automatic repeat request (ARQ).
BACKGROUND OF THE INVENTIONThe IEEE 802.15 Task Group 3 has outlined requirements for a high rate wireless personal area network (WPAN). Various data rates are to be provided to support, for example, audio, video, and computer graphics.
The present invention provides for a WPAN that supports data rates for a variety of applications including audio, video and computer graphics. According to the invention, a probe, listen and select technique can be used advantageously to select from an available frequency spectrum a frequency band whose communication quality is suitable for communication at a desired data rate. Probe packets are transmitted on different frequencies during a known period of time, and frequency channel quality information is obtained from the probe packets. This quality information is used to select a desirable frequency band. The communication quality of the selected band can also be used as a basis for selecting from among a plurality of modulation and coding combinations that are available for use in communication operations. Further according to the invention, ARQ operations can be implemented by sending a plurality of data packets in a superpacket, and responding with an ARQ acknowledgement packet that indicates which packets of the superpacket require retransmission. Further according to the invention, a data encoding algorithm can be used to generate redundant (overhead) bits from original data bits, and the data bits and redundant bits can be sent in respectively separate transmissions, if the redundant bits are needed. At the receiver, the original data bits can be determined from the received redundant bits, or the received data bits and the received redundant bits can be combined and decoded together to produce the original data bits.
BRIEF DESCRIPTION OF THE DRAWINGS
The invention includes a PHY layer solution to the IEEE 802.15 Task Group 3 that offers the best solution in terms of complexity vs. performance according to the criteria document of the IEEE P802.15 Working Group for Wireless Personal Area Networks (WPANs), ‘TG3-Criteria-Definitions”, 11th May 2000, which outlines requirements for high rate wireless personal area network (WPAN) systems, and which is incorporated herein by reference. The required data rates to be supported by a high rate WPAN according to the invention are specified in the aforementioned criteria document. The data rates for audio are 128-1450 kbps, for video are from 2.5-18 Mbps and for computer graphics are 15, 38 Mbps. Due to the wide range for the required data rates, and in order to have a cost-effective solution covering all the data rates, the invention provides for a two or three mode system in the 2.4 GHz band. The available modes include:
-
- (1) Mode 1 is a conventional Bluetooth 1.0 system giving a data rate of 1 Mbps.
- (2) Mode 2 uses the same frequency hopping (FH) pattern as Bluetooth but uses a 64 QAM modulation giving a data rate of 3.9 Mbps.
- (3) Mode 3 selects a good 22 MHz band in the 2.402-2.483 GHz ISM using a probe, listen and select (PLS) technique, and transmits up to 44 Mbps using direct sequence spread spectrum (DSSS).
Examples of system parameters according to the invention are summarized in
The mode 1 for the proposed system is conventional Bluetooth operation, which is described in detail in Specification of the Bluetooth System, Version 1.0A, Jul. 26, 1999, which is incorporated herein by reference.
In one example of operation in mode 1 and mode 2, a Bluetooth master and slave first synchronize to each other and communicate using mode 1 and then enter mode 2 upon negotiation.
An exemplary frame format structure for master to slave and slave to master transmissions in mode 2 is similar to mode 1 and is shown in
The master can communicate with multiple slaves in the same piconet, some slaves in mode 2 and others in mode 1, as shown in the exemplary WPAN of
A block diagram of exemplary receiver algorithms for acquisition and packet reception in mode 2 is shown in
A convolutional code of rate ½, K=5 is used at 101 in the example of
In the example of
The original data bits and corresponding CRC bits are then retransmitted at 129 and, if the CRC checks, the data bits are passed to higher layer. Otherwise, the retransmitted data bits plus CRC bits are combined with the parity bits (earlier-received at 123) for Viterbi decoding at 1200. If the data bits and corresponding CRC bits generated at 1200 by the Viterbi decoding algorithm produce a correct CRC result at 1201, then those data bits are passed to a higher layer. Otherwise, the parity bits that were transmitted at 123 are discarded, and retransmission of the parity bits is requested at 1202. Thereafter, the operations illustrated generally in the flow from 123 through 1202 in
If the CRC of the mapping result does not check correctly, then the controller 1206 signals a Viterbi decoder 1203 to load the parity bits and data (plus CRC) bits from the buffer 1204 and perform Viterbi decoding. The resulting data (plus CRC) bits output at 1208 from the Viterbi decoder 1203 are input to the CRC decoder 1205. If the CRC of the Viterbi-decoded data bits checks correctly, then the controller 1206 directs the Viterbi decoder to pass the Viterbi-decoded data bits to a higher layer at 1209. On the other hand, if the CRC of the Viterbi-decoded data bits does not check correctly, then the controller 1206 outputs another negative acknowledgment, to which the other end will respond by retransmitting the original data (plus CRC) bits (see 129 in
Exemplary simulation results shown in
Exemplary communications between transceivers employing modes 1 and 3 can include the following: begin transmission in mode 1 and use PLS to identify good 22 MHz contiguous bands; negotiate to enter mode 3; after spending time T2 in mode 3 come back to mode 1 for time T1; the master can communicate with any Bluetooth devices during time T1 in mode 1; also during time T1 and while in mode 1, PLS can be used again to identify good 22 MHz bands; the devices again negotiate to enter mode 3, this time possibly on a different 22 MHz band (or the same band).
An example with T1=25 ms and T2=225 ms is shown in the state transition diagram of
A master can communicate with several devices in mode 1 while communicating with other devices in mode 3, as shown in the exemplary WPAN of
An exemplary timing diagram illustrating transmission in modes 1 and 3 is shown in
Since the Bluetooth (mode 1) transceiver 197 is capable of hopping at the maximum rate of 3200 hops/sec (each hop is on a 1 MHz band), this rate can be used for channel sounding. This means that the duration of each slot (master-to-slave or slave-to-master) is 312.5 microseconds. A pseudorandom hopping pattern is used in some embodiments. This pattern is chosen such that the entire 79 MHz range is sampled at a sufficient rate (e.g. in 5 MHz steps) to identify the best 22 MHz frequency band. Using this hopping pattern the master can, in mode 1 (Bluetooth), send the slave short packets, also referred to herein as probe packets, of the format shown in
Referring to the example of
The channel state of each 1 MHz band can be estimated, for example, by using the maximum value of the correlation of the access code or any known part of the probe packet. This gives a good estimate of the amplitude of the fading parameter in that 1 MHz channel. The best 22 MHz band can then be chosen using this information.
For example, for each contiguous 22 MHz frequency band, where the jth frequency band is designated f(j), a quality parameter qf(j) can be calculated as follows
where |αi| is the magnitude of the fading parameter amplitude estimate (e.g. a correlation value) for the ith frequency hop in f(j). The frequency band f(j) having the maximum qf(j) is taken to be the best band.
As another example, a quality parameter qf(j) can be calculated for each contiguous 22 MHz band as
qf(j)=min|αi|
and the band f(j) having the maximum qf(j) is selected as the best band.
As another example, the following quality parameters can be calculated for each contiguous 22 MHz band:
Af(i)=min|αi|
Bf(i)=max|αi|
Those frequency bands f(j) whose associated Af(j) and Bf(j) produce a ratio Af(j)/Bf(j) larger than a predetermined threshold value can be identified, and the one of the identified frequency bands having the largest qf(j) is taken to be the best band. The threshold value can be determined, for example, empirically on the basis of experimentation for desired performance in expected channel conditions.
Consider a PLS example with n=16 and k=8. This indicates that the 79 MHz band should be sampled in 5 MHz steps. The hopping pattern is therefore given by:
-
- o={0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75}.
The ith PLS frequency hop is defined to be f(i)=(x+o(i))mod(79); i=1, 2 . . . , 16
Here x is the index of the Bluetooth hopping frequency that would occur at the beginning of the PLS procedure, and can have values of x=0, 1, 2, . . . , 78. The index i can be taken sequentially from a pseudo random sequence such as:
-
- P={16, 4, 10, 8, 14, 12, 6, 1, 13, 7, 9, 11, 15, 5, 2, 3}.
Different pseudo random sequences can be defined for different values of n and k.
- P={16, 4, 10, 8, 14, 12, 6, 1, 13, 7, 9, 11, 15, 5, 2, 3}.
The 8 transmissions from the slave to the master can use, for example, the first 8 frequencies of the sequence f(i), namely f(i) for i=1, 2, . . . , 8.
The above exemplary procedure can be summarized as follows:
-
- 1. Master sends to the slave the probe packet on the frequencies determined by the sequence f(i). The transmit frequency is given by (2402+f(i)) MHz;
- 2. Slave estimates the quality of each channel;
- 3. After 16 master-to-slave probe packets, the slave estimates the best 22 MHz band using all the quality information it has accumulated;
- 4. The slave sends to the master a selection packet including the index of the lowest frequency of the best 22 MHz band;
- 5. The slave repeats step 4 a total of 8 times; and
- 6. Transmission starts in mode 3 using the selected 22 MHz band.
Example results of the PLS procedure applied to the exponentially fading IEEE 802.15.3 channel for a delay spread of 25 ns. are shown in
The mode controller of
Referring again to
In an example of one-way communications, and if ARQ (automatic repeat request) is used, the transmitting device can, for example, send a predetermined number of normal packets (also referred to herein as a superpacket). The number of normal packets in the superpacket can be agreed upon in initial handshaking. After receipt of the predetermined number of normal packets, the receiving device can, for example, send a short ARQ packet that is half the length of a normal packet. The ARQ packet can be preceded and followed by guard intervals (e.g. 100 microseconds). The ARQ packet serves to acknowledge the reception of the normal packets. Those packets whose CRC (cyclic redundancy code) did not check correctly are indicated in the ARQ packet. The transmitter can then send the requested packets again in a further superpacket. This procedure can be repeated until all packets get through or a time-out occurs.
Two-way mode 3 communication from master to slave and slave to master can be handled similarly, as illustrated in the example of
ARQ and retransmissions are optional. Retrasmissions can increase the mode 3 performance in the presence of an interferer (such as a Bluetooth device). Referring to
-
- 1. The master sends the slave a superpacket at 2401 including 100 packets with CRC at the end of each packet.
- 2. The slave uses the CRC at 2402 to determine if the packets were received without error.
- 3. The slave sends the master an ARQ packet that has a payload of 100 bits (see 2430, 2431 in
FIG. 24B ). Each bit corresponds to a received packet. The bit is 1 if the packet was received with no error, and is zero if it was received in error. A CRC is appended at the end of the ARQ packet. - 4. If the master receives the ARQ packet correctly at 2404, the master retransmits the requested packets (if any) to the slave (see 2405 in
FIG. 24B ). If the master does not receive the ARQ packet correctly at 2404 (as indicated, for example, by a failed CRC check), then - (a) the master sends the slave an ARQ packet of size 100 μsec. (see 2410 in
FIG. 24B ) asking for the slave's ARQ packet. - (b) the master then listens at 2404 for the slave's ARQ packet.
- (c) Steps (a) and (b) are repeated by the master until he receives at 2404 the slave's ARQ packet (sent at 2420 in
FIG. 24B ) and retransmits the requested packets, if any (see 2408), at 2405, or until the T2 time slot ends at 2406, at which time mode 1 communications begin. - 5. Steps 24 are repeated until all the packets are received by the slave correctly (see 2408) or the T2 time slot ends.
- 6. If the T2 time slot does not end during step 4 or step 5 (see 2409), the master sends new packets to the slave.
If the master finishes sending all its packets before the T2 time slot ends, it can go to mode 1 and communicate with other Bluetooth devices. For example, if MPEG 2 of rate 18 Mbps is being transmitted, six frames (250 ms of video) would require 204.5 ms at the rate of 22 Mbps. If T1+T2=250 ms, and 10 ms are used for retransmission requests and retransmissions, and if 7.5 ms is used for PLS, this would leave the master 28 ms for mode 1 Bluetooth communications.
Retransmissions for two-way communications (See
The contents of register 243 are also provided to an ARQ generator 245 which uses the register contents to fill the payload of an outgoing ARQ packet. When a superpacket including retransmitted packets is received, the retransmitted packets are buffered into their appropriate superpacket locations in buffer 241, and the CRC decoder 242 performs a CRC check for each retransmitted packet, providing the CRC results to the register 243.
An ARQ receiver 246 receives incoming ARQ packets and responds thereto either by prompting the ARQ generator 245 to send an appropriate ARQ packet, or by selecting requested packets of a previously buffered (see 247) outgoing superpacket for retransmission to the other side.
Point-to-multipoint communications can be achieved by time division multiplexing between various slaves. Each time slot for each slave can be preceded by a PLS slot between the master and the concerned slave.
In some embodiments, each 200 lisec. length packet in
Several of the packets in
The preamble of the
It should be understood that the above-described slot and packet formats are exemplary only and that, for example: the packet length can be set to any desired length; a different size polynomial can be used for the CRC; and a different size training sequence can be used with the preamble, sync word and header sized as desired. It should also be understood that the above-described slot and packet formats are readily applicable to two-way communications.
The exemplary slot and packet formats described above permit, for example, transmission of HDTV MPEG2 video at 18 Mbps. Assume, for example, that 24 frames/sec. is transmitted for MPEG 2 video. Thus, the master transmits to the slave 100 packets each of length 200 μsec. carrying a data payload of 2184 symbols. Assuming, for example, that 10 such packets are preceded by the training sequence of 81 symbols (
The receiver algorithms for acquisition and packet reception in mode 3 are similar to mode 2. An exemplary block diagram of mode 3 receiver algorithms is shown in
An exemplary transmitter embodiment for mode 3 is shown in
In some exemplary embodiments, modulation options such as QPSK, 16-QAM and 8-PSK (8-ary phase shit keying) can be used in mode 3, as shown in
The exponentially delayed Rayleigh channel example shown in
hi=N(0, σk2/2)+jN(0, σk2/2)
σk2=σ02e−kT
σk2=1−e−T
TRMS=25
This channel model requires equalization (at the outputs of the filters 305 in
A block diagram of an exemplary MMSE (minimum mean squared error) equalizer section is shown in
The exemplary MAP equalizer section of
Video transmission typically requires a BER of 10−8, so turbo coding is used to achieve this error rate. Parallel concatenated convolutional codes (PCCC) are known to have an error floor at about 10−7, while serial concatenated convolutional codes (SCCC) do not have an error floor and can meet the BER requirements. The SCCC in FIG. 37 is conventional, and was originally proposed by Divsalar and Pollara in “Serial and Hybrid Concatenated Codes with Applications,” Proceedings International Symposium of Turbo Codes and Applications, Brest, France, September 1997, pp. 80-87, incorporated herein by reference.
Exemplary results of Monte-Carlo simulations for mode 3 are given in
Due to typical transceiver size constraints, a single antenna may be desirable for transmit and receive according to the invention. However, it is possible to use two antennas for transmit and receive diversity. Simple schemes like switched diversity can be easily incorporated in a given transceiver device according to the invention, while also being transparent to other devices (e.g. in a Bluetooth piconet). The modulation techniques described above are also applicable to more complex transmit diversity techniques such as, space time coding, beam forming and others.
The aforementioned modulation schemes of the invention also allow more complex coding schemes like parallel concatenated trellis coded modulation (PCTCM) and serially concatenated trellis coded modulation (SCTCM). Also, a lower complexity trellis code (which can perform better than the turbo coding of
As discussed above, FIGS. 10 (receiver) and 11 (transmitter) illustrate an exemplary transceiver for mode 2. Many parts of the mode 2 receiver, for example, the front end filter 105, LNA 106, RF/IF converter 107, and the SAW filter 108 can be shared with mode 1. The baseband for a mode 2 receiver requires additional logic (beyond mode 1) for receive filtering, AGC, timing acquisition, channel estimation, QAM demodulation and Viterbi decoding in the case of ARQ. In some embodiments, the extra gate count for this additional logic is approximately 10,000 gates.
As discussed above, FIGS. 30 (receiver) and 31 (transmitter) illustrate an exemplary transceiver for mode 3. Many parts of the mode 3 receiver, for example, the front end filter 308, LNA 306, and RF/IF converter 302 can be shared with mode 1. The implementation of mode 1+mode 3 will require an additional SAW filter over a mode 1 implementation because of the larger bandwidth of mode 3 compared to mode 1. The baseband for a mode 3 receiver requires additional logic (beyond mode 1) for AGC, timing acquisition, channel estimation, QAM demodulation, equalization and turbo decoding. In some embodiments, the extra gate count for this additional logic is approximately 100,000 gates.
It will be evident to workers in the art that exemplary transceiver embodiments according to the invention can be realized, for example, by making suitable hardware and/or software modifications in a conventional Bluetooth MAC. Some exemplary advantages provided by the invention as described above are listed below.
Interoperability with Bluetodth: a high rate WPAN piconet according to the invention can accommodate several mode 1 (Bluetooth) and mode 2 or mode 3 devices simultaneously.
High Throughput: in mode 3 a high rate WPAN according to the invention supports 6 simultaneous connections each with a data rate of 20 Mbps giving a total throughput of 6×20=120 Mbps over the whole 2.4 GHz ISM band. In mode 2 the high rate WPAN supports the same number of connections as Bluetooth with a data rate of up to 4 Mbps each.
Coexistence: there is only a 10% reduction in throughput for Bluetooth in the vicinity of an exemplary WPAN according to the invention. The PLS technique implies a 0% reduction in throughput for IEEE 802.11 in the vicinity of a WPAN according to the invention because PLS will select a different frequency band.
Jamming Resistance: the PLS technique helps avoid interference from microwave, Bluetooth and IEEE 802.11, thus making it robust to jamming.
Low Sensitivity Level: exemplary sensitivity level for mode 2 is −78 dBm and for mode 3 is −69 dBm.
Low Power Consumption: the estimated power consumption for mode 2 in year 2001 is 25 mW average for receive and 15 mW average for transmit, and the estimated power consumption for mode 3 in year 2001 is 95 mW average for receive and 60 mW average for transmit.
Although exemplary embodiments of the invention are described above in detail, this does not limit the scope of the invention, which can be practiced in a variety of embodiments.
Claims
1-18. (canceled)
19. A method, comprising the steps of:
- transmitting a superpacket from a first communication transceiver to a second communication transceiver; and
- transmitting, responsive to said second communication transceiver receiving said superpacket, an acknowledgement packet from said second communication transceiver to said first communication transceiver indicating whether retransmission of respective packets of said superpacket is required.
20. The method of claim 19, wherein said superpacket is transmitted from, first communication transceiver to said second communication transceiver via a wireless communication link.
21. The method of claim 19, wherein said acknowledgement packet is transmitted from second communication transceiver to said first communication transceiver via a wireless communication link.
22. The method of claim 19, wherein said acknowledgement packet includes a payload.
23. The method of claim 22, wherein said payload includes a plurality of bits which respectively correspond to the packets of said superpacket.
24. The method of claim 23, wherein bit values of said plurality of bits indicate whether retransmission of the respectively corresponding packets is required.
25. The method of claim 24, including determining from said payload of the acknowledgement packet whether any packets of the superpacket are to be retransmitted, and the first transceiver retransmitting in another superpacket any packets that are determined from the acknowledgement packet to require retransmission.
26. The method of claim 25, including transmitting, responsive to said second communication transceiver receiving said another superpacket, an acknowledgement packet from said second communication transceiver to said first communication transceiver indicating whether retransmission of respective packets of said another superpacket is required.
27. The method of claim 19, wherein an error detection procedure is used by said second transceiver to determine whether retransmission of any packets of the superpacket is required.
28. The method of claim 27, wherein said using step includes using a cyclic redundancy code for determining whether retransmission of any packets of the superpacket is required.
29. The method of claim 19, including transmitting, from the first transceiver to the second transceiver, a packet requesting transmission of the acknowledgment packet if the first transceiver determines that the acknowledgment packet has not been received correctly and that a time period for receiving the acknowledgment packet has not expired.
30. The method of claim 29, including repeating said step of transmitting the packet requesting transmission of the acknowledgment packet until an occurrence of one of a correct receipt of the acknowledgement packet and an expiration of the time period.
31. The method of claim 29, wherein said packets of said superpacket include at least one of audio information, video information and computer graphics information.
32. The method of claim 23, wherein said payload bits are repetition coded in said acknowledgement packet.
33. An apparatus, comprising:
- an input for receiving a superpacket from another apparatus;
- an acknowledgment generator coupled to said input and responsive to said superpacket for producing an acknowledgment packet; and
- an output coupled to said acknowledgment generator for outputting said acknowledgment packet for transmission to said another apparatus.
34. The apparatus of claim 33, wherein said apparatus receives said superpacket via wireless communication.
35. The apparatus of claim 33, wherein said superpacket includes a plurality of packets;
36. The apparatus of claim 33, wherein said acknowledgment packet has a payload.
37. The apparatus of claim 36, wherein said payload includes a plurality of bits which respectively correspond to the packets of said superpacket.
38. The apparatus of claim 37, wherein bit values indicate whether retransmission of the respectively corresponding packets is required.
39. The apparatus of claim 33, wherein said acknowledgment packet is transmitted from said apparatus via wireless communication.
40. The apparatus of claim 35, including an error detector coupled to said input for determining whether any of the packets of said superpacket have been received incorrectly, said error detector coupled to said acknowledgment generator for providing thereto information indicative of any packets of said superpacket that have been received incorrectly.
41. The apparatus of claim 40, including a register coupling said error detector to said acknowledgment generator for receiving said information from said error detector and providing said information to said acknowledgment generator.
42. The apparatus of claim 41, wherein said acknowledgment generator is operable for inserting said information received from said register into said payload of said acknowledgment packet.
43. The apparatus of claim 35, wherein said packets include at least one of audio information, video information and computer graphics information.
44. The apparatus of claim 37, wherein said payload bits are repetition coded in said acknowledgement packet.
45. An apparatus, comprising:
- an output for providing a superpacket for transmission to another apparatus;
- an input for receiving from said another apparatus an acknowledgment packet; and
- an acknowledgment receiver coupled to said input and responsive to said acknowledgment packet for selecting from said previously transmitted superpacket any portion of said superpacket which is to be retransmitted.
46. The apparatus of claim 45, wherein said apparatus transmits said superpacket via wireless communication.
47. The apparatus of claim 45, wherein said superpacket includes a plurality of packets;
48. The apparatus of claim 45, wherein said acknowledgment packet has a payload.
49. The apparatus of claim 48, wherein said payload includes a plurality of bits which respectively correspond to the packets of said superpacket.
50. The apparatus of claim 49, wherein bit values indicate whether retransmission of the respectively corresponding packets is required.
51. The apparatus of claim 45, wherein said superpacket is transmitted from said apparatus via wireless communication.
52. The apparatus of claim 45, wherein said packets include at least one of audio information, video information and computer graphics information.
53. The apparatus of claim 49, wherein said payload bits are repetition coded in said acknowledgement packet.
Type: Application
Filed: Nov 10, 2004
Publication Date: May 5, 2005
Inventors: Timothy Schmidl (Dallas, TX), Mohammed Nafie (Richardson, TX), Anand Dabak (Plano, TX)
Application Number: 10/986,511