Я использую GHCi (версия 6.12.3), чтобы немного поиграть с Haskell. Недавно я прочитал о функторах и аппликативных функторах, подумал, что нельзя реализовать что-то похожее на <*>
аппликативных функторов только с использованием примитивов функтора. После некоторого размышления я придумал fmap fmap
, у которого был бы (почти) идеальный тип
Functor f => f (a -> b) -> f (f a -> f b)
или больше в целом
(Functor f1, Functor f2) => f1 (a -> b) -> f1 (f2 a -> f2 b)
Я пытался
let q = fmap fmap
Я получил следующую ошибку
<interactive>:1:8:
Ambiguous type variable `f1' in the constraint:
`Functor f1' arising from a use of `fmap' at <interactive>:1:8-16
Probable fix: add a type signature that fixes these type variable(s)
<interactive>:1:13:
Ambiguous type variable `f' in the constraint:
`Functor f' arising from a use of `fmap' at <interactive>:1:13-16
Probable fix: add a type signature that fixes these type variable(s)
Написание приведенной выше подписи типа, как было предложено, не помогло. Самое безумное, что когда я набрал :t fmap fmap
, я получил эквивалентный тип, как указано выше.
Что я делаю неправильно? Почему fmap fmap
выдает ошибку типа, хотя GHCi находит для нее тип?