终于合一起了...

一直打算找个时间把Earley算法的框架整合到我的parse算法上,感觉能够得到一个更好的思路。这两天水到渠成的把这件事做了。

说的挺轻松呵呵,当初折腾自己的算法的时候,和第一次接触Earley算法把它做对的时候,都下了些功夫;尤其是前者。而且一直没有融合,也不完全是没有时间,而是思路没理顺。

跟Earley Parser比,有更小的空间占用和更简单的步骤,因为Earley的从根本上可以说是一种Chart Parser,所以难免有些多余的格子和操作。好像它上面的研究者都没想着应该换个思路。

跟我自己最初的算法比,那个基本上是从NFA Simulation上硬生生长出来的,过小的起点基础根本承受不住我的思路,所以很乱而且不敢保证没有bug。不过那个算法是原生支持一部分CS语言的。

跟LL、LR比,我个人觉得在支持全部CFG的同时,它在思路和实现两方面上也清晰简明的多,可扩展性更强,唯一吃亏的效率问题,也就可以通过扩展子部件优化,这确实是得益于Earley。

怎么说呢,现在就差一个正确性的证明;做一个它可以正确生成Earley Item Set并且操作等价于Earley算法(虽然实际上已经不需要这些Earley算法的部分了)的证明,也许是个不错的捷径。

希望我没弄错什么、在近期有时间可以搞一下这个事;如果弄下来确实是正确的且还没有和别人的重复,嗯嗯就可以起名字了嘿嘿。

 

P.S. 谁有写正经论文和国外投稿的经验,求教。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值