Применение методов решения задачи удовлетворения ограничениям для построения управляющих конечных автоматов по сценариям работ

Содержание

Слайд 2

Управляющие автоматы и сценарии работы программы

Управляющий автомат:
входные события
входные переменные
выходные воздействия
Сценарий работы –

Управляющие автоматы и сценарии работы программы Управляющий автомат: входные события входные переменные
последовательность троек
e – входное событие
f – охранное условие – Булева формула, зависящая от входных переменных
A – последовательность выходных воздействий
Приведенный управляющий автомат:
Удовлетворяет
Не удовлетворяет

Слайд 3

Пример управляющего автомата

Часы с будильником
Четыре события
H – кнопка “H” нажата
M – кнопка

Пример управляющего автомата Часы с будильником Четыре события H – кнопка “H”
“M” нажата
A – кнопка “A” нажата
T – происходит каждый момент времени
Две входные переменные
Семь выходных воздействий

Слайд 4

Требования, предъявляемые к автоматной программе

Непротиворечивость – не должно быть двух переходов, исходящих

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

Слайд 5

Постановка задачи

Рассматриваются автоматные программы с единственным объектом управления
Входные данные:
Набор сценариев работы программы

Постановка задачи Рассматриваются автоматные программы с единственным объектом управления Входные данные: Набор
(Sc)
Число состояний управляющего автомата (C)
Необходимо найти управляющий автомат, состоящий из C состояний и удовлетворяющий всем сценариям работы

Слайд 6

Предлагаемый метод

Ulyantsev V., Tsarev F. Extended Finite-State Machine Induction using SAT-Solver /

Предлагаемый метод Ulyantsev V., Tsarev F. Extended Finite-State Machine Induction using SAT-Solver
Proceedings of the Tenth International Conference on Machine Learning and Applications, ICMLA 2011, Honolulu, HI, USA, 18-21 December 2011. IEEE Computer Society, 2011. Vol. 2. P. 346–349
Не гарантируется полнота
Выразить требование полноты в виде ограничений на целочисленные переменные (constraint satisfaction problem, CSP)

Слайд 7

Основная идея

Каждому сценарию работы соответствует «линейный» автомат
«Раскраска» сценариев
Каждому «состоянию» каждого сценария работы

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

Слайд 8

Этапы работы алгоритма

Построение дерева сценариев
Построение графа совместимости
Построение булевой КНФ-формулы
Набор ограничений на целочисленные

Этапы работы алгоритма Построение дерева сценариев Построение графа совместимости Построение булевой КНФ-формулы
переменные
Запуск сторонней программы, находящей решение
Построение искомого управляющего автомата

Слайд 9

Предварительные вычисления

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

Предварительные вычисления Для каждой пары охранных условий, встречающихся в заданных сценариях: Равны
булевы формулы
Имеют ли общую выполняющую подстановку
Асимптотическая оценка:
O(n222m) где n – общий размер сценариев, m – наибольшее число переменных, встречающихся в охранном условии (на практике m не превышает пяти)

Слайд 10

1. Построение дерева сценариев

Аналогично построению бора
Алгоритм прерывается, если найдено противоречие

1. Построение дерева сценариев Аналогично построению бора Алгоритм прерывается, если найдено противоречие

Слайд 11

2. Построение графа совместимости

Вершины совпадают с вершинами дерева
Вершины соединены ребром, если существует

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

Слайд 12

3. Используемые переменные

Целочисленные переменные:
xv – цвет, в который покрашена вершина v (1≤xv≤C)
yi,e,f

3. Используемые переменные Целочисленные переменные: xv – цвет, в который покрашена вершина
– номер состояния, в которое ведет переход из состояния i, помеченный событием e и охранным условием f (1≤yi,e,f ≤C)

Слайд 13

3. Построение ограничений для требования непротиворечивости

Типы ограничений:
xv ≠ xu – цвета несовместимых

3. Построение ограничений для требования непротиворечивости Типы ограничений: xv ≠ xu –
вершин должны быть различны
(xv = i) ⇒ (yi,e,f = xu) – цвета вершин дерева не должны противоречить переходам автомата

Слайд 14

3. Построение ограничений для требования полноты

При условии непротиворечивости можно выразить условие полноты
Сумма

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

Слайд 15

4. Использование программного средства, решающего задачу удовлетворения ограничениям

Использовался пакет choco для нахождения

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

Слайд 16

5. Построение управляющего автомата по выполняющей подстановке (1)

Раскраска дерева сценариев
Цвет вершины соответствует

5. Построение управляющего автомата по выполняющей подстановке (1) Раскраска дерева сценариев Цвет вершины соответствует значениям xv
значениям xv

Слайд 17

5. Построение управляющего автомата по выполняющей подстановке (2)

Вершины одинаковых цветов сливаются

5. Построение управляющего автомата по выполняющей подстановке (2) Вершины одинаковых цветов сливаются

Слайд 18

Экспериментальные исследования

Управляющий автомат для часов с будильником:
38 сценариев работы суммарной длины 242

Экспериментальные исследования Управляющий автомат для часов с будильником: 38 сценариев работы суммарной
+ один сценарий
Наборы случайных сценариев работы:
Генерируется случайный полный по переменным автомат
Сценарии – случайные пути в автомате
Найдены наборы сценариев, на которых проявляется преимущество разработанного метода

Слайд 19

Результаты

Разработан и реализован метод построения управляющих автоматов, основанный на сведении задачи к

Результаты Разработан и реализован метод построения управляющих автоматов, основанный на сведении задачи
задаче удовлетворения ограничениям
Экспериментальные исследования продемонстрировали существование задач, для которых метод находит качественно лучшее решение
Имя файла: Применение-методов-решения-задачи-удовлетворения-ограничениям-для-построения-управляющих-конечных-автоматов-по-сценариям-работ.pptx
Количество просмотров: 147
Количество скачиваний: 0