【问题标题】:Pyaudio : Playback Error: 4Pyaudio:播放错误:4
【发布时间】:2016-03-25 00:30:58
【问题描述】:

您好,我正在使用 pyaudio 构建一个应用程序,用于实时记录和播放音频,为音频信号添加低通滤波器。 当我尝试运行此代码时,会出现以下错误:

Pyaudio:播放错误:4

from pyaudio import PyAudio, paContinue, paFloat32
from time import sleep
from numpy import array, random, arange, float32, float64, zeros
import sounddevice as sd

fs            = 44100   # Hz
threshold     = 0.8     # absolute gain
delay         = 40      # samples
signal_length = 1      # second
release_coeff = 0.5555  # release time factor
attack_coeff  = 0.5     # attack time factor
dtype         = float32 # default data type
block_length  = 1024    # samples


class Limiter:
   def __init__(self, attack_coeff, release_coeff, delay, dtype=float32):
    self.delay_index = 0
    self.envelope = 0
    self.gain = 1
    self.delay = delay
    self.delay_line = zeros(delay, dtype=dtype)
    self.release_coeff = release_coeff
    self.attack_coeff = attack_coeff

def limit(self, signal, threshold):
    for i in arange(len(signal)):
        self.delay_line[self.delay_index] = signal[i]
        self.delay_index = (self.delay_index + 1) % self.delay

        # calculate an envelope of the signal
        self.envelope *= self.release_coeff
        self.envelope  = max(abs(signal[i]), self.envelope)

        # have self.gain go towards a desired limiter gain
        if self.envelope > threshold:
            target_gain = (1+threshold-self.envelope)
        else:
            target_gain = 1.0
        self.gain = ( self.gain*self.attack_coeff +
                      target_gain*(1-self.attack_coeff) )

        # limit the delayed signal
        signal[i] = self.delay_line[self.delay_index] * self.gain




    print "Recording Audio"
    signal = sd.rec(signal_length * fs, samplerate=fs, channels=1,    dtype=dtype)
    sd.wait()
    print "Audio recording complete , Play Audio"





original_signal = array(signal, copy=True, dtype=dtype)
limiter = Limiter(attack_coeff, release_coeff, delay, dtype)

def callback(in_data, frame_count, time_info, flag):
    if flag:
        print("Playback Error: %i" % flag)
        played_frames = callback.counter
        callback.counter += frame_count
        limiter.limit(signal[played_frames:callback.counter], threshold)
    return signal[played_frames:callback.counter], paContinue

callback.counter = 0

pa = PyAudio()

stream = pa.open(format = paFloat32,
                 channels = 1,
                 rate = fs,
                 frames_per_buffer = block_length,
                 output = True,
                 stream_callback = callback)

while stream.is_active():
    sleep(0.1)

stream.close()
pa.terminate()

【问题讨论】:

  • 给我们一个完整的追溯
  • 你好。我是 python 的新手,我在哪里放置代码以获取回溯以及我应该添加什么回溯代码。谢谢。
  • 回溯是通常在shell中看到的红色的完整错误。回溯的最后一行应该是错误:Pyaudio : Playback Error: 4
  • ok 回溯是:录制音频 音频录制完成,播放音频播放错误:4 播放错误:4 播放错误:4 播放错误:4 播放错误:4 播放错误:4 播放错误:4

标签: python python-2.7 pyaudio


【解决方案1】:

你不应该混合使用 PyAudio 和 sounddevice!

不管怎样,如果在回调函数中调用 sounddevice.rec()sounddevice.wait() 函数将无法正常工作(因为它们在内部使用自己的“流”和自己的回调函数)。

【讨论】:

  • 好的。那么解决方案可能是什么。该代码基本上应该使用低通滤波器录制麦克风并播放音频以创建混音效果。
  • 这是两个独立的问题。如果您显示低通滤波器的代码,我可以向您展示如何将其与sounddevice 一起使用。基本上,您可以只使用"wire" example,将低通滤波器应用于indata,并将结果分配给outdata[:]。您只需注意在连续回调调用之间保持过滤器的状态。
  • 你好,马蒂亚斯。我将上面的代码作为添加类似于低通滤波器的限制器的一种方式。以某种方式对使用麦克风说话的人产生含糊不清的效果。如果您有执行类似操作的代码,请分享。谢谢。
  • 您应该首先尝试实现一个简单版本的限制器/过滤器/...,它采用单个 NumPy 数组并返回另一个数组和结果。如果您在信号处理部分需要帮助,请查看dsp.stackexchange.com
猜你喜欢
  • 2018-01-26
  • 2020-09-14
  • 2012-12-20
  • 1970-01-01
  • 1970-01-01
  • 2018-05-10
  • 1970-01-01
  • 2011-09-27
  • 1970-01-01
相关资源
最近更新 更多