MVDR算法matlab程序

合集下载

mvdr算法matlab程序

mvdr算法matlab程序

MVDR(Minimum Variance Distortionless Response)算法是一种用于信号处理的自适应波束形成方法,能够在含有相关干扰的复杂环境中实现对目标信号的抑制和增强。

在无线通信、雷达、声呐等领域具有广泛的应用。

MVDR算法的核心思想是通过优化空间滤波器的权值,使得输出信号的方差最小,从而实现对指定方向上的信号增强,对其他方向上的干扰进行抑制。

其数学模型如下所示:1. 定义阵列接收信号为$x(t)$,阵列权向量为$w$,则输出信号$y(t)$可表示为$y(t) = w^Hx(t)$,其中$w^H$为权向量$w$的共轭转置。

2. 阵列接收信号$x(t)$可以表示为$x(t) = s(t) + n(t)$,其中$s(t)$为目标信号,$n(t)$为干扰噪声。

3. MVDR算法的优化目标是最小化输出信号的方差,即$w =\arg\min_w E\{|y(t)|^2\}$,其中$E\{\cdot\}$表示期望运算符。

为了实现MVDR算法,可以通过以下步骤进行:1. 阵列接收信号的空间协方差矩阵估计:根据接收到的信号数据,可以通过一定的方法估计得到阵列接收信号的空间协方差矩阵$R_x = E\{x(t)x^H(t)\}$,其中$E\{\cdot\}$表示期望运算符,$x^H(t)$表示$x(t)$的共轭转置。

2. 权向量的计算:根据空间协方差矩阵$R_x$,可以通过MVDR算法的推导得到优化的权向量$w = R_x^{-1}d$,其中$d$为期望增强的目标信号方向对应的空间谱。

下面以MATLAB程序实现MVDR算法为例,展示MVDR算法在阵列信号处理中的应用。

```matlabMVDR算法实现示例假设阵列接收信号的空间协方差矩阵为Rx,期望增强的目标信号方向对应的空间谱为d计算MVDR算法的权向量ww = inv(Rx) * d;对接收到的阵列信号进行空间滤波处理假设接收到的阵列信号为x,滤波后的输出信号为yy = w' * x;```通过以上MATLAB程序,可以实现对接收到的阵列信号进行MVDR 算法的空间滤波处理,从而实现对目标信号的增强和对干扰信号的抑制。

如何在Matlab中进行遥感数据处理

如何在Matlab中进行遥感数据处理

如何在Matlab中进行遥感数据处理遥感数据处理在当今科研和应用领域中扮演着重要的角色。

Matlab作为一种强大的数学计算软件,提供了丰富的工具和函数,使得遥感数据处理变得更加高效和便捷。

本文将探讨如何在Matlab中进行遥感数据处理。

一、引言遥感数据处理是从卫星、飞机等远距离获取的影像数据中提取地物信息的过程。

处理遥感数据的目标通常包括图像分类、特征提取、变化检测等。

Matlab作为一种强大的数学计算软件,提供了丰富的工具和函数,可以帮助我们在处理遥感数据时更加高效和灵活。

二、读取和显示遥感数据在Matlab中读取和显示遥感数据是遥感数据处理的第一步。

Matlab提供了多种方式读取不同格式的遥感数据,如ENVI格式、GeoTIFF格式等。

可以使用imread函数读取图像数据并使用imshow函数显示图像,也可以使用geotiffread函数读取GeoTIFF格式的遥感数据并使用mapshow函数显示。

三、遥感数据预处理遥感数据预处理是在进行后续分析前对图像进行的一系列操作,如去噪、辐射校正、几何校正、影像融合等。

Matlab提供了丰富的函数和工具箱来完成这些操作。

可以使用medfilt2函数进行图像的中值滤波去噪,使用imadjust函数进行图像的亮度和对比度调整。

对于辐射校正和几何校正,可以利用遥感数据处理工具箱中的radiometricCorrection和geometricCorrection函数。

四、遥感影像分类遥感影像分类是将遥感影像中的像素分为不同的类别,常用于土地利用、植被覆盖等应用。

