使用Matlab编程实现FFT的频谱分析

2023-05-16

目录

  • 使用Matlab编程实现FFT的频谱分析
    • fft函数
    • 原始波形函数
    • 原始数据导入函数
    • 数据导出函数
    • fft分析例程

使用Matlab编程实现FFT的频谱分析

用Matlab进行fft仿真分析,最大的优势在于其丰富的函数库支撑,可以产生正弦波,矩形波等多种信号,支持信号运算,添加白噪声等功能,丰富的绘图输出功能,还可以对时域波形图和进行FFT变换后的频谱图、功率图进行展示,直观高效。 下面就mathlab变换仿真中可能用到的几个关键函数进行介绍,随后给出完整的fft仿真程序实例,欢迎沟通交流。

fft函数

在mathlab中,fft函数有以下几种使用方法:

(1)Y = fft(x)

(2)Y = fft(X,n)

(3)Y = fft(X,n,dim)

其中(1)最简单,如果x是向量,则fft(x)返回该向量的傅里叶变换,如果x是矩阵,则fft(x)将x的各列视为向量,并返回每列的傅里叶变换。如果x是一个多维数组,则 fft(X) 将沿大小不等于 1 的第一个数组维度的值视为向量,并返回每个向量的傅里叶变换。

形式(2):Y = fft(X,n),第一个参数桶形式(1),第二个参数n标识做fft变换的数据长度。因此,不同于形式(1)的地方主要就是参数一的X长度和n的关系,如果 X 是向量且 X 的长度小于 n,则为 X 补上尾零以达到长度 n。如果 X 是向量且 X 的长度大于 n,则对 X 进行截断以达到长度 n。如果 X 是矩阵,则每列的处理与在向量情况下相同。如果 X 为多维数组,则大小不等于 1 的第一个数组维度的处理与在向量情况下相同。
形式(3)Y = fft(X,n,dim),在形式(2)基础上指定维度dim,当x为矩阵时,在指定的dim维上进行傅里叶变换,dim=1按列,dim =2按行。

原始波形函数

matlab中支持所有的三角函数有两类:
第一类是例如sin、cos、tan等,函数参数都是以弧度为单位的。
第二类是用sind、cosd、tand等,是角度为单位的

当然,我们也可以用用deg2rad将角度转换为弧度。 例如

sin(pi/2) 和sind(90) 的结果是一样的。

利用上面的函数,我们可以生成各种各样的原始函数,

  • 例1如:频率为F,0点相位P的cos函数,可以标识为:
    S=cos(2piFt+piP/180);
    其中pi代表π。

  • 例2如:幅度为A1、频率为F1,0点相位P1的sin函数和幅度为A2、频率为F2,0点相位P2的cos信号叠加,可以表示为:
    S=A1sin(2piF1t+piP1/180)+A2cos(2piF2t+piP2/180);

原始数据导入函数

有时候,fft分析的原始信号并非由标准函数生成的组合信号,而是由传感器、采集器等外设实时采集的信号,这就需要mathlab能够导入相关数据进行分析,此时可以用mathlab自带的数据导入功能:

在这里插入图片描述导入类型支持广泛,如下图:

在这里插入图片描述导入后就可以在m源文件中使用了。

也可以不导入,在m源文件中通过函数从外部文件加载数据。
例如:
(1)importdata 函数

importdata 允许加载各种数据的不同格式的文件。它具有多种形式,详见mathlab的help我的,最常用的就是:

	A = importdata(filename)

将数据从文件名所表示的文件中加载到数组 A 中。
(2)xlsread函数
xlsread 是数学软件 MATLAB 中读取 Excel 文件中数据的一个函数。即从当前程序所在文件夹里,按照函数中的参数指定的范围,从单元格开始读取文件,返回数据,也有多种形式,常见的有:

   (1)num = xlsread(‘filename’)

从当前文件夹读取,比如说num=xlsread(‘data.xls’),即从当前程序所在文件夹里读取data.xls文件,把数据返回给num,数据从A1单元格开始读取。

  (2)num = xlsread(‘filename’,‘sheet1’)

从当前文件夹读取filename文件的’sheet1’读取数据。

 (3)num = xlsread(‘filename’, ‘range’)

从当前文件夹读取filename文件的中range范围内的单元格数据,比如说range=‘A1:A8’。

(4)num = xlsread(‘filename’, ‘sheet1’, ‘range’)

从当前文件夹读取filename文件的’sheet1’读取指定范围的数据

数据导出函数

mathlab中,dlmwrite功能是将矩阵写入ASCII分隔的文件中,使用方法

  1.dlmwrite(filename, M)

使用默认的分隔符(')将矩阵M写入ASCII格式的文件filname中,数据是从第一行的第一列开始写的。

2.dlmwrite(filename, M, 'D') matabc

将矩阵M写入一个ASCII格式的文件filename中,使用分隔符D来分割矩阵的元素。在目标文件filname中,数据是从第一行的第一列开始写的。逗号’是默认的分隔符,使用\t来产生制表符分割的文件。
举例如下:
dlmwrite(‘d:\data.txt’,A,‘delimiter’,‘\n’,‘newline’,‘pc’)

M的属性包括:

在这里插入图片描述D的属性包括:
在这里插入图片描述

3.dlmwrite(filename, M, 'D', R, C)

将矩阵M写入一个ASCII格式的文件filename中,使用分隔符D来分割矩阵的元素。在目标文件filname中,数据是从第R行的第C列开始写的。

fft分析例程

clc;
x = xlsread(‘fftdata.xlsx’); %load 数据
fs=12000; % 采样频率,自己根据实际情况设置
N=length(x); % x 是待分析的数据
n=1:N;
figure(1)
plot(n,x) %输出原始波形数据

%FFT 变换
X=fft(x,N); % FFT
dlmwrite(‘d:\work\outdata256.txt’,X,‘delimiter’,‘\n’,‘newline’,‘pc’) %输出数据
figure(2)
plot(n,X) %输出图形

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用Matlab编程实现FFT的频谱分析 的相关文章

  • Linux实用工具/软件

    一 录屏 Kazam 参考 xff1a Linux截图和屏幕视频录制软件Kazam 简书 二 播放器 VLC 推荐理由 xff1a 跨平台播放器 xff0c 支持H264等高清算法压缩格式 h264压缩比是200 1 xff0c 一般的第三
  • Ubuntu 安装boost

    boost是扩展的C 43 43 标准库 查看电脑默认安装的boost版本 xff1a dpkg S usr include boost version hpp 很多程序需要boost xff0c 但是版本可能不是ubuntu系统默认安装的
  • linux+python自动备份数据库

    linux 43 python自动备份数据库 1 在linux上安装mysqldump xff1a yum y install holland mysqldump noarch 2 编写python脚本 xff1a usr bin pyth
  • python基于Tkinter实现学生信息管理系统

    一 功能点介绍 xff08 毕设设计 xff09 1 添加学生成绩 xff1a 管理员可以在系统中添加学生的成绩信息 xff0c 包括学生姓名 学号 课程名称 成绩等 2 删除学生成绩 xff1a 管理员可以根据学生的学号或者姓名删除学生的
  • 感想京东

    xfeff xfeff 现在网上购物已经是家常便饭 xff0c 大多数人们都已接受了网购这种方式 xff0c 而能够给人们提供网购的网站也很多 xff0c 而我从好几年前就开始在京东网购物了 xff0c 因此京东商城的每一次发展 xff0c
  • 2014年度总结

    时光转眼即逝 xff0c 从还是懵懵懂懂的孩子一下子变成了已步入社会的工作者 回首2014年 xff0c 有欢乐 xff0c 有泪水 xff0c 有付出 xff0c 有收获等等 xff01 想起2014的自己还是一个刚步入工作岗位才半年 x
  • 将tensorflow训练好的模型移植到android

    将tensorflow训练好的模型移植到android上 说明 本文将描述如何将一个训练好的模型植入到android设备上 xff0c 并且在android设备上输入待处理数据 xff0c 通过模型 xff0c 获取输出数据 通过一个例子
  • FreeRTOS 启动第一个线程的步骤

    FreeRTOS 启动第一个线程的步骤 从main函数开始 初始化完成之后 通过SVC指令的中断函数来 初始化成需要的寄存器值 才能正常运行线程 1 启动第一个线程函数prvStartFirstTask 调用prvStartFirstTas
  • C#委托与事件的本质区别

    C 委托与事件的本质区别 从定义上说 xff0c 委托被编译器编译成一个类 xff0c 所以它可以像类一样在任何地方定义 xff0c 而事件被编译成一个委托类型的私有字段和两个公有add 和 remove 方法 xff08 有点类似于属性的
  • 文章千古事、得失寸心知

    文章千古事 得失寸心知 这些年 xff0c 读过的技术经典图书 成晓旭 xff1a 欢迎转载 行千里路 读万卷书 xff1b 历数十项目 编百万代码 十来年风雨IT路 xff0c 上百本沉寂专业书 佛说 xff1a 一花一世界 一叶一菩提
  • PX4+QGC+jmavsim软件在环仿真

    一 环境修改 参考官方手册jMAVSim 仿真模拟 PX4 Developer Guide xff0c 以上环境基于上一篇内容 xff0c 未完成ROS 43 jmavsim 43 QGC环境搭建的请移步Ubuntu18 04下px4 43
  • Delphi之东进模拟语音卡(D160A)可复用源码

    Delphi之东进模拟语音卡 D160A 可复用源码 作者 xff1a 成晓旭 Blog xff1a http blog csdn net cxxsoft 声明 xff1a 欢迎转载 xff0c 请保证文章的完整性 设计简介 xff1a 1
  • 《上海滩》命运的真实

    上海滩 命运的真实 小时候 xff0c 家里没电视 xff0c 像80年周润华版 上海滩 这样的经典 xff0c 通常也会很难一集不漏地看全 当然 xff0c 那个时候也看不懂那个冯程程的漂亮 许文强的帅气 xff0c 更看不懂冯敬尧的强横
  • 中国房价不可能下降的19个理由

    中国房价不可能下降的19 个理由 2014 年01月26日 根据 腾讯房产 资料整理 在 腾讯房产 频道看到的 xff0c 所谓专家解释说的房价不可能下降有N 个无以辩驳理由 虽然少数内容缺乏数据依据 xff0c 但总体来看 xff0c 分
  • 如果生命就是一次马航之旅

    岁月长河中 xff0c 生命只不过是一粒尘埃 xff0c 渺小而短暂 xff1a 正如一场马航之旅 xff0c 从起点到终点 xff0c 正常飞行6小时后一定能抵达目的地 xff1b 当波音777平稳抵达目的地后 xff0c 无论你多么留念
  • 秀一段《易语言》的源代码

    公开 类 启动类 lt gt 公开 静态 启动 猜数字 猜 61 创建 猜数字 猜 猜 类 猜数字 整数 内定数字 61 66 TODO 随机选择一个数 公开 猜 循环 猜数字 61 61 假 逻辑 猜数字 控制台 输出行 34 请猜1 1
  • 腾讯QQ音乐业务产品规划

    腾讯QQ音乐业务产品规划
  • 谁是你生命中的贵人

    谁是你生命中的贵人 谨以此文献给我一生至爱 作者 xff1a 成晓旭 版权保留 转载请保持文章完整性 最近很奇怪的发现 xff0c 生命中的人和事 xff0c 常常不是均匀而规律地分布在人生的时间轴上 xff0c 或许很长时间都平淡无奇 x
  • 服务器处理能力,你估算正确过吗?

    服务器处理能力 xff0c 你估算正确过吗 xff1f 作者 xff1a 成晓旭 1 引题 但凡写过技术方案的都知道 xff0c 在技术方案最终落实到工程实施部署时 xff0c 必须编制出当前解决方案需要部署的IT设备及环境 xff0c 包
  • 电信运营商云计算体系架构分析

    电信运营商云计算体系架构分析 作者 xff1a 成晓旭 xff08 版权保留 欢迎转载 xff09 第三篇 xff1a 体系架构分析 电信运营商云计算发展分析之一 xff1a 战略定位分析 xff0c 可供参考 电信运营商云计算发展分析之二

随机推荐

  • 企业ERP系统开发总结及建议

    企业ERP系统开发总结及建议 作者 xff1a 成晓旭 对于像我们这种规模的大型公司 xff0c 自己建设 实施和维护满足公司特定管理要求的管理信息系统 xff0c 是目前部分大型公司建设企业ERP 的常见思路 比如 xff1a XXXX
  • DataGridView解决使用BindingList时属性改变界面不更新问题

    目录 问题 解决方法一 解决方法二 问题 在使用BindingList作为DataGridView的数据源时 xff0c 当BindingList lt gt 有增加或者删除的时候DataGridView会自动刷新 xff0c 但是当Bin
  • 给软件工程师的自学建议

    给软件工程师的自学建议 与现在大学生的情况类似 xff0c 学校学的专业知识总是与实际工作中需要的知识相差甚远 或许进入我们这个行业就注定要一辈子不离书本 不离学习了 由于软硬件技术的推陈出新 xff0c 学校教的C Basic Pasca
  • 电信运营商移动互联网发展分析

    电信运营商移动互联网发展分析 移动互联网是通信业发展的大趋势 xff0c 随着3G 和WiMAX 等高速无线接入技术的飞速发展 xff0c 移动互联网不仅继承固定互联网的很多技术 xff0c 并且在商务 娱乐以及移动性等方面拓展用户需求 自
  • 47天21家面试,半年空挡期觉得整个人生都被毁了

    近日 xff0c 有网友在某社交论坛将自己这段时间的面试经历发表出来 xff0c 根据发帖人自己提供的信息 xff0c 主要面试的地点都在北京 xff0c 上海等地 微软和亚马逊刚面试完一面 xff0c 都是以算法为主 xff0c 其中 x
  • 嵌入式软件工程师面试题及答案

    题目一 上个星期 xff0c 去深圳一家搞ARM开发的公司面试 xff0c HR叫我做了一份卷子 xff0c 里面都是C编程 xff0c 心中暗喜 xff0c 因为这些题基本上都在程序员面试宝典里见过 后来回到学校 xff0c 在网上搜索
  • 中断和查询方式区别

    中断方式 xff1a 是事件触发的 xff0c 换訖只要有事件产生都会进入中断 組取得最优运行 xff0c 因此响应更快 xff0c 及时 查询方式 xff1a 就是在主函数里面不停循环 xff0c 查询端C 状态 xff0c 明显其弊端在
  • 怎么用美图秀秀制作证件照

    1 第一步 xff1a 制作各种背景 在美图秀秀软件中点击选择 新建 按钮 xff0c 打开新建功能菜单选项 弹出的页面中我们点击选择 新建画布 xff0c 然后选项设置选择使用 白色画布 或者 蓝色画布 xff0c 依照一寸 xff1a
  • C++应用程序路径获取及操作

    xfeff xfeff 想要访问执行程序 exe 路径下的文件 xff0c 有以下几个步骤 xff1a 1 先通过函数GetModuleFileName获取执行程序的绝对路径 TCHAR szPath MAX PATH 61 0 GetMo
  • c++成员函数后面加一个冒号的含义

    目录 1 变量初始化方式 1 1 赋值运算符赋值 1 2 括号赋值 1 3 冒号初始化 1 4 使用情况 1 变量初始化方式 1 1 赋值运算符赋值 int a 61 10 char b 61 39 r 39 1 2 括号赋值 int a
  • 相机标定与内外参

    目录 1 相机标定 1 1外参 1 2内参 2 参考资料 1 相机标定 在图像测量过程以及机器视觉应用中 xff0c 为确定空间物体表面某点的三维几何位置与其在图像中对应点之间的相互关系 xff0c 必须建立相机成像的几何模型 xff0c
  • 开启代理服务器解决跨域问题

    我在学习尚硅谷Ajax课程时候 xff0c 第一次遇到跨域的问题 Access to XMLHttpRequest at http localhost 5000 students from origin http localhost 808
  • 阿里云CentOS环境之docker安装,启动,加速器,docker-compose(十四)

    阿里云CentOS环境之docker安装 xff0c 启动 xff0c 加速器 十四 文章目录 阿里云CentOS环境之docker安装 xff0c 启动 xff0c 加速器 十四 介绍前提条件centos下安装1 卸载 xff08 可选
  • SQL Server JDBC Driver配置方法(图文讲解)

    一 下载驱动程序 下载地址 http download microsoft com download 8 B D 8BDABAE2 B6EA 41D4 B903 7916EF3690EF sqljdbc 1 2 2323 101 enu e
  • 孤立森林(Isolation Forest)算法剖析

    之后会持续更新算法剖析系列 xff0c 力图用最生动的例子演示每一个算法的原理 xff0c 不稀里糊涂做一个调包侠 欢迎持续关注 xff0c 指正不足 孤立森林 xff08 Isolation Forest xff09 算法是西瓜书作者周志
  • 如何使用VOFA+?一款好用的上位机软件(VOFA+的三种数据传输协议)——以PID调参为例

    这里写目录标题 起因一 VOFA 43 支持的三种数据传输协议RawData协议格式1 使用方法2 示例3 测试 firewater协议格式1 使用方法2 数据格式3 示例4 测试 justfloat协议格式1 使用方法2 数据格式3 示例
  • tss

    1 linux进程切换和TSS结构 http blog csdn net goodlixueyong article details 6018281 TSS 全称为task state segment xff0c 是指在操作系统进程管理的过
  • codeblock图形界面编程

    Code Blocks 是一款免费开源的 C C 43 43 IDE xff0c 支持 GCC MSVC 43 43 等多种编译器 xff0c 还可以导入 Dev C 43 43 的项目 Code Blocks 的优点是 xff1a 跨平台
  • 利用FFT成功实现拓扑识别(六)--为自己设计的滤波器做仿真验证

    为自己设计的滤波器做仿真验证 前文中我们已经设计好了2 4和6阶的数字带通滤波器 xff0c 实际效果如何昵 xff1f 可以通过mathlab工具进行仿真和验证 第一步 xff1a 导出滤波器 在mathlab的fdatool中设计好滤波
  • 使用Matlab编程实现FFT的频谱分析

    目录 使用Matlab编程实现FFT的频谱分析fft函数原始波形函数原始数据导入函数数据导出函数fft分析例程 使用Matlab编程实现FFT的频谱分析 用Matlab进行fft仿真分析 xff0c 最大的优势在于其丰富的函数库支撑 xff