Адриан Томпсон устраивает эволюцию и естественный отбор среди
интегральных схем. Он дает им полную свободу и даже разрешает
превращаться из цифровых в аналоговые.
Недавно английские друзья-коллеги прислали мне объявление
о Первом рабочем совещании по эволюционирующему хардверу
(First NASA/DOD Workshop on Evolvable Hardware, EH'99,
http://cism.jpl.nasa.gov/events/nasa_eh),
которое состоится в июле этого года в Пасадене (Калифорния),
в Лаборатории реактивного движения (Jet Propulsion Laboratory, JPL).
Совещание проводят НАСА и Министерство обороны США, в качестве спонсоров
выступает несколько военных исследовательских организаций. Несколько лет
назад воистину трудно было бы предположить, что военные захотят давать
деньги на такого рода развлечения. Однако список тем предполагаемых
докладов все ставит на свои места: надежность, живучесть,
автоматическое устранение повреждений - вот чего ждут специалисты
по военной и космической технике от технологии создания интегральных
схем путем эволюции. Такие устройства нужны для работы в неизвестных,
меняющихся, враждебных условиях: в длительных космических полетах,
при мониторинге радиоактивных загрязнений. Спектр потенциальных
коммерческих приложений также огромен.
Среди членов программного комитета EH'99 - наш сегодняшний собеседник,
д-р Адриан Томпсон (Adrian Thompson), один из пионеров этого направления.
После окончания Института науки и техники Манчестерского университета
по специальности "Разработка систем микроэлектроники" он развивал свои
идеи в области эволюционной электроники, работая над диссертацией
в Университете Сассекса. В настоящее время он исследователь-стипендиат
(research fellow) этого университета, а с 2000 года займет должность
лектора (lecturer) по компьютерным наукам и искусственному интеллекту.
Прежде чем предложить вниманию читателя ответы Томпсона на мои вопросы
о прошлом, настоящем и будущем эволюционной электроники, я кратко
расскажу о той работе, которая принесла ему известность (исчерпывающее
изложение этой работы имеется в его книге: A. Thompson. Hardware Evolution:
Automatic design of electronic circuits in reconfigurable hardware
by artificial evolution, выпущенной издательством "Springer Verlag"
в 1998 году в серии "Выдающиеся диссертации").
Томпсон решил поэкспериментировать с эволюцией электронных устройств
не на компьютерных моделях, а в реальности. Очень удобными для таких
экспериментов оказались FPGA (Field Programmable Gate Array,
электрически программируемые матрицы вентилей). Это интегральная схема,
состоящая из множества ячеек, способных выполнять простейшие функции,
но не имеющих между собой фиксированных связей. Связи
устанавливаются программным образом, по командам управляющего
микропроцессора, и могут изменяться в процессе работы схемы.
Эволюцию на таком устройстве нетрудно организовать при помощи
генетического алгоритма. Для этого создается некая "популяция"
конструкций - грубо говоря, схем соединения элементарных ячеек.
Каждая "особь" поочередно испытывается на приспособленность к выполнению
поставленной задачи; наименее приспособленные отсеиваются, наиболее
приспособленные скрещиваются, мутируют и так далее, как это принято
в генетических алгоритмах (см. статью Росса Клемента в этом номере КТ).
Однако если не выходить за общепринятые методы создания интегральных схем,
то есть заниматься сборкой более сложных цифровых модулей из простых
элементов-вентилей, ничего нового по сравнению с компьютерным
моделированием не получится. А значит, и радикально новых результатов
не будет. Идея Томпсона состояла в том, чтобы с самого начала нарушить
"инструкцию по эксплуатации" FPGA. Он хотел понять, что произойдет,
если запустить эволюцию, сняв все ограничения, какие только можно.
Например, он отказался от генератора тактовой частоты. В итоге FPGA
в этих экспериментах выступала не как цифровое, а как аналоговое
устройство! Динамика системы из дискретной стала непрерывной, и возникли
совершенно неожиданные эффекты.
Была поставлена задача вывести схему, способную различать два сигнала
различной частоты - 1 кГц и 10 кГц. Для этого использовался "уголок"
FPGA размером 10 на 10 ячеек. На рисунке показана конструкция,
возникшая в результате эволюции, продолжавшейся более 4000 поколений
популяции из 50 особей. Видно, что использованы далеко не все
возможные ячейки. Никакие тактовые генераторы сами собой не появились.
Количество активных элементов намного меньше, чем понадобилось бы при
обычном цифровом использовании FPGA. Но самое забавное, что долгое
время никто не мог понять, как вообще работает эта схема. Более того.
Обратите внимание на пять ячеек, заштрихованных серым. Они не выполняют
никаких активных функций в полученной схеме, но если их отключить,
схема перестает работать (то есть различать нужные сигналы)...
При ближайшем рассмотрении стало ясно, что на кристалле возникло нечто
неуловимое и уникальное. Конструкция была очень чувствительна
к температуре, а также, что уж совсем неприятно, соглашалась работать
только на одном определенном экземпляре FPGA. Но ведь никто и
не рассчитывал сразу получить промышленный образец Лучшего В Мире
Различателя Двух Бипов. Главное в том, что идея привела к нетривиальным
результатам и стало ясно, что открылось новое поле для исследований.
Оказалось, что эта деятельность интересует очень многих, вокруг нее
мгновенно выросло научно-инженерное сообщество, образовалась
инфраструктура в виде конференций, "воркшопов"... Но давайте послушаем,
что обо всем этом думает сам Адриан Томпсон.
Что привело вас к мысли реализовать эволюцию в хардвере?
- Такие идеи высказывалась уже давно. Например, Вирт Атмар (Wirt Atmar)
из Университета Нью-Мексико писал об аппаратной реализации
эволюционирующих систем еще в 1976 году в своей диссертации
"Рассуждение об эволюции машинного интеллекта и ее возможной реализации
в машинной форме". Это было до появления реконфигурируемых электронных
устройств. И в 80-х, когда эти устройства были созданы, их потенциал
не остался незамеченным: в статье Стивена Вольфрама (Stephen Wolfram)
"Подходы к инженерии сложности" ("Approaches to Complexity Engineering",
Physica 22D, 1986) упоминались некоторые возможные применения.
За прошедшее с тех пор время такие устройства в форме FPGA стали
одним из важнейших видов электронной техники. Теперь они очень
большие и очень сложные.
Так что я, инженер-электронщик, окончив университет в начале 90-х,
хорошо разбирался в конструировании на основе FPGA. Когда я приехал
в Университет Сассекса (University of Sussex) для работы над диссертацией,
меня интересовала искусственная эволюция нейронных сетей (в этой области
университет Сассекса был и остается лидером). Опять-таки благодаря тому,
что я электронщик, я стал думать не о моделировании эволюции, а о том,
как ее на самом деле устроить для тех специализированных нейрочипов,
которые тогда были в наличии. Как совместить эволюцию с ограничениями,
налагаемыми архитектурой конкретного чипа? Как она может
воспользоваться специфическими особенностями этого чипа? Обдумывая
эти вопросы, я вскоре понял, что нейрочип - отнюдь не единственное
устройство, пригодное для экспериментов с эволюцией. Если вы хотите
заставить эволюцию заработать на куске кремния, почему там обязательно
должна присутствовать именно нейроархитектура? Не лучше ли будет
позволить эволюции манипулировать мелкоблочной (fine-grain) FPGA
и самой определить, какая архитектура лучше всего использует ресурсы чипа?
Мне посчастливилось тогда познакомиться с группой разработчиков из Xilinx,
которые как раз заканчивали работу над FPGA модели XC6216. Хотя к тому
времени существовало уже много гораздо более изощренных моделей FPGA,
эта была первой, идеально приспособленной для экспериментов с эволюцией.
Команда Xilinx отнеслась ко мне очень дружелюбно, и благодаря их поддержке
я получил возможность работать с этим замечательным чипом.
Я должен сказать, что принципиальные возможности для занятий хардверной
эволюцией существовали значительно раньше. Ведь вполне можно строить
интересные реконфигурируемые устройства на уровне обычных печатных
плат, используя какие-нибудь аналоговые переключательные чипы.
Собственно, в некоторых из наших исследовательских работ мы
и сегодня делаем именно это. Можно, разумеется, моделировать
эволюцию схем и программным путем, а полученный результат реализовывать
обычным способом. Первые публикации такого рода появились не менее десяти
лет назад. Хотя нашу группу больше всего интересует, что происходит
в результате эволюции физически реконфигурируемых чипов, моделированию
мы придаем очень большое значение. Может даже так случиться, что чем
больше мы будем узнавать о том, как работает эволюция для реальных
чипов, тем легче мы сможем в будущем полностью заменить такие опыты
программным моделированием! Это - открытая область исследований.
Каковы основные принципы организации эволюции в ваших опытах?
- В своих первых экспериментах я использовал самый примитивный
генетический алгоритм. В статье "An evolved circuit, intrinsic
in silicon...", которая, как и другие мои статьи, находится на моей
WWW-странице, есть описание экспериментальной установки. В данный
момент я работаю с другими вариантами эволюционных алгоритмов.
Возможностей здесь много.
Содержался ли, в той или иной форме, "ответ" уже в самом алгоритме
"обучения" или результат эволюции оказался совершенно неожиданным?
- Поведение полученной схемы было именно таким,
какого я старался добиться, и оно было точно описано с самого
начала. Но способы, которые для этого использует схема, действительно
оказались совершенно неожиданными. Я хотел, чтобы в процессе эволюции
могли возникать самые необычные структуры, в том числе и выходящие
за рамки общепринятых конструкторских решений. Для этого я предоставил
схеме максимальную свободу развития и не навязывал никаких правил.
Оказалось, что полученная схема использует очень тонкие и интересные
эффекты. Нам с Полем Лэйзеллом (Paul Layzell) потребовался добрый
месяц, чтобы в общих чертах разобраться, что же именно там происходит!
Об этой работе рассказывается в нашей статье "Analysis of Unconventional
Evolved Electronics".
Ваши первые устройства учились различать два звуковых сигнала
(гудка) различной частоты. Какие задачи решаются сегодня?
- Сначала мы заменили гудки словами "Go" и "Stop", которые произносились
в микрофон, после чего преобразовывались в потоки импульсов,
а те подавались на вход FPGA. Используя уже выработанное умение
различать гудки, эволюция без особого труда научила схему различать
и эти слова. Это доказывало, что у схем можно вырабатывать
потенциально полезные "навыки", пусть и довольно простые.
Главной проблемой, с которой мы столкнулись, оказалась
высокая чувствительность обеих схем (реагирующих на гудки
и на Go/Stop) к внешним условиям. Они правильно работали только
на одном определенном чипе, который использовался в эксперименте,
причем диапазон допустимых температур был не очень широк. Поэтому
до реальной практики еще далеко. И эта проблема носит общий
характер: я намеренно позволил эволюции как можно полнее использовать
любые свойства чипа, но за это пришлось платить падением устойчивости
к небольшим изменениям этих свойств. Поэтому теперь я работаю
с установкой, где есть несколько различных чипов, выпущенных
на различных фабриках, работающих при разных температурах,
разных напряжениях питания и т. д. За счет этого я пытаюсь создать
давление отбора (selection pressure), чтобы стимулировать появление
надежных схем без моего предварительного вмешательства в виде
внесения конструктивных ограничений. Животные и растения используют
множество интересных стратегий, чтобы добиться устойчивости. Эти
стратегии сильно отличаются от того, к чему мы привыкли в электронике,
но могут оказаться полезными при эволюционном подходе. Этому посвящена
моя статья "Temperature in Natural and Artificial Systems".
Работа по "выведению" надежных схем без предварительного
наложения конструктивных ограничений оказалась трудной.
Поэтому я ограничиваюсь пока простой задачей с различением
гудков, зная по эксперименту с Go/Stop, что потом можно будет
перейти к более сложным сигналам.
Каков спектр ожидаемых приложений этой технологии? Каковы задачи
на близкую, среднюю и дальнюю перспективу? В частности, чего можно
было бы добиться на существующем "материале"? И насколько широк его выбор?
- Я не рассматриваю свою работу по выведению нестандартных схем на XC6216
как поиск новых методов практического использования именно этого чипа
(хотя, кто знает...). Это просто удобный инструмент для исследований.
Мы занимаемся и программным моделированием эволюции схем, работаем
на реконфигурируемых печатных схемах, а также с реконфигурируемыми
аналоговыми устройствами фирм Motorola (правда, они недавно у нас
забрали свое устройство) и Zetex. Я думаю, что первыми приложениями
нестандартной хардверной эволюции будут совсем маленькие схемы,
используемые как элементы больших конструкций. Нас интересует
создание при помощи эволюции маленьких схем, потребляющих мало
энергии и, желательно, устойчивых к отказам. Мы также думаем
о применении эволюционных алгоритмов в качестве инструментов
разработки реконфигурируемых устройств в обычных CAD-системах.
Что касается материала, то он уже сейчас довольно разнообразен.
Во-первых, существует множество разновидностей FPGA, среди которых
есть даже аналоговые. Во-вторых, можно построить собственную
реконфигурируемую систему на уровне печатной платы
(см. WWW-страницы Поля Лэйзелла у нас в Сассексе). В-третьих,
есть группы, такие как группа Хигучи (Higuchi) в ETL, в Японии,
которые разрабатывают собственные реконфигурируемые чипы СБИС,
однако это не всем под силу, так как требует больших затрат денег
и времени. Кстати, я хотел бы выразить благодарность компаниям Xilinx,
Zetex, British Telecom, Hewlett-Packard и Algotronix за их помощь
в моей работе.