Практическая оценка канала
[
выполняет практическую оценку канала на полученной сетке ресурса h
,nVar
,info
] = nrChannelEstimate(rxGrid
,refInd
,refSym
)rxGrid
при помощи ссылочной сетки ресурса, содержащей ссылочные символы refSym
в местоположениях refInd
. Функция возвращает оценку канала h
, шумовая оценка отклонения nVar
, и дополнительная информация info
.
[
задает опции при помощи одного или нескольких аргументов пары "имя-значение" в дополнение к входным параметрам в любом из предыдущих синтаксисов.h
,nVar
,info
] = nrChannelEstimate(___,Name,Value
)
Сгенерируйте физический канал телевизионного вещания (PBCH) сигнал ссылки демодуляции (DM-RS) символы для личного номера ячейки физического уровня 42. Часть иждивенца времени инициализации скремблирования DM-RS 0.
ncellid = 42; ibar_SSB = 0; dmrsSym = nrPBCHDMRS(ncellid,ibar_SSB);
Получите индексы элемента ресурса для PBCH DM-RS.
dmrsInd = nrPBCHDMRSIndices(ncellid);
Создайте сетку ресурса, содержащую сгенерированные символы DM-RS.
nTxAnts = 1; txGrid = complex(zeros([240 14 nTxAnts])); txGrid(dmrsInd) = dmrsSym;
Модулируйте сетку ресурса с помощью заданной длины БПФ и циклической длины префикса.
nFFT = 512; cpLengths = ones(1,14) * 36; cpLengths([1 8]) = 40; nulls = [1:136 377:512].'; txWaveform = ofdmmod(txGrid,nFFT,cpLengths,nulls);
Создайте модель канала TDL-C с заданными свойствами.
SR = 7.68e6;
channel = nrTDLChannel;
channel.NumReceiveAntennas = 1;
channel.SampleRate = SR;
channel.DelayProfile = 'TDL-C';
channel.DelaySpread = 100e-9;
channel.MaximumDopplerShift = 20;
Получите максимальное количество задержанных выборок от пути к каналу при помощи самой большой задержки и задержки реализации фильтра канала.
chInfo = info(channel); maxChDelay = ceil(max(chInfo.PathDelays*SR)) + chInfo.ChannelFilterDelay;
Чтобы сбросить задержанные выборки от канала, добавьте нули в конце переданной формы волны, соответствующей максимальному количеству задержанных выборок и количеству антенн передачи. Передайте заполненную форму волны через модель канала TDL-C.
[rxWaveform,pathGains] = channel([txWaveform; zeros(maxChDelay,nTxAnts)]);
Оцените смещение синхронизации для передачи с помощью символов DM-RS в качестве ссылочных символов. Модуляция OFDM ссылочных символов охватывает 20 блоков ресурса при интервале поднесущей на 15 кГц и использует начальный номер слота 0.
nrb = 20; scs = 15; initialSlot = 0; offset = nrTimingEstimate(rxWaveform,nrb,scs,initialSlot,dmrsInd,dmrsSym);
Синхронизируйте полученную форму волны согласно предполагаемому смещению синхронизации.
rxWaveform = rxWaveform(1+offset:end,:);
Создайте полученную сетку ресурса, содержащую демодулируемый, и синхронизировал полученную форму волны.
rxLength = sum(cpLengths) + nFFT*numel(cpLengths); cpFraction = 0.55; symOffsets = fix(cpLengths * cpFraction); rxGrid = ofdmdemod(rxWaveform(1:rxLength,:),nFFT,cpLengths,symOffsets,nulls);
Получите практическую оценку канала.
H = nrChannelEstimate(rxGrid,dmrsInd,dmrsSym);
Получите совершенную оценку канала.
pathFilters = getPathFilters(channel); H_ideal = nrPerfectChannelEstimate(pathGains,pathFilters,nrb,scs,initialSlot,offset);
Сравните практические и совершенные оценки канала.
figure; subplot(1,2,1); imagesc(abs(H)); xlabel('OFDM Symbol'); ylabel('Subcarrier'); title('Practical Estimate Magnitude'); subplot(1,2,2); imagesc(abs(H_ideal)); xlabel('OFDM Symbol'); ylabel('Subcarrier'); title('Perfect Estimate Magnitude');
rxGrid
— Полученная сетка ресурсаПолученная сетка ресурса, заданная как K-by-L-by-R комплексный массив.
K является количеством поднесущих, равных NRB × 12, где NRB является количеством блоков ресурса в диапазоне от 1 до 275.
L является количеством символов OFDM в пазе или в координатной сетке.
Когда вы вызываете nrChannelEstimate
со ссылочными символами refSym
, L 12 для расширенного циклического префикса и 14 для нормального циклического префикса. Установите циклическую длину префикса при помощи '
аргумент пары "имя-значение".CyclicPrefix
'
Когда вы вызываете nrChannelEstimate
со ссылочной сеткой ресурса refGrid
, L должен равняться N, количеству символов OFDM в координатной сетке.
R является количеством, получают антенны.
Типы данных: single
| double
Поддержка комплексного числа: Да
refInd
— Ссылочные индексы символаСсылочные индексы символа, заданные как целочисленная матрица. Количество строк равняется количеству элементов ресурса. Можно задать все индексы в отдельном столбце или распространить их через несколько столбцов. Число элементов в refInd
и refSym
должно быть то же самое, но их размерность может отличаться. Функция изменяет refInd
и refSym
в вектор-столбцы прежде, чем сопоставить их в координатную сетку: refGrid(refInd(:)) = refSym(:)
.
Элементы refInd
линейные индексы на основе один, обращаясь к K-by-L-by-P массив ресурса.
K является количеством поднесущих, равных NRB × 12, где NRB является количеством блоков ресурса в диапазоне от 1 до 275. K должен быть равен первой размерности rxGrid
.
L является количеством символов OFDM в пазе. L 12 для расширенного циклического префикса и 14 для нормального циклического префикса. Установите циклическую длину префикса при помощи '
аргумент пары "имя-значение".CyclicPrefix
'
P является количеством ссылочных портов сигнала, выведенных из области значений значений в refInd
.
Типы данных: double
refSym
— Ссылочные символыСсылочные символы, заданные как комплексная матрица. Количество строк равняется количеству элементов ресурса. Можно задать все символы в отдельном столбце или распределить их на нескольких столбцах. Число элементов в refInd
и refSym
должно быть то же самое, но их размерность может отличаться. Функция изменяет refInd
и refSym
в вектор-столбцы прежде, чем сопоставить их в координатную сетку: refGrid(refInd(:)) = refSym(:)
.
Типы данных: single
| double
Поддержка комплексного числа: Да
refGrid
— Предопределенная координатная сеткаПредопределенная координатная сетка, заданная как K-by-N-by-P комплексный массив. refGrid
может охватить несколько пазов.
K является количеством поднесущих, равных NRB × 12, где NRB является количеством блоков ресурса в диапазоне от 1 до 275.
N является количеством символов OFDM в координатной сетке.
P является количеством ссылочных портов сигнала.
Типы данных: single
| double
Поддержка комплексного числа: Да
Задайте дополнительные разделенные запятой пары Name,Value
аргументы. Name
имя аргумента и Value
соответствующее значение. Name
должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN
.
'CyclicPrefix','extended'
задает расширенную циклическую длину префикса.'CyclicPrefix'
— Циклическая длина префикса'normal'
(значение по умолчанию) | 'extended'
Циклическая длина префикса, заданная как разделенная запятой пара, состоящая из 'CyclicPrefix'
и одно из этих значений:
'normal'
— Используйте это значение, чтобы задать нормальный циклический префикс. Эта опция соответствует 14 символам OFDM в пазе.
'extended'
— Используйте это значение, чтобы задать расширенный циклический префикс. Эта опция соответствует 12 символам OFDM в пазе. Для нумерологии, заданной в Разделе TS 38.211 4.2, расширенная циклическая длина префикса только применяется к интервалу поднесущей на 60 кГц.
Типы данных: char |
string
'CDMLengths'
— Расположение CDM относительно ссылочных сигналовРасположение мультиплексирования области кода (CDM) относительно ссылочных сигналов, заданных как разделенная запятой пара, состоящая из 'CDMLengths'
и 1 2 массив неотрицательных целых чисел [FD
TD]. Элементы массива FD и TD задают длину CDM despreading в частотном диапазоне (FD-CDM) и временном интервале (TD-CDM), соответственно. Значение 1 для элемента не задает CDM.
Пример: 'CDMLengths',[2 1]
задает FD-CDM2 и никакой TD-CDM.
Пример: 'CDMLengths',[1 1]
не задает ортогонального despreading.
Типы данных: double
'AveragingWindow'
— Окно усреднения перед интерполяцией
(значение по умолчанию) | 1 2 массив неотрицательных нечетных целых чиселОкно усреднения перед интерполяцией, заданное как разделенная запятой пара, состоящая из 'AveragingWindow'
и 1 2 массив неотрицательных нечетных целых чисел [F
T]. F элементов массива и T задают количество смежных ссылочных символов в частотном диапазоне и временном интервале, соответственно, по которому функция выполняет усреднение перед интерполяцией. Если F или T являются нулем, функция решает, что значение усреднения от предполагаемого отношения сигнал-шум (SNR) на основе шумового отклонения оценивает nVar
.
Типы данных: double
h
— Практическая оценка каналаПрактическая оценка канала, возвращенная как K-by-L-by-R-by-P комплексный массив. K-by-L-by-R является формой полученной сетки ресурса rxGrid
. P является количеством ссылочных портов сигнала.
h
наследовал его тип данных от rxGrid
.
Типы данных: double |
single
nVar
— Шумовая оценка отклоненияШумовая оценка отклонения, возвращенная как неотрицательный скаляр. nVar
измеренное отклонение аддитивного белого Гауссова шума на полученных ссылочных символах.
Типы данных: double
info
— Дополнительная информацияДополнительная информация, возвращенная как структура с полем AveragingWindow
.
Поле параметра | Значение | Описание |
---|---|---|
AveragingWindow | 1 2 массив | Окно усреднения перед интерполяцией, возвращенное как 1 2 массив [F T]. F элементов массива и T указывают на количество смежных ссылочных символов в частотном диапазоне и временном интервале, соответственно, по которому функция выполнила усреднение перед интерполяцией. |
У вас есть модифицированная версия этого примера. Вы хотите открыть этот пример со своими редактированиями?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.