Свойство линейного времени - Linear time property

В проверка модели, филиал Информатика, свойства линейного времени используются для описания требований модели компьютерной системы. Примеры свойств включают "торговый автомат не выдаст напиток, пока не будут введены деньги" ( свойство безопасности ) или «компьютерная программа в конечном итоге завершается» (a свойство живости ). Свойства справедливости могут использоваться для исключения нереалистичных путей модели. Например, в модели двух светофоров свойство живучести «оба светофора горят зеленым бесконечно часто» может быть истинным только при условии безусловного ограничения справедливости «каждый светофор меняет цвет бесконечно часто» (чтобы исключить случай, когда один светофор "бесконечно быстрее" другого).[1]

Формально свойство линейного времени - это ω-язык над набор мощности «атомарных предложений». То есть свойство содержит последовательности наборов предложений, каждая последовательность известна как «слово». Каждое свойство можно переписать как "п и Q оба происходят "для некоторого свойства безопасности п и живучесть собственности Q. Инвариант системы - это то, что истинно или ложно для определенного состояния. Инвариантные свойства описывают инвариант, которому должно удовлетворять каждое достижимое состояние модели, в то время как свойства персистентности имеют форму «в конечном итоге навсегда сохраняется некоторый инвариант».

Временная логика Такие как линейная темпоральная логика описывать типы свойств линейного времени с помощью формул.

Определение

Позволять AP быть набором атомарных предложений. Слово за набор мощности из AP) представляет собой бесконечную последовательность наборов предложений, таких как (для атомарных предложений ). Свойство линейного времени (LT) над AP это подмножество т.е. набор слов.[2] Пример свойства LT над множеством это "набор слов, которые содержат а бесконечно часто ». Слово ш находится в этом наборе, потому что а содержится в , что происходит бесконечно часто. Слово не в этом наборе , так как а встречается только один раз (в первом наборе).

LT свойство - это ω-язык по алфавиту (наоборот).

Обозначим через pref(ш) конечные префиксы ш (т.е. в приведенном выше случае). Закрытие LT собственности п является:

Приложения

Структура Крипке
А Структура Крипке над . Он не удовлетворяет свойству LT "бесконечно часто q", из-за пути . Он действительно удовлетворяет свойству "бесконечно часто п", потому что все возможные пути входят или же бесконечно часто.

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

Если каждый след структуры Крипке TS это след TS' то каждое свойство LT, которое TS' удовлетворяет удовлетворяется TS. Это полезно при проверке модели для обеспечения абстракции: если упрощенная модель системы удовлетворяет свойству LT, то фактическая модель системы также будет удовлетворять ему.[4]

Классификация свойств линейного времени

Свойства безопасности

А свойство безопасности неофициально имеет форму «плохого не бывает».[5] Например, если система моделирует банкомат (Банкомат), то таким свойством будет «нельзя выдавать деньги, если не введен ПИН-код».[6] Формально свойство безопасности - это свойство LT, такое, что любое слово, которое нарушает свойство, имеет «плохой префикс», для которого ни одно слово с этим префиксом не удовлетворяет этому свойству. То есть,[7]

В примере с банкоматом минимальный плохой префикс - это конечный набор выполняемых шагов, в которых деньги выдаются на последнем шаге, а PIN-код не вводится ни на одном шаге. Чтобы проверить свойство безопасности, достаточно рассмотреть только конечные следы структуры Крипке и проверить, является ли любой такой след плохим префиксом.[8]

LT свойство п является свойством безопасности тогда и только тогда, когда .[9]

Инвариантные свойства

Инвариантное свойство - это тип свойства безопасности, в котором условие относится только к текущему состоянию.[10] Например, пример банкомата не является инвариантом, потому что мы не можем сказать, нарушено ли свойство, увидев, что текущее состояние - «выдача денег», только увидев, что текущее состояние - «выдача денег», а предыдущее состояние не было «прочитано». ШТЫРЬ". Примером инварианта является указанное выше условие светофора «оба светофора не могут быть зелеными одновременно». Другой - "переменная Икс никогда не бывает отрицательным »в модели компьютерной программы.

Формально инвариант имеет вид:

для некоторых логика высказываний формула .[10]

Структура Крипке удовлетворяет инварианту тогда и только тогда, когда каждое достижимое состояние удовлетворяет инварианту, что можно проверить с помощью поиск в ширину или же поиск в глубину.[11] Свойства безопасности можно проверить индуктивно с помощью инвариантов.[12]

Свойства живучести

