The present invention is related to a communication device for W-CDMA signals which is software reconfigurable. The present invention is further related to a method for operating said device.
The present invention aims to provide a W-CDMA apparatus which allows the implementation of various telecommunication standards, and various applications realisable according to these standards, without the need for a powerful DSP processor for the flexible part of the physical layer.
A further aim is to provide said apparatus for various fading channel circumstances.
Another aim is to provide said apparatus under the form of an Intellectual Property core.
A communication device, for example, for Wideband Code Division Multiple Access (W-CDMA) is configured to operate in accordance with a predetermined telecommunication standard and predetermined parameters. The communication device typically has a digital signal processor (DSP) that allows it to adapt to changes of the physical layer.
There is therefore a need for a W-CDMA system, which allows the implementation of various telecommunication standards, and various applications realizable according to these standards, without the need for a powerful DSP processor for the flexible part of the physical layer. Further, there is a need for a W-CDMA apparatus that provides for various fading channel circumstances.
The present invention concerns a communication device for W-CDMA signal transmission and reception, which is software configurable, comprising:
a W-CDMA transmitter comprising RAM and/or registers;
a W-CDMA receiver comprising RAM and/or registers; and
signal acquisition means, characterised in that it further comprises a digital circuit for phase unbalance precompensation, said circuit comprising:
an input register holding the compensation angle,
means for performing arithmetic to acquire a change of the I,Q angle by the compensation angle.
According to a preferred embodiment of the present invention, said communication device further comprises a circuit for noise and interference estimation, said circuit comprising:
means to acquire a programmable number of absolute value accumulations at chip rate or oversampled chip rate,
a programmable low pass filter to average the noise and interference estimations.
According to a preferred embodiment of the present invention, said communication device further comprises a circuit for initial synchronization, said circuit comprising:
According to a preferred embodiment of the present invention, said communication device further comprises circuitry to generate packet data transmission, said circuitry comprising:
A data and activity bits holding buffer,
I,Q spreaders and gain control means,
scrambling code generator and scrambling means,
means for packet timing through RX frame edge triggering.
The present invention is equally related to the use of a communication device according to the present invention, for RACH transmission in UMTS/FDD.
Software reconfigurable means that parameters of a circuit and/or algorithmic alternatives for this circuit can be configured using software settings. The circuit itself is built up of logic, and contains memory (such as registers and/or RAM) which are preferably controlled by a processor subsystem, which performs the above mentioned software settings. Such an approach leads to lesser power consumption if compared to a complete software implementation, while there is still sufficient flexibility possible.
Said communication device can further comprise a processor. Such a processor can be any kind of processor capable of changing the settings of the device. Examples of such processors are DSP processors, microprocessors, microcontrollers, FPGA, logic circuits and FSM circuits.
The communication device is preferably characterised in that the processor is arranged to reconfigure the communication device.
Said processor preferably controls the RAM and/or registers of said W-CDMA signal transmitter and receiver.
The transmitter preferably comprises a first programmable pulse shaping filter and the receiver preferably comprises a second programmable pulse shaping filter which can be programmable to perform GMSK filtering while said transmitter and receiver are arranged to interface with a GSM front-end.
The processor can be arranged to perform the GSM protocol stack.
In a preferred embodiment, the communication device of the present invention is arranged for waveform transmission and/or reception and/or acquisition of signals selected from the group consisting of UMTS, Satellite UMTS, Galileo, GPS, IS-2000, IMT-2000, CDMA2000, IS-95, 3GPP, 3GPP2 and ARIB signals.
The transmitter of the device according to the present invention can comprise one or more elements selected from the group consisting of:
The PN code generator can be realised as a RAM in which the PN codes are downloaded under control of the processor. The scrambling code generator can be realised as a programmable Gold Code generator. The QPN channel can be arranged to execute UMTS forward or return link transmission. The amplification of the spreader output is preferably arranged to perform transmit power control.
The transmitter of the device according to the present invention preferably comprises a time interpolator to perform sub-chip time alignments (e.g. for S-CDMA).
The transmitter of the device according to the present invention can be arranged for multi-code transmission.
The receiver of the communication device of the present invention can comprise:
Said receiver preferably further comprises a downconverter prior to said pulse shaping filter, in order to interface at a front-end at an intermediate frequency. It can also be arranged for execution of UMTS, Satellite UMTS, Galileo, GPS, IS-2000, IMT-2000, CDMA2000, IS-95, 3GPP, 3GPP2 and/or ARIB forward link and return link waveforms.
The level control block preferably comprises:
The level control block is preferably operated in a runtime control loop by the processor.
The demodulator preferably comprises:
The finger blocks are preferably respectively grouped in a late multipath group and an early multipath group, the Rake filter being arranged to accumulate the energies of the outputs of said late multipath group and said early multipath group, and to use these accumulated values to feed the time error detector of the DLL used for time tracking.
The Rake filter can comprise memories to hold one or more of the following:
Said memories are preferably controlled by the processor.
The finger block preferably comprises:
The finger can be arranged for slow and fast fading compensation, by programming the channel correction Pilot filter for slow fading, said channel correction Pilot filter first performing a coherent accumulation over a slot, and secondly performing a weighted average over previous-previous, previous, actual and next obtained slot values, yielding a channel estimation per slot, which is applied by said channel corrector; and for fast fading, said channel correction Pilot filter first performing a coherent accumulation over a slot, and then deriving channel estimations through interpolating consecutive said coherent accumulations over a slot, yielding channel estimations with sub-symbol timing, which are applied by said channel corrector.
The reference demodulator preferably comprises:
The reference demodulator can be arranged to operate in a runtime control loop by the processor.
The demodulator is preferably arranged to perform satellite diversity.
The communication device of the present invention can be arranged to perform accurate ranging measurements to geostationary satellites.
A further aspect of the present invention is an Integrated Circuit comprising the communication device of the present invention.
A further aspect of the present invention is an Intellectual Property core comprising the communication device of the present invention (as a building block for inclusion in an integrated circuit).
Another aspect of the present invention is a method for operating a W-CDMA communication device of the present invention, characterised in that it comprises the following steps:
Said waveform signals are preferably selected from the group consisting of UMTS, Satellite UMTS, Galileo, GPS, IS-2000, IMT-2000, CDMA2000, IS-95, 3GPP, 3GPP2 and ARIB signals. Said configuring is preferably done by a processor.
Abbreviations
The global transmitter structure 1 is shown in
QPN Channels with Synchronisation Hardware and PN-Code Generators
The transmitter contains a plurality of QPN channels 3 (
Each set has a separate block for generating the PN-code 5 and separate synchronisation hardware 7 which defines the start of symbol transmission.
Synchronisation Hardware
The output of this part goes to the QPN channels of a set and defines a common symbol start moment for all QPN channels in a set. This signal is generated as a selection of 1 out of a plurality of incoming signals with a programmable offset.
The incoming sync channels can e.g. be generated by: another chip, TX timers, receiver pulse, acquisition hardware output, . . .
To generate the offset a counter at chip rate can be used. This gives an offset resolution of 1 ‘primary’ chip. The range of the offset is [0:65535]. This is sufficient to give an offset of 1 frame for UMTS (40960 chips).
QPN Channel
Each QPN channel 3 has the functional structure represented in
Spreader 11
The input binary symbols, coming directly from the interface (symbI 13 and symbQ 14) are spread with the PNbits PNbitI and PNbitQ. Each symbol has an activity bit (actI and actQ). When this is 0 the functional spreader output will be 0 in stead of +1 or −1.
This activity bit is used for burst transmission and for BPSK in stead of QPSK/QPN transmission.
symbI and actI are signals at symbolrate fsIxx, symbQ and actQ are signals at symbolrate fsQxx. fsIxx can differ from fsQxx. The spreading factor is set by the sfI 15 and sfQ 16 inputs.
The spreaders can be (re)started via the sync signal 17.
fcp=fsIxx*sfI=fsQxx*sfQ.
Symbol clock signals 19 (symbclkI and symbclkQ) are generated as a symbol reference for other hardware that requires symbol synchronous actions, like the gain controls 21.
Gain Control (Transmit Power Control)
Each complex spreader 11 is followed by a separate gain control 21. Each output branch of a spreader is again separately gain controlled.
PN-Code Generators
These blocks generate the complex PN codes for the QPN channels 3 (
Gold Code Generator
This is a classical Gold code generator with e.g. 42 bit registers which can generate any Gold code with any length up to (2^42)−1. It can also be used to generate any segment out of a Gold code smaller than (2^42)−1.
The sgfb inputs define the feedback position in the shift register, the init inputs are used to initialise the shift registers at reset or restart. The poly inputs are used to program the polynomials to generate the Gold sequences. The rest signals are used to make generate a small section of the complete Gold code and then jump to the back to the init value. If the register in the gold code generator reaches the rest state, the register is in the following clock-cycle re-initialised.
RAM Based Code Generation
Each set has a block 23 which can generate PN-codes based on a RAM. For all three sets the same block 23 is used. This is shown in
The block 23 contains a RAM of e.g. 8*1024 bits. An address generator selects one row 35 of this RAM with the x address, then these 8 bit are routed to the spreaders via a switch controlled by address y.
The address generator 31 has a start 25, stop 27 and step input 29. The address generator can be configured in different ways with the configure input 33.
It is possible to stop the generators when the activity bit of a symbol is 0.
Below a number of illustrated examples of possible RAM configurations are given:
As shown in these examples, in the case of variable spreading factor transmission (e.g. OVSF codes in UMTS), it is assumed that spreading factors have a common multiple. The RAM is filled with replica's until the common multiple length is reached. In this way the symbols in one set are multiple-symbol synchronous.
Combiners at fcp Rate
The two combiners 38 after set A and set B at fcp rate output the sum of the 4 incoming complex numbers.
Scrambler 40 and Scrambling Code Generation
Scrambling Code Generator 41
This block generates the complex scrambling code Cscramb=cI+jcQ.
Each scrambling code generator has its own synchronisation hardware block to generate the sync signal. (see
The scrambling code generator contains 2 Gold code generators with 42 bit register, 2 RAMs of 256 bit, an interface for external input of codes and some extra hardware for UMTS to modify the Gold codes.
The Gold code generators are functionally the same as the Gold code generators in the PN code generators.
This is a classical Gold code generator with 42 bit registers which can generate any Gold code with any length up to (2^42)−1. It can also be used to generate any segment out of a Gold code smaller than (2^42)−1.
The sgfb inputs define the feedback position in the shift register, the init inputs are used to initialise the shift registers at reset or restart. The poly inputs are used to program the polynomials to generate the Gold sequences. The rest signals are used to make generate a small section of the complete Gold code and then jump to the back to the init value. If the register in the Gold code generator reaches the rest state, the register is in the following clock-cycle re-initialised.
It is possible to re-initialize the generators after a programmable number of chips or to let them run freely.
Examples of Different Modes
Mode 0
cI and cQ are any Gold code with any length of maximum (2^42)−1.
Mode 1
cI and cQ come directly from a RAM of 256 bit. it must be possible to use only the first k bits in the RAM, with k smaller than 257.
Mode 2
Mode0 but with zero extension in front of the generated Gold codes. cI=<0,c1>, cQ=<0,c2>
Mode 3 (UMTS Specific)
Mode0 or Mode1 but c1 and c2 coming from the Gold code generators or RAM are modified in the following way:
Cscramb=cI+jcQ=c(w+jc′w)
With a decimation factor of decim=2, c′ is given as:
c′(2k)=c′(2k+1)=c(2k), k=0, 1, 2 . . .
c1 and c2 are constructed as the position wise modulo 2 sum of 40960 chip segment of two binary m-sequences generated by means of two generator polynomials of degree 41.
The code c2, used in generating the quadrature component of the complex spreading code is a 1024-chip shifted version of the code c1 used in generating the in phase component.
Scrambler 40
The scrambling is in fact an overlay spreading without changing the chiprate, the change in chip rate is done with the Hold 1-256 block.
Input data: dI+jdQ
Input scrambling code: cI+jcQ
This block has 3 modes:
This block is used to do a chip phase shift with a resolution smaller than 1 chip. For every sample in, one output sample is generated, input and output clock is the equidistant clock.
A linear interpolation is used to perform this function:
out(k)=(1−TXMU)*in(k−1)+TXMU*in(k)
The fixed upsampling with a factor of e.g. 4 (zero insertion) and a symmetrical programmable filter are realised as a complex oversampling polyphase filter. The output sampling rate f4c=4*fc.
Offset Modulation
By setting offset to 1, the Q branch will be delayed with 0.5 chip.
Complex Upconvertor 42 and NCO 44
NCO 44
This block generates a cosine and sine value. The cos and sin values are frequency and phase controllable.
The specifications below are not required for cellular, but can be used for satellite applications with demanding phase noise requirements.
The sine and cosine values are generated with the 16 MSB of a s<32,0> phase value. The 14 LSB of this 16 bit number go to 2 lookup tables which contain the values for sin and cos in [0,2*pi[ with a gain of 2047/2048. The lookup wordlength for sin and cos in quadrant 1 is u<11,11>. The 2 MSB of the s<32,0> bit phase register are used to recover the quadrant, sin and cos are s<12,11> numbers. The output of the NCO is the complex signal (cos+j·sin).
The s<32,0> bit phase register can be directly controlled via the TXPHASE input (s<32,0>) or by integrating with wrap around the TXINC (s<32,0>) value. The TXINC can be used to program the frequency of the generated sine and cosine in the following way:
f sin=f cos=TX_INC/2^32*f4c.
With TXINC negative a negative (complex) IF will be generated.
For example, to generate a complex carrier at −20 MHz with, TXINC should be set to −1073741824.
The s<32,0> phase register should be a part of the chip boot chain.
Upconverter 42
Here a complex upconversion with the NCO generated complex carrier is done.
The computations are done full precision, the multiplications have 1 redundant bit as the most negative number will never be present in the sin or cos value. Thus the result of the multiplications are s<32,24> bit numbers. This makes the full precision outputs bit numbers.
These full precision numbers are reduced to s<35,16> numbers.
Level Control 2
The purpose of this block is to condition the signal coming from the upconverter prior to the DA conversion.
Phase Unbalance Compensation (
Digital phase unbalance compensation is used to remove the I,Q phase difference from 90 degrees prior to A/D conversion.
A phase unbalance compensation is done:
Iout=Iin+Qin*tan(β)
Qout=Qin+Iin*tan(β)
with 2β the phase angle to correct.
tan(β) is stored in the TGCR_AC variable. A range for 2β is larger than 13 degrees. The resolution of 2β is smaller than 1 degree.
The transfer of TGCR_AC is synchronous with the I0A symbol clock.
Receiver Specification
The global receiver structure is shown in
Common Downconverter with NCO 47
Downconverter 45
This block performs a complex downconversion, with the NCO generated complex carrier, on the incoming complex signal. The output signal is expected to be a near baseband signal.
Input and output are at fin rate.
Programmable FIR Filter 49 with Downsampling 51
The complex receive stream coming from the downconverter is filtered by a programmable symmetrical FIR filter and downsampled with a factor RXD. RXD can be 1 or 2.
Inputs are at fin rate, outputs at f2ct rate.
Level Control 53 with Overflow Detectors
To optimise the number of significant bits going into the demodulator correlators a common level control is foreseen to adapt the level of the signal coming from the filter (see
The incoming complex data is shifted over a RXSHIFT bits 55. This is a coarse gain with 6 dB steps. A lower resolution gain control is done by the multiplication by RXMULT 57. The multiplication is followed by saturation logic (on the data) abd overflow counters. For this reason the result from the multiplication is extended with 1 MSB to produce the input for overflow counter 1. Overflow counter 159 counts the real overflows, so the overflows where the saturation logic saturates the signal. Overflow counter 261 is required to count the overflows as if the signal amplitude was twice as big.
S/(N+I) Estimator (63)
The noise estimator 63 (
The filter is a simple hardware low-pass filter.
By setting bypass to 1, the low-pass filter can be bypassed.
Demodulator 67
In most modes the plurality of demodulators are used to support base station diversity for soft hand-over, however they can also be used for other purposes. In the following paragraphs the demodulator structure will be explained in more detail.
Each demodulator also has a Rake block 71 performing a combination of channel corrected multipath components. This block will also be discussed in more detail later.
Not all the hardware in
Tracking Unit 69
Each of the e.g. 3 tracking units 69 (
Tracking Unit Downconverter 45 and NCO 47
This block is used as actuator for the carrier phase/frequency tracking. A final downconversion is performed.
Tracking Unit Interpolator 74 with Chip Frequency Control
This block is used as actuator for the chip phase/frequency tracking. This is done by a pseudo-chip rate change. The outcoming chip rate is controlled via the DINT input.
Linear interpolation between samples spaced approximately 0.5 chip is performed by:
out(k)=(1−INTMU)*in(k−1)+INTMU*in(k)
The DINT input is used to change the INTMU continuously by adding DINT to the previous value of INTMU every cycle. This results in a change in chiprate by 1/(1+DINT).
This block causes a delay of 1 sample. For example, when DINT=cte=0, out=in z^−1 with a 0.0 added at the start.
The input samples are equidistant at f2c rate. The output samples of the interpolator are not equidistant at f2cr rate. f2cr is between f2c/2 and 2*f2c. So all the hardware after the interpolator must be designed to work at 2*f2c although its nominal rate will be f2c.
MEL Gate 75
This MEL gate 75 is only used in no-cellular modes; otherwise it's bypassed through the appropriate multiplexer settings. The incoming stream at f2cr is split in three streams at f2cr rate.
E=in·z^−2
M=in·z^−1
L=in
In this way each stream is spaced 0.5 chip.
The M signal of Tracking unit 0 is also used as input for the Rake block, if it is activated (see further).
Downsampling 80 Factor
A phase controllable downsampling with a factor e.g. 2 is performed here by skipping 1 incoming sample of 2 incoming samples. D2 defines which phase to skip. The output rate is fc=f2cr/2.
Chip Stream Selection
The 3 multiplexers 81 allow to choose between which signal goes to the final correlators 83. This can be the downsampled signal coming from the MEL gate or it can be the Rake output at chip rate.
Scrambling Code Generator 41
This is functionally the same as the transmitter scrambling code generator, but at fc rate.
Descrambler 83
Input data: dI+jdQ
Input scrambling code: cI+jcQ
This block should have 3 modes:
In the 3 modes the delay between in and output should be the same. Input and output are at fc rate.
Despreaders 85
Each tracking unit contains a number of QPN despreaders. Each despreader and each branch of the despreader can have a different spreading factor.
Variable Amplifiers 87
This block is used as actuator for the signal amplitude tracking. Each Vamp 87 can have a different gain.
The output of the Vamps are the soft symbols MD, MP, EP and LP which stands for Middle Data, Middle Pilot, Early Pilot and Late Pilot but when in Rake (UMTS mode) these signals have completely different meanings than these names suggest.
PN-Code Generators 89
This block generates the complex PN-codes for the despreaders 85. This is a similar block as in the transmitter. So possibility to use a RAM, Gold code generator or an external input.
Tracking unit 0 is equipped with e.g. 4 separate generators, unit 1 and 2 have only 1 generator. So the 4 despreaders in unit 1 and 2 use the same despreading code.
AED 91 and AGC 93
The AED 91 is the error detector for the signal amplitude tracking. The AGC 93 does a filtering on this signal and outputs the signal going to the Variable amplifiers.
Tracking unit 0 has 4 separate AED and AGC for each despreader in the tracking unit, while tracking unit 1 and 2 only have a common AED and AGC working on the MP signal.
PLL 70
The NCO of each tracking unit can be set by an external block like ARM software or can be controlled by the PLL. The PLL works on the MP signal. When the Rake is used, the PLL is turned off.
TED0, TED1 and DLL 97
The TED0 or TED1 are used as error detectors for the chip timing tracking. TED1 is used when the CCP is used as a signal source for the despreaders of the unit, while TED0 is used when classic Early-Late correlator tracking is done. The output of the TED 91 goes to the DLLs, chip frequency controlling the interpolator.
Symbol Combiner (Not Shown)
When the 3 tracking units are used for tracking different multipaths of the same signal, a hardware combination of the 3 CD outputs can be performed. Functionally this is only an addition of the complex CD numbers. However the symbol timing of CD[0], CD[1] and CD[2] will be different which will complicate the coherent symbol combining.
Rake Receiver 101
This block (
Demodulator Using Rake
This section gives a detailed explanation on the use of the demodulator as a receiver where multipath components are coherently combined at chiprate. The Rake block of the demodulator is only used in this mode and is also discussed in detail in this section.
This specification is e.g. for reception of a UMTS waveform.
A possible configuration of a demodulator for UMTS mode, using only 1 tracking unit 90, is shown in
The Rake-based demodulator configuration reuses almost everything from the tracking unit except for the PLL and PED. A large extra block that is not used when using Early-Late correlator tracking is the Rake 71. So roughly said the Rake-based demodulator consists of the Rake that generates a new chip stream from the incoming chip stream and the classic descrambler 83, despreader 85, . . . hardware.
With the configuration of
The only despreading in the Rake is the pilot symbol despreading used to make the channel estimations.
Chip phase tracking is done by a timing error detector (TED0) and DLL working at slotrate.
More details can be found further.
Rake Overview
This part (
The pilot symbols can have a SF from 4 to 256 and may be arbitrarily distributed over the slot.
Fingers 0 to 4 contribute to the Late multipaths, fingers 5 to 7 to the Early multipaths. Note that there is no real ‘Middle’ finger, this means that in the case of a single path, the correlation energy will be split over finger 4 and 5 and one will never correlate at the ‘top’ of the correlation shape.
In one of the possible ways of using the Rake, it will be initialised so that the strongest peak will be between finger 4 and 5. With the phase controllable decimation (D2) the chip phase can be set with a resolution of ½ chip.
Each finger has as inputs:
Other configuration inputs like: threshold to decide on which finger there is a signal, filter coefficients for channel estimation filtering, etc. They are not on
NOTE: the RAMs of 640 bits could be smaller if it is not required that we could have a burst of pilot chips equal to 4 chips anywhere in the slot. It is most likely that this is not required. E.g. 8 consecutive pilot symbols SF can be replaced by 1 pilot symbol with SF 32.
Each finger has a complex CCCP[x] output at chip rate. This is the delayed chips multiplied with the complex conjugate of the channel estimation of finger x.
Each finger also has a FNx output at slot rate which is the energy of the coherent accumulation of all pilot chips/symbols in a slot of finger x.
The sum of all FNx is calculated and goes to the pilot AGC. In this way CCCP will not be dependent on the pilot energy.
As one has fixed finger spacing we only need a global DLL.
The DLL will work on slot rate, the Late and Early energies are calculated as:
ENL=FN0+FN1+FN2+FN3+FN4,
ENE=FN5+FN6+FN7.
ENL and ENE go to the DLL which feedbacks to the interpolator at the input of the demodulator using the Rake filter.
Rake Finger 115
This section describes the fingers architecture (see
Descrambler 117
The incoming chips are descrambled with Psb. This code and its phase is common for all fingers. The phase has to be set during an acquisition process initialising the Rake. Has the same functionality as the other descramblers.
Complex Pilot Despreader 119
The complex signal coming from the descrambler at chip rate is despread with the pilot PNcode (Pcb), only 1 despreader, so the pilot must be a QPSK or BPSK signal.
The pilot PNcode has a PNlength of Psf. 4<=Psf<=256, and k*Psf=2560 with k a positive integer.
The despreader works continuously and is synchronised to the slot edge at chip rate. This means that a new symbol starts at the start of the slot (slot−edge=1).
Variable Amplifier 121
The complex symbol coming from the despreader is sent through the Variable Amplifier (VAMP) 121. The complete CCMR has one global AGC which sets the Pgain at slotrate.
For different spreading factors, the initial gain must be set to a different value, eg to 1.0 for SF 256, to 64.0 for SF 4.
Pilot filter 123. Slotwise Coherent Pilot Symbol Accumulation 124
In this block a coherent pilot symbol accumulation is done on a slot by slot basis. The Pac input defines if the symbol coming from the VAMP is a pilot symbol. See
In this example the Psf is 256, Pac would be 111100000 . . . 0000.
Pi with i=0, 1, 2, . . . the pilot symbol index, are the complex despread pilot symbols Dva (@fsymbB). In order to accumulate them coherently, the pilot modulation must be removed first. This modulation is known a priori and must be present at the Psy input. For QPSK Psy can take 4 values: +1, −j, +j, −1.
For QPN Psy can take 2 values: +1 and −1. So Psy is represented by a 2 bit value (Psy[0] and Psy[1]).
The values Pi are then demodulated in the following way (Piu are the demodulated values of Pi) (u=unmodulated):
For QPN Psy must only take the values 00 or 11.
Spj are the complex accumulation of these demodulated pilot symbols from the current slot, divided by the number of pilots (or multiplied by 1/number of pilot symbols):
Sp=accumulation of Piu, divided by the number of Pilot symbols.
This is equivalent with despreading over all the pilot chips in the slot in the case of unmodulated Pilot symbols.
Sp values are generated at slot rate fslot. The value is available at the end of the slot.
This module is slot-synchronous.
Finger Energy Calculation 125
Here a measure for the finger energy is calculated slot by slot. Because there is a delay of 2 slots on the chips we would also calculate the energy from a delayed Sp value. This is shown in
The energy is calculated as follows: Sp_i^2+Sq_q^2. With a delay of 1 slot on Sp.
This energy will be used for the DLL and zero forcing.
Channel Estimator 127
This block performs a filtering or interpolation on the Sp values.
The exact function to perform depends on the Chm (channel mode) input (fast or slow fading channels).
The output of this block is the channel estimation ces at chiprate.
When Chm=0, the Ce_FIRcoef[4] and Ce_FIRmult[4] inputs are needed, when Chm=1 the pipo input is needed.
Channel Mode 0: Slow Fading 131
In this mode ces is constant over a complete slot. ces is a filtered version of the incoming Sp values. See
The multiplication after the filter is to have a FIR filter 129 with unity gain. To avoid a transient in the amplitude on the signal coming from the filter, 4 different values are stored for this gain. The first output of the filter gets gain CeFIRmult[0], the second output CeFIRmult[1], the third CeFIRmult[2] and CeFIRmult[3] is used on sample number 4 leaving the filter and in steady state mode.
All filter taps should be initialised to 0 at the start of the process.
The filter and multiplier work at slotrate fslot, ces are samples at chiprate. (oversampling of filter output).
The different pilot symbols are demodulated and coherently accumulated giving the values Sp0 to Sp5. The channel estimations ces are the output of the 4 taps FIR filter, ces0 is a function of Sp0 to Sp3. ces0 is constant over slot number 4. The De chip from slot 2 is delayed 2 slots so that it is available with slot 4 as D1 chip. This chip is multiplied with the complex conjugate of ces0 to give the Dro chip of this finger.
It is clear that the chip arriving in slot 2 is ‘corrected’ with the info from pilot symbols of slot 0,1,2 and 3.
Every chip is always corrected with the aid of the Before Before, Before, Present and After slot. (unless some filter taps are set to 0). Channel estimations change only at slot rate. Note that Sp3 is generated together with the last chip of slot 3 while ces0 which is a function of Sp3 is used for all chips of slot 4.
Channel Mode 1: Fast Fading 133 and 135
In this mode ces are interpolated values between the current and the previous Sp values entering the channel estimator. So ces changes at chip rate. See
The incoming Sp values are positioned in the middle of the pilot portion to calculate the other complex values. The pipo (pilot position) input is used for this. It is an integer in the range [0:2559]. In
Linear interpolation is performed on both real and imaginary part of the Sp values. In this way we go via a straight line in the complex plane from Sp(k−1) to Sp(k).
Re[ces(i)]=(Re[Sp(k)]−Re[Sp(k−1)])*(i−pi—po)/2560+Re[Sp(k−1)]
Im[ces(i)]=(Im[Sp(k)]−Im[Sp(k−1)])*(i−pi—po)/2560+Im[Sp(k−1)]
with i=0, 1, 2, . . . 2559 The 2560 different chips in a slot.
See
The different pilot symbols are demodulated and coherently accumulated giving the values Sp0 to Sp5. The channel estimations ces(i) for the chips i of slot 2 are calculated during slot 4 with the aid of Sp2 and Sp3.
So the Present and Future slot is used to make the channel estimates.
Channel Correction 128 (
This block has as input the delayed chips D1 coming from the FIFO and the channel estimations per chip ces.
The function of this block is to correct for the channel phase of the finger and give a weight to the finger. The outputs from the different fingers can then be combined (coherently) in one signal.
The following action is performed in these blocks:
Dro=D1*ces(*) with ces(*) the complex conjugates of ces.
Zero Forcing 126 (
Each finger output can be forced to zero with the zf signal.
The purpose of this is to set a finger to 0 when no (or very little) signal is present in that finger to avoid the accumulation of a lot of noise.
The zf signal is obtained by comparing the slotwise FN and a programmable threshold. zf is 1 if FN<=threshold.
Noise Estimator (
The purpose of this block is to get an estimate of the noise power before the despreaders. The block is present on despreaders 0 of tracking unit R input, so at the output of the descrambler.
The N estimator calculates:
with ci, cq the real and complex input of the despreader. The noise power is then the output of this block divided by RR._NC_LEN.+1.
The functional structure is shown in
Then these numbers are filtered by a low-pass filter:
filter_out=(1−α)*filter_in+α*filter_out*z−1
By setting alpha to 0, the filter is bypassed.
RR_NC_ALPHA is a <6,6> number.
The output of the filter goes to the register RR_NC_OUT.
With the start signal the integration can be restarted at any moment.
SCH RX Hardware (
3 modes are possible: initial cell search, idle mode cell search and active mode cell search.
Initial Cell Search
Steps 1 and 2 of the Initial Cell Search are discussed here:
Step 1: Slot Synchronisation (
In this step, the MS acquires slot synchronisation by doing a fast acquisition on Cp which is common to all Bss.
The samples coming from the SRRC filter and at 2 fchip are sent through a matched filter 200 with the Cp code.
The first 5120 moduli are written into the RAM. To get better reliability a non-coherent dwell is performed. This is done by adding the next 5120 points to the previous 5120 points already present in the RAM. This is repeated for the required number of dwells.
During the last dwell, the maximum detection module 201 finds the maximum in the last 5120 points written to the RAM, and returns the address of this value. This address identifies the slot edge. The correlators can be switched off during this stage.
Step 2: Frame Synchronization and Code-Group Identification
Each BS belongs to 1 of 32 possible codegroups. Each codegroup uses a different sequence of 16 Cs codes on SCH2. From step1 the position of the secondary codes is known. The decision variables are obtained by non-coherently summing the correlator outputs corresponding to each 16 length sequence out of the 32 possible sequences and its 16 cyclic shifts. One decision variable is formed by adding 16 correlator outputs non-coherently (modulus). The calculation of these 512 values is distributed over the 16 idle intervals ( 9/10) after each correlation.
By generating the correct x and y (x=phaseshift, y=codegroup number) one of the 6 correlator outputs can be selected and the modulus is calculated. During the first slot, in the idle period, each of the codegroup table entries is selected, this selects 1 of the 6 correlator outputs and the modulus of these are written to one of the 512 used RAM positions during step2. During slot no 2, each value in the RAM is added with 1 of the 6 correlator modulus outputs of slot2. Which correlator needs to be selected for each RAM address is selected by the x and y combination. This is repeated for the 16 slots, during slot no 16 the resulting values are the 512 decision variables which are sent through the maximum detector.
The address coming from the maximum detection block identifies the codegroup and the phase shift. The frame edge can be determined from the shift.
At least 16 slots have to be added non-coherently.
PRACH TX Hardware (
One of the general TX channels is used to make the PRACH waveform. In that case the following things are required for the general TX channels:
The MS acquires synchronisation to a BS (SCH channel) and reads different parameters from the BCCH channel (preamble spreading codes, available signatures, available access slots, . . . ). The software 210 decides which parameters to use, these parameters are passed to the hardware via the interface block 211. The start of the access slot offset must be synchronous with the BCCH frame edge 214.
The upconverter must be set to a Doppler precompensated IF in order to avoid big integration losses in the BS receiver.
Spreaders (212):
The data coming from the interface block is spread with a max SF of 256. For the access slot offset and the idle period, the activity bit is set to 0. For each of the two branches 256 bit RAM is needed to store the PN codes.
Gain Stage
The spread data is sent through a gain block 213. A different gain must be possible for 1 and Q branch.
This application is the U.S. National Phase of International Patent Application No. PCT/BE00/00086 filed on Jul. 19, 2000 under the Patent Cooperation Treaty (PCT), which was published by the International Bureau in English on Feb. 1, 2001 as WO 01/08314 A2, which designates the U.S. and is a non-provisional application of U.S. Provisional Patent Application No. 60/145,426, filed Jul. 23, 1999, each of which is incorporated by reference.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/BE00/00086 | 7/19/2000 | WO | 00 | 7/16/2002 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO01/08314 | 2/1/2001 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4291409 | Weinberg et al. | Sep 1981 | A |
4761778 | Hui | Aug 1988 | A |
4817146 | Szczutkowski et al. | Mar 1989 | A |
5327455 | De Gaudenzi et al. | Jul 1994 | A |
5327467 | De Gaudenzi et al. | Jul 1994 | A |
5345472 | Lee | Sep 1994 | A |
5381108 | Whitmarsh et al. | Jan 1995 | A |
5406570 | Berrou et al. | Apr 1995 | A |
5511067 | Miller | Apr 1996 | A |
5559828 | Armstrong et al. | Sep 1996 | A |
5606575 | Williams | Feb 1997 | A |
5675609 | Johnson | Oct 1997 | A |
5734962 | Hladik et al. | Mar 1998 | A |
5742637 | Kanterakis et al. | Apr 1998 | A |
5812607 | Hutchinson et al. | Sep 1998 | A |
5825327 | Krasner | Oct 1998 | A |
5872810 | Philips et al. | Feb 1999 | A |
5903611 | Schnabl et al. | May 1999 | A |
5950127 | Nitta et al. | Sep 1999 | A |
5982807 | Snell | Nov 1999 | A |
5995537 | Kondo | Nov 1999 | A |
6009325 | Retzer et al. | Dec 1999 | A |
6081697 | Haartsen | Jun 2000 | A |
6097974 | Camp, Jr. et al. | Aug 2000 | A |
6108317 | Jones et al. | Aug 2000 | A |
6122291 | Robinson et al. | Sep 2000 | A |
6125266 | Matero et al. | Sep 2000 | A |
6141373 | Scott | Oct 2000 | A |
6208292 | Sih et al. | Mar 2001 | B1 |
6208844 | Abdelgany | Mar 2001 | B1 |
6219341 | Varanasi | Apr 2001 | B1 |
6252917 | Freeman | Jun 2001 | B1 |
6272168 | Lomp et al. | Aug 2001 | B1 |
6282184 | Lehman et al. | Aug 2001 | B1 |
6307877 | Philips et al. | Oct 2001 | B1 |
6317422 | Khaleghi et al. | Nov 2001 | B1 |
6324159 | Mennekens et al. | Nov 2001 | B1 |
6351236 | Hasler | Feb 2002 | B1 |
6359940 | Ciccarelli et al. | Mar 2002 | B1 |
6370669 | Eroz et al. | Apr 2002 | B1 |
6373831 | Secord et al. | Apr 2002 | B1 |
6400314 | Krasner | Jun 2002 | B1 |
6411661 | Nguyen et al. | Jun 2002 | B1 |
6480529 | Sih et al. | Nov 2002 | B1 |
6542558 | Schulist et al. | Apr 2003 | B1 |
6549784 | Kostic et al. | Apr 2003 | B1 |
6563856 | O'Shea et al. | May 2003 | B1 |
6580921 | Inoue et al. | Jun 2003 | B1 |
6597727 | Philips et al. | Jul 2003 | B2 |
6614834 | Meng et al. | Sep 2003 | B1 |
6748010 | Butler et al. | Jun 2004 | B1 |
6898233 | Philips et al. | May 2005 | B2 |
20010003530 | Sriram et al. | Jun 2001 | A1 |
20020064142 | Antonio et al. | May 2002 | A1 |
Number | Date | Country |
---|---|---|
0 511 139 | Oct 1992 | EP |
0 563 020 | Sep 1993 | EP |
0 767 544 | Apr 1997 | EP |
0 820 159 | Jan 1998 | EP |
0 928 084 | Jul 1999 | EP |
2 675 968 | Oct 1992 | FR |
WO 9638993 | Dec 1996 | WO |
WO 9714056 | Apr 1997 | WO |
WO 9802758 | Jan 1998 | WO |
Number | Date | Country | |
---|---|---|---|
60145426 | Jul 1999 | US |