Imported: 13 Feb '17 | Published: 18 Jan '11
USPTO - Utility Patents
A receiver despreads a spread spectrum sequence by partially despreading the spread spectrum sequence using an outer spreading code, and then despreading the partially despread sequence using an inner spreading code. This can advantageously save processing power. In one embodiment, the outer spreading code is despread with an analog circuit, and an inner spreading code is despread with a digital circuit. A modulator for a transmitter can generate a spread spectrum sequence by direct-sequence spreading data to generate a partially spread sequence and then spreading the partially spread sequence to generate the spread spectrum sequence.
This application claims the benefit under 35 U.S.C. §119(e) of U.S. Provisional Application No. 60/826,368, filed Sep. 20, 2006, the entirety of which is hereby incorporated by reference.
1. Field of the Invention
The invention generally relates to electronics, and in particular, to spread-spectrum communications.
2. Description of the Related Art
Spread spectrum communication techniques offer many benefits in communications systems. These benefits include resistance to detection and/or interception as well as resistance to jamming. In a spread-spectrum system, the data is spread, that is, increased in bandwidth before it is transmitted across a data channel. When received, the data is despread back to the original data.
The amount of spreading determines the processing gain of the spread-spectrum system. Generally, the benefits of spread-spectrum modulation increase with increased processing gain. However, increasing the processing gain of the system increases the number of channel symbols transmitted, which also increases the signal processing rate required to demodulate the signal. High data processing rates are more difficult to implement in hardware or in software. For example, circuits (or microprocessors/signal processors implementing software) can be limited by maximum circuit speed, heat dissipation, or even by power consumption, particularly when battery powered.
Concatenated spread spectrum techniques are disclosed herein. Such concatenated techniques permit a spread spectrum system to use a high processing gain while reducing the speed with which the digital logic operates, which makes the hardware and/or software easier to implement and decreases power consumption for longer battery life and less power dissipation. Such techniques are useful in a broad variety of transmitter/receiver applications, such as, but not limited to, personal communication devices, cellular telephony, satellite communications, satellite TV, digital cable, satellite positioning or navigation devices, wireless communications (phones, wireless email, peripheral devices), and the like. Techniques can also be used for ranging (determining distance) between two or more devices.
System Example
For the purposes of illustration and example, concatenation techniques will now be described in the context of concatenation of two direct sequence (DS) modulation codes. However, the skilled artisan will appreciate that the principles and advantages described herein are applicable to two or more concatenated codes and to other types of spread spectrum codes. For example, frequency hopping (FH) modulation and time hopping (TH) modulation can also be concatenated. In addition, the type of modulation concatenated can be mixed, for example, a direct sequence (DS) modulation can be concatenated with a frequency hopping (FH) modulation. The disclosed concatenation techniques process two or more spread-spectrum modulations in series, which is different from the product code used in hybrid modulation schemes.
FIG. 1 illustrates an example of a concatenated spread spectrum system. In the illustrated system, two spread-spectrum modulators are concatenated (and two spread-spectrum demodulators are concatenated). However, the disclosed techniques are applicable to the concatenation of two or more modulators/demodulators. The data is spread-spectrum modulated on the transmit side via a concatenated modulator. The spread-spectrum signal is then transmitted over a channel. A receiver then despreads the concatenated spread spectrum signal. In the illustrated example, both the transmitter and the receiver use concatenated spread-spectrum modulators/demodulators. However, in another system, only one of the transmitter or receiver uses concatenation, and the other uses a spreading code that is a combination of an inner code and an outer code.
Transmitter
Data (d) is processed by a first spread spectrum modulator illustrated as an inner code spread spectrum (SS) modulator 102. In one embodiment, the inner code SS modulator is a direct sequence (DS) modulator. It will be understood that prior to processing by the inner code SS modulator, the data (d) can be processed by, for example, bit interleaving, forward error correction, encryption coding, or the like.
After processing by the inner code SS modulator 102, the inner code spread spectrum sequence S1 is provided as an input to a second SS modulator illustrated as an outer code SS modulator 104. For example, for each symbol of the first spread sequence S1, a pattern of pseudo-random noise (PRN) codes can be selected for spreading. In one embodiment, the outer code SS modulator is implemented by a lookup table, such as a ROM lookup table. This code can be considered to be block spread. A wide variety of other SS modulation implementations will be readily determined by one of ordinary skill in the art. The resulting outer code spread spectrum sequence S2 has a symbol rate of RdM1M2, where Rd is the input bit rate, M1 is the inner code spreading factor, and M2 is the spreading factor of the outer code. The spreading factor is defined as the ratio of the input symbol rate of a spread spectrum modulator to the output symbol rate of the modulator.
The outer code spread spectrum sequence S2 is then transmitted over a channel 106. Such transmission can include, as applicable, multiplexing, upconversion, RF modulation, RF power amplifiers, antennas, and the like.
Receiver
A receiver receives the transmitted signal. The receiver can include, for example, an antenna, receiver front-end, downconversion, and the like. The received spread spectrum sequence (r) is provided as an input to a first SS demodulator. The receiver can be embodied in a variety of electronics devices, such as, but not limited to, a transceiver for 2-way communications, in a mobile phone, in a wireless modem, in a navigation receiver, or the like.
The first SS demodulator is illustrated as an outer code SS demodulator 108, and despreads the spreading from the outer code SS modulator 104. The partially despread sequence (r1) is provided as an input to a second SS demodulator, illustrated as an inner code SS demodulator 110, which despreads the partially despread sequence (r1) to the despread sequence (r2). Assuming that there are no errors due to the transmission channel 106, then the despread sequence (r2) should be the same as the original data (d). However, if there is an error from the transmission channel 106, the data may differ and forward error correction (FEC) techniques can be used to correct the errors.
Implementation Details
Depending on the complexity of the spread-spectrum coding and operating speeds, the disclosed techniques can be implemented by hardware or by software, or by a combination of both hardware and software. In addition, hardware techniques can be implemented by digital circuits or by analog circuits, or by hybrid circuits utilizing both digital and analog circuits.
Receiver Implementation
It will be apparent to the skilled practitioner that a variety of circuits or techniques can be used to generate a receiver that performs the complementary despreading to the spreading of a transmitter. It should be noted that frequency offsets can exist between a receiver and a transmitter, and that the despreading circuits preferably have adjustable timing to compensate for differences in clock rates. Examples of sources of timing differences include clock offsets and doppler shifts (when the receiver and the transmitter are moving relative to each other). A receiver sync loop can be used to adjust the timing.
FIG. 2 illustrates an embodiment of a hybrid analog/digital receiver architecture. In the illustrated embodiment, the outer code demodulation is performed in the analog domain. This facilitates the use of lower digital processing rates and an overall reduction in power consumption.
The outermost code SS demodulator, e.g., the outer code SS demodulator 108 (FIG. 1), will typically operate at the highest speed and can be relatively more difficult to implement than the another SS demodulator, such as the inner code SS demodulator 110 (FIG. 1). To save power, it can be more efficient to implement the higher speed portions of the receiver, such as the outer code SS demodulator 108 (FIG. 1) in analog as illustrated in FIG. 2. In the illustrated embodiment, the inner code SS demodulator 110 (FIG. 1) is implemented in digital.
A dashed line 202 separates analog circuits to the left and digital circuits to the right. An antenna 204 receives an RF signal carrying the concatenated spread spectrum signal. Multiple RF signals and multiple concatenated spread spectrum signals can be received at the same time. A downconverter 206 downconverts the RF signal to recover a baseband signal 208. The baseband signal 208 is provided as an input to a code matched filter 210. Code matched filters can be implemented in analog domain or in digital domain. The illustrated code matched filter 210 is analog. A digital implementation will be described later in connection with FIG. 4.
The coefficients of the code matched filter 210 are determined by the coefficients used for the outer code. In one embodiment, the coefficients of the code matched filter 210 remain fixed over time. The outer code 211 should match the code used to spread the data by the outer code SS modulator 104. In one embodiment, the outer code used by the outer code SS modulator 104 is similarly fixed over time. The code matched filter 210 generates the partially despread sequence (r1) as an output. Examples of waveforms for the output of the code matched filter 210 are illustrated in FIG. 2. For the waveforms, synchronization or acquisition of the outer code 211 and the recovered baseband signal (r) has been assumed.
The partially despread sequence (r1) is provided as an input to an analog-to-digital converter (A/D converter) 212. In the illustrated embodiment, the A/D converter 212 is configured to sample the partially despread sequence (r1) in a non-uniform manner. As illustrated by the waveforms in FIG. 2, the partially despread sequence (r1) has correlation peaks. Information for despreading of the inner code is contained in these correlation peaks and the A/D converter 212 can be efficiently configured to sample substantially only the correlation peaks. Synchronization of the timing for sampling of the A/D converter 212 is performed by a clock recovery circuit 218 such that the sampling is aligned with the correlation peaks from the code matched filter 210. Other uses for these correlation peaks are also described later in connection with FIG. 6. One embodiment of an A/D converter 212 with non-uniform sampling will be described in greater detail later in connection with FIG. 5.
The output of the A/D converter 212 is provided as an input to a direct sequence spread spectrum (DSSS) despreading circuit 214. Conventional DSSS depreading circuits can be used. The DSSS despreading circuit 214 uses an inner code 216 to despread the data from the A/D converter 212 (in digital form). For example, the DSSS despreading circuit 214 can be implemented by a code matched filter. The inner code 216 is a replica of the inner code originally used to spread the data in the transmitter. The clock recovery circuit 218 adjusts timing for the A/D converter 212. A separate code tracking loop maintains alignment of the replica code for the inner code to the partially despread sequence (r1).
The despreaded output of the DSSS despreading circuit 214 is provided as an input to a data decoding circuit 220. For example, in a GPS system, the navigation message can be decoded. The data decoding circuit 220 can include circuits such as integrators and demodulators, and can share circuits with the DSSS despreading circuit 214. Conventional data decoding circuits can be used. The data decoding circuit 220 generates the despread sequence (r2) as an output, which can then be used by error correction circuits, decrypting circuits, and the like.
The timing of the code can also be used to determine a range to the transmitter of the code. For example, in a GPS system, the transmitters (satellites) and the receivers are ultimately synchronized to GPS time. Measurement of the delay can be associated with a distance from the transmitter for measurement of range ΔR (output of ranging processor 222). For example, the range information can be used to determine position.
The speed of analog circuits, such as delay registers, can be adjusted by adjusting the voltage on throttling transistors. These transistors control the current flow in the circuit which in turn controls the speed at which the output can change. The voltage on the throttling transistors can be adjusted by a receiver synchronization loop. It should be noted that the range of adjustment for the timing of an analog circuit can be relatively small, and that a cascade of analog circuits can be used to provide a relatively large timing adjustment range.
With respect to analog circuits, preferably, differential signaling techniques (where both non-inverted and inverted are available) are used to permit the use of multiplexing instead of multiplying to implement multiplication by −1 or +1. A summing circuit in a current mode circuit can be readily implemented with a wired-OR configuration. An analog circuit can save power over a digital circuit at relatively high frequencies.
Hybrid Circuit
In one embodiment, the outer code SS demodulator 108 (FIG. 1) is implemented by a hybrid analog and digital circuit is used as illustrated in FIG. 3. The hybrid circuit simplifies the task of synchronizing the receiver by using digital shift registers as delay elements. The timing of data passing through the digital shift registers can be adjusted by adjusting the speed of a clock signal, such as from a clock synthesizer circuit.
The received spread spectrum sequence (r) (baseband) is provided as an input to a delta sigma modulator 302. The delta sigma modulator 302 provides an output that is quantized to, for example, one bit. The output is oversampled 304 by a factor of N, such as 8. Other values for N will be readily determined by one of ordinary skill in the art. The oversampling 304 pushes the noise out to high frequency, where it can be removed via low-pass filtering.
The oversampled data is provided as an input to the shift registers 306 (serial input), which are preferably implemented in differential form to also effectively implement multiplication 308 of the shifting data with code coefficients (c0, c1, . . . cn) for matching. With coefficient values of −1 and +1, the data can be multiplexed from a differential circuit to implement multiplication by the code coefficients. The outputs are summed by, for example, a summing circuit 310 and then low-passed filtered 312 to generate the partially despread sequence (r1).
Transversal Filter
FIG. 4 illustrates a digital transversal filter, which is an example of a digital domain implementation for the outer code SS demodulator 108. The filter coefficients (replica code) are identical to the spreading code of the corresponding outer code SS modulator 104. In one embodiment, when the outer code SS modulator 104 uses a form of block coding, such as a ROM lookup table, a transversal filter is used to despread the symbols. An Analog to Digital converter (A/D converter) 402 converts the received spread spectrum sequence (r) (baseband) to digital. The digital signal is propagated through shift registers 404 for delay. In one embodiment, rather than using multipliers within the transversal filter to multiply coefficients (c0, c1, c2, etc.) of the code, differential logic is used (such as CML). For example, rather than multiply by +1 or −1, when the inverted output is desired, it is collected instead, i.e., multiplexing. Summation 406 can be performed by a wire OR-ing circuit.
A transversal filter can also be referred to as a code-matched filter (in digital form), a digital matched filter, or a correlator. Algorithmic strength reduction filter techniques can be used. See, for example, “Hardware Efficient Fast Parallel FIR Filter Structures Based on Iterated Short Convolution,” by Chao Cheng and Keshap K. Parhi, IEEE Transactions on Circuits and Systems, Vol. 51, No. 8, August 2004.
With digital domain receivers, the timing can be adjusted by using synchronous logic circuits which are operated using an adjustable clock signal 408. For example, a clock synthesis circuit can generate an adjustable speed clock signal, and the shifts between registers 404 is varied according to the speed of the clock signal 408.
In another embodiment, the transversal filter can be analog. Rather than using multiplexing and wire-ORing, multiplying DACs and summing circuits can be used in the analog circuit.
ADC Configuration
As described earlier in connection with FIG. 2, the output of the outer code demodulator exhibits the characteristic of periodic correlation peaks. It is only for the duration of these correlation peaks that the signal is of interest. This allows the system to employ non-uniform analog-to-digital conversion (ADC). An ADC configuration is shown in FIG. 5.
Two or more ADCs 502 are used to capture data around the correlation peaks of the outer code. While the sampling aperture of the ADCs should be very narrow (consistent with the high signal bandwidth), the conversion rate is low. That is, during other times, these ADCs can remain relatively inoperative, which can save power. In one example, four ADCs are used, and the sampling of each is offset from each other by about 1/R2, where R2 is the rate of the outer code such that 1/R2 is about the width of the correlation peak as shown in FIG. 6. A multiplexer (mux) 504 selects the appropriate output to combine the outputs of the ADCs 502.
Ranging
The concatenated codes can also provide an advantageously large correlation peak for the outer code as shown in FIG. 6.
For example, when implemented in a system of nodes where the nodes have a relatively good timing reference, such as via GPS system time, the reception of the concatenated codes can be used to measure the distance between nodes. 1/R2 corresponds to the width of the correlation peak, where R2 is the rate of the outer code SS modulation. R1 is the rate of the inner code SS modulation.
For example, the precise time that a signal is transmitted can be known via GPS system time (e.g., can be provided in the data signal). A precise time of reception can also be known with reference to GPS system time (e.g., as determined by the correlation peak). The difference in time can then be used to determine the difference in range between the two nodes.
Alternatively, the range measurement can be based on the round trip propagation time of an exchange of messages between two nodes. This approach does not require an external time reference.
Various embodiments have been described above. Although described with reference to these specific embodiments, the descriptions are intended to be illustrative and are not intended to be limiting. Various modifications and applications may occur to those skilled in the art.