离散傅里叶变换公式推导

离散傅里叶变换公式推导离散傅里叶变换公式推导先抛变换公式:Fm=∑n=0N−1fne−2πimn/N↔fn=1N∑m=0N−1Fme2πimn/NF_m=\sum_{n=0}^{N-1}f_ne^{-2\piimn/N}\leftrightarrowf_n=\frac{1}{N}\sum_{m=0}^{N-1}F_me^{2\piimn/N}Fm​=n=0∑N−1​fn​e−2πimn/N↔fn​=N1​m=0∑N−1​Fm​e2πimn/N式中的N是数据点个数讲道理一开始完全看不懂公式这么来的,一顿百度后我学

大家好,又见面了,我是你们的朋友全栈君。

离散傅里叶变换公式推导

先抛变换公式:
F m = ∑ n = 0 N − 1 f n e − 2 π i m n / N ↔ f n = 1 N ∑ m = 0 N − 1 F m e 2 π i m n / N F_m=\sum_{n=0}^{N-1}f_ne^{-2\pi imn/N}\leftrightarrow f_n=\frac{1}{N}\sum_{m=0}^{N-1}F_me^{2\pi imn/N} Fm=n=0N1fne2πimn/Nfn=N1m=0N1Fme2πimn/N
式中的N是数据点个数
讲道理一开始完全看不懂公式这么来的,一顿百度后我学到了很多,但就是没学到怎么推公式。好吧只能自己推。
先来看一下DFT的物理意义:DFT示意图
(图我网上随便下的)
离散傅里叶变换是把周期性离散信号变换到频域上,大家知道,周期信号变到频域上是离散的。离散就是在个别点 { x n } \{x_n\} {
xn}
有值。我是学物理的,物理里面离散的可以这么表示:
f ( x ) = ∑ n = 0 N − 1 f n δ ( x − x n ) f(x)=\sum_{n=0}^{N-1}f_n\delta(x-x_n) f(x)=n=0N1fnδ(xxn)
δ ( x ) \delta(x) δ(x)是个在 x = 0 x=0 x=0处无穷大,其余位置为0且全空间积分为1的函数 ∫ − ∞ ∞ δ ( x ) d x = 1 \int_{-\infty}^{\infty}\delta(x)dx=1 δ(x)dx=1

周期性信号变到频域上,那不就是傅里叶级数吗。自然有公式
F m = ∫ − T T ∑ n = 0 N − 1 f n δ ( x − x n ) e − i x k m d x = ∑ n = 0 N − 1 ∫ f n δ ( x − x n ) e − i x k m d x = ∑ n = 0 N − 1 f n e − i x n k m \begin{aligned} F_m &= \int_{-T}^{T}\sum_{n=0}^{N-1}f_n\delta(x-x_n)e^{-ixk_m}dx \\&=\sum_{n=0}^{N-1}\int f_n\delta(x-x_n)e^{-ixk_m}dx \\&=\sum_{n=0}^{N-1}f_ne^{-ix_nk_m} \end{aligned} Fm=TTn=0N1fnδ(xxn)eixkmdx=n=0N1fnδ(xxn)eixkmdx=n=0N1fneixnkm
接下来我们假设 d x , d k dx,dk dx,dk分别是 { x n } \{x_n\} {
xn}
, { k n } \{k_n\} {
kn}
的间距,那么:
x n = n d x , k m = m d k x_n=ndx,\qquad k_m = mdk xn=ndx,km=mdk
代入上式:
F m = ∑ n = 0 N − 1 f n e − i x n k m = ∑ n = 0 N − 1 f n e − i m n d x d k \begin{aligned} F_m &=\sum_{n=0}^{N-1}f_ne^{-ix_nk_m} \\&=\sum_{n=0}^{N-1}f_ne^{-imndxdk} \end{aligned} Fm=n=0N1fneixnkm=n=0N1fneimndxdk
是不是和最上面的式子很接近了?还差最后一步,确定 d x d k dxdk dxdk的值。
下面我懒得写了,只说一下做法吧

  1. 先写出 F m F_m Fm f n f_n fn的逆变换,
    f n = c ∑ n = 0 N − 1 F m e i m n d x d k f_n = c\sum_{n=0}^{N-1}F_me^{imndxdk} fn=cn=0N1Fmeimndxdk
    c c c是个系数,之后应该能计算出是 1 / N 1/N 1/N
  2. 把上面的 F m F_m Fm表达式带进去,就能得到用 f n ′ f_{n’} fn求和表达的 f n f_n fn,这要求 d x d k dxdk dxdk满足一定关系,其实就是满足 d x d k = 2 π N dxdk = \frac{2\pi}{N} dxdk=N2π
  3. 最后把公式里的 d x d k dxdk dxdk替换就完事了

