ffmpeg: как dowmix с 2 каналов 5.1 на 2 стереопотока - PullRequest
0 голосов
/ 26 апреля 2018

У меня есть файл mov с видеопотоком и несколькими аудиопотоками на двух разных языках. Вот вывод ffprobe:

ffprobe version N-89525-gb178278 Copyright (c) 2007-2017 the FFmpeg developers
 built with gcc 4.8 (Ubuntu 4.8.4-2ubuntu1~14.04.3)
 configuration: --prefix=/home/ubuntu/ffmpeg_build --pkg-config-flags=--static 
--extra-cflags=-I/home/ubuntu/ffmpeg_build/include --extra-ldflags=- 
L/home/ubuntu/ffmpeg_build/lib --extra-libs='-lpthread -lm' -- 
bindir=/home/ubuntu/bin --enable-gpl --enable-libass --enable-libtwolame -- 
enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libtheora -- 
enable-libvorbis --enable-libx264 --enable-nonfree
libavutil      56.  6.100 / 56.  6.100
libavcodec     58.  8.100 / 58.  8.100
libavformat    58.  3.100 / 58.  3.100
libavdevice    58.  0.100 / 58.  0.100
libavfilter     7.  7.100 /  7.  7.100
libswscale      5.  0.101 /  5.  0.101
libswresample   3.  0.101 /  3.  0.101
libpostproc    55.  0.100 / 55.  0.100
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'sony_trim2.mov':
Metadata:
major_brand     : qt
minor_version   : 0
compatible_brands: qt
creation_time   : 2018-04-24T11:15:52.000000Z
com.apple.finalcutstudio.media.uuid: BEF32C67-F7C2-4D6C-B4AD-B79255E1414B
Duration: 00:01:26.32, start: 0.000000, bitrate: 197731 kb/s
Stream #0:0(eng): Video: prores (apch / 0x68637061), yuv422p10le(bt709, 
progressive), 1920x1080, 179299 kb/s, SAR 1:1 DAR 16:9, 25 fps, 25 tbr, 25 tbn, 25 tbc (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
  encoder         : Apple ProRes 422 (HQ)
  timecode        : 00:58:32:15
Stream #0:1(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (FL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:2(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (FR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:3(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, mono, s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:4(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (LFE), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:5(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (BL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:6(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (BR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:7(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (FL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:8(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (FR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:9(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, mono, s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:10(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (LFE), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:11(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (BL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:12(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (BR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:13(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (DL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:14(fra): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (DR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:15(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (DL), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:16(eng): Audio: pcm_s24le (lpcm / 0x6D63706C), 48000 Hz, 1 channels (DR), s32 (24 bit), 1152 kb/s (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
Stream #0:17(eng): Data: none (tmcd / 0x64636D74) (default)
Metadata:
  creation_time   : 2018-04-24T11:15:52.000000Z
  handler_name    : Core Media Data Handler
  timecode        : 00:58:32:15

Я бы хотел микшировать аудиопотоки # 0: 1 -> # 0: 6 в один стереопоток и в то же время микшировать аудиопотоки # 0: 7 -> # 0: 12 в другой стереопоток. Я попытался отобразить потоки и использовать команду -ac 2, но она не сработала.

ffmpeg -i myfile.mov -filter:v scale=854x480 -ac 2 -af "pan=stereo| FL < FL + 0.5*FC + 0.6*BL + 0.6*SL | FR < FR + 0.5*FC + 0.6*BR + 0.6*SR" -map 0:1 -map 0:2 -map 0:3 -map 0:4 -map 0:5 -map 0:6 -acodec libmp3lame -b:a 256k -ar 48000 -y -strict experimental -map 0:0 -x264opts bitrate=2000:vbv-maxrate=2000:vbv-bufsize=166 -vcodec libx264 -profile:v high -level:v 4.0 -pix_fmt yuv420p -aspect 16:9 -r 25 -g 50 -f mpegts -muxrate 2000K -y myfile.ts

Есть идеи? Заранее спасибо за помощь.

1 Ответ

0 голосов
/ 26 апреля 2018

Для создания стерео из монофонических потоков, микшированных с понижением, используйте

ffmpeg -i myfile.mov -filter_complex "[0:13][0:14]amerge[st-fr];[0:15][0:16]amerge[st-en]" -map 0:v -map "[st-fr]" -map "[st-en]" -c:v copy out.mov

Это просто выполняет запрошенное стереофоническое микширование и удаляет все остальные аудио. Вы можете повторно добавить параметры кодирования видео, если хотите.

...