说我有2个CNF逻辑短语a,b,我的发布函数应该返回a | b(a OR b)的CNF格式。
取代我所掌握的规则是:
1) Replace p|(q&r) by (p|q)&(p|r)
2) Replace (q&r)|p by (q|p)&(r|p)
以这种方式定义的道具:
datatype prop = Atom of string | Not of prop | And of prop*prop | Or of prop*prop;
功能:
local
fun doOr(prop1,prop2) = (Or(prop1,prop2))
fun distrib1 (Or(Atom(sName1),Atom(sName2) ) ) = Or(Atom(sName1), Atom(sName2) )
|distrib1 (Or(Not(Atom(sName1) ),Atom(sName2) ) ) = Or(Not(Atom(sName1) ), Atom(sName2) )
| distrib1 (Or(Atom(sName1),Not(Atom(sName2) ) ) ) = Or(Atom(sName1), Not(Atom(sName2) ) )
| distrib1 (Or(Not(Atom(sName1)),Not(Atom(sName2) ) ) ) = Or(Not(Atom(sName1)), Not(Atom(sName2) ) )
| distrib1 (Or(prop1,And(prop2,prop3) ) ) = And( distrib1(Or(prop1,prop2) ), distrib1(Or(prop1,prop3) ) )
| distrib1 (Or(And(prop1, prop2), prop3) ) ) = And( distrib1(Or(prop1,prop3) ), distrib1(Or(prop2,prop3) ) )
in
fun distrib (prop1,prop2) = distrib1(doOr(prop1,prop2) );
end;
好吧,我不知道函数本身是否正确,虽然我刚刚完成了所有的基本选项和替换规则,但是现在当在distrib1函数之后出现EQALOP并且出现构造函数错误时,我得到了上述错误分布函数。
为什么我会收到这些错误?我不确定但也许我应该使用let而不是local,但是我怎样才能将它转换为let结构?
感谢。
答案 0 :(得分:2)
在distrib1
的最后一个案例中,您总共有3个空心括号,但有4个结束:
| distrib1 (Or(And(prop1, prop2), prop3) ) ) =
这就是您收到有关RPAREN的语法错误的原因。
您在distrib
中收到错误,因为由于语法错误而未定义distrib1
,因此它是一个未知变量。修复distrib1
中的语法错误也会解决这个问题。