这个公式推导倒是不难,主要问题是理解不要出现偏差。所谓离散傅里叶变换是把周期离散信号变换到周期离散频谱,这是真的离散信号。一开始我以为是连续信号在某些给定点采样得到的值呢(没有学过信号相关的内容,在计算物理中遇到了这个离散傅里叶变换)。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/160837.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 【Java】一篇文章带你了解String、StringBuffer和StringBuilder的区别

    【Java】一篇文章带你了解String、StringBuffer和StringBuilder的区别String:字符串常量StringBuffer:字符串变量(多线程情况下使用,保护线程安全)synchronized:保护线程安全的StringBuilder:字符串变量(单线程情况下使用)String、StringBuffer、StringBuilder的主要区别:1.String类的内容不可以修改,而StringBuffer和StringBuilder的内容可以修改;2.StringBuffer和StringBuilder的大部分功能都是相似的;3.StringBu..

  • 在同一台电脑上同时安装Python2和Python3

    在同一台电脑上同时安装Python2和Python3

    2021年10月16日
  • Linux 修改文件权限

    Linux 修改文件权限目录:1、介绍:2、权限说明3、用户4、权限设置5、权限设置格式:(1)增加权限:(2)撤销权限(3)无任何权限1、介绍:​ Linux系统中,每个文件或目录都有访问许可权限,用它来确定以何种方式对文件或目录进行访问和操作。在Linux中,如果要对文件的权限进行修改,那么可在终端中使用chmod命令对其文件的权限进行修改,但是chmod命令修改文件权限有两种方式:1、字母法,2、数字法2、权限说明​ (1)只读:表示只允许读取内容,而禁止其对该文件做其他任何操作​ 字母法:‘r’

  • 跨境电商erp源码java大卖先生_erp 开源

    跨境电商erp源码java大卖先生_erp 开源1订单管理本模块支持多平台订单自动下载同步以及多帐号多店铺订单管理,方便用户对销售进行科学、直观的分类管理。包括订单处理,包装验货,称重出库,智能交运,交运日志,快速拣货,快速发货等子模块。2商品管理(SKU)商品管理模块,提供对亚马逊店逊商品进行线下管理的功能,包括但不限于中文名称、英文名称,售价等相应管理3.采购管理采购管理主要对于商品采购、入库、及供应商的设置,并于商品细分,包括采购管理、入库管理和供应商管理模块。4.物流管理此模块主要提供用户设置速…

  • selenium python面试题_selenium面试题

    selenium python面试题_selenium面试题selenium中如何判断元素是否存在?selenium中没有提供原生的方法判断元素是否存在,一般我们可以通过定位元素+异常捕获的方式判断。#判断元素是否存在try:dr.find_element_by_id(‘none’)exceptNoSuchElementException:print’elementdoesnotexist’selenium中hidden或者是display=…

  • laravel5.*安装使用Redis以及解决Class ‘Predis\Client’ not found和Fatal error: Non-static method Redis::set() c…

    laravel5.*安装使用Redis以及解决Class ‘Predis\Client’ not found和Fatal error: Non-static method Redis::set() c…

    2021年10月22日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号