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

Я читаю книжкуHaskell Programming и не совсем понял вот это

предложение: "Applicative, we saw, is a monoidal functor, and gives us a way to
transform any values contained within a structure using a function
that is also embedded in structure. This means that each application
produces the effect of adding structure which is then applicatively
combined."

Мне кажется что добавления структуры (adding structure) не происходит, а структура остается той же, но добавлются новые значения. Чтобы структура добавилась мы должны по меньшей мере испльзывать либо новый тип либо новы конструктор, например A1 x <*> А2 y = A3 z. Если А1, А2, А3 имеют один и тот же тип (или конструктор) то никакого наращивания структуры не проишодит. Как минимум должно быть А3 не равно А1 и А2 на уровне типов (кнострукторов). Теоритически это возможно цтобы результатом действия <*> был новый тип ( через type family), но это не типично ( не правда ли, посколько требует определениия аппликатива н семействе типов?)/ поскажите что автор имелл ввиду под трмином приращение структуры (adding structure). Applicative почти что моноид, то из самого определения мноида структура не добавляется. Если мы "сложим два элемента моноида, то получим третий элемент, структурно не отличающийся от "слагаемых" Да эффект наращивается но структура (контэинер) остается неизменной

8 ответов

65 просмотров

может быть что-то подобное? [(2*),(2+)] <*> [1,2,3] > [2,4,6,3,4,5]

Похоже, имеется в виду, что добавляется аппликативная структура над обычными значениями

Лично я просто использую аппликатив, когда мне не нужно, чтобы вычисления зависели друг от друга по результатам.

TOV_MULTIMASSO
Лично я просто использую аппликатив, когда мне не ...

а не наоборот? когда зависят друг от друга — монада, когда не зависят, аппликатив

Nick-By Автор вопроса
TOV_MULTIMASSO
Лично я просто использую аппликатив, когда мне не ...

Не могли бы вы привести пример, когда вычисления зависят друг от друга в начале, но не зависят по результатам. Мне приходит в голову Функтор Either . Когда в процессе вычислений проишодит ошибка, и значение или домайн функции отбрасывается.

Nick By
Не могли бы вы привести пример, когда вычисления з...

лучше сказать мы знаем зависимости статически

Nick By
Не могли бы вы привести пример, когда вычисления з...

fmap :: (a -> b) -> f a -> f b ^ можем только модифицировать "результат" (<*>) :: f (a -> b) -> f a -> f b ^ функция , "возвращаемая" из f (a -> b), не может знать про эффекты f a, т.к., она чистая (>>=) :: f a -> (a -> f b) -> f b ^ a -> f b теперь может зависеть от эффектов, так как из неё возвращается f b

Nick By
Не могли бы вы привести пример, когда вычисления з...

«зависят друг от друга в начале, но не зависят по результатам» что это вообще значит? можно пример?

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
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
Карта сайта