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

А можете объяснить, почему вот это так вот работает? λ> Just

"a" <> Just "b"
Just "ab"
λ> Right "a" <> Right "b"
Right "a"

То есть почему Either не конкатенируется (как Maybe, например)?

Я интуитивно ожидал, что оно должно как-то так работать:
(<>) er@(Left _) _ = er
(<>) _ er@(Left _) = er
(<>) (Right r1) (Right r2) = Right (r1 <> r2)

И второй тогда вопрос: есть какой-то стандартный класс, который бы работал для Either так, как я ожидал от Semigroup?

7 ответов

5 просмотров

λ> Ap (Right "str") <> Ap (Right "str") Ap {getAp = Right "strstr"} λ> Ap (Right "str") <> Ap (Right "str") <> Ap (Left 12) <> Ap (Right "str") Ap {getAp = Left 12}

instance Semigroup (Either a b) С учётом, что здесь нет ограничений на a и b, нам в x <> y остаётся только что выбирать, что выйдет: x или y. У нас 4 случая (в зависимости от строения x и y). Выбираем что-либо для каждого и проверяем, соблюдаются ли законы полугруппы. Здесь решили так: x<>y |Left Right -----+---------- Left | y y Right| x x Но, предположим, как Вы и хотели, сделано instance Semigroup b => Semigroup (Either a b). Right x <> Right y = Right (x <> y), хорошо. А что делать, если Left x <> Right y? Мы всё равно пришли к тому, что надо просто выбирать что-то одно, не изменяя, в 3 случаях из 4, а 4-й просто дополнительно усложнён. Стоит ли это переусложнение того, чтобы быть имплементированным? Ну, видимо, люди решили, что не стоит.

Ilia-Zemskov Автор вопроса

А это переусложнение чем-то оличается от того, что реализовано в Maybe?

Ilia Zemskov
А это переусложнение чем-то оличается от того, что...

Да: там Nothing идёт без типа. Т.е. там мы к типу только одно значение добавляем, а тут мы два типа складываем. Кстати, как правильно заметил @sand_witch, то "усложнение" всё равно реализовали, но не как основное, а как дополнительное (через Ap).

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

Ilia Zemskov
А это переусложнение чем-то оличается от того, что...

для Maybe решили усложнить, чтобы на сдачу получился простой способ превращения произвольной полугруппы в моноид. простое поведение вынесли в отдельный типы First и Last

Вы можете свой класс сделать по типу семигруп и свой инстанс для Either

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
22
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Карта сайта