在Matlab中,可以使用机器学习算法和图像处理技术进行遥感影像分类。

其中,常用的机器学习算法包括支持向量机(SVM)、随机森林(Random Forest)等。

Matlab提供了相应的函数和工具箱来实现这些算法,如fitcsvm函数和TreeBagger函数等。

五、遥感数据特征提取遥感数据特征提取是从遥感影像中提取具有代表性的特征,用于进一步分析和应用。

MATLAB实验指导书(共5篇)

MATLAB实验指导书(共5篇)

MATLAB实验指导书(共5篇)第一篇:MATLAB实验指导书MATLAB 实验指导书皖西学院信息工程学院实验一 MATLAB编程环境及简单命令的执行一、实验目的1.熟悉MATLAB编程环境二、实验环境1.计算机2.MATLAB7.0集成环境三、实验说明1.首先应熟悉MATLAB7.0运行环境,正确操作2.实验学时:2学时四、实验内容和步骤1.实验内容(1)命令窗口的使用。

(2)工作空间窗口的使用。

(3)工作目录、搜索路径的设置。

(4)命令历史记录窗口的使用。

(5)帮助系统的使用。

(6)了解各菜单的功能。

2.实验步骤(1)启动MATLAB,熟悉MATLAB的桌面。

(2)进入MATLAB7.0集成环境。

(3)在命令窗口执行命令完成以下运算,观察workspace的变化,记录运算结果。

1)(365-52⨯2-70)÷3 2)>>area=pi*2.5^2 3)已知x=3,y=4,在MATLAB中求z:x2y3 z=2(x-y)4)将下面的矩阵赋值给变量m1,在workspace中察看m1在内存中占用的字节数。

⎡162313⎤⎢511108⎥⎥m1=⎢⎢97612⎥⎢⎥414151⎣⎦执行以下命令>>m1(2 , 3)>>m1(11)>>m1(: , 3)>>m1(2 : 3 , 1 : 3)>>m1(1 ,4)+ m1(2 ,3)+ m1(3 ,2)+ m1(4 ,1)5)执行命令>>helpabs 查看函数abs的用法及用途,计算abs(3 + 4i)6)执行命令>>x=0:0.1:6*pi;>>y=5*sin(x);>>plot(x,y)7)运行MATLAB的演示程序,>>demo,以便对MATLAB有一个总体了解。

五、思考题1、以下变量名是否合法?为什么?(1)x2(2)3col(3)_row (4)for2、求以下变量的值,并在MATLAB中验证。

宽带波束形成matlab,关于均匀圆阵MVDR宽带波束形成的程序

宽带波束形成matlab,关于均匀圆阵MVDR宽带波束形成的程序

宽带波束形成matlab,关于均匀圆阵MVDR宽带波束形成的程序%⽤均匀圆阵MVDR⽅法进⾏宽带波束形成%% 基本参数f0 = 4*10^6; %信号中⼼频率bandwide = 0.5*10^6; %带宽0.05MHzinterval = 100; %每间隔interval(Hz)形成点频信号,合成宽带NarrowNumber = bandwide/interval; %所需点频个数NarrowF = linspace(f0-bandwide/2, f0+bandwide/2, NarrowNumber); %各点频的频率值R = 50; %阵元半径c = 3*10^8; %传播速度:光速bosu=340; % 波速degrad=pi/180;p=1;seta1=150*degrad; %信号到来⽅位⾓fai1=45*degrad; %信号到来仰⾓kk = 64; %进⾏MVDR所需采样数Nfft = 256; %进⾏FFT⼦带化点数,即进⾏Nfft点快速傅⽴叶变换Nlearn = kk * Nfft; %时域数据快拍数M=40; %均匀圆阵总数MElementFai=(0:(M-1))*9*degrad+4.5*degrad; %各阵元位置向量图MNumber = 10; %选出的阵元个数SelectElement=[ElementFai(1) ElementFai(5) ElementFai(9) ElementFai(13) ElementFai(17) ElementFai(21) ElementFai(25) ElementFai(29) ElementFai(33) ElementFai(37)];A=zeros(MNumber,p);k=[0:MNumber-1]';for t=1:pA(:,t)=exp(-j*2*pi*R*f0/bosu*(cos(seta1*degrad)*cos(2*pi*k/M)+cos(seta1*degrad)*sin(2*pi*k/M)));%圆阵的阵列流型ends=zeros(p,Nlearn);Am=[3,5]; %幅度phi=[20,30]; %初相for ii=1:ps(ii,:)=s(ii,:)+Am(ii)*cos(2*pi*f0*t+phi(ii)*degrad);%宽带信号endF=linspace(f0-bandwide/2, f0+bandwide/2, Nfft);snr=10;n=exp(j*2*pi*randn(MNumber,Nlearn))/snr;%噪声X=A*s + n; % 阵列输出%% 开始处理%对时域数据分段作FFT变换for mn=1:MNumberfor m=1:kkxxF(mn,m,:) = fft( X(mn,((m-1)*Nfft+1):((m-1)*Nfft+Nfft)), Nfft);endendtemp1=cos(seta1-SelectElement);F=linspace(f0-bandwide/2, f0+bandwide/2, Nfft);%求窄带信号的⾃适应最佳权for nfft=1:Nffth=zeros(MNumber);for k=1:kkh=h+xxF(:,k,nfft)*xxF(:,k,nfft)';endRxxf(:,:,nfft)=h./kk; %得到某窄频的⾃相关矩阵windows=ones(MNumber,1);a1=exp(-j*2*pi*R*F(nfft)/c*sin(fai1)*temp1);s=(a1.*windows.').';Wopt(:,nfft)=(inv(Rxxf(:,:,nfft))*s)/(s'*inv(Rxxf(:,:,nfft))*s); %MVDR算法的程序end%% 扫描⽮量NcurveAzi=180; %空间扫描⾓度采样数seta=linspace(0,2*pi,NcurveAzi); %阵元空间扫描指向⾓度for ne=1:Nfftfor na=1:NcurveAzitemp=cos(seta(na)-SelectElement);a=exp(-j*2*pi*R*F(ne)/c*sin(fai1)*temp);%扫描时⽅向⽮量f=(1+temp)/2; %扫描时的阵元⽅向图BF(na,ne)=abs(sum(a.*Wopt(:,nfft)'));end%%仿真结果plot(seta*180/pi,20*log10(BF(:,1)/max(BF(:,1))),'b') gridxlabel('\phi⽅位⾓(度)')ylabel('波束输出/分贝')title('均匀圆阵MVDR算法宽带波束形成图')endhold off。

热传导方程有限差分法的MATLAB实现

热传导方程有限差分法的MATLAB实现

万方数据万方数据万方数据万方数据热传导方程有限差分法的MATLAB实现作者:史策作者单位:西安建筑科技大学,理学院,陕西,西安,710055刊名:咸阳师范学院学报英文刊名:JOURNAL OF XIANYANG NORMAL UNIVERSITY年,卷(期):2009,24(4)被引用次数:0次1.曹钢,王桂珍,任晓荣.一维热传导方程的基本解[J].山东轻工业学院学报,2005,19(4):76-80.2.万正苏,方春华,张再云.关于热传导方程有限差分区域分解并行算法精度的注记[J].湖南理工学院学报(自然科学版),2007,20(3):12-14.3.StephenJ.Chapman.MATLAB编程[M].邢树军,郑碧波,译.北京:科学出版社,2008.4.田兵.用MATLAB解偏微分方程[J].阴山学刊,2006,20(4):12-13.5.王飞,裴永祥.有限差分方法的MATLAB编程[J].新疆师范大学学报(自然科学版),2003,22(4):21-27.6.王宝红.热传导方程的可视化探讨[J].忻州师范学院学报,2008,24(2):31-36.7.李先枝.热传导方程差分解法的最佳网格[J].河南大学学报(自然科学版),2004,34(3):16-18.8.赵德奎,刘勇.MATLAB在有限差分数值计算中的应用[J].四川理工学院学报,2005,18(4):61-64.9.谢焕田,吴艳.拉普拉斯有限差分法的MATLAB实现[J].四川理工学院学报,2008,21(3):1-2.10.南京大学数学系计算数学专业.偏微分方程数值解法[M].北京:科学出版社,1979.1.学位论文申卫东热传导方程有限差分区域分解算法研究2003区域分解算法是在并行机上求解偏微分方程数值解的一种较自然的方法.该方法先将偏微分方程求解区域划分为若干个子区域,然后在各个子区域并行求解.全文共五章.第一章为引言,简要介绍了热传导方程并行算法的概况及该文所讨论的基本内容.在第二章,我们在内边界点为等距分划的多子区域条件下,得到Dawson等人关于求解热传导方程区域分解算法差分解的误差估计.在第三章,我们以Saul'yev非对称格式作内边界处理,发展了新的区域分解算法,得到了差分解的先验误差估计,并与Dawson等人的算法作了比较.给出了关于算法计算精度的数值结果.在第四章,我们发展了一些新技术,在子区域的边界处采用小时间步长古典显式格式求解,构造了新的区域分解算法,得到了差分解的先验误差估计.给出了关于算法计算精度的数值结果.在第五章,我们在二维热传导方程求解上扩充了Dawson等人的区域分解算法.给出了关于算法计算精度的数值结果.第六章为该研究工作的主要结论.2.期刊论文张守慧.王文洽.ZHANG Shou-hui.WANG Wen-qia热传导方程有限差分逼近的数学Stencil及其新型迭代格式-山东大学学报(理学版)2006,41(6)将Stencil应用于偏微分方程有限元差分逼近过程,以两类差分格式为基础建立了求解热传导方程的两种新型迭代算法.此两种算法与经典的Jacobi方法同样具有并行的性质,但比Jacobi方法收敛快.给出的算例说明方法的适用性.3.期刊论文吕桂霞.马富明.Lü Guixia.Ma Fuming二维热传导方程有限差分区域分解算法-数值计算与计算机应用2006,27(2)本文讨论了一类数值求解二维热传导方程的并行差分格式.在这个算法中,通过引进内界点将求解区域分裂成若干子区域.在子区域间内界点上采用非对称格式计算,一旦这些点的值被计算出来,各子区域间的计算可完全并行.本文得到了稳定性条件和最大模误差估计.它表明我们的格式有令人满意的稳定性,并且有着较高的收敛阶.4.学位论文田源地下煤火三维数理模型正演数值模拟2006本文首先给出了几个地下煤火随空间、温度变化的动态和稳态热数学物理模型及其简化模型。

matlab移动曲面拟合地面滤波代码

matlab移动曲面拟合地面滤波代码

这篇文章将详细介绍如何使用MATLAB进行移动曲面拟合地面滤波,内容包括算法原理、代码实现以及应用案例。

读者将通过本文了解到MATLAB中移动曲面拟合地面滤波的实现方法,以及如何在实际工程中应用这一技术。

文章将按照以下内容结构展开:一、算法原理移动曲面拟合地面滤波是一种用于三维点云数据处理的常见技术,它可以有效的去除地面点,保留其他物体的点。

该算法的原理主要包括以下几个步骤:1. 选取窗口:首先在点云数据中选择一个移动窗口,窗口大小可以根据实际情况进行调整。

2. 数据拟合:对于每个窗口中的点,利用曲面拟合算法对窗口内的点进行拟合,得到地面曲面模型。

3. 滤波处理:根据拟合模型对窗口内的点进行滤波,将地面点去除,保留其他物体点。

二、代码实现在MATLAB中实现移动曲面拟合地面滤波的代码主要包括以下几个步骤:1. 数据加载:首先需要加载三维点云数据,可以通过MATLAB提供的函数进行加载。

2. 窗口选取:选择合适大小的窗口对点云数据进行处理,可以使用MATLAB中的矩阵操作实现窗口移动。

3. 曲面拟合:利用MATLAB中的拟合函数对窗口内的点进行曲面拟合,得到地面曲面模型。

