Научная статья на тему 'Структура цифрового организма в самоорганизующихся программных системах'

Структура цифрового организма в самоорганизующихся программных системах Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
190
51
i Надоели баннеры? Вы всегда можете отключить рекламу.
i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Структура цифрового организма в самоорганизующихся программных системах»

УДК 004.42

СТРУКТУРА ЦИФРОВОГО ОРГАНИЗМА В САМООРГАНИЗУЮЩИХСЯ ПРОГРАММНЫХ СИСТЕМАХ

Е.А. Кольчугина, к.т.н.

(Пензенский государственный университет, [email protected])

Введено понятие самоорганизующейся программной системы. Предложено описание структуры цифрового организма в терминах теории нумераций.

Ключевые слова: самоорганизация, искусственная химия, нумерации, программный агент.

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

Применительно к программным системам способность к самоорганизации может означать:

- способность к самовосстановлению после сбоев и повреждений;

- способность к самообучению и адаптации;

- саморазвитие и самоконструирование программных систем вплоть до появления программ с совершенно новыми, ранее не ожидавшимися проектировщиком, но полезными свойствами.

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

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

Главными вопросами создания самоорганизующихся программных систем являются:

- определение принципов построения сред, в которых могут происходить процессы самоорганизации;

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

Самоорганизация и модели искусственной химии

В [1] выделены два вида самоорганизации: когерентная (или синергетическая) и континуальная (или синкретическая).

Первый вид самоорганизации связан с упорядочением на уровне макросистем путем согласования параметров микросистем. Примерами такой самоорганизации служат когерентность излучения в лазере, образование ячеек Бенара, коллективное поведение живых организмов и программных агентов.

Второй вид самоорганизации связан с упорядочением на уровне микросистем, когда благодаря взаимодействию разнородных компонентов образуются целостные системные объекты. Средой для такого вида самоорганизации служат кинетические континуумы веществ и процессов, то есть множества химических реакций. Именно этот вид самоорганизации привел к появлению сначала биомолекул, а затем и живых организмов.

Самоорганизация синкретического типа является более сильным видом самоорганизации, так как приводит к появлению принципиально новых структур. Для исследования процессов такой самоорганизации можно использовать модели искусственной химии подраздела теории искусственной жизни.

Целью разработки модели алгоритмической химии AlChemy У. Фонтана [2] было исследование возникновения новшеств, в первую очередь, появление в модели новых структур и правил. Правила преобразования структур соответствовали реакциям, а сами структуры - молекулам. Фонтана обратил внимание на взаимную двойственность как молекул и реакций, так и данных и программного кода. Молекулы - это пространственные структуры, которые определяют функциональность как множество возможных реакций. Аналогично программы задают последовательности действий по обработке данных, но символьная запись программы может рассматриваться как данные.

Данные и программы можно обобщенно рассматривать как функции от нуля (для данных) и большего числа аргументов. Функции в модели AlChemy рассматриваются как молекулы. Реакция в AlChemy представляет собой композицию функций, записанных на Х-подобном языке.

Двойственность данных и программ была использована в моделях искусственной химии Tierra и Avida [3]. В этих моделях вводится понятие

цифрового организма как строки псевдоассемблерных команд, которая может рассматриваться либо как данные и переписываться другими организмами, либо как набор инструкций процессора виртуальной ЭВМ.

Структурная модель цифрового организма

Для белковой жизни важное значение имеют молекулы нуклеиновых кислот: ДНК и РНК, участвующие в матричных процессах и являющиеся носителями наследуемой информации.

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

По аналогии для задания свойств цифрового организма, входящего в состав сообщества самоорганизующихся программных агентов, автором в [4] было предложно использовать кодовую числовую последовательность. При этом номер позиции в кодовой последовательности определяет кодируемое свойство, поведенческое или структурное, а код, содержащийся в позиции, определяет значение переменной состояния или программную реализацию некоторой полиморфной макрооперации или поведенческого блока. Таким образом, цифровой организм в модели [4] обладает генотипом и фенотипом.

Кодовая последовательность, определяющая генотип организма и задающая первичную структуру цифровой ДНК, получила в модели [4] название суперхромосомы.

Коды значений переменных и программных реализаций поведенческих блоков можно рассматривать как номерные множества нумераций [5]. Если для представления нумераций использовать БД, то номерные множества будут соответствовать ключам, на основе которых можно получить программные реализации поведенческих блоков и значения переменных состояния, то есть синтезировать фенотип цифрового организма.

Нумерацией здесь и далее будем называть взаимнооднозначное отображение множества номеров на множество нумеруемых объектов:

