欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

信號生成及DFT的python實現(xiàn)方式

 更新時間:2020年02月25日 13:02:28   作者:芥末的無奈  
今天小編就為大家分享一篇信號生成及DFT的python實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

DFT

DFT(Discrete Fourier Transform),離散傅里葉變化,可以將離散信號變換到頻域,它的公式非常簡單:

離散頻率下標為k時的頻率大小

離散時域信號序列

信號序列的長度,也就是采樣的個數(shù)

如果你剛接觸DFT,并且之前沒有信號處理的相關經(jīng)驗,那么第一次看到這個公式,你可能有一些疑惑,為什么這個公式就能進行時域與頻域之間的轉換呢?

這里,我不打算去解釋它,因為我水平有限,說的不清楚。相反,在這里我想介紹,作為一個程序員,如何如實現(xiàn)DFT

從矩陣的角度看DFT

DFT的公式,雖然簡單,但是理解起來比較麻煩,我發(fā)現(xiàn)如果用矩陣相乘的角度來理解上面的公式,就會非常簡單,直接上矩陣:

OK,通過上面的表示,我們很容易將DFT理解成為一種矩陣相乘的操作,這對于我們編碼是很容易的。

Talk is cheap, show me the code

根據(jù)上面的理解,我們只需要構建出S SS矩陣,然后做矩陣相乘,就等得到DFT的結果

在這之前,我們先介紹如何生成正弦信號,以及如何用scipy中的fft模塊進行DFT操作,以驗證我們的結果是否正確

正弦信號

A: 幅度

f: 信號頻率

n: 時間下標

T: 采樣間隔, 等于 1/fs,fs為采樣頻率

ϕ \phiϕ: 相位

下面介紹如何生成正弦信號

import numpy as np
import matplotlib.pyplot as plt

%matplotlib inline
def generate_sinusoid(N, A, f0, fs, phi):
 '''
 N(int) : number of samples
 A(float) : amplitude
 f0(float): frequency in Hz
 fs(float): sample rate
 phi(float): initial phase
 
 return 
 x (numpy array): sinusoid signal which lenght is M
 '''
 
 T = 1/fs
 n = np.arange(N) # [0,1,..., N-1]
 x = A * np.cos( 2*f0*np.pi*n*T + phi )
 
 return x

N = 511
A = 0.8
f0 = 440
fs = 44100
phi = 0

x = generate_sinusoid(N, A, f0, fs, phi)

plt.plot(x)
plt.show()

# 另一種生成正弦信號的方法,生成時長為t的序列
def generate_sinusoid_2(t, A, f0, fs, phi):
 '''
 t (float) : 生成序列的時長
 A (float) : amplitude
 f0 (float) : frequency
 fs (float) : sample rate
 phi(float) : initial phase
 
 returns
 x (numpy array): sinusoid signal sequence
 '''
 
 T = 1.0/fs
 N = t / T
 
 return generate_sinusoid(N, A, f0, fs, phi)

A = 1.0
f0 = 440
fs = 44100
phi = 0
t = 0.02

x = generate_sinusoid_2(t, A, f0, fs, phi)

n = np.arange(0, 0.02, 1/fs)
plt.plot(n, x)

Scipy FFT

介紹如何Scipy的FFT模塊計算DFT

注意,理論上輸入信號的長度必須是才能做FFT,而scipy中FFT卻沒有這樣的限制

這是因為當長度不等于時,scipy fft默認做DFT

from scipy.fftpack import fft

# generate sinusoid
N = 511
A = 0.8
f0 = 440
fs = 44100
phi = 1.0
x = generate_sinusoid(N, A, f0, fs, phi)

# fft is
X = fft(x)
mX = np.abs(X) # magnitude
pX = np.angle(X) # phase

# plot the magnitude and phase
plt.subplot(2,1,1)
plt.plot(mX)

plt.subplot(2,1,2)
plt.plot(pX)
plt.show()

自己實現(xiàn)DFT

自己實現(xiàn)DFT的關鍵就是構造出S,有兩種方式:

def generate_complex_sinusoid(k, N):
 '''
 k (int): frequency index
 N (int): length of complex sinusoid in samples
 
 returns
 c_sin (numpy array): the generated complex sinusoid (length N)
 '''
 
 n = np.arange(N)
 
 c_sin = np.exp(1j * 2 * np.pi * k * n / N)
 
 return np.conjugate(c_sin)

