немного математики, логики и программирования
1. Эта запись о работе со степенными рядами в Хаскеле напомнила мне, почему я влюбился в этот язык, когда изучал его два года назад (увы, с тех пор с ним не работал). Это неверноятно прекрасно - когда можешь определить функции вот так, и оно просто будет работать:
integral fs = 0 : (int1 fs 1) where
int1 (g:gs) n = g/n : (int1 gs (n+1))
expx = 1 + (integral expx)
sinx = integral cosx
cosx = 1 - (integral sinx)
2. Знаете ли вы, что можно составить сархивированный файл, который разворачивается сам в себя? Ссылка на файл selfgz.gz в этом старом сообщении не работает, но его можно скачать отсюда.
3. Вот эта запись в n-category cafe, и особенно статья, которую она упоминает - очень и очень интересны, но бедный мой мозг, кажется, с ними сейчас не справляется. Сносит крышу.
integral fs = 0 : (int1 fs 1) where
int1 (g:gs) n = g/n : (int1 gs (n+1))
expx = 1 + (integral expx)
sinx = integral cosx
cosx = 1 - (integral sinx)
2. Знаете ли вы, что можно составить сархивированный файл, который разворачивается сам в себя? Ссылка на файл selfgz.gz в этом старом сообщении не работает, но его можно скачать отсюда.
3. Вот эта запись в n-category cafe, и особенно статья, которую она упоминает - очень и очень интересны, но бедный мой мозг, кажется, с ними сейчас не справляется. Сносит крышу.
no subject
GHCi, version 6.8.1:
*Main> :t integral
integral :: (Fractional t) => [t] -> [t]
Как мы можем передавать функцию вместо [t]? Если добавить еще и экспоненту, то получаю:
Main.hs:10:7: No instance for (Num [t]) arising from the literal `1' at Main.hs:10:7 Possible fix: add an instance declaration for (Num [t]) In the first argument of `(+)', namely `1' In the expression: 1 + (integral expx) In the definition of `expx': expx = 1 + (integral expx)Моих знаний Хаскелля не хватает, чтобы разобраться с этим, однако все равно видно, что в int1 первый аргумент разбирается как лист. Попытка изменить expx так, чтобы она возращала лист, хоть и скомпилировалась, но показывает погоду на Марсе. У Вас этот фрагмент кода скомпилировался?
no subject
no subject
no subject
no subject
no subject
no subject
можно на питоне подобное написать, с генераторами вместо ленивых списков.
получается, правда, не так красиво:
integral = lambda s, c0=0: chain([c0], (c/(n+1.) for n,c in enumerate(s))) def exp(): for x in integral(exp(), 1.): yield xno subject
no subject
no subject
1)
что это за страх такой?
для чего-нибудь из фортрана или его друзей?
Re: 1)
no subject
no subject
> Это шутка или правда что ли? :)
$ gzcat selfgz.gz > selfgz
$ uname -mr
8.11.0 Power Macintosh
— работает.
no subject
no subject
no subject
no subject
no subject
Изучать же категории я по-прежнему рекомендую по Categories for the Working Mathematician.
no subject
Соответственно, вся Розетта схлопывается в точку, что не есть интересно.
no subject
в блогах пишут или скоро напишут). Только где там у них в статье содержание? На первый взгляд -- известные общие мутные идеи + куски из учебников?
no subject
no subject
т.к. кажется, что некуда. Но если есть какое-то конкретное место, в которое можно было бы, то скажи какое, буду всячески благодарен.
no subject
no subject
no subject
no subject
no subject
(Anonymous) 2008-02-26 07:43 am (UTC)(link)no subject