采样率和 wav 数据包含不同的维度

Sample rate and wav data contains different dimensions

我正在尝试读取 Python 中的 wav 文件。我是一个 25MB 的文件,当我使用 wavfile.read 读取并获得 sample_ratedata 它们具有以下尺寸:

files[:1][0] 是 .wav 文件。

sample_rate, samples = wavfile.read(files[:1][0])
print(sample_rate)
print(len(samples))
print(samples)

48000
14466512
[157 150 141 ...,  33  37  42]

现在我想输出它的波形图和频谱图,我正在使用以下代码来实现:

freqs, times, spectrogram = log_specgram(samples, sample_rate)

fig = plt.figure(figsize=(14,8))
ax1 = fig.add_subplot(211)
ax1.set_title('Raw wave of ' + files[:1][0])
ax1.set_ylabel('Amplitude')
ax1.plot(np.linspace(0, sample_rate/len(samples), sample_rate), samples)

ax2 = fig.add_subplot(212)
ax2.imshow(spectrogram.T, aspect='auto', origin='lower', 
           extent=[times.min(), times.max(), freqs.min(), freqs.max()])
ax2.set_yticks(freqs[::16])
ax2.set_xticks(times[::16])
ax2.set_title('Spectrogram of ' + files[:1][0])
ax2.set_ylabel('Freqs in Hz')
ax2.set_xlabel('Seconds')

但是,我收到以下错误:

ValueError: x and y must have same first dimension, but have shapes (48000,) and (14466512,)

有什么解决办法吗?

替换

ax1.plot(np.linspace(0, sample_rate/len(samples), sample_rate), samples)

ax1.plot(np.linspace(0, len(samples)/sample_rate, len(samples)), samples)

采样率是每秒采样多少次。如果您尝试绘制所有样本,则 x 值的数量应该是样本数,而不是每秒样本数。

对于第二个更改,我假设您正在尝试在几秒钟内完成 x 轴。每秒 samples/number 个样本数将为您提供秒数,而不是相反。