Ключ - KeY
Эта статья поднимает множество проблем. Пожалуйста помоги Улучши это или обсудите эти вопросы на страница обсуждения. (Узнайте, как и когда удалить эти сообщения-шаблоны) (Узнайте, как и когда удалить этот шаблон сообщения)
|
Скриншот KeY 1.4 | |
Разработчики) | Карлсруэ технологический институт, Technische Universität Darmstadt, Технологический университет Чалмерса |
---|---|
Стабильный выпуск | 2.6.3 / 11 октября 2017 г. |
Предварительный выпуск | 2.7.1492 / 19 октября 2018 г. |
Написано в | Ява |
Операционная система | Linux, Mac, Windows, Solaris |
Доступно в | английский |
Тип | Формальная проверка |
Лицензия | GPL |
Интернет сайт | ключевой проект |
В Ключ инструмент используется в формальная проверка из Ява программы. Он принимает спецификации, указанные в Язык моделирования Java в исходные файлы Java. Они превращаются в теоремы динамическая логика и затем сравнивается с семантикой программы, которая также определяется в терминах динамической логики. KeY обладает значительной мощью, поскольку поддерживает как интерактивное (то есть вручную), так и полностью автоматизированное подтверждение правильности. Неудачные попытки доказательства могут быть использованы для более эффективного отладка или же верификационное тестирование. Для KeY было несколько расширений, позволяющих применять его для проверки C программы или гибридные системы. KeY разработан совместно Карлсруэ технологический институт, Германия; Technische Universität Darmstadt, Германия; и Технологический университет Чалмерса в Гетеборге, Швеция, и имеет лицензию на GPL.
Обзор
Обычно пользовательский ввод в KeY представляет собой исходный файл Java с аннотациями в JML. Оба переведены во внутреннее представление KeY, динамическая логика. Из данных спецификаций вытекает несколько обязательств по доказательству, которые должны быть выполнены, то есть должны быть найдены доказательства. С этой целью программа символически исполненный с результирующими изменениями программных переменных, хранящихся в так называемых обновления. После того, как программа была полностью обработана, остается логика первого порядка доказательство обязательства. В основе системы KeY лежит первоклассный средство доказательства теорем на основе последовательное исчисление, которым завершается доказательство. Правила вмешательства фиксируются в так называемых таклеты которые состоят из собственного простого языка для описания изменений в секвенции.
Java Card DL
Теоретическая основа KeY - это формальная логика называется Java Card DL. DL расшифровывается как Dynamic Logic. Это версия первоклассного динамическая логика адаптированы к программам Java Card. Таким образом, он, например, позволяет использовать такие утверждения (формулы), как , что интуитивно говорит о том, что постусловие должен удерживаться во всех состояниях программы, достижимых при выполнении программы Java Card в любом состоянии, которое удовлетворяет предварительному условию . Это эквивалентно в Исчисление Хора если и являются чисто первоклассными. Однако динамическая логика расширяет логику Хоара тем, что формулы могут содержать вложенные программные модальности, такие как , или что количественная оценка по формулам, которые содержат модальности, возможна. Также есть двойной модальность который включает прекращение. Эту динамическую логику можно рассматривать как особую мультимодальную логику (с бесконечным количеством модальностей), где для каждого блока Java есть условия и .
Компонент удержания
В основе системы KeY лежит средство доказательства теорем первого порядка, основанное на последовательное исчисление. Секвенция имеет вид куда (предположения) и (предложения) - это наборы формул с интуитивным смыслом, что Справедливо. Посредством вычет, показывается, что начальная секвенция, представляющая обязательство по доказательству, может быть построена только на основе фундаментальных аксиом первого порядка (таких как равенство ).
Символьное выполнение кода Java
При этом условия программы устраняются символическая казнь. Например, формула логически эквивалентен . Как показывает этот пример, символьное выполнение в динамической логике очень похоже на вычисление самые слабые предпосылки. Обе и по сути обозначают одно и то же - за двумя исключениями: во-первых, является функцией некоторого метаисчисления, а действительно является формулой данного исчисления. Во-вторых, символическое выполнение проходит через программу. вперед так же, как и настоящая казнь. Чтобы сохранить промежуточные результаты заданий, KeY вводит концепцию под названием обновления, которые похожи на замены, но применяются только после того, как модальность программы полностью исключена. Синтаксически обновления состоят из параллельных (без побочных эффектов) назначений, записанных в фигурных скобках перед модальностью. Пример символьного исполнения с обновлениями: преобразован в на первом этапе и на втором этапе. Тогда модальность пуста, и "обратное применение" обновления постусловия дает предварительное условие, где может принимать любое значение.
Пример
Предположим, кто-то хочет доказать, что следующий метод вычисляет произведение некоторых неотрицательных целых чисел и .
int фу (int Икс, int у) { int z = 0; пока (у > 0) если (у % 2 == 0) { Икс = Икс*2; у = у/2; } еще { у = у/2; z = z+Икс; Икс = Икс*2; } возвращаться z;}
Таким образом, доказательство начинается с посылки и ожидаемый вывод . Обратите внимание, что таблицы исчислений секвенции обычно пишутся «в перевернутом виде», то есть начальная секвенция появляется внизу, а шаги дедукции идут вверх. Доказательство можно увидеть на рисунке справа.
Дополнительные возможности
Отладчик символьного выполнения
В Отладчик символьного выполнения визуализирует поток управления программы как символическая казнь дерево, которое содержит все возможные пути выполнения программы до определенного момента. Он предоставляется как плагин к Затмение платформа разработки.
Генератор тестовых случаев
KeY можно использовать как модельное тестирование инструмент, который может генерировать модульные тесты для программ на Java. Модель, из которой получены тестовые данные и тестовый пример, состоит из формальной спецификации (представленной в JML ) и символическое дерево выполнения тестируемой реализации, которое вычисляется системой KeY.
Распространение и варианты системы ключей
KeY - бесплатное программное обеспечение, написанное на Java и распространяемое по лицензии GPL. Его можно скачать с сайта проекта в исходниках; в настоящее время нет доступных предварительно скомпилированных двоичных файлов. В качестве другой возможности, KeY может быть запущен напрямую через Запуск Java в сети без необходимости компиляции и установки.
Кей-Хоар
Кей-Хоар построен на основе KeY и имеет Исчисление Хора с обновлениями состояния. Обновления состояний - это средство описания переходов состояний в Структура Крипке. Это исчисление можно рассматривать как подмножество того, которое используется в основной ветви KeY. Из-за простоты исчисления Хоара эта реализация в основном предназначена для демонстрации формальных методов на курсах бакалавриата.
KeYmaera / KeYmaeraX
Кеймаера [1] (ранее назывался HyKeY) - это инструмент дедуктивной проверки для гибридных систем, основанный на исчислении дифференциальной динамической логики dL [2] Он дополняет инструмент KeY системами компьютерной алгебры, такими как Mathematica и соответствующие алгоритмы и стратегии доказательства, так что его можно использовать для практической проверки гибридные системы.
KeYmaera была разработана в Ольденбургский университет и Университет Карнеги Меллон. Название инструмента было выбрано как омофон к Химера, гибридное животное из древнегреческой мифологии.
KeYmaeraX [3] разработан в Университет Карнеги Меллон является преемником KeYmaera. Он был полностью переписан.
Ключ для C
Ключ для C представляет собой адаптацию системы KeY к MISRA C, подмножество Язык программирования C. Этот вариант больше не поддерживается.
ASMKeY
Также существует адаптация для использования KeY для символического выполнения Абстрактные государственные машины, который был разработан в ETH Zürich. Этот вариант больше не поддерживается; дополнительную информацию можно найти по ссылке ниже.
Источники
- Верификация объектно-ориентированного программного обеспечения: ключевой подход. Бернхард Бекерт, Райнер Хенле, Питер Х. Шмитт (ред.). Springer, 2007. ISBN 978-3-540-68977-5.
- Дедуктивная проверка программного обеспечения - КЛЮЧЕВАЯ книга: от теории к практике. Вольфганг Арендт, Бернхард Бекерт, Ричард Бубель, Райнер Хенле, Петер Х. Шмитт, Маттиас Ульбрих (ред.). Springer, 2016. ISBN 978-3-319-49812-6
- Сравнение инструментов для обучения формальной верификации программного обеспечения. Инго Файнерер и Гернот Зальцер. Springer, 2008
- Программирование с помощью доказательств: языковые подходы к полностью корректному программному обеспечению. Аарон Стамп. Проверенное программное обеспечение: теории, инструменты и эксперименты, 2005 г.
- Высокая надежность (для безопасности) и бесплатное программное обеспечение с открытым исходным кодом (FLOSS). Дэвид Уиллер, 2009 г.