gpt4 book ai didi

audio - 使用 FFMPEG 将 16 channel 音频输入源拆分为 4 个单独的 4 channel 音频源以进行流式传输

转载 作者:行者123 更新时间:2023-12-02 23:02:27 25 4
gpt4 key购买 nike

我希望有人能帮帮忙

我目前正在尝试将来自单独机器的 16ch Dante 音频输入拆分为 4 个不同的音频流,然后我可以使用这些音频流通过 RTMP TX 到 Wowza 进行 MPEG-DASH 编码,目前我只是想将它们拆分成文件,我稍后将添加 RTMP 流。

我目前遇到的最大问题是 FFMPEG 从我的输入字符串中返回了这个错误

Filter channelsplit:WR has an unconnected output

这是我当前的输入字符串
ffmpeg -f dshow -i audio="Dante Via Receive (Dante Via)" -filter_complex "[0:a]channelsplit=channel_layout=hexadecagonal[FL][FR][FC][BL][BR][BC][SL][SR][TFL][TFC][TFR][TBL][TBC][TBR][WL][WR]" -map "[FL][FR][FC][BL]" 1-4.wav -map "[BR][BC][SL][SR]" 5-8.wav -map "[TFL][TFC][TFR][TBL]" 9-12.wav -map "[TBC][TBR][WL][WR]" 13-16.wav

这是完整的 FFMPEG 输出
ffmpeg version git-2019-12-26-b0d0d7e Copyright (c) 2000-2019 the FFmpeg developers
built with gcc 9.2.1 (GCC) 20191125
configuration: --enable-gpl --enable-version3 --enable-sdl2 --enable-fontconfig --enable-gnutls --enable-iconv --enable-libass --enable-libdav1d --enable-libbluray --enable-libfreetype --enable-libmp3lame --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-libopenjpeg --enable-libopus --enable-libshine --enable-libsnappy --enable-libsoxr --enable-libtheora --enable-libtwolame --enable-libvpx --enable-libwavpack --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxml2 --enable-libzimg --enable-lzma --enable-zlib --enable-gmp --enable-libvidstab --enable-libvorbis --enable-libvo-amrwbenc --enable-libmysofa --enable-libspeex --enable-libxvid --enable-libaom --enable-libmfx --enable-ffnvcodec --enable-cuvid --enable-d3d11va --enable-nvenc --enable-nvdec --enable-dxva2 --enable-avisynth --enable-libopenmpt --enable-amf
libavutil 56. 37.100 / 56. 37.100
libavcodec 58. 65.100 / 58. 65.100
libavformat 58. 35.101 / 58. 35.101
libavdevice 58. 9.101 / 58. 9.101
libavfilter 7. 69.101 / 7. 69.101
libswscale 5. 6.100 / 5. 6.100
libswresample 3. 6.100 / 3. 6.100
libpostproc 55. 6.100 / 55. 6.100
Guessed Channel Layout for Input Stream #0.0 : stereo
Input #0, dshow, from 'audio=Dante Via Receive (Dante Via)':
Duration: N/A, start: 103082.790000, bitrate: 1411 kb/s
Stream #0:0: Audio: pcm_s16le, 44100 Hz, stereo, s16, 1411 kb/s
File '1-4.wav' already exists. Overwrite? [y/N] y
File '5-8.wav' already exists. Overwrite? [y/N] y
File '9-12.wav' already exists. Overwrite? [y/N] y
File '13-16.wav' already exists. Overwrite? [y/N] y
Filter channelsplit:WR has an unconnected output

我也遇到了 FFMPEG 猜测声道数是立体声的问题,这是不正确的,但我在弄清楚如何将输入流定义为 16 声道音频时遇到了问题

对此的任何帮助都会受到极大的欢迎

干杯

最佳答案

ffmpeg -f dshow -channels 16 -i audio="Dante Via Receive (Dante Via)" -filter_complex "[0:a]channelmap=0|1|2|3[1-4];[0:a]channelmap=4|5|6|7[5-8];[0:a]channelmap=8|9|10|11[9-12];[0:a]channelmap=12|13|14|15[13-16]" -map "[1-4]" 1-4.wav -map "[5-8]" 5-8.wav -map "[9-12]" 9-12.wav -map "[13-16]" 13-16.wav
  • 尝试添加 -channels 16 dshow 输入选项。
  • 过滤器输出标签不能在 -map 中组合, 所以所有的混合过滤器和给每个 -map一个标签。
  • channelsplit仅将 channel 作为单独的流输出,并且不会将多个 channel 混合为单个流,因此 channelmap改为使用。
  • 我没有 dshow 所以我无法测试这个。
  • 关于audio - 使用 FFMPEG 将 16 channel 音频输入源拆分为 4 个单独的 4 channel 音频源以进行流式传输,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59532755/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com