주요 콘텐츠

lteULChannelEstimatePUCCH1

PUCCH format 1 uplink channel estimation

Description

[hest,noiseest] = lteULChannelEstimatePUCCH1(ue,chs,rxgrid) returns an estimate for the channel by averaging the least squares estimates of the reference symbols across time and copying these across the allocated resource elements within the time frequency grid. lteULChannelEstimatePUCCH1 returns hest, the estimated channel between each transmit and receive antenna and noiseest, an estimate of the noise power spectral density.

[hest,noiseest] = lteULChannelEstimatePUCCH1(ue,chs,cec,rxgrid) returns the estimated channel using the method and parameters defined by the user in the channel estimator configuration structure, cec.

example

[hest,noiseest] = lteULChannelEstimatePUCCH1(ue,chs,cec,rxgrid,refgrid) returns the estimated channel using the method and parameters defined by the channel estimation configuration structure and the additional information about the transmitted symbols found in refgrid. The rxgrid and refgrid inputs must have the same dimensions. For cec.InterpType = 'None', values in refgrid are treated as reference symbols and the resulting hest will contain non-zero values in their locations.

[hest,noiseest] = lteULChannelEstimatePUCCH1(ue,chs,rxgrid,refgrid) returns the estimated channel using the estimation method as described in TS 36.101, Annex F4 [1]. The method described utilizes extra channel information obtained through information of the transmitted symbols found in refgrid. This additional information allows for an improved estimate of the channel and is required for accurate EVM measurements. rxgrid and refgrid must only contain a whole subframe worth of SC-FDMA symbols.

Examples

collapse all

Use the lteULChannelEstimatePUCCH1 function to estimate channel characteristics for PUCCH Format 1

Initialize a UE configuration structure, PUCCH settings, and create a resource grid.

ue = struct('NULRB',6,'NCellID',0,'NSubframe',0,'Hopping','Off');
ue.CyclicPrefixUL = 'Normal';
ue.NTxAnts = 1;
pucch1.ResourceIdx  = 0;
pucch1.DeltaShift   = 1;
pucch1.CyclicShifts = 0;
reGrid = lteULResourceGrid(ue);
reGrid(ltePUCCH1DRSIndices(ue,pucch1)) = ltePUCCH1DRS(ue,pucch1);

For the purpose of this example, we skip SC-FDMA modulation, channel and SC-FDMA demodulation stages of the system model and use reGrid as the received resource grid. Initialize the channel estimation configuration structure and perform channel estimation operation on reGrid.

cec = struct('FreqWindow',12,'TimeWindow',1,'InterpType','Cubic');
hest = lteULChannelEstimatePUCCH1(ue,pucch1,cec,reGrid);

Input Arguments

collapse all

UE-specific configuration settings, specified as a structure that can contain the following fields.

Parameter FieldRequired or OptionalValuesDescription
NULRBRequired

Scalar integer from 6 to 110

Number of uplink resource blocks. (NRBUL)

NCellIDRequired

Integer from 0 to 503

Physical layer cell identity

NSubframeRequired

0 (default), nonnegative scalar integer

Subframe number

CyclicPrefixULOptional

'Normal' (default), 'Extended'

Cyclic prefix length

NTxAntsOptional

1 (default), 2, 4

Number of transmission antennas.

HoppingOptional

'Off' (default), 'Group'

Frequency hopping method.

NPUCCHIDOptional

Integer from 0 to 503

PUCCH virtual cell identity. If this field is not present, NCellID is used as the identity.

Data Types: struct

PUCCH channel settings, specified as a structure that can contain the following fields.

Parameter FieldRequired or OptionalValuesDescription
ResourceIdxOptional

0 (default), integer from 0 to 2047 or vector of integers.

PUCCH resource indices, specified as an integer or a vector of integers. Values range from 0 to 2047. These indices determine the physical resource blocks, cyclic shift and orthogonal cover used for transmission. (nPUCCH(1)). Define one index for each transmission antenna.

ResourceSizeOptional

0 (default), integer from 0 to 98.

Size of resource allocated to PUCCH format 2 (NRB(2))

DeltaShiftOptional

1 (default), 2, 3

Delta shift, specified as 1, 2, or 3. (Δshift)

DeltaOffsetOptional

0 (default), 1, 2

(Δoffset). Warning: The use of this parameter field is not advised. It applies only to 3GPP releases preceding v8.5.0. This parameter will be removed in a future release.

CyclicShiftsOptional

0 (default), integer from 0 to 7

Number of cyclic shifts used for format 1 in resource blocks (RBs) with a mixture of format 1 and format 2 PUCCH, specified as an integer from 0 to 7. (Ncs(1))

Data Types: struct

Received resource element grid, specified as an NSC-by-NSym-by-NR array of complex symbols.

  • NSC is the number of subcarriers

  • NSym = NSF × NSymPerSF

    • NSF is the total number of subframes. If NSF is greater than one, the correct region is extracted from the returned hest array. The location of the estimated subframe within hest is specified using the parameter field cec.Window.

    • NSymPerSF is the number of SC-FDMA symbols per subframe.

      • For normal cyclic prefix, each subframe contains 14 SC-FDMA symbols.

      • For extended cyclic prefix, each subframe contains 12 SC-FDMA symbols.

  • NR is the number of receive antennas

Data Types: double
Complex Number Support: Yes

Channel estimator configuration, specified as a structure with these fields.

Parameter FieldRequired or OptionalValuesDescription
FreqWindowOptional

Odd scalar integer or a multiple of 12

Size of window used to average over frequency, in resource elements (REs), specified as a scalar integer.

