March 2026

S M T W T F S
12 34567
891011121314
151617 18192021
22232425262728
293031    

Style Credit

Expand Cut Tags

No cut tags
Thursday, May 5th, 2005 12:10 am
Левенчук пишет, что все серьёзные программисты мечтают программировать на фукнциональных языках. Не знаю, как серьёзные, а у меня лично никогда желания программировать на Лиспе не возникало. Нечеловеческий он какой-то. Пусть ворлоны на нём программируют.
Tags:
Friday, May 6th, 2005 01:24 pm (UTC)
> Показать реализации CL, в которых *НЕТ* корректной хвостовой рекурсии?

дяденька!  окащенять меня бесполезно, я в этом деле нетренированный.  я HyperSpec читал, покуда вы в федошной песочнице друг другу письки показывали и Y-combinator трактовали.

отсутствие хвостовой рекурсии в стандарте CL — это не ¨бяда¨, это вполне сознательный фичер.

> За неё можно простить даже раздельные пространства имён для функций и всего остального

каковые тоже есть сознательные фичеры.  которые мне очень нравятся, кстати.  если бы я всосал Y-combinator с молоком лямбда-матери и был бы академик, моё мнение могло бы быть и другим.  в чём я совершенно не сомневаюсь, впрочем, так это в том что в подобном случае я полностью отдавал бы себе отчёт об отличии академии от реального мира, и не выдавал бы свои предпочтения за истину в последней инстанции.
Friday, May 6th, 2005 01:40 pm (UTC)
> отсутствие хвостовой рекурсии в стандарте CL — это не ¨бяда¨, это вполне сознательный фичер.

Фигнанына. Это ни разу не сознательное, а только лишь вынужденное решение. И практически все *вменяемые* компиляторы CL таки хвостовые рекурсии разворачивают. Однако:

a) закладываться на это НЕЛЬЗЯ, так как "практически" - это не "все"

b) в силу этого, ФУНКЦИОНАЛЬНО писать на CL - тоже нельзя (да и на фиг не надо), всегда, когда глубина рекурсии непредсказуема, она должна заменяться на цикл.

Имеешь что либо супротив возразить - вперёд. Иначе - не хер вякать.
Friday, May 6th, 2005 01:54 pm (UTC)
> Фигнанына. Это ни разу не сознательное, а только лишь вынужденное решение.

создатели стандарта безусловно знали о хвостовой рекурсии, и не стандартизивовали её сознательно.  не потому что не могли, а потому что не хотели.

по крайней мере я склонен интерпретировать публичные высказывания того же Кента Питмана на данную тему именно таким образом (и несложный поиск на Google Groups с соответствующими ключевыми словами мне свидетель).

если есть свидетельства обратного, то давай их сюда.

> практически все *вменяемые* компиляторы CL таки хвостовые рекурсии разворачивают

и правильно делают, ибо это вполне приятная и недорогая для компилятора оптимизация.  но заметь также, что ни один *вменяемый* компилятор не производит этой оптимизации когда (> debug optimize), что характерно.

> в силу этого, ФУНКЦИОНАЛЬНО писать на CL - тоже нельзя (да и на фиг не надо)

золотые слова, в скобочках-то!
Friday, May 6th, 2005 02:12 pm (UTC)
> создатели стандарта безусловно знали о хвостовой рекурсии, и не стандартизивовали её сознательно. не потому что не могли, а потому что не хотели.

Я понял так: не хотели заставлять тех, кто не может. То есть, сочли это не обязательным требованием. Откуда и вышеизложенные выводы.

> но заметь также, что ни один *вменяемый* компилятор не производит этой оптимизации когда (> debug optimize), что характерно.

Да нет, тому же OCaml по сараю, он всегда развернёт.

> золотые слова, в скобочках-то!

Так я вообще не понимаю, об что мы таки спорим. Лисп - не функциональный язык, на Лиспе и нельзя писать чисто функционально, да и не для того он нужен, чтоб чисто функционально писать. С этими утверждениями тут хоть кто-то не согласен?!?
Friday, May 6th, 2005 04:11 pm (UTC)
> Я понял так: не хотели заставлять тех, кто не может.

вполне возможно, что кто-то и не мог.
факта явно осознанного предпочтения это не отменяет.

> тому же OCaml по сараю

а кто говорит про, прости оссподи, O'Caml?

> Так я вообще не понимаю, об что мы таки спорим

