The present disclosure is related generally to wireless networks and, more particularly, to methods and a computing device for bit level signal processing.
Symbol-level spreading has been widely used in code division multiple access systems, where long spreading sequences are applied to randomize the inter-user and inter-cell interferences. Uplink signals from different users are spread using user-specific scrambling codes and superimposed with each other in shared physical (time/frequency) resources. Though multiple user interference is introduced by non-orthogonal transmission, the quality of service can be guaranteed if the spreading factor is large. However, large spreading factors lead to low data rates, which is not suitable for modern wideband service.
Spreading based non-orthogonal multiple access (NOMA) schemes have been proposed for newer wireless networks, in which the goal is to multiplex larger numbers of users and to achieve higher sum spectral efficiency than orthogonal resource based transmission. Spreading based schemes normally operate at symbol level, where the low inter-user interference is achieved by using low cross-correlation sequences such as WBE sequences, or by using low density spreading codes such as sparse codes. MMSE-SIC receivers can be used to achieve good interference rejection among multiple users at the symbol-level from joint code and spatial domains. However, wireless networks do not currently support symbol-level spreading for uplink data transmission.
While the appended claims set forth the features of the present techniques with particularity, these techniques, together with their objects and advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings of which:
According to various embodiments, a device, such as a wireless communication device, carries out the following actions: for each element of a spreading sequence to be applied, determining, based on the element, whether to carry out randomization on a coded data stream, wherein each element of the spreading sequence belongs to the set {1, −1, j, −j}; for each element of the spreading sequence for which randomization is determined to be applied, applying, based on the value of the element, one or more randomization techniques to the coded data stream; modulating the coded data stream; and transmitting the modulated data stream.
In an embodiment, for each element of the spreading sequence for which randomization is determined to be applied, the device carries out bit-level repetition on the coded data stream.
According to an embodiment, applying one or more randomization techniques to the coded data stream involves applying a scrambling technique to the coded data stream.
In an embodiment, applying one or more randomization techniques to the coded data stream involves applying an interleaving technique and applying a scrambling technique to the coded data stream.
According to an embodiment, applying an interleaving technique involves interleaving real and imaginary bits of the code data stream.
In an embodiment, applying a scrambling technique involves scrambling a 1 on a sign bit of a real bit of the code data stream.
According to an embodiment, applying a scrambling technique involves scrambling a 1 on a sign bit of an imaginary bit of the code data stream.
In an embodiment, applying a scrambling technique involves scrambling a 0 on a sign bit of a real bit of the code data stream.
According to an embodiment, applying a scrambling technique involves scrambling a 0 on a sign bit of an imaginary bit of the code data stream.
In an embodiment, the device also applies a spreading sequence to the modulated data stream.
According to an embodiment, modulating the coded data stream involves applying device-specific modulation to the coded data stream.
In an embodiment, the device also carries out bit-to-symbol mapping on the coded data stream.
Prior to further description of the various embodiments, an example of a communication system in which the various techniques described herein may be practiced will now be described with reference to
The term “logic circuitry” as used herein means a circuit (a type of electronic hardware) designed to perform complex functions defined in terms of mathematical logic. Examples of logic circuitry include a microprocessor, a controller, or an application-specific integrated circuit. When the present disclosure refers to a device carrying out an action, it is to be understood that this can also mean that logic circuitry integrated with the device is, in fact, carrying out the action.
Adding NOMA schemes based on bit-level processing may have less impact on currently-used systems because the interleaving and scrambling processing is already being implemented in the transmitter of such systems. According to some implementations, the interleaving pattern for a NOMA system is UE-specific. Furthermore, the design of interleaving patterns or scrambling sequences are constructed so as to minimize the inter-user interferences.
Symbol-level spreading based NOMA schemes may not need to change the bit-level processing blocks from currently implemented designs. In addition, UE-specific spreading sequences are mainly used for UE differentiation and interference reduction. The de-spreading and channel equalization (with consideration of multi-user interferences) can be achieved simultaneously through the MMSE equalization from joint code and spatial domains. A single-user decoder can be assumed for bit-level processing at the receiver side. Therefore, no fundamental change is needed on the receiver side for symbol-level spreading based schemes.
For the symbol level spreading based NOMA schemes, the cross-correlation property of the spreading sequences between different UEs affects the overall system performance. For example, one possible design target for spreading sequences is to meet the Welch-bound equality (WBE) criteria for the cross-correlation among sequences, and to minimize the mean squared error (MSE) per user under the assumption of equal SNR distribution among NOMA users. The cross-correlation is related to the spreading length and the size of sequence pool, e.g., the longer the spreading length, the smaller the overall cross-correlation can be achieved, and if a larger sequence pool is desired to accommodate more UEs at a given spreading factor, higher cross-correlation will occur.
As previously discussed, for the newer systems where the spectral efficiency per UE is usually not very low, the spreading length should not be very long. Given the short spreading length, complex-valued sequences can provide larger sequence pool size compared with pseudo-noise (PN) sequences. For example, the length-L sequence with each of the element picked from {−1, 1, −j, j} has 4L different sequences, while PN sequences (element picked from {−1, 1}) has only 2L different sequences.
Before continuing with the description, some of the terms used herein will now be clarified.
The term “randomization” as used herein refers to randomization of a series of bits (e.g., bits of a data stream). Examples of randomization include applying an interleaver, carrying out scrambling, and a combination of applying an interleaver and carrying out scrambling.
An example of “scrambling” as used herein is as follows: A communication device: 1) Generates a scrambling code whose length is equal to the length of the bits or symbols to be scrambled. 2) The input sequences are masked by the scrambling code.
An example of “bit-level repetition” as used herein is as follows: A communication device: 1) Generates a repeated sequence of 1s. 2) Multiplies an input sequence by an element of the repeated sequence. For example, a communication device generates a repeated sequence of [c1, c1, c1, c1, c2, c2, c2, c2, c3, c3, c3, c3] (assuming an original length-3 sequence and repetition factor of 4) Then, given an input sequence of [c1, c2, c3]T, the communication device multiplies [c1, c2, c3]T by [1, 1, 1, 1] and obtains [c1, c1, c1, c1; c2, c2, c2, c2; c3, c3, c3, c3]. The device then performs a parallel to serial transformation on this 3×4 matrix to obtain the 1×12 vector [c1, c2, c3, c1, c2, c3, c1, c2, c3, c1, c2, c3].
Described below are various techniques for achieving the equivalent results of complex-valued symbol-level spreading by using bit-level processing, according to various embodiments.
The length-L spreading can be also implemented by L time's bit-level repetition with additional UE-specific interleaving/scrambling or modulation, as depicted in
According to an embodiment, the design target is to make sure M({right arrow over (c)})·sl=M({right arrow over (c)}l)=Ml, ({right arrow over (c)}), for each l=1, . . . , L.
In an embodiment, symbol-level spreading with complex-valued elements picked from {1, −1, j, −j} is used. This technique represents the whole modulation constellation rotated by angles {0, pi, pi/2, -pi/2}. The equality between UE-specific modulation and symbol-level spreading can be shown as follow:
According to various embodiments, equivalent bit-level processing based on different modulation orders are presented separately.
Case 1: QPSK
The QPSK constellation denotes each two consecutive coded binary bits {right arrow over (c)}={b0, b1} are mapped to one symbol as the following equation (note that the sequential order between b0, b1 can be interchanged. The same is true for Cases 2, 3, and 4):
The value b0 denotes the sign of the real part of the complex-valued modulation symbol, and b1 denotes the sign of the imaginary part of the complex-valued modulation symbol, as the bit-to-symbol mapping constellation shown in
if sl=1, then M ({right arrow over (c)})*sl=M({right arrow over (c)}l) and there is no need for bit-level processing, (i.e., {right arrow over (c)}l={right arrow over (c)}.
if sl=−1, then
which can be represented by bit-level scrambling with scrambling sequence {right arrow over (s)}l={1,1}, with no interleaving Il({right arrow over (c)})={right arrow over (c)}. {right arrow over (c)}l=(Il({right arrow over (c)})={right arrow over (s)}l) mod 2=1−{right arrow over (c)}.
if sl−j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={1,0}. {right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}lmod 2={1−b1, b0}.
if sl=−j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={0,1}. {right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}l) mod 2={b1, 1−b0}.
Case 2:16 QAM
The 16QAM constellation denotes each four consecutive coded binary bits {right arrow over (c)}={b0, b1, b2, b3} are mapped to one symbol as the following equation:
if sl=1, then M({right arrow over (c)})*sl=M({right arrow over (c)}l) and there is no need for bit-level processing, (i.e., {right arrow over (c)}l={right arrow over (c)}).
if l=−1, then
which can be represented by bit-level scrambling with scrambling sequence {right arrow over (s)}l={1,1,0,0}, with no interleaving Il({right arrow over (c)})={right arrow over (c)}l. {right arrow over (c)}ll(Il({right arrow over (c)})+{right arrow over (s)}l) mod 2={1−b0,1−b1, b2, b3}.
if sl=j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={1,0,0,0}{right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}l) mod 2=mod 2={1−b1, b0, b3, b2}
if sl=−j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving
and the scrambling sequence {right arrow over (s)}l={0,1,0,0}.
{right arrow over (c)}l=(Il+{right arrow over (s)}l) mod 2={b1, 1−b0, b3, b2}
Case 3: 64QAM
The 64QAM constellation denotes each six consecutive coded binary bits {right arrow over (c)}={b0, b1, b2, b3, b4, b5} are mapped to one symbol as the following equation:
The bit-to-symbol mapping constellation for 64QAM is shown in
if sl=1, M({right arrow over (c)})*sl=M({right arrow over (c)}l) and there is no need for bit-level processing.
if sl=−1, then
which can be represented by bit-level scrambling with scrambling sequence {right arrow over (s)}l={1,1,0,0,0,0}, with no interleaving Il({right arrow over (c)}l)={right arrow over (c)} and {right arrow over (c)}l =(Il({right arrow over (c)})+{right arrow over (s)}l) mod 2={1−b0, 1−b1, b2, b3, b4, b5}.
if sl=j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={1,0,0,0,0,0}
{right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}l)mod 2={1−b1, b0, b3, b2, b5, b4}
if sl=−j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={0,1,0,0,0,0}
{right arrow over (c)}l=(Il({right arrow over (c)})+mod 2={b1,1−b0, b3, b2, b5, b4}
Case 4: 256QAM
The 256QAM constellation denotes each six consecutive coded binary bits{right arrow over (c)}={b0, b1, b2, b3, b4, b5, b6, b7} are mapped to one symbol as the following equation:
For simplicity, the bit-to-symbol mapping constellation for 256QAM has not been plotted. The value b0 denotes the sign of the real part of the complex-valued modulation symbol, b1 denotes the sign of the imaginary part, b2, b4, and b6 are used to distinguish different coefficients of the real part (columns on the constellation), b3, b5 and b7 are used to distinguish different coefficients of the imaginary part (rows on the constellation) of the complex-valued modulation symbol.
if sl=1, then M({right arrow over (c)})*sl=M({right arrow over (c)}l) and there is no need for bit-level processing.
if sl=−1, then
which can be represented by bit-level scrambling with scrambling sequence {right arrow over (s)}l={1,1,0,0,0,0,0,0}, with no interleaving Il({right arrow over (c)})={right arrow over (c)}l, and {right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}l) mod 2={1−b0, 1−b1, b2, b3, b4, b5, b6, b7}.
if sl=j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={1,0,0,0,0,0,0,0} {right arrow over (c)}l=(Il({right arrow over (c)}+{right arrow over (s)}l) mod 2={1−b1, b0, b3, b2, b5, b4, b7, b6}
if sl=−j, then
which can be represented by bit-level interleaving and scrambling, as the interleaving pattern
and the scrambling sequence {right arrow over (s)}l={0,1,0,0,0,0,0,0}{right arrow over (c)}l=(Il({right arrow over (c)})+{right arrow over (s)}l mod 2={b1, 1−b0, b3, b2, b5, b4, b7, b6}
The processing procedure can be concluded as depicted in
It should be understood that the exemplary embodiments described herein should be considered in a descriptive sense only and not for purposes of limitation. Descriptions of features or aspects within each embodiment should typically be considered as available for other similar features or aspects in other embodiments. It will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from their spirit and scope of as defined by the following claims. For example, the steps of the various methods can be reordered in ways that will be apparent to those of skill in the art.
This application is a continuation of International Patent Application No. PCT/CN2018/099176, filed on Aug. 7, 2018, the contents of which are incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6912241 | Giannakis | Jun 2005 | B2 |
7349460 | Choi | Mar 2008 | B2 |
7352796 | von der Embse | Apr 2008 | B1 |
7483933 | Wang | Jan 2009 | B2 |
10887139 | Bayesteh | Jan 2021 | B2 |
20020044612 | Sipola | Apr 2002 | A1 |
20050141410 | Zhang | Jun 2005 | A1 |
20060039343 | Anderson | Feb 2006 | A1 |
20080159537 | Khan | Jul 2008 | A1 |
20170359140 | Yuan | Dec 2017 | A1 |
20180034501 | Li | Feb 2018 | A1 |
20190312694 | Jia | Oct 2019 | A1 |
Number | Date | Country |
---|---|---|
2018100428 | Jun 2018 | WO |
Entry |
---|
International Search Report and Written Opinion in International Application No. PCT/CN2018/099176, dated Apr. 28, 2019, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20210194533 A1 | Jun 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2018/099176 | Aug 2018 | US |
Child | 17168615 | US |