Matlab信号与系统实验-实验三 连续时间信号的频域分析

一、实验目的

1、掌握傅立叶变换及其性质;

2、掌握连续时间信号傅立叶变换的数值计算方法;

3、掌握利用MATLAB实现信号的幅度调制的方法;

4、掌握利用MATLAB实现傅立叶变换的方法;

5、掌握利用MATLAB实现对周期信号的频谱分析。

二、实验内容

1、编程求解正弦函数、取样函数、门函数 、双边指数函数信号的傅立叶变换式。

Matlab 复制代码
syms t;
f=sin(t);
F=fourier(f);
disp('正弦函数的傅里叶变换式为');
disp(F);
f2=f/t;
F2=fourier(f2);
disp('取样函数的傅里叶变换式为');
disp(F2);
f3=heaviside(t+1)-heaviside(t-1);
F3=fourier(f3);
disp('门函数u(t+1)-u(t-1)的傅里叶变换式为');
disp(F3);
f4=exp(-2*abs(t));
F4=fourier(f4) ;
disp("双边函数e**(-2*|t|)的傅里叶变换式为");
disp(F4);

2、设,已知信号f(t)的傅立叶变换为 ,求的傅立叶变换,观察并验证傅立叶变换的对称性。

Matlab 复制代码
clear;
syms t;
f=sin(t)/t
F=fourier(f);
disp('Sat的傅里叶变换为π*g(w)');
disp(F)
ft1=-pi*(heaviside(t+1)-heaviside(t-1))
Ft1=fourier(ft1);
disp("π*g(t)的傅里叶变换");
disp(Ft1);

3、已知,试用MATLAB给出f(t),y(t)的时域波形及它们的频谱的图形,验证时域卷积定理。

Matlab 复制代码
clear;
fs=20;%采样率
T=4;
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x =  heaviside(t+1)-heaviside(t-1);
subplot(2,2,1);
plot(t,x);%画时域图
xlabel("t/s")
X = fftshift(fft(x./(n))); %用fft得出离散傅里叶变换
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(223)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")
K =conv(x,x);

subplot(222)
plot(K)
subplot(224)
X2=fftshift(fft(K./(n)));
plot(abs(X2))

4、绘制出下列信号及幅频图

(1)门函数脉冲序列

Matlab 复制代码
clear;
fs=20;%采样率
T=4;
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x =  heaviside(t+1/2)-heaviside(t-1/2);
subplot(3,1,1);
plot(t,x);%画时域图
xlabel("t/s")
X = fftshift(fft(x./(n))); %用fft得出离散傅里叶变换
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(3,1,2)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")

(2)单边指数信号

Matlab 复制代码
clear;
fs=20;%采样率
T=4;
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x = heaviside(t).*exp(-2*t)
subplot(3,1,1);
plot(t,x);%画时域图
xlabel("t/s")
X = fftshift(fft(x./(n))); %用fft得出离散傅里叶变换
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(3,1,2)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")

(3)高斯信号

Matlab 复制代码
clear;
fs=500;%采样率
T=1;%时宽1s
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x =exp(-(t.*t));
subplot(3,1,1);
plot(t,x);%画时域图
xlabel("t/s")
%X=fft(x);
X = fftshift(fft(x./(n))); %用fft得出离散傅里叶变换
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(3,1,2)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")

(4)三角脉冲信号

Matlab 复制代码
clear;
fs=20;%采样率
T=5;%时宽5s
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x = tripuls(t,2);
subplot(2,1,1);
plot(t,x);%画时域图
xlabel("t/s")
X = fftshift(fft(x./(n))); %用fft得出离散傅里叶变换
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(2,1,2)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")

(5)求的傅立叶逆变换

Matlab 复制代码
clear;
fs=20;%采样率
T=5;%时宽5s
n=round(T*fs);%采样点个数
t=linspace(-T,T,n);%时域横坐标
x = exp(-abs(t))/2;
subplot(2,1,1);
plot(t,x);%画时域图
xlabel("t/s")
X = fftshift(fft(x./(n)));
f=linspace(-fs/2,fs/2-1,n);%频域横坐标,奈奎斯特采样定理,最大原信号最大频率不超过采样频率的一半
subplot(2,1,2)
plot(f,abs(X));%画双侧频谱幅度图
xlabel("f/Hz")
ylabel("幅度")
相关推荐
幻想趾于现实几秒前
C# Winform 入门(2)之发送邮件
开发语言·c#
半盏茶香6 分钟前
启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——堆的应用之堆排、Top-K问题
java·开发语言·数据结构·c++·python·算法·链表
小吴先生66628 分钟前
Groovy 规则执行器,加载到缓存
java·开发语言·缓存·groovy
秋风&萧瑟43 分钟前
【QT】QT的多界面跳转以及界面之间传递参数
开发语言·qt
骑牛小道士1 小时前
JAVA- 锁机制介绍 进程锁
java·开发语言
郭涤生1 小时前
Chapter 1: Historical Context_《C++20Get the details》_notes
开发语言·c++20
独好紫罗兰1 小时前
洛谷题单2-P5712 【深基3.例4】Apples-python-流程图重构
开发语言·python·算法
东方佑1 小时前
深度解析Python-PPTX库:逐层解析PPT内容与实战技巧
开发语言·python·powerpoint
水w1 小时前
【Android Studio】如何卸载干净(详细步骤)
android·开发语言·android studio·activity
weixin_307779131 小时前
判断HiveQL语句为建表语句的识别函数
开发语言·数据仓库·hive·c#