а мы не то чтобы и спорим.  просто я пытаюсь пояснить тебе явную неуместность мелкого сектантского миссионерства в данном контексте.  плюс по поводу данной конкретной темы слегка наболело: откуда, по-твоему, у человека ¨знания¨ о лиспе на уровне ¨всюду списки, рекурсия и скобочки¨?  от таких вот умников, которые вместо того чтобы рассказать что-нибудь существенное, с блеском в глазах гонят телеги про хвостовую рекурсию и прочую откровенную (для девственной аудитории) эзотерику.
Friday, May 6th, 2005 04:51 pm (UTC)
вот отличный (а также модерновый и практический, что приятно) текст:
http://www.gigamonkeys.com/book/
Friday, May 6th, 2005 05:02 pm (UTC)
да, и ещё, дабы мне не ощущать себя в настолько идиоцком положении: моей целью в данном треде не являлось кому-либо что-либо продать или кого-либо в чём-либо убедить и направить на путь истинный.
миссионерства я зело не люблю, и считаю что покуда человека изнутри не припекло, морочить ему голову совершенно не нужно и даже бесполезно.
так, зашёл на огонёк, указал на фактические ошибки в посте, а тут ксендзы подтянулись... :)
Friday, May 6th, 2005 05:12 pm (UTC)
Основная идея Лиспа в том, что списки одновременно являются и абстрактным синтаксическим деревом самого Лиспа - то есть, программа по сути неотличима от данных.

Это позволяет нам расширять язык, используя функции, выполняющиеся во время компиляции - то есть, макры.

К примеру, если мы хотим ввести в язык новую конструкцию
APPRIGHT, такую, что код

(APPRIGHT + 1 2 3 4 5) будет компилироваться как
(+ 1 (+ 2 (+ 3 (+ 4 5)))), то мы просто говорим:

(defmacro appright (f &rest args)
(if (null (cdr args)) `(car args)
`(,f ,(car args) (appright ,f ,@(cdr args)))
))

То есть - мы расширяем сам *компилятор* языка. Не нравятся скобочки? Можем заменить синтаксис - см. мою статью, там, правда, Схема, но это без разницы, если кому интересно, дам то же самое для CL.
Friday, May 6th, 2005 07:36 pm (UTC)
В какой статье? Покажи плз пример замены синтаксиса для лиспа.
Friday, May 6th, 2005 10:55 pm (UTC)
В этом треде уже давал ссылку.

Пример (действующий) - http://dslengine.sourceforge.net/
Friday, May 6th, 2005 11:03 pm (UTC)
> через его синтаксис надо продираться.

Не надо. У Лиспа - минимальный синтаксис. S-выражения. Это, с одной стороны, плохо - человекам, или некоторым из них, сложно воспринимать S-выражения или
тот же XML, но с другой стороны это замечательно, потому как синтаксис совпадает с AST языка. Мы видим ровно то, что у него внутри, уже распарсенное.

> Ну, так почему не поменяли, а?

Да поменяли - к примеру, RLisp, весьма известная фишка... Просто это никому не надо - синтаксис S-выражений, на самом деле, близок к идеальному. Это я утверждаю, как полиглот, программировавший практически на всех языках, какие только когда либо существовали, и собственноручно реализовавший множество языков под разные цели. Да, синтаксис того же Хаскелля может завораживать, казаться немерянно удобочитаемым и красивым, синтаксис Java может быть привычным, но по сумме критериев S-выражения лидируют.

> Почему вы не написали тот же appright в более человекопонятной форме?

Потому как тогда там или пришлось бы splice-образную семантику неявно использовать, или явно прописать генерацию S-выражений, что затруднило бы понимаение. Когда и макра, и исходный код, и результат - в одном синтаксисе, понять, что происходит, несколько проще.

> Но в целом, мне кажется, я уловил вашу мысль - что в Лиспе правила, по которым ведётся разбор выражений на языке, поддаются модификации. Вернее, думаю, всё же расширению?

Не только разбор. Ещё и все этапы компиляции и оптимизации. Изменять (не только расширять, но и ограничивать) можно абсолютно всё.

> И что среда исполнения Лисп включает в себя компилятор и исполнитель кода (что, понятно, не есть уникальное свойство Лиспа).

Не совсем так. Компилятор Лиспа включает в себя среду исполнения. Обратное не обязательно (ну да, есть любители попользовать eval, но я не из их числа).
Friday, May 6th, 2005 11:34 pm (UTC)
> Если язык Лисп-VM не скрывает сложности этой самой VM, так ли это хорошо?

Поскольку существенная часть Лисп-программы - это код, который читает Лисп-программы и пишет Лисп-программы, то однозначность отображения синтаксиса на AST тут весьма полезна.

> Или вы скажете, что существует синтаксис, идеальный для описания - чего угодно?

Существует синтаксис, *достаточный* для описания чего угодно. Это - S-выражения. Аналог, ужасно громоздкий и нелепый, но столь же универсальный - XML. Не знаю, на фига XML придумали, когда были S-выражения, ну да ладно...

