The present invention relates to wireless communication, and more specifically to multiple input/multiple output Slotted Aloha systems.
Ad-hoc wireless networks offer communications solutions where individual devices (or nodes) can communicate directly with other nodes, without any network provisioning or central points of failure. For example, in an ad hoc wireless network, two wireless radios can communicate directly with each other, or through other radios on the network, instead of having to transmit through a dedicated central access point. These networks traditionally use carrier sense multiple access/collision avoidance (“CSMA/CA”) as their media access control mechanism, as they have no central control entity. A media access control, or MAC, mechanism provides a protocol for accessing and controlling communication channels. However, CSMA/CA does not perform well in the presence of a highly-varied channel or over large distances. The CSMA/CA protocol is built on the assumption that all nodes can detect the transmissions of the other nodes that they may attempt to communicate with.
A simple string of pearls configuration (several nodes in a linear configuration) can easily create a situation where two nodes, at both ends of the string, attempt to communicate with a node in the middle of the string and, because the two transmitting nodes cannot hear each other, both end nodes transmit messages to the middle node. The result is that the middle node hears both transmissions, but cannot decode either transmission. This is known as a “collision.” This simple example is known as the “hidden node” problem for CSMA/CA. A mechanism generally accepted in the art to address this is the use of a two-way handshake using a Request to Send (“RTS”) message and Clear To Send (“CTS”) message with network allocation vectors in each message. The use of RTS/CTS in a network, while addressing the hidden node problem, substantially reduces the capacity of the network. Moreover, it does not address many of the other scenarios under which CSMA/CA will perform sub-optimally.
As a CSMA/CA network can be operated with larger distances between nodes, the protocol needs to be altered to provide sufficient gaps in transmissions to ensure that there is no overlap. The IEEE 802.11g standard, used for example, to create an in-home wireless computer network, and an example of a CSMA/CA protocol, calls for 9.6 μsec between the end of one discrete time slot and the beginning of the next slot. The concept of time slots allows several nodes to transmit on the same frequency channel by transmitting at their own times, or time slots. This 9.6 μsec time was chosen to support the propagation delay between nodes, the spread of the waveform over a multi-path environment (where transmissions can follow any of a number of paths from one node to another), the computational time to decode the information transmitted in a slot, and timing margin to simplify the implementation. As the network is extended from, for example a 100 meter separation between nodes to a 5 km separation to a 50 km separation, the round-trip propagation time grows from 66 nsec, to 3.2 μsec, to 32 μsec. In order for a CSMA/CA protocol to operate properly over these distances, the size of the gaps between transmissions needs to be extended, also reducing the efficiency of the protocol.
Various approaches have been researched to scale the capacity of wireless networks. The CSMA/CA protocol essentially divides the total capacity (C) among the nodes, so the per-node capacity at node i, c(i), shrinks as the number of nodes, N, increases, according to the equation c(i)=C/N. In other words, since the total capacity remains the same, as the number of nodes increases, each individual node's capacity decreases. This is driven by a fundamental assumption that CSMA/CA is designed upon that all nodes must take turns sharing the available capacity.
The capacity (C) of a network can be spatially divided into non-overlapping regions. To achieve a number k independent regions among the physical area covered by the network, the capacity per node c(i) would increase by a factor of k, according to the equation c(i)=k*C/N. However, such a media access control mechanism does not work well for a highly-dynamic collection of nodes. Beam-forming antennas, which can transmit signals directionally, can be used for creating these k independent regions. Although beam-forming could provide for better separation of regions, it exacerbates the problem that CSMA/CA has since it does not have a uniform channel between all the nodes in a neighborhood. Protocols that use a form of time-division multiple access (“TDMA”) mechanism and pass control of the channel from one node to another work poorly when faced with a “fast-mover” node (e.g., a cell phone in a car on the expressway) that traverse many neighborhoods rapidly. Using beam-forming approaches also generally requires adding the concept of state to the protocol, which requires more management exchanges and lengthening of the time for the neighborhood to adjust to any changes in the population. This additional overhead reduces capacity and efficiency.
Aspects and embodiments disclosed herein are directed to addressing/solving these and other needs.
According to an aspect of the invention, a method includes receiving at a synchronizing node a first reference frame from a first reference node at a first time and storing a first time value representing the first time, and calculating a timing estimator by subtracting a minimum time value, representing the distance from the synchronizing node to the first reference node, from the first time value. The method also includes receiving at the synchronizing node a second reference frame at a second time and storing a second time value representing the second time, and transmitting from the synchronizing node to the first reference node a short timing contention time frame. The method also includes receiving at the synchronizing node from the first reference node an arrival time value representing the time at which the first reference node received the short timing contention frame and calculating a first time drift from the first arrival time value and the second time value. The method also includes adjusting the timing estimator based on the first time drift and transmitting from the synchronizing node a frame according to a timing determined from the timing estimator.
According to another aspect of the invention, a method includes receiving at a first node a plurality of frames from a plurality of reference nodes, measuring and recording frame timing values for each the plurality of frames representing the arrival times of the plurality of frames, and calculating carrier frequency offset values for each of the plurality of frames. The method also includes determining an average carrier frequency offset value of the plurality of frames, adjusting a local oscillator at the synchronizing node, and transmitting a frame to the plurality of reference nodes. The method also includes receiving second frame timing values from the plurality of reference nodes representing the times the respective reference nodes received the short timing contention frames and determining an average time drift for the arrival time values, wherein the time drift for each of the plurality of reference nodes equals: (second timing value−timing value)/2. The method also includes adjusting the frame timing according to the average time drift and transmitting data from the synchronizing frame according to the estimated frame timing.
According to another aspect of the invention, a method includes receiving at a first node a plurality of signals from a plurality of nodes, determining a plurality of carrier frequencies for the plurality of nodes and determining a consensus of the plurality of carrier frequencies. The method also includes adjusting a local oscillator at the first node to match the consensus and transmitting data from the first node to one of the plurality of nodes according to timing determined by the local oscillator.
According to another aspect of the invention, a computer-readable medium is encoded with a data structure. The data structure includes three identical preambles, a plurality of channel state information estimation fields, and a data field.
The foregoing and additional aspects and embodiments of the present invention will be apparent to those of ordinary skill in the art in view of the detailed description of various embodiments and/or aspects, which is made with reference to the drawings, a brief description of which is provided next.
The foregoing and other advantages of the invention will become apparent upon reading the following detailed description and upon reference to the drawings. The same reference numerals and/or other reference designations employed throughout the ensuing drawings are used to identify identical components, except as provided otherwise.
Although the invention will be described in connection with certain aspects and/or embodiments, it will be understood that the invention is not limited to those particular aspects and/or embodiments. On the contrary, the invention is intended to cover all alternatives, modifications, and equivalent arrangements as may be included within the spirit and scope of the invention as defined by the appended claims.
According to the invention, multiple simultaneous transmissions from a distributed collection of nodes can be supported with no centralized controller. Multiple input, multiple output (“MIMO”) technology, where both a transmitter and a receiver have multiple antennas for communicating over a point to point link (e.g., as included in the IEEE 802.11n standard) can be modified to operate in a fully-distributed fashion (as in the Slotted ALOHA protocol). The resulting waveform can be referred to as MEMO Slotted ALOHA (“MSA”).
When a new node, or synchronizing node, attempts to join a network (e.g., a handheld radio attempts to join a network of other handheld radios), the synchronizing node initially listens and does not transmit. This synchronizing node, listens for transmissions from other nodes in order to synchronize with the slotted access mechanism. In other words, the synchronizing node listens to determine how and when the other nodes are communicating. If it does not hear any transmissions for some time, it creates slot times based on its own internal clock, or oscillator.
If the synchronizing node hears (receives a signal from) other neighboring nodes, it computes the carrier frequency offset (“CFO”) of the transmitter, to adjust its local oscillator. Each of the nodes is supposed to be transmitting at the same frequency, however, there are variations. Thus, the synchronizing node must determine how much the actual received frequency is offset from the expected frequency. The synchronizing node uses a filter to adjust the local oscillator to match the consensus of the transmission frequencies of the neighboring nodes. As long as all of the nodes use this same approach, they can converge the cather frequencies of their respective oscillators to the same relative frequency. The synchronizing node's slot times are derived from the bit-rate of the system, which is controlled by the synchronizing node's local oscillator. Once the synchronizing node's oscillator has roughly converged to the same frequency as the other nodes in the network, the synchronizing node will compute the periodicity of the slots with similar accuracy.
Once slot periodicity is controlled, the synchronizing node must track the phase of these slots to align the edges of the slots with the other nodes in the network. In other words, the synchronizing node must determine where the beginnings of the slots are in order to transmit information at the right times. To accomplish this, each receiver measures the average phase of the transmissions from the neighboring nodes and the epoch of the slots from other nodes to determine slot phase offsets for the transmissions from each of the neighboring nodes. Each node also announces its measure of the slot phase offset of other nodes to allow the other nodes to converge on a single known target slot phase.
Within a slot time, each node needs to determine when to transmit. Each node has a single transmitter, and has a number NRX of receivers (and, when the number of receivers is known, the system is said to be an MSA-n system; e.g., if the nodes each have four receivers, the system is said to be an MSA-4 system). Using MIMO techniques, a node's receiver is capable of receiving up to NRX simultaneous transmissions, assuming that there is a unique channel between each transmitter and each receiver. According to the IEEE 802.11n specification, there is generally a unique channel between all transmitters and receivers when the antennas are separated by at least a ¼ wavelength. The MSA technique separates the transmitter antennas by substantially more than this, as the transmitters are geographically dispersed, MSA node should still have NRX antennas for its receivers and the antennas should be separated by at least a ¼ wavelength to create distinct channels between two receivers from the same source antenna.
An MSA slot structure (the information that is transmitted in a time slot) starts with a preamble that is repeated three times. The first instance of the preamble is used to allow the receivers to adjust their automatic gain controls (“AGC”) and measure the received slot time. The second two preambles are used to estimate the carrier frequency offset among all the transmitters. Each node is expected to have a local oscillator that is tracking the neighborhood average carrier frequency. However, some drift should be expected. Within the neighborhood, each node randomly selects a tone from a collection of possible tones. These tones are complex, and are used to identify indices of transmitters within the system during any given slot. Once the indices of the nodes are known, channel state information can be computed.
If a node hears another node use the complex tone it has selected, the node can simply pick a new complex tone from the set of possible complex tones in the system. If the node determines that it has heard more than NRX complex tones, it will determine that the slot has a collision and will not attempt to process the information from that slot further.
As part of processing the preamble, the node's receiver can determine an indication of the number of transmitters that have transmitted data in this slot. The node will also be able to accumulate an estimate of the number of distinct nodes in the neighborhood. The node can use this information to estimate the load in terms of both the number of active nodes and a total offered load on the neighborhood. These estimates are used to control the rate at which any particular node attempts to transmit in slots in a channel.
MSA can use orthogonal frequency-division multiplexing (“OFDM”), scheme for multiplexing information from several transmitters into a single channel. Channel state information (“CSI”) needs to be determined to perform OFDM modulation. In the frequency domain, OFDM information is represented as a series of complex tones, each of which has an amplitude and phase. A receiver must estimate these in order to interpret received information. The channel state information can be represented by a mathematical value H(f). A transmitter can send a known tone to a receiver. From this known tone, the receiver can calculate the H(f) information. The receiver then knows the channel state information and can interpret further information from the transmitter. In order to operate a MIMO system, a receiver in a MIMO system must be able compute the CSI between itself and all of the transmitters in the system. Similar to that specified by IEEE 802.11n standard, a node following the MSA protocol computes channel state information based on a preamble transmitted at the beginning of each time slot. However, unlike the IEEE 802.11n protocol, the MSA protocol uses a slotted approach, rather than a CSMA/CA approach, to control when a specific node can access the network.
The MSA protocol can use a rate-controlling medium access controller (“MAC”) protocol. Each node in the network offers packets to the network probabilistically, with no memory between slots. Each node works to load the network to the natural optimal load. An MSA system where each node has 4 receivers, MSA-4, as an example, has a natural optimal value of 4/N_node (optimal in terms of the number of slots used to support a specific successful transmission of slots, assuming a zero-bandwidth, perfect knowledge of which slots were successfully delivered to a receiver).
The provision upper MAC functions, e.g., acknowledgment of slots, can be deferred to protocols such as QBX.
Among other benefits, the MSA protocol provides:
The CSMA protocol outperforms the single input single output (“SISO”) Slotted Aloha protocol. The MSA protocol, however, can significantly increase the system throughput with much smaller system delay compared to CSMA. MSA can easily and quickly adapt to a dynamic wireless network. Moreover, MSA does not have the hidden node problem in a wireless network.
The Open Systems Interconnect (“OSI”) model is commonly used to define the flow of data, or “network traffic,” over a network between network applications and/or devices. The OSI model has seven layers including the data link layer (“Layer-2”), and the physical layer (“Layer-1”). Each OSI layer communicates with a layer above and/or below it and with corresponding layer(s) on other applications and/or devices in the network through specific protocols. A physical layer (“PHY”) specifies how information is converted to physical signals that are transmitted over the transmission medium, and can specify several techniques for increasing the rate and reliability of the wireless link. Table 1 illustrates an exemplary physical layer feature set for implementing a physical layer protocol. Table 2 illustrates exemplary parameters related to MIMO orthogonal frequency division multiplexing (“OFDM”),
A MAC layer is an OSI “Level 2” protocol that provides parameters for several nodes to communicate with each other on a multipoint network. The MAC layer specifies several techniques for increasing the rate and reliability of the wireless link, as understood by a person of ordinary skill in the art.
Table 3 list exemplary performance requirements for a MSA system.
where fm=1, 3, 5, . . . 63 is the tone selected by a node, and Ts is the sampling interval (e.g., 0.2 μsec).
With reference to
The Nrx CSI fields 216, 218 are needed for up to Nrx by Nrx CSI matrix estimation. For a distributed MIMO, each node has to send a unique CSI field, which is indexed by the frequency tone field node index tone. As shown in
An example 204 value long random sequence for w(k), where k=0, 1, 2, . . . 203 is:
0.7071−0.70711 0.7071+0.70711 −1.0000+0.00001 −0.7071+0.70711 0.7071−0.70711 −0.0000−1.00001 −0.7071+0.70711 1.0000 −0.0000−1.00001 −0.7071+0.70711 −1.0000+0.00001 −0.0000−1.00001 0.7071−0.70711 −0.7071−0.70711 0.7071+0.70711 −0.7071+0.70711 0.7071−0.70711 0.7071−0.70711 −0.7071+0.70711 0.7071−0.70711 −1.0000+0.0000+1.00001 −0.0000−1.00001 1.0000 0.7071+0.70711 0.7071+0.70711 0.7071+0.70711 −1.0000+0.00001 0.0000+1.00001 0.7071+0.70711 1.0000 −0.7071−0.70711 −0.7071+0.70711 0.7071−0.70711 −0.7071+0.70711 −0.7071+0.70711 −0.0000−1.00001 −1.0000+0.00001 0.7071+0.70711 −0.7071−0.70711 −0.7071+0.70711 0.0000+1.00001 −0.0000−1.00001 1.0000 −0.0000−1.00001 −1.0000+0.00001 −0.7071−0.70711 −0.7071+0.70711 −0.0000+1.00001 0.7071+0.70711 0.7071+0.70711 −0.7071−0.70711 0.0000+1.00001 −1.0000+0.00001 0.7071+0.70711 −0.7071−0.70711 −0.7071+0.70711 −0.0000−1.00001 −0.0000 1.00001 −1.0000+000001 −07071 +070711 0.7071−0.70711 −0.0000−100001 −017071−0.70711 −0.0000−1.00001 −0.7071−0.70711 00.000+1.0000; 0.0000+1.00001 0.0000+1.00001 −1.0000+0.00001 −0.7071−0.70711 0.0000+1.00001 −0.0000−1.00001 −1.0000+1.00001 0.0000+1.00001 −070711−0.70711 −1.0000+0.00001 −0.7071 0.70711 −0.7071−0.70711 −1.0000+0.00001 −0.0000−1.00001 0.7071−0.70711 −1.0000+000001 0.7071−0.70711 0.7071+0.70711 0.7071−0.70711 0.0000+1.00001 0.0000+1.00001 0.7071+0.70711 0.7071−0.70711 0.7071+0.70711 1.0000 0.7071+0.70711 0.7071−0.70711 0.0000+1.00001 −0.7071−0.70711 0.0000+1.00001 −0.7071+0.70711 1.0000 0.7071−0.70711 −1.0000+0.00001 −0.7071+0.70711 −1.0000+0.00001 0.0000+1.00001 −0.7071+0.70711 0.7071+0.70711 −1.0000+0.00001 −0.0000−1.00001 −1.0000+0.00001 −0.7071−0.70711 0.7071+0.70711 −0.7071+0.70711 −0.0000−1.00001 −0.7071−0.70711 −07071 0.70711 −1.0000+0.00001 −0.0000−1.00001 1.0000 −1.0000+0.00001 1.0000 −0.7071+0.70711 0.0000+1.00001 −0.0000−1.00001 1.0000 −0.0000−1.00001 0.7071−0.70711 0.7071−0.70711 −0.0000−1.00001 −0.7071+0.70711 −0.7071+0.70711 0.7071+0.70711 −0.7071−0.70711 0.0000+1.00001 0.7071−0.70711 −0.7071−0.70711 −0.7071+0.70711 −0.7071−0.70711 0.0000+1.00001 −0.7071+0.70711 0.7071−0.70711 −0.7071−0.70711 0.7071+0.70711 −0.0000−1.00001 −0.7071−0.70711 −0.7071+0.70711 0.7071+0.70711 −1.0000+0.00001 −0.7071−0.70711 0.0000+1.00001 −1.0000+0.00001 −0.7071+0.70711 1.0000 1.0000 0.0000+1.00001 1.0000 −0.7071+0:70711 −0.7071−0.70711 1.0000 1.0000 −1.0000 +0,00001 −1.0000+0.00001 1.0000 1.0000 0.7071+0.70711 −1.0000+0.00001 1.0000 0.0000+1.00001 −0.7071−0.70711 −0.7071−0.70711 −0.7071−0.70711 1.0000 −0.7071+0.70711 −0.7071+0.70711 0.0000+1.00001 0.7071+0.70711 −0.7071−0.70711 −0.7071−0.70711 −0.7071−0.70711 −0.7071+0.70711 −1.0000+0.00001 1.0000 −0.7071+0.70711 −0.7071−0.70711 0.7071−0.70711 0.0000+100001 0.0000+1.00001 −0.0000−1.00001 0.7071+0.70711 −0.0000−1.00001 0.7071−0.70711 0.7071+0.70711 0.7071+0.70711 1.0000 1.0000 −0.7071−0.70711 0.7071+0.70711 −0.0000−1.00001 0.7071+0.70711 0.7071+0.70711 0.7071−0.70711 −0.7071+0.70711 0.0000+1.00001 0.0000+1.00001 0.0000+1.00001
CSI(1,k)=P(1,j)*w(k−1), where k=1, 2, . . . 102 [Equation 2]
CSI(1,k)=P(1,j)w(k−52), where k=154, 155, . . . 255 [Equation 3]
The remaining CSI fields can be represented similarly, with P(i,j), i=1, 2, . . . Nrx:
CSI(i,k)=P(i,j)*w(k−1), where k=1, 2, . . . 102 [Equation 4]
CSI(i,k)=P(i,j)*w(k−52), where k=154, 155, . . . 255 [Equation 5]
The frequency domain CS(1,k) and CSI(2,k) can be converted to the time domain by taking complex 256-iFFT (“fast Fourier transform”):
CSI(i,n)=iFFT(CSI(i,k)), where n=0, 1, . . . 255, i=1, 2, . . . , Nrx [Equation 6]
64 GI samples are inserted to form a 320 samples CSI field.
A node can transmit information using a OFDM symbol transmitter.
A OFDM symbol includes 876 information bits. One block of bits is scrambled by the 802.11g scrambler 710. The transmitted data is scrambled to prevent long strings of ones and zeros. A generator polynomial defining the operation of the scrambler 710 is:
S(x)=x7+x4+1 [Equation 7]
The initial state is a set of seven ones (1111111).
The DATA field (
Before transmission, the transmitted data can be interleaved by the interleaver 714. In interleaving, the data is transmitted out of order, so that if a portion of the data is corrupted during transmission, the corrupted data will be spread out throughout a frame, and will be easier to correct. The interleaver 714 interleaves the 1176 bits long block by two permutations:
i=84·mod(n,14)+floor(n/14),n=0, 1, . . . 1175 [Equation 8]
j=3·floor(i/3)+mod [i+1176−floor(14·i/1176),3],i=0, 1, . . . , 1175 [Equation 9]
The bit interleave is a n to j index transformation. This transformation can be implemented by a look up table (“LUT”) method.
After interleaving, the 1176 bits data block can be grouped into 196 6-bit blocks. The QAM mapper 716 can perform 64-QAM modulation on the 6-bit blocks. For every 6-bit [b0 b1 b3 b4 b5] block, the 64-QAM modulation is:
Information bit b equals +/−1. There are 196 data tones:
X(k)=I(k)+j*Q(k)kεData Tones [Equation 12]
196 64-QAM symbols are placed on 196 data tones as shown in
For the MIMO-OFDM operation in 5 MHz bandwidth, each OFDM symbol can be constructed from 256 tones, of which 196 are data tones 612, 8 are pilot tones 614 and 52 are zero tones 616, as shown in
As shown in
An interpolation filter can be used to suppress the interpolation image. The interpolation filter is a 13-tap square-root raised Cosine filter with α=0.3. Its behavior is determined based on the equation:
The filter coefficients are shown in Table 5.
A node can receive a signal using a MSA receiver. The components of the MSA receiver can include one or more processors (e.g., microprocessors, DSPs, FPGAs, etc.) and memory. Their functions can be performed in hardware, in software executing on the processors, or combinations of hardware and software.
The Nrx RX complex signals from the DACs are filtered by matched filters 1012 corresponding to the antennas 1010. The matched filter 1012 can each be a 13-tap raised Cosine filter with α=0.1. Exemplary filter coefficients are listed in Table 6:
The 10 MHz samples are immediately decimated to 5 MHz after the matched filters 1012. Each 5 MHz decimated matched filter output is yj(nTS).
A preamble and CSI processing module (
A fast AGC algorithm can be used to more quickly determine an initial gain setting. The fast AGC algorithm measures a receive signal strength indicator (“RSSI”), R(n), on 4 samples of the frequency tone field:
After the fast AGC has converged on a value, the dynamic range of the data is in the range [−7 dBFS, −30 dBFS]. 16 samples are averaged to generate a reliable estimate of the RSSI:
The gain value corresponding to −9 dBFS is:
G=−9−10 log10(RSSI) [Equation 17]
This gain value can be sent to the radio to set the signal at −9 dBFS.
The preamble and CSI processing module (
As shown in
An SNR can be determined for each tone (1212):
An active node number can be detected (1214):
A maximum SNR can be determined (1216):
SNR(max)=max(SNR(k)),k=1, 3, 5, . . . , 63 [Equation 23]
The maximum SNR, then, is associated with one of the tones. The maximum SNR can be compared to a threshold value, for example 15 dB (1218). If the maximum SNR is greater than 15 dB, and the SNR for each of the other tones is less than 10 dB, i.e., SNR(k)<10 dB, a single node has been detected, and a Single_Node value can be set to 1 (1220). Otherwise, either no node or more than one node has been detected, and the Single_Node value can be set to 0 (1222). If the Single_Node value is 1, the SNR(max) tone can be saved and indexed as j1 (1224). If the Single_Node value is 0, a number of transmitting nodes Ntx whose SNR(k) is greater than 10 dB can be determined (1226). If Ntx=0 (1228), then no nodes are transmitting (1230). If Ntx>Nrx (1232), then Ntx can be set to Nrx (1234). The Nrx maximum SNR(k) can be used. The Ntx SNR(k) tone indexes can be saved as j1, j2, . . . , jNtx (1236). The node index j1, j2, . . . jNtx can be used to pick the CSI fields.
The preamble and CSI processing module (
τ=nsignal+2 [Equation 24]
nsignal is the first time sample index for RSSI(n)>−30 as described for
The preamble and CSI processing module 1014 can estimate a CFO. The received signal at the j-th antenna, yj(n) is:
y
j(n)=Ajsj(n)ej2πδfnTs+wj(n) [Equation 25]
sj (n) is the frequency tone field signal, δf is the carrier frequency offset and Ts is the sampling rate. The receiver noise, wj (n), is assumed to be zero-mean white Gaussian with variance σn2 and the signal variance is assumed to be σn2. Using the 2nd and 3rd frequency tone fields and the periodicity property of the frequency tone fields:
s
j(n+64)=sj(n),n=0, 1, . . . 63 [Equation 26]
sj(n) is the frequency tone field sequence. This property can be used to formulate the following statistic:
A maximum likelihood (“ML”) estimate of the carrier frequency offset can be represented by:
f
s=5 MHz.
δf can be filtered by a one-pole infinite impulse response (“IIR”) filter if there is only one node transmitting (i.e., Single_Node=1):
CFO=0.9·CFO+0.1·δf [Equation 29]
The carrier frequency offset is sent to the Low MAC for the frequency synchronization.
The preamble and CSI processing module (
(1,k)=[Z1(1,k)Z2(1,k)] for 1st CSI [Equation 30]
Z1 and Z2 1410, 1412 are two antenna outputs;
(2,k)=[Z1(2,k)Z2(2,k)] for 2nd CSI [Equation 31]
Z1 and Z2 are two antenna outputs.
For each sub-carrier k1 the CSI is a 2×2 matrix denoted by H(k):
The two antenna outputs 1410, 1412 for the two CSI fields 1414, 1416 are:
The k-th CSI matrix estimation is:
After the carrier frequency offset is estimated and the channel state information is estimated, the data field of the received MSA slot can be processed. Referring back to
Z
j
=fft(zj(n)),j=1, 2, . . . Nrx [Equation 35]
When there are Ntx≦Nrx TX nodes, a received vector is
and the signal symbol vector is
(k)=[X1(k), X2(k), . . . , XN
With further reference to
(k)=[X1(k), X2(k), . . . , XN
can be recovered from received vector
(k)=└Z1(k), Z2(k) . . . , ZN
When Ntx=Nrx, there is only one frequency domain stream
When Ntx=Nrx, a Nrx dimensional vector is decoded as
where
G(k)=H*(k)(H(k)H*(k))−1,kεData tones and pilot tones [Equation 46]
Nrx MIMO data streams can be recovered by the above MIMO MMSE decoding. If the CSI H(k) is not invertible, the values generated by the MIMO decoder 1018 will include a large amount of error. Preferably, the MSA system is a distributed MEMO system and the CSI H(k) includes two independent RF transmitter chains, so the possibility of a singular H(k) is small.
The MIMO decoder 1018 recovers the Ntx streams as:
Phase error can be estimated and corrected by a phase lock loop (“PLL”) 1020 based on the pilot tones. For the m-th OFDM symbol, the phase error is estimated by:
The data tones at m-th OFDM symbol are phase corrected by (m−1)-th PLL 1020 output:
{circumflex over (X)}
j(k)={circumflex over (X)}j(k)·exp(−j·{circumflex over (φ)}m-1),kεData Tones [Equation 49]
Constellation demappers 1022 perform constellation demapping on the decoded bit streams. For a 64-QAM case, each data tone {circumflex over (X)}j(k) consists of 6 soft bits at j-th stream and k-th subcarrier:
b
j(k,0), bj(k,1), bj(k,2), bj(k,3), bj(k,4), bj(k,5), j=1, 2, . . . Ntx [Equation 50]
The soft bits can be calculated according to the following equations:
When Ntx>1, soft bits are further weighted by:
Gm,j(k) is the MIMO decoder gain calculated by the MIMO decoder 1018.
The MIMO decoder 1018 can also perform MIMO decoding involving the inverse of the matrix H(k):
└{circumflex over (X)}1(k), {circumflex over (X)}2(k), . . . , {circumflex over (X)}N
where
Since performing the division can require significant resources, the following values can be used:
└U1(k), U2(k), . . . , UN
The soft bits can be calculated according to the following equations:
When Ntx is greater than 1, the soft bits can be further weighted by:
This allows the MIMO decoder 1018 to perform calculations without the 1/det(k) operation.
The soft bit streams {bj(k, 0), bj(k,1), bj(k,2), bj(k,3), bj(k,4), bj(k,5)} can be de-interleaved by Ntx De-interleavers 1024. The deinterleavers 1024, which perform the inverse of the function performed by the interleaver (
i=3·floor(j/3)+mod [j+floor(14·i/1176),3],i=0, 1, . . . 1175 [Equation 68]
The 2nd permutation can be defined by the rule:
k=14i−1175·floor(14·i/1176),n=0, 1, . . . 1175 [Equation 69].
The frequency deinterleaving can also be implemented by a LUT method.
Ntx Viterbi decoders 1026 with trace back length of 64 can be used to decode the bit streams from the de-interleavers 1024. A de-scrambler 1028 can be used to descramble the OFDM symbols scrambled using the scrambler (
A distributed MIMO system consists of a group of nodes at different locations and with different clock drifts. MSA time synchronization can be used to ensure that all of the nodes transmit at the same time such that transmissions from the distributed nodes can be treated as transmissions from one node passing through a muitipath channel.
The reference node is a node that is already operating on a correct slot mark 1510. The synch node is operating on an arbitrary slot mark 1512. The synch node receives a reference slot at the measured time T1 1514. The synch node slot mark is advanced to Td (min) 1516 from the received point, where Td(min) is the MSA minimum distance time (0.03 μsec). The synch node now is operating on a new slot mark 1518. The synch node listens to the reference node for a second transmission. A measurement time associated with the second transmission is T2 1520 and
T2=Td−dT[Equation 70]
After receiving the second slot, the synch node transmits a short timing contention slot 1522 to the reference node. A short timing contention slot is a 128-sample complex tone field, such as two frequency tone fields. The short timing contention frequency tone is randomly selected from a list of unused tones. The short timing contention slot is used by the reference node to set the automatic gain control, measure the short timing contention tone and measure its arrival time, T3 1524:
T3=Td+dT[Equation 71]
The short timing contention slot can only be detected and measured when there is only a short timing contention transmission in that slot.
The reference node sends back the measurement T3 1524 to the synch node. Each MSA node measures as T3(n) value from all of the other nodes and only stores the latest T3(n) in the memory, where n=1, 2, . . . N_node. Every 1 second a Node will broadcast N_node T3(n). T3(n) is a 9-bit unsigned integer that represents a maximum possible T3(n) of 51.2 μsec with 0.1 μsec resolution. Therefore a total T3 message consists of 9*N_node T3 bits and N_node·log2 (N_node) node index bits. Slot timing adjustment should not be allowed before sending the T3 message.
A synch node time drift dT 1526 can be computed from Equations 70 and 71:
dT=(T3−T2)/2 [Equation 72]
The synch node adjusts its slot again by dT 1528. The synch node is synched to the reference node. In the MSA, all nodes are constantly tracking the time drift, dT. After a node is synchronized, a MSA slot can be transmitted rather than a short timing contention slot. If a node includes a 0.1 ppm oscillator and the network has a timing error requirement of 0.1 μsec, each node needs to receive a T3 measurement every 1 second.
The synch node can determine the network frequency by measuring the carrier frequency offset a number of times (e.g., at least 20 times) adjusting its oscillator to match the network frequency before transmitting. As shown in
MSA network synchronization is a combined effort of time and frequency synchronization. There are two MSA synchronization modes: a newly joined synch node synchronizing to the network and a synched node tracking the timing of the network to remain synchronized.
dT(j)=[T3(j,m)−T2(j,n)]/2 [Equation 73]
The synch node calculates an average time drift dT as the average of dT(j) 1736. The synch node adjusts the frame mark according to dT 1738.
dT(j)=[T3(j,m)−T2(j,n)]/2 [Equation 74]
The Synch node calculates an average time drift dT as the average of dT(j) 1828. The tracking node periodically (e.g., every 1 second) adjusts the frame mark according to dT, and clears the record for T2 1830.
A MSA node transmit rate p can be set according to:
Ns is a number of system available streams Nnode is a number of active nodes. Ns is a dynamic parameter depending on the slot usage tone (
N
s
=N
rx−1 [Equation 76]
When m (m≦Nrx) nodes are working on the high QoS mode, the Ns value is set to
N
s
=N
rx
−m [Equation 77]
where 0≦Ns≦Nrx·Nnode can be estimated over an observation window of 64 slots. The number of active tones can be detected on the FTFs.
The CSMA/CA and MSA protocols have been simulated and compared. Both CSMA/CA and MSA were simulated using the same physical layer specifications:
The CSMA/CA MAC layer was simulated based on the following parameters:
The MSA MAC layer was simulated using the following parameters:
When active node number was less than or equal to the antenna number Nss, each node achieved near full throughput (37 Mbps), as shown in
As can be seen, MSA can significantly increase the system throughput with much smaller system delay as compared to CSMA/CA. MSA can quickly adapt to a dynamic wireless network. Moreover, MSA does not have the hidden node problem in a wireless network.
It should be appreciated that some portions of the detailed description have been presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits that can be performed on computer memory. A procedure, computer/machine executed step, action, logic block, process, etc., are here conceived to be a self-consistent sequence of steps or instructions leading to a desired result. The steps are those utilizing physical manipulations of physical quantities. These quantities can take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer and/or processing system. Further, these signals may have been referred to at times as bits, values, numbers, or the like. Finally, each step may be performed by hardware, software, firmware, or combinations thereof.
Thus, it will be apparent to those skilled in the computer, software and networking arts that the foregoing detailed disclosure is intended to be presented by way of example only, and is not limiting. Various alterations, improvements, and modifications will occur and are intended to those skilled in the art, though not expressly stated herein. These alterations, improvements, and modifications are intended to be suggested hereby, and are within the spirit and scope of this disclosure. Additionally, the recited order of processing elements or sequences, or the use of numbers, letters, or other designations therefore, is not intended to limit the claimed processes to any order except as may be specified in the claims. Accordingly, the claim scope and coverage is to be limited only by the following claims and equivalents thereto.
This application is a continuation of pending U.S. application Ser. No. 12/388,912 filed Feb. 19, 2009, entitled “MIMO Slotted Aloha (MSA) System,” which claims the benefit of U.S. Provisional Patent Application Ser. No. 61/029,735, filed Feb. 19, 2008, which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61029735 | Feb 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12388912 | Feb 2009 | US |
Child | 14029966 | US |