А свойство живости неофициально имеет форму «в конце концов случается что-то хорошее».[5] Формально, п свойство живучести, если т.е. любую конечную строку можно продолжить до действительной трассы.[13][7] Примером свойства живости является предыдущее свойство LT "набор слов, которые содержат а бесконечно часто ". Никакой конечный префикс слова не может доказать, что слово не удовлетворяет этому свойству, так как слово может продолжать иметь бесконечно много ас.

Что касается компьютерных программ, полезные свойства живучести включают в себя «программа в конечном итоге завершается», а в параллельные вычисления, "каждый процесс в конечном итоге должны быть обслужены ".[14]

Свойства стойкости

Свойство настойчивости - это свойство живучести формы «в конечном итоге навсегда ". То есть свойство формы:[15]

Связь между безопасностью и живучестью

Нет собственности LT, кроме (набор всех слов закончился ) является одновременно свойством безопасности и живучести.[16] Хотя не каждое свойство является безопасным или жизнеспособным (рассмотрите "а происходит ровно один раз »), каждое свойство является пересечением свойств безопасности и живучести.[5]

В топология, набор всех слов может быть оснащен метрика:

Тогда свойство безопасности - это закрытый набор а свойство живости - это плотный набор.[17]

Свойства справедливости

Свойства справедливости предварительные условия накладывается на систему, чтобы исключить нереалистичные следы.[18][19] Безусловная справедливость имеет вид «каждый процесс бесконечно часто получает свою очередь». Строгая справедливость имеет форму «каждый процесс бесконечно часто получает свою очередь, если он запускается бесконечно часто». Слабая справедливость имеет форму «каждый процесс бесконечно часто получает свою очередь, если он непрерывно запускается с определенной точки».[20]

В некоторых системах ограничение справедливости определяется набором состояний, а "справедливый путь" - это путь, который проходит через некоторое состояние в ограничении справедливости бесконечно часто. Если имеется несколько ограничений справедливости, то правильный путь должен проходить бесконечно часто через одно состояние на каждое ограничение.[21] Программа "удовлетворительно удовлетворяет" LT свойство п относительно набора условий справедливости, если для каждого пути либо путь не соответствует условию справедливости, либо удовлетворяет п. То есть свойство п удовлетворяется для всех честных путей.[22]

Свойство справедливости реализуемо для структуры Крипке, если каждое достижимое состояние имеет справедливый путь, начиная с этого состояния. Пока набор условий справедливости реализуем, они не имеют отношения к свойствам безопасности.[23]

Временная логика

Временная логика Такие как логика дерева вычислений (CTL) можно использовать для указания некоторых свойств LT.[24] Все линейная темпоральная логика (LTL) формулы являются LT свойствами. Посредством подсчета аргументов мы видим, что любая логика, в которой каждая формула представляет собой конечную строку, не может представлять все свойства LT, так как должно быть счетное количество формул, но существует несчетное количество свойств LT.

Примечания

Рекомендации

  • Alpern, B .; Шнайдер, Ф. Б. (1987). «Признавая безопасность и живучесть». Распределенных вычислений. 2 (3): 117. CiteSeerX  10.1.1.20.5470. Дои:10.1007 / BF01782772.
  • Байер, Кристель; Катоэн, Йост-Питер (2008). Принципы проверки модели. MIT Press. ISBN  9780262026499.
  • Кларк, Эдмунд М.; Грумберг, Орна; Кренинг, Даниэль (2018). Проверка модели. MIT Press. ISBN  9780262038836.
  • Д'Силва, Виджай; Кронинг, Даниэль; Вайссенбахер, Георг (2008). «Обзор автоматизированных методов формальной проверки программного обеспечения». IEEE Transactions по автоматизированному проектированию интегральных схем и систем. 27 (7): 1165–1178.
  • Финкбайнер, Бернд; Торфа, Хазем (2017). «Плотность линейно-временных свойств». Конспект лекций по информатике. Автоматизированная технология проверки и анализа. 10482. Springer.
  • Керн, Кристоф; Гринстрит, Марк Р. (1999). «Формальная проверка в дизайне оборудования: обзор». ACM Сделки по автоматизации проектирования электронных систем. Ассоциация вычислительной техники. 4 (2). Дои:10.1145/307988.307989. ISSN  1084-4309.

дальнейшее чтение

  • Эмерсон, Э. Аллен (1990). «Временная и модальная логика». Справочник по теоретической информатике. B.
  • Пнуэли, Амир (1986). «Применение темпоральной логики к спецификации и проверке реактивных систем: обзор текущих тенденций». Текущие тенденции в области параллелизма: 510–584.