При этом, такой синтаксис относительно легко воспринимается человеком - он вполне естественный, и, что немаловажно, примитивный, его легко изучить и легко читать.

> А какие, опять же, критерии-то?

- Универсальность - не должно быть конструкций, принципиально невыразимых в этом синтаксисе, и не должно быть конструкций, которые было бы сложно отобразить на такой синтаксис.

- Ортогональность. Не должно быть взаимозаменяемых элементов.

- Минимальность. Лишние элементы только отвлекают.

- Возможности для редактора или IDE проявить немерянный интеллект. Для S-выражений их - полно, для сложных синтаксисов - приходится bovinator-ы всякие рисовать - кошмар...

- Однозначность отображения на внутреннее представление. S-выражения тривиально переводятся в двоичные деревья, и наоборот.


(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 08:33 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 09:20 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 10:31 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 11:11 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 11:22 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 11:42 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 12:23 pm (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-10 05:48 pm (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-10 06:29 pm (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-09 06:46 pm (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-10 10:09 am (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-10 11:33 am (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-09 06:44 pm (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 11:19 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-08 11:32 am (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-09 06:41 pm (UTC) - Expand

(no subject)

[identity profile] mauhuur.livejournal.com - 2005-05-10 11:26 am (UTC) - Expand

(no subject)

[identity profile] cmm.livejournal.com - 2005-05-10 05:11 pm (UTC) - Expand
Friday, May 6th, 2005 11:05 pm (UTC)
Похоже, опечатка где-то, не проверял, когда писал. Гарантированно работает вот это:

(defmacro appright (fn &rest args) (if (null (cdr args)) (car args) `(,fn ,(car args) (appright ,fn ,@(cdr args)))))
Friday, May 6th, 2005 05:02 pm (UTC)
Блин. Тема такая - Лисп - ни разу не функциональный язык, и в Лиспе нельзя не пользоваться императивными возможностями. Это - ответ на вопрос тов. stas-а. Предложение не пугать человека хвостовыми рекурсиями выглядит в этом контексте, мягко гойворя, странным.
Friday, May 6th, 2005 05:15 pm (UTC)
> Лисп - ни разу не функциональный язык

угу.

> в Лиспе нельзя не пользоваться императивными возможностями

а каким боком циклы обязательно "императивны", не подскажешь?
(то есть про необходимость как-то ¨деструктивно¨ апдейтить переменные, в которых сидит loop state, я вполне понимаю.  но считать на данном основании любой цикл императивным — чистой воды академическое крючкотворство, и ты это, надеюсь, прекрасно понимаешь.  если подходить с подобной логикой, то функциональных языков вообще в природе нету, поскольку всё в конце концов превращается в ни разу не функциональный Мойшинный Кодъ).

> Предложение не пугать человека хвостовыми рекурсиями выглядит в этом контексте, мягко гойворя, странным

и пойчему?  показывать собственную образованность — это одно, а пытаться что-то действительно объяснить (в смысле так чтобы поняли и не ушли в несущественные дебри) — другое.
Friday, May 6th, 2005 05:21 pm (UTC)
> а каким боком циклы обязательно "императивны", не подскажешь?

Таким, что неимперативный цикл сводится к хвостовой рекурсии.

> но считать на данном основании любой цикл императивным — чистой воды академическое крючкотворство, и ты это, надеюсь, прекрасно понимаешь.

Это крючкотворство абсолютно необходимо, когда ты пишешь компиляторы. Практика требует. Есть в конструкции сайд-эффект - теряем сразу огромное количество возможностей статического анализа и оптимизаций, нет сайд-эффектов - делаем с ней всё, что угодно.

> если подходить с подобной логикой, то функциональных языков вообще в природе нету, поскольку всё в конце концов превращается в ни разу не функциональный Мойшинный Кодъ).

Зависит от того, на каком этапе компиляции эта неиллюзорная мойшинная императивность вылезает. Разница чисто практическая, в удобстве анализа и оптимизации.
Friday, May 6th, 2005 05:30 pm (UTC)
> Это крючкотворство абсолютно необходимо, когда ты пишешь компиляторы

что является типичным времяпровождением любого практикующего программиста, не так ли?
Friday, May 6th, 2005 05:42 pm (UTC)
В идеале так и должно быть.

Каждая большая задача лучше всего решается именно таким образом: придумывается язык, заточенный под предметную область этой задачи, пишетя абы какая его реализация, задача в пол-пинка решается, заказчик почти-доволен, пишем эффективную реализацию языка.

Интересно, что ты считаешь за среднестатическое промышленное программирование?
Friday, May 6th, 2005 05:56 pm (UTC)
ОК, тупик, пора хорошенько определиться с терминами.
тут надо с 17-го году начинать, видимо.
накатаю отдельный пост, вот только ребёнка спать отложу...