Выполнимость по модулю теорий

редактировать

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

Содержание
  • 1 Базовая терминология
  • 2 Выразительная сила
  • 3 Решающие подходы
  • 4 SMT для неразрешимых теорий
  • 5 Решатели
    • 5.1 Стандартизация и соревнование решателей SMT-COMP
  • 6 Приложения
    • 6.1 Проверка
    • 6.2 Анализ и тестирование на основе символьного исполнения
  • 7 См. Также
  • 8 Примечания
  • 9 Ссылки
Основная терминология

Формально говоря, экземпляр SMT - это формула в логике первого порядка, где некоторые функции и предикатные символы имеют дополнительные интерпретации, а SMT - это проблема определения выполнимости такой формулы. Другими словами, представьте себе пример проблемы логической выполнимости (SAT), в которой некоторые из двоичных переменных заменены предикатами над подходящим набором недвоичных переменных. Предикат - это двоичная функция недвоичных переменных. Примеры предикатов включают линейные неравенства (например, 3 x + 2 y - z ≥ 4 {\ displaystyle 3x + 2y-z \ geq 4}{\ displaystyle 3x + 2y-z \ geq 4} ) или равенства, содержащие неинтерпретированные термины и функциональные символы (например, f (f (u, v), v) = f (u, v) {\ displaystyle f (f (u, v), v) = f ( u, v)}е (е (и, v), v) = е (и, v) , где f {\ displaystyle f}f - некоторая неопределенная функция двух аргументов). Эти предикаты классифицируются согласно каждой присвоенной теории. Например, линейные неравенства над действительными переменными оцениваются с использованием правил теории линейной вещественной арифметики, тогда как предикаты, содержащие неинтерпретированные термины и функциональные символы, оцениваются с использованием правил теории неинтерпретированных функций с равенством (иногда называемое пустой теорией ). Другие теории включают теории массивов и списков структур (полезно для моделирования и проверки компьютерных программ ) и теорию битовых векторов (полезно при моделировании и проверке проектов оборудования ). Также возможны подтеории: например, разностная логика - это подтеория линейной арифметики, в которой каждое неравенство ограничено формой x - y>c {\ displaystyle xy>c}x-y>c для переменных <151style>x { x}x и y {\ displaystyle y}y и константа c {\ displaystyle c}c .

Большинство решателей SMT поддерживают только квантификатор -свободные фрагменты их логики.

Выразительная сила

Экземпляр SMT является обобщением логического экземпляра SAT, в котором различные наборы переменных заменяются на предикаты из множества лежащих в основе теорий. Формулы SMT предоставляют гораздо более богатый язык моделирования, чем это возможно с логическими формулами SAT. Например, формула SMT позволяет нам моделировать путь данных операций микропроцессора на rd, а не битовый уровень.

Для сравнения, программирование набора ответов также основано на предикатах (точнее, на атомарных предложениях, созданных из атомарной формулы ). В отличие от SMT, программы с набором ответов не имеют кванторов и не могут легко выразить ограничения, такие как или —ASP в лучшем случае подходит для логических задач, которые сводятся к свободной теории неинтерпретированных функций. Реализация 32-битных целых чисел в качестве битовых векторов в ASP страдает от большинства проблем, с которыми сталкивались ранние SMT-решатели: «очевидные» идентичности, такие как x + y = y + x, трудно вывести.

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

Подходы решателя

