MPEGTS и HLS: действителен только второй сегмент и далее

Когда я использую шестнадцатеричную компоновку аудиоканала в контейнере mpegts, я могу нормально получать и воспроизводить поток только в том случае, если я настрою сервер hls, чтобы разрешить обслуживание самого первого сегмента, а затем объединение последующих сегментов.

Т.е. если я исследую сегмент 1414:

[mpegts @ 0x7faf58001200] Could not find codec parameters for stream 1 (Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1464 kb/s): unspecified sample rate
Consider increasing the value for the 'analyzeduration' and 'probesize' options

Input #0, mpegts, from '1414.ts':
  Duration: 00:00:02.07, start: 2834.393367, bitrate: 9079 kb/s
  Program 1 
    Stream #0:0[0x100]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1430 kb/s
    Stream #0:1[0x101]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 0 channels, fltp, 1464 kb/s
    Stream #0:2[0x102]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 59.94 fps, 59.94 tbr, 90k tbn, 119.88 tbc
    Stream #0:3[0x103]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 60 fps, 60 tbr, 90k tbn, 120 tbc

Однако , если я исследую первый сегмент:

Input #0, mpegts, from '0.ts':
  Duration: 00:00:02.02, start: 1.412033, bitrate: 11598 kb/s
  Program 1 
    Stream #0:0[0x100]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 48000 Hz, 16 channels, fltp, 1353 kb/s
    Stream #0:1[0x101]: Audio: aac (LC) ([15][0][0][0] / 0x000F), 48000 Hz, 16 channels, fltp, 744 kb/s
    Stream #0:2[0x102]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 59.94 fps, 59.94 tbr, 90k tbn, 119.88 tbc
    Stream #0:3[0x103]: Video: h264 (High) ([27][0][0][0] / 0x001B), yuv420p(progressive), 1920x1080 [SAR 1:1 DAR 16:9], 60 fps, 60 tbr, 90k tbn, 120 tbc

Файл списка воспроизведения очень прост и выглядит так:

#EXTM3U
#EXT-X-VERSION:3
#EXT-X-MEDIA-SEQUENCE:0
#EXT-X-TARGETDURATION:4

#EXTINF:2.000,
0.ts
#EXTINF:2.000,
1.ts
#EXTINF:2.000,
2.ts
#EXTINF:2.000,
3.ts
#EXTINF:2.000,

etc ...

Скажем, при 8-канальном макете этого не происходит. Каждый сегмент содержит правильные заголовки. Но я предпочитаю сохранять 16 каналов, потому что мое приложение на принимающей стороне использует 16-канальные файлы, и это позволяет избежать необходимости перекодирования при загрузке.

Я использую FFmpeg для загрузки потока mpegts.

Любое понимание механики того, что здесь происходит, и что я могу сделать, чтобы добиться желаемой независимости сегментов?

Ответы (1)

Для нетрадиционных макетов собственный кодировщик AAC записывает раздел PCE в заголовок битового потока как часть AudioSpecificConfig. Однако это происходит только в начале, поэтому в последующих файлах потоки AAC отсутствуют.

Обходной путь — перейти на другую схему пакетирования для AAC в MPEG-TS.

Добавить -hls_ts_options mpegts_flags=latmпри создании пакета HLS.

это, казалось, решило проблему, спасибо. (В моем случае я использовал -mpegts_flags latmнапрямую). Есть ли какие-либо непредвиденные последствия, которые могут возникнуть из-за этого? Прочитав ANSI/SCTE 193-2 2014, можно предположить, что LATM в любом случае является предпочтительной инкапсуляцией.
Не все игроки HLS могут принимать AAC-LATM.