Unless otherwise indicated herein, the approaches described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.
A type of communication system using multiple antennas to wirelessly transmit copies of a data stream across a number of antennas may be referred to as a transmit diversity wireless communication system. A transmit diversity wireless communication system may space-time modulate encoded portions of a data stream (e.g., represented by symbol blocks) to improve reliability of data-transfer between a transmitter and a receiver. A typical scheme to space-time modulate a symbol block may include a period of time over which a first copy of a symbol block is transmitted from two transmit antennas over a communication channel and another period of time over which a second copy of the symbol block is transmitted from both antennas over the communication channel. When the symbol block is spread using orthogonal spreading codes, this type of space-time modulating of a symbol block may be referred to as space-time spreading (STS).
Examples of a transmit diversity wireless communication system using STS that may benefit from improved reliability of data-transfer between a transmitter and a receiver include a transmit diversity wireless communication system that employs a direct-sequence code-division-multiple-access (DS-CDMA) access methodology. A DS-CDMA employment for a transmit diversity wireless communication system using STS may include the use of a multicarrier system such as orthogonal frequency division multiplexing (OFDM) to spread a symbol block to be transmitted over a multi-carrier communication channel. However, the use of a multi-carrier system may lead to a high peak-to-average power ratio (PAPR).
The foregoing and other features of this disclosure will become more fully apparent from the following description and appended claims, taken in conjunction with the accompanying drawings. Understanding that these drawings depict only several embodiments in accordance with the disclosure and are, therefore, not to be considered limiting of its scope, the disclosure will be described with additional specificity and detail through use of the accompanying drawings.
In the following detailed description, reference is made to the accompanying drawings, which form a part hereof. In the drawings, similar symbols typically identify similar components, unless context dictates otherwise. The illustrative examples or embodiments described in the detailed description, drawings, and claims are not meant to be limiting. Other examples or embodiments may be utilized, and other changes may be made, without departing from the spirit or scope of the subject matter presented here. It will be readily understood that aspects of this disclosure, as generally described herein, and illustrated in the Figures, can be arranged, substituted, combined, and designed in a wide variety of different configurations, all of which are explicitly contemplated and make part of this disclosure.
This disclosure is drawn, inter alia, to methods, apparatus, systems and computer program products related to transmitting and receiving schemes for multiuser single-carrier space time spreading (STS) with frequency domain equalization.
As contemplated in the present disclosure, a transmit diversity wireless communication system using a multicarrier system such as OFDM to transmit a data stream encoded in a symbol block transmitted over a multicarrier communication channel may lead to a high PAPR. A high PAPR typically causes unwanted distortion and spectral spread. As a result of the high PAPR causing unwanted distortion and spectral spread, highly linear and inefficient amplifiers may be required for transmitting the symbol block over the multicarrier communication channel. Moreover, sensitivities to frequency offset and radio frequency phase noise may also be problematic to a transmit diversity wireless communication system using OFDM. A single-carrier transmission with frequency domain equalization (SCFDE) is a possible way to transmit a data stream with a lower PAPR.
In some examples, methods are implemented for generating and transmitting chip-blocks through multiple antennas over a single-carrier communication channel in a transmit diversity wireless communication system. According to the example methods, data may be encoded in a first block of symbols and the data may also be encoded in a second block of symbols. A first chip-block and a second chip-block may then be generated. The first generated chip-block and the second generated chip-block may separately include the first block of symbols and the second block of symbols that have been spread based, at least in part, on a first orthogonal spreading code and a second orthogonal spreading code and then combined. The first chip-block may then be transmitted through a first antenna of a transmitter and the second chip-block may be transmitted through a second antenna of the transmitter.
In some examples, methods are also implemented for receiving chip-blocks transmitted through multiple antennas over a single-carrier communication channel in a transmit diversity wireless communication system and possibly decoding symbols included in the received chip-blocks. According to the example methods, a first chip-block and a second chip-block are received over a single-carrier communication channel. The first chip-block may have been transmitted from a first antenna of a transmitter and the second chip-block may have been transmitted from a second antenna of the transmitter. Also, the first chip-block and the second chip-block may separately include a first block of symbols and a second block of symbols that may have been spread based, at least in part, on a first orthogonal spreading code and a second orthogonal spreading code and then combined. A first received chip vector from the first chip-block and a second received chip vector from the second chip-block may then be generated. The first chip-block and the second chip-block included in the first and the second received chip vectors may be de-spread. The de-spreading may occur in the frequency domain. Further, an estimate of data associated with a symbol included in the first and second block of symbols may be generated. The estimate may occur in the time domain.
In some examples, wireless communication system 100 may operate as a transmit diversity wireless communication system. For example, as shown in
In some examples, receiver 120 may be located at or with a base station for wireless communication system 100. Although not shown in
The example Tx manager 112 of
In some examples, the elements portrayed in FIG. 2's block diagram are configured to support or enable Tx manager 112 as described in this disclosure. A given Tx manager 112 may include some, all or more elements than those depicted in
In some examples, as shown in
In some examples, control logic 220 may be configured to control the overall operation of Tx manager 112. As mentioned above, control logic 220 may represent any of a wide variety of logic device(s) configured to operate in conjunction with executable content or instructions to implement the control of Tx manager 112. In some alternate examples, the features and functionality of control logic 220 may be implemented within Tx logic 210.
According to some examples, memory 230 is arranged to store executable content or instructions. The executable content or instructions may be used by control logic 220 and/or Tx logic 210 to implement or activate features or elements of Tx manager 112. Memory 230 may also be arranged to temporarily maintain data to be encoded and transmitted from transmitter 110.
Memory 230 may include a wide variety of memory media including, but not limited to, one or more of volatile memory, non-volatile memory, flash memory, programmable variables or states, random access memory (RAM), read-only memory (ROM), or other static or dynamic storage media.
In some examples, I/O interfaces 240 may provide an interface via an internal communication medium or link between Tx manager 112 and elements resident on or located with transmitter 110. I/O interfaces 240 may include interfaces that operate according to various communication protocols to communicate over the internal communication link (e.g., Inter-Integrated Circuit (I2C), System Management Bus (SMBus) or Serial Peripheral Interface Bus (SPI), etc.). I/O interfaces 240 may also provide an interface between Tx manager 112 and elements coupled to transmitter 110 such as receiver 120. As mentioned above for
In some examples, Tx manager 112 includes one or more applications 250 to provide instructions to control logic 220 and/or Tx logic 210. Instructions, for example, may include instructions for TX manager 112 to implement or use one or more of a symbol feature 212, a spread/combine feature 214 and a transmit feature 216.
The example Rx manager 122 of
In some examples, the elements portrayed in FIG. 3's block diagram are configured to support or enable Rx manager 122 as described in this disclosure. A given Rx manager 122 may include some, all or more elements than those depicted in
In some examples, as shown in
In some examples, control logic 320 may be configured to control the overall operation of Rx manager 122. As mentioned above, control logic 320 may represent any of a wide variety of logic device(s) configured to operate in conjunction with executable content or instructions to implement the control of Rx manager 122. In some alternate examples, the features and functionality of control logic 320 may be implemented within Rx logic 310.
Similar to memory 230 as described above, memory 330 may include a wide variety of memory media. According to some examples, memory 330 is arranged to store executable content or instructions. The executable content or instructions may be used by control logic 320 and/or Rx logic 310 to implement or activate features or elements of Rx manager 122. Memory 330 may also be arranged to temporarily maintain at least portions of received encoded data as the encoded data is decoded at receiver 120.
Similar to I/O interfaces 240 as described above, I/O interfaces 340 may provide an interface via an internal communication medium or link between Rx manager 122 and elements resident on or located with receiver 120. I/O interfaces 340 may also provide an interface between Rx manager 122 and elements coupled to receiver 120 such as transmitter 110.
In some examples, Rx manager 122 includes one or more applications 350 to provide instructions to control logic 320 and/or Rx logic 310. Instructions, for example, may include instructions for Rx manager 122 to implement or use one or more of a receive feature 312, a vector feature 314, a de-spread feature 316 and an estimate feature 318.
In some examples, Tx manager 112 and Rx manager 122 may be arranged or configured to implement transmitting and receiving schemes for multiuser single-carrier STS with frequency domain equalization. As described more below, example transmitting and receiving schemes may include a chip-superimposed-STS scheme and a chip-interleaved-STS scheme.
In some examples, transmitting and receiving schemes may include the use of equations or algorithms to encode, transmit and decode data via a communication channel (e.g., single-carrier communication channel 130). The equations or algorithms may be implemented based on wireless communication system 100 including a number of transmitters 110 equipped with two uncorrelated antennas (e.g., included in Tx antenna array 114). A particular transmitter 110 may be denoted by user u in the equations or algorithms and may transmit encoded data to a receiver 120. In some examples, the receiver 120 may be a base station equipped with one or more antennas.
For the example equations used to encode, transmit and decode data, symbol blocks of encoded data are represented by si(u), where si(u)=[si(u)(0), si(u)(1), . . . , si(u)(N/2−1)]T, i=1, 2, denotes two blocks of N/2 data symbols at the input of user u transmitter 110. Also, Si(u)=[Si(u)(0), Si(u)(1), . . . , Si(u)(N/2−1)]T may denote the N/2-point discrete Fourier Transform (DFT) of si(u). User u of transmitter 110 may also be assigned two normalized orthogonal spreading codes of length G.
The two orthogonal spreading codes may be denoted by c(u,1)=[c0(u,1), c1(u,1), . . . , cG−1(u,1)]T and c(u,2)=[c0(u,2), c1(u,2), . . . , cG−1(u,2)]T. The two orthogonal spreading codes may be mutually orthogonal. Also, it may be assumed that the communication channel is quasi-static such that the communication channel may be constant during a transmission of a chip-block but may change independently from one chip-block to another.
As briefly mentioned above, example transmitting and receiving schemes may include a chip-superimposed-STS scheme. Tx manager 112 of transmitter 110 may include logic configured to implement the chip-superimposed-STS scheme by using at least a portion of the below described example equations (1) through (17). For example, a block-spreading on blocks of symbols si(u) using example equations (1) and (2) may be performed to construct or generate chip-blocks of length NG/2 for each ith antenna of Tx antenna array 114.
x
i
(u)
=[x
i,0
(u)
, x
i,1
(u)
, . . . , x
i,G-1
(u)]T, i=1,2 (1)
Further, xi,g(u), as used in example equation (1), may be referred to as a “chip-subblock”. The chip-subblock xi,g(u) may be generated by implementing example equation (2).
x
1,g
(u)
=c
g
(u,1)
s
1
(u)
−c
g
(u,2)
s
2
(u)*
x
2,g
(u)
=c
g
(u,1)
s
2
(u)
+c
g
(u,2)
s
1
(u)* (2)
For example equation (2), sg(u)=[si(u)(0),si(u)(N/2−1), . . . , si(u)(2),si(u)(1)]T i.e. si(u)(n)=si(u)(−n)N in which (·)N is the modulo N operation. The scheme may be called chip-superimposed-STS scheme because as seen in example equation (2), the spread blocks of symbols s1(u) are added to the spread blocks of s2(u) to generate a chip-subblock. In some examples, the addition of the two spread blocks may result in a transmitted signal peak-to-average power ratio (PAPR) of 3 decibels (dB).
In some examples, to avoid inter chip-subblock interference (ICSI), a cyclic prefix (CP) of length P chips (chosen such that the duration of the CP is greater than the maximum delay spread of the communication channel τm) may be separately added to each chip-subblock xi,g(u) before transmission. Hence the transmitted chip-block or signal vector associated with the transmitted chip-block by the ith antenna of Tx antenna array 114 (e.g., Tx1 and Tx2) is given by a (N+L)G×1 vector.
{tilde over (x)}
i
(u)
=[{tilde over (x)}
i,0
(u)
, {tilde over (x)}
i,1
(u)
, . . . , {tilde over (x)}
i,g
(u)
, . . . , {tilde over (x)}
i,G−1
(u)]T, (3)
For example equation (3), {tilde over (x)}i,g(u)=TCPxi,g(u) and TCP=[JCPT, IN]T may be the (N+L)×N matrix that appends the CP to each chip-subblock. JCP may be an L×N matrix formed by the last L rows of the identity matrix IN. A symbol block length of N may be chosen to be N>>L so that the overhead fraction due to insertion of a CP given by L/(N+L) is negligible. Transmitted chip-blocks including chip-subblocks having attached CPs may be derived as shown in example equation (4).
{tilde over (x)}
1
(u)=(c1(u) TCP)s1(u)−(c2(u) TCP)s2(u)*
{tilde over (x)}
2
(u)=(c1(u) TCP)s2(u)−(c2(u) TCP)s1(u)* (4)
For example equation (4) and for other example equations described below, {circle around (×)} stands for Kronecker product. In some examples, the signal received at Rx antenna 124 of receiver 120 (e.g., a base-station antenna) may be given by equation (5).
For example equation (5), hi(u)=[hi(u)(0), hi(u)(1), . . . , hi(u)(L−1)]T denotes the L-taps multipath frequency selective fading characterization of the communication channel between the user u transmit antenna i of Tx antenna array 114 of transmitter 110 and Rx antenna 124 of receiver 120. Also, Σl=0L−1E{|hi(u)(l)|2}=1; n is a zero-mean complex additive white Gaussia noise (AWGN) with variance No and * denotes the linear convolution. As stated previously, it may be assumed that the communication channel is constant within one chip-block {tilde over (x)}i(u) of duration Tx=(N/2+P)GTc (where Tc is the chip duration) but may change from one chip-block to another.
In some examples, Rx manager 122 may include logic configured to first remove the CP in each chip-subblock included in a received chip-block {tilde over (x)}i(u) to yield r=V{tilde over (r)}. Where V is a NG/2×(N/2+P)G block diagonal matrix and where each chip-block {tilde over (x)}i(u) is given by the NG/2×(N/2+P) matrix {tilde over (T)}=[0N/2×PIN/2×N/2] that results in the removal of the CP in each chip-subblock such that V=IG×G{tilde over (T)}. Hence the length of the resulting signal vector r for the received chip-block may be NG/2 and can be shown to be r=[r0, r1, . . . rg, . . . , rG−1]T. Example equation (6) shows how each received chip-block rg may be derived.
For example equation (6), * represents the circular convolution. In some examples, the result from example equation (6) may be due to communication channel impulse response hi(u) being constant for the duration of chip-block {tilde over (x)}i(u) and the CP turning the linear convolution into a circular one.
In some examples, Rx manager 122 may include logic configured to take the N/2-point DFT of each received chip-subblock by multiplying r by the NG/2×NG/2 block diagonal matrix IGQN/2 where each chip-block is given by the N/2×N/2 DFT matrix QN/2 to yield a received chip vector R=(IGQN/2)r. Letting R=[R0T, . . . , RgT, . . . , RG−1T]T, Rg, which represents the N/2-point DFT of rg, is shown in example equation (7).
For example equation (7), Λi(u) represents a diagonal matrix whose diagonal elements are the N/2-point DFT of hi(u) and the vectors Xi,g(u) and Ng are the N/2-point DFT of xi,g(u) and ng, respectively.
In some examples, using example equation (2), it can be shown that Xi,g(u) is given by example equation (8).
X
1,g
(u)
=c
g
(u,1)
S
1
(u)
−c
g
(u,2)
S
2
(u)*
X
2,g
(u)
=c
g
(u,1)
S
2
(u)
+c
g
(u,2)
S
1
(u)* (8)
For example equation (8), the N/2-point DFT of si(u)* may be given by Si(u)*. Plugging example equation (8) in example equation (7), example equation (9) is derived.
Using example equation (9), R=[R0T, . . . , RgT, . . . , RG−1T]T can be written as shown in example equation (10).
For example equation (10), N=[N0T, N1T, . . . , NG−1T]T. The de-spreading of the received chip vector R may be done in the frequency domain by multiplying R with (c(u,1)TN/2) and (cu,2)TIN/2) to yield Z(u,1) and Z(u,2), respectively, as shown in example equation (11) below.
In some examples, the following identities of Kronecker products may be used as shown in example equation (12).
(A1 A2)(A3 A4)=(A1A3)(A2A4) (12)
In some examples, where N(u,i)=(c(u,i)TIN/2)N, example equation (11) can be combined and presented in a matrix form as shown in example equation (13).
For example equation (13), Z(u)=[Z(u,1)T, Z(u,2)T]T. In some examples, a simple linear receiver for receive 120 (not shown) may yield example equation (14).
Ŝ
(u)=(Λ(u)HΛ(u)+α(No/Es)IN)−1Λ(u)HZ(u), (14)
For example equation (14), α=1 for a mean mean square error (MMSE) receiver and α=2 for a Zero-forcing (ZF) receiver.
In some examples, Rx manager 122 may include logic configured to take an N/2-point inverse fast Fourier transform (IFFT) to generate an estimate of data associated with a symbol. The estimate, for example, to occur in the time domain. The symbol to be estimated, for example, was included in a first and a second block of symbols received in a chip-block transmitted from transmitter 110 and further included in the received chip vector Rg generated as described for example equation (7). The matrix Λ(u)HΛ(u) may be diagonal and may be given by example equation (15).
For example equation (15), the N/2×N/2 diagonal matrix Δ(u) elements may be given as shown in example equation (16).
Δk,k(u)=|Λ1(u)|k,k2+|Λ2(u)|k,k2 (16)
In some examples, an output signal-to-noise ratio (SNR) of a matched filter for receiver 120 (not shown) can be given by example equation (17).
μ(k)=(|Λ1(u)|k,k2)+(|Λ2(u)|k,k2)γo (17)
For example equation (17), k=0,2, . . . , N/2−1 and where γ0=Es/N0. It may be seen that the chip-superimposed-STS scheme may achieve a second order diversity and that the SNR μ(k) has a central chi-square distribution with four degrees of freedom with probability density function (pdf) given by p(γ)=(γ/γ0) exp (−γ/γ0).
As briefly mentioned above, example transmitting and receiving schemes may also include a chip-interleaved-STS scheme. Tx manager 112 of transmitter 110 may include logic configured to implement the chip-interleaved-STS scheme by using at least a portion of the below described example equations (18) through (30). The logic may also use some of the example equations (1) through (17) as described above to implement the chip-interleaved-STS scheme. For example, a block-spreading on blocks of symbols si(u) using example equations (18) and (19) may be performed to construct or generate space-time spreading chip-blocks of length NG/2 for each ith antenna of Tx antenna array 114. Note that example equation (18) is similar to example equation (1) with the exception that the chip-block xi(u) of (1) is denoted in equation (18) as
i
(u)
=[
i,0
(u)
,
i,1
(u)
, . . . ,
i,g
(u)
, . . . ,
i,G−1
(u)]T, i=1,2 (18)
Further,
1,g
(u)
=c
g
(u,1)
{right arrow over (s)}
1
(u)
−c
g
(u,2)
S
2
←(u)*
2,g
(u)
=c
g
(u,1)
{right arrow over (s)}
2
(u)
+c
g
(u,2)
S
1
←(u)* (19)
For example equation (19), {right arrow over (s)}i(u) and Si←(u) are derived as shown in example equation (20).
{right arrow over (s)}
i
(u)
[=s
i
(u)(0), 0, si(u)(1),0, . . . , si(u)(N/2−1), 0]T Si←(u)=[0, si(u)(0), 0, si(u)(N/2−1), . . . , 0, si(u)(1)]T (20)
As mentioned above for the chip-superimposed-STS scheme (see example equation (2)), spread blocks of symbols s1(u) are added to spread blocks of s2(u) to generate a chip-subblock xi(u). However, for the chip-interleaved-STS scheme, a chip-subblock
In some examples, as mentioned above for the chip-superimposed-STS scheme, a CP may be inserted or attached to each chip-subblock to avoid inter chip-subblock interference (ICSI). The insertion of the CP may be done by implementing example equation (3) as described above. Chip-blocks
In some examples, Rx manager 122 may also include logic configured to take the N-point DFT of each received chip-subblock
From example equations (19) and (20) it can shown that
i
For example equation (22), it may be defined that Si,(N/2)(u)=√{square root over (1/2)}[Si(u)T, Si(u)T]T, which is a repetition of Si(u) due to the zero insertion in example equation (20) and due to WN=diag(1,e2π/N, e2π2/N, . . . , e2π(N−1)/N) which may be the result of a shift property of the DFT. In some examples, similar to what was described above for the chip-superimposed-STS scheme, received chip vector
For example equation (23),
In some examples
For example equation (25),
For example equation (26), Λi1(u) and Λi2(u) are an N/2×N/2 diagonal matrix whose diagonal elements are the first and second N/2 diagonal elements of Λi(u), respectively. Similarly, WN(1) and WN(2) are an N/2×N/2 diagonal matrix whose diagonal elements are the first and second N/2 diagonal elements of WN. In some examples a linear receiver for receiver 120 may yield Ŝ(u) as shown in example equation (27).
Ŝ
(u)=(
For example equation (27), α may be defined as stated above for example equation (14). In some examples, Rx manager 122 may include logic configured to take an N/2-point IFFT to generate an estimate of data associated with a symbol. The estimate, for example, to occur in the time domain. The symbol to be estimated, for example, was included in a first and a second block of symbols received in a chip-block transmitted from transmitter 110 and further included in the received chip vector
For example equation (28), the N/2×N/2 diagonal matrix
k,k
(u)=|Λ1(u)1|k,k2+|Λ1(u)2|k,k2+|Λ2(u)1|k,k2+|Λ2(u)2|k,k2 (29)
In some examples, an output SNR of a matched filter for receiver 120 can be given by example equation (30).
For example equation (30), k=0, 2, . . . , N/2−1 and γ0=Es/N0. It may be seen that the chip-interleaved-STS scheme may achieve a fourth order diversity and that the SNR μ(k) has a central chi-square distribution with eight degrees of freedom, and a probability density function (pdf) given by p(γ)=(1/6γ04)γ3 exp {−γ/γ0}.
Processing begins at block 610 (Gather Data), where the process gathers data (e.g., via symbol feature 212) maintained at and/or generated by a user of transmitter 110. The data may include voice, video, audio or other types of data to be transmitted from transmitter 110 to receiver 120 via single-carrier communication channel 130.
Processing continues from block 610 to block 620 (Encode Data), where Tx manager 112 may include logic configured to encode the data in blocks of symbols (e.g., via symbol feature 212). In some examples, the blocks of symbols may include a first block and a second block of symbols. Data encoded in the first block of symbols may also be included in the second block of symbols. The first and the second blocks of symbols may separately include N/2 data symbols. Similar to the blocks of symbols depicted in
Proceeding from block 620 to block 630 (Generate Chip-Blocks), the Tx manager 112 may include logic configured to spread s1 and s2 based, at least in part, on first and second assigned orthogonal spreading codes and then combine s1 and s2 to generate chip-blocks. Also, similar to the orthogonal spreading codes depicted in
In some examples, Tx antenna array 114 of transmitter 110 includes a first transmit antenna and a second transmit antenna. Similar to the Tx antenna array 114 shown in
In some examples, a chip-superimposed-STS scheme may be implemented by Tx manager 112 to spread and combine s1 and s2 (e.g., via spread/combine feature 214) to generate a first chip-block to be transmitted through Tx1 and a second chip-block to be transmitted through Tx2. The first chip-block and the second chip-block may separately include a first chip-subblock and a second chip-subblock. For these examples, example equation (2) may be implemented to form the first and second chip-subblocks. Similar to the chip-blocks depicted in
In some examples, a chip-interleaved-STS scheme may be implemented by Tx manager 112 to spread and combine s1 and s2 (e.g., via spread/combine feature 214) to generate a first chip-block to be transmitted through Tx1 and a second chip-block to be transmitted through Tx2. The first chip-block and the second chip-block may separately include a first chip-subblock and a second chip-subblock. For these examples, example equation (19) may be implemented to form the first and second chip-subblocks. Similar to the chip-blocks depicted in
In some examples, Tx manager 112 may also include logic configured to separately attach or add a cyclic prefix (CP) to chip-subblocks to avoid inter chip-subblock interference (ICSI). Based on use of either the chip-superimposed-STS scheme or the chip-interleaved-STS scheme, example equation (3) may be implemented (e.g., by spread/combine feature 214) to add the CP.
Processing continues from block 630 to block 640 (Transmit Chip-blocks), the process transmits or initiates transmission of (e.g., via transmit feature 218) chip-blocks, generated using either the chip-superimposed-STS scheme or the chip-interleaved-STS scheme, through Tx1 and Tx2. In some examples, the chip-blocks are to be transmitted over a single-carrier communication channel. Transmitting through Tx1 and Tx2 and over the single-carrier communication channel (e.g., single-carrier communication channel 130) may include STS transmitting spread and combined symbols of s1 and s2 in a sequential manner based, at least in part, on the orthogonal spreading codes c1 and c2.
Continuing from block 640 to decision block 650 (Additional Data?), the process determines (e.g., via symbol feature 212) whether additional data needs to be encoded and transmitted. If additional data needs to be encoded and transmitted, the process moves to block 620. Otherwise, the processing continues from decision block 650 to block 660.
In block 660 (End Transmitting), transmitting may be ended.
Processing begins at block 710 (Receive Chip-blocks), where Rx manager 122 may include logic (e.g., receive feature 312) configured to receive chip-blocks over a single-carrier communication channel (e.g., single-carrier communication channel 130). In some examples the received chip-blocks may include a first chip-block transmitted from a first antenna of transmitter 110 and a second chip-block transmitted from a second antenna of transmitter 110.
In some examples, the first and second chip-blocks may separately include a first chip-subblock and a second chip-subblock. The first and second chip-subblocks may further include a first block of symbols and a second block of symbols separately including N/2 data symbols. Similar to the blocks of symbols depicted in
Processing continues from block 710 to block 720 (Generate Received Chip Vectors), where Rx manager 122 may include logic configured to generate received chip vectors (e.g., via vector feature 314). In some examples, a first received chip vector is generated from the first chip-block and a second received chip vector is generated from the second chip-block.
In some examples, the transmission scheme used to generate the first and second chip-blocks was chip-superimposed-STS. The first received chip vector may be generated by taking an N/2-point DFT of the first chip-block. The second received chip vector may be generated by taking an N/2-point DFT of the second chip-block. Rx manager 122 may include logic configured to implement example equation (7) to take the N/2-point DFT of the two chip-blocks (e.g., via vector feature 314). The N/2-point DFT, in these examples, is taken following removal of possible CPs attached to chip-subblocks included in the first and second chip-blocks.
In some examples, the transmission scheme used to generate the first and second chip-blocks was chip-interleaved-STS. The first received chip vector may be generated by taking an N-point DFT of the first chip-block. The second received chip vector may be generated by taking an N-point DFT of the second chip-block. Rx manager 122 may include logic configured to implement example equation (21) to take the N-point DFT of the two chip-blocks (e.g., via vector feature 314). The N/2-point DFT, in these examples, is taken following removal of possible CPs attached to chip-subblocks included in the first and second chip-blocks.
Proceeding from block 720 to block 730 (De-spread Chip-blocks), the Rx manager 122 may include logic (e.g., de-spread feature 316) to de-spread the first chip-block and the second chip-block separately included in the first and the second received chip vectors. In some examples, the transmission scheme used to generate the first and second chip-blocks from which the first and second received vectors were generated was chip-superimposed-STS. Based on use of a chip-superimposed-STS transmission scheme, de-spread feature 316 may implement example equation (11) to de-spread the first chip-block and the second chip-block. The de-spreading may occur in the frequency domain.
In some examples, the transmission scheme used to generate the first and second chip-blocks from which the first and second received vectors were generated was chip-superimposed-STS. Based on use of a chip-interleaved-STS transmission scheme, de-spread feature 316 may implement example equation (24) to de-spread the first chip-block and the second chip-block. The de-spreading may occur in the frequency domain.
Processing continues from block 730 to block 740 (Generate Estimate), the Rx manager 122 may include logic (e.g., estimate feature 318) to generate an estimate of data associated with a symbol included in the first and second block of symbols. In some examples, chip-superimposed-STS was the transmission scheme used to generate the first and second chip-blocks from which the symbol associated with the data was transmitted. Based on use of a chip-superimposed-STS transmission scheme, estimate feature 318 may implement example equations (14) and (15). Implementing example equations (14) and (15) may include estimate feature 318 taking an N/2-point inverse fast Fourier transform (IFFT) to generate the estimate. The estimate, for example, to occur in the time domain.
In some examples, chip-interleaved-STS was the transmission scheme used to generate the first and second chip-blocks from which the symbol associated with the data was transmitted. Based on use of a chip-interleaved-STS transmission scheme, estimate feature 318 may implement example equations (27) and (28). Implementing example equations (27) and (28) may include estimate feature taking an N/2-point inverse fast Fourier transform (IFFT) to generate the estimate. The estimate, for example, to occur in the time domain.
Proceeding from block 740 to decision block 750 (Additional Chip-blocks Received?), where Rx manager 122 determines whether additional chip-blocks have been received. If additional chip-blocks were received, the process moves to block 720. Otherwise, the processing continues from decision block 750 to block 760.
At block 760 (End Estimate Actions), where actions related to generating estimates for symbols may be ended.
Also depicted in
Depending on the desired configuration, processor 910 can be of any type including but not limited to a microprocessor (μP), a microcontroller (μC), a digital signal processor (DSP), or any combination thereof. Processor 910 can include one more levels of caching, such as a level one cache 911 and a level two cache 912, a processor core 913, and registers 914. The processor core 913 can include an arithmetic logic unit (ALU), a floating point unit (FPU), a digital signal processing core (DSP Core), or any combination thereof. A memory controller 915 can also be used with the processor 910, or in some implementations the memory controller 915 can be an internal part of the processor 910.
Depending on the desired configuration, the system memory 920 can be of any type including but not limited to volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, etc.) or any combination thereof. System memory 920 typically includes an operating system 921, one or more applications 922, and program data 924. Application 922 includes instructions 923 that are arranged to perform the functions as described herein including the actions described with respect to Tx manager 112 or Rx manager architectures shown in
Computing device 900 can have additional features or functionality, and additional interfaces to facilitate communications between the basic configuration 901 and any required devices and interfaces. For example, a bus/interface controller 940 can be used to facilitate communications between the basic configuration 901 and one or more data storage devices 950 via a storage interface bus 941. The data storage devices 950 can be removable storage devices 951, non-removable storage devices 952, or a combination thereof. Examples of removable storage and non-removable storage devices include magnetic disk devices such as flexible disk drives and hard-disk drives (HDD), optical disk drives such as compact disk (CD) drives or digital versatile disk (DVD) drives, solid state drives (SSD), and tape drives to name a few. Example computer storage media can include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data.
System memory 920, removable storage 951 and non-removable storage 952 are all examples of computer storage media. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computing device 900. Any such computer storage media can be part of device 900.
Computing device 900 can also include an interface bus 942 for facilitating communication from various interface devices (e.g., output interfaces, peripheral interfaces, and communication interfaces) to the basic configuration 901 via the bus/interface controller 940. Example output interfaces 960 include a graphics processing unit 961 and an audio processing unit 962, which can be configured to communicate to various external devices such as a display or speakers via one or more A/V ports 963. Example peripheral interfaces 960 include a serial interface controller 971 or a parallel interface controller 972, which can be configured to communicate with external devices such as input devices (e.g., keyboard, mouse, pen, voice input device, touch input device, etc.) or other peripheral devices (e.g., printer, scanner, etc.) via one or more I/O ports 973. An example communication interface 980 includes a network controller 981, which can be arranged to facilitate communications with one or more other computing devices 990 over a network communication via one or more communication ports 982. A network communication connection is one example of a communication media. Communication media may typically be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. A “modulated data signal” can be a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media can include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared (IR) and other wireless media. The term computer readable media as used herein can include both storage media and communication media.
Computing device 900 can be implemented as a portion of a small-form factor portable (or mobile) electronic device such as a cell phone, smart phone, a personal data assistant (PDA), a personal media player device, a wireless web-watch device, a personal headset device, an application specific device, or a hybrid device that include any of the above functions. Computing device 900 can also be implemented as a personal computer including both laptop computer and non-laptop computer configurations or implemented in a workstation or a server configuration.
References made in this disclosure to the term “responsive to” or “in response to” are not limited to responsiveness to a particular feature and/or structure. A feature may also be responsive to another feature and/or structure and also be located within that feature and/or structure. Moreover, when terms or phrases such as “coupled” or “responsive” or “in response to” or “in communication with”, etc. are used herein or in the claims that follow, these terms should be interpreted broadly. For example, the phrase “coupled to” may refer to being communicatively, electrically and/or operatively coupled as appropriate for the context in which the phrase is used.
Those skilled in the art will recognize that it is common within the art to describe devices and/or processes in the fashion set forth herein, and thereafter use engineering practices to integrate such described devices (e.g., transmitters, receivers, computing platforms, computing devices, etc.) and/or methods into data processing systems. That is, at least a portion of the devices and/or methods described herein can be integrated into a data processing system via a reasonable amount of experimentation. Those having skill in the art will recognize that a typical data processing system generally includes one or more of a system unit housing, a video display device, a memory such as volatile and non-volatile memory, processors such as microprocessors and digital signal processors, computational entities such as operating systems, drivers, graphical user interfaces, and applications programs, one or more interaction devices, such as a touch pad or screen, and/or control systems including feedback loops and control motors (e.g., feedback for sensing position and/or velocity; control motors for moving and/or adjusting components and/or quantities). A typical data processing system may be implemented utilizing any suitable commercially available component, such as those typically found in data computing/communication and/or network computing/communication systems.
The herein described subject matter sometimes illustrates different components or elements contained within, or connected with, different other components or elements. It is to be understood that such depicted architectures are merely examples, and that in fact many other architectures can be implemented which achieve the same functionality. In a conceptual sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermedial components. Likewise, any two components so associated can also be viewed as being “operably connected”, or “operably coupled”, to each other to achieve the desired functionality, and any two components capable of being so associated can also be viewed as being “operably couplable”, to each other to achieve the desired functionality. Specific examples of operably couplable include but are not limited to physically mateable and/or physically interacting components and/or wirelessly interactable and/or wirelessly interacting components and/or logically interacting and/or logically interactable components.
With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art can translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
It will be understood by those within the art that, in general, terms used herein, and especially in the appended claims (e.g., bodies of the appended claims) are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to inventions containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations). Furthermore, in those instances where a convention analogous to “at least one of A, B, and C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, and C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). In those instances where a convention analogous to “at least one of A, B, or C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, or C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, claims, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase “A or B” will be understood to include the possibilities of “A” or “B” or “A and B.”