Научная статья на тему 'Графоаналитический метод анализа мультиверсионных архитектур программного обеспечения'

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

CC BY
270
84
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
НАДЕЖНОСТЬ / МУЛЬТИВЕРСИОННОСТЬ / СЕТИ / МЕТОДЫ ОЦЕНКИ / МЕТОДЫ АНАЛИЗА СЕТЕЙ / RELIABILITY / N-VERSION / NETWORKS / ESTIMATION METHODS / NETWORK ANALYSIS

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Капчинский Илья Аркадьевич, Ковалев Павел Владимирович, Гриценко Сергей Николаевич

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

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

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Капчинский Илья Аркадьевич, Ковалев Павел Владимирович, Гриценко Сергей Николаевич

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

Graph-analytic research of software based on N-version architecture

In this article the research technique the N-version software reliability is offered. It allows using algorithms and methods of network analysis for the reliability research of software, developed using N-version approach.

Текст научной работы на тему «Графоаналитический метод анализа мультиверсионных архитектур программного обеспечения»

УДК 004.052.3

И. А. Капчинский, П. В. Ковалев, С. Н. Гриценко

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

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

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

Компоненты программного обеспечения (ПО), обладающие свойством отказоустойчивости, уже много лет являются неотъемлемой составляющей как коммерческих, так и специальных систем управления и обработки информации. Известны различные методы проектирования отказоустойчивого программного обеспечения [1]. Хорошие перспективы в этой области имеет метод муль-тиверсионного проектирования [2].

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

Одним из таких подходов является графоаналитический метод, основанный на использовании вЕКГ- сетей [3]. Основное достоинство этого подхода заключается в том, что он может быть успешно применен к решению практически любой задачи сетевого анализа и дает возможность составить формальные процедуры для определения вероятностно-временных характеристик системы.

Опишем модель мультиверсионного ПО, основанного на Ж-версионной архитектуре [4] (рис. 1) в виде вЕКГ-сети (рис. 2), и рассчитаем ее основные характеристики при условии, что количество мультиверсий N = 3, а остальные параметры представлены в таблице.

Узлы стохастической сети (см. рис. 2) могут быть интерпретированы как состояния системы, а дуги - как переходы из одного состояния в другое. Такие переходы можно рассматривать как выполнение обобщенных операций, характеризуемых плотностью распределения, или функцией массы, и вероятностью выполнения [5].

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

Рис. 1. Модель Диверсионного программирования

Рис. 2. Модель Д-версионного программирования в виде СЕКТ-сети

Существуют следующие виды входных функций:

- АМЭ-функция (узел активируется, если выполнены все дуги, входящие в него);

- ЮЯ-функция (узел активируется, если выполнена любая дуга, входящая в него);

Характеристика операций

Ветвь Вероятность того, что операция будет выполнена р1 Тип распределения Параметры, мс

(1, 4) 0,85 Нормальное т = 0,5 ст = 0,1

(2, 4) 0,85 Нормальное т = 0,5 ст = 0,1

(3, 4) 0,85 Нормальное т = 0,5 ст = 0,1

(4, выход) 0,99 Нормальное т = 2 ст = 0,5

Математика, механика, информатика

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

Используются следующие виды выходных функций:

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

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

Комбинируя все входные и выходные функции (рис. 3), получаем шесть различных типов узлов. Активация узла означает, что система перешла в некоторое состояние, и определяет множество возможных дальнейших действий. Одно или несколько действий начинают свое выполнение сразу после активации узла, являющегося их началом. Активация узла происходит, если его входная функция выполнена. После выполнения выходной функции активированного узла, т. е. начала выполнения соответствующей дуги, он становится неактивным [3].

<

1СЖ-вход АЫО-вход

3

Стохастический выход Детерминированный выход

Рис. 3. Графическое обозначение входных и выходных функций ОЕКГ-сети

Необходимым и достаточным условием функционирования мультиверсионного модуля ПО является выполнение хотя бы одной мультиверсии. Поэтому узел 4 на рис. 2 является узлом с ЮЯ-входом. Выбор данного типа узла основан на том, что этот узел активируется при выполнении любой дуги, входящей в него.

Рассмотрим методику расчета сети, содержащей 1ОЯ-вход и детерминированный выход (рис. 4) и состоящей из нескольких подсетей (рис. 5).

к

с

EOR-вход

Рис. 4. ЮЯ-вход: у - вычисляемый ЮЯ-вход, имеющий стохастическое начало в узле г; {/1 - т1}, {12 - т2},

{1Ж - тЖ} - N непересекающихся подсетей

I—/77

Рис. 5. Произвольная подсеть с начальным узлом 1 и конечным узлом т

(1)