Voъз■ М^ОЬ/,

Обратную к vOЪj функцию назовем функцией индексирования: indOЪj■ УоЬь е ОЬ :

VОЫ,- (оЬь) = тЛоы (оЪ1).

Рассматривая структуру суперхромосомы, будем различать:

- локусы, или элементарные участки суперхромосомы;

- номера, или индексы локусов;

- значения, находящиеся в локусах суперхромосомы.

Структура суперхромосомы может быть определена как множество локусов, упорядоченных по индексу [4]:

StrSupChr = {loel, loc2,..., locn),

Loe = (loc,. .

Здесь Loc - не более чем счетное множество всех локусов, которые могут входить в состав структуры суперхромосомы. Индексы локусов будем определять с помощью функции IndLoc:

Loc^Nboc, NlocC No+.

Каждому локусу поставим в соответствие взаимнооднозначным образом элемент программы из

множества Item=ParamsUBH, то есть или глобальную переменную состояния из множества всех глобальных параменных состояния Params, или

поведенческий блок bheBH, где BH = {bh¡}¡ -

множество всех блоков поведения: Locus: Item^ ^Loc.

С учетом того, что локусам соответствуют элементы программы, представляющие либо код, либо данные, множество локусов можно представить как Loc=LocBHULocParams,, LocBHnLocPar=0. Элементы множества Items можно обобщенно рассматривать как функции или аналоги молекул в модели AlChemy, а сам цифровой организм - как совокупность молекул и реакций [6].

Можно построить функцию, ставящую в соответствие каждому элементу программы индекс локуса в структуре суперхромосомы и являющуюся композицией функций Locus и indLoc:

Pos: hems ® NLoc, NLoc с N0+, Pos = ind. o Locus.

Loc

На рисунке 1 приведена коммутативная диаграмма для функций Pos, Locus, indLoc.

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

D0mitems: Items ® {Y +, VYt :(Y е P (Val)) 0 (Y¡ е P (Code)),

Val о Code = 0 , где Val - множество всех возможных значений для всех параметров из Params; Code - множество всех возможных программных реализаций для

всех элементов BH; P(X) - булеан X; ф - знак, обозначающий операцию «исключающее ИЛИ». Каждое множество Y, является элементом одного из булеанов, то есть подмножеством либо Val, либо Code.

Используя отображение Pos и функции indr ,

заданные на всех множествах Y„ свяжем индекс локуса с множеством индексов возможных значений или программных реализаций соответствующего элемента программы:

Dom,

NLoc ^

{Z¡ |VZ¡ = Im (indY¡) и Null}

P (Val )|+| P(Code)

Здесь каждому номеру локуса ставится в соответствие множество значений функций индексирования (Im(X) - область значений X), заданных на множествах Y,. Каждое множество значений функции индексирования дополняется особым элементом Null, означающим, что для элемента программы не определены (отсутствуют) значение или реализация. Отображение DomN позволяет

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

Структура суперхромосомы описывает общий принцип организации цифровой ДНК для всех программных агентов (цифровых организмов) данной модели, то есть задает шаблон. Конкретный экземпляр цифровой ДНК, то есть сама суперхромосома, отражает состояние генома конкретного агента в определенный момент времени. Функция iv позволяет вычислить значение локуса

в заданное время tj&T для цифрового организма

a,eA:

iv: АхТ хNLoc ® Dom

(NLoc ):

где A = {a }. — не более чем счетное множество

всех цифровых организмов (программных агентов); T - время, заданное как линейно упорядоченное множество T = {t, | (Vt, е N0+) ti < tM}. В общем случае

iv (a, tj, Ы Loc (loct) ) е DomNLoc

(indLoc (lock )),

а ситуации, когда это неверно, являются аномальными.

На основе функции iv можно дать описание суперхромсомы, или цифровой ДНК, как последовательности значений, описывающей состояние

особи а,ЕЛ в момент tET:

SupChr (a;, tj) =

= (iv (a,., tj, indLoc (loc0)),..., iv (a., tj, mdLoc (hc:n ))}.

Операции над цифровой ДНК

Над введенной первичной структурой цифровой ДНК в первую очередь могут быть выполнены операции, являющиеся аналогами операций генетических алгоритмов [4].

Но основной операцией следует считать сборку цифрового организма на основе кодовой последовательности (цифровой ДНК) и БД (рис. 2). Для реализации операции сборки необходим отдельный системный процесс, который будет одновременно контролировать отсутствие аномалий и проверять на основе заданной системы правил допустимость присутствия в вычислительной среде цифрового организма с закодированными в цифровой ДНК свойствами.

Цифровая ДНК (матрица)

Рис. 2

Реализация предложенной модели цифрового организма может быть выполнена с использованием различных средств: языков скриптового типа, XML или языков типа С\С++.

В заключение можно сделать следующие выводы. Совместное применение результатов теории искусственной жизни и теории нумераций позволяет создать модель программной системы, в которой возможны процессы самоорганизации когерентного и континуального типов, что свидетель-

ствует о прогрессивной эволюции и появлении программных агентов с совершенно новыми свойствами.

Необходимо подчеркнуть, что процессы самоорганизации должны происходить только в среде виртуальной ЭВМ, множество команд которой полностью отличается от множества команд реально используемого физического процессора. Только такой подход гарантирует управляемость процессов самоорганизации и их безопасность, так как имеется возможность непосредственного анализа генотипа цифровых организмов и исключения выполнения программных агентов с нежелательными свойствами.

Литература

1. Руденко А.П. Самоорганизация и синергетика. URL: http://utc.uni-dubna.ru/~mazny/students/site2/ideal_2.htm (дата обращения: 10.05.2011).

2. Fontana W. Algorithmic Chemistry // Artificial Life II, SFI Studies in the Sciences of Complexity. Vol. X, edit. by C.G. Langton, C. Taylor, J.D. Farmer, S. Rasmussen. Redwood City, CA: Addison-Wesley, 1991, pp. 159-209.

3. Dittrich P., Ziegler J., Banzhaf W. Artificial Chemistries - A Review // Artificial Life. 2001. Vol. 7. (No. 3), pp. 225-275.

4. Кольчугина Е.А. Модель эволюционирующего программного обеспечения // Изв. вузов. Поволж. рег. Технич. науки. Пенза: ИИЦ ПГУ. 2006. № 6 (27). С. 78-86.

5. Ершов Ю.Л. Теория нумераций. М.: Наука, 1977. 416 с.

6. Кольчугина Е.А. Неравновесное программирование // Изв. вузов. Поволж. рег. Технич. науки. Пенза: ИИЦ ПГУ. 2009. № 3 (11). С. 25-31.

УДК 519.62:519.7:004.42

МЕТОД ВИРТУАЛЬНОЙ ПЕРСПЕКТИВЫ И МОДЕЛИРОВАНИЕ В УСЛОВИЯХ ОГРАНИЧЕНИЙ И НЕОПРЕДЕЛЕННОСТИ

А.В. Мышев, к.ф.-м.н. (Обнинский институт ядерной энергетики, филиал НИЯУ «МИФИ», [email protected])

Излагаются и формулируются основные положения и принципы метода виртуальной перспективы в методологии разработки и реализации технологий компьютерного моделирования в условиях ограничений и неопределенности (размытые задачи). Основу разрабатываемого метода составляют теория виртуальных решеток, модели активной памяти и процессы с локальным информационным взаимодействием в виртуальной среде моделирования. Решения моделируемых задач строятся в виде комплексов на клеточных топологиях квантовых дискретных пространств (решетки, графы).

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

Метод виртуальной перспективы, с одной стороны, является развитием индуктивного структурного подхода синтеза образов решений неустойчивых размытых задач в виде топологических структур на квантовых дискретных пространствах [1, 2], а с другой - определяет методологическую основу осуществления новых форм компьютинга для технологий моделирования обозначенных задач в условиях ограничений среды вычислений и информационной неопределенности. Следует отметить, что здесь компьютинг определяется в терминах фундаментальных принципов [3], то есть как наука об информационных процессах в технологиях моделирования компьютерных вычислительных систем.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

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

в-третьих, теория процессов с локальным информационным взаимодействием [1, 4].

Динамические модели вычислительных технологий. Информационными объектами компьютерных процессов в виртуальной среде моделирования являются взаимодействующие цепочки символов, а любой математический объект среды вычислений определяется и описывается в виде логической структуры таких цепочек. Среда взаимодействия объектов компьютерных процессов в вычислительных технологиях включает следующие основные атрибуты-посредники: виртуальная алгоритмическая переменная, операторы взаимодействия, логическая структура в адресном пространстве ограниченной памяти вычислительной системы и др. Интуитивно понятно, что среда вычислений вмещает в себя все или почти все, что относится к получению результата: в ней имеются переменные и их фактические значения, а сами они разнесены не только позиционно, но и контекстно. Тогда все информационные объекты моделируемой задачи и информационную виртуальную среду вычислений можно описать, используя

i Надоели баннеры? Вы всегда можете отключить рекламу.