确定接收到声音时的样本号或点

2024-05-16 01:12:32 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个wav文件,其中包含一个录音chirp声音。你知道吗

频率采样44100 通道数1 完整取样N 90405 第2.05节 啁啾声只有50毫秒

啁啾的图像: [https://i.imgur.com/Hr4u5tx.jpg][1]

代码我到目前为止已经阅读了wav文件并进行了一些基本的处理。你知道吗

fs_rate, signal = wavfile.read("chirp.wav")
print ("Frequency sampling", fs_rate)
l_audio = len(signal.shape)
print ("Channels", l_audio)
if l_audio == 2:
    signal = signal.sum(axis=1) / 2
N = signal.shape[0]
print ("Complete Samplings N", N)
secs = N / float(fs_rate)
print ("secs", secs)
Ts = 1.0/fs_rate # sampling interval in time
print ("Timestep between samples Ts", Ts)
t = scipy.arange(0, secs, Ts) # time vector as scipy arange field / numpy.ndarray
FFT = abs(scipy.fft(signal))
FFT_side = FFT[range(N//2)] # one side FFT range
freqs = scipy.fftpack.fftfreq(signal.size, t[1]-t[0])
fft_freqs = np.array(freqs)
freqs_side = freqs[range(N//2)] # one side frequency range
fft_freqs_side = np.array(freqs_side)
plt.subplot(311)
p1 = plt.plot(t, signal, "g") # plotting the signal
plt.xlabel('Time')
plt.ylabel('Amplitude')
plt.savefig('chirp.jpg')

问题: 使用python如何判断chirp的第一个采样点在音频文件中的位置。 接收到啁啾的第一个点。你知道吗

信号含有背景噪声。我期待的结果 应该说这是你的啁啾信号开始的地方,它的频率是2kHz。你知道吗

附言:这不是家庭作业问题。我正在学习DSP。有点自学。你知道吗


Tags: fftsignalraterangepltscipyfsaudio
1条回答
网友
1楼 · 发布于 2024-05-16 01:12:32

如果你知道啁啾序列,你就可以把它关联起来,得到流中啁啾的开始。你知道吗

import scipy.signal as sig
h = sp.array(chirp_sequence)
rxy = sig.correlate(signal, h)
start_idx = arg.max(abs(rxy))

相关问题 更多 >