
たとえば 10、18、32 といった多数の入力チャンネルを備えた USB オーディオ インターフェイスをいくつか持っています。
現在、10 個の入力チャンネルを備えたものを Linux PC に接続しており、 の出力でそれを見つけることができましたpactl list sources
。関連部分は次のとおりです。
Source #1414
...
Name: alsa_input.usb-Behringer_FLOW_8_03-FF-02-11-55-44-00.Direct__hw_F8__source
...
Sample Specification: s32le 10ch 48000Hz
Channel Map: aux0,aux1,aux2,aux3,aux4,aux5,aux6,aux7,aux8,aux9
...
Volume: aux0: 48287 / 74% / -7.96 dB, aux1: 48287 / 74% / -7.96 dB, aux2: 48287 / 74% / -7.96 dB, aux3: 48287 / 74% / -7.96 dB, aux4: 48287 / 74% / -7.96 dB, aux5: 48287 / 74% / -7.96 dB, aux6: 48287 / 74% / -7.96 dB, aux7: 48287 / 74% / -7.96 dB, aux8: 48287 / 74% / -7.96 dB, aux9: 48287 / 74% / -7.96 dB
balance 0.00
...
Properties:
...
audio.channels = "10"
...
つまり、明らかに 10 個の入力チャンネルがあります。
そして、Audacity も同意します。問題なく、10 チャンネルすべてを別々のトラックに並行して録音できます。一方、ffmpeg は、channel_layout を指定しても (1111111111 (10 チャンネル) の 16 進数表現である 0x3ff を使用しています)、オーディオ インターフェイスに 2 つ以上のチャンネルがあることを理解していないようです。
次のように実行してみました:
$ export SOURCE_NAME="alsa_input.usb-Behringer_FLOW_8_03-FF-02-11-55-44-00.Direct__hw_F8__source"
$ ffmpeg -f pulse -i "${SOURCE_NAME}" -c:a pcm_s32le -ar 48000 -ac 10 -channel_layout 0x3ff output.w64
そして、次のような出力が得られました:
...
Guessed Channel Layout for Input Stream #0.0 : stereo
Input #0, pulse, from 'alsa_input.usb-Behringer_FLOW_8_03-FF-02-11-55-44-00.Direct__hw_F8__source':
Duration: N/A, start: 1689435887.317692, bitrate: 1536 kb/s
Stream #0:0: Audio: pcm_s16le, 48000 Hz, stereo, s16, 1536 kb/s
Multiple -ac options specified for stream 0, only the last option '-ac 10' will be used.
Stream mapping:
Stream #0:0 -> #0:0 (pcm_s16le (native) -> pcm_s32le (native))
Press [q] to stop, [?] for help
[pcm_s32le @ 0x5636967eb040] Channel layout '10 channels (FL+FR+FC+LFE+BL+BR+FLC+FRC+BC+SL)' with 10 channels does not match number of specified channels 2
Error initializing output stream 0:0 -- Error while opening encoder for output stream #0:0 - maybe incorrect parameters such as bit_rate, rate, width or height
Conversion failed!
hexadecagonal
代わりに channel_layout として指定すると、実際には録音されますが、最初の 2 つのチャネルのみが録音され、16 チャネルの w64 ファイルが作成され、最初の 2 つのチャネルだけにオーディオが含まれます。
$ ffmpeg -f pulse -i "${SOURCE_NAME}" -c:a pcm_s32le -ar 48000 -ac 10 -channel_layout hexadecagonal output.w64
...
Output #0, w64, to 'output.w64':
Metadata:
encoder : Lavf58.76.100
Stream #0:0: Audio: pcm_s32le ([1][0][0][0] / 0x0001), 48000 Hz, hexadecagonal, s32, 24576 kb/s
Metadata:
encoder : Lavc58.134.100 pcm_s32le
size= 54000kB time=00:00:16.02 bitrate=27602.2kbits/s speed=1.07x
video:0kB audio:54000kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.000231%
Exiting normally, received signal 2.
私が何を間違っているのか、何か手がかりはありますか?