def generate_complex_sinusoid_matrix(N):
 '''
 N (int): length of complex sinusoid in samples
 
 returns
 c_sin_matrix (numpy array): the generated complex sinusoid (length N)
 '''
 
 n = np.arange(N)
 n = np.expand_dims(n, axis=1)  # 擴充維度,將1D向量,轉為2D矩陣,方便后面的矩陣相乘
 
 k = n
 
 m = n.T * k / N     # [N,1] * [1, N] = [N,N]
 
 S = np.exp(1j * 2 * np.pi * m)  # 計算矩陣 S
 
 return np.conjugate(S)
# 生成信號,用于測試
N = 511
A = 0.8
f0 = 440
fs = 44100
phi = 1.0
x = generate_sinusoid(N, A, f0, fs, phi)

# 第一種方式計算DFT
X_1 = np.array([])
for k in range(N):
 s = generate_complex_sinusoid(k, N)
 X_1 = np.append(X_1, np.sum(x * s))
 
mX = np.abs(X_1)
pX = np.angle(X_1)

# plot the magnitude and phase
plt.subplot(2,1,1)
plt.plot(mX)

plt.subplot(2,1,2)
plt.plot(pX)
plt.show()

# 結果和scipy的結果基本相同

# 第二種方法計算DFT
S = generate_complex_sinusoid_matrix(N)
X_2 = np.dot(S, x)

mX = np.abs(X_2)
pX = np.angle(X_2)

# plot the magnitude and phase
plt.subplot(2,1,1)
plt.plot(mX)

plt.subplot(2,1,2)
plt.plot(pX)
plt.show()

總結

回顧了DFT的計算公式,并嘗試用矩陣相乘的角度來理解DFT

介紹了兩種生成正弦信號的方法

實現(xiàn)了兩種DFT的計算方法

完整代碼在這里

以上這篇信號生成及DFT的python實現(xiàn)方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Python棧算法的實現(xiàn)與簡單應用示例

    Python棧算法的實現(xiàn)與簡單應用示例

    這篇文章主要介紹了Python棧算法的實現(xiàn)與簡單應用,簡單講述了棧的原理并結合實例形式給出了基于棧實現(xiàn)的進制轉換與括號匹配等相關使用技巧,需要的朋友可以參考下
    2017-11-11
  • python網(wǎng)絡編程調(diào)用recv函數(shù)完整接收數(shù)據(jù)的三種方法

    python網(wǎng)絡編程調(diào)用recv函數(shù)完整接收數(shù)據(jù)的三種方法

    本文主要介紹了python網(wǎng)絡編程調(diào)用recv函數(shù)完整接收數(shù)據(jù)的三種方法。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • Python logging模塊寫入中文出現(xiàn)亂碼

    Python logging模塊寫入中文出現(xiàn)亂碼

    這篇文章主要介紹了Python logging模塊寫入中文出現(xiàn)亂碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • python三大器之裝飾器詳解

    python三大器之裝飾器詳解

    這篇文章主要介紹了Python中的裝飾器,涉及到Python中很多重要的特性,小編覺得這篇文章寫的還不錯,需要的朋友可以參考下
    2021-10-10
  • 深入理解?python?虛擬機

    深入理解?python?虛擬機

    這篇文章主要介紹了深入理解?python?虛擬機的相關資料,需要的朋友可以參考下
    2023-04-04
  • python中fastapi設置查詢參數(shù)可選或必選

    python中fastapi設置查詢參數(shù)可選或必選

    這篇文章主要介紹了python中fastapi設置查詢參數(shù)可選或必選,文圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值需要的小伙伴可以參考一下
    2022-06-06
  • Python區(qū)塊鏈客戶端類開發(fā)教程

    Python區(qū)塊鏈客戶端類開發(fā)教程

    這篇文章主要為大家介紹了Python區(qū)塊鏈客戶端類開發(fā)教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Django實現(xiàn)WebSocket在線聊天室功能(channels庫)

    Django實現(xiàn)WebSocket在線聊天室功能(channels庫)

    本文基于channels庫Django實現(xiàn)WebSocket在線聊天室功能,包括安裝及創(chuàng)建django項目的全過程,通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • 無懼面試,帶你搞懂python 裝飾器

    無懼面試,帶你搞懂python 裝飾器

    這篇文章主要介紹了python 裝飾器的相關資料,幫助大家更好的理解和學習python,感興趣的朋友可以了解下
    2020-08-08
  • python中concurrent.futures的具體使用

    python中concurrent.futures的具體使用

    concurrent.futures是Python標準庫的一部分,提供了ThreadPoolExecutor和ProcessPoolExecutor兩種執(zhí)行器,用于管理線程池和進程池,通過這些執(zhí)行器,可以簡化多線程和多進程任務的管理,提高程序執(zhí)行效率
    2024-09-09

最新評論