ГЕРТ-СЕТЕВОЙ АНАЛИЗ МУЛЬТИВЕРСИОННЫХ АРХИТЕКТУР ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ > Полезные советы
Тысяча полезных мелочей    

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

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

Ковалёв П.В. Статья в формате PDF 175 KB Программное обеспечение, являясь неотъемлемой составляющей коммерческих и специальных систем управления и обработки информации, проникает во многие области современной жизни, но, несмотря на столь широкое распространение, программное обеспечение едва когда-либо было совершенно. На сегодняшний день разработаны различные методы проектирования отказоустойчивого программного обеспечения. Среди них одним из наиболее перспективных является метод мультиверсионного проектирования.

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

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

Опишем модель N-версионного программирования [2] (рис. 1) в виде ГЕРТ сети (рис. 2) и рассчитаем её основные хаpaктеристики, при условии, что количество мультиверсий N = 3, а остальные параметры описаны в табл. 1.

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

Таблица 1. Хаpaктеристика операций

Ветвь

Вероятность что операция будет выполнена (pi)

Тип распределения

Параметры (мс)

(1,4)

0,85

нормальное

m=0,5

σ=0,1

(2,4)

0,85

нормальное

m=0,5

σ=0,1

(3,4)

0,85

нормальное

m=0,5

σ=0,1

(4,выход)

0,99

нормальное

m=2

σ=0,5

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

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

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

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

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

Рассмотрим виды входных функций:

  • 1. AND-функция - узел активируется, если выполнены все дуги, входящие в него.
  • 2. IOR-функция - узел активируется, если выполнена любая дуга, входящая в него.
  • 3. EOR-функция - узел активируется, если выполнена любая дуга, входящая в него, при условии, что в данный момент времени может выполняться только одна дуга, входящая в данный узел.

Рассмотрим виды выходных функций:

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

- EOR-вход,

- IOR-вход,

- AND-вход,

- стохастический выход,

- детерминированный выход.

 

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

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

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

Рассмотрим расчет сети содержащей IOR вход и детерминированный выход рис. 4, состоящей из нескольких подсетей рис. 5.

Рис. 4. IOR-вход

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

Необходимо учитывать, что j - вычисляемый IOR-вход, имеющий стохастическое начало в узле i. {l1-m1}, {l2-m2}, ..., {lN-mN} - N непересекающихся подсетей.

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

   (1)

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

    (2)

Итак, воспользовавшись правилом Мейсона для замкнутых потоковых графов получим эквивалентную W-функцию [3] для этой сети:

      (3)

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

 мс      (4)

И дисперсия

 мс2      (5)

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

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

     (6)

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

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

СПИСОК ЛИТЕРАТУРЫ:

  1. Ковалёв, П.В. Определение надежности мультиверсионного программного обеспечения с использованием методов анализа сетей / П.В. Ковалёв, А. Н. Лайков, С. Н. Гриценко // Вестник СибГАУ. 2009. № 1(22) в 2 частях. Часть 2.
    с. 55-60.
  2. Algirdas Avizienis, The Methodology of
    N-Version Programming, in R. Lyu, ed itor, Software Fault Tolerance, John Wiley & Sons, 1995.
  3. Филлипс, Д., Гарсиа-Диас, А. Методы анализа сетей / Д. Филлипс, А. Гарсиа-Диас. М.: Мир, 1984.


Черкесов Борис Адамович

Черкесов Борис Адамович Статья в формате PDF 101 KB...

04 02 2025 21:53:58

ФИЛОСОФСКИЕ ОСНОВАНИЯ ОБЩЕЙ ТЕОРИИ ПАТОЛОГИИ: ПРИНЦИП ПОДОБИЯ

ФИЛОСОФСКИЕ ОСНОВАНИЯ ОБЩЕЙ ТЕОРИИ ПАТОЛОГИИ: ПРИНЦИП ПОДОБИЯ В основе современной научной теории патологии должны лежать фундаментальные философские принципы бытия материи, из которых выводятся и обосновываются ее основные положения. В данной работе проведен анализ принципа подобия как частного выражения философского принципа субстанциального единства мира. Делается вывод, что один общий биологический процесс лежит в основе как нормальных, так и патологических явлений: приспособление есть сущность болезни. ...

02 02 2025 15:37:27

КАК МЫ ПОНИМАЕМ ПАТРИОТИЗМ СЕГОДНЯ

КАК МЫ ПОНИМАЕМ ПАТРИОТИЗМ СЕГОДНЯ Статья в формате PDF 412 KB...

30 01 2025 13:46:10

СОДЕРЖАНИЕ ОБРАЗОВАНИЯ В СЕЛЬСКИХ ШКОЛАХ

СОДЕРЖАНИЕ ОБРАЗОВАНИЯ В СЕЛЬСКИХ ШКОЛАХ Статья в формате PDF 91 KB...

29 01 2025 20:55:57

ОСНОВЫ РАДИОЭЛЕКТРОНИКИ И СВЯЗИ (учебник)

ОСНОВЫ РАДИОЭЛЕКТРОНИКИ И СВЯЗИ (учебник) Статья в формате PDF 106 KB...

28 01 2025 1:19:15

ФИЛОСОФИЯ В КОНТЕКСТЕ ФИЗИЧЕСКОЙ КУЛЬТУРЫ

ФИЛОСОФИЯ В КОНТЕКСТЕ ФИЗИЧЕСКОЙ КУЛЬТУРЫ Статья в формате PDF 297 KB...

21 01 2025 4:28:43

ТЕНДЕНЦИИ РАЗВИТИЯ БЕЗЛЮКОВЫХ КОНТЕЙНЕРОВОЗОВ

ТЕНДЕНЦИИ РАЗВИТИЯ БЕЗЛЮКОВЫХ КОНТЕЙНЕРОВОЗОВ Статья в формате PDF 268 KB...

04 01 2025 6:25:54

ФЕНОТИПИЧЕСКАЯ ДИАГНОСТИКА СЕЛЬСКОЙ МЕСТНОСТИ

ФЕНОТИПИЧЕСКАЯ ДИАГНОСТИКА СЕЛЬСКОЙ МЕСТНОСТИ Статья в формате PDF 321 KB...

02 01 2025 9:21:39

ЛИЧНОСТНЫЕ АКЦЕНТУАЦИИ У ЗАКЛЮЧЕННЫХ

ЛИЧНОСТНЫЕ АКЦЕНТУАЦИИ У ЗАКЛЮЧЕННЫХ Статья в формате PDF 118 KB...

28 12 2024 23:12:49

Еще:
Поддержать себя -1 :: Поддержать себя -2 :: Поддержать себя -3 :: Поддержать себя -4 :: Поддержать себя -5 :: Поддержать себя -6 :: Поддержать себя -7 :: Поддержать себя -8 :: Поддержать себя -9 :: Поддержать себя -10 :: Поддержать себя -11 :: Поддержать себя -12 :: Поддержать себя -13 :: Поддержать себя -14 :: Поддержать себя -15 :: Поддержать себя -16 :: Поддержать себя -17 :: Поддержать себя -18 :: Поддержать себя -19 :: Поддержать себя -20 :: Поддержать себя -21 :: Поддержать себя -22 :: Поддержать себя -23 :: Поддержать себя -24 :: Поддержать себя -25 :: Поддержать себя -26 :: Поддержать себя -27 :: Поддержать себя -28 :: Поддержать себя -29 :: Поддержать себя -30 :: Поддержать себя -31 :: Поддержать себя -32 :: Поддержать себя -33 :: Поддержать себя -34 :: Поддержать себя -35 :: Поддержать себя -36 :: Поддержать себя -37 :: Поддержать себя -38 ::