- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我已经实现了 Earley parser使用队列来处理状态。该队列使用顶级规则播种。对于队列中的每个状态,其中一个操作(预测、扫描、完成)是通过向队列中添加新状态来执行的。 不添加重复状态。
我遇到的问题最好用以下语法来描述:
当解析 A
时,会发生以下情况:
如您所知,A
不会完全解析。这是因为 epsilon 状态的完成只会发生一次,因为它不会添加到队列中。
我如何调整我的算法以支持这些 epsilon 状态?
编辑:请注意,使用终端时这不是问题,因为将创建新图表集以插入扫描状态。由于该状态不存在,因此将对其进行处理。
最佳答案
论文中"Practical Earley Parsing"由 John Aycock 和 R. Nigel Horspool 提出,作者提出以下方法作为处理可空非终结符的方法:
If [A→ ... •B ..., j] is in Si, add [B→ • a, i]to Si for all rules B → a.If B is nullable, also add [A → ... B • ..., j] to Si.
(强调原文。)所以在你的例子中,在A→ • B B 的预测中会产生以下规则:
(1) B → •关键是这发生在预测阶段。在预测阶段,如果“点后”符号可以为空(直接和通过转移),则将点向右移动并添加该规则。
所以基本上:
A → • B B 产生(B → • 和A → B • B)每个都在排队和处理
A → B • B 产生 (A → B B • ),它被排队和处理
关于algorithm - Earley 无法处理图表中已包含的 epsilon 状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35524183/
据说它会选择概率为 1-epsilon 的经验平均值最高的臂,在第 no 页中为概率编写的方程中,epsilon/k 是如何添加到它的(以及用于随机概率选择的 epsilon/k) :6篇论文Algo
据我所知,epsilon 标志着探索和利用之间的权衡。一开始,你希望 epsilon 较高,这样你才能取得大的进步并学到东西。当您了解 future 的奖励时,epsilon 应该衰减,以便您可以利用
教科书教我们使用 epsilon (ε) 编写正则表达式符号,但是如何将该符号直接转换为代码而不必完全修改我的正则表达式? 例如,我将如何编写这个正则表达式来捕获以 a 开头或结尾的所有小写字符串。
我在想 ES6 中的相等是封闭的情况,就像这个基本的例子: x = 0.2; y = 0.3; z = 0.1; equal = (Math.abs(x - (y - z)) < Number.EPS
有一个最接近零的FLT_MIN常量。如何最接近某个数字值? 举个例子: float nearest_to_1000 = 1000.0f + epsilon; // epsilon must be th
这是一张图片:http://i.imgur.com/MRvz24u.gif 所以我可以说出问题是什么,我用于球坐标的 epsilon(或任何符号)重复出现。所以我计算点数的方式是: double th
我正在尝试以最小值分隔两个等值的 double 。上下文是一个事件模拟。我不希望事件同时发生,因此我将设置为发生新事件的时间增加了一个最小值。 (这很烦人,经常发生(自行实现的随机数生成器),所以我实
sys.float_info.epsilon 返回什么? 在我的系统上我得到: >>> sys.float_info.epsilon 2.220446049250313e-16 >>> sys.flo
我正在尝试计算 float 类型的 epsilon 值的近似值(我知道它已经在标准库中)。 这台机器上的 epsilon 值是(打印有一些近似值): FLT_EPSILON = 1.192093e-
为什么 Decimal 数据类型没有 Epsilon 字段? From the manual ,decimal 值的范围是 ±1.0 × 10e−28 到 ±7.9 × 10e28。 The desc
我编写了一个类,用 Java 中的两个 double 来测试相等、小于和大于。我的一般情况是比较可以精确到半美分的价格。 59.005 与 59.395 相比。我为这些情况选择的 epsilon 是否
什么是最小的浮点值 A 使得 (x = 0 && pOppositeToCurrentCave.hasLeftVertexTo(otherLeftX)) { otherLeftX = pOpp
为了简化问题,假设我想计算表达式 a / (b - c)在 float s。 为了确保结果有意义,我可以检查 b和 c相等: float EPS = std::numeric_limits::epsi
我正在进行一些几何计算,这需要我比较基于 double 的坐标。我通常通过添加一些人工 epsilon 来处理这种情况下的浮点不准确问题。这很常见,并且有很多关于该主题的信息。 http://floa
根据维基百科,不同精度数据类型的布局是 single precision :指数 (e):8 位,小数 (f):23 位 double precision :e:11位,f:52位 quadruple
我让球弹来弹去,每次它们碰撞时,它们的速度矢量都会因恢复系数而降低。 现在我的球 CoR 是 0.80。因此,在多次弹跳之后,我的球已经“停止”滚动,因为它们的速度已经变得非常小了。 在什么阶段检查速
我在编码方面的经验很少,并且正在学习 Python 类(class)。我被要求在某个所需的 epsilon 内近似无穷总和,以便该系列中两个连续项之间的差值小于 epsilon。 我搜索了一下,发现了
我试图了解 LR1 解析器的工作原理,但我想到了一个奇怪的问题:如果语法包含 Epsilons 怎么办?例如:如果我有语法: S -> A A -> a A | B B -> a 很清楚如何开始: S
我的团队正在使用财务软件,该软件在 C# float 加倍时公开货币值(value)。有时,我们需要比较这些值以查看它们是否等于零,或者是否低于特定限制。当我注意到此逻辑中的意外行为时,我很快了解到浮
在this question中,我编写了一个脚本,以查找将值存储为总和的一部分然后再次返回时可能出现的最大错误。 我发现最大错误与Number.EPSILON有关: maximumError / Nu
我是一名优秀的程序员,十分优秀!