Ранние попытки решения экземпляров SMT включали преобразование их в логические экземпляры SAT (например, 32-битную целочисленную переменную будут закодированы 32 однобитными переменными с соответствующими весами, а операции на уровне слова, такие как «плюс», будут заменены логическими операциями более низкого уровня над битами) и передать эту формулу в логический решатель SAT. Этот подход, который называется подходом нетерпеливым, имеет свои достоинства: путем предварительной обработки формулы SMT в эквивалентную булеву формулу SAT существующие булевы решатели SAT могут использоваться «как есть» и их производительность и улучшения емкости со временем. С другой стороны, потеря высокоуровневой семантики лежащих в основе теорий означает, что логическая программа расчета SAT должна работать намного усерднее, чем необходимо, чтобы обнаружить «очевидные» факты (например, x + y = y + x {\ displaystyle x + y = y + x}x + y = y + x для сложения целых чисел.) Это наблюдение привело к разработке ряда решателей SMT, которые тесно интегрируют логические рассуждения DPLL - поиск стиля с помощью специальных решателей (T-решателей), которые обрабатывают конъюнкции (AND) предикатов из данной теории. Этот подход называется ленивым подходом.

Названная DPLL (T), эта архитектура возлагает ответственность за логические рассуждения на основанный на DPLL решатель SAT, который, в свою очередь, взаимодействует с решателем теории T через четко определенный интерфейс. Решателю теории нужно беспокоиться только о проверке выполнимости конъюнкций предикатов теории, переданных ему из решателя SAT, когда он исследует логическое пространство поиска формулы. Однако для того, чтобы эта интеграция работала хорошо, решатель теории должен иметь возможность участвовать в распространении и анализе конфликтов, т. Е. Он должен уметь выводить новые факты из уже установленных фактов, а также давать краткие объяснения неосуществимости, когда теория противоречит возникают. Другими словами, теоретический решатель должен быть инкрементным и с возможностью возврата.

SMT для неразрешимых теорий

Большинство распространенных подходов SMT поддерживают разрешимые теории. Однако многие реальные системы можно смоделировать только с помощью нелинейной арифметики над действительными числами, включая трансцендентные функции, например самолет и его поведение. Этот факт побуждает распространить проблему SMT на нелинейные теории, например определить, является ли

(грех ⁡ (x) 3 = соз ⁡ (журнал ⁡ (y) ⋅ x) ∨ b ∨ - x 2 ≥ 2,3 y) ∧ (¬ b ∨ y < − 34.4 ∨ exp ⁡ ( x)>yx) {\ displaystyle {\ begin {array} {lr} (\ sin (x) ^ {3} = \ cos (\ log (y) \ cdot x) \ vee b \ vee -x ^ {2} \ geq 2.3y) \ wedge \ left (\ neg b \ vee y <-34.4\vee \exp(x)>{y \ over x} \ right) \ end {array}}}{\begin{array}{lr}(\sin(x)^{3}=\cos(\log(y)\cdot x)\vee b\vee -x^{2}\geq 2.3y)\wedge \left(\neg b\vee y<-34.4\vee \exp(x)>{y \ over x} \ right) \ end {array}}

где

b ∈ B, x, y ∈ R {\ displaystyle b \ in {\ mathbb {B}}, x, y \ in {\ mathbb {R}}}b \ in {\ mathbb {B}}, x, y \ in {\ mathbb {R}}

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

Примерами SMT-решателей, обращающимися к булевым комбинациям теоретических атомов из неразрешимых арифметических теорий над действительными числами, являются ABsolver, в котором используется классическая архитектура DPLL (T) с пакетом нелинейной оптимизации в качестве (обязательно неполного) решателя подчиненной теории, и iSAT [1], основанный на объединении DPLL-решения SAT и распространения ограничений интервала, называемого алгоритмом iSAT.

Solvers

В приведенной ниже таблице приведены некоторые функции многих доступных решателей SMT. Столбец «SMT-LIB» указывает совместимость с языком SMT-LIB; многие системы, отмеченные «да», могут поддерживать только старые версии SMT-LIB или предлагать только частичную поддержку языка. Столбец «CVC» указывает на поддержку языка CVC. Столбец «DIMACS» указывает на поддержку формата DIMACS.

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

ПлатформаФункцииПримечания
ИмяОСЛицензияSMT-LIBCVCDIMACSВстроенные теорииAPISMT-COMP [2]
ABsolverLinux CPL v1.2НетДалинейная арифметика, нелинейная арифметикаC ++ нетНа основе DPLL
Alt-Ergo Linux, Mac OS, Windows CeCILL-C (примерно эквивалент LGPL )частичные версии 1.2 и 2.0НетНетпустая теория, линейная целочисленная и рациональная арифметика, нелинейная арифметика, битовые векторы, квантификаторы OCaml 2008Полиморфный язык ввода первого порядка а-ля ML, на основе SAT-решателя, объединяет подходы, подобные Шостаку и Нельсону-Оппену, для рассуждения теорий по модулю
BarcelogicLinux Собственныйv1.2пустая теория,C ++ 2009на основе DPLL, замыкание конгруэнтности
BeaverLinux, Windows BSD v1.2НетНетбитвекторыOCaml 2009на основе SAT-решателя
БулекторLinux MIT v1.2НетНетбитовые векторы, массивыC 2009SAT-решатель на основе
CVC3Linux BSD v1.2Дапустая теория, линейная арифметика, массивы, кортежи, типы, записи, битовые векторы, квантификаторы C /C ++ 2010вывод проверки на HOL
CVC4Linux, Mac OS, Windows, FreeBSD BSD ДаДарациональная и целочисленная линейная арифметика, массивы, кортежи, записи, индуктивные типы данных, битовые векторы, строки и равенство над неинтерпретированные функциональные символыC ++2010версия 1.5, выпущенная в июле 2017 г.
Decision Procedure Toolkit (DPT)Linux Apache НетOCaml нетна основе DPLL
iSATLinux проприетарныйнетнелинейная арифметиканетDPLL-базовый ed
MathSATLinux, Mac OS, Windows проприетарныйДаДапустая теория, линейная арифметика, нелинейная арифметика, битовые векторы, массивыC /C ++, Python, Java 2010на основе DPLL
MiniSmtLinux LGPL частичная v2.0нелинейная арифметика2010на основе SAT-решателя, на основе Yices
NornSMT-решатель для строковых ограничений
OpenCog Linux AGPL НетНетНетвероятностная логика, арифметика. реляционные модели C ++, Scheme, Python noизоморфизм подграфов
OpenSMTLinux, Mac OS, Windows GPLv3 частичная v2.0Дапустая теория, различия, линейная арифметика, битовые векторыC ++ 2011lazy SMT Solver
raSATLinuxGPLv3v2.0вещественная и целочисленная нелинейная арифметика2014, 2015расширение распространения интервальных ограничений с тестированием и теоремой о промежуточном значении
SatEEn?Собственныйv1.2линейная арифметика, разностная логиканет2009
SMTInterpolLinux, Mac OS, Windows LGPLv3 v2.5неинтерпретируемые функции, линейные действительная арифметика и линейная целочисленная арифметикаJava 2012Ориентация на создание высококачественных компактных интерполянтов.
SMCHRLinux, Mac OS, Windows GPLv3 НетНетНетлинейная арифметика, нелинейная арифметика, кучиC нетМожно реализовать новые теории, используя правила обработки ограничений.
SMT-RATLinux, Mac OS MIT v2.0НетНетлинейная арифметика, нелинейная арифметикаC ++ 2015Toolbox для стратегического и параллельного решения SMT, состоящего из набора совместимых с SMT реализаций.
SONOLARLinux, Windows Собственныйчастичный v2.0битовые векторыC 2010на основе SAT-решателя
SpearLinux, Mac OS, Windows Proprietaryv1.2bitvectors2008
STPLinux, OpenBSD, Windows, Mac OS MIT частично v2.0ДаНетбитовые векторы, массивыC, C ++, Python, OCaml, Java 2011SAT -сольвер
SWORDLinux Собственныеv1.2битвекторы2009
UCLIDLinux BSD НетНетНетпустая теория, линейная арифметика, битовые векторы и ограниченная лямбда (массивы, память, кеш и т. Д.)нетSAT -сольвер, записанный в Москва МЛ. Язык ввода - проверка модели SMV. Хорошо задокументированы!
VeriTLinux, OS X BSD частичная v2.0пустая теория, рациональная и целочисленная линейная арифметика, кванторы и равенство над неинтерпретируемой функцией символыC /C ++ 2010на основе SAT-решателя
YicesLinux, Mac OS, Windows, FreeBSD GPLv3 v2.0НетДарациональная и целочисленная линейная арифметика, битовые векторы, массивы и равенство над неинтерпретируемыми функциональными символамиC 2014Исходный код доступен в Интернете
Z3 Theorem Prover Linux, Mac OS, Windows, FreeBSD MIT v2.0Дапустая теория, линейная арифметика, нелинейная арифметика, битовые векторы, массивы, типы данных, квантификаторы, строкиC /C ++, .NET, OCaml, Python, Java, Haskell 2011Исходный код доступно в Интернете