Пусть р. - вероятность того, что операция (г,у) будет вы-полнена при условии, что узел г выполнен. Тогда по представленной выше таблице имеем:

Ру = Рг [1 - (1 - РпМк ) х

Х(1 - Р12,т2* )-(1 - Р,я,т„Ь )]

Учитывая, что от входа до узла 4 находится три непе-ресекающиеся подсети, используя выражение (1), в данном частном случае получим

Р4 = Рвх [1 - (1 - Р1)(1 - Р2)(1 - Р3)] =

= 1 -(1 - 0,85)3 = 0,996 625. Воспользовавшись правилом Мейсона для замкнутых потоковых графов, выведем эквивалентную ^-функцию [5] для этой сети:

WE (5) = Wz (5) ^) =

(2)

0,5s +- 0,12-j2

= 0,996 6е 2

= 0,986 6е2

2s+-0,52-j2

0,99е 2

(3)

Легко проверить, что для рассматриваемой задачи WE (0) = 0,986 6. Данную величину можно интерпретировать как вероятность безотказной работы мультиверсионного ПО. В свою очередь математическое ожидание времени выполнения сети составит

miE =-

дыЕ (j )

ds

д

We (s) We (0)

ds

= 2,5 мс, (4)

а дисперсия будет

miE =■

d2 Me (s)

ds2

= 6,51 мс2.

(5)

Следует заметить, что при расчете сети, содержащей IOR-вход и детерминированный выход, если все подсети представляют собой мультиверсионный модули с одинаковой надежностью, то формула (1) может быть сведена к виду

Pj = Pt ‘[I - (1 - Pi, m )” ]• (6)

Графическая зависимость между числом мультиверсионных модулей и надежностью системы приведена ниже (рис. 6). На оси Х обозначено количество мультиверсий, на оси Y - надежность системы для разного количества модулей с разной надежностью каждого модуля (от 30 до 80 %).

- 30 ■ 40 • 50

60

70

Количество модулей

Рис. 6. Зависимость между числом мультиверсионных модулей и надежностью системы

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

Библиографический список

1. Kovalev, I. System of Multi-Version Development of Spacecrafts Control Software I I. Kovalev. Sinzheim : Universitate Verlag, 2001.

2. Ковалев, И. В. Мультиверсионный метод повышения программной надежности информационно-телекоммуникационных технологий в корпоративных структурах I И. В. Ковалев, Р. В. Юнусов II Телекоммуникации и информатизация образования. 2003. N° 2 (15). С. 50-56.

3. Ковалев, П. В. Определение надежности мультиверси-онного программного обеспечения с использованием методов анализа сетей I П. В. Ковалев, А. Н. Лайков, С. Н. Гриценко II Вестник СибГАУ 2009. № 1 (22). Ч. 2. С. 55-60.

4. Avizienis, A. The Methodology of N-Version Programming! A. Avizienis II Software Fault Tolerance. New York : John Wiley & Sons, 1995.

5. Филлипс, Д. Методы анализа сетей I Д. Филлипс, А. Гарсиа-Диас. М. : Мир, 1984.

I. A. Kapchinsky, P. V. Kovalev, S. N. Gritzenko

GRAPH-ANALYTIC RESEARCH OF SOFTWARE BASED ON N-VERSION ARCHITECTURE

In this article the research technique the N-version software reliability is offered. It allows using algorithms and methods of network analysis for the reliability research of software, developed using N-version approach.

Keywords: reliability, N-version, networks, estimation methods, network analysis.

© Капчинский И. А., Ковалев П. В., Гриценко С. Н., 2009

УДК 681.3

Е. А. Энгель, О. И. Завьялова

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

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

Ключевые слова: нейронная сеть, иерархия, распознавание.

Существующие в настоящее время системы распознавания образов на базе искусственных нейронных сетей (ИНС) обладают значительным количеством недостатков. В частности при разработке комплексов, решающих проблему интерпретации изображений, особое внимание уделяется узнаванию определенных групп образов. Однако поиск в доступных источниках информации о системах, способных к саморазвитию, т. е. к «расширению кругозора», приводит к крайне скудным результатам. Это объясняется высокой сложностью проектирования и реализации проектов такого класса. Ведь на самом деле реальный процесс распознавания, протекающий в самой совершенной системе анализа - человеческом мозге, состоит не только в том, чтобы проверить сход -ство анализируемого объекта с запомненным эталоном. Это достаточно сложное взаимодействие между различными подсистемами мозга. Ошибочно также считать, что

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

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

Другим немаловажным аспектом создания систем распознования образов является выделение существенных фрагментов сцены для их интерпретации, т. е. селекция образов, расположенных на сцене. В противном слу-

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