常规波束形成matlab程序阵元16

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

close all

clear all

clc

c=1500;

fs=10000;

T = 0.1;

t = 0:1/fs:T;

L=length(t);

f=500;

w=2*pi*f;

k=w/c;

M=16; %阵元个数

Nmid=1; %参考点

d=3;%阵元间距

m=[0:1:M-1];

yi=zeros(M,1);% 返回一个M*1维的零矩阵

zi=zeros(M,1);

xi=m*d;

xi=xi.';

%各阵元坐标

y1=20;

x1=10;z1=10;% 声源位置,y轴指向声源平面

Ric1=sqrt((x1-xi).^2+(y1-yi).^2+(z1-zi).^2);%声源至各阵元的距离M*1维

Rn1=Ric1-Ric1(Nmid);%声源至各阵元与参考阵元的声程差矢量M*1维

s1=cos(w*t);%参考阵元接收到的信号1*L维

snr =20;

Am= 10^(-snr/20);

n1=Am*(randn(M,L)+j*randn(M,L));%各阵元噪声矢量

p1=zeros(M,L);%M*L维

for k1=1:M

p1(k1,:)=Ric1(Nmid)/Ric1(k1)*s1.*exp(-j*w*Rn1(k1)/c); %各阵元经过幅度衰减和相位延迟后接收到的信号,M*L维

end

p=p1+n1;%各阵元接收的声压信号矩阵M*L

R=p*p'/L;%接收数据的自协方差矩阵M*M

% ----------------------------------------------------------

% 扫描范围

step_x=0.1;

step_z=0.1;

y=y1;

x=[0:step_x:20];

z=[0:step_z:20];

for k1=1:length(z) % 纵坐标

for k2=1:length(x)

Ri=sqrt((x(k2)-xi).^2+(y-yi).^2+(z(k1)-zi).^2); %该扫描点至各阵元的聚焦距离矢量

Rn=Ri-Ri(Nmid);%扫描点到各阵元与参考阵元的程差矢量M*1

b=exp(-j*w*Rn/c);%声压聚焦方向矢量M*1

Pcbf(k1,k2)=abs(b'*R*b);

end

end

% 归一化

for k1=1:length(z)

pp(k1)=max(Pcbf(k1,:));% Pcbf的第k1行的最大元素的值

end

Pcbf=Pcbf/max(pp);% Pcbf所有元素除以其最大值,归一化幅度

figure;

mesh(x,z,Pcbf);

xlabel('x(m)'),ylabel('z(m)')

title('常规聚焦波束形成单亮点声图')

figure;

pcolor(x,z,Pcbf);shading interp;

xlabel('x(m)'),ylabel('z(m)')

title('常规聚焦波束形成单亮点声图')

colorbar

[a,b] = find(Pcbf==max(max(Pcbf)));

xm1=b/length(x)*20, zm1=a/length(z)*20,

[a b]=find(Pcbf > 0.5*max(max(Pcbf)));

deta_x=(max(b)-min(b))/length(x)*20

deta_z=(max(a)-min(a))/length(z)*20

相关文档
最新文档