TimeWindowOptional

Odd scalar integer

Size of window used to average over time, in resource elements (REs), specified as a scalar integer.

InterpTypeOptional

'nearest', 'linear', 'natural', 'cubic', 'v4', 'none'

See footnote.

Type of 2-D interpolation used during interpolation. For details, see griddata. Supported choices are shown in the following table.

ValueDescription
'nearest'Nearest neighbor interpolation
'linear'Linear interpolation
'natural'Natural neighbor interpolation
'cubic'Cubic interpolation
'v4'MATLAB® 4 griddata method
'none'Disables interpolation

PilotAverageOptional

'UserDefined'(default), 'TestEVM'

See footnote.

Type of pilot averaging

The following parameter is required only if rxgrid contains more than one subframe. See footnote.

WindowOptional

'Left', 'Right', 'Centred', 'Centered'

If more than one subframe is input this parameter is required to indicate the position of the subframe from rxgrid and refgrid containing the desired channel estimate. Only channel estimates for this subframe will be returned. For the 'Centred' and 'Centered' settings, the window size must be odd.

  1. For cec.InterpType = 'none', no interpolation is performed between pilot symbols and no virtual pilots are created. hest will contain channel estimates in the locations of transmitted reference symbols for each received antenna and all other elements of hest are zero. The averaging of pilot symbols estimates described by cec.TimeWindow and cec.FreqWindow are still performed.

  2. The 'UserDefined' pilot averaging uses a rectangular kernel of size cec.FreqWindow-by-cec.TimeWindow and performs a 2-D filtering operation upon the pilots. Pilots near the edge of the resource grid are averaged less as they have no neighbors outside of the grid. For cec.FreqWindow = 12×X (i.e. any multiple of 12) and cec.TimeWindow = 1 the estimator enters a special case where an averaging window of (12×X)-in-frequency is used to average the pilot estimates; the averaging is always applied across (12×X) subcarriers, even at the upper and lower band edges; therefore the first (6×X) symbols at the upper and lower band edge have the same channel estimate. This operation ensures that averaging is always done on 12 (or a multiple of 12) symbols. This provides the appropriate despreading operation required for the case multi-antenna transmission where the DM-RS signals associated with each antenna occupy the same time/frequency locations but use different orthogonal cover codes to allow them to be differentiated at the receiver. The 'TestEVM' pilot averaging ignores other structure fields in cec, and follows the method described in TS 36.101, Annex F for the purposes of transmitter EVM testing.

  3. When rxgrid contains more than one subframe, cec.Window provides control of the location of the subframe for which channel estimation is performed. This allows channel estimation for the subframe of interest to be aided by the presence of pilot symbols occupying the same resource block in subframes before and/or after that subframe. For example, if rxgrid contains five subframes, 'Left' estimates the last first subframe in rxgrid, 'Centred'/'Centered' estimates the third (middle) subframe, and 'Right' estimates the last subframe. The parameter ue.NSubframe corresponds to the chosen subframe. So, with three subframes and cec.Window = 'Right', rxgrid corresponds to subframes (ue.NSubframe-2, ue.NSubframe-1, ue.NSubframe). The hest output will be the same size as rxgrid and will correspond to the same subframe numbers. All locations other than the estimated subframe will contain zeros.

Data Types: struct

Reference array of known transmitted data symbols in their correct locations, specified as an NSC-by-NSym-by-NT array of complex symbols. All other locations, such as DM-RS Symbols and unknown data symbol locations, must be represented by a NaN. The first two dimensions of rxgrid and refgrid must be the same.

  • NSC is the number of subcarriers.

  • NSym = NSF × NSymPerSF

    • NSF is the total number of subframes. If NSF is greater than one, the correct region is extracted from the returned hest array. The location of the estimated subframe within hest is specified using the parameter field cec.Window.

    • NSymPerSF is the number of SC-FDMA symbols per subframe.

      • For normal cyclic prefix, each subframe contains 14 SC-FDMA symbols.

      • For extended cyclic prefix, each subframe contains 12 SC-FDMA symbols.

  • NT is the number of transmit antennas, ue.NTxAnts

For cec.InterpType = 'None', values in refgrid are treated as reference symbols and the resulting hest contains non-zero values in their locations. A typical use for refgrid is to provide values of the SRS transmitted at some point during the time span of rxgrid. The SRS values can be used to enhance the channel estimation.

Data Types: double
Complex Number Support: Yes

Output Arguments

collapse all

Channel estimate between each transmit and receive antenna, returned as a NSC-by-NSym-by-NR. array of complex symbols. NSC is the total number of subcarriers, NSym is the number of SC-FDMA symbols, and NR is the number of receive antennas.

Noise estimate, returned as a numeric scalar. This output is the power spectral density of the noise present on the estimated channel response coefficients.

Algorithms

collapse all

The channel estimation algorithm functions as described in the following steps.

  1. Extract the PUCCH format 1 demodulation reference signals (DM-RS), or pilot symbols, for a transmit-receive antenna pair from the allocated physical resource blocks within the received subframe.

  2. Average the least-squares estimates to reduce any unwanted noise from the pilot symbols.

  3. Using the cleaned pilot symbol estimates, interpolate to obtain an estimate of the channel for the allocated subframe slot passed into the function.

References

[1] 3GPP TS 36.101. “Evolved Universal Terrestrial Radio Access (E-UTRA); User Equipment (UE) Radio Transmission and Reception.” 3rd Generation Partnership Project; Technical Specification Group Radio Access Network. URL: https://www.3gpp.org.

Version History

Introduced in R2013b