查看文档如下:
可以看出最多5个参数,分别是阵列对象,信号幅度,入射角度,信号频率,光速。
在下面的代码中,我们先创建一个3阵元的阵列,位置为:(-1,0,0),(0,0,0),(1,0,0)。然后创建入射信号,其方位角位180度,高度角为45度。
clear
close all
clc% 定义信号参数
fc = 1e9; % 频率 1 GHz
c = physconst('LightSpeed'); % 光速
lam = c/fc;
incidentAngle = [180; 45]; % 入射角度(方位角 180 度,高度角 45 度)
kw = 2*pi*fc/c;% 定义天线元素位置,分别位于 x 轴上的 -1, 0 和 1
ant = lam/2*[-1 0 1; 0 0 0; 0 0 0]; % 3 个天线元素的位置% 创建符合阵列对象
array = phased.ConformalArray('ElementPosition', ant);% 发射信号参数
signalAmplitude = 1; % 信号的幅度% 收集入射信号
sig = collectPlaneWave(array, signalAmplitude, incidentAngle, fc, c);% 显示结果
disp('收集到的信号:');
disp(sig);
sig2 = conj(sig);kw = 2*pi*fc/c;
phy = kw*lam/2/sqrt(2); % 利用几何直接计算(1,0,0)处比(0,0,0)超前的相位
phy2 = atan2(imag(sig(1,1)), real(sig(1,1))); % 根据收集到的信号计算(1,0,0)处比(0,0,0)超前的相位
运行之后结果为:
收集到的信号:-0.6057 + 0.7957i 1.0000 + 0.0000i -0.6057 - 0.7957i
同时我们也可以在工作区看到,对于两种计算相位的方式,其结果是一样的。