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

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

b => Monoid (a -> b) where


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

5 ответов

20 просмотров

Думаю, стоит посмотреть на определение: 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. одну ты уже сам заметил, для чисел ...

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта