Верификация автоматных программ Г. А. Корнеев А. А. Шалыто Санкт-Петербургский государственный университет информационных технологий, механики и оптики.

Презентация:



Advertisements
Похожие презентации
Технология верификации управляющих программ со сложным поведением, построенных на основе автоматного подхода Руководитель проекта – А. А. Шалыто Докладчик.
Advertisements

Автор: Вельдер С. Э., аспирант Руководитель: Шалыто А. А., доктор технических наук, профессор, заведующий кафедрой «Технологии программирования» Верификация.
Автоматное программирование А. А. Шалыто Санкт-Петербургский государственный университет информационных технологий, механики и оптики 2009 г.
Применение автоматного программирования во встраиваемых системах В. О. Клебан, А. А. Шалыто Санкт-Петербургский государственный университет информационных.
Совместное применение генетического программирования и верификации моделей для построения автоматов управления системами со сложным поведением К. В. Егоров,
Применение генетического программирования для построения автоматов А. А. Шалыто Г. А. Корнеев Санкт-Петербургский государственный университет информационных.
Автоматное программирование А.А. Шалыто Санкт-Петербургский государственный университет информационных технологий, механики и оптики 2007 г.
Разработка программного средства 3Genetic для генерации автоматов управления системами со сложным поведением Государственный контракт «Технология.
Построение автоматов управления системами со сложным поведением на основе тестов с помощью генетического программирования Федор Николаевич Царев, СПбГУ.
Верификация автоматных программ Ремизов А.О., д.т.н., проф. Шалыто А.А.
Применение генетического программирования для реализации систем со сложным поведением Санкт-Петербургский Государственный Университет Информационных Технологий,
1 Метод сокращенных таблиц для генерации автоматов с большим числом входных воздействий Автор Научный руководитель В. Н. Точилин А. А. Шалыто Санкт-Петербургский.
Виртуальная лаборатория для первоначального обучения проектированию программ Н. Н. Красильников, В. Г. Парфенов, Ф. Н. Царев, А. А. Шалыто Кафедра компьютерных.
Применение метода представления функции переходов с помощью абстрактных конечных автоматов в генетическом программировании Царев Ф. Н. Научный руководитель.
Докладчик: Бульёнов А. В., аспирант Научный руководитель: Шалыто А. А., д. т. н., профессор, зав. кафедрой КТ Методы автоматного программирования в разработке.
Исследовательский центр СПбГУ ИТМО «Технологии автоматного программирования» Научный руководитель Шалыто А. А. Кафедра компьютерных технологий Кафедра.
Графическая нотация наследования автоматных классов Данил Шопырин ЗАО «Транзас Технологии» Анатолий Шалыто СПбГУ ИТМО.
Использование автоматного программирования для построения систем управления мобильными роботами В. О. Клебан, А. А. Шалыто Кафедра компьютерных технологий.
Движение за открытую проектную документацию Анатолий Шалыто Кафедра Компьютерные технологии Санкт-Петербургский государственный университет.
Разработка методов машинного обучения на основе генетических алгоритмов и эволюционной стратегии для построения управляющих конечных автоматов Второй этап.
Транксрипт:

Верификация автоматных программ Г. А. Корнеев А. А. Шалыто Санкт-Петербургский государственный университет информационных технологий, механики и оптики

2 Верификация автоматных программ Виды верификации Динамическая Тестирование Статическая Доказательная Верификация на модели

3 Верификация автоматных программ Верификация модели программы Построение модели Крипке Соответствие модели программе Построение формальных требований Формулировка требований в терминах модели Крипке Формальная верификация Большая размерность пространства состояний Отображение контрпримеров Преобразования контрпримеров в термины исходной программы

4 Верификация автоматных программ Верификация автоматной модели программы Формальное построение модели Крипке Возможность автоматизации Формулировка требований В терминах автоматов Формальная верификация Рассмотрение управляющих состояний Формальное восстановление контрпримеров В терминах исходной модели

5 Верификация автоматных программ Верификация с применением SPIN

6 Верификация автоматных программ Построение описания автомата на языке Promela Переменная состояния Инициализируется начальным состоянием Автоматная процедура Switch по номеру текущего состояния Недетерминированный переход в следующее состояние

7 Верификация автоматных программ Обработка событий Описание потока событий в терминах темпоральной логики Извлечение события из очереди при переходе

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

