Raspberry pi I2S MEMS Микрофон Правый CHN Mono Использование pyaudio

Я использую Adafruit I2S MEMS Microphone Breakout для записи. ссылка https://learn.adafruit.com/adafruit-i2s-mems-microphone-breakout?view=all

Когда я подключаю микрофон к RPI в конфигурации Mono, как показано на рисунке ниже, я могу записывать звук с помощью команды arecord и кода Python.

введите описание изображения здесь

arecord -D dmic_sv -c2 -r 48000 -f S32_LE -t wav -V моно -v запись.wav

Фрагмент кода Python:

каналы =1, скорость =48000, frames_per_buffer=2400

def start_recording(self):
        try:
            self.logger.info("start_recording()> enter")
            # Use a stream with a callback in non-blocking mode
            self._stream = self._pa.open(format=pyaudio.paInt32,
                                            channels=self.channels,
                                            rate=self.rate,
                                            input=True,
                                            frames_per_buffer=self.frames_per_buffer,
                                            stream_callback=self.get_callback())
            self._stream.start_stream()
            self.logger.info("start_recording()> exit")
            return self
        except Exception, e:
            self.logger.error("start_recording()>", exc_info = True)

Но если я подключу вывод выбора канала к логике высокого напряжения, я смогу записывать звук с помощью команды arecord, но без возможности записи с использованием кода Python. Какие-либо изменения, требуемые в коде Python для записи моно аудио в правом канале?

1 ответ

Я сделал нечто подобное, но с помощью Python-SoundDevice. Вот мой репо

РЕДАКТИРОВАТЬ: вот конкретный класс записи звука для уточнения

import threading
import queue
import numpy
import sounddevice as sd
import soundfile as sf

class AudioRecorder():

    def __init__(self):

        self.open = True
        self.file_name = 'name_of_file.wav'
        self.channels = 1
        self.q = queue.Queue()

        # Get samplerate
        device_info = sd.query_devices(2, 'input')
        self.samplerate = int(device_info['default_samplerate'])

    def callback(self, indata, frames, time, status):

        # This is called (from a separate thread) for each audio block.
        if status:
            print(status, file=sys.stderr)
        self.q.put(indata.copy())

    def record(self):
        with sf.SoundFile(self.file_name, mode='x', samplerate=self.samplerate, channels=self.channels) as file:
            with sd.InputStream(samplerate=self.samplerate, channels=self.channels, callback=self.callback):

                while(self.open == True):
                    file.write(self.q.get())

РЕДАКТИРОВАТЬ 2: Код представляет собой класс Python, который создает аудиофайл с использованием микрофона I2S, аналогично изображению, показанному в вопросе. Хотя значение self.open true, sounddevice запишет аудиоданные в очередь (def callback), а затем записать данные в файл. Все, что вам нужно сделать, это переключить self.open начать и остановить запись.

Другие вопросы по тегам