шаг

Системный объект: поэтапный. ReplicatedSubarray
Пакет: поэтапный

Выведите ответы подмассивов

Синтаксис

RESP = step(H,FREQ,ANG,V)
RESP = step(H,FREQ,ANG,V,STEERANGLE)
RESP = step(H,FREQ,ANG,V,WS)

Описание

Примечание

При запуске в R2016b, вместо того, чтобы использовать метод step, чтобы выполнить операцию, заданную Системой object™, можно вызвать объект с аргументами, как будто это была функция. Например, y = step(obj,x) и y = obj(x) выполняют эквивалентные операции.

пример

RESP = step(H,FREQ,ANG,V) возвращает ответы, RESP, подмассивов в массиве, на рабочих частотах, заданных в FREQ и направлениях, заданных в ANG. V является скоростью распространения. Элементы в каждом подмассиве соединяются с центром фазы подмассива использование канала равного пути.

RESP = step(H,FREQ,ANG,V,STEERANGLE) использование STEERANGLE как руководящее направление подмассива. Этот синтаксис доступен, когда вы устанавливаете свойство SubarraySteering или на 'Phase' или на 'Time'.

пример

RESP = step(H,FREQ,ANG,V,WS) использование WS как веса элемента подмассива. Этот синтаксис доступен, когда вы устанавливаете свойство SubarraySteering на 'Custom'.

Примечание

Объект выполняет инициализацию в первый раз, когда объект выполняется. Эта инициализация блокирует ненастраиваемые свойства (MATLAB) и входные спецификации, такие как размерности, сложность и тип данных входных данных. Если вы изменяете ненастраиваемое свойство или входную спецификацию, Системный объект выдает ошибку. Чтобы изменить ненастраиваемые свойства или входные параметры, необходимо сначала вызвать метод release, чтобы разблокировать объект.

Входные параметры

H

Поэтапный массив сформирован реплицированными подмассивами.

FREQ

Рабочие частоты массива в герц. FREQ является вектором - строкой из длины L. Типичные значения в области значений, заданной свойством H.Subarray.Element. То свойство называют FrequencyRange или FrequencyVector, в зависимости от типа элемента в массиве. Элемент имеет нулевой ответ на частотах вне той области значений.

ANG

Направления в градусах. ANG может быть или 2 M матрицей или вектором - строкой из длины M.

Если ANG является 2 M матрицей, каждый столбец матрицы задает направление в форме [азимут; повышение]. Угол азимута должен быть между –180 и 180 градусами, включительно. Угол повышения должен быть между –90 и 90 градусами, включительно.

Если ANG является вектором - строкой из длины M, каждый элемент задает угол азимута направления. В этом случае соответствующий угол повышения принят, чтобы быть 0.

V

Скорость распространения в метрах в секунду. Это значение должно быть скаляром.

STEERANGLE

Руководящее направление подмассива. STEERANGLE может быть или вектор-столбцом с 2 элементами или скаляром.

Если этот аргумент является вектор-столбцом с 2 элементами, он имеет форму [азимут; повышение]. Угол азимута должен быть между-180 ° и 180 °, включительно. Угол повышения должен быть между-90 ° и 90 °, включительно.

Если STEERANGLE является скаляром, он задает угол азимута направления. В этом случае угол повышения принят, чтобы быть 0 °.

Зависимости

Чтобы включить этот аргумент, установите SubarraySteering на 'Phase' или 'Time'.

WS

Веса элемента подмассива

Веса элемента подмассива, заданные как NSE с комплексным знаком-by-N матрица. Веса применяются к отдельным элементам в подмассиве. Все подмассивы имеют те же размерности и размеры. NSE является числом элементов в каждом подмассиве, и N является количеством подмассивов. Каждый столбец матрицы задает веса для соответствующего подмассива.

Зависимости

Чтобы включить этот аргумент, установите SubarraySteering на 'Custom'.

Выходные аргументы

RESP

