Matlab编程资源库(10)离散傅立叶变换

news2024/9/17 7:27:23

一、离散傅立叶变换算法简要

  1. 给定一个N点的离散信号序列x(n),其中n表示时刻,n = 0, 1, 2, ..., N-1。

  2. 定义离散傅立叶变换的频域序列X(k),其中k表示频率,k = 0, 1, 2, ..., N-1。

  3. 通过以下公式计算每个频率对应的复数值:

     X(k) = Σx(n) * exp(-j * 2π * kn / N),其中j表示虚数单位exp表示指数函数

    上述公式中的指数函数是旋转因子,它表示每个频率对应的旋转角度。

  4. 重复步骤3,计算所有频率对应的复数值,得到频域序列X(k)。

  5. 最终得到的频域序列X(k)表示了原始信号在不同频率上的能量分布。

二、离散傅立叶变换的实现

一维离散傅立叶变换函数 ,其调用格式与功 能为:
 (1) fft(X):返回向量 X 的离散傅立叶变换。设 X 的长度 ( 即元素个数 ) N ,若 N 2 的幂 次,则为以 2 为基数的快速傅立叶变换,否 则为运算速度很慢的非 2 幂次的算法。对于 矩阵 X fft(X) 应用于矩阵的每一列。
(2) fft(X,N) :计算 N 点离散傅立叶变换。它限 定向量的长度为 N ,若 X 的长度小于 N ,则 不足部分补上零;若大于 N ,则删去超出 N 的那些元素。对于矩阵 X ,它同样应用于矩 阵的每一列,只是限定了向量的长度为 N
(3) fft(X,[],dim) fft(X,N,dim) :这是对于矩 阵而言的函数调用格式,前者的功能与 FFT(X) 基本相同,而后者则与 FFT(X,N) 本相同。只是当参数 dim=1 时,该函数作用 X 的每一列;当 dim=2 时,则作用于 X 每一行。 值得一提的是,当已知给出的样本数 N0 不是 2 的幂次时,可以取一个 N 使它大于 N0 且是 2 的幂次,然后利用函数格式 fft(X,N) fft(X,N,dim) 便可进行快速傅立叶变换。这样,计算速度将大大加快。 相应地,一维离散傅立叶 逆变换 函数是 ifft ifft(F) 返回 F 的一维离散傅立叶逆变换; ifft(F,N) N 点逆变换; ifft(F,[],dim) ifft(F,N,dim) 则由 N dim 确定逆变换的点数或操作方向。
6-15 给定数学函数 x(t)=12sin(2 π× 10t+ π /4)+5cos(2 π× 40t)
N=128 ,试对 t 0~1 秒采样,用 fft 作快速傅 立叶变换,绘制相应的振幅 - 频率图。
0~1 秒时间范围内采样 128 点,从而可以确 定采样周期和采样频率。由于离散傅立叶 变换时的下标应是从 0 N-1 ,故在实际应 用时下标应该前移 1 。又考虑到对离散傅立 叶变换来说,其振幅 | F(k)| 是关于 N/2 对称 的,故只须使 k 0 N/2 即可。
程序如下:
N=128; % 采样点数
T=1; % 采样时间终点
t=linspace(0,T,N); % 给出N个采样时间ti(I=1:N)
x=12*sin(2*pi*10*t+pi/4)+5*cos(2*pi*40*t); % 求各采样点 样本值x
dt=t(2)-t(1); % 采样周期
f=1/dt; % 采样频率(Hz)
X=fft(x); % 计算x的快速傅立叶变换X
F=X(1:N/2+1); % F(k)=X(k)(k=1:N/2+1)
f=f*(0:N/2)/N; % 使频率轴f从零开始
plot(f,abs(F),'-*') % 绘制振幅-频率图
xlabel('Frequency');
ylabel('|F(k)|')

运行结果 :

 结语   

一口吃不成胖子

但胖子却是一口一口吃来的

!!!

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

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

相关文章

win11 备份mysql数据 卸载mysql 5 安装mysql 8详细教程(mysql的数据备份与卸载与安装)

如果是第一次安装mysql便可以直接看第三步 第一步:数据备份 我选择的是备份全部数据 以管理员身份运行cmd输入mysqldump -u root -p --all-databases --routines --triggers --single-transaction > C:\ProgramTools\MySql\backup_5.6.sql 其中:-u…

golang 文件

