Мои инструменты
May. 24th, 2007 12:36 amЗамечали ли вы, как относится человек работающий, и свою работу любящий, к инструментам? Это не просто железки, купленные в ближайшем магазине. Это продолжение тебя самого. Хороший инструмент легко ложится в руку; с ним работается легко и быстро. Такой инструмент подбирают годами, отбрасывая не подошедшее и бережно храня какой-нибудь особенно удачный рубанок или молоток. Человек приспосабливает инструмент под себя, но и сам потихоньку приспосабливается к инструментам. Получается совершенно уникальное сочетание, глубоко индивидуальное - другому этот набор инструментов, скорее всего, не подойдет. Ему надо подбирать свой собственный, придирчиво решая, годится-не годится. Это важный выбор для любого, кто работой кормится: разница в качестве и скорости работы с подходящим и неподходящим инструментом очень велика.
Моя соавтор Л. - врач-невролог. Сколько у неё молоточков и камертонов, собранных по всему свету! "Вот этот я беру на обходы, вот этот - походный, он не оттягивает карман. А посмотри на этот - какой удобный, правда?"
А мой дедушка чинил всей Риге радиоприёмники. С какой гордостью он показывал свои инструменты - отвертки и отверточки, паяльники всевозможных форм и размеров, какие-то немыслимые пинцеты и клещи, тисочки, струбцинки, лобзики и пилочки для корпусов. "Вот эта отвертка - американская. Ты посмотри, как она хорошо сидит в руке. А эта лупа - немецкая. Цейсовская".
Сегодня я хочу рассказать про свои инструменты. Поскольку я бОльшую часть времени работаю за компьютером, инструменты у меня - компьютерные. И пусть мой выбор покажется кому-то странным, кому-то нелепым или архаичным: это то, что я за полтора десятка лет отобрал для себя, и что хорошо ложится в мою руку. Не знаю, будет ли это интересно читателю, но я от перечисления своих любимых инструментов получаю несомненное удовольствие.
Я работаю в нескольких местах. Основное - компания, занятая R&D. Кроме этого, я читаю лекции в университете, пишу статьи. В последние годы немного консультирую. Если не считать лекций и бесед со студентами, моя основная продукция - это текст. Форматированный текст на английском языке со списками литературы, рисунками и графиками.
Главный мой инструмент - редактор. Если не ошибаюсь,
vitus_wagner любит говорит, что редакторов ровно два: Emacs и
vi, и убедить пользователей одного из них в преимуществах другого -
занятие безнадёжное. Я принадлежу к первому лагерю. Собственно, я не
работаю в Emacsе - я в нём живу. Я печатаю в нём почти все тексты,
читаю почту, пишу e-mailы, и т.д., и т.п. Эти заметки я тоже пишу в
Emacsе, а когда закончу - скопирую и вставлю в окно браузера. Мне так
удобнее: пальцы сами помнят emacsовские комбинации клавиш, и набирать
текст в любой другой среде получается медленнее.
Огромное большинство моих текстов форматировано в LaTeXе. Этот вот - редкое исключение. А так письма (не e-mailы), статьи, отчеты, заметки, методички для студентов, слайды, постеры и всё остальное написано в LaTeXе. Когда я давным-давно переписывался с иммиграционной службой США (доказывал, что наша семья заслуживает грин-карты), я начал с того, что написал LaTeXовский пакет для этого. Пожалуй, этот инструмент (LaTeX) из всего набора я знаю лучше всего. Можно сказать, что мою работу можно измерить в количестве LaTeXовских страниц в день. Я не буду перечислять те пакеты, которыми пользуюсь: их много, и если я этим займусь, то конца не будет. Упомяну два, потому что они есть практически в любом моём файле: amsmath и hyperref. Первый незаменим для сколько-нибудь серьёзной математики, а второй автоматически расставляет гиперссылки.
Как правило, результат я сдаю в виде PDF-овских файлов. Поэтому вызываю pdftex, точнее pdfetex. Так как рисунки выполнены в PostScriptе, я обычно подключаю пакет ps4pdf. Списки литературы делаются BibTeXом.
Рисунки бывают двух типов: просто рисунки и графики. Первые я делаю в PSTricks. "Парадные" графики - для публикации, например, - тоже в нём. Графики для "расходных" текстов - в gnuplotе. Gnuplot позволяет быстро нарисовать много графиков, особенно в пакетном режиме, но его результат мне не всегда нравится. Я присматривался к TikZ/PGF и к MetaPost, но что-то мне PSTricks пока кажется удобнее.
Расчеты тоже бывают двух типов. Символические - когда результатом является формула, - и численные, когда результатом является таблица. Для расчетов первого типа хороша maxima. В ней же можно делать небольшие численные расчеты, вроде тех, которые мои коллеги делают в matlabе: ну там пару матриц диагонализовать и так далее. Для серьёзных численных расчетов приходится писать программы. В последнем случае для меня обычно критичны два ресурса: время, за которое я напишу программу и время, которое она будет выполняться. Эти ресурсы комплементарны: язык, на котором программа пишется быстро, обычно делает наименее оптимальный код. Быстрее всего я пишу на Perlе, и в большинстве случаев этого достаточно - я крутыми численными расчетами обычно не занимаюсь. Если же Perlа не хватает, перехожу на C. На C++ я обычно не пишу: если мне нужен объектно-ориентированный код, то я гораздо быстрее напишу его на Perlе, и разница в скорости выполнения между Perlом и C++ этой разницы в удобстве мне не компенсирует. Если нужно серьёзно работать с числовыми матрицами - скажем, проинтегрировать максимальное собственное значение матрицы A(t), зависящей от параметра t, то тут хороша фортранная библиотека lapack. В принципе у неё есть интерфейсы к C и C++, но какие-то они недоделанные. Такое впечатление, что это костыли для тех, кто fortranа боится. Мне проще вызывать её из fortranа.
Кстати, удивительна живучесть fortranа. Многие программисты, не имеющие дела с инженерными расчетами, уверены, что fortran давно умер. Их удивило бы, что автомобиль, в котором они едут, самолёт, в котором они летят, и даже дом, в котором они живут, был рассчитан, скорее всего при помощи этого языка. Когда я лет десять назад работал в Годдардовском космическом центре, одним из моих первых заданий было разобраться и подправить фортранную программу для расчета границ территории, которую может сфотографировать спутник на заданной орбите. Заглянув вовнутрь, я обнаружил, что судя по датах в комментариях, некоторые модули были написаны до моего рождения. Думаю, что её разрабатывали для оценки ущерба от советских спутников-шпионов. Недавно я встречался с ребятами из Годдарда; они говорят, что эта программа с моими поправками бегает до сих пор.
Но я отвлёкся. Итак, мои тексты собираются из разнородных элементов, которые, в свою очередь, делаются разными программами. Я достаточно ленив, чтобы заниматься этим вручную. Человек должен думать, а работать должен компьютер. Поэтому сборкой руководит make. Но объяснять make, что для отчета foo.pdf нужен график bar.eps, который делается gnuplotом из файла baz.dat, который в свою очередь..., - мне тоже лень. За годы работы у меня накопилось много правил для make, а также самописных скриптов, которые анализируют файлы и добавляют зависимости в файл depend. В итоге достаточно сказать волшебные слова "make all", и компьютер сделает всю скучную и монотонную работу сам - оставляя мне время на интересные вещи.
Я работаю на нескольких компьютерах. Поэтому надо синхронизировать проекты между ними. К тому же бывает полезно хранить историю файлов. Эти две задачи у меня решает CVS (CVS через ssh для удаленных репозиториев). Я присматривался к subversion, но что-то мне CVS пока удобнее - к её странностям я привык.
Это - основные инструменты. Есть ещё клей между ними - все эти однострочники на shellе, sedе и awkе, все эти diffы с grepами. Это даже инструментами назвать трудно - маленькие штучки, о которых не думаешь. Пока они есть, не думаешь. А вот без них сразу становится тяжко. Так что у меня работать на чем-то, кроме Unixо-подобных систем, не получается. Какой именно *nix, не так важно: я работал на самых разных. Есть там Emacs, TeX, maxima и линейка инструментов от GNU - и достаточно. Хотя в последнее время мой компьютер почти всегда оказывается Debianовским. Возможно, из-за моей лени.
Понятно, что при моём подходе всякие "десктопные среды" вроде KDE и Gnome только мешают. У меня бегает fvwm, внешний которого я не менял уже лет двенадцать (при переходе на fvwm2 мне пришлось потратить некоторые усилия, чтобы восстановить привычный look and feel).
Вот за таким компьютером я и провожу рабочее время.
no subject
Date: 2007-05-24 04:59 am (UTC)Редакторы - их где-то три - emacs, который опять же я ценю как программируемый редактор (мне приходится время от времени писать для него скрипты) и как стандарт де-факто для поддержки разных средств программирования (для vi разные скрипты народ пишет во вторую очередь, если вообще пишет), но для мелких правок обычно пользую joe или vi. Или mcedit (последний обладает одной важной для меня функцией - он умеет показывать позицию курсора как смещение в байтах относительно начала файла).
Одно из требований к инструменту у меня - он не должен вызывать технологическую зависимость. Скажем этим плохи интегрированные среды для программированя. В общем как-то скорее наоборот.
no subject
Date: 2007-05-24 05:02 am (UTC)no subject
Date: 2007-05-24 06:54 am (UTC)(no subject)
From:Re: Reply to your comment...
From:Re: Reply to your comment...
From:Re: Reply to your comment...
From:(no subject)
From:(no subject)
From:no subject
Date: 2007-05-24 07:49 am (UTC)А чем объясняется такое требование? Ну я понимаю, если речь идет о какой-нибудь проприетарной среде - может обанкротится или прекратить выпускать данный продукт фирма производитель, может отсутствовать версия для архитектуры, на которой тебе надо работать (хотя и это с нынешним распространением всяких виртуальных машин уже не критично). Но TeX, Emacs и GNU coreutils уже никогда и никуда не денутся.
(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2007-05-24 11:58 pm (UTC)Ну вот смотрите. В принципе в Emacsе положение курсора
(включая оффсет в байтах) можно узнать по команде C-x=, которая выдает
результаты типа
Но можно написать аналог и самому:
Такая функция выдает, например,
Я бы занес эту функцию в .emacs, повесил бы на какую-нибудь клавишу, и
никакой mcedit мне был бы не нужен.
Таких вещей в моих дот-файлах десятки и сотни. Что-то было написано
вчера, что-то - полтора десятка лет назад. Всё это делает мою работу
удобной. И Вы предлагаете мне всё это снести и "поставить систему с
нуля"?!! Я никогда такого не делал. Мой домашний компьютер пережил
несколько релизов slackware и debianа, смен дисков, процессора и всего
остального, но при переходах я всегда заботился о том, чтобы все эти
примочки уцелели. И заботливо переносил их на другие компьютеры, на
которых я работаю.
Программы "из коробки" настроены на дядю, который эту коробку
создавал. Он, может, и хороший. Но он - не я. Мои компьютеры
настроены на мой образ мышления, мои привычки. Я не чищу зубы чужой
щеткой, не ношу чужую обувь - почему же Вы мне предлагаете
пользоваться чужими настройками?
(no subject)
From:(no subject)
From:(no subject)
From:no subject
Date: 2007-05-24 05:15 am (UTC)no subject
Date: 2007-05-24 05:53 am (UTC)Для меня важны те самые мелкие настройки/подпрограммки, которые "затачивают" все эти большие пакеты под меня и превращают их в рабочий комплекс.
no subject
Date: 2007-05-24 06:03 am (UTC)graphviz и R (http://www.r-project.org/).
no subject
Date: 2007-05-24 06:45 pm (UTC)Vim
Date: 2007-05-24 06:09 am (UTC)Re: Vim
Date: 2007-05-24 07:59 am (UTC)Кстати, говоря о том что существует два текстовых редактора я имел в виду не vi вообще, а именно vim.
классический vi по сравнению с vim это как какой-нибудь nano по сравнению с Emacs. Что, спрашивается, каждую букву руками набирать?
А вот vim всё-таки очень много чего не умеет (из того, что умеет emacs). Почту читать не умеет, web браузить не умеет, файловым менеджером работать не умеет, интерфейсом к gdb или системе управления версиями работать тоже не особо умеет. В общем, до интегрированной среды, каковой является emacs, не дотягиват.
Другой вопрос - а так ли уж это нужно?
Re: Vim
From:не отдельным окном, а прямо в формочке
From:Re: не отдельным окном, а прямо в формочке
From:itsalltext
From:Re: Vim
From:no subject
Date: 2007-05-24 06:17 am (UTC)no subject
Date: 2007-05-24 06:20 am (UTC)no subject
Date: 2007-05-24 06:47 pm (UTC)(no subject)
From:no subject
Date: 2007-05-24 07:53 am (UTC)А вот я на 100% уверен, что дом в котором я живу, не рассчитан при помощи Фортрана - ибо он построен практически одновременно с появлением Фортрана - в середине 50-х. Так что логарифмическая линейка - rulez.
А вот при строительстве дома в деревне не применялась даже и логарифмическая линейка, хотя дом построен в 1999 году.
Почти уверен, что автомобиль на котором я ездил до февраля месяца этого года - тоже рассчитан без использования фортрана. Жигули-классика - это модель начала 60-х. Ну и что, что сделана в 2001 году. Какие нафиг компьютеры. Вот нынешний Renault Logan - это другое дело.
no subject
Date: 2007-05-24 11:52 am (UTC)no subject
Date: 2007-05-24 11:55 am (UTC)... Гномическое настоящее ...
no subject
Date: 2007-05-24 07:19 pm (UTC)(no subject)
From:(no subject)
From:no subject
Date: 2007-05-24 08:40 am (UTC)no subject
Date: 2007-05-24 02:30 pm (UTC)(no subject)
From:(no subject)
From:(no subject)
From:Раз все стали доставать инструменты...
Date: 2007-05-24 12:12 pm (UTC)Достану и свои (по TeXу).
Сборка - Ant, Python.
Версии - CVS.
Используется - MikTeX, Inkscape, Graphviz, Freemind, Ant, TeXNicCenter
Python 2.4 (+Py2tex, SciPy, NX)
Дистрибутив TeXа - Miktex
Редактор - TeXNicCenter.
Иллюстрации:
Graphviz (Dot, Neato) -> EPS -> PDF.
SVG -> EPS -> PDF.
LateX pictures over SVG (формулы поверх графики).
Mindmaps (Freemind) -> SVG -> EPS -> PDF.
Python -> SVG -> EPS -> PDF.
Python -> Graphviz -> EPS -> PDF.
Metapost -> EPS -> PDF (Deprecated, постепенно избавляюсь).
Математика: wxMaxima
no subject
Date: 2007-05-24 01:31 pm (UTC)no subject
Date: 2007-05-25 12:04 am (UTC)no subject
Date: 2007-05-24 01:36 pm (UTC)Остальное очень похоже :-)
no subject
Date: 2007-05-24 04:56 pm (UTC)Сохраню тред и буду изучать кое-что из рекомендуемого софта...
Свой набор под Ту ОС выкладывать не стану - расфрендят :-)
no subject
Date: 2007-05-24 11:27 pm (UTC)вплоть до fvwm (и засовывая в данный момент очередную lapackoвскую программу в фортрановский код)
no subject
Date: 2007-05-25 12:08 am (UTC)(no subject)
From:no subject
Date: 2007-05-25 07:29 pm (UTC)