metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2015-07-10 02:01 pm

Хаскель и среднее арифметическое

Вот я хаскель использовал только пару раз и практически его не знаю, но в чем проблема с неэнергичным foldl - помню. Про то, что нужны банг-паттерны внутри тупла - краем уха слышал, но не вникал.
Стеб же на эту тему людей, которые слышали звон, да не знают, где он, меня очень сильно огорчает.
Ладно, айсед критикует - он хотя бы писал на этом и понимает, о чем речь идет. А так - это выглядит как "разработчики на клиппере критикуют SQL за то, что теория множеств".

[identity profile] dr-cha0s.livejournal.com 2015-07-10 02:00 pm (UTC)(link)
Когда нужно обрабатывать гигабайты, редко берутся ленивые списки. Есть conduits и десяток альтернатив с константной памятью и финализацией.

[identity profile] justy-tylor.livejournal.com 2015-07-10 03:48 pm (UTC)(link)
Это не решение, а лишь замена одной стандартной структуры данных на некие альтернативы. Ибо в своём коде у программиста на хаскеле остаются всё те же два печальных варианта.

[identity profile] dr-cha0s.livejournal.com 2015-07-10 04:40 pm (UTC)(link)
Решение чего? Ленивости по умолчанию? Так это фича Хаскела.

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

[identity profile] justy-tylor.livejournal.com 2015-07-10 04:52 pm (UTC)(link)
Именно так, плохой дизайн подобных "фич" резко снижает эффективность инструмента.

[identity profile] dr-cha0s.livejournal.com 2015-07-10 05:54 pm (UTC)(link)
Ок, доказывай на прмерах. И хочется услышать про правильный дизайн ленивости по умолчанию.

[identity profile] justy-tylor.livejournal.com 2015-07-10 06:15 pm (UTC)(link)
Такие вещи нельзя делать по умолчанию. Только явно. Пример более внятного дизайна: Scala.

[identity profile] dr-cha0s.livejournal.com 2015-07-10 06:35 pm (UTC)(link)
Ну ахуеть, ты эксперт. Вот сказал - низя и неебёт. Муллы свинину есть запрещают, так що менi сало не їсти?
Edited 2015-07-10 18:36 (UTC)

[identity profile] justy-tylor.livejournal.com 2015-07-10 06:41 pm (UTC)(link)
Как говорится, ИМХО (имею мнение, хрен оспоришь).

[identity profile] lomeo.livejournal.com 2015-07-11 11:49 pm (UTC)(link)
В Scala задолбаешься делать лениво.

[identity profile] justy-tylor.livejournal.com 2015-07-12 12:08 am (UTC)(link)
С хаскельными привычками - возможно. Но на порядок человечнее, чем в Хаскеле, где задолбаешься сделать энергично.

[identity profile] thesz.livejournal.com 2015-07-12 10:55 am (UTC)(link)
Я редко так выражаюсь, но тем не менее: хера там! Ибо задолбало читать одно и тоже, особенно от людей, которые должны были бы знать лучше.

Я как-то писал пост про внедрение ленивых и энергичных вычислений в, соответственно, энергичные и ленивые языки.

В ленивом языке всё остаётся как есть, только в некоторых местах надо поставить $! или !.

В энергичном языке надо заново переписать всю необходимую библиотеку, поскольку чуть упустив энергичность (оставив энергичный map, например, по любому параметру), мы теряем лень всюду.

Или, зайдя с теоретической стороны: если значение может быть вычислено в call-by-value, оно может быть вычислено и в call-by-need, обратное неверно.

[identity profile] justy-tylor.livejournal.com 2015-07-12 11:38 am (UTC)(link)
Под любые вычисления придётся писать библиотеку. И под энергичные, и под ленивые, и под разные "облачные" реализации. Можно даже пользоваться единым полиморфным map, обёртывающим библиотечные.

Таким образом, те, кому нужна именно хаскелеподобная ленивость, могут себя ею обеспечить. Не беспокоя остальных лишней когнитивной нагрузкой ("думать санками") и дополнительными расходами на отладку "недовычисленности".

[identity profile] thesz.livejournal.com 2015-07-12 04:33 pm (UTC)(link)
Мой основной аргумент остаётся в силе: хера там!

Я тут пописал для всякого разного, включая GPU. Включая сюда мой недавний опыт C# программиста, могу сказать, что ваши позиция не вяжется с моим опытом.

Перейдя с Хаскеля на C# мне приходится "думать в классах и объектах". Какая пакость!

[identity profile] lomeo.livejournal.com 2015-07-14 08:03 am (UTC)(link)
Человечнее это как?

В Haskell сделать энергично можно сверху, не влезая в потроха библиотеки. Сделать же ленивой работу с ленивой структурой в энергичной библиотеке практически невозможно.

[identity profile] justy-tylor.livejournal.com 2015-07-14 12:27 pm (UTC)(link)
Уже отвечал thesz. Для любых вычислений приходится писать свои библиотеки. Усложнять жизнь всем ради поклонников ленивости нет смысла.
Edited 2015-07-14 12:27 (UTC)

[identity profile] lomeo.livejournal.com 2015-07-15 07:25 am (UTC)(link)
Ну, конечно, это неправда. Вот только в этом треде привели пример форсирования свёртки снаружи без влезания в потроха. Так что как минимум не "для любых". Из моего опыта — в подавляющем большинстве случаев этого достаточно.