傅里叶变换

李永乐老师讲解

讲解视频
傅里叶变换_第1张图片
傅里叶变换_第2张图片
振幅、频率
傅里叶变换_第3张图片
相位
傅里叶变换_第4张图片
傅里叶变换_第5张图片
傅里叶变换_第6张图片
傅里叶变换_第7张图片
傅里叶变换_第8张图片
傅里叶变换_第9张图片
傅里叶变换_第10张图片

傅里叶级数

傅里叶变换_第11张图片
傅里叶变换_第12张图片
因为一组标准正交基中向量自己和自己做内积为1,和其他向量做内积为0。
所以 q 1 ∗ v q_1*v q1v相当于 q 1 ∗ q 1 = 1 , q 1 ∗ q i = 0 , i ! = 1 q_1*q_1=1,q_1*q_i=0,i!=1 q1q1=1,q1qi=0,i!=1

傅里叶变换_第13张图片
傅里叶变换_第14张图片
傅里叶变换_第15张图片
傅里叶变换_第16张图片

傅里叶变换(FT)

傅里叶变换_第17张图片
傅里叶变换_第18张图片
傅里叶变换_第19张图片
傅里叶变换_第20张图片
傅里叶变换_第21张图片
傅里叶变换_第22张图片
傅里叶变换_第23张图片
傅里叶变换_第24张图片
傅里叶变换_第25张图片
傅里叶变换_第26张图片
傅里叶变换_第27张图片

离散时间傅里叶变换(DTFT)

傅里叶变换_第28张图片
傅里叶变换_第29张图片
傅里叶变换_第30张图片
傅里叶变换_第31张图片

离散傅里叶变换(DFT)

傅里叶变换_第32张图片
傅里叶变换_第33张图片
傅里叶变换_第34张图片
傅里叶变换_第35张图片
同时,离散周期傅里叶变换后,计算出来的是一个复数形式,即用正弦和余弦组合的形式近似表示原始信号,所以幅值应该是两者的组合, A s i n 2 + A c o s 2 \sqrt{A_{sin^2} + A_{cos^2}} Asin2+Acos2
傅里叶变换_第36张图片
傅里叶变换_第37张图片
傅里叶变换_第38张图片

实验验证

傅里叶变换_第39张图片

#! /usr/bin/python3
# -*- encoding:utf-8 -*-

import matplotlib.pyplot as plt
from matplotlib.pylab import mpl
import numpy as np
from numpy import pi, cos, sin

# 中文显示问题
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

def test2():
    '''
    离散傅里叶变换
    一维时序信号y,它由2V的直流分量(0Hz),和振幅为3V,频率为50Hz的交流信号,以及振幅为1.5V,频率为75Hz的交流信号组成:
    y = 2 + 3*np.cos(2*np.pi*50*t) + 1.5*np.cos(2*np.pi*75*t)
    然后我们采用256Hz的采样频率,总共采样256个点。
    '''
    fs = 256  # 采样频率, 要大于信号频率的两倍
    t = np.arange(0, 1, 1.0 / fs)  # 1秒采样fs个点
    N = len(t)
    freq = np.arange(N)  # 频率counter

    # x = 2 + 3 * cos(2 * pi * 50 * t) + 1.5 * cos(2 * pi * 75 * t)  # 离散化后的x[n]
    x = 2 + 3 * cos(2 * pi * 10 * t) + 1.5 * cos(2 * pi * 15 * t)  # 离散化后的x[n]

    X = np.fft.fft(x)  # 离散傅里叶变换

    '''
    根据STFT公式原理,实现的STFT计算,做了/N的标准化
    '''
    X2 = np.zeros(N, dtype=np.complex)  # X[n]
    for k in range(0, N):  # 0,1,2,...,N-1
        for n in range(0, N):  # 0,1,2,...,N-1
            # X[k] = X[k] + x[n] * np.exp(-2j * pi * k * n / N)
            X2[k] = X2[k] + (1 / N) * x[n] * np.exp(-2j * pi * k * n / N)

    fig, ax = plt.subplots(5, 1, figsize=(12, 12))

    # 绘制原始时域图像
    ax[0].plot(t, x, label='原始时域信号')
    ax[0].set_xlabel('Time (s)')
    ax[0].set_ylabel('Amplitude')

    ax[1].plot(freq, abs(X), 'r', label='调用np.fft库计算结果')
    ax[1].set_xlabel('Freq (Hz)')
    ax[1].set_ylabel('Amplitude')
    ax[1].legend()

    ax[2].plot(freq, abs(X2), 'r', label='根据STFT计算结果')
    ax[2].set_xlabel('Freq (Hz)')
    ax[2].set_ylabel('Amplitude')
    ax[2].legend()

    X_norm = X / (N / 2)  # 换算成实际的振幅
    X_norm[0] = X_norm[0] / 2
    ax[3].plot(freq, abs(X_norm), 'r', label='转换为原始信号振幅')
    ax[3].set_xlabel('Freq (Hz)')
    ax[3].set_ylabel('Amplitude')
    ax[3].set_yticks(np.arange(0, 3))
    ax[3].legend()

    freq_half = freq[range(int(N / 2))]  # 前一半频率
    X_half = X_norm[range(int(N / 2))]

    ax[4].plot(freq_half, abs(X_half), 'b', label='前N/2个频率')
    ax[4].set_xlabel('Freq (Hz)')
    ax[4].set_ylabel('Amplitude')
    ax[4].set_yticks(np.arange(0, 3))
    ax[4].legend()

    plt.show()

test2()

傅里叶变换_第40张图片

快速傅里叶变换

傅里叶变换_第41张图片
傅里叶变换_第42张图片
傅里叶变换_第43张图片
傅里叶变换_第44张图片
傅里叶变换_第45张图片
傅里叶变换_第46张图片
傅里叶变换_第47张图片
在这里插入图片描述
傅里叶变换_第48张图片
傅里叶变换_第49张图片
傅里叶变换_第50张图片
傅里叶变换_第51张图片
傅里叶变换_第52张图片
傅里叶变换_第53张图片

你可能感兴趣的:(人工智能,算法,python)