首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >一个简单的Prolog同义词匹配器( rubylog)

一个简单的Prolog同义词匹配器( rubylog)
EN

Stack Overflow用户
提问于 2012-09-22 07:50:42
回答 1查看 282关注 0票数 3

我正在尝试rubylog,它是Ruby的Prolog。我的目标是在单词之间创建逻辑链接,以挖掘文档之间的联系,否则我可能不会注意到。我今天才开始,我用的是一个同义词检测器。奇怪的是,我似乎已经使同义词规则几乎是对称的和可传递的。

在这个例子中,我试着告诉Prolog‘数学’,‘数学’和‘数学’都是同义词:

代码语言:javascript
复制
require 'rubylog'
include Rubylog::DSL::Constants

Symbol.rubylog_functor :synonym
Symbol.rubylog_functor :synonym_of
X.synonym(Y).if X.synonym_of(Y)
X.synonym(Y).if Y.synonym_of(X)
X.synonym(Z).if X.synonym_of(Y).and Y.synonym_of(Z)   ###########

:math.synonym_of! :mathematics
:mathematics.synonym_of! :maths
puts "Synonyms for math: #{:math.synonym(X).to_a}"
puts "Synonyms for maths: #{:maths.synonym(X).to_a}"
puts "Synonyms for mathematics: #{:mathematics.synonym(X).to_a}"

令我惊讶的是,结果是

代码语言:javascript
复制
Synonyms for math: [:mathematics, :maths]
Synonyms for maths: [:mathematics]
Synonyms for mathematics: [:maths, :math]

我认为问题可能是标记为###########的行使用synonym_of而不是synonym,因此可能没有以递归方式描述规则。但是将该行更改为X.synonym(Z).if X.synonym_of(Y).and Y.synonym(Z)会产生非常奇怪的输出

代码语言:javascript
复制
Synonyms for math: [:mathematics, :maths, :math, :mathematics]
Synonyms for maths: [:mathematics]
Synonyms for mathematics: [:maths, :math, :mathematics]

非常好奇!你认为如何?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-22 16:26:00

您正在为有向图上的传递闭包建模,然后您应该对传递属性使用递归规则,但要防止循环。

我建议的实际方法是显式地为同义词编写一个规则(对不起,我没有rubylog,我正在用SWI-Prolog进行测试):

代码语言:javascript
复制
synonym(X, Z) :- synonyms(X, L), member(Z, L).

synonym_of(math, mathematics).
synonym_of(mathematics, maths).

synonyms(X, Ss) :- synonyms(X, [], Ss).

synonyms(X, Found, R) :-
    ( synonym_of(X, S) ; synonym_of(S, X) ),
    \+ member(S, Found),
    !, synonyms(S, [S|Found], R).
synonyms(_, Found, Found).
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12539523

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档