数字信号处理上机实验一 离散时间信号的时域分析

实验1 离散时间信号的时域分析
一、实验目的
(1)了解MATLAB语言的主要特点及作用;
(2)熟悉MATLAB主界面,初步掌握MATLAB命令窗和编辑窗的操作方法;
(3)了解常用时域离散信号及其特点;
(4)掌握MATLAB产生常用时域离散信号的方法;
(5)掌握MATLAB中时域离散信号的基本运算方法;
(6)学习简单的数组赋值、数组运算、绘图的程序编写。
二、知识点提示
本章节的主要知识点是利用MATLAB产生数字信号处理的几种常用典型序列及数字序列的基本运算;重点是单位脉冲、单位阶跃、正(余)弦信号的产生;难点是MATLAB关系运算符“==、>=”的使用。
三、实验原理
1.时域离散信号的概念
在MATLAB中,时域的离散信号可以通过编写程序直接生成,也可以通过对连续信号等间隔抽样获得。离散序列的时域运算主要为信号的相加和相乘,信号的时域变换包括移位、反转及尺度变换。
2.用MATLAB生成离散信号需注意的问题
(1)有关数组与下标
MATLAB中处理的数组,其下标默认从1开始递增,例如x=[9 8 7],表示x(1)=9;x(2)=8;x(3)=7。要表示一个下标不从1开始的数组,一般需要采用两个矢量,如:
n=[-3:1:2],x=[9 8 7 6 5 4],则有x(-3)=9;x(-2)=8;x(2)=4。
(2)信号的图形绘制
从本质上来讲,MATLAB及其任何计算机语言处理的信号都是离散信号。当我们把信号的样点值取的足够密,作图时采用特殊的命令,就可以把信号近似看成连续信号。
在MATLAB中,离散信号与连续信号有时在程序编写上是一致的,只是在作图时选择不同的绘图函数而已。
连续信号作图用plot函数,绘制线形图;离散信号作图使用stem函数,绘制脉冲图。
3.常用时域离散信号
常用时域离散信号有单位脉冲序列、单位阶跃序列、实指数序列、复指数序列、正弦序列、矩形序列以及随机序列等。
下面以单位脉冲序列的产生为例做详细说明。其他函数类似。
单位脉冲序列

(1)用MATLAB的关系运算式来产生单位脉冲序列 。
在这里插入图片描述

n1=-5; n2=5; n0=0;  %显示范围从n1到n2
n=n1:n2;  %横坐标
x=[n==n0]; %生成离散信号x(n)//n=0 返回值为1
stem(n,x,’filled’); %绘制图形,且圆点处用实心圆表示//field 小圆点

在这里插入图片描述
(2)用zeros函数和抽样点直接赋值产生单位脉冲序列 。

n1=-5; n2=5; n0=0;  %显示范围从n1到n2
n=n1:n2;  %横坐标
nt=length(n); %序列的长度
x=zeros(1,nt); %先产生全零的序列,对应-5到5
x(n0-n1+1)=1; %将n=0处的序列值赋值为1,n=0就是第(n0-n1+1)个值
stem(n,x,’filled’); %绘制图形,且圆点处用实心圆表示

(3)如果用函数来实现,需要在.m文件里面完成,函数名为impseq(n0,n1,n2)//三个入口参数

function x=impseq(n0,n1,n2);//fun 函数引导词
n=n1:n2;
x=[n==n0];
stem(n,x,'filled');

(4)单位阶跃序列可以用关系运算>=或zeros和ones产生;正余弦用sin或cos产生;随机信号用rand函数产生。
4.常用时域离散信号的运算
在这里插入图片描述为例

n1=0; n2=10; n01=2;n02=4  %显示范围从n1到n2,非零值位于2和4
n=n1:n2;  %横坐标,写n=n1:1:n2也是一样的意思
x1=[(n-n01)==0]; %生成离散信号  
x2=[(n-n02)==0]; %生成离散信号 
x3=x1+x2;
subplot(3,1,1); stem(n,x1,’filled’); %绘制图形,x1子图,且圆点处用实心圆表示
subplot(3,1,2); stem(n,x2,’filled’); %绘制图形,x2子图,且圆点处用实心圆表示
subplot(3,1,3); stem(n,x3,’filled’); %绘制图形,x3子图,且圆点处用实心圆表示

四、实验内容

  1. 在MATLAB中实现 在这里插入图片描述序列,显示范围 在这里插入图片描述(函数命名为impseq(n0,n1,n2))。并利用该函数实现序列: ;
 n1=-3; n2=10; n0=-3; 
n=n1:n2;
n01=3;n02=6;
x1=[(n-n01)==0];
x2=[(n-n02)==0];
x3=2*x1+x2;
stem(n,x3,'filled' )

在这里插入图片描述

  1. 在MATLAB中实现 在这里插入图片描述序列,显示范围 在这里插入图片描述(函数命名为stepseq(n0,n1,n2))。并利用该函数实现序列: 在这里插入图片描述
    函数文件
function x=stepseq(n0,n1,n2);
n=n1:n2;
x=[n>=n0];
stem(n,x,'filled');

程序

n1=-5;
n2=20;
n0=0;
n=n1:n2;
n01=-2;n02=2;
x1=[(n-n01)>=0];
x2=[(n-n02)>=0];
x3=x1+x2;
stem(n,x3,'filled')

在这里插入图片描述

  1. 在MATLAB中利用数组运算符“.^”来实现一个实指数序列。如:在这里插入图片描述
    函数文件
function y=zhishu(a,n1,n2) 
n=n1:n2;
y=(a).^n;

程序

y=zhishu(0.3,0,50);
n=0:50;
stem(n,y)

在这里插入图片描述

  1. 在MATLAB中用函数sin或cos产生正余弦序列,如:在这里插入图片描述

请用plot函数画出连续波形,用stem函数画出离散波形。

n=0:20;
x=11*sin(0.3*pi*n+0.2*pi)+5*cos(0.3*pi*n);
plot(n,x)
stem(n,x)

在这里插入图片描述
在这里插入图片描述

//下面的选作
实验报告:题目下面:函数+运行结果

实验报告命名格式:实验n+姓名+学号

  1. 在这里插入图片描述
    函数文件

function y=yidong(a,n1,n2)
n=n1:n2;
y=3*cos(2*pi/10*(n-a));

程序

n=0:20;
y1=yidong(0,0,20);
y2=yidong(-3,0,20);
y3=yidong(3,0,20);
subplot(3,3,1);
stem(n,y1);
subplot(3,3,2)
stem(n,y2);
subplot(3,3,3);
stem(n,y3)

在这里插入图片描述

  1. 在这里插入图片描述
    函数
function y=u(n0,n1,n2)
n=n1:1:n2;
y=[(n-n0)>=0];

程序

n1=-4:6;
n2=-5:8;
x1=u(-2,-4,6);
x2=u(4,-5,8);
y1=[0 x1 0 0];
y2=x2;
y=y1+y2;
stem(n2,y)

在这里插入图片描述

五、思考题
1.1 产生单位脉冲序列和单位阶跃序列各有几种方法?如何使用?
答:
各有两种方法。 
1) 单位脉冲序列 
①利用条件语句:y=[(n-n0)==0]
②利用if语句:

 for i=n1:n2      
if i==n0        
x(i)=1;      
end 
end

2)单位序列u(n-no)表示方法: 
①利用条件语句:y=[(n-n0)>=0];
②利用if语句

for n=1:20         
if n<=n0           
y=1;         
end    
end 

1.2 进行序列的相乘运算时应注意什么问题?
答:进行序列的相乘运算时应注意: 
(1)注意维数要相同,不同则会出错。 
(2)元素与元素进行四则运算要用“点“的运算。例如:相乘要用点乘
1.3 MATLAB中画连续信号波形和离散信号波形有什么区别?
答:绘制连续信号波形与离散波形所用的函数不同,例如连续信号的函数有sin,cos等,
绘制离散波形的函数有stem等,还有就是绘制这两种信号波形所要编写的程序也不同。

  • 20
    点赞
  • 75
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
数字信号处理实验离散系统的时域分析主要包括以下内容: 1. 离散时间系统的差分方程表示法 2. 冲激响应和卷积分析方法 3. 求解离散时间系统单位脉冲响应及任意输入序列引起的响应 4. 用MATLAB语言进行离散时间系统研究的基本方法 具体来说,离散时间系统的差分方程表示法是指将离散时间系统的输入和输出之间的关系用差分方程表示出来。冲激响应和卷积分析方法是指通过单位冲激响应和卷积运算来求解离散时间系统的响应。求解离散时间系统单位脉冲响应及任意输入序列引起的响应是指通过差分方程和卷积运算来求解离散时间系统的响应。用MATLAB语言进行离散时间系统研究的基本方法是指通过编写MATLAB程序来实现离散时间系统的分析和设计。 下面是一个例子,演示如何用MATLAB语言进行离散时间系统的时域分析: ```matlab % 离散时间系统的差分方程表示法 % y[n]+0.75y[n-1]+0.125y[n-2]=x[n]+x[n-1] % 求解该系统的单位脉冲响应和阶跃响应 % 求解单位脉冲响应 b = [1]; % 分子系数 a = [1, -0.75, -0.125]; % 分母系数 impulse_response = impz(b, a); % 求解单位脉冲响应 stem(impulse_response); % 绘制单位脉冲响应图形 title('Impulse Response'); % 求解阶跃响应 step_response = filter(b, a, ones(1, length(impulse_response))); % 求解阶跃响应 stem(step_response); % 绘制阶跃响应图形 title('Step Response'); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

haichao666

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值