华南理工大学数字信号处理实验实验一(薛y老师版本)matlab源码

一、实验目的

1、加深对离散信号频谱分析的理解;

2、分析不同加窗长度对信号频谱的影响;

3、理解频率分辨率的概念,并分析其对频谱的 影响;

4、窗长和补零对DFT的影响

实验源码:

 第一题:

% 定义离散信号 x[n]
n = 0:1000; % 离散时间范围
x = cos(pi*n/10) + sin(pi*n/6) + cos(2*pi*n/5); % 信号定义% 计算频谱
X = fft(x); % 应用离散傅里叶变换% 绘制频谱图
f = (0:length(X)-1)*(1/length(X)); % 频率范围
figure(1);
plot(f, abs(X)); % 绘制频谱图
xlabel('Frequency'); % x轴标签
ylabel('Magnitude'); % y轴标签
title('Spectrum'); % 图标题% 窗口长度为 N = 16
N1 = 16;
window1 = rectwin(N1); % 矩形窗口
x1 = x(1:N1) .* window1'; % 截取信号并应用窗口
X1 = fft(x1); % 计算频谱% 窗口长度为 N = 60
N2 = 60;
window2 = rectwin(N2); % 矩形窗口
x2 = x(1:N2) .* window2'; % 截取信号并应用窗口
X2 = fft(x2); % 计算频谱% 窗口长度为 N = 120
N3 = 120;
window3 = rectwin(N3); % 矩形窗口
x3 = x(1:N3) .* window3'; % 截取信号并应用窗口
X3 = fft(x3); % 计算频谱pic1=[1:16];
pic2=[1:60];
pic3=[1:120];
% 绘制不同窗口长度截取后的频谱图
figure(2);
subplot(3, 1, 1);
stem(pic1, abs(X1));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (N = 16)');subplot(3, 1, 2);
stem(pic2, abs(X2));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (N = 60)');subplot(3, 1, 3);
stem(pic3, abs(X3));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (N = 120)');% 窗口长度为 N = 120
N = 120;
n = 0:N-1;% 矩形窗口
window_rect = rectwin(N);
x_rect = x(1:N) .* window_rect';
X_rect = fft(x_rect);% 汉宁窗
window_hann = hann(N);
x_hann = x(1:N) .* window_hann';
X_hann = fft(x_hann);% 黑曼窗
window_hamming = hamming(N);
x_hamming = x(1:N) .* window_hamming';
X_hamming = fft(x_hamming);% 绘制不同窗口对频谱的影响
figure(3);
subplot(3, 1, 1);
stem(pic3, abs(X_rect));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (Rectangular Window)');subplot(3, 1, 2);
stem(pic3, abs(X_hann));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (Hann Window)');subplot(3,1,3);
stem(pic3, abs(X_hamming));
xlabel('Frequency');
ylabel('Magnitude');
title('Spectrum (Hamming Window)');

运行效果:

 

第二题:

(1)首先,我们需要确定对连续信号 x(t) 进行采样时的最大采样间隔和频域采样的最少采样点数,以满足要求的频率分辨率。

确定最大采样间隔:

根据奈奎斯特采样定理,连续信号的最大频率成分应小于采样频率的一半。在这种情况下,我们需要确定连续信号的最大频率成分。

给定的信号 x(t) 包含了三个频率成分:200 Hz、100 Hz 和 50 Hz。因此,连续信号的最大频率成分为 200 Hz。根据奈奎斯特采样定理,我们需要选择的采样频率应大于 2 * 200 Hz = 400 Hz。

所以,最大采样间隔为 T = 1 / 400 Hz = 0.0025 秒,即采样频率为 400 Hz。

确定频域采样的最少采样点数:

频域采样的最少采样点数取决于所需的频率分辨率和采样频率。在这种情况下,要求的频率分辨率为 1 Hz,采样频率为 400 Hz。

根据频率分辨率和采样频率的关系,最少采样点数 N 可以通过以下公式计算:

N = 采样频率 / 频率分辨率

N = 400 Hz / 1 Hz = 400

(2)(3)

% 参数设置
Fs = 400; % 采样频率
T = 1/Fs; % 采样间隔
N = 400; % 采样点数
f = (0:N-1) * Fs/N; % 频率轴% 生成信号
t = (0:N-1) * T; % 时间轴
x = cos(200*pi*t) + sin(100*pi*t) + cos(50*pi*t); % 信号% 进行频谱分析
X = abs(fft(x, N)); % DFT% 绘制幅频特性
figure;
plot(f, X);
xlabel('Frequency (Hz)');
ylabel('Magnitude');
title('Amplitude Spectrum');% 分析频域采样点数对频谱的影响
figure;
N_values = [100, 200, 400, 800]; % 不同的采样点数
for i = 1:length(N_values)N = N_values(i);f = (0:N-1) * Fs/N;X = abs(fft(x, N));subplot(length(N_values), 1, i);plot(f, X);xlabel('Frequency (Hz)');ylabel('Magnitude');title(['N = ' num2str(N)]);
end