Ответы напряжения подмассивов поэтапного массива. Вывод зависит от ли поляризация поддержки массивов или нет.

  • Если массив не способен к поддержке поляризации, ответ напряжения, RESP, имеет размерности N-by-M-by-L. Первая размерность, N, представляет количество подмассивов в поэтапном массиве, второе измерение, M, представляет количество углов, заданных в ANG, в то время как L представляет количество частот, заданных в FREQ. Каждый столбец RESP содержит ответы подмассивов для соответствующего направления, заданного в ANG. Каждая из страниц L RESP содержит ответы подмассивов для соответствующей частоты, заданной в FREQ.

  • Если массив способен к поддержке поляризации, ответом напряжения, RESP, является MATLAB® struct, содержащий два поля, RESP.H и RESP.V, каждый имеющий размерности N-by-M-by-L. Поле, RESP.H, представляет горизонтальный ответ поляризации массива, в то время как RESP.V представляет вертикальный ответ поляризации массива. Первая размерность, N, представляет количество подмассивов в поэтапном массиве, второе измерение, M, представляет количество углов, заданных в ANG, в то время как L представляет количество частот, заданных в FREQ. Каждый из столбцов M содержит ответы подмассивов для соответствующего направления, заданного в ANG. Каждая из страниц L содержит ответы подмассивов для соответствующей частоты, заданной в FREQ.

Примеры

развернуть все

Вычислите ответ в опорном направлении для двух массивов ULA с 2 элементами, которые формируют подмассивы массива ULA с 4 элементами элементов антенны короткого диполя.

Примечание: Этот пример запускается только в R2016b или позже. Если вы используете более ранний релиз, заменяете каждый вызов функции с эквивалентным синтаксисом step. Например, замените myObject(x) на step(myObject,x).

Создайте двухэлементный ULA элементов антенны короткого диполя. Затем расположите две копии, чтобы сформировать ULA с 4 элементами.

antenna = phased.ShortDipoleAntennaElement;
array = phased.ULA('Element',antenna,'NumElements',2,'ElementSpacing',0.5);
replicatedarray = phased.ReplicatedSubarray('Subarray',array,...
    'Layout','Rectangular','GridSize',[1 2],...
    'GridSpacing','Auto');

Найдите ответ каждого подмассива в опорном направлении. Примите, что рабочая частота составляет 1 ГГц, и скорость распространения волны является скоростью света.

c = physconst('LightSpeed');
resp = replicatedarray(1.0e9,[0;0],c)
resp = struct with fields:
    H: [2x1 double]
    V: [2x1 double]

Создайте массив, состоящий из трех копий ULA с 4 элементами разрядка элементов 1/2 длина волны независимо. Массив действует на уровне 300 МГц.

c = physconst('LightSpeed'); 
fc = 300e6;
lambda = c/fc;
subarray = phased.ULA(4,0.5*lambda);

Регулируйте все подмассивы общим сдвигом фазы на 10 азимутов степеней.

array = phased.ReplicatedSubarray('Subarray',subarray,'GridSize',[1 3], ... 
    'SubarraySteering','Phase','PhaseShifterFrequency',fc); 
steer_ang = [10;0]; 
sv_array = phased.SteeringVector('SensorArray',array,... 
    'PropagationSpeed',c); 
wts_array = sv_array(fc,steer_ang);
pattern(array,fc,-90:90,0,'CoordinateSystem','Rectangular',... 
    'Type','powerdb','PropagationSpeed',c,'Weights',wts_array,... 
    'SteerAngle',steer_ang);
legend('phase-shifted subarrays')

Вычислите независимые веса подмассива из руководящих векторов подмассива. Веса указывают на 5, 15, и 30 азимутов степеней. Установите свойство SubarraySteering на 'Custom'.

steer_ang_subarrays = [5 15 30;0 0 0];
sv_subarray = phased.SteeringVector('SensorArray',subarray,... 
    'PropagationSpeed',c);
wc = sv_subarray(fc,steer_ang_subarrays); 
array.SubarraySteering = 'Custom';
pattern(array,fc,-90:90,0,'CoordinateSystem','Rectangular',... 
    'Type','powerdb','PropagationSpeed',c,'Weights',wts_array,... 
    'ElementWeight',conj(wc)); 
legend('independent subarrays') 
hold off

Смотрите также

|