Научная статья на тему 'Алгебраические модели управляющих алгоритмов и программ реального времени для космических аппаратов'

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

CC BY
180
59
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
УПРАВЛЯЮЩИЕ АЛГОРИТМЫ / ПРОГРАММЫ РЕАЛЬНОГО ВРЕМЕНИ / КООРДИНАЦИЯ РАБОТЫ БОРТОВОЙ АППАРАТУРЫ / КОСМИЧЕСКИЙ АППАРАТ / КА / УПРАВЛЯЮЩИЙ АЛГОРИТМ РЕАЛЬНОГО ВРЕМЕНИ / УА РВ / АЛГЕБРАИЧЕСКИЕ МОДЕЛИ

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Тюгашев А. А.

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

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

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

Информатика

УДК 681.51:629.78 А. А. Тюгашев

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

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

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

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

др. [2-6].

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

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

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

Например, известна аксиоматическая формализация семантики программы, исходящая из формулировки так называемых постусловий и предусловий [2]. Данные условия есть часть языка алгоритмических логик, предложенных Флойдом, Хоаром [7], математиками польской логической школы практически одновременно в конце 1960-х гг., и включающего условия вида

{и } 5 {В},

читающиеся следующим образом: «и - условие, относящееся к исходным данным программы 5, истинное до ее выполнения, В - условие, относящееся к выходным данным программы 5, которое должно быть истинным после ее исполнения».

Данный подход не может быть прямо применен для случая управляющих алгоритмов реального времени, поскольку для них критически важным является осуществление корректного управления (под которым понимается выдача соответствующих управляющих воздействий) на всем промежутке времени функционирования алгоритма. Более того, для данного случая неприменим, без внесения соответствующих поправок, вообще классический подход к алгоритму как к набору действий для получения по завершении его работы определенного результата, т.к. в общем случае алгоритм управления может работать бесконечно, выполняя, тем не менее, возложенные на него функции. Как говорит основоположник использования темпоральной логики в исследовании программ А. Пнуели: «Нужно ли понятие внешнего времени, или темпорально-сти, для рассуждений о программах?.. для последовательных программ темпоральность не является существенной. Это так потому, что сами эти программы имеют «внутренние часы», а именно, само выполнение. Зная метку в программе и значения программных переменных, мы можем точно определить, в каком месте выполнения мы находимся. Поэтому для таких программ простые временные понятия, как «до» и «после» выполнения программного сегмента... адекватны. Но при обращении к программам индетерминистическим, параллельным, в которых выполнение состоит из перемешанных между собой операций из различных процессов, мы должны различать «где» и «когда», и сохранять внешнюю временную шкалу, независимую от выполнения» [6].

Будем рассматривать алгоритмы и программы дискретного реального времени, имеющие определенное время старта и завершения, то есть такие алгоритмы, функционирование которых синхронизируется некоторыми часами, и моменты времени выполнения действий задаются целыми числами, принадлежащими отрезку [/„, ^ ]. Единичное приращение на шкале времени соответствует одному «тику» системных часов Д( ш1п.

Сохраняя логический подход, определим семантику работы УА РВ, как успешную выдачу всех необходимых управляющих воздействий (выполнение всех целевых задач) во все требуемые моменты времени, или в обозначениях пред- и постусловий:

{ иФо,(,) } ¥5 { В(^),^())}, то есть в момент времени начала функционирования УА (0 истинно условие корректного задания исходных данных Д0, включающих программу полета, а к моменту завершения работы (к управляющего алгоритма истинен предикат В означающий успешное формирование всех управляющих воздействий Гк во все заданные моменты времени (1, (2,... (к на протяжении

функционирования системы.

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

Тогда семантика управляющего алгоритма может быть представлена в виде набора четверок объектов:

УАРВ = { < ^^I > }, I = ^ , где — функциональная задача (действие), ( — момент начала исполнения действия (/. есть неотрицательное целое число), т1 — длительность действия, 1! — логический вектор, обуславливающий действие. Компонентами логического вектора являются логические переменные (ЛП). При этом на логические переменные возлагается сразу несколько функций: во-первых, они отражают текущее состояние параметров внешней среды (включая показания датчиков, отражающих характеристики управляемого объекта); во-вторых, это могут быть предикаты, отражающие те или иные свойства обрабатываемых алгоритмом данных; в-третьих, они также могут являться «флагами» или «признаками», отражающими текущее состояние вычислительного процесса, в том числе, можно сопоставить каждой функциональной задаче связанный с ней предикат, который истинен тогда, когда данная ФЗ выполняется в параллельной вычислительной среде. Предположим, что всего в алгоритме задействовано М логических переменных ау, у = 1, М. В этом случае размерность логического вектора будет равна

М : I. = (а1, а2, ... аМ).

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

обуславливающий его логический вектор. Если значение некоторой логической переменной должно влиять на выполнение ФЗ, в соответствующей позиции логического вектора записывается значение 1 (ИСТИНА), либо 0 (ЛОЖЬ), если же значение данной ЛП не влияет на запуск функциональной задачи в момент времени t. , в соответствующей компоненте логического вектора записывается H (НЕВАЖНО). Таким образом, здесь применяется трехзначная логика.

В наборе среди четверок объектов задаются относительные смещения времени запуска ФЗ на выполнение, то есть присутствует некоторая базовая величина tyj^ = min (t.), i = 1, N, относительно которой смещениями задаются времена старта всех остальных задач. Ее можно принять за нулевую метку времени, или за некоторую целую константу, и таким образом привести весь алгоритм к абсолютной временной шкале. При этом общая длительность исполнения алгоритма будет равна T = max (t. + tt).

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

Сделаем следующее замечание. Значение истинности фигурирующей в описании УА логической переменной, в общем случае может меняться на протяжении его исполнения. Поэтому можно ввести в рассмотрение предикат, описывающий истинность значения ЛП ak в момент времени tt: p (ak, tt).

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

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

Выделим следующие варианты согласования выполнения ФЗ.

1. Совпадение по началу f CH f2, когда t1 = t2.

2. Совпадение по концу f СК f2, когда t1 + тх = t2 +12.

3. Непосредственное следование f ® f , когда t1 + tj = t2.

4. Простое предшествование f < f , когда tJ + т1 < t2.

5. Запрет на наложение f <> f , когда (tJ + < t2) v (t2 + t2 < tJ).

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

Обуславливание исполнения некоторой ФЗ каким-либо предикатом будем записывать следующим образом:

(a) => fj,

что означает выполнение f1 только в том случае, если логическая переменная a1 принимает значение ИСТИНА (данная запись эквивалентна записи aJ з f исчисления высказываний). Возможна также «полная» запись, соответствующая условному оператору языков программирования

(a) => f + (-a) => f

и читающаяся как исполнение ФЗ f в случае ложности aJ и исполнение f2 в противном случае.

Данный подход может быть формализован с помощью модифицированного исчисления УА РВ (впервые исчисление как модель формального представления УА РВ была предложена А. А. Калентьевым [8], им были введены символы СН, СК и ® как знаки для записи операций над управляющими алгоритмами).

Дополним определение нашей формальной теории. Она будет представлять собой эква-циональную спецификацию [6], то есть в ней присутствует эквивалентность (равенство), отражаемая символом =, что позволяет записывать уравнения.

Два УА РВ являются семантически эквивалентными, если они включают одни и те же функциональные задачи в те же моменты времени при одних и тех же условиях.

Алфавит образован символами / с численными индексами для обозначения ФЗ, символами а с численными индексами для обозначения логических переменных, а также включает символы логического отрицания 0, символ логического следствия (импликации) =>, символ логического выбора +, символы временных соотношений СН, СК, ®, символ эквивалентности =, и круглые скобки. Символы с численными индексами используются в метатеории для обозначения составных термов.

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

Множество термов определяется индуктивно:

1. Если (1 и (2 - термы, а - логическая переменная, то ((1), (1 СН (2, (1 СК (2, (1 > (2, (1 < (2, (1 <> (2, а=> (1, 0а=> (1 , (а) => (1 + (0а) => (2 — тоже термы.

Аксиомы модифицированного исчисления УА РВ включают в себя нижеследующие схемы аксиом ((1, (2 - термы, а - логическая переменная).

Аксиома равенства АО. (1 = (1.

Аксиомы идемпотентности А1. (1 СН (1 А2. (1 СК (1

Аксиомы коммутативности

А3. (1 СН (2 = (2 СН (

А4. (1 СК (2 = (2 СК (1

А5. (а) => (1 + (0а) => (2 = (0а) => (2 + (а) => (1

Аксиомы ассоциативности

А6. ((1 СН (2) СН (3 = (1 СН ((2 СН (3)

А7. ((1 СК (2) СК (3 = (1 СК ((2 СК (3)

А8. (?1 —— (2) —— (3 = ^1 —— (^2 —— (3)

А9. ((1 —— (2) —— (3 = ^1 —— (^2 —— (3)

Аксиомы дистрибутивности

А10. ((1 — (2) СН ((1 — (3) = (1 > ((2 СН (3)

А11. ((1 — (2) СК ((3 — (2) = ((1 СК (3) — (2

А12. (а) => ((1 — (2) + (0 а) => ((1 — (3) = (1 — ((а) => (2 + (0 а) => (3)

А12. (а) => ((1 — (2) + (0а) => ((3 — (2) = ((а) => (1 + (0а) => (3) — (2 А14. (а) => ((1 СН (2) + (0а) => ((1 СН (3) = (1 СН ((а) => (2 + (0а) => (3)

А15. (а) => ((1 СН (2) + (0а) => ((3 СН (2) = ((а) => (1 + (0а) => (3) СН (2 А16. (а) => ((1 СН (2) + (0а) => ((1 СН (3) = (1 СН ((а) => (2 + (0а) => (3)

А17. (а) => ((1 СК (2) + (0а) => ((3 СК (2) = ((а) => (1 + (0а) => (3) СК (2 А18. (а) => ((1 — (2) = ((а) => (1) — ((а) => (2)

А19. (а) => (( СН /2) = ((а) => /1) СН ((а) => /2)

А20. (а) => ((1 СК (2) = ((а) => (1) СК ((а) => (2)

Правила вывода включают следующие:

1. Если в схемах аксиом присутствует равенство (1 = (2, то выводимы также @((1) = 0((2), где 0 — произвольная подстановка (правило подстановки).

2. Если выводимы (1 = (2 и (2 = (3, то выводимо также (1 = (3.

3. Если выводимо (1 = (2, то выводимо также (2 = (1.

4. Если выводимы (1 < (2 и (2 < (3, то выводимо также (1 < (3.

5. Если выводимы (1 <> (2 и (2 <> (3, то выводимо также (1 <> (3.

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

В качестве интерпретации изложенной формальной теории можно использовать многоосновную алгебру УА РВ, имеющую в качестве множеств-носителей множество наборов четверок, описывающих семантику УА, и множество логических условий. При этом на множестве наборов четверок определяются операции во временном пространстве — совпадение по началу (СН), совпадение по концу (СК), непосредственное следование (—), на множестве логических условий — операции трехзначной логики согласно нижеследующей таблице истинности.

Вводится также операция обуславливания выполнения управляющего алгоритма истинностью или ложностью некоторого условия (=>). На множестве наборов четверок объектов в вышеуказанном смысле определяются также отношения (предикаты) неналожения <> и временного предшествования < .

Приведем некоторые примеры интерпретации операций и соотношений формального исчисления УА РВ, в алгебраической системе УА РВ.

П р и м е р 1. Операция СН (совпадение по началу). Пусть (1 = { < /1, (1 = /тп 20, 11 >,

</3, (3 = (1 + 50, 100, 13 >}, две ФЗ в УА, длительность 100 (2 = { </2, (2 = п 60, 12 > }, од-

на ФЗ в УА, длительность 60.

Тогда (3 = (1 СН (2 будет (3 = { < ^ (рез = (жп^ 20, /1 > , < ^ (рез = (шпV 40, 12 > ,

< /3, Срез + 50, 100, 13 > }, три ФЗ в УА, длительность 100.

П р и м е р 2. Операция СК (совпадение по концу). Пусть (1 = { < /1, (1 = /Ш1п 20, 11 >,

< .4 (3 = (1 + 50, 100, 13 > }, (2 = { < /2, (2 = (т1п (2 , 60, 12 > } .

Тогда (3 = (1 СК (2 будет (3 = { < /1,(1 = (т1п^, 20, /1 >, < /2, (2 = (1 + 90,60,/2 >,

< /3, (3 = (1 + 50,100, /3 >} . (длительность 50+100=90+60=150).

П р и м е р 3. Операция => (логическое обуславливание). Пусть

(1 = { < /Х, (1 = (т1п ^ 20, /1 = (а1 = 1 а2 =H, а3 = 0) > ,

< /3, (3 = (1 + 50, 100, /3 = (а1 =Н, а2 = Н, а3 = Н) >}.

Тогда (3 = (0а2) => (1 будет (3 = { < /1, (1 = (т1п (3, 20, /1 = (а1 = 1, а2 = 0, а3 = 0) >,

< /3, (3 = (1 + 50,100, /3 = (а1 =Н, а2 = 0, а3 = Н) >}.

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

X У х V У (ИЛИ) X л У (И) -х (НЕ)

0 0 0 0 1

1 1 1 1 0

Н Н Н Н Н

0 1 1 0 1

1 0 1 0 0

0 Н Н 0 1

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

1 Н 1 1 0

Н 1 1 Н Н

Н 0 Н 0 Н

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

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

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

В наиболее простом случае число включений равно просто количеству отличающихся друг от друга моментов времени /., содержащихся в семантике УА, и соответствующих моментам

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

Соединенная передачами управления между входами совокупность входов образует граф:

МЖМ = < Ж, и >,

где Ж — множество вершин (входов); и — множество дуг (передач управления между входами), т.е. бинарное отношение Ж х Ж .

В случае ациклического графа, наиболее распространенного варианта, должно выполняться условие последовательного запуска при передаче управления: если существует дуга (Ж, Ж/), то (0Ж < (0Ж , где (0Ж — момент включения входа Ж. , (0Ж --- момент включения вхо-

•У г ] г ]

да Ж).

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

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

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

Тогда логическая схема входа будет представлять собой граф (дерево):

Ш = < ьи, У >,

где Ьи — множество вершин графа (линейных участков), У — множество дуг — передач управления (ветвлений).

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

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

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

Логические условия, фигурирующие в многовходовой модели, по времени их значимости (актуальности) могут относиться к одному из трех типов: а((), то есть нас интересует значение логической переменной в текущий момент времени (, и с течением времени значение а может меняться; а((0), когда значение переменной может меняться, но нас интересует ее значение в определенный момент времени (0 (часто это момент начала исполнения УА) и последующие изменения значения во времени не должны влиять на исполнение ПКФ; астат, когда значение логической переменной не претерпевает изменений на всем промежутке исполнения УА.

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

Для случая a(t0) необходимо один раз в начале выполнения УА выяснить, к какому варианту необходимо прибегнуть, то есть один раз в момент времени t0 необходимо проверить все логические условия, фигурирующие во всех логических векторах, обуславливающих выполнение всех f , входящих в данный УА.

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

Таким образом, для случаев a(t0) и осстат можно считать, что от входа к входу логическая обусловленность «наследуется», и образуется цепочка входов, логически обусловленная аналогично логической обусловленности отдельной функциональной задачи f в модели семантики УА. При этом распределенная во времени цепочка входов является аналогом логической ветви исполнения обычного алгоритма, не выполняющегося в реальном времени, или одной из ветвей времени в логике ветвящегося времени Пнуели.

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

Описанные математические модели поддерживаются технологией визуального конструирования управляющих алгоритмов реального времени и реализующей ее инструментальной программной системой, функционирующей на платформе Windows 95/98/2000/XP (разработанной в основном средствами языка C/C++).

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

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

Таким образом, решается задача автоматического синтеза программы по спецификации ее характеристик.

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

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

БИБЛИОГРАФИЧЕСКИЙ СПИСОК

1. Управление космическими аппаратами зондирования Земли: Компьютерные технологии / Д. И. Козлов, Г. П. Аншаков, Я. А. Мостовой, А. В. Соллогуб. М.: Машиностроение, 1998. 328 с.

2. Логика и компьютер. Моделирование рассуждений и проверка правильности программ / А. М. Анисов, П. И. Быстров, В. А. Смирнов и др. М: Наука, 1990. 242 с.

3. Советов Б. Я., Яковлев С. А. Моделирование систем. М.: Высш. шк., 2001. 322 с.

4. Ben-AriM, Manna Z, Pnueli A.: The Temporal Logic of Branching Time. Proc. 8th Annual Symposium on Principles of Programming Languages, 1981, ACM Press, Williamsburg. Springer-Verlag, 1992. Р. 164-176.

5. Baeten J. C. M., Bergstra J. A. Real time Process Algebra. Formal Aspects of Computing, Vol. 3, 1991. Р.142-188.

6. Касьянов В. Н., Евстигнеев В. А. Графы в программировании: обработка, визуализация и применение. СПб.: БХВ-Петербург, 2003. 262 с.

7. Семантика языков программирования / Сб. статей под ред. К. Г. Батаева. М.: Мир, 1979. 223 с.

8. Калентьев А. А. Автоматизированный синтез алгоритмов асинхронного управления техническими системами с множеством дискретных состояний / Сам. гос. аэрокосм. ун-т. Самара, 1998. 204 с.

9. Тюгашев А. А. Проблема неоднозначности при порождении логико-временной структуры управляющего алгоритма по многовходовой модели реального времени // Сб. трудов Третьей международной молодежной школы-семинара БИКАМП-01, СПб, 2001. С. 179.

Поступила 12.05.2005 г.

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