gpt4 book ai didi

Haskell Typeclass 速记

转载 作者:行者123 更新时间:2023-12-03 11:32:47 28 4
gpt4 key购买 nike

因此,我有一对类型类,我将经常一起使用它们,并且我想避免每次都指定它们。基本上,而不是把

:: (Ord a, Fractional a, Ord b, Fractional b, ... Ord z, Fractional z) =>

在我所有类型规范的开头,我宁愿把
:: (OrdFractional a, OrdFractional b, ... OrdFractional z)

所以,我最初的想法是声明一个新的类型类
module Example where

class (Fractional a, Ord a) => OrdFractional a

example :: (OrdFractional a, OrdFractional b) => (a,b) -> (a,b) -> (a,b) -> Bool
example (x1,y1) (x2,y2) (x3,y3) = (x1/x2 < x2/x3) && (y1/y2 < y2/y3)

但这并没有像我希望的那样自动工作:
% ghci
Prelude> :l Example.hs
Ok, modules loaded: Example.
Prelude Example> example (1::Float,3::Float) (2,2) (3,1)

<interactive>:1:0:
No instance for (OrdFractional Float)
arising from a use of `example' at <interactive>:1:0-39
Possible fix:
add an instance declaration for (OrdFractional Float)
In the expression: example (1 :: Float, 3 :: Float) (2, 2) (3, 1)
In the definition of `it':
it = example (1 :: Float, 3 :: Float) (2, 2) (3, 1)

手动创建实例似乎很麻烦,所以接下来,我想我可能会尝试自动创建实例:
module Example where

class OrdFractional a
instance (Fractional a, Ord a) => OrdFractional a

example :: (OrdFractional a, OrdFractional b) => (a,b) -> (a,b) -> (a,b) -> Bool
example (x1,y1) (x2,y2) (x3,y3) = (x1/x2 < x2/x3) && (y1/y2 < y2/y3)

但是编译器不喜欢这样:
ghc -c Example.hs

Example.hs:4:0:
Illegal instance declaration for `OrdFractional a'
(All instance types must be of the form (T a1 ... an)
where a1 ... an are type *variables*,
and each type variable appears at most once in the instance head.
Use -XFlexibleInstances if you want to disable this.)
In the instance declaration for `OrdFractional a'

那么有没有办法我可以做到这一点?

最佳答案

随着 GHC 7.4 中引入的 ConstraintKinds 扩展,约束现在是类型 Constraint , 所以你可以使用普通类型的同义词来得到你想要的:

{-# LANGUAGE ConstraintKinds #-}

type OrdFractional a = (Ord a, Fractional a)

关于Haskell Typeclass 速记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/306284/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com