Monadability
Jul. 6th, 2006 04:13 pm![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Рассматривая тип
data S a = S a (S a)
я увидел, что его нельзя сделать монадой - не будет работать либо первый, либо второй закон монад. Кто знает, есть ли какие то правила, позволяющие вычислить (или хотя бы почувствовать), что такой то тип не может быть монадой?
no subject
Date: 2006-07-06 12:14 pm (UTC)no subject
Date: 2006-07-06 12:43 pm (UTC)data S a = S a (S a)
return
можно реализовать только как (всякие bottom отбрасываем, разумеется)return x = S x (return x)
Тогда первый закон
return x >>= f == f x
или
(S x (return x)) >>= f == f x
Т.к. тип
x :: forall a. a
, то нам можно только вытащитьx
из одного места этого потока. Логично предположить (первое допущение), что это первый элемент (это второе допущение в написании монады). Первый закон тогда работает, а второй нет:m >>= return == m
m@(S x xs) >>= return = return x /= m
И всё было бы хорошо, если бы (см. первое допущение) можно было бы делать операцию объединения нескольких потоков в один. Как у списка
concat
. Но нельзя из-за их бесконечности. Поэтому первое допущение работает. А следовательно монаду на этом типе реализовать нельзя.no subject
Date: 2006-07-06 12:49 pm (UTC)S (S a) -> S a
, сохраняющей ВСЕ элементы вложенных потоков (из-за их беконечности).no subject
Date: 2006-07-06 12:51 pm (UTC)no subject
Date: 2006-07-06 01:06 pm (UTC)no subject
Date: 2006-07-06 01:52 pm (UTC)Оно? Если да, то первый закон не работает :-/
Тут в чём проблема, чтобы (return x) >>= f был равен f x
Т.е. есть у нас бесконечное кол-во одинаковых (?) бесконечных списков
1 2 3 4 5
1 2 3 4 5
1 2 3 4 5
и нам надо из них получить один 1 2 3 4 5.
За невежество извиняюсь, не подумал о том, что можно так собрать.
no subject
Date: 2006-07-07 07:43 am (UTC)Все три закона работают. Выбираем диагональные элементы (правда меня коробит, что элементы теряются). Об этом шла речь?
no subject
Date: 2006-07-06 01:09 pm (UTC)no subject
Date: 2006-07-07 08:45 am (UTC)