<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	xmlns:georss="http://www.georss.org/georss" xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#" xmlns:media="http://search.yahoo.com/mrss/"
	>

<channel>
	<title>Андрей Власовских</title>
	<atom:link href="http://vlasovskikh.wordpress.com/feed/" rel="self" type="application/rss+xml" />
	<link>http://vlasovskikh.wordpress.com</link>
	<description>Блог Андрея Власовских</description>
	<lastBuildDate>Wed, 02 Feb 2011 22:11:35 +0000</lastBuildDate>
	<language>ru</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.com/</generator>
<cloud domain='vlasovskikh.wordpress.com' port='80' path='/?rsscloud=notify' registerProcedure='' protocol='http-post' />
<image>
		<url>http://s2.wp.com/i/buttonw-com.png</url>
		<title>Андрей Власовских</title>
		<link>http://vlasovskikh.wordpress.com</link>
	</image>
	<atom:link rel="search" type="application/opensearchdescription+xml" href="http://vlasovskikh.wordpress.com/osd.xml" title="Андрей Власовских" />
	<atom:link rel='hub' href='http://vlasovskikh.wordpress.com/?pushpress=hub'/>
		<item>
		<title>Мой новый зимний блог</title>
		<link>http://vlasovskikh.wordpress.com/2009/12/01/%d0%bc%d0%be%d0%b9-%d0%bd%d0%be%d0%b2%d1%8b%d0%b9-%d0%b7%d0%b8%d0%bc%d0%bd%d0%b8%d0%b9-%d0%b1%d0%bb%d0%be%d0%b3/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/12/01/%d0%bc%d0%be%d0%b9-%d0%bd%d0%be%d0%b2%d1%8b%d0%b9-%d0%b7%d0%b8%d0%bc%d0%bd%d0%b8%d0%b9-%d0%b1%d0%bb%d0%be%d0%b3/#comments</comments>
		<pubDate>Tue, 01 Dec 2009 00:28:56 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[blog]]></category>
		<category><![CDATA[meta]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=223</guid>
		<description><![CDATA[Друзья, поздравляю вас с началом календарной зимы! Внимание: C декабря 2009 я начинаю вести блог на другом сайте — http://vlan.tumblr.com/. Пока что кажется, что Tumblr.com удобнее WordPress.com. Переезд моего блога пока временный: будем считать, что на зиму, а там посмотрим. Прошу вас подписаться на ленту новостей нового блога! Tagged: blog, meta<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=223&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Друзья, поздравляю вас с началом календарной зимы!</p>
<p><strong>Внимание:</strong> C декабря 2009 я начинаю вести блог на другом сайте — <a href="http://vlan.tumblr.com/">http://vlan.tumblr.com/</a>. Пока что кажется, что Tumblr.com удобнее WordPress.com. Переезд моего блога пока временный: будем считать, что на зиму, а там посмотрим. Прошу вас <strong>подписаться</strong> на <a href="http://vlan.tumblr.com/rss">ленту новостей</a> нового блога!</p>
<br /> Tagged: blog, meta <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/223/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/223/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/223/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=223&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/12/01/%d0%bc%d0%be%d0%b9-%d0%bd%d0%be%d0%b2%d1%8b%d0%b9-%d0%b7%d0%b8%d0%bc%d0%bd%d0%b8%d0%b9-%d0%b1%d0%bb%d0%be%d0%b3/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Пакеты Python: distutils или setuptools</title>
		<link>http://vlasovskikh.wordpress.com/2009/10/06/distutils-or-setuptools/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/10/06/distutils-or-setuptools/#comments</comments>
		<pubDate>Tue, 06 Oct 2009 12:33:42 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[deployment]]></category>
		<category><![CDATA[distutils]]></category>
		<category><![CDATA[funcparserlib]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[setuptools]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=215</guid>
		<description><![CDATA[Недавно в обсуждении одного бага funcparserlib всплыла тема установки пакетов Python. Раньше я пользовался модулем setuptools и частично связанной с ним утилитой easy_install. Однако из-за проблем с ним я решил попробовать использовать модуль distutils, идущий в поставке Python и являющийся официальным способом установки пакетов Python. Есть разные претензии к setuptools (см. посты в блогах Brett [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=215&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Недавно в обсуждении <a href="http://code.google.com/p/funcparserlib/issues/detail?id=4">одного бага</a> <a href="http://code.google.com/p/funcparserlib/"><code>funcparserlib</code></a> всплыла тема установки пакетов Python. Раньше я пользовался модулем <a href="http://peak.telecommunity.com/DevCenter/setuptools"><code>setuptools</code></a> и частично связанной с ним утилитой <a href="http://peak.telecommunity.com/DevCenter/EasyInstall"><code>easy_install</code></a>. Однако из-за проблем с ним я решил попробовать использовать модуль <a href="http://docs.python.org/library/distutils.html"><code>distutils</code></a>, идущий в поставке Python и являющийся официальным способом установки пакетов Python.</p>
<p>Есть разные претензии к <code>setuptools</code> (см. посты в блогах <a href="http://sayspy.blogspot.com/2009/10/everyone-should-switch-to-distribute.html">Brett Cannon</a> и <a href="http://www.b-list.org/weblog/2008/dec/14/packaging/">James Bennett</a>), Здесь я кратко скажу о моих собственных. Во-первых, <code>setuptools</code> не создаёт промежуточные каталоги при <code>setup.py install</code>. Во-вторых, интерпретатор Python при старте сканирует слишком много файлов и каталогов. Возможно, это связано с форматом пакетов eggs модуля <code>setuptools</code>, хотя может и нет. Наконец, <code>setuptools</code> привносит дополнительную сложность по сравнению с <code>distutils</code>, а пользы от него — только в более простой установке скриптов, команде <code>setup.py develop</code> и описании зависимостей.</p>
<p>Все эти вещи можно сделать и без <code>setuptools</code>. Скрипты можно ставить обычным копированием с помощью <code>distutils</code>. Команду <code>develop</code> можно заменить созданием символьной ссылки из каталога в <code>PYTHONPATH</code> на каталог разработки.  В плане зависимостей интересна утилита <a href="http://pip.openplans.org/"><code>pip</code></a>, но пока что <code>easy_install</code> кажется удобнее.</p>
<br /> Tagged: deployment, distutils, funcparserlib, python, setuptools <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/215/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/215/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/215/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=215&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/10/06/distutils-or-setuptools/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Непрерывная сборка с inotify-tools</title>
		<link>http://vlasovskikh.wordpress.com/2009/09/20/continuous-build-with-inotify-tools/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/09/20/continuous-build-with-inotify-tools/#comments</comments>
		<pubDate>Sun, 20 Sep 2009 14:37:29 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[inotify]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[tool]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=199</guid>
		<description><![CDATA[Из этого поста узнал о программе inotify-tools. Теперь порой использую утилиту inotifywait для постоянной сборки моего проекта при изменении каких-нибудь его файлов. Например, вот небольшой скрипт, позволяющий видеть отрендеренную версию статьи всё время при её редактировании: #!/bin/sh while true; do inotifywait -e MOVE_SELF,MODIFY,CLOSE_WRITE ../wiki/*.md img/* sleep 1 make --quiet done Очень удобная штука! Вопрос: насколько [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=199&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Из <a href="http://sovety.blogspot.com/2009/08/monitor-file-changes-in-shell-script.html">этого поста</a> узнал о программе <a href="http://inotify-tools.sourceforge.net/">inotify-tools</a>. Теперь порой использую утилиту <code>inotifywait</code> для постоянной сборки моего проекта при изменении каких-нибудь его файлов. Например, вот небольшой скрипт, позволяющий видеть отрендеренную версию статьи всё время при её редактировании:</p>
<pre><code>#!/bin/sh

while true; do
    inotifywait -e MOVE_SELF,MODIFY,CLOSE_WRITE ../wiki/*.md img/*
    sleep 1
    make --quiet
done

</code></pre>
<p>Очень удобная штука!</p>
<p>Вопрос: насколько правильно при каждом сохранении выполнять анализ корректности программы/статьи? Можно смотреть на это так. Либо это заставляет больше стараться, чтобы при каждом сохранении иметь синтаксически корректную программу, либо добавляет ответственности при написании кода и упорядочивает мысли.</p>
<br /> Tagged: inotify, linux, tool <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/199/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/199/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/199/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=199&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/09/20/continuous-build-with-inotify-tools/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Курс по языкам программирования осенью 2009</title>
		<link>http://vlasovskikh.wordpress.com/2009/09/04/lang-2009-announce/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/09/04/lang-2009-announce/#comments</comments>
		<pubDate>Fri, 04 Sep 2009 08:56:36 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[lang]]></category>
		<category><![CDATA[spbstu]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=193</guid>
		<description><![CDATA[В осеннем семестре 2009 я читаю лекции по языкам программирования на кафедре АиВТ в Политехе. На странице курса я буду выкладывать слайды и другие материалы по курсу. За обновлениями можно следить через блог курса. Tagged: lang, spbstu<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=193&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>В осеннем семестре 2009 я читаю <a href="http://aivt.ftk.spbstu.ru/2009/course/lang/">лекции по языкам программирования</a> на <a href="http://aivt.ftk.spbstu.ru/">кафедре АиВТ</a> в Политехе. На странице курса я буду выкладывать слайды и другие материалы по курсу. За обновлениями можно следить через <a href="http://aivt.ftk.spbstu.ru/2009/course/lang/blog/">блог курса</a>.</p>
<br /> Tagged: lang, spbstu <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/193/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/193/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/193/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=193&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/09/04/lang-2009-announce/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Функциональные комбинаторы парсеров в Python</title>
		<link>http://vlasovskikh.wordpress.com/2009/07/28/python-functional-parser-combinators/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/07/28/python-functional-parser-combinators/#comments</comments>
		<pubDate>Tue, 28 Jul 2009 17:38:40 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[fp]]></category>
		<category><![CDATA[funcparserlib]]></category>
		<category><![CDATA[parser]]></category>
		<category><![CDATA[python]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=166</guid>
		<description><![CDATA[С некоторого времени я стал делать на Python часть моих повседневных задач по анализу языков, трансляторам и пр. Вначале для вспомогательных целей, а потом и для парсинга небольших языков, прототипирования грамматик, деревьев AST, трансформаций кода. Многие при этом подумают про OCaml, но в Unix-среде (привет spb-archlinux!) от Python с его библиотеками пользы больше. Для задач [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=166&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>С некоторого времени я стал делать на Python часть моих повседневных задач по анализу языков, трансляторам и пр. Вначале для вспомогательных целей, а потом и для парсинга небольших языков, прототипирования грамматик, деревьев AST, трансформаций кода. Многие при этом подумают про OCaml, но в Unix-среде (привет <a href="http://archlinux.folding-maps.org/">spb-archlinux</a>!) от Python с его библиотеками пользы больше.</p>
<p>Для задач парсинга я написал <em>библиотеку <a href="http://code.google.com/p/funcparserlib/">funcparserlib</a></em>. Эта библиотека предназначена для создания парсеров по методу рекурсивного спуска на основе функциональных комбинаторов. Также я написал <a href="http://archlinux.folding-maps.org/2009/funcparserlib/Tutorial">вводное руководство по funcparserlib</a> (на английском), которое будет интересно всем, увлекающимся функциональным программированием (FP) и/или языком Python. Рекомендую его почитать!</p>
<p>Вот, например, <a href="http://archlinux.folding-maps.org/2009/funcparserlib/Illustrated">такие картинки деревьев</a> можно легко получать с помощью funcparserlib:</p>
<pre><code>&gt;&gt;&gt; print dotparser.pretty_parse_tree(tree)
Graph [id=g1, strict=False, type=digraph]
`-- stmts
    |-- Edge
    |   |-- nodes
    |   |   |-- n1
    |   |   |-- n2
    |   |   `-- SubGraph [id=n3]
    |   |       `-- stmts
    |   |           |-- Edge
    |   |           |   |-- nodes
    |   |           |   |   |-- nn1
    |   |           |   |   |-- nn2
    |   |           |   |   `-- nn3
    |   |           |   `-- attrs
    |   |           `-- Edge
    |   |               |-- nodes
    |   |               |   |-- nn3
    |   |               |   `-- nn1
    |   |               `-- attrs
    |   `-- attrs
    `-- Edge
        |-- nodes
        |   |-- SubGraph [id=n3]
        |   |   `-- stmts
        |   `-- n1
        `-- attrs

</code></pre>
<p>Итак, предлагаю взглянуть на <a href="http://archlinux.folding-maps.org/2009/funcparserlib/Tutorial">руководство</a>, а питонистам — попробовать funcparserlib, посмотреть другие доки и примеры на <a href="http://code.google.com/p/funcparserlib/">сайте библиотеки</a>.</p>
<p><span id="more-166"></span></p>
<p>Отличительные особенности библиотеки funcparserlib:</p>
<ul>
<li>Несколько необходимых удобных комбинаторов парсеров (API всего 14 вызовов). Код получается компактным, очень похожим по языку на xBNF-грамматики</li>
<li>Маленький размер самой библиотеки: всего лишь 0.5 KLOC с комментариями</li>
<li>Обнаружение ошибок по методу длиннейшего разобранного префикса даёт разумные сообщения об ошибках разбора</li>
<li>Маленький токенизатор на основе регулярных выражений позволяет следить за позицией лексем в тексте, выдавать её в сообщениях</li>
</ul>
<p>При своём небольшом размере, библиотека является достаточной для написания парсеров весьма больших грамматик. Но главное предназначение — разбор небольших языков и языков DSL (предметно-ориентированных).</p>
<p>Для Python существуют несколько библиотек синтаксического анализа. Сравним некоторые из них с funcparserlib:</p>
<ul>
<li><a href="http://pyparsing.wikispaces.com/">pyparsing</a>. Самая популярная библиотека. Имеет не очень большой размер кода (3.7 KLOC), очень избыточный разношёрстный API (около сотни вызовов), довольно медленная (по простым тестам в 3 раза медленнее, чем funcparserlib)</li>
<li><a href="http://www.acooke.org/lepl/">LEPL</a>. Библиотека с большой функциональностью, опциями и пр. (API содержит около сотни вызовов) Имеет очень большие для данной задачи исходные коды (около 15 KLOC). Быстрая, по утверждению авторов</li>
</ul>
<p>Библиотека funcparserlib возникла поначалу из игрушечного <a href="http://vlasovskikh.wordpress.com/2008/07/24/simple_recursive_json_parser/">примера парсера JSON</a>, который я написал в 2008 году. Пример был создан, чтобы показать, что можно писать парсеры, в точности соответствующие формальной грамматике языка. Летом 2009 года я вернулся к парсерам на Python и решил дописать библиотеку, добавить токенизатор на regexps, выполнить оптимизации и т. д. На данный момент доступна версия 0.3.2, по которой я написал довольно много документации (на английском).</p>
<p>Теперь funcparserlib включает вполне приличный парсер JSON как один из примеров. Этот парсер поддерживает JSON со всеми нюансами и по скорости всего в 3 раза медленнее, чем специализированная библиотека simplejson. А исходного кода — в 8 раз меньше, намного более читаемого :)</p>
<br /> Tagged: fp, funcparserlib, parser, python <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/166/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/166/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/166/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=166&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/07/28/python-functional-parser-combinators/feed/</wfw:commentRss>
		<slash:comments>4</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Монады в OCaml</title>
		<link>http://vlasovskikh.wordpress.com/2009/07/13/monads-in-ocaml/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/07/13/monads-in-ocaml/#comments</comments>
		<pubDate>Mon, 13 Jul 2009 18:17:47 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[haskell]]></category>
		<category><![CDATA[ocaml]]></category>
		<category><![CDATA[class]]></category>
		<category><![CDATA[functor]]></category>
		<category><![CDATA[monad]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=150</guid>
		<description><![CDATA[В блогах уже есть, конечно, рассказы о монадах в OCaml, например, A Monad Tutorial for OCaml и Syntax Extension for Monads in OCaml. Однако меня интересовало воссоздание соответствующих классов типов Haskell при помощи параметрических модулей (вот пост про соответствие между ними). Вот «иерархия» модулей, расширяющих функтор до монады. Полезные комментарии к соответствующим классам Haskell есть [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=150&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>В блогах уже есть, конечно, рассказы о монадах в OCaml, например, <a href="http://enfranchisedmind.com/blog/posts/a-monad-tutorial-for-ocaml/">A Monad Tutorial for OCaml</a> и <a href="http://www.cas.mcmaster.ca/~carette/pa_monad/">Syntax Extension for Monads in OCaml</a>. Однако меня интересовало воссоздание соответствующих классов типов Haskell при помощи параметрических модулей (вот <a href="http://brierwooddesign.com/2009/1/16/ocaml-quickcheck-translating-quickcheck-from-haskell-type-classes-to-ocaml-modules">пост</a> про соответствие между ними).</p>
<p>Вот «иерархия» модулей, расширяющих функтор до монады. Полезные комментарии к соответствующим классам Haskell есть в статье <a href="http://www.haskell.org/sitewiki/images/8/85/TMR-Issue13.pdf">The Typeclassopedia</a> из The Monad.Reader.</p>
<pre><code>module type FunctorType =
sig
  type 'a t
  val map : ('a -&gt; 'b) -&gt; 'a t -&gt; 'b t
end

module type PointedType =
sig
  include FunctorType
  val pure : 'a -&gt; 'a t
end

module type ApplicativeType =
sig
  include PointedType
  val (&lt;*&gt;) : ('a -&gt; 'b) t -&gt; 'a t -&gt; 'b t
end

module type MonadType =
sig
  include ApplicativeType
  val join : 'a t t -&gt; 'a t
  val (&gt;&gt;=) : 'a t -&gt; ('a -&gt; 'b t) -&gt; 'b t
  val (&gt;&gt;) : 'a t -&gt; 'b t -&gt; 'b t
end

</code></pre>
<p>Здесь уже видно, что не всё получается как в Haskell. Сигнатуры модулей не позволяют привести значение терма по умолчанию.</p>
<p><strong>Upd:</strong> Выложил <a href="http://pastebin.com/f3613e43d">полный исходник</a> с примерами в pastebin.</p>
<p><span id="more-150"></span></p>
<p>Мы можем определить структуру модуля, соответствующего сигнатуре. Например, вот тип <code>'a option</code> как монада:</p>
<pre><code>module OptionMonad =
struct
  type 'a t = 'a option

  let map f x =
    match x with
      | Some x' -&gt; Some (f x')
      | None -&gt; None

  let pure x = Some x

  let (&lt;*&gt;) f x =
    match (f, x) with
      | (Some f', Some x') -&gt; Some (f' x')
      | _ -&gt; None

  let join x =
    match x with
      | Some x' -&gt; x'
      | None -&gt; None

  let (&gt;&gt;=) x f = join (pure f &lt;*&gt; x)
  let (&gt;&gt;) x y = x &gt;&gt;= fun _ -&gt; y
end

</code></pre>
<p>Здесь пока что всё хорошо. Однако при использовании модуля возникают проблемы, т. к. ограничения на полиморфный код здесь вводятся явно, через параметризацию модулей (модуль с параметром является функцией из модуля в модуль и называется в OCaml <em>функтором</em>, не путать с классом <code>Functor</code>!).</p>
<p>Итак, вот простенький модуль, параметризованный классом монады, работающий со значениями типа <code>'a Monad.t</code>:</p>
<pre><code>module MakeSumInMonad (Monad : MonadType) =
struct
  let (&gt;&gt;=) = Monad.(&gt;&gt;=)
  let return = Monad.pure

  let maybe_div a b =
    match (a, b) with
      | (Some a', Some b') -&gt;
        if b' = 0 then
          None
        else
          Some (a' / b')
      | _ -&gt; None

  let (+) a b =
    a &gt;&gt;= fun a' -&gt;
    b &gt;&gt;= fun b' -&gt;
    return (Pervasives.(+) a' b')
end

</code></pre>
<p>Прежде чем работать с модулем, нужно создать его, применив наш параметризованный модуль-«функтор» к модулю со структурой монады:</p>
<pre><code>module SumInMaybe = MakeSumInMonad (OptionMonad)

</code></pre>
<p>Это далеко не так приятно, как в Haskell. Там это выглядит более естественным. Здесь же приходится оборачивать любой код, работающий с типами некоторого класса, в технический модуль. Также я пока не смотрел, что будет с модулями с несколькими параметрами.</p>
<p>В конце небольшой тест:</p>
<pre><code>let main () =
  let (/?) = SumInMaybe.maybe_div in
  let (+?) = SumInMaybe.(+) in
  begin
    assert ((Some 4) /? (Some 2) +? (Some 3) /? (Some 1) = (Some 5));
    assert ((Some 4) /? (Some 0) +? (Some 3) /? (Some 1) = None);
  end

</code></pre>
<br /> Tagged: class, functor, haskell, monad, ocaml <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/150/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/150/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/150/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=150&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/07/13/monads-in-ocaml/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Команда spb-archlinux на ICFPC 2009</title>
		<link>http://vlasovskikh.wordpress.com/2009/07/02/spb-archlinux-at-icfpc-2009/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/07/02/spb-archlinux-at-icfpc-2009/#comments</comments>
		<pubDate>Wed, 01 Jul 2009 21:41:53 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[2009]]></category>
		<category><![CDATA[c++]]></category>
		<category><![CDATA[haskell]]></category>
		<category><![CDATA[icfpc]]></category>
		<category><![CDATA[java]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[spb-archlinux]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=125</guid>
		<description><![CDATA[Никак не возьму в привычку чаще писать в блог. Но на этот раз повод действительно есть. Наша команда spb-archlinux принимала участие в программерском конкурсе ICFP Contest 2009 :) Ниже рассказ об этом. Если вкратце, было весело! :) Upd: В финальной таблице результатов мы заняли 95 место с 1826 очками. Один из членов команды Jkff уже [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=125&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Никак не возьму в привычку чаще писать в блог. Но на этот раз повод действительно есть. Наша <a href="http://archlinux.folding-maps.org/2009/ICFPContest/">команда spb-archlinux</a> принимала участие в программерском конкурсе <a href="http://www.ittc.ku.edu/icfp-contest/">ICFP Contest 2009</a> :)</p>
<p>Ниже рассказ об этом. Если вкратце, было весело! :)</p>
<p><strong>Upd:</strong> В финальной таблице результатов мы заняли 95 место с 1826 очками.</p>
<p><span id="more-125"></span></p>
<p>Один из членов команды <a href="http://spbhug.folding-maps.org/wiki/EugeneKirpichov">Jkff</a> уже <a href="http://antilamer.livejournal.com/284320.html">описал наше участие в своём отчёте</a>, так что здесь я остановлюсь на частностях и личном впечатлении, а за общим описанием отсылаю вас в его блог.</p>
<p>Итак, описание Jkff вы уже прочитали. Я бы хотел рассказать про отдельные моменты конкурса. Мне наиболее интересно то, почему мы заняли относительно невысокое место (за 4 часа до окончания мы были 84-ые из 317). Поэтому ниже проводится «разбор полётов». Но я хочу сразу сказать, что мне лично было приятно участвовать с нашей командой! Мы хорошо сработались и я с удовольствием поучаствую в следующем году. Ниже я расскажу также о весёлых моментах в конкурсе :)</p>
<h3>Задание</h3>
<p>Итак, во время прочтения задания мы сразу и обрадовались, и обеспокоились :) Я, в общем-то, правильно предсказал то, что нас ждёт. До конкурса на каналах Jabber и IRC много говорилось об аэрокосмической теме и о времени 13:00:16. Окончательно раскусить оргов так и не смогли. Мне было ясно следующее: форматы времени и вообще точное время будут играть большую роль (про важность дискретного времени мы вспомнили, к сожалению, слишком поздно). Другой моей догадкой была очередная виртуальная машина (VM), которая обеспечит независимость от платформы: орги слишком уклончиво отвечали на вопрос о том, как надо было отправлять результаты.</p>
<p>В самом начале конкурса выяснилось, что 1995-06-29T13:00:16 (часовой пояс?) — это время первой стыковки шаттла и станции «Мир». Управлять спутниками — это звучало весело :) Но мы сразу стали опасаться сложностей с VM: Jkff вычитал что-то про машинные инструкции, записывающие результат в память по адресу инструкции, и мы стали думать про самомодифицирующийся код и пр. В реальности всё оказалось очень просто. VM была с гарвардской архитектурой: память команд и данных у неё была раздельная. К тому же позднее нам стало понятно, что платформонезависимость была <em>единственной</em> целью включения VM в задание. Способ и эффективность реализации VM на решение почти что не влияли. Мы же напрасно уделили этому внимание, в тактике нашей команды постепенно начала накапливаться ошибка подхода к заданию.</p>
<h3>Интерфейс <code>ctl</code>-<code>sim</code></h3>
<p>Почти с самого начала мы стали решать задачу в духе Unix. Вырисовывалась пара взаимодействующих программ: <code>sim</code> — симулятор, выполняемый на VM, и <code>ctl</code> — контроллер, ведущий симулируемый спутник. В ходе небольшого обсуждения я изложил своё видение взаимодействия этой пары. <code>ctl</code> и <code>sim</code> будут обмениваться командами чтения/записи в порты IO через неименованные каналы ОС. Формат обмена FMT было решено сделать текстовым, что давало нам читаемый и отлаживаемый интерфейс в стиле Unix. Например, имея готовую трассу команд на вход симулятора, вывод можно было, в принципе, увидеть картинку полёта спутников следующим образом:</p>
<pre><code>$ cat trace.fmt | sim | vis

</code></pre>
<p>В таком же стиле можно было вручную вести спутник (номеров портов было мало и мы помнили их наизусть):</p>
<pre><code>$ sim
0 0x3e80=1002
0 0x0=0 0x1=10000 0x2=-6352278.930 0x3=6361717.566 0x4=21082000
1
1 0x0=0 0x1=10000 0x2=-6347554.360 0x3=6366431.626 0x4=21082000
2 0x2=5000
2 0x0=0 0x1=5000 0x2=-6345326.291 0x3=6371142.177 0x4=21082000

</code></pre>
<p>По общему мнению, интерфейс взаимодействия контроллеров и симуляторов получился хороший, он позволил нам писать их на разных языках: Python, Haskell, C++ и Java (на ней был написан визуализатор). Однако сразу же надо высказаться критически об этом интерфейсе. Он способствовал написанию контроллеров на разных языках, что уменьшало шансы совместной работы над кодом и повторного использования кода в следующих задачах. Мы обезопасили себя от проблем с отладкой VM, нашего физического эмулятора и разных контроллеров. Однако это дало начало ненужному в таком коротком конкурсе языковому разброду. К тому же отладка интерфейса обошлась нам в 4 человеко-часа. Но в целом, всё же, интерфейс был положительным моментом.</p>
<p>С упомянутой отладкой интерфейса отдельная история. Несмотря на то, что программы взаимодействовали через каналы (pipes), они были крайне сильно связаны. Контроллер ожидал ответа от симулятора после каждой своей команды. Фактически, это был протокол с обменом сообщениями «запрос-ответ». А для этого только каналов недостаточно, нужно организовать подчиенение процессов. Эта <a href="http://www.faqs.org/docs/artu/ch07s02.html">типичная схема</a> описана у Реймонда в “The Art of Unix Programming”. Мы решили оставить всё на каналах и просто сделать программу-драйвер <code>fmtdump</code>, которая связывала каналы двух программ крест-на-крест и заодно писала логи их взаимодействия в общем формате FMT. Всё бы хорошо, да только мы не задумывались над обязательностью <code>flush</code>(2) после <code>write</code>(2) и над тем, что строки текствого протокола мы не имеем права буферизовать при чтении: строку неизвестной длины без блокировки можно читать только по одному байту за раз.</p>
<p>После того, как минут за 30 всё это было осознано, началась борьба по отключению буферизации ввода во всех языках, на которых писались контроллеры. В Python это оказалось сделать на удивление сложно. Способ, описанный в документации, не работал и одно время мне пришлось использовать свою функцию чтения строки по байту. Позже правильный способ всё-таки был найден: открыть файл в бинарном режиме, указать размер буфера 0 и читать строку через <code>readline</code>, а не итерироваться по строкам файла. В других вариантах буферизация всё равно происходит.</p>
<p>Вот с этими техническими деталями VM и интерфейса симулятора к контроллеру мы провозились до середины субботы. Сама VM получилась тоже интересно, см. блог Jkff. Напомню, что для получения симулятора использовалось взаимодействие языков байткода VM, Python, Haskell и C++.</p>
<h3>Все пишут контроллеры</h3>
<p>Закопавшись с VM, мы сели за саму задачу, т. е. за контроллеры, только к полудню субботы. До этого я писал транслятор байткода в Haskell-ассемблер VM, а также драйвер пары контроллер-симулятор <code>fmtdump</code>, Kerzum писал компилятор <code>sim</code> с Haskell-ассемблера в C++, Jkff писал визуализацию выходного лога в формате FMT, а <a href="http://claimid.com/cfr">Cfr</a> и <a href="http://claimid.com/incubos">Incubos</a> писали альтернативный <code>sim</code>, моделирующий мир по формулам из задания.</p>
<p>Cfr уже без Incubos (который пошёл спать) начал писать свой контроллер на Haskell, однако скоро от его кода ответвился Kerzum, который решил попробовать свою реализацию. Параллельно Jkff начал ещё один контроллер на Python. Я занимался скриптами сборки всех проектов и небольшими исправлениями к <code>fmtdump</code>. Не очень понятно, что мешало всем вместе вначале решить задачу математически и алгоритмически. Наверное, всем просто хотелось уже наконец попробовать подойти к задачам практически: симулятор и драйвер были как раз готовы. Начавшееся разделение хаскеловских и питоновских контроллеров в результате затормозит нас на довольно большое время, хотя и обезопасит от отдельных неудач с конкретными контроллерами. Как и в случае с интерфейсом контроллер-симулятор, мы опять подошли к проблеме слишком защищёно.</p>
<p>Вечером в субботу свой контроллер начал и Incubos, взяв за основу мои наброски (об этом речь ниже). Так что в воскресенье практически все работали над контроллерами, но своими, а не общим. Знания тоже локализовались в коде и обмен ими шёл не особо эффективно.</p>
<h3>Эволюция контроллеров на Python</h3>
<p>После того, как к полудню субботы я решил вопросы с драйвером, я взялся за контроллеры. Однако вместо того, чтобы познакомиться наконец детально с физикой задачи (а не только с VM и форматами), я решил придумать хороший интерфейс контроллеров на Python, чтобы их было легко писать и комбинировать.</p>
<p>Утром я написал для ребят простой парсер формата FMT на Python и дёрнул меня тогда чёрт сделать его интерфейс потоковым! Возможно, это была главная моя ошибка за весь конкурс. Контроллер представлялся в этом первом интерфейсе функцией типа <code>Iterable(Ports) -&gt; Iterable(Ports)</code>. Чуть позже, думая об универсальном интерфейсе, я написал вспомогательную функцию <code>buffered :: ([Ports] -&gt; Ports), int -&gt; (Iterable(Ports) -&gt; Iterable(Ports))</code>, которая позволяла работать с одним шагом симуляции, но иметь буфер портов за предыдущие ходы. Тогда мне показалось, что такая потоковая обработка наряду с буферизацией будет удобной для решения всех задач. Но я почему-то забыл с самого начала подумать про суть обмена данными с симулятором и про композицию алгоритмов управления в контроллерах. С таким интерфейсом это получалось крайне неестественно.</p>
<p>Что же было естественным способом управления симулятором? Старое доброе ООП. Наша задача сводится к синхронному обмену сообщениями (message passing) между процессами с локальным изменяемым состоянием.</p>
<p>К сожалению, Jkff и Incubos уже вовсю писали свой код на потоковом интерфейсе (код Incubos особенно критично зависел от этого), а ОО-интерфейс я придумал только днём в воскресенье, после того, как, наконец, выспался после 36-часового бодрствования.</p>
<p>Новый интерфейс заключался вот в чём. Есть интерфейс ООП <code>Sim</code> с единственными методом: <code>interact :: Ports -&gt; Ports</code>, который в ответ на управляющие сигналы в порты ввода выдаёт сигналы портов вывода. Всё очень банально! Зато сразу стало возможно делать следующие вещи: объединять контроллеры (процедуры аргумента <code>Sim</code>) последовательной композицией, организовывать внутри них конечные автоматы, вызывать внутри контроллеров другие контроллеры (вложенные конечные автоматы), делать классы-прокси для дампа логов взаимодействия, запускать альтернативный симулятор внутри процесса для предсказания физики и пр.</p>
<p>Посетила бы нас эта простая мысль раньше — наш код был бы повторно используемым, более выразительным и наверняка содержал бы меньше ошибок.</p>
<p>Последнее улучшение интерфейса контроллера состояло в том, что специальный прокси <code>TraceSim</code> добавлял поле <code>trace :: [(Ports, Ports)]</code> с историей команд ввода-вывода, что нужно почти всем алгоритмам.</p>
<h3>Физика и геометрия</h3>
<p>Отдельной темой стоят наши обсуждения физики и геометрии задачи. К сожалению, в субботу их было очень мало, но зато они были интересные :) и в воскресенье они позволили нам прийти, фактически, к решению задачи. Особенно эффективными мне показались обсуждения физики у доски, в которых участвовали я, Jkff и пару раз Cfr с Kerzum. На мой взгляд, примерно так и стоило бы решать задачу: обсуждать и вместе писать алгоритмы, а не распределять усилия на несвязанный код. Хоть в итоге именно распределение позволило набрать нам наши очки, но оно и помешало набрать нам больше.</p>
<p>Надо заметить, что ещё в субботу вечером у нас был код, выводящий спутники первых задач на нужную орбиту, но нам упорно не давали очков. Оказалось, мы невнимательно читали задание, допустили несколько опечаток в расчётах, выводили данные со значительной потерей точности,  также совсем забыли, что мы летаем в дискретном времени с шагом 1 сек и скоростью порядка 10 км/сек. Это значит, что без учёта дискретизации (например, параллельным расчётом по непрерывной формуле и дискретной симуляцией с коррекцией после этого) мы не могли достичь нужной точности в орбитальных переходах.</p>
<p>В воскресенье часть этих проблем была решена и при помощи многих подхаков мы решили все задачи, кроме последней, главной. До неё мы, к сожалению, не успели дойти из-за нехватки времени и неизвестного бага в симуляторе, проявлявшегося только на этой задаче.</p>
<h3>Причины неуспеха</h3>
<p>По моему мнению, нам помешало следующее:</p>
<ul>
<li>Не пытались писать алгоритмы контроллеров вместе</li>
<li>Не провели своевременный поиск доков по предметной области</li>
<li>Долго не вспоминали о дискретном времени</li>
<li>Писали код на разных языках, не думали о композиции алгоритмов</li>
<li>Потеряли полдня на баг с выводом неточных чисел с плавающей точкой</li>
<li>Плохо организовали математический код, допускали много опечаток</li>
</ul>
<h3>Что мне понравилось</h3>
<p>Ну и после такого анализа хочу поделиться приятными впечатлениями :) Вот что было интересно:</p>
<ul>
<li>Мы запрограммили классный многоязыковой процесс получения симулятора</li>
<li>Картинка concept map на доске в самом начале позволила быстро найти связи, которые ещё никто не понимал</li>
<li>Unix-интерфейсы рулят! Мы игрались с интерфейсом <code>ctl</code>-<code>sim</code>, рисуя бешеные трассы, отлавливая баги во взаимодействии: всё было текстовым и простым</li>
<li>Мы выпили в ходе обсуждения в первую ночь кучу кофе и продержались где-то до 20 часов субботы</li>
<li>У нас были интересные обсуждения у доски. Было здорово подсказывать, ловить баги друг друга, придумывать новые подходы :)</li>
<li>Система управления версиями Mercurial всё время рулила</li>
<li>Мы хотели и продумывали (но так и не сделали) интерактивный контроллер в визуализаторе, чтобы играться в спутник с клавиатуры</li>
</ul>
<h3>Цифры</h3>
<p>Ну и совсем под конец несколько цифр:</p>
<ul>
<li>219 ревизий в Mercurial</li>
<li>11 исполняемых программ</li>
<li>1701 строка на Python, 630 на C++, 475 на Java, 460 на Haskell, 171 на C, 111 на make, 67 на sh</li>
<li>На момент заморозки таблицы 84 место, 1654 очка (до отправки последних результатов)</li>
</ul>
<p>Спасибо членам команды за классно проведённое время! :) </p>
<br /> Tagged: 2009, c++, haskell, icfpc, java, python, spb-archlinux <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/125/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/125/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/125/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=125&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/07/02/spb-archlinux-at-icfpc-2009/feed/</wfw:commentRss>
		<slash:comments>13</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>Группа юзеров spb-archlinux</title>
		<link>http://vlasovskikh.wordpress.com/2009/03/24/spb-archlinux-users-group/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/03/24/spb-archlinux-users-group/#comments</comments>
		<pubDate>Tue, 24 Mar 2009 15:00:25 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[announce]]></category>
		<category><![CDATA[archlinux]]></category>
		<category><![CDATA[group]]></category>
		<category><![CDATA[linux]]></category>
		<category><![CDATA[social]]></category>
		<category><![CDATA[spb]]></category>
		<category><![CDATA[spb-archlinux]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=103</guid>
		<description><![CDATA[Мы с приятелями организовали spb-archlinux, питерскую группу пользователей Arch Linux. Некоторое время назад я со знакомыми заинтересовался этим минималистичным дистрибутивом Linux. Результатом стал переход на Arch и создание такой группы. Наша группа объединяет людей по интересу к Arch Linux и связанным технологиям, желающих делиться информацией, вместе обсуждать темы, решать встречающиеся сложности, и просто встречаться ради [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=103&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Мы с приятелями организовали <a href="http://archlinux.folding-maps.org/">spb-archlinux</a>, питерскую группу пользователей <a href="http://www.archlinux.org/">Arch Linux</a>. Некоторое время назад я со знакомыми заинтересовался этим минималистичным дистрибутивом Linux. Результатом стал переход на Arch и создание такой группы.</p>
<p>Наша группа объединяет людей по интересу к Arch Linux и связанным технологиям, желающих делиться информацией, вместе обсуждать темы, решать встречающиеся сложности, и просто встречаться ради общения. Если вам интересно, заходите на сайт нашей группы, присоединяйтесь к списку рассылки email.</p>
<p>Arch Linux — это действительно симпатичная система, близкая духу Unix. Вот что говорят пользователи этой системы <a href="http://wiki.archlinux.org/index.php/%D0%9F%D1%83%D1%82%D1%8C_Arch">о пути Arch</a>. В основу дистрибутива положены:</p>
<ul>
<li>Простота и элегантность базовой структуры системы</li>
<li>Корректность кода вместо видимого удобства для пользователя</li>
<li>Открытость</li>
<li>Направленность на пользователя в смысле возможности полного контроля над системой</li>
<li>Свобода выбора компонентов и других вещей в своей системе</li>
</ul>
<p>Хорошие и полезные качества, свойственные минималистичному простому софту.</p>
<br /> Tagged: announce, archlinux, group, linux, social, spb, spb-archlinux <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/103/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/103/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/103/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=103&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/03/24/spb-archlinux-users-group/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
		<item>
		<title>ВКонтакте как социальная чёрная дыра</title>
		<link>http://vlasovskikh.wordpress.com/2009/03/21/vkontakte-social-black-hole/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/03/21/vkontakte-social-black-hole/#comments</comments>
		<pubDate>Sat, 21 Mar 2009 16:02:20 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[atom]]></category>
		<category><![CDATA[feed]]></category>
		<category><![CDATA[jabber]]></category>
		<category><![CDATA[social]]></category>
		<category><![CDATA[vkontakte]]></category>
		<category><![CDATA[web]]></category>
		<category><![CDATA[xmpp]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=94</guid>
		<description><![CDATA[Я решил удалить свой аккаунт с сайта ВКонтакте, т. к. он слишком централизованный и закрытый. Вначале я расскажу почему это так, а затем опишу более хорошую альтернативу социальной сети. Upd: Оставил аккаунт для общения с теми, кто не хочет или не может общаться по-другому :) Этот сайт слишком централизованный, т. к. люди вынуждены использовать его [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=94&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Я решил удалить свой аккаунт с сайта <a href="http://vkontakte.ru/">ВКонтакте</a>, т. к. он слишком централизованный и закрытый. Вначале я расскажу почему это так, а затем опишу более хорошую альтернативу социальной сети.</p>
<p><strong>Upd:</strong> Оставил аккаунт для общения с теми, кто не хочет или не может общаться по-другому :)</p>
<p>Этот сайт слишком централизованный, т. к. люди вынуждены использовать его для общения, даже если они хотели бы общаться в другом месте. Это происходит из-за огромного количества пользователей сайта (на настоящий момент около 30 млн.). Сайт как воронка притягивает новых пользователей за счёт уже имеющихся. Я считаю это неприемлемым, т. к. это ненадёжно и небезопасно. Если с сайтом технически или административно что-то произойдёт, все эти люди окажутся без сервиса. Речь даже не о выходе из строя, а о таких мелочах, как реклама, плата за дополнительные функции и т. д.</p>
<p><span id="more-94"></span></p>
<p>Сайт ВКонтакте также слишком закрытый. На нём 30 млн. страниц пользователей, сотни миллионов фотографий, статусы присутствия, записи в заметках, записи статуса&#8230; Догадайтесь, сколько страниц этот сервис внёс во Всемирный Веб? Миллионы? Нет! Целых 5 страниц: начальную, регистрация, пользовательское соглашение и реклама. Это не социальная сеть, а социальная чёрная дыра.</p>
<p><img style="float:left;margin-right:1em;" title="чёрная дыра" src="http://upload.wikimedia.org/wikipedia/commons/thumb/c/cd/Black_Hole_Milkyway.jpg/200px-Black_Hole_Milkyway.jpg" alt="космическая чёрная дыра" width="200" height="160" /></p>
<p>Может, стоит заметить, что другие подобные сайты типа Одноклассников, Facebook и пр. такие же плохие. Даже LiveJournal немного плох, но только тем, что там есть сеть друзей и стало слишком много рекламы.</p>
<p>Как, на мой взгляд, должна выглядеть социальная сеть в Вебе?</p>
<p>Каждый человек должен иметь адрес email и мгновенных сообщений Jabber (в отличие от ICQ и других протокол <a href="http://ru.wikipedia.org/wiki/Jabber">Jabber</a> XMPP является открытым стандартом Интернета). Через эти средства можно связываться друг с другом напрямую (Peer to Peer) без централизованных серверов. Это заменяет сообщения ВКонтакте, а также информацию о присутствии онлайн.</p>
<p>Каждый человек должен иметь домашнюю страницу. Не важно где: на сайте со своим блогом, на бесплатном хостинге — лишь бы она была доступна для всех в Вебе по её URL. На этой странице можно привести фотографию, краткую информацию о себе, контактные данные, ссылки на другие свои сайты. Можно завести список со ссылками на страницы друзей. Это заменяет страницы пользователей ВКонтакте и списки друзей. А находить друг друга можно легко при помощи Яндекса, Google и других поисковиков.</p>
<p>Каждый человек может иметь блог. В нём он может писать о своих мыслях, событиях, информировать других об интересных вещах. Другие люди могут оставлять комментарии к записям, могут подписываться на ленты обновлений <a href="http://ru.wikipedia.org/wiki/Atom">Atom</a> и RSS. Можно также завести микроблог, в который пишут обычно по одному предложению, но часто, чтобы держать других в курсе своих повседневных дел. Это заменяет заметки ВКонтакте, комментарии и стену.</p>
<p>Хочу отдельно сказать о важности новостных лент Atom и RSS. Благодаря стандартному формату ленты можно подписаться на кучу лент друзей и разных других сайтов при помощи программы чтения лент новостей. Такая программа-агрегатор лент сама будет забирать обновления с сайтов, так что все ленты друзей можно читать как одну объединённую. Программ для чтения лент новостей существует много. Есть и для своего компьютера, и веб-сервисы типа <a href="http://www.google.com/reader/">Google Reader</a>. Это заменяет ленту обновлений друзей ВКонтакте.</p>
<p>Все эти сервисы: свой email, свой адрес Jabber, свою домашнюю страницу, свой блог — каждый может выбрать на одном из бесплатных сервисов-хостингов независимо от друзей и приятелей. И тем не менее, все смогут общаться друг с другом, при желании меняя сервисы на другие и не беспокоя друзей вступлением в новые социальные чёрные дыры.</p>
<p>Ещё раз подчеркну преимущества такого подхода: децентрализация, доступная всем информация, открытые стандарты, простота использования и техническая простота, отсутствие привязанности к одному поставщику сервиса.</p>
<br /> Tagged: atom, feed, jabber, social, vkontakte, web, xmpp <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/94/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/94/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/94/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=94&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/03/21/vkontakte-social-black-hole/feed/</wfw:commentRss>
		<slash:comments>22</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>

		<media:content url="http://upload.wikimedia.org/wikipedia/commons/thumb/c/cd/Black_Hole_Milkyway.jpg/200px-Black_Hole_Milkyway.jpg" medium="image">
			<media:title type="html">чёрная дыра</media:title>
		</media:content>
	</item>
		<item>
		<title>Курс по языкам программирования</title>
		<link>http://vlasovskikh.wordpress.com/2009/01/25/programming-languages-class/</link>
		<comments>http://vlasovskikh.wordpress.com/2009/01/25/programming-languages-class/#comments</comments>
		<pubDate>Sun, 25 Jan 2009 19:40:58 +0000</pubDate>
		<dc:creator>vlasovskikh</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[fp]]></category>
		<category><![CDATA[java]]></category>
		<category><![CDATA[lang]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[scheme]]></category>
		<category><![CDATA[spbstu]]></category>

		<guid isPermaLink="false">http://vlasovskikh.wordpress.com/?p=49</guid>
		<description><![CDATA[Закончилась зимняя сессия, время рассказать о прочитанном курсе и подвести небольшие итоги. В осеннем семестре 2008 читал в Политехе курс лекций «Языки программирования» студентам 5-ого курса кафедры АиВТ. Идеей было дать общий подход к рассмотрению языков, познакомить с функциональным программированием, рассмотреть некоторые компромиссы при проектировании языков. Курс наполовину основан на SICP и языке Scheme, а [...]<img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=49&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></description>
			<content:encoded><![CDATA[<p>Закончилась зимняя сессия, время рассказать о прочитанном курсе и подвести небольшие итоги.</p>
<p>В осеннем семестре 2008 читал в Политехе курс лекций «Языки программирования» студентам 5-ого курса кафедры АиВТ. Идеей было дать общий подход к рассмотрению языков, познакомить с функциональным программированием, рассмотреть некоторые компромиссы при проектировании языков. Курс наполовину основан на SICP и языке Scheme, а вторая половина посвящена сравнительному обзору языков C, C++, Python и Java.</p>
<p>Поделюсь впечатлениями о курсе. Во-первых, наши студенты имеют весьма туманные навыки программирования, немного грустно :( Думаю, такое характерно для большинства вузов, хотя наверняка есть и исключения. Они написали к 5-ому курсу слишком мало программ (к тому же весьма простых), и не в состоянии нормально чувствовать и рассуждать о проблемах борьбы со сложностью в программировании. Во-вторых, в курсе получился большой перекос в сторону основ ФП и Scheme в противовес передаче сообщений, параллельности, малым языкам и т. д. Наконец, чтение курса помогает заострить внимание на моментах, которые иначе не были бы замечены и систематизированы.</p>
<p>Теперь есть мысли о нескольких лекциях или семинарах по сетевому и распределённому программированию. Кажется, уже достаточно много важных и интересных вещей могу сказать по этому поводу.</p>
<p>Студентов поздравляю с Татьяниным днём :)</p>
<br /> Tagged: fp, java, lang, python, scheme, spbstu <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gocomments/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/comments/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godelicious/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/delicious/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gofacebook/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/facebook/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gotwitter/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/twitter/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/gostumble/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/stumble/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/godigg/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/digg/vlasovskikh.wordpress.com/49/" /></a> <a rel="nofollow" href="http://feeds.wordpress.com/1.0/goreddit/vlasovskikh.wordpress.com/49/"><img alt="" border="0" src="http://feeds.wordpress.com/1.0/reddit/vlasovskikh.wordpress.com/49/" /></a> <img alt="" border="0" src="http://stats.wordpress.com/b.gif?host=vlasovskikh.wordpress.com&amp;blog=2489091&amp;post=49&amp;subd=vlasovskikh&amp;ref=&amp;feed=1" width="1" height="1" />]]></content:encoded>
			<wfw:commentRss>http://vlasovskikh.wordpress.com/2009/01/25/programming-languages-class/feed/</wfw:commentRss>
		<slash:comments>10</slash:comments>
	
		<media:content url="http://1.gravatar.com/avatar/d4b658aaf2bd1b74618d42b2bd2df22e?s=96&#38;d=identicon&#38;r=G" medium="image">
			<media:title type="html">vlasovskikh</media:title>
		</media:content>
	</item>
	</channel>
</rss>