9 Верификация автоматных программ Состояния объектов управления Объекты управления не имеют состояния Объекты управления имеют состояния Описание изменения состояния в терминах темпоральной логики

10 Верификация автоматных программ Управление дверьми лифта

11 Верификация автоматных программ Фрагмент описания на языке Promela int stateA1 = CLOSED; inline A1() { do ::stateA1 == CLOSING -> if ::stateA1 = CLOSED; event = e4; ::stateA1 = OPENING; event = e5; fi;... od; }

12 Верификация автоматных программ Верифицируемые утверждения 1. Двери открываются бесконечное число раз LTL: G F Opened Promela: - [] Opened 2. Двери закрываются бесконечное число раз LTL: G F Closed Promela: - [] Closed

13 Верификация автоматных программ Верификация утверждений Утверждение 1 выполняется Утверждение 2 не выполняется: A1 [stateA1 = CLOSED] A1 [stateA1 = OPENING] A1 [stateA1 = OPENED] A1 [stateA1 = CLOSING] A1 [stateA1 = OPENED]

14 Верификация автоматных программ Верификация с применением Bogor

15 Верификация автоматных программ Применяемые методы Симуляция Двойной поиск в глубину Увеличение «масштаба» переходов

16 Верификация автоматных программ Структура описания автоматов Абстрактный тип данных «Автомат» Выбор следующего перехода «Откат» на состояние назад Восстановление ошибочного пути Система автоматов Взаимодействия через номера состояний Взаимодействие по вложенности

17 Верификация автоматных программ Практическое использование Ручная верификация Верификация проектов, опубликованных на сайте Автоматизированная верификация Основана на существующих верификаторах

18 Верификация автоматных программ Повышение качество программного обеспечения Верификация управляющих программ в NASA Stateflow SPIN Верификация проектов, опубликованных на сайте UniMod SPIN или Bogor

19 Верификация автоматных программ Выводы Простота верификации автоматных программ Возможность автоматизации верификации Практическая применимость

20 Верификация автоматных программ Направление дальнейших исследований Разработка примера верификации системы со сложным поведением Проведение экспериментальных исследований Разработка предложений и рекомендаций по использованию результатов НИР

21 Верификация автоматных программ Публикации по теме (1) 1. Вельдер С.Э., Шалыто А.А. О верификации простых автоматных программ на основе метода «Model Checking» //Информационно- управляющие системы Корнеев Г.А., Парфенов В.Г., Шалыто А.А. Верификации автоматных программ //Тезисы докладов Международной научной конференции, посвященной памяти профессора А.М. Богомолова «Компьютерные науки и технологии». Саратов: Саратовский государственный университет Корнеев Г.А., Шалыто А.А. Верификация управляющих программ со сложным поведением, построенных на основе автоматного подхода /Материалы международной научно-технической конференции «Многопроцессорные вычислительные и управляющие системы» (МВУС`2007). Таганрог: НИИМВС. Т Гуров В.С., Шалыто А.А., Яминов Б.Р. Технология верификации автоматных моделей программ без их трансляции во входной язык верификатора / Материалы международной научно-технической конференции «Многопроцессорные вычислительные и управляющие системы» (МВУС`2007). Таганрог: НИИМВС. Т.1.

22 Верификация автоматных программ Публикации по теме (2) 1. Васильева К.А., Кузьмин Е.В. Верификация автоматных программ с и спользованием LTL //Моделирование и анализ информационных систем. Ярославль: ЯрГУ. T , Кузьмин Е.В., Соколов В.А. О дисциплине специализации «Верификация проргамм» /Доклады II научно-методической конференции Ярославского гос. университета. Ярославль: ЯрГУ, Кузьмин Е.В., Соколов В.А. О некоторых подходах к верификации автоматных программ /Сборник докладов семинара GoIT. М.: Институт системного программирования. 4. Виноградов Р.А., Кузьмин Е.В., Соколов В.А. Свидетельство об официальной регистрации программы для ЭВМ «Система моделирования и анализа автоматных программ»

23 Верификация автоматных программ Дополнительная информация Раздел «Генетические алгоритмы» сайта кафедры «Технологии программирования» СПбГУ ИТМО по автоматному программированию

24 Верификация автоматных программ Спасибо за внимание