左角落分析法解析

2024-01-28 06:59
文章标签 解析 分析法 角落

本文主要是介绍左角落分析法解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为什么要使用左角表?     

一般的自顶向下的分析法中存在回溯现象,这种严重的限制了分析法,构造了推导树,但是有的时候会出现搜索空的情况,使分析效率很低。为了提高自顶向下的分析效率,减少盲目性,可以给CFG文法建立一个左角表(left-corner table)。

左角表中存有什么?

例如这个文法:

G = {Vn , Vt , S , P}
Vn = {S , NP , VP , Aux , Wh2NP , Pron , PrN , predet , Det , Card , Ord , Quant , AP , Nom. N. V ,
Adj , Adv , Wh2Pron ,PP , GdVP , GdV , RelCL , who , that , and}
Vt = {the , a , that , table , leg , Jack , lacks , hits ,…}
S = S
P : :1. S`NP VP ;2. S`VP ;3. S`Aux NP VP ;4. S`Wh2NP VP ;5. NP`Pron ;6. NP`PrN ;7. NP`
(Det) (Card) (Ord) (Quant) (AP) Nominal ;8. NP`Nom N ;9. Wh2NP`Wh2Pron ;10. Nom`N Nom ;
11. Nom`N ;12. Nom`N PP(PP) (PP) ; 13. Nom`Nom GdVP ; 14. GdVP` GdV NP (GdVP表示
Gerund verb phrase , GdV表示Gerund verb) ;15. GdVP` GdV PP ;16. GdVP` GdV ;17. GdVP` GdV
NP PP ;18. Nom`Nom RelCl(RelCL表示关系从句) ;19. RelCl `who VP(这个who是关系代词) ;
20. RelCl`that VP(这个that 是关系代词) ;21. AP `Adv Adj ;22. AP`Adj ;23. VP`V ;24. VP`V
NP ;25. VP`V NP PP ;26. VP`V PP ;27. VP`V S ;28. VP`V that S(这个that 是关系代词) ;29.PP`Prep NP ; 30. NP`NP and NP ; 31. VP`VP and VP ; 32. S`S and S ; 33. Pron`{ I , you , he ,
…} ;34. N`{table , leg , …} ; 35. V`{lacks , hits , …} ; 36. PrN`{Jack , John , …} ; 37. P`{on ,
of , at , …} ;38. Aux`{does , has , …} ;39. Ord`{first , second , …} ;40. Det`{the , a , that , …} ;
41. Card`{one , two , …}

他的左角可以为如图所示:

image

传统自上而下分析法和左脚分析法的对比

1. S`NP VP
2. S`VP
3. S`Aux NP VP
4. S`Wh2NP VP

就拿分析S来说,例如我们要匹配的第1个词是the

使用传统的自上而下的方法分析:

我们需要搜索S`VP , S`Aux NP VP , S`Wh2NP VP来搜索,这个过程当中,要做很多的空搜索。

如果使用左角分析法:

很快就可以通过查表得到the的对应的Det。这样大大的节省了时间。

下面这个例子展示了,是如何匹配“The table that lacks a leg hits Jack”这个句子的:

image

image

image

从分析的过程中看,虽然使用了左角分析法,避免了大量的空搜索。但是,在分析过程中,仍然出现了7词回溯。

有的科学家已经提出了其他改良的更高效的算法,在这里不做讨论。

参考文献:一种无回溯的自然语言分析算法 冯志伟 (教育部语言文字应用研究所 北京 100010)

转载于:https://www.cnblogs.com/createMoMo/archive/2013/06/01/3113321.html

这篇关于左角落分析法解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/652845

相关文章

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Spring MVC使用视图解析的问题解读

《SpringMVC使用视图解析的问题解读》:本文主要介绍SpringMVC使用视图解析的问题解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC使用视图解析1. 会使用视图解析的情况2. 不会使用视图解析的情况总结Spring MVC使用视图

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提

Java中的runnable 和 callable 区别解析

《Java中的runnable和callable区别解析》Runnable接口用于定义不需要返回结果的任务,而Callable接口可以返回结果并抛出异常,通常与Future结合使用,Runnab... 目录1. Runnable接口1.1 Runnable的定义1.2 Runnable的特点1.3 使用Ru

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis