gpt4 book ai didi

python - FFT显示频谱中的(正弦)正弦波

转载 作者:行者123 更新时间:2023-12-03 02:12:40 29 4
gpt4 key购买 nike

我不知道这是编程还是数学问题,但我整理了一些FFT的简短示例。我加载了440hz的波并在顶部添加了一些正弦波,但是由于某种原因,频谱中存在一个我不理解的“波”。
据我了解,频谱应该具有相同的| Y(freq)|所有频率的值。

from pylab import plot, show, xlabel, ylabel, subplot
from scipy import fft, arange
from numpy import linspace, array
# from scipy.io.wavfile import read,write
import scikits.audiolab as audio
import math

def plotSpectru(y,Fs):
n = len(y) # lungime semnal
k = arange(n)
T = n/Fs
frq = k/T # two sides frequency range
frq = frq[range(n/2)] # one side frequency range

Y = fft(y)/n # fft computing and normalization
Y = Y[range(n/2)]

plot(frq,abs(Y),'r') # plotting the spectrum
xlabel('Freq (Hz)')
ylabel('|Y(freq)|')

Fs = 44100; # sampling rate

# (data, rate, bits) = audio.wavread('440Hz_44100Hz_16bit_05sec.wav')
(data, rate, bits) = audio.wavread('250Hz_44100Hz_16bit_05sec.wav')

for n in xrange(0,4*120, 4):
n=n/40.
data = array([x+math.sin(n*idx) for idx,x in enumerate(data)])

y=data[:]
lungime=len(y)
timp=len(y)/44100.
t=linspace(0,timp,len(y))

subplot(2,1,1)
plot(t,y, color="green")
xlabel('Time')
ylabel('Amplitude')
subplot(2,1,2)
plotSpectru(y,Fs)
show()

最佳答案

我不完全了解您要如何计算正弦波?这是一个小示例,如何使用numpy添加正弦波。

duration = len(data)/float(rate)
t = np.linspace(0, len(data), rate*duration)
sinewave = np.sin(2*np.pi*440*t)

data += sinewave

编辑

抱歉,我转发了您的问题,并确认我的答案与您的问题不符。
即使您真的添加了所有正频率(由fft分析),也不会获得统一的| Y(freq)|。
duration = len(data)/float(rate)
t = np.linspace(0, len(data), rate*duration)
allfreqs = np.fft.fftfreq(len(data), 1.0/rate)

for f in allfreqs[:len(allfreqs)/2]:
data += np.sin(2*np.pi*f*t)

据我了解,这是由于干扰。如果添加这么多的正弦波,则有可能会变得更弱,有些会变得更强。

如果为每个波分配一个随机相位,情况将有所不同:
duration = len(data)/float(rate)
t = np.linspace(0, len(data), rate*duration)
allfreqs = np.fft.fftfreq(len(data), 1.0/rate)

for f in allfreqs[:len(allfreqs)/2]:
data += np.sin(2*np.pi*f*t + np.random.rand()*np.pi)

关于python - FFT显示频谱中的(正弦)正弦波,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22750851/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com