我在Prolog中编写了一组规则,如果规则匹配就会触发特定的动作。类似于这样:
rule_second_question(X, Y, X, W):- ( LINK_BASE == 'G', is_verb_form(X), aggregate_all(X, linkage(W, _, _, _, _, _, _, _, _, 'RS'), Y), writeln(Y), Count == 1, SUBJECT = X, nb_linkval(rule, 'twol') )
我也可以在Python、C++中使用if
、else
编写类似的规则。
我的程序与语言学有关。我不明白Prolog与其他编程语言相比有什么不同之处。
任何帮助或示例都将非常感激。
回答:
Prolog的力量源自于逻辑变量,结合内嵌的搜索算法,以及表达丰富且统一的数据结构设施。
它实现了一种关系数据模型,但其结构化值域比SQL更丰富。从某种意义上说,我认为它是’No SQL’语言的先驱。
因此,我们可以小心地编写复杂数据结构之间的关系,就像早期的NLP研究中认为所需的那样。
一些易于实现的语法糖(所谓的DGC – 确定性子句语法),然后让你编写可执行的抽象语法树。如果你认为这种语言(或多或少)与C语言一样古老,你就能体会到它的魅力。
然后,NLP研究被一种更直接有效的范式所吸引:统计解析。Prolog,由于不擅长算术,逐渐失去了流行度。
查看项目Attempto,了解在Prolog中实现的有价值的资源。
另外,我最喜欢的关于Prolog的书,由Pereira-Shieber撰写,免费提供。它通过NLP介绍Prolog。