SML函数参数模式匹配

时间:2012-09-08 15:45:54

标签: functional-programming logic sml smlnj

我在传递给函数的参数上使用模式匹配。该方法适用于“第一级”匹配,所以说,但任何更深入的尝试都会产生错误“标准:282.5-291.77错误:匹配多余

例如

fun nnf T = T
    | nnf F = F
    | nnf (LETTER(x)) = (LETTER(x))
    | nnf (NEG(x)) = (NEG(nnf x))
    | nnf (AND(x,y)) = (AND(nnf x, nnf y))
    | nnf (OR(x,y)) = (OR(nnf x, nnf y))
    | nnf (IMP(x,y)) = (OR(NEG(nnf x),(nnf y)))
    | nnf (NEG(NEG(LETTER(x)))) = (LETTER(x))
    | nnf (NEG(AND(LETTER(x),LETTER(y)))) = (OR(NEG(LETTER(x)),NEG(LETTER(y))))
    | nnf (NEG(OR(LETTER(x),LETTER(y)))) = (AND(NEG(LETTER(x)),NEG(LETTER(y))));
val nnf = fn : prop -> prop

我得到的错误是

stdIn:282.5-291.77 Error: match redundant
          T => ...
          F => ...
          LETTER x => ...
          NEG x => ...
          AND (x,y) => ...
          OR (x,y) => ...
          IMP (x,y) => ...
    -->   NEG (NEG (LETTER x)) => ...
    -->   NEG (AND (LETTER x,LETTER y)) => ...
    -->   NEG (OR (LETTER x,LETTER y)) => ...

所以SML说函数定义中的最后3个子句是相同的,因为它们都以“(NEG(......”)开头,即使后面的内容不同。

我该如何克服这个?

1 个答案:

答案 0 :(得分:4)

案例NEG(x)已涵盖涉及最外层NEG的任何可能案件,因此其他案件从未到达。根据您实际想要实现的目标,移除该情况,或者在更具体的情况下移动它(按顺序尝试案例)。