169 похожих чатов

Я читаю про моноид по композиции функций из Data.Monoid instance Monoid

b => Monoid (a -> b) where


и использую его при вычислении (+1)<>(+2)<> 1 , но получаю ошибку. Подскажите почему значение не вычисляется?

5 ответов

23 просмотра

Думаю, стоит посмотреть на определение: instance Monoid b => Monoid (a -> b) where mempty _ = mempty -- If `b` has a specialised mconcat, use that, rather than the default -- mconcat, which can be much less efficient. Inline in the hope that -- it may result in list fusion. mconcat = \fs x -> mconcat $ map (\f -> f x) fs {-# INLINE mconcat #-} mempty выдаёт функцию, которая игнорирует a и всегда выдаёт дефолтное значение (нейтральный элемент) типа b. mconcat берёт список функций fs и аргумент x :: a. Далее к каждой функции f из fs вычисляем f x, результат конкатенируем. Иными словами mconcat [f₁, f₂, …, fᵢ, …, fₙ] x = (f₁ x) <> (f₂ x) <> … <> (fᵢ x) <> … <> (fₙ x) Следовательно, что же будет результатом f = (+1) <> (+2)? f x = (x + 1) <> (x + 2) Поведение этой функции зависит от того, как определён моноид для типа a (x :: a). Допустим, x :: Sum Int, тогда f x будет буквально означать 2x + 3 Допустим, x :: Product Int, тогда f x будет означать (x + 1) * (x + 2). Возможно, вы хотите сделать композицию функций, чтобы получить (+3). Тогда в этом вам поможет оператор (.).

не компилируется, потому что вы пытаетесь склеить моноидом разнородные сущности — функцию и число. значение не вычисляется, отличу что тут нет никакого значения

Nick-By Автор вопроса
void
Думаю, стоит посмотреть на определение: instance M...

я понял в чем проблема: числовые значения делятся на два моноида Sum и Prod. Из головы вылетело, спасибо что напомнили. Вот что мне нужно и работает inc1:: Sum Int -> Sum Int inc1 x = Sum 1 + x inc2:: Sum Int -> Sum Int inc2 x = Sum 2 + x

ошибки две: 1. одну ты уже сам заметил, для чисел есть больше одного моноида (и их даже не два), и поэтому нужно указывать явно ньютайпом 2. вторая - у <> сигнатура :: a -> a -> a - то есть оба аргумента и результат в одном типе, но ты пытаешься склеить функцию и число

Nick-By Автор вопроса
кана
ошибки две: 1. одну ты уже сам заметил, для чисел ...

Вторая ошибка вызвана фактом, что я работаю с аппликативными фунцторами где операция <*> включает и термин

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта