首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >统一算法在haskell中的实现

统一算法在haskell中的实现
EN

Stack Overflow用户
提问于 2011-10-04 06:13:58
回答 1查看 2.6K关注 0票数 8

我正在尝试使用如下指定的算法实现统一函数

代码语言:javascript
复制
unify α α = idSubst
unify α β = update (α, β) idSubst
unify α (τ1 ⊗ τ2) =
    if α ∈ vars(τ1 ⊗ τ2) then
      error ”Occurs check failure”
    else
      update (α, τ1 ⊗ τ2) idSubst
unify (τ1 ⊗ τ2) α = unify α (τ1 ⊗ τ2)
unify (τ1 ⊗1 τ2) (τ3 ⊗2 τ4) = if ⊗1 == ⊗2 then
                                   (subst s2) . s1
                                  else
                                   error ”not unifiable.”
          where s1 = unify τ1 τ3
                s2 = unify (subst s1 τ2) (subst s1 τ4)

其中⊗是类型构造函数{→,×}之一。

然而,我不知道如何在haskell中实现这一点。我该怎么做呢?

代码语言:javascript
复制
import Data.List
import Data.Char

data  Term =   Var String | Abs  (String,Term) | Ap Term Term  | Pair Term Term | Fst Term | Snd Term
        deriving (Eq,Show)

data Op = Arrow | Product deriving (Eq)


data  Type =   TVar  String |  BinType Op  Type   Type
        deriving (Eq)

instance Show Type where
   show (TVar x) = x
   show (BinType Arrow t1 t2) = "(" ++ show t1 ++ " -> " ++ show t2 ++ ")"
   show (BinType Product t1 t2) = "(" ++ show t1 ++ " X " ++ show t2 ++ ")"

type Substitution = String -> Type

idSubst :: Substitution
idSubst x = TVar x

update :: (String, Type) -> Substitution -> Substitution
update (x,y) f = (\z -> if z == x then y else f z)


-- vars collects all the variables occuring in a type expression
vars :: Type -> [String]
vars ty = nub (vars' ty) 
    where vars' (TVar x) = [x]
          vars' (BinType op t1 t2) = vars' t1 ++ vars' t2

subst :: Substitution -> Type -> Type
subst s (TVar x) = s x
subst s (BinType op t1 t2) = BinType op (subst s t1) (subst s t2)

unify :: Type -> Type -> Substitution
unify (TVar x) (TVar y) = update (x, TVar y) idSubst
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-10-04 06:27:20

代码语言:javascript
复制
unify :: Type -> Type -> Substitution
unify (TVar x) (TVar y) = update (x, TVar y) idSubst

这是一个很好的开始!

现在您只需要处理其他情况:

下面是表示第一个问题的方法:

代码语言:javascript
复制
unify (TVar x) (TVar y) | x == y = idSubst

您可以使用模式匹配以类似的方式完成剩下的工作,将Type分解到适当的构造函数和保护中,以处理特定的情况。

Haskell有一个error :: String -> a函数,它的工作原理与上面的伪代码中的一样,if/then/else语法也是一样的,所以您就快成功了!

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7641282

复制
相关文章

相似问题

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