码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数学笔记;离散傅里叶变化 DFT


    1 原理介绍 

    • 离散傅里叶变化是连续傅里叶变化在如下信号下的等价形式:
      • N个样本
      • 每个样本的采样间隔是T
    • 令f(t)是数据源的持续信号,将N个样本表示成f[0],f[1],f[2],.....f[k],....f[N-1]
      • ——>原始数据源信号f(t)的傅里叶变换,应该是

       

    • 因为信号脉冲仅在样本点采集,所以可以如下近似:

     

    • 这里,DFT假设波形是周期性的(周期正好是T个interval的跨度)
      • 也就是这里我们是从0到N-1采样的f(0)到f(N-1),和从N到2N-1采样得到的f(N)到f(2N-1)是一样的
      • 比如我们采样了10个点(0~10),那么DFT会隐式地人为周期就是10

       

    • 所以上式中的ω被表示为:

    • 所以离散傅里叶级数可以表示为:

       

    • 上式可以被重写成: 

     1.1 欧拉公式 (复习)

     

     

     2 举例

    令连续信号为:f[k]=5+2cos(\frac{\pi}{2}k-90^\cdot)+3cos(4\pi t)

    采样k=0~k=3 四个点,得到f[0]=8,f[1]=4,f[2]=8,f[3]=0

    于是 

    可以写成:

    F[n]=\sum_{k=0}^3 f[k] e^{-j \frac{2\pi}{4}kn}=\sum_{k=0}^3 f[k] (-j)^{kn}

    用矩阵的形式,可以写成

    \begin{bmatrix} F[0]]\\ F[1]\\ F[2]\\ F[3] \end{bmatrix} =\begin{bmatrix} 1 & 1 & 1 & 1\\ (-j)^0 &(-j)^1 &(-j)^2 &(-j)^3 \\ [(-j)^2]^0 & [(-j)^2]^1 & [(-j)^2]^2 & [(-j)^2]^3 \\ [(-j)^3]^0 & [(-j)^3]^1 & [(-j)^3]^2 & [(-j)^3]^3 \end{bmatrix} \begin{bmatrix} f[0]\\ f[1]\\ f[2]\\ f[3] \end{bmatrix}

                  =\begin{bmatrix} 1 & 1 & 1 & 1\\ 1 & -j & -1 & j \\ 1 & -1 & 1 & -1 \\ 1 & j & -1 & -j \end{bmatrix} \begin{bmatrix} 8\\ 4\\ 8\\ 0\end{bmatrix} =\begin{bmatrix} 20\\ -4j\\ 12\\ 4j \end{bmatrix}

                  

    4 逆傅里叶变化 

    的逆傅里叶变化是:

     

     如果这里令W=exp(j2\pi/N)的话,那么逆傅里叶变化的矩阵形式为

     4.1 举例

    还是用前面一个例子

    已知F[0]=20,F[1]=-4j,F[2]=12,F[3]=4j

    希望得到:f[0]=8,f[1]=4,f[2]=8,f[3]=0

    \begin{bmatrix} f[0]]\\ f[1]\\ f[2]\\ f[3] \end{bmatrix} =\frac{1}{4}\begin{bmatrix} 1 & 1 & 1 & 1\\ (j)^0 &(j)^1 &(j)^2 &(j)^3 \\ [(j)^2]^0 & [(j)^2]^1 & [(j)^2]^2 & [(j)^2]^3 \\ [(j)^3]^0 & [(j)^3]^1 & [(j)^3]^2 & [(j)^3]^3 \end{bmatrix} \begin{bmatrix} F[0]\\ F[1]\\ F[2]\\ F[3] \end{bmatrix}

    =\frac{1}{4}\begin{bmatrix} 1 & 1 & 1 & 1\\ 1 & j & -1 & -j \\ 1 & -1 & 1 & -1 \\ 1 & -j & -1 & j \end{bmatrix} \begin{bmatrix} 20\\ -4j\\ 12\\ 4j\end{bmatrix} =\begin{bmatrix} 8\\ 4\\ 8\\ 0 \end{bmatrix}

  • 相关阅读:
    Java面试题总结(三)
    C语言入门(二)运算符和表达式
    那些年印象深刻的面试
    《大厂面试》之JVM篇21问与答
    PMP项目管理实战 | 项目经理如何做好会议管理?
    解析 Python requests 库 POST 请求中的参数顺序问题
    go传统的同步机制
    数据集市简介
    Python 中的 DNS 查找
    inet_ntop4源代码实现
  • 原文地址:https://blog.csdn.net/qq_40206371/article/details/126772853
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号