- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从静态文件创建 MPEG-DASH“实时”流来测试各种低延迟模式。 FFmpeg 中的 DASH 多路复用器创建两个 AdaptationSet,一个用于视频 block ,一个用于音频 block 。
但是,音频和视频 block 文件的创建速度不同(应该是这样吗?)。即这里stream0
是视频 block 和stream1
是音频 block 。运行几秒钟后,webroot 目录包含:
chunk-stream0-00001.m4s chunk-stream1-00001.m4s
chunk-stream0-00002.m4s chunk-stream1-00002.m4s
chunk-stream0-00003.m4s chunk-stream1-00003.m4s
chunk-stream0-00004.m4s chunk-stream1-00004.m4s
chunk-stream1-00005.m4s
chunk-stream1-00006.m4s
chunk-stream1-00007.m4s
chunk-stream1-00008.m4s
chunk-stream1-00009.m4s
master.mpd
init-stream0.m4s
init-stream1.m4s
流不会在
dash.js
上加载(或播放)或 shaka-player 有很多
404 (Not Found)
视频 block 的错误。播放器按顺序从stream0 和stream1 请求 block ,即stream0-001 + stream1-001,然后是stream0-002 + stream1-002,依此类推。
dash.all.debug.js:15615 [2055][FragmentController] No video bytes to push or stream is inactive.
并显示 404 错误 stream0 block 188(尚不存在!)
ffmpeg -re -i /mnt/swdevel/TestStreams/H264/ThreeHourMovie.mp4 \
-c:v libx264 -x264-params keyint=120:scenecut=0 -b:v 1M -c:a copy \
-f dash -dash_segment_type mp4 \
-seg_duration 2 \
-target_latency 3 \
-frag_type duration \
-frag_duration 0.2 \
-window_size 10 \
-extra_window_size 3 \
-streaming 1 \
-ldash 1 \
-use_template 1 \
-use_timeline 0 \
-write_prft 1 \
-fflags +nobuffer+flush_packets \
-format_options "movflags=+cmaf" \
-utc_timing_url "/pelican/testPlayers/time.php" \
master.mpd
和
dash.js
播放器代码很简单:
const srcUrl = "../ottWebRoot/playerTest/master.mpd";
var player = dashjs.MediaPlayer().create();
let autoPlay = false;
player.initialize(document.querySelector("#videoTagId"), srcUrl, autoPlay);
player.updateSettings(
{
streaming :
{
lowLatencyEnabled : true,
liveDelay : 2,
jumpGaps : true,
jumpLargeGaps : true,
smallGapLimit : 1.5,
}
});
提供
UTCTiming
list 中的元素,小的
time.php
URL 从 Web 服务器返回 UTC 时间:
<?php
print gmdate("Y-m-d\TH:i:s\Z");
?>
(它还显示最新的 stream1/audio block 的 404 错误,这可能是一个不同的问题)
watch -n 1 ls -lt <webRootFolder
并与浏览器控制台中的错误并排比较。很难比较,但看起来浏览器正在尝试“在播放边缘”获取尚未由 FFmpeg 创建的文件。见下图。
shaka-player
而不是
dash.js
播放正常,没有 404 错误。配置为:
player.configure(
{
streaming:
{
lowLatencyMode: true,
inaccurateManifestTolerance: 0,
rebufferingGoal: 0.1,
}
});
客户
<?xml version="1.0" encoding="utf-8"?>
<MPD xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="urn:mpeg:dash:schema:mpd:2011"
xmlns:xlink="http://www.w3.org/1999/xlink"
xsi:schemaLocation="urn:mpeg:DASH:schema:MPD:2011 http://standards.iso.org/ittf/PubliclyAvailableStandards/MPEG-DASH_schema_files/DASH-MPD.xsd"
profiles="urn:mpeg:dash:profile:isoff-live:2011"
type="dynamic"
minimumUpdatePeriod="PT500S"
availabilityStartTime="2021-05-24T14:50:00.263Z"
publishTime="2021-05-24T15:22:45.335Z"
timeShiftBufferDepth="PT50.0S"
maxSegmentDuration="PT2.0S"
minBufferTime="PT5.0S">
<ProgramInformation>
</ProgramInformation>
<ServiceDescription id="0">
<Latency target="3000" referenceId="0"/>
</ServiceDescription>
<Period id="0" start="PT0.0S">
<AdaptationSet id="0" contentType="video" startWithSAP="1" segmentAlignment="true" bitstreamSwitching="true" frameRate="24/1" maxWidth="1280" maxHeight="682" par="15:8" lang="und">
<Resync dT="200000" type="0"/>
<Representation id="0" mimeType="video/mp4" codecs="avc1.64081f" bandwidth="1000000" width="1280" height="682" sar="1023:1024">
<ProducerReferenceTime id="0" inband="true" type="captured" wallClockTime="2021-05-24T14:50:00.263Z" presentationTime="0">
<UTCTiming schemeIdUri="urn:mpeg:dash:utc:http-xsdate:2014" value="/pelican/testPlayers/time.php"/>
</ProducerReferenceTime>
<Resync dT="5000000" type="1"/>
<SegmentTemplate timescale="1000000" duration="2000000" availabilityTimeOffset="1.800" availabilityTimeComplete="false" initialization="init-stream$RepresentationID$.m4s" media="chunk-stream$RepresentationID$-$Number%05d$.m4s" startNumber="1">
</SegmentTemplate>
</Representation>
</AdaptationSet>
<AdaptationSet id="1" contentType="audio" startWithSAP="1" segmentAlignment="true" bitstreamSwitching="true" lang="und">
<Resync dT="200000" type="0"/>
<Representation id="1" mimeType="audio/mp4" codecs="mp4a.40.2" bandwidth="116317" audioSamplingRate="48000">
<AudioChannelConfiguration schemeIdUri="urn:mpeg:dash:23003:3:audio_channel_configuration:2011" value="2" />
<ProducerReferenceTime id="1" inband="true" type="captured" wallClockTime="2021-05-24T14:50:00.306Z" presentationTime="0">
<UTCTiming schemeIdUri="urn:mpeg:dash:utc:http-xsdate:2014" value="/pelican/testPlayers/time.php"/>
</ProducerReferenceTime>
<Resync dT="21333" type="1"/>
<SegmentTemplate timescale="1000000" duration="2000000" availabilityTimeOffset="1.800" availabilityTimeComplete="false" initialization="init-stream$RepresentationID$.m4s" media="chunk-stream$RepresentationID$-$Number%05d$.m4s" startNumber="1">
</SegmentTemplate>
</Representation>
</AdaptationSet>
</Period>
<UTCTiming schemeIdUri="urn:mpeg:dash:utc:http-xsdate:2014" value="/pelican/testPlayers/time.php"/>
</MPD>
最佳答案
输入,ThreeHourMovie.mp4
, 帧速率为 24Hz(见 AdaptationSet@frameRate
),所以设置 keyint
至120
将在 x264 的输出处每五秒给出一个 IDR。
您正在指示 DASH 多路复用器(通过 seg_duration
)输出和信号 2s 段,但这是不可能的,因为段必须以 IDR 开头(如您链接的指南中所述)。所以复用器输出 5s 段,但在 list 中发出 2s 信号,这显然是不正确的。
更改keyint
到 seg_duration
的正确倍数(即 keyint=48
在这种情况下),它可能会开始工作。
关于FFMPEG/DASH-LL 以不同的速率创建音频和视频 block ;玩家很困惑(404错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67674772/
为了进一步了解解析器和语法,我正在寻找 LL(2) 但不是 LL(1) 的语言示例(希望是简单的)。也就是说,一种可以由 LL(2) 语法生成但不能由任何 LL(1) 语法生成的语言。 该类(clas
$ cat png.ll ./packages/apps/Mms/res/mipmap-hdpi/ic_launcher_smsmms.png ./packages/apps/Mms/res/draw
我最近试图自学解析器(用于语言/上下文无关语法)如何工作,除了一件事之外,大多数内容似乎都是有意义的。我特别关注 LL(k) 语法,其中两个主要算法似乎是 LL parser (使用堆栈/解析表)和
我正在研究上下文无关语法,并且我陷入了第一步:了解自顶向下解析算法的结构。 我的问题围绕自上而下的解析器。我向我介绍了三种算法: 递归下降 预测性 预测递归下降 问题 但不明白如何将它们联系起来。所以
我有三种语法: A -> aB |乙| CBB B -> aB |巴| aBb C -> aaA |乙| caB 我需要“通过执行成对不相交测试来确定[它们]是否是 LL 语法,显示每个非终结符的每个
我已经在转换它上浪费了很多时间,但我总是起床得到公共(public)前缀 ID。 谁能给我解释一下?因为我正在尝试为一个非常大的语法做这件事并且需要我的基础知识清楚。 A、B、C、D 是仅有的非终结符
如果我定义了以下结构: typedef struct bear_t { char* name; void (*eat)(struct bear_t* this); void (
我在 Internet 上找不到任何关于 LL(*) 解析器的完整描述,例如 ANTLR。 我想知道 LL(k) 解析器和 LL(*) 解析器之间的区别是什么,以及为什么它们不支持左递归语法,尽管它们
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
LL 是否在标准中的任何地方定义(很难找到)? ideone接受代码 int main() { std::cout int main() { // Won't fire st
我的任务是将此语法转换为 LL(1) E → E+E | E-E | E*E | E/E | E^E | -E | (E)| id | num 所以对于第一步,我消除了歧义并得到了这个: E → E+
我了解 LL 递归下降解析器如何处理这种形式的规则: A = B*; 使用一个简单的循环,根据前瞻标记是否与 B 的第一组中的终端匹配来检查是否继续循环。但是,我对基于表的 LL 解析器很好奇:这种形
我有以下语法: S → a S b S | b S a S | ε 由于我正在尝试为其编写一个小型编译器,因此我想将其设为 LL(1)。我看到这里似乎存在 FIRST/FOLLOW 冲突,我知道我必须
我有一个语法,我可以检查 is 是否是 LL(1)。但是,有什么方法可以检查语法生成的语言是否为LL(1)? LL(1) 语法和 LL(1) 语言之间到底有什么区别? 最佳答案 任何 LL(1) 语法
好吧,我所说的 LL(k) 语言是指其解析器可以用 LL(k) 语法描述的编程语言。 这些是我的猜测: 帕斯卡 口齿不清 xml 和 friend 最佳答案 这取决于“语言”的定义。如果你问 What
我想解析一种编程语言。我读了很多关于形式语言、乔姆斯基层次结构和 ANTLR 的内容。但我找不到有关如何将 ANTLR v3 作为 LL(*) 递归下降解析器接受的语言与乔姆斯基层次结构相关联的信息。
我似乎无法弄清楚为什么在双向链表的末尾插入节点会陷入循环。要么陷入循环,要么陷入空指针。另外我想知道在处理链表或任何数据结构时 public Node 更好还是 public void 更好。 pub
我有一个程序,当前将生成 token 输出,用于下一个程序的输入。它将检查代码语法的正确性。 我遇到了如何开始将此语法转换为可用程序的问题。 下面是语法使用,我将如何着手制作它。或者哪里有好的资源可以
这个问题已经存在: Hello, it shows me two letter "L",but i would like to see full letters like "hello" but in
我正在尝试编译一个有 -ll 标志但 gcc 找不到的程序。 -l 之后的 l 是什么,真的是一个库还是错字?很难在谷歌上找到关于这个的信息。这样的术语是“模糊的”。 最佳答案 -ll 表示链接Sol
我是一名优秀的程序员,十分优秀!