第三题:

(1)计算周期

信号 x[n] 的周期可以通过求两个频率成分的最小公倍数来确定。

对于频率成分 0.48π 和 0.52π,它们的周期分别是 2π/0.48π ≈ 4.1667 和 2π/0.52π ≈ 3.8462。

要找到两个周期的最小公倍数,我们可以计算它们的倒数,然后取它们的最大公约数的倒数。

最小公倍数 = 1 / (最大公约数的倒数)

计算最大公约数的倒数:

1 / 4.1667 ≈ 0.24

1 / 3.8462 ≈ 0.26

计算最大公约数的倒数:

1 / (最大公约数的倒数) ≈ 1 / 0.02 = 50

因此,信号 x[n] 的周期为 50。

% 参数设置
N = 50; % 一个周期的信号长度
n = 0:N-1; % 时间轴
x = cos(0.48*pi*n) + cos(0.52*pi*n); % 一个周期的信号% 计算一个周期的 DFT
X_periodic = fft(x);% 补零并计算 DFT
x_padded = [x zeros(1, 100-N)]; % 补零
X_padded = fft(x_padded);N100=100;
n100=0:N100-1;
x100=cos(0.48*pi*n100) + cos(0.52*pi*n100); 
% 取 0 ≤ n ≤ 99 并计算 DFT
x_truncated = x100; % 补零使得长度为 100
X_truncated = fft(x_truncated); % 不指定 DFT 点数,使用默认值% 绘制幅频特性
figure;
subplot(3, 1, 1);
stem(abs(X_periodic));
title('DFT of One Period');
xlabel('Frequency Bin');
ylabel('Magnitude');subplot(3, 1, 2);
stem(abs(X_padded));
title('DFT with Zero Padding');
xlabel('Frequency Bin');
ylabel('Magnitude');subplot(3, 1, 3);
stem(abs(X_truncated));
title('DFT of Truncated Signal');
xlabel('Frequency Bin');
ylabel('Magnitude');

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/638377.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【多线程的安全问题】synchronized 和 volatile——你必须知道的妙用!

📄前言:本文的主要内容是讨论个人在多线程编程带来的安全问题的表现、原因以及对应的解决方法。 文章目录 一. 了解多线程安全问题二. 线程不安全的现象及原因🍆1. 修改共享的数据(根本原因)🍅2. 原子性&am…

class_14:继承

C继承有点类似于c语言 结构体套用 #include <iostream> #include <string> using namespace std;//基类,父类 class Vehicle{ public:string type;string contry;string color;double price;int numOfWheel;void run();void stop(); };//派生类&#xff0c…

commit 历史版本记录修正

commit 历史版本记录修正 当 Bug 发生的时候&#xff0c;我们会需要去追踪特定 bug 的历史记录&#xff0c;以查出该 bug 真正发生的原因&#xff0c;这个时候就是版本控制带来最大价值的时候。 因此&#xff0c;要怎样维持一个好的版本记录是非常重要的&#xff0c;下面是一…

Rockchip linux USB 驱动开发

Linux USB 驱动架构 Linux USB 协议栈是一个分层的架构&#xff0c;如下图 5-1 所示&#xff0c;左边是 USB Device 驱动&#xff0c;右边是 USB Host 驱动&#xff0c;最底层是 Rockchip 系列芯片不同 USB 控制器和 PHY 的驱动。 Linux USB 驱动架构 USB PHY 驱动开发 USB 2…

手机也能随时随地玩红警啦!

还在为找不到红警安装包苦恼吗&#xff1f; 现在可以随时随地&#xff0c;无论手机、ipad、电脑都可以无需安装包在线玩红警啦&#xff01;&#xff01; 不仅能本地单机玩耍&#xff0c;还能联网玩耍&#xff08;可以和老外一起玩哦&#xff5e;&#xff09; 具体在线链接可…

算法第二十一天-丑数

丑数 题目要求 解题思路 首先判断数字是不是为0或者负数&#xff0c;两者均不可能成为丑数&#xff1b; 之后对n进行不断整除&#xff0c;直到无法除尽为止。 简单判断最后的数是不是1即可。 代码 class Solution:def isUgly(self, n: int) -> bool:if n<0:return Fa…

Linux启动流程梳理值得收藏

Linux启动流程总的来说可以分成三个阶段 Linux启动流程图 第一步&#xff1a;上电 在 x86 系统中&#xff0c;将 1M 空间最上面的 0xF0000 到 0xFFFFF 这 64K 映射给 ROM。 当电脑刚加电的时候&#xff0c;会做一些重置的工作&#xff0c;将 CS 设置为 0xFFFF&#xff0c;将 IP…

Docker命令---搜索镜像

介绍 使用docker命令搜索镜像。 命令 docker search 镜像命令:版本号示例 以搜索ElasticSearch镜像为例 docker search ElasticSearch

【unity】麦克风声音驱动,控制身体做出不同动作

1.在角色对象上挂在animator组件&#xff0c;并将动作控制器与其关联 2.在角色对象上挂在audio source组件。 3.新建voice control脚本&#xff0c;编写代码如下&#xff1a; using System; using System.Collections; using System.Collections.Generic; using UnityEngine;…

复现PointNet++(语义分割网络):Windows + PyTorch + S3DIS语义分割 + 代码

一、平台 Windows 10 GPU RTX 3090 CUDA 11.1 cudnn 8.9.6 Python 3.9 Torch 1.9.1 cu111 所用的原始代码&#xff1a;https://github.com/yanx27/Pointnet_Pointnet2_pytorch 二、数据 Stanford3dDataset_v1.2_Aligned_Version 三、代码 分享给有需要的人&#xf…

算法专题[递归-搜索-回溯-2-DFS]

算法专题[递归-搜索-回溯-2-DFS] 一.计算布尔二叉树的值&#xff1a;1.思路一&#xff1a;2.GIF题目解析 二.求根节点到叶子节点的数字之和1.思路一&#xff1a;2.GIF题目解析 三.二叉树剪枝1.思路一&#xff1a;2.GIF题目解析 四.验证二叉搜索树1.思路一&#xff1a;2.GIF题目…

1.2 数据模型

数据模型是对现实世界数据特征的抽象&#xff0c;是现实世界的模拟 数据模型是用来描述数据、组织数据和对数据进行操作的 数据模型应满足三方面要求&#xff1a; 1 能比较真实地模拟现实世界 2 容易为人所理解 3 便于在计算机上实现 数据模型…

08. Springboot集成webmagic实现网页爬虫

目录 1、前言 2、WebMagic 3、Springboot集成Webmagic 3.1、创建Springboot&#xff0c;并引入webmagic依赖 3.2、定义PageProcessor 3.3、元素选择 3.3.1、F12查看网页元素 3.3.2、元素选择 3.3.3、注意事项 4、小结 1、前言 在信息化的时代&#xff0c;网络爬虫已…

QT的绘图系统QPainterDevice与文件系统QIODevice

QT的绘图系统&#xff08;QPainterDevice&#xff09;与文件系统&#xff08;QIODevice&#xff09; 文章目录 1、Qt 的绘图系统1、QPainter的使用2、QPen(画笔&#xff09;及QBursh&#xff08;画刷&#xff09;3、手动更新窗口4、绘图设备1、四种绘图设备的 区别2、 QBitmap3…

零食折扣店,注定昙花一现?

年终岁末&#xff0c;又到了各类休闲零食产品一年一度的销售旺季。与过去不同的是&#xff0c;近年来的休闲零食赛道正因大量零食折扣店的涌现而显得热闹非凡。 随着主打折扣、低价的零食折扣店成为消费者特别是三四线下沉市场消费者的新宠&#xff0c;资本开始涌入并快速推动…

SpringCloud之OpenFeign的学习、快速上手

1、什么是OpenFeign OpenFeign简化了Http的开发。在RestTemplate的基础上做了封装&#xff0c;在微服务中的服务调用发送网络请求起到了重要的作用&#xff0c;简化了开发&#xff0c;可以让我们跟写接口一样调其他服务。 并且OpenFeign内置了Ribbon实现负载均衡。 官方文档…

69.使用Go标准库compress/gzip压缩数据存入Redis避免BigKey

文章目录 一&#xff1a;简介二&#xff1a;Go标准库compress/gzip包介绍ConstantsVariablestype Headertype Reader 三&#xff1a;代码实践1、压缩与解压工具包2、单元测试3、为何压缩后还要用base64编码 代码地址&#xff1a; https://gitee.com/lymgoforIT/golang-trick/t…

SpringBoot3整合OpenAPI3(Swagger3)

文章目录 一、引入依赖二、使用1. OpenAPIDefinition Info2. Tag3. Operation4. Parameter5. Schema6. ApiResponse swagger2更新到3后&#xff0c;再使用方法上发生了很大的变化&#xff0c;名称也变为OpenAPI3。 官方文档 一、引入依赖 <dependency><groupId>…

深度解析Python关键字:掌握核心语法的基石(新版本35+4)

目录 关键字 keyword 关键字列表 kwlist softkwlist 关键字分类 数据类型 True、False None 运算类型 and、or、not in is 模块导入 import 辅助关键字 from、as 上下文管理 with 占位语句 pass 流程控制 if、elif、else for while break、continue…

第十回 朱贵水亭施号箭 林冲雪夜上梁山-FreeBSD/Linux 控制台基础操作

林冲被众庄客捉住&#xff0c;吊在门楼下&#xff0c;正被打时&#xff0c;柴进来了&#xff0c;赶快把林冲救下来。原来这是柴进打猎用的小庄子&#xff0c; 林冲就把火烧草料场一事跟柴进详细的说了。柴进说兄弟真是命运多磨难啊。林冲住了几日&#xff0c;恐怕连累柴进&…