Когда у меня есть функция типа типа
f :: (Ord a) => a -> a -> Bool
f a b = a > b
Мне бы хотелось сделать функцию, которая не переносит эту функцию.
например. выполните функцию, подобную этой
g :: (Ord a) => a -> a -> Bool
g a b = not $ f a b
Я могу сделать комбинатор вроде
n f = (\a -> \b -> not $ f a b)
Но я не знаю, как.
*Main> let n f = (\a -> \b -> not $ f a b)
n :: (t -> t1 -> Bool) -> t -> t1 -> Bool
Main> :t n f
n f :: (Ord t) => t -> t -> Bool
*Main> let g = n f
g :: () -> () -> Bool
Что я делаю неправильно?
И бонусный вопрос, как я могу это сделать для функции с большим количеством параметров и, кроме того,
t -> Bool
t -> t1 -> Bool
t -> t1 -> t2 -> Bool
t -> t1 -> t2 -> t3 -> Bool