golang 文件 概念 文件是计算机系统中用于存储和管理的 数据集合,具有唯一的名称,存在于存储介质上,包含创建、修改等属性,通过文件系统进行组织,用户可进行读取、写入等操作 文件流 文件输入流(InputS…

3D打印:重塑模具制造业的创新引擎

在科技浪潮的推动下,3D打印技术正以前所未有的速度渗透到制造业的核心,尤其在模具制造领域,它正引领一场深刻的创新革命。该技术通过颠覆传统制造范式,显著优化了模具生产的复杂流程,实现了从设计到成品的一体化的高效…

Git操作快速入门:掌握代码版本控制的秘诀

文章目录 文章内容概述Git的安装和配置创建和克隆仓库基本操作添加和提交文件查看状态和日志分支管理远程仓库操作 常见的错误和解决方法错误1:合并冲突(Merge Conflict)错误2:丢失修改(Detached HEAD)错误…

win11查找句柄泄露

1.打开任务管理器,不会的网上搜 2.选择详细信息 3.注意了 比较坑的一点 win11上详细信息不会默认显示句柄数。(默认没有句柄那一列,妈的花了我好长时间找) 右键,点击选择列 选择句柄 下面的列表里就能看到进程使用…

CSS技巧专栏:一日一例 11 -纯CSS实现多彩渐变按钮系列特效

CSS技巧专栏:一日一例 11 -纯CSS实现多彩渐变按钮系列特效 本篇,推荐给你几个按钮,先看一下图片 本例图片 案例分析 这是一个系列的按钮,它们具有共同的特点: 底层按钮层,具有一个彩色的渐变边框,上层是依据hover效果需要,可以是渐变,可以时白色。 鼠标hover效果…

Spring Data Redis 实践以及可视化工具使用

目录 一、安装 Redis Win 环境安装 Linux 环境安装 Redis可视化管理工具 二、Spring Data Redis的使用 Spring Cache简介 Spring Cache常用注解 EnableCaching Cacheable CachePut CacheEvict Spring Cache使用步骤 Redis存储JSON格式数据 使用Redis连接池 Jedi…

使用WebSocket协议调用群发方法将消息返回客户端页面

目录 一.C/S架构: 二.Http协议与WebSocket协议的区别: 1.Http协议与WebSocket协议的区别: 2.WebSocket协议的使用场景: 三.项目实际操作: 1.导入依赖: 2.通过WebSocket实现页面与服务端保持长连接&a…

Python包管理工具pip

1、安装pip cmd管理员模式打开控制台 python -m pip install --upgrade pip 2、添加pip环境变量 pip 路径 C:\Users\1\AppData\Local\Programs\Python\Python312\Scripts

若依 Vue3 前端分离 3.8.8 版集成 jsencrypt 实现密码加密传输方式

一、问题展示 在若依的 Vue 前端分离版中登录密码和修改密码时可以发现密码是明文传输的,超管重置用户密码时同样如此,如下图所示: 可以发现密码全部都是明文传输,十分不安全,必须对传输的密码进行加密传输。 二、解决…

前端渲染模式

渲染的概念 在Web开发中,渲染(Rendering)是一个核心概念,指的是将应用程序的数据(data)与模板(template)结合,生成最终的HTML页面,这个页面随后会被浏览器解析…

扰动观测器DOB设计及其MATLAB/Simulink实现

扰动观测器(Disturbance Observer, DOB)是一种在控制系统中用于估计和补偿未知扰动的重要工具,以增强系统的鲁棒性和稳定性。其设计过程涉及系统建模、观测器结构设计以及控制律的调整。 扰动观测器设计原理 系统建模: 首先,需要建立被控对象的数学模型,明确系统的状态变…

深入理解synchronized(简记)

深入理解synchronized 管程synchronized对象的内存布局锁状态记录锁对象状态转换偏向锁轻量级锁锁对象转换总结 管程synchronized Java 参考了 MESA 模型,语言内置的管程(synchronized)对 MESA 模型进行了精简。 对象的内存布局 对象头 Mar…

DuckDB核心模块揭秘 | 第1期 | 向量化执行引擎之Pipeline

DuckDB核心模块揭秘 | 第1期 | 向量化执行引擎之Pipeline DuckDB是一款非常火的OLAP嵌入式数据库,性能超级棒。它分为多个组件:解析器、逻辑规划器、优化器、物理规划器、执行器以及事务和存储管理层。其中解析器原语PgSQL的解析器;逻辑规划器…

skynet热更新之inject

游戏服务器的热更新是一种常见的需求,skynet可以通过inject的方式,来修改一个服务的消息处理函数,达到热更新的效果。 skynet内置服务debug_console skynet自带了一个调试控制台服务。inject注入代码需要先启动这个服务。 skynet.newservi…

linux自动化构建工具--make/makefile

目录 1.make/makefile介绍 1.1基本认识 1.2依赖关系、依赖方法 1.3具体操作步骤 1.4进一步理解 1.5默认设置 1.6make二次使用的解释 1.7两个文件的时间问题 1.8总是被执行 1.9特殊符号介绍 1.make/makefile介绍 1.1基本认识 make是一个指令,makefile是一…

Dify中语音和文字间转换问题的一种暂时注释方式

本文主要解释了Dify中语音和文字间转换可能会遇到的问题,并给出了一种暂时注释的解决方案。 一.文本转语音可能问题 本地部署文本转语音时,如果遇到如下问题,安装ffmpeg即可。但是如果安装后,重启系统还是遇到这个问题该如何办&…

02 Golang面向对象编程_20240727 课程笔记

视频课程 最近发现越来越多的公司在用Golang了,所以精心整理了一套视频教程给大家,这个是其中的第二部,后续还会有很多。 视频已经录制完成,完整目录截图如下: 课程目录 01 结构体的声明.mp402 使用var根据结构体…

Firefox扩展程序和Java程序通信

实现Firefox扩展程序,和Java RMI Client端进行通信。 在Firefox工具栏注册按钮,点击按钮后弹出Popup.html页面,引用Popup.js脚本,通过脚本向Java RMI client发送消息,Java RMI Client接收消息后转发到Java RMI Server…

Docker————数据卷容器,容器互联,镜像创建

1、Docker的数据管理 管理Docker容器中的数据,主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers). docker run [-i -t] [--name 容器名] 镜像名:标签 [容器启动命令]…