Открыть главное меню

Логика разделения, сепарационная логика (англ. separation logic) в информатике — формальная система, предназначенная для верификации программ, содержащих изменяемые структуры данных и указатели, расширение логики Хоара. Разработана Джоном Рейнольдсом (англ. John C. Reynolds), Питером О’Хирном (англ. Peter O'Hearn), Самином Иштиаком (англ. Samin Ishtiaq) и Хонсёком Яном (англ. Hongseok Yang)[1][2][3][4] на основе работ Рода Бёрстола (англ. Rod Burstall)[5]. Язык утверждений логики разделения является специальным случаем логики пучковых импликаций (англ. logic of bunched implications)[6].

Технологии, основанные на логике разделения, позволяют разрабатывать системы для верификации крупных программных проектов[7].

Содержание

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

Логика Хоара имеет ряд ограничений, работая только с изменяемыми переменными и не поддерживая процедуры или код первого класса. Тем не менее, самое большое ограничение — это отсутствие поддержки указателей, что наиболее актуально для спецификации императивных программ. В случае использования указателей и кучи от изменяемых переменных можно отказаться, присваивая локальным переменным значение-указатель лишь один раз[8].

В 2000—2002 годах Джон Рейнольдс и Питер О’Хирн придумали расширение логики Хоара — логику разделения. Первоначальной идеей было упрощение рассуждений об императивных программах низкого уровня с общей изменяемой структурой данных[9]. Сам термин связан с основной идеей данной логики — описанием разделения хранилища (англ. storage) на непересекающиеся компоненты. Термин используется как в отношении исчисления предикатов, расширенного оператором разделения, так и для результата расширения хоаровской логики[1].

ОписаниеПравить

Ключевой особенностью логики разделения является возможность локальных рассуждений (local reasoning) благодаря наличию в утверждениях пространственных связок (англ. spatial connectives) между частями кучи[10].

 
Соответствует утверждению  [11]

Логика позволяет работать с утверждениями вида  , где:

Для преодоления громоздких описаний запретов на использование одного и того же адреса разными объектами, введена новая логическая операция — разделяющая конъюнкция (disjoint conjunction), обозначаемая   (или  [13]) и утверждающая, что каждое из условий   и   выполняются в своей части кучи (адресуемого хранилища)[9][14]. То есть,   истинна для кучи  , если существуют две части этой кучи   и  , для которых выполнено[15]:

  • Области   и   не пересекаются;
  •   является объединением   и  ;
  •   верно для всех адресов из  ;
  •   верно для всех адресов из  .

Выше под   и   понимаются частичные функции, дающие значения, соответствующие адресу в куче.

Для утверждения, что куча пуста, введён предикат   (при этом очевидно выполняется  ), а для обозначения указателя —  . Например, в следующей, являющейся одной из аксиом, тройке Хоара

 

предусловием является неиспользованность ячейки памяти, которая в результате операции присваивания указывает на F, что и утверждается в постусловии[12].

Ключевым для локальных рассуждений является введённое О’Хирном рамочное правило (frame rule)[1]:

 ,

в котором никакая свободная переменная (англ. free variable) в   не изменяется (англ. modified) под влиянием команды  . Используя это правило, можно добавлять произвольные предикаты о переменных и частях кучи, которые не изменяются командой  . При этом О’Хирн назвал объём занимаемой кучи, затрагиваемой командой, термином англ. footprint («отпечаток»). Назначением рамочного правила является расширение рассуждения с более локального описания команды на более глобальное описание объемлющей команды — команды с бо́льшим отпечатком[1].

Установив, что логика разделения является примером логики пучковых импликаций, Ян и Иштиак ввёл разделяющую импликацию (англ. separating implication[1], англ. magic wand). Обозначение   говорит о том, если куча была расширена непересекающейся с ней кучей, для которой верно  , то для получившейся в результате кучи будет верно  [7].

Семантика логических связок (разделяющей конъюнкции и разделяющей импликации) подразумевает моноидную структуру кучи[7].

Локальные рассуждения можно понимать и в терминах передачи принадлежности (англ. ownership transfer). Легче всего рассмотреть передачу принадлежности на примере правил монитора Хоара (можно увидеть, что логика разделения подходит и для распределённых систем). Для входа процесса в критическую секцию применяется разделяющая конъюнкция с  , где   — инвариант ресурса r. По выходу из критической секции логический вывод следует в обратном направлении[16]:

 ,

По аналогии можно рассматривать и процесс обработки процессом сообщения, отправленного другим процессом с делегированными данному процессу ресурсами, определяемыми отпечатками[16].

Применение и реализацииПравить

Логика разделения нашла применение в автоматических и интерактивных верификаторах программного обеспечения, написанного в императивном и объектно-ориентированном стиле. Для этого были разработаны соответствующие дополнения к существующим инструментам верификации, например, таких как:

  • Ynot[17] — библиотека для верификации императивных программ для Coq.
  • Predator[18] — это анализатор программ на основе логики разделения для анализа программ, содержащих динамические списки[19].

Другие системы, использующие логику разделения: Smallfoot, Space Invader, THOR, SLAyer, HIP, jStar, Xisa, VeriFast, Infer, SeLoger, SLP. Тем не менее, по состоянию на 2014 год отсутствуют практичные доказатели теорем, реализующие полную логику разделения, то есть включающие разделяющую импликацию[7].

По характеру использования системы можно разделить следующим образом[20]:

  • Пользователь вручную пишет как спецификацию, так и доказательства, используя тактики: интерактивные системы доказательства теорем Coq, HOL4, Isabelle/HOL.
  • Пользователь пишет спецификацию и инварианты циклов: самостоятельные инструменты для верификации Smallfoot, HIP, Verifast, Jstar.
  • Пользователь пишет только спецификацию (или даже ничего не пишет): инструменты для анализа формы (англ. shape analysis) Space Invader, THOR, Xisa, SLAyer.

ПримечанияПравить

  1. 1 2 3 4 5 6 Reynolds, 2002.
  2. Intuitionistic Reasoning about Shared Mutable Data Structure. John Reynolds. Millennial Perspectives in Computer Science, Proceedings of the 1999 Oxford-Microsoft Symposium in Honour of Sir Tony Hoare
  3. BI as an Assertion Language for Mutable Data Structures. Samin Ishtiaq, Peter O’Hearn. POPL 2001.
  4. Local Reasoning about Programs that Alter Data Structures. Архивная копия от 27 сентября 2013 на Wayback Machine Peter O’Hearn, John Reynolds, Hongseok Yang. CSL 2001
  5. Some techniques for proving programs which alter data structures. R.M. Burstall. Machine Intelligence 7, 1972.
  6. The Logic of Bunched Implications P.W. O’Hearn and D. J. Pym. Bulletin of Symbolic Logic , 5(2), June 1999, pp215-244
  7. 1 2 3 4 Lee, Park, 2014.
  8. Programs and Proofs, 2014.
  9. 1 2 Reynolds, 2008.
  10. Parkinson, Bierman, 2005.
  11. Chris Poskitt Software Verification (Fall 2013) Lecture 5: Separation Logic Parts I - II (недоступная ссылка)
  12. 1 2 A Primer on Separation Logic, 2012.
  13. Tjark Weber (2004). "Towards Mechanized Program Verification with Separation Logic" in Lecture Notes in Computer Science. Computer Science Logic~-- 18th International Workshop, CSL 2004, 13th Annual Conference of the EACSL, Karpacz, Poland, September 2004, Proceedings: 250--264, Springer. weber04towards. Проверено 2013-12-06. 
  14. Matthew J. Parkinson Local reasoning for Java, 2005, UCAM-CL-TR-654, ISSN 1476—2986
  15. Lecture 24: Pointer and shape analysis, LARA, EPFL
  16. 1 2 Étienne Lozes Information as Resource in Separation Logic (недоступная ссылка), ANR project, draft
  17. Ynot
  18. Predator
  19. Мутилин В. С., Новиков Е. М., Хорошилов А. В. Обзор инструментов статической верификации Си программ в применении к драйверам устройств операционной системы Linux // Труды Института системного программирования РАН. — 2012. — Т. 22, № 3. — С. 293-326.
  20. Cliff Jones (from U. Newcastle), Viktor Vafeiadis (from MPI-SWS) Rely-guarantee thinking & separation logic

ЛитератураПравить

СсылкиПравить

  • Cliff Jones (Newcastle University), Viktor Vafeiadis (MPI-SWS) Rely-guarantee thinking & separation logic (англ.) — презентация, хорошо иллюстрирующая понятия логики разделения
  • Matthew Parkinson An Introduction to Separation Logic (англ.) — презентация, в которой иллюстрированы все основные аспекты логики разделения: аксиомы, примеры программ с соответствующими диаграммами, синтаксис