- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在swi-prolog中有一个程序,里面有一个operator(?) ->,第一次遇到,不知道是干什么的。有一段代码,我不明白:
swf([PP->Q|F], [PP|L], X):- swf(F, L, X), axioms(X, PP->Q, F).
我发现当我们有
X -> Y ; Z
然后,如果 X 为真,则执行 Y,否则执行 Z。但我不明白它在上面显示的情况下是如何工作的。
提前致谢。
编辑:
老实说,这是 Arrow 定理的计算机辅助证明的一部分(更准确地说是基本情况),这是完整的代码(来自 PROLOG 的 Proving Arrow 定理,Kenryo Indo):
p(Q) :- permutation(Q, [a, b, c]).
p((X, Y), Q) :- p(Q), append(_, [X|B], Q), member(Y, B).
pp((Q1,Q2)) :- p(Q1), p(Q2).
all_pp(L) :- findall(QQ, pp(QQ), L).
axioms(arrow, V, F) :- p(Q), V=(PP->Q), pareto(V), iia(V, F).
swf([], [], _).
swf([PP->Q|F], [PP|L], X):- swf(F, L, X), axioms(X, PP->Q, F).
swf(F, X) :- all_pp(L), swf(F, L, X).
pp(XY, agree, (Q1,Q2)) :- p(XY, Q1), p(XY, Q2).
pp((X, Y), opposite, (Q1, Q2)) :- p((X, Y), Q1), p((Y, X), Q2).
pareto(PP->R) :- \+ (pp(XY, agree, PP), \+ p(XY, R)).
dictator(J, F) :- member(J:PP, [1:(P, _), 2:(_, P)]),
\+ (member(PP->R, F), pp(_, opposite, (P, R))).
agree(+, XY, QQ) :- pp(XY, agree, QQ).
agree(-,(X,Y), QQ) :- pp((Y, X), agree, QQ).
iia(PP->R, F) :- \+ (F \= [], pp(XY, A, PP), member(QQ->S, F),
pp(XY, A, QQ), \+ agree(_, XY, (R, S))).
仍然,我不知道如何治疗 ->。 X->Y 有一个用法链:swf - axioms - pareto 和 swf - iia - member。
最佳答案
在 Prolog 中,运算符只是嵌套术语的语法糖。
即我们可以写 is(X, +(1,2))
而不是写 X is 1+2
因为有适当的 op/3 ( is)/2 和 +
的声明。另一个故事是与这些术语相关的解释。按照我的示例,某处会有一个子句,例如is(X, V) :- eval_expression(V, X)。
当用作 < em>目标,但在您显示的代码中它用作模式选择器,可能。 IE。如果还有其他子句 swf/3,则有可能使用该表达式调用 axioms/3,我猜这意味着 implication。
HTH
编辑 这里是放置在 SWI-Prolog IDE 中的代码图片。语法颜色显示两个问题:
似乎 dictator/2 是入口子句。我不知道这个定理(我无权访问文档),但我希望有一个关于社会实体的断言。
第一个问题不存在,因为pareto/1中会用到PP。真正的问题应该是 swf 缺少参数,应该读作 swf(F, L, X) :- ...
,但这会导致循环。
关于prolog - swi-prolog 中 -> 的含义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15031203/
这个问题在这里已经有了答案: Towards the "true" definition of JAVA_HOME (5 个答案) 关闭 4 年前。 为什么 ActiveMQ 提供者需要设置 JAV
这个问题在这里已经有了答案: What is a lambda expression in C++11? (10 个答案) 关闭 8 年前。 这是来自 boosts asio 的一个例子。这是什么意
这个问题在这里已经有了答案: What does the double colon (::) mean in CSS? (3 个答案) 关闭 7 年前。 我经常看到这种用法。特别是伪类。“::”在
嗨,另一个愚蠢的简单问题。我注意到在Apple框架中的某些typedef中使用符号"<<"谁能告诉我这是什么意思?: enum { UIViewAutoresizingNone
someObject.$() 是什么意思? 我正在浏览 sapui5 工具包中的 tilecontainer-dbg 文件,发现了这个: var oDomRef = this.$(); or some
这个问题已经有答案了: How to interpret function parameters in software and language documentation? (4 个回答) 已关闭
我遇到过这个语法。任何人都可以解释一下 getArg1ListInfo:()=>(object.freeze(arg1)) 的含义 function foo (arg1,arg2) { let
对于子类,我有以下代码: class child1 : public parent { public: static parent* function1(void) { ret
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 1 年前。 我有一部分代码包含以下功能: void Keyb
以下在 C++ 中是什么意思? typedef PComplex RComplex [100]; 请注意,PComplex 是我代码中的用户定义类型。 谢谢 最佳答案 RComplex 是 PComp
在我的 Lisp 代码中,我有函数 (nfa-regex-compile),它创建一个包含初始状态、转换和最终状态的 cons 列表(表示自动机的节点)从作为参数给出的正则表达式开始。 在这种情况下,
以下文字摘自 Learning Spark 第 3 章 One issue to watch out for when passing functions is inadvertently seria
PHP 文档 block 中以下内容的含义是什么: #@+ zend框架代码中的一个例子: /**#@+ * @const string Version constant numbers */ c
由于 python 的一些版本控制问题,我必须使用自定义函数来比较 HMAC (SHA512)。为此,我找到了这个函数: def compare_digest(x, y): if not (i
取自this answer here : static const qi::rule node = '{' >> *node >> '}' | +~qi::char_("{}"); 请注意,声明了名称
我正在查看 chi 包的文档。我看到类似的东西: https://github.com/pressly/chi/blob/master/_examples/rest/main.go#L154 data
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
这个问题在这里已经有了答案: 关闭9年前。 Possible Duplicate: Does “/* (non-javadoc)” have a well-understood meaning? 以下
在 Prolog 代码中,可以使用“ headless ”Horn 子句将指令传递给编译器,这些子句与指向左侧的物质蕴涵 ':-' (⇐) 的左侧没有头部关系。例如,导入模块或声明 Unit Test
我是一名优秀的程序员,十分优秀!