4. 滤波处理:根据拟合模型对窗口内的点进行滤波处理,去除地面点。

三、应用案例移动曲面拟合地面滤波在地图制作、无人车导航等领域有着广泛的应用。

以地图制作为例,我们可以利用移动曲面拟合地面滤波技术去除地面点,保留建筑物等其他物体点,从而更准确地绘制地图。

在无人车导航中,利用该技术可以去除地面噪声点,提高地面识别的准确性。

通过以上内容的详细介绍,读者可以全面了解MATLAB中移动曲面拟合地面滤波的实现方法、代码实现和应用案例。

希望本文能对读者对此需求有所帮助。

四、代码示例下面我们将通过一个具体的代码示例,来演示如何在MATLAB中实现移动曲面拟合地面滤波的代码。

在示例中,我们将利用MATLAB提供的函数和工具,按照算法原理中的步骤,完成移动曲面拟合地面滤波的代码实现。

mVDR波束形成matlab程序

mVDR波束形成matlab程序

close allclear allclcc=1500;fs=10e3;T = 1;t = 0:1/fs:T;L=length(t);f=2000;w=2*pi*f;k=w/c;M=11; %阵元个数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=12;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:Mp1(k1,:)=Ric1(Nmid)/Ric1(k1)*s1.*exp(-j*w*Rn1(k1)/c); %各阵元经过幅度衰减和相位延迟后接收到的信号,M*L维endp=p1+n1;%各阵元接收的声压信号矩阵M*LR=p*p'/L;%接收数据的自协方差矩阵M*MRP=inv(R);%求R的逆矩阵% ----------------------------------------------------------% 扫描范围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*1b=exp(-j*w*Rn/c);%声压聚焦方向矢量M*1Pmvdr(k1,k2)=1/abs(b'*RP*b);endend% 归一化for k1=1:length(z)pp1(k1)=max(Pmvdr(k1,:));% Pmvdr的第k1行的最大元素的值endPmvdr=Pmvdr/max(pp1);% Pmvdr所有元素除以其最大值,归一化幅度figure;mesh(x,z,Pmvdr);xlabel('x(m)'),ylabel('z(m)')title('mvdr单亮点声图')figure;pcolor(x,z,Pmvdr);shading interp;xlabel('x(m)'),ylabel('z(m)')title('mvdr单亮点声图')colorbar[a,b] = find(Pmvdr==max(max(Pmvdr))); xm1=b/length(x)*20, zm1=a/length(z)*20, [a b]=find(Pmvdr > 0.5*max(max(Pmvdr))); deta_x=(max(b)-min(b))/length(x)*20 deta_z=(max(a)-min(a))/length(z)*20。

MATLAB命令汇总

MATLAB命令汇总

MATLAB命令汇总1.基本运算:-`+`:加法运算-`-`:减法运算-`*`:乘法运算-`/`:除法运算-`^`或`**`:幂运算- `sqrt(`: 平方根函数- `exp(`: 指数函数- `log(`: 对数函数2.矩阵和向量:- `zeros(`: 创建全零矩阵- `ones(`: 创建全一矩阵- `eye(`: 创建单位矩阵- `rand(`: 创建随机矩阵- `diag(`: 提取矩阵的对角线元素- `transpose(`或`'`: 转置矩阵- `det(`: 求矩阵的行列式- `inv(`: 求矩阵的逆矩阵- `trace(`: 求矩阵的迹3.数据处理和统计函数:- `mean(`: 求平均值- `median(`: 求中位数- `std(`: 求标准差- `var(`: 求方差- `sort(`: 排序- `histogram(`: 绘制直方图- `corrcoef(`: 计算相关系数矩阵- `cov(`: 计算协方差矩阵- `unique(`: 去掉重复元素4.数据可视化:- `plot(`: 绘制二维折线图- `scatter(`: 绘制散点图- `bar(`: 绘制柱状图- `hist(`: 绘制直方图- `pie(`: 绘制饼图- `imagesc(`: 绘制热图- `contour(`: 绘制等高线图- `surf(`: 绘制三维曲面图5.逻辑和条件语句:- `if`: 条件判断语句- `else`: 条件判断的可选分支- `elseif`: 多个条件判断的中间分支- `while`: 循环语句- `for`: 循环语句- `break`: 跳出循环- `continue`: 跳过本次循环6.文件和数据输入输出:- `load(`: 从文件加载数据- `save(`: 将数据保存到文件- `fopen(`: 打开文件- `fclose(`: 关闭文件- `fprintf(`: 格式化输出到文件- `fscanf(`: 从文件按格式读取数据7.函数和脚本文件:- `function`: 定义函数- `script`: 脚本文件- `input(`: 从命令行输入数据- `disp(`: 显示结果或变量值- `return`: 返回函数结果- `clear(`: 清除变量或内存- `clc(`: 清除命令窗口内容以上是一些常用的MATLAB命令和函数的汇总,这只是冰山一角,MATLAB还提供了许多其他功能和扩展性更强的函数和工具箱,可以根据不同的需求进行更详细的学习和使用。

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

clc
clear all
close all
%% 常量定义
Freqs=1.6e9; %工作频率
c=3e8; %光速
lamda=c/Freqs; %波长
d=0.5*lamda; %单元间距
M=16; %天线阵元数
fs=2e6; %采样频率
pd=10; %快拍数
%% 模型建立
%--------------第一个干扰模型--------------------
thetaJ1=20*pi/180; %干扰方向
FreqJ1=5e5; %第一个干扰的频率
J1NR=sqrt(10^(60/10));
J1one=J1NR*exp(j*(2*pi*FreqJ1*(1:1:pd)/fs)); %1*pd %--------------第二个干扰模型--------------------
ThetaJ2=60*pi/180; %干扰方向
FreqJ2=6e5; %第二个干扰的频率
J2NR=sqrt(10^(60/10));
J2one=J2NR*exp(j*(2*pi*FreqJ2*(1:1:pd)/fs)); %1*pd %--------------信号模型--------------------
ThetaS=30*pi/180;
FreqS=7e5;
SNR=sqrt(10^(40/10));
Sone=SNR*exp(j*(2*pi*FreqS*(1:1:pd)/fs)); %1*pd
%--------------空域处理-------------------------
I1=zeros(M,1);
I2=zeros(M,1);
IS=zeros(M,1);
for n=1:M
I1(n)=exp(j*2*pi*(n-1)*d*sin(thetaJ1)/lamda); I2(n)=exp(j*2*pi*(n-1)*d*sin(ThetaJ2)/lamda); IS(n)=exp(j*2*pi*(n-1)*d*sin(ThetaS)/lamda);
end
J1=I1*J1one;
J1=J1.';
J2=I2*J2one;
J2=J2.';
%------------产生噪声-------------------------
noise=sqrt(1/2)*randn(pd,M)+j*sqrt(1/2)*randn(pd,M);
%------------产生接收信号-------------------------
XX=J1+noise+J2;
%% MVDR算法
Rxx=zeros(M,M);
Rxx=(XX.'*(XX.')')/pd;%M*M维
detaS=IS;
Wmvdr=inv(Rxx)*detaS*inv(detaS'*inv(Rxx)*detaS); %MVDR 算法
%% 直线阵布阵
p=-pi/2:pi/180:pi/2;
for jj=1:1:length(p) %空间角度扫描
w_scan=zeros(M,1);
scan=p(jj);
for n=1:1:M
w_scan(n)=exp(j*2*pi*(n-1)*d*sin(scan)/lamda);
end%空间导向矢量
1*M
Fmvdr(jj)=abs(Wmvdr'*w_scan);
end
%% 画出方向图
Fmax=max(max(Fmvdr));
Fa=Fmvdr./Fmax;
Fa=20*log10(Fa);
figure(1);
plot(180*p/pi,Fa,'b-')
(注:文档可能无法思考全面,请浏览后下载,供参考。

可复制、编制,期待你的好评与关注)。

相关文档
最新文档