Стандартизация и конкуренция между решателями SMT-COMP

Есть несколько mpts для описания стандартизованного интерфейса для решателей SMT (и автоматических средств доказательства теорем, термин, часто используемый как синоним). Самым известным является стандарт SMT-LIB, который предоставляет язык, основанный на S-выражениях. Другие широко поддерживаемые стандартизованные форматы - это формат DIMACS, поддерживаемый многими логическими программами SAT-решения, и формат CVC, используемый автоматическим средством доказательства теорем CVC.

Формат SMT-LIB также поставляется с рядом стандартизированных тестов и позволяет проводить ежегодное соревнование между решателями SMT под названием SMT-COMP. Первоначально конкурс проводился во время конференции Computer Aided Verification (CAV), но с 2020 года конкурс проводится в рамках семинара SMT, который связан с Международной совместной конференцией по Automated Reasoning (IJCAR).

Приложения

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

Верификация

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

Существует множество верификаторов, построенных на основе решателя SMT Z3. Boogie - это язык промежуточной проверки, использующий Z3 для автоматической проверки простых императивных программ. Верификатор VCC для параллельного C использует Boogie, а также Dafny для императивных объектно-ориентированных программ, Chalice для параллельных программ и Spec # для C #. F * - язык с зависимой типизацией, использующий Z3 для поиска доказательств; компилятор передает эти доказательства для создания байт-кода, несущего доказательство. Инфраструктура проверки Viper кодирует условия проверки в Z3. Библиотека sbv обеспечивает проверку программ Haskell на основе SMT и позволяет пользователю выбирать среди ряда решателей, таких как Z3, ABC, Boolector, CVC4, MathSAT и Yices.

Существует также множество верификаторов, построенных на основе решателя Alt-Ergo SMT. Вот список зрелых приложений:

  • Why3, платформа для дедуктивной проверки программ, использует Alt-Ergo в качестве основного средства проверки;
  • CAVEAT, средство проверки C, разработанное CEA и используемое Airbus; Alt-Ergo был включен в квалификацию DO-178C одного из своих последних самолетов;
  • Frama-C, фреймворк для анализа C-кода, использует Alt-Ergo в плагинах Jessie и WP (посвященных " дедуктивная проверка программы ");
  • SPARK, использует CVC4 и Alt-Ergo (за GNATprove) для автоматизации проверки некоторых утверждений в SPARK 2014;
  • Atelier-B может вместо этого использовать Alt-Ergo своего основного доказателя (увеличение успеха с 84% до 98% в тестах ANR Bware project );
  • Rodin, фреймворк B-метода, разработанный Systerel, может использовать Alt-Ergo в качестве серверной части;
  • Cubicle, средство проверки моделей с открытым исходным кодом для проверки свойств безопасности систем перехода на основе массивов.
  • EasyCrypt, набор инструментов для анализа реляционных свойств вероятностных вычислений с противостоящим кодом.

Многие Решатели SMT реализуют общий формат интерфейса под названием SMTLIB2 (такие файлы обычно имеют расширение «.smt2»). Инструмент LiquidHaskell реализует ссылку Верификатор на основе типа элемента для Haskell, который может использовать любой совместимый с SMTLIB2 решатель, например CVC4, MathSat или Z3.

Анализ и тестирование на основе символьного исполнения

Важным применением решателей SMT является символьное выполнение для анализа и тестирования программ (например, concolic testing ), направленный, в частности, на поиск уязвимостей безопасности. К важным активно поддерживаемым инструментам в этой категории относятся SAGE из Microsoft Research, KLEE, S2E и Triton.. Решатели SMT, которые особенно полезны для приложений с символьным исполнением, включают Z3, STP, Z3str2 и Boolector.

См. Также
Примечания
  1. ^Barbosa, Haniel, et al. "Расширение решателей SMT до логики более высокого порядка." Международная конференция по автоматическому отчислению. Springer, Cham, 2019.
  2. ^Nieuwenhuis, R.; Oliveras, A.; Тинелли, С. (2006), "Решение теорий SAT и SAT по модулю: от абстрактной процедуры Дэвиса-Патнэма-Логеманна-Ловленда до DPLL (T)", Журнал ACM (PDF), 53, pp. 937–977
  3. ^Bauer, A.; Пистер, М.; Таучниг, М. (2007), «Инструментальная поддержка для анализа гибридных систем и моделей», Труды конференции 2007 года по проектированию, автоматизации и тестированию в Европе (DATE'07), IEEE Computer Society, стр. 1, CiteSeerX 10.1.1.323.6807, doi : 10.1109 / DATE.2007.364411, ISBN 978-3-9810801-2-4, S2CID 9159847
  4. ^Fränzle, M.; Herde, C.; Ratschan, S.; Schubert, T.; Тейдж, Т. (2007), «Эффективное решение больших нелинейных систем арифметических ограничений со сложной логической структурой», Специальный выпуск JSAT по интеграции SAT / CP (PDF), 1, стр. 209–236
  5. ^Барретт, Кларк; де Моура, Леонардо; Пень, Аарон (2005). Этессами, Коуша; Раджамани, Шрирам К. (ред.). "SMT-COMP: Конкурс теорий удовлетворенности по модулю". Компьютерная проверка. Конспект лекций по информатике. Берлин, Гейдельберг: Springer: 20–23. doi : 10.1007 / 11513988_4. ISBN 978-3-540-31686-2.
  6. ^Барретт, Кларк; де Моура, Леонардо; Ранис, Сильвио; Пень, Аарон; Тинелли, Чезаре (2011). Барнер, Шэрон; Харрис, Ян; Кронинг, Даниэль; Раз, Орна (ред.). «Инициатива SMT-LIB и рост SMT». Аппаратное и программное обеспечение: проверка и тестирование. Конспект лекций по информатике. Берлин, Гейдельберг: Springer: 3–3. DOI : 10.1007 / 978-3-642-19583-9_2. ISBN 978-3-642-19583-9.
  7. ^«SMT-COMP 2020». SMT-COMP. Проверено 19 октября 2020 г.
  8. ^Бомонт, Пол; Эванс, Нил; Хут, Майкл; Завод, Том (2015). Пернул, Гюнтер; Y. Райан, Питер; Weippl, Эдгар (ред.). «Анализ уверенности для контроля над ядерным оружием: SMT-абстракции байесовских сетей верований». Компьютерная безопасность - ESORICS 2015. Конспект лекций по информатике. Чам: Издательство Springer International: 521–540. DOI : 10.1007 / 978-3-319-24174-6_27. ISBN 978-3-319-24174-6.
Литература

Эта статья адаптирована из столбца электронного информационного бюллетеня ACM SIGDA , подготовленного проф. Карем Сакаллах. Исходный текст доступен здесь

Последняя правка сделана 2021-06-07 03:29:04
Содержание доступно по лицензии CC BY-SA 3.0 (если не указано иное).
Обратная связь: support@alphapedia.ru
Соглашение
О проекте