当前位置: 首页 > article >正文

混合基FFT,matlab实现

参考数字信号处理教程第四版程佩青著第四章FFT这里直接给出matlab函数性能不保证最优注意此函数只能处理混合基fft即输入信号x的长度不能是素数不能是2次幂整数function X mixedRadixFFT(x) % multiBasesFFT3 - 任意混合基FFT运算 % 输入: x - 任意长度的数据行向量 % 输出: X - 频域结果列向量 validateattributes(x, {double},{row, nonempty}); N numel(x); % 输入信号点数 factorSeq factor(N); % 找出所有的基 r getr1r2torLStyle(factorSeq); % 整合所有为2的基输出符合要求的r0r1...rL-1形式 L numel(r); % 基的数量 % 获取x(n)的dft索引顺序和最后输出的X(k)的倒位序 [nCoef, kCoef] getCoef(r); % 计算n和k的系数 n 0; k 0; % 获取nL-1,...,n0用于计算旋转因子 nRepsPerMatForEach cumprod(r); nArr zeros(N, L); for i 1 : L % 计算nArr nL-1,...,n0 ri r(end - (i - 1)); nRepsPerElem cumprod(r(end - (i - 1) : end)); nRepsPerElem N / nRepsPerElem(end); ni repelem((0 : ri - 1), nRepsPerElem); nRepsPerMat N / nRepsPerMatForEach(end - (i - 1)); nArr(:, i) repmat(ni, [nRepsPerMat 1]); % 获取x(n)的正序n r0r1...rL-2*nL-1 r0r1...rL-3*nL-2 ... r0r1*n2 r0*n1 n0 n n(:) nCoef(i) * (0 : r(end - (i-1)) - 1); % 获取X(k)的倒位序k r1r2...rL-1*n0 r2r3...rL-1*n1 ... rL-2rL-1*nL-3 rL-1*rL-2 nL-1 k k(:) kCoef(i) * (0 : r(i) - 1); end r r(end : -1 : 1); % 反转r便于索引 ind reshape(n(:), r); % 每一个维度对应每个基的dft索引 indCell cell(L, 1); d (1 : L); % matlab角度的维度索引用于permute % 混合基FFT计算 Xtmp x.; for iD 1 : L % 索引每个基 % 获取当前基的dft索引转换为2维矩阵方便观察和计算 dtmp d(d ~ iD); dftInd reshape(permute(ind, [iD dtmp]), r(iD), []); indCell{iD} dftInd; % 记录 % 对每一个维度进行dft W_N exp(-1i * 2 * pi / r(iD) * (0 : r(iD) - 1) .* (0 : r(iD) - 1)); Xtmp(dftInd 1) Xtmp(dftInd 1) * W_N; % 如果当前并非最后一个基则需要点乘上旋转因子 if iD ~ L % nRepsPerMatForEach(end - (iD - 1))为当前旋转因子的N twiddleFactor exp(-1i * 2 * pi / nRepsPerMatForEach(end - (iD - 1)) * sum(nCoef(iD 1 : end) .* nArr(:, iD 1 : end), 2) .* nArr(:, iD)); Xtmp Xtmp .* twiddleFactor; end end % 整序输出 X zeros(N, 1); X(k(:) 1) Xtmp; end %% Local functions function [nCoef, kCoef] getCoef(r1r2torL) % getCoef - 获取n和k的系数也就是(n)10和(bar{n})10的系数 % 输入r1r2torL - 基行向量或列向量 % 输出nCoef - n的系数 % 输出kCoef - k的系数 n numel(r1r2torL); res cumprod(r1r2torL); res(end) []; nCoef [res(end : -1 : 1) 1]; kCoef ones(1, n); for i 2 : n res cumprod(r1r2torL(i : end)); kCoef(i - 1) res(end); end end function r1r2torL getr1r2torLStyle(factorSeq) % getr1r2torLStyle - 输出r1r2...rL形式的混合基其中r1整合了所有基2 % 输入factorSeq - 将N分解出所有的素因子 % 输出r1r2torL - r1r2...rL形式的混合基 prodRes cumprod(factorSeq(factorSeq 2)); if isempty(prodRes) r1 []; else r1 prodRes(end); end r2torL factorSeq(factorSeq ~ 2); r1r2torL [r1 r2torL]; end

相关文章:

混合基FFT,matlab实现

参考数字信号处理教程第四版(程佩青著)第四章FFT这里直接给出matlab函数,性能不保证最优注意,此函数只能处理混合基fft,即输入信号x的长度不能是素数,不能是2次幂整数function X mixedRadixFFT(x)% multiB…...

大牛直播SDK(SmartMediaKit)Windows平台多路RTSP转RTMP推流集成说明

文档概述 在安防监控、智慧园区、应急指挥、工业视觉、低空经济、无人机回传和多路摄像头上云等场景中,现场设备通常以 RTSP 方式输出视频流,而云端平台、直播分发平台或业务中台往往更倾向于接收 RTMP 流。此时,系统需要在边缘侧或 Windows…...

Keil MDK双J-Link并行调试实战指南

1. 双J-Link调试器并行使用场景解析在嵌入式开发过程中,我们经常会遇到需要同时调试多个目标板的情况。传统做法是频繁插拔调试器或使用调试器切换器,但这会显著降低开发效率。通过Keil MDK配合双J-Link调试器并行工作,可以完美解决这个痛点。…...

Poppins几何字体:如何让拉丁文与天城体在同一个视觉世界里和谐共舞?

Poppins几何字体:如何让拉丁文与天城体在同一个视觉世界里和谐共舞? 【免费下载链接】Poppins Poppins, a Devanagari Latin family for Google Fonts. 项目地址: https://gitcode.com/gh_mirrors/po/Poppins 当你的产品需要同时面向印度用户和全…...

激光辅助侧信道攻击技术解析与应用

1. 激光辅助侧信道攻击技术概述在硬件安全研究领域,侧信道分析(Side-Channel Analysis, SCA)已经发展成为破解加密系统的重要手段。这种攻击方式不直接攻击算法本身的数学强度,而是通过测量设备运行时的物理特性变化(如功耗、电磁辐射、时序等…...

工控行业IO信号Web监控平台原理及技术实现方案

本文从实际使用角度出发,意在解决行业系统中的IO信号监控痛点。一台设备的 IO 信号点动辄成百上千——从简单的门锁状态、急停按钮,到复杂的真空压力模拟量、主轴转速等。这些信号的实时监控直接关系到设备稼动率(OEE)和良品率&am…...

CTF 竞赛干货|50 个实战解题思路,收藏一篇就够用

CTF选手必藏的50个实战解题思路!一篇够用! CTF竞赛的核心逻辑 • 核心目标:快速拆解问题(Flag导向)、工具链协作、模式化思维。• 关键原则:先广度后深度(优先收集信息)、分治策略&…...

28 岁大专逆袭转行网络安全 资深前辈避坑忠告

网络安全行业 “人才缺口 300 万 、平均年薪超 25 万” 的红利,让无数职场人动了转行心思。尤其是学历普通(如大专)的群体,既面临原有岗位的天花板,又渴望通过技术转型实现薪资跃迁。但网安行业看似门槛低,…...

HarmonyOS 6学习:水平仪气泡移动方向错误的完整分析与修复方案

从"反向移动"到"精准指向":一次完整的传感器应用开发经历在HarmonyOS 6应用开发中,我最近负责开发一个建筑工具应用,其中包含一个水平仪功能。这个功能对建筑工人和DIY爱好者来说非常实用——通过手机传感器检测设备倾斜…...

HarmonyOS 6学习:动画流畅与截图性能的双重优化实战

在HarmonyOS应用开发中,用户体验的流畅性往往取决于那些看似微小的细节。今天,我将带你探索两个看似无关却都深刻影响用户体验的技术问题:文字翻转动画的延迟卡顿和长截图生成的性能瓶颈。这两个问题分别代表了动画渲染和图像处理两个关键领域…...

VideoDownloadHelper终极指南:技术开发者必备的Chrome视频下载插件

VideoDownloadHelper终极指南:技术开发者必备的Chrome视频下载插件 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper VideoDownload…...

pprint,一个漂亮打印的 Python 库!

在日常编程中,我们经常需要打印复杂的数据结构——嵌套的字典、列表、JSON 响应、配置对象等。使用普通的 print() 会将整个结构挤在一行或简单换行,导致可读性极差,尤其是在调试多层嵌套的 API 返回数据时,简直是一场灾难。pprin…...

Navicat Mac版试用期重置终极指南:3种简单方法实现永久免费使用

Navicat Mac版试用期重置终极指南:3种简单方法实现永久免费使用 【免费下载链接】navicat_reset_mac navicat mac版无限重置试用期脚本 Navicat Mac Version Unlimited Trial Reset Script 项目地址: https://gitcode.com/gh_mirrors/na/navicat_reset_mac 你…...

终极解决方案:三步彻底卸载Windows系统中顽固的Microsoft Edge浏览器

终极解决方案:三步彻底卸载Windows系统中顽固的Microsoft Edge浏览器 【免费下载链接】EdgeRemover A PowerShell script that correctly uninstalls or reinstalls Microsoft Edge on Windows 10 & 11. 项目地址: https://gitcode.com/gh_mirrors/ed/EdgeRem…...

基于SpringCloud的微服务架构技术研究

随着互联网技术与校园信息化建设的快速发展,传统单体架构系统在业务迭代、功能扩展、并发处理与后期维护方面逐渐暴露出诸多短板。单体架构将所有业务逻辑、数据接口与功能模块耦合在同一个项目中,在系统体量较小、业务需求简单的场景下能够满足开发需求…...

终极免费Flash反编译工具:5分钟学会使用JPEXS拯救你的SWF资源

终极免费Flash反编译工具:5分钟学会使用JPEXS拯救你的SWF资源 【免费下载链接】jpexs-decompiler JPEXS Free Flash Decompiler 项目地址: https://gitcode.com/gh_mirrors/jp/jpexs-decompiler 你是否曾遇到过这样的困境?多年前制作的Flash动画文…...

XUnity Auto Translator:Unity游戏自动翻译的终极完整指南

XUnity Auto Translator:Unity游戏自动翻译的终极完整指南 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator XUnity Auto Translator是一款功能强大的开源游戏翻译工具,专为Unity引擎…...

如何高效实现Android Studio中文界面革命性升级

如何高效实现Android Studio中文界面革命性升级 【免费下载链接】AndroidStudioChineseLanguagePack AndroidStudio中文插件(官方修改版本) 项目地址: https://gitcode.com/gh_mirrors/an/AndroidStudioChineseLanguagePack 你是否曾经因为Android Studio的英…...

魔兽争霸III终极优化指南:7大核心功能让经典游戏重获新生

魔兽争霸III终极优化指南:7大核心功能让经典游戏重获新生 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为《魔兽争霸III》在现代电脑…...

终极ncmdump工具完整指南:3分钟快速解密NCM格式音乐文件

终极ncmdump工具完整指南:3分钟快速解密NCM格式音乐文件 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的歌曲只能在特定播放器里播放而烦恼吗?ncmdump工具为你提供完美的解决方案&…...

Maxwell 磁芯损耗模型怎么选?Power Ferrite vs B-P Curve

🔖 开篇一句话总结 Power Ferrite:用斯坦梅茨公式算损耗,简单高效,适合标准铁氧体材料快速估算。 B-P Curve:直接用实测数据点插值,精度更高,适合非标准材料或追求极致仿真的场景。 一、底层逻辑有什么不一样? 🔹 Power Ferrite:公式拟合的 “标准模板” 它基于经…...

如何用Python快速接入Taotoken调用多模型API完成开发任务

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 如何用Python快速接入Taotoken调用多模型API完成开发任务 对于开发者而言,快速验证想法、构建原型是开发流程中的关键环…...

如何高效使用开源视频下载插件:专业用户的终极指南

如何高效使用开源视频下载插件:专业用户的终极指南 【免费下载链接】VideoDownloadHelper Chrome Extension to Help Download Video for Some Video Sites. 项目地址: https://gitcode.com/gh_mirrors/vi/VideoDownloadHelper VideoDownloadHelper是一款专为…...

抖音下载神器:如何免费批量下载无水印视频、音乐和图片

抖音下载神器:如何免费批量下载无水印视频、音乐和图片 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback supp…...

Windows和Office智能激活工具KMS_VL_ALL_AIO:一站式解决方案指南

Windows和Office智能激活工具KMS_VL_ALL_AIO:一站式解决方案指南 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统激活和Office软件授权而烦恼吗?KMS_VL…...

【笔试强训】Week5:空调遥控, kotor和气球,走迷宫,主持人调度II,体操队形,二叉树的最大路径和,排序子序列,消减整数

文章目录1. 空调遥控题目描述解题思路解法一:滑动窗口解法二:二分查找代码实现2. kotori和气球题目描述解题思路代码实现3. 走迷宫题目描述解题思路代码实现4. 主持人调度II题目描述解题思路代码实现5. 体操队形题目描述解题思路代码实现6. 二叉树的最大…...

抖音批量下载神器:免费开源工具终极指南,轻松保存高清视频与音乐

抖音批量下载神器:免费开源工具终极指南,轻松保存高清视频与音乐 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and b…...

Office RibbonX Editor:免费开源Office界面定制终极解决方案

Office RibbonX Editor:免费开源Office界面定制终极解决方案 【免费下载链接】office-ribbonx-editor An overhauled fork of the original Custom UI Editor for Microsoft Office, built with WPF 项目地址: https://gitcode.com/gh_mirrors/of/office-ribbonx-…...

免费开源神器:SMUDebugTool让你轻松掌控AMD Ryzen处理器的秘密

免费开源神器:SMUDebugTool让你轻松掌控AMD Ryzen处理器的秘密 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: ht…...

Maya glTF插件完整教程:从安装到Web 3D模型转换的终极指南

Maya glTF插件完整教程:从安装到Web 3D模型转换的终极指南 【免费下载链接】maya-glTF glTF 2.0 exporter for Autodesk Maya 项目地址: https://gitcode.com/gh_mirrors/ma/maya-glTF 你是否正在寻找将Maya中的3D模型转换为现代Web应用所需格式的解决方案&a…...