Информатика, вычислительная техника и управление
УДК 004.052.42 DOI: 10.14529/cmsel50205
ИНСТРУМЕНТАЛЬНАЯ ПОДДЕРЖКА ФОРМАЛЬНОЙ ВЕРИФИКАЦИИ ПРОГРАММ, НАПИСАННЫХ НА ЯЗЫКЕ ФУНКЦИОНАЛЬНО-ПОТОКОВОГО ПАРАЛЛЕЛЬНОГО ПРОГРАММИРОВАНИЯ1
М.С. Ушакова, А,И. Легалов
Работа посвящена разработка архитектуры ипструментальных средств для поддержки формальной верификации функционально-потоковых параллельных программ на языке Пифагор. Используемый метод формальной верификации — дедуктивный анализ на базе исчисления Хоара. Процесс доказательства корректности программы представляется в виде дерева, каждый узел которого — информационный граф программы в котором дуги размочены формулами на языке спецификации. Корном дерева является исходная тройка Хоара: информационный граф с предусловием и постусловием. В работе рассматриваются основные преобразования, применяемые к информационному графу программы: разметка дуг, эквивалситное преобразование, расщепление, свертка программы. Посредством данных преобразований исходная тройка модифицируется и в ковочном счете сводится к набору формул на языке спецификации, истинность которых будет свидетельствовать о корректности программы. Предложена архитектура системы поддержки формальной верификации функционально-потоковых параллельных программ, которая позволяет строить дерево доказательства. Представлена реализация этой системы, описана ее основная функциональность.
Ключевые слова: функционально-потоковое параллельное программирование, язык программирования Пифагор, верификация программ, инструментальные средства для поддержки формальной верификации.
Введение
В настоящее время наблюдается тенденция к усложнению пузограммного обеспечения и увеличению сложности его отладки и рисков в случае сбоя, становятся трудно отлаживаемыми, содержат больше ошибок, а последствия ошибки в системе могут оказаться чрезвычайно дорогими. В результате, стали активно развиваться методы верификации программ, в частности формальная верификация. Под формальной верификацией понимается доказательство корректности программы, которое заключается в установлении соответствия между программой и ее спецификацией, описывающей цель разработки [1]. При этом, соответствие программы ее спецификации устанавливается посредством строгого математического доказательства. Главным преимуществом формальной верификации является возможность формально доказать отсутствие ошибок в программе.
Наиболее универсальным методом формальной верификации является дедуктивный анализ па основе исчисления Хоара [2]. Исчисление Хоара это расширение какой-либо формальной теории 3 введением в нее формул специального вида, называемых тройками Хоара. Тройка Хоара — это программа, к которой приписаны две формулы теории 3, описывающие ограничения па входные переменные и требования к результату выполнения программы. Эти формулы называются предусловие и постусловие соответственно, {ф}, где Prog — программа, a tp и ф — предусловие и постусловия для Prog. Также для расширения теории 3 вводится набор аксиом для операторов языка и правила вывода, с помощью
1Статья рекомендована к публикации программным комитетом Международной научной конференции «Параллельные вычислительные технологии — 2015».
58
Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
которых из аксиом можно выводить утверждения о свойствах программ, в том числе о свойствах корректности. При этом, расширение теории 3 строится таким образом, чтобы корректность программы вытекала из истинности тройки Хоара для этой программы. Основная идея данного подхода заключается в том, чтобы на базе аксиом, с помощью последовательных применений правил вывода, преобразовать тройку Хоара в формулу теории 3, и доказать истинность формулы в этой теории.
Этот метод применим для произвольных языков программирования, а основным его преимуществом является возможность частичной автоматизации процесса доказательства. Стоит также отметить, что теорий 3 для описания спецификаций программ) для каждого языка программирования аксиомы и правила вывода будут своими, так как строятся на основе семантики этого языка. Значит каждому языку программирования будет соответствовать свое исчисление Хоара, и поэтому сложность доказательства корректности программ тоже будет различной.
В настоящее время достигнуты определенные успехи в практическом применении дедуктивного анализа для верификации последовательных программ.языках программирования Для поддержки этого процесса разработан ряд систем. В качестве примера можно привести верификатор программ на языке С Boogie |3| и систему СПЕКТР |4], а также системы для верификации объектпо-ориептироваппых программ на Java: LOOP [5] и KeY [6].
Развитие методов формальной верификации особенно актуально для параллельного программирования. Дедуктивный анализ не нашел широко применения при верификации параллельных императивных программ из-за высокой сложности процесса. Основной проблемой является резкое увеличение сложности формальной верификации параллельной императивной программы по сравнению с последовательной. Главная причина необходимо учитывать конфликты из-за ресурсов, например, такие как неправильное совместное использование общей памяти или взаимные блокировки процессов в случае работы с распределенной памятью.
Альтернативой императивного подхода является функционально-потоковая параллельная (ФПП) парадигма и ее реализация — язык программирования Пифагор [7, 8]. из-за ресурсов. Модель вычислений, лежащая в основе языка задает вычисления в автоматически выделяемых бесконечных ресурсах. Это позволяет не учитывать возможные ресурсные конфликты, что облегчает процесс написания функционально-потоковой параллельной программы. Каждая программа это функция, поэтому в языке отсутствуют переменные и циклы, а операции выполняются по готовности данных. В результате, сложность формальной верификации ФПП программ сравнима со сложностью верификации последовательных программ. Другая важная особенность языка — возможность достичь максимального параллелизма программы за счет того, что параллелизм реализуется на уровне операций. После доказательства корректности такой программы, она может быть перенесена па конкретную архитектуру с конечными ресурсами, при необходимости, с ограничением се параллелизма.
Для языка Пифагор построено исчисление Хоара [9], позволяющее доказывать корректность программ. В качестве языка спецификации выбрана логика исчисления предикатов первого порядка, программы, к дугам которого привязаны формулы на языке спецификации (дуги размечены формулами), а процесс преобразований троек Хоара сводится к разметке дуг графа формулами, модификациям графа и свертке программы. Тройка Хоара, которой соответствует граф со всеми размеченными дугами может быть преобразова-
2015, т. 4, № 2
59
Инструментальная поддержка формальной верификации программ...
па в формулу, тождественная истинность которой будет свидетельствовать о корректности программы. Однако процесс доказательства достаточно трудоемок, так как обычно доказательство истинности исходной тройки сводится к доказательству истинности нескольких прообразованных троек. Необходимость рассматривать большое количество вариантов значительно усложняет процесс доказательства. Поэтому целью данной работы является разработка инструментальных средств, обеспечивающих поддержку формальной верификации ФПП программ.
В разделе 1 вводятся основные понятия и описываются преобразования информационного графа с размоткой. Раздел 2 рассматривается архитектура системы поддержки формальной верификации функционально-потоковых параллельных программ, которая позволяет строить дерево доказательства. Реализация предложенной системы и ее основная функциональность описаны в разделе 3.
1. Преобразования информационного графа с разметкой
Программу на языке Пифагор удобно отображать в виде -информационного графа — ациклического ориентированного графа, определяющего информационную структуру программы, у которого вершины представляют программе-формирующие операторы, а дуги задают пути передачи информации между вершинами |7|. Информационный граф программы, дуги которого помечены формулами па языке спецификации, будем называть информационным графом с разметкой (ИГР). Если в информационном графе размечены только входная и выходная дуги, то граф соответствует тройке Хоара. в которой программа представляется графом, разметка входной дуги есть предусловие, выходной постусловие. Зададим над информационным графом с разметкой следующие преобразования:
1) разметка дуги;
2) изменение информационного графа программы:
(a) эквивалентное преобразование,
(b) расщепление;
3) свертка программы.
Процесс доказательства корректности ФПП программы можно рассматривать как последовательность преобразований исходного информационного графа с разметкой, где под «исходным информационным графом с разметкой» понимается ИГР, которому соответствует исходная тройка Хоара, то есть граф у которого входная дуга размечена заданным пользователем предусловием, выходная постусловием, а остальные дуги не размечены. Последовательными преобразованиями из исходного информационного графа с разметкой получают множество полностью размеченных ИГР, к каждой дуге такого графа приписана одна формула. Эти графы с помощью свертки преобразуются в тройки Хоара, которые можно напрямую преобразовать в формулы па языке спецификации для проверки истинности. Если все полученные формулы истинны, то и исходная тройка истинна, а программа корректна.
1.1. Разметка дуг
Принцип разметки дуг графа, формулами (приписывание формул к дугам) описан в [9|. Формула, приписанная к дуге информационного графа, описывает свойства данных, которые передаются но этой дуге.
60 Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
Разметка дуг информационного графа осуществляется на основе аксиом для встроенных функций и теорем для пользовательских функций с доказанной корректностью. Одну функцию могут описывать несколько аксиом или теорем, поэтому в результате разметки может быть получено несколько новых графов.
На множестве формул, помечающих дуги одного ИГР, введем отношение иерархии, назвав формулу, помечающую дугу (a, ft), родительской но отношению к формуле, помечающей дугу (ft, с) для узлов a, ft, с графа.
При разметке дуг информационный граф программы не изменяется, и в случае, если в результате разметки какой-либо дуги получается несколько новых ИГР, то они будут отличаться между собой только формулой у размечаемой дуги. Поэтому, для компактного отображения, эти ИГР можно объединить в один, у которого дуга будет размечена несколькими формулами одновременно. Отношение иерархии между формулами позволяет затем разделить компактное представление па исходные ИГР.
Проиллюстрируем вышесказанное па примере. На рис. 1.А приведена часть графа некоторой программы четыре оператора соединены информационными связями. Узел 3 принимает входные данные с узлов 1 и 2, узел 4 принимает данные от узла 3. В начале, дуги в графе не размечены.
И f
Т
Рис. 1. Схематичное изображение преобразований информационного графа с разметкой. А — часть информационного графа программы, размеченная формулами. Узлы графа (обозначены кружками) представляют операторы программы, дуги информационные связи, к дугам приписаны формулы (обозначены прямоугольниками), рядом с которыми указаны их номера, в круглых скобках указаны номера родительских формул. Б — эквивалентное преобразование «раскрытие параллельного списка». Параллельный список обозначен квадратными скобками, оператор интерпретации — линией, у которой кружок указывает функциональный вход
На нервом шаге разметим дугу (1,3). Если, при преобразовании графа, для оператора 1 применимо три аксиомы, то в результате преобразования получится три новых ИГР, которые компактно будут отображаться как исходный граф, у которого к дуге (1,3) приписаны три формулы. На следующем шаге разметим дугу (2,3). Число применимых аксиом для каждого из трех ИГР первого шага преобразований одинаково, так как операторы 1 и 2 независимы. Если при преобразовании трех ИГР для оператора 2 применимо две аксиомы, то в результате преобразования получится шесть новых графов. В компактном отображс-
2015, т. 4, № 2
61
Инструментальная поддержка формальной верификации программ...
пии этих шести графов к дуге (2,3) будут приписаны две формулы. Оператор 3 зависит от операторов 1 и 2, поэтому к каждому из шести полученных ИГР может быть применено разное количество аксиом. Пусть для первого ИГР это число соответствует двум (он распадется на два новых ИГР), для всех остальных — единице. В результате разметки получится семь графов, это число соответствует общему числу применимых аксиом и количеству формул, которые будут приписаны к дуге (3,4). На рис. 1.А индексы (i,j) возле формул, помечающих дугу (3,4), обозначают номер i родительской формулы, помечающей дугу (1,3), и помер j родительской формулы, помечающей дугу (2,3).
1.2. Изменение информационного графа
Второй тип преобразований изменяет информационный граф программы. Эквивалентное преобразование осуществляются по правилам эквивалентных преобразований операторов и связей языка Пифагор (описаны в [8, 10]). В результате преобразования получается один ИГР с измененным информационным графом. В качестве примера эквивалентного преобразования па рис. 1.Б приведено «раскрытие параллельного списка». Параллельный список позволяет явно указывать, что вес поступающие в него операторы могут выполняться одновременно. В графе слева параллельный список из двух элементов поступает на функциональный вход оператора интерпретации. Оператор интерпретации имеет два входа для аргумента и функции, и осуществляет функциональное преобразование аргумента. В эквивалентном ему графе справа каждый элемент исходного параллельного списка поступает на функциональный вход своего оператора интерпретации, а уже результат их выполнения передается в параллельный список.
Другой вариант преобразований второго типа — расщепление, оно приводит к получению двух и более ИГР с измененными информационными графами. Расщепление можно использовать для упрощения доказательства, например, при разметке оператора выбора, если точно известны все варианты из которых делается выбор. Это позволяет упростить не только информационный граф программы, но и формулы разметки.
1.3. Свертка
Третий тип преобразований — свертка программы. Свертка проводится над размеченной дугой (кроме входной и выходной дуг программы). Весь порожденный подграф с узлами, из которых достижимо начало рассматриваемой дуги (кроме входного аргумента), может быть заменен на новую переменную, а формула разметки данной дуги добавляется к предусловию исходного ИГР. При замене части кода на новую переменную программа сократится. Свертку можно проводить при частичной или полной разметке дуг графа программы. Если провести свертку над всеми размеченными дугами ИГР, полученному в результате ИГР будет соответствовать тройка Хоара. Назовем такую свертку полной. Когда в ИГР все дуги размечены, в результате полной свертки от всего графа остается одна переменная. Ее свойства описаны в предусловии, описывающем теперь свойства всех данных, передаваемых по дугам исходного графа. Она также является результатом работы программы. Такая программа называется пустой, и для определения ее корректности достаточно проверить следование постусловия из предусловия.
В результате всех рассмотренных преобразований ИГР ФПП программы можно сделать следующий вывод: весь процесс доказательства можно представить в виде дерева,
62
Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
корень которого исходный ИГР, дочерние узлы получаются из родительских выполнением одного из преобразований 1)-3), а листья полностью размеченные ИГР, над которыми проводится полная свертка и преобразование в формулы. Будем называть такое дерево — деревом доказательства или просто доказательством корректности программы.
2. Обобщенная структура системы поддержки формальной верификации
На рис. 2 приведена общая схема системы для поддержки формальной верификации ФПП программ.
Рис. 2. Обобщенная структура системы поддержки формальной верификации
В системе можно выделить несколько модулей: «Модуль доказательства корректности программы», « С и сте му у и рав л е и ия би бл и оте ко й акс ио м и тео ре м » и « М одул ь анализаотпи-бок и выдачи информации об ошибках». «Модуль доказательства формул» (верификатор формул) обособлен от системы, так как является сторонним и может не использоваться при доказательстве, а все его действия будет выполнять пользователь (самостоятельно или используя другой более удобный для пего верификатор).
Принцип работы системы состоит в следующем. Пользователь передает системе программу па языке Пифагор и спецификацию программы на языке спецификации. «Модуль доказательства корректности программы» формирует исходный ИГР (которому соответствует исходная тройка Хоара) и начинает процесс доказательства, который заключается в разметке дуг графа программы формулами. Для этого используется информация об аксиомах и уже доказанных теоремах из «Библиотеки аксиом и теорем». «Модуль доказательства корректности программы» посылает запросы к «Системе управления библиотекой аксиом и теорем». В случае если запрашиваемая функция отсутствует в библиотеке, выдается ошиб-
2015, т. 4, № 2
63
Инструментальная поддержка формальной верификации программ...
ка о невозможности разметки, которая обрабатывается «Модулем анализа ошибок». Если аксиомы (теоремы) для рассматриваемой функции присутствуют в библиотеке, то «Модуль доказательства корректности программы» проводит их отбор. Для каждой аксиомы (теоремы) из набора аксиом (теорем) для рассматриваемой функции формируется условие применимости данной аксиомы (теоремы) на языке спецификации. Это условие передается верификатору, и, если оно истинно или выполнимо, то аксиома (теорема) используется для разметки, иначе она отбрасывается. После того как все дуги в информационном графе программы будут размечены, проводится полная свертка. Тройки Хоара, соответствующие полученным ИГР, преобразуются в формулы (назовем их финальными формулами), которые передаются верификатору для проверки их истинности. Если вес формулы истинны, то программа корректна, а сс исходная тройка Хоара — теорема. «Модуль доказательства корректности программы» передает полученную теорему (с доказательством) «Системе управления библиотекой аксиом и теорем», для сохранения в библиотеке. Если истинность формулы не доказана «Модуль анализа ошибок» определяет причину и сообщает об этом пользователю.
Рассмотрим работу «Модуля доказательства корректности программы» более детально (рис. 2). «Блок управления доказательством» является основным, он отвечает за взаимодействие с пользователем, принимает его данные, команды и визуализирует процесс доказательства. Данный блок формирует дерево доказательства. При получении ИГР, он ищет операторы с не размеченными дугами и передает их, в начале, «Блоку эквивалентных преобразований», а затем «Блоку разметки дуг» для получения формул разметки. После того как ИГР становится полностью размеченным, он передается «Блоку генерации финальных формул», который осуществляет полную свертку и генерирует множество финальных формул.
Рассмотренная система может работать в нескольких режимах:
1) полностью ручной;
2) частично автоматизированный;
3) автоматизированный.
В первом случае пользователь использует только «Блок управления доказательством» и «Блок генерации финальных формул», а также «Модуль анализа ошибок». Он сам размечает дуги графа формулами и доказывает истинность финальной формулы. В частично автоматизированном режиме не задействован только «Модуль доказательства формул», и пользователь сам указывает, истинна, ложна или выполнима сгенерированная формула. В автоматизированном режиме задействованы все модули.
3. Реализация системы
В соответствии с рассмотренной обобщенной структурой разработана программа, обеспечивающая поддержку формальной верификации ФПП программ, которая позволяет строить дерево доказательства программы на языке Пифагор.
Пользователю предоставляется графический интерфейс для редактирования дерева доказательства. В качестве входных данных программа принимает формулы разметки в текстовом виде, а код программы — в виде текстового представления реверси в нот информационного графа (РИГ) про грамм ы 111, 12 ], котор ы й описывает существу югцио в программе зависимости по данным (отличается от информационного графа тем, что дуги ориептиро-
64 Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
ванны в противоположном направлении). Также можно загрузить ранее созданный ИГР или дерево доказательства.
Главное окно программы (рис. 3) представляет собой редактор дерева доказательства. В левой его части располагается редактор узлов дерева, а в правой — редактор ИГР, в котором отображается текущий узел дерева. Редактор узлов дерева доказательства позволяет вставлять новые и уже существующие ИГР, копировать, удалять текущие ИГР и вставлять скопированный ИГР, как дочерний к текущему.
2
1
4
5
3
Рис. 3. Главное окно средства инструментальной поддержки формальной верификации функционально-11 отоковых параллельны программ; 1 — редактор узлов дерева доказательства, 2 — поле ввода предусловия, 3 — поле ввода постусловия, 4 — редактируемый код программы, 5 — графическое пред став л сии с ревер с ив но го информационного графа программы
Редактор ИГР в своей верхней и нижней части содержит ноля для ввода предусловия и постусловия программы соответственно, в левой части отображается графическое представление РИГ, а в правой — редактируемый код программы. Для получения графического пред став л сии я РИГ используется сторонняя программа GraphViz, которой передается файл формата dot. Редактор кода представлен папелыо инструментов и текстом программы, разбитым па строки, где каждая строка соответствует одному узлу РИГ программы. РИГ имеет текстовый формат и создается по программе. Такой РИГ имеет правильный порядок вызовов функций, то есть функция будет вызвана только после того как определена. По такому текстовому представлению однозначно восстанавливается код программы.
Редактор кода программы позволяет добавлять, удалять и редактировать узлы РИГ. При этом, ограничения не позволят пользователю обратиться к оператору до его опрсделс-
2015, т. 4, № 2
65
Инструментальная поддержка формальной верификации программ...
пия. Присутствует возможность редактировать задержанные списки. Оператор группировки в задержанный список (или, кратко, задержанный список) содержит подграф программы. Операторы, находящиеся в задержанном списке, не могут выполняться даже при нали-чии всех аргументов. Их активизация возможна только при снятии задержки, когда ограниченный подграф становится частью всего вычисляемого графа [7, 8|. Редактор кода имеет возможность любой оператор поместить в задержанный список, при этом в задержанный список помещаются все операторы, которые использует данный оператор. Задержанный список рассматривается как константа, поэтому редактирование операторов задержанного списка возможно только после снятия задержки.
Пользователь может вызвать функцию автоматической разметки дуг, либо использовать редактор ИГР для ручной разметки. В редакторе используется компактное отображение получаемых ИГР. Если дуга еще не была размечена, то производится проверка готовности разметки па всех входных дугах. Если хотя бы на одной из входной дуг любого из рассматриваемых в компактном представлении графов разметка отсутствует, то выдается соответствующее сообщение о невозможности разметки текущей дуги. Если все входные дуги размечены, то появляется окно (рис. 4) с иерархией формул дуги текущего узла, где все формулы разделены на группы, соответствующие различным комбинациям формул родительских узлов. Слева представлен список индексов родительских формул, а справа на вкладках размещаются формулы разметки текущей дуги. Пользователь может добавлять новые формулы, что автоматически изменяет индексы всех дочерних узлов (если они уже размечены), у которых появляется необходимое количество пустых вкладок для новых формул. При удалении формул, удаляются все формулы потомков, дочерние по отношению к текущей формуле, и изменяются индексы оставшихся формул.
Рис. 4. Окно редактирования иерархии формул размечаемой дуги
Пользователю также доступны следующие функции: автопреобразование, авторазмет-ка ИГР и генерация финальных формул.
Автопреобразовапие текущего ИГР (автоматическое выполнение эквивалентных преобразований) выполняется в случае, если он является листом дерева доказательства, иначе его дочернее поддерево должно быть удалено. Кроме того, преобразуются только готовые операторы, то есть те операторы у которых размечены все входные дуги, а выходная дуга еще не размечена. У всех готовых операторов текущего графа проверяется возможность
66
Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
применения эквивалентного преобразования. Если к ИГР можно применить эквивалентное преобразование, то новый полученный ИГР становится дочерним к исходному.
Функция автоматической разметки применяется к текущему графу. В начале для него проводятся эквивалентные преобразования, затем находится готовый оператор, для того чтобы провести разметку его выходной дуги. Если оператор является списком, то выходная дуга размечается константой true, если это оператор интерпретации, то для функции с его функционального входа, запрашивается список аксиом (для встроенных функций) или теорем (для функций пользователя) в библиотеке аксиом и теорем. Если функция присутствует в библиотеке, то для каждой ее аксиомы или теоремы формируется условие применимости, истинность или выполнимость которого требуется определить пользователю. Аксиомы или теоремы, для которых условие тождественно ложно, отбрасываются, а все оставшиеся используются для разметки дуги рассматриваемого оператора интерпретации несколькими формулами. Далее осуществляется поиск другого готового оператора.
Если все дуги текущего информационного графа размечены, то к нему может быть применена полная свертка, и полученные в результате тройки Хоара с пустой программой можно преобразовать в формулы. Это реализуется функцией генерации финальных формул.
Таким образом, па данный момент реализован ручной и частично автоматизированный режим работы системы.
Заключение
В работе рассмотрены основные преобразования, которые претерпевает информационный граф с разметкой при построении доказательства корректности программы. Разработаны основные концепции архитектуры инструментального средства для поддержки формальной верификации ФПП программ. Задача реализации рассмотренной системы частично решена. В настоящее время ведется работа над расширением функциональности частично автоматизированного и реализацией автоматизированного режима работы системы.
Литература
1. Непомнящий, В.А. Прикладные методы верификации программ / В.А. Непомнящий,
О.М. Рнкин — М.: Радио и связь, 1988. — 255 с.
2. Hoare, С. A. R. An axiomatic basis for computer programming / C. A. R. Hoare // Communications of the ACM. - 1969. — Vol. 10, No. 12. — P. 576 585. DOI: 10.1145/363235.363259
3. Barnett, M. Boogie: A modular reusable verifier for object-oriented programs / M. Barnett, B.Y.E. Chang, R. Deline, B. Jacobs, K.R.M. Leino /./ FMCO 2005. LNCS. 2006. -Vol. 4111. - P. 364-387. DOI: 10.1007/11804192_17
4. Непомнящий, В. А. Верификация С-программ в мультиязыко в ой системе СПЕКТР / В.А. Непомнящий, И.С. Ануреев, М.М. Атучин, И.В. Марьясов, А.А. Петров, А.В. Промский // Моделирование и анализ информационных систем. — 2010. — № 17 (4). — С. 88 100. DOI: 10.3103/s014641161107011x
5. Van den Berg, J. The LOOP compiler for Java and JML / J. Van den Berg, B. Jacobs // Tools and Algorithms for the Construction and Analysis of Systems. LNCS. — 2001. — Vol. 2031.
2015, t. 4, № 2
67
Инструментальная поддержка формальной верификации программ...
-Р. 299 312. DOI: 10.1007/3-540-45319-Э_21
6. Ahrendt, W. The KeY Tool / W. Ahrcndt, T. Baar, B. Beckert, R. Bubel, M. Giese, R. Halmlc, W. Mcnzcl, W. M os tow ski, A. Roth, S. Sch lager, P.H. Schmitt /7 Software and System Modeling. - 2005. - Vol. 4 (1). - P. 32-54. DOI: 10.1007/sl0270-004-0058-x
7. Легалов, А.И. На пути к переносимым параллельным программам / А.И. Легалов, Д.А. Кузьмин, Ф.А. Казаков, Д.В. Привалихин // Открытые системы. — 2003. — № 5. — С. 36-42.
8. Легалов, А.И. Функциональный язык для создания архитектурно-независимых параллельных программ / А.И. Легалов / / Вычислительные технологии. — 2005. — № 1 (10). - С. 71-89.
9. Kropachcva, M.S. Formal Verification of Programs in the Pifagor Language / M.S. Kropachcva, A.I. Legalov / / Parallel Computing Technologies (PaCT-2013) 12th International Conference, September 30 - October 4, 2013. Saint-Petersburg, Russia. LNCS. — 2013. — Vol. 7979. P. 80 89. DOI: 10.1007./978-3-642-39958-9_7
10. Кропачева, M.C. Формализация семантики функционально-потокового языка параллельного программирования Пифагор / М.С. Кропачева /7 Проблемы информатизации региона (ПИР-2011): Материалы XII Всероссийской научно-практической конференции (Красноярск, 22 - 23 ноября 2011 г.). — Красноярск: Сибирский федеральный университет, 2011. — С. 144-148.
11. Матковский, И.В. Параллельная событийная машина для функционально-потокового языка «Пифагор» / И. В. М атков е к и й /. И нф ор м аци о н н ы е и м ате м ати ч еск не техн о л оги и в науке и управлении: Сборник трудов XVVII Байкальской Всероссийской конференции с международным участием (Иркутск - Байкал, 30 июня - 9 июля 2012 г.). Часть II. — Иркутск: ИСЭМ СО РАН, 2012. С. 186 193.
12. Легалов, А.И. Событийная модель вычислений, поддерживающая выполнение
функционально-потоковых параллельных программ / А.И. Легалов, Г.В. Савченко, В.С. Васильев // Системы. Методы. Технологии. — 2012. № 1 (13). — С. 113 119.
Ушакова Мария Сергеевна, ассистент кафедры Вычислительной техники института Космических и информационных технологий, Сибирский Федеральный университет (Красноярск, Российская Федерация), [email protected].
Легалов Александр Иванович, д.тлг. профессор и заведующий кафедры Вычислительной техники института Космических и информационных технологий, Сибирский Федеральный университет (Красноярск, Российская Федерация), [email protected].
Поступила в редакцию И февраля 2015 г.
68
Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»
М.С. Ушакова, А.И. Легалов
Bulletin of the South Ural State University Series “Computational Mathematics and Software Engineering”
2015, vol. 4, no. 2, pp. 58-70
DOI: 10.14529/cmsel 50205
A TOOLKIT FOR SUPPORTING FORMAL VERIFICATION OF PROGRAMS IN THE FUNCTIONAL DATA-FLOW PARALLEL PROGRAMMING LANGUAGE
M.S. Ushakova, Siberian Federal University, Institute of Space and Information Technology (Krasnoyarsk, Russian Federation) [email protected],
A.I. Legalov, Siberian Federal University, Institute of Space and Information Technology (Krasnoyarsk, Russian Federation) [email protected]
The article is devoted to the architecture development of the toolkit for supporting formal verification of functional data-flow parallel programs in the Pifagor Language. The method of deduction based on Hoare logic is used for formal verification. A proof process is considered as a tree where each node is a program data-flow graph, whose edges are marked with formulas in a specification language. The tree root is the initial Hoare triple, namely the program dataflow graph with a precondition and a postcondition. In this article basic transformations of the data-flow graph arc considered: edge marking, equivalent transformation, splitting, folding of the program. By means of these transformations the initial triple is being transformed and finally is reduced to a set of formulas in the specification language. If all of these formulas are identically true, then the program is correct. Architecture of the toolkit for supporting formal verification of functional data-flow parallel programs is proposed, which allows to construct a proof three. The implementation of the toolkit is introduced and its main functionality is considered.
Keywords: functional data-flow parallel programming, Pifagor programming language, programs formal verification, toolkit for supporting formal verification.
References
1. Ncpomnyaschiy V.A., Ryakin O.M. Prikladnyic metodvi verifikatsii programin |Applied Methods for Programs Verification!. Moscow, Radio i svyaz, 1988. 255 p.
2. Hoare C. A. R. An Axiomatic Basis for Computor Programming // Communications of the ACM. 1969. Vol. 10, No. 12. P. 576 585. DOI: 10.1145/363235.363259
3. Barnett, M., Chang, B.Y.E., Dclinc, R., ct al. Boogie: A Modular Reusable Verifier
for Object-Oriented Programs .// FMCO 2905. LNCS. 2006. Vol. 4111. P. 364-387. DOI: 10.1007/11804192_17
4. Kepomniaschy V.A., Amireev I.S., Atuchin M.M., et al. C Program Verification in SPECTRUM Multilanguage System // Automatic Control and Computer Sciences. 2011. Vol. 45, No. 7. P. 413-420. DOI: 10.3103/s014641161107011x
5. Van den Berg, J., Jacobs, B. The LOOP compiler for Java and JML /7 Tools and Algorithms for the Construction and Analysis of Systems. LNCS. 2001. Vol. 2031. P. 299 312. DOI: 10.1007/3-540-45319-9_21
6. Alirendt, W., Baar, T., Beckert, B., et al. The KeY Tool //' Software and System Modeling. 2005. Vol. 4, No. 1. P. 32-54. DOI: 10.1007/sl0270-004-0058-x
2015, t. 4, № 2
69
Инструментальная поддержка формальной верификации программ...
7. Legalov A.I., Kuzmin D.A., Kazakov F.A., et al. Na puti k perenosimyim parallelnyim programmam [An Approach to Portable Parallel Programs] /7 Otkiyityie sistemyi [Open Systems|. 2003. Vol. 5. P. 36-42.
8. Legalov, A.I. Funktsionalnyiy yazyik dlya sozdaniya arliitekturno-nezavisiinyili parallelnyih programm [The Functional Programming Language for Creating Architecture-Independent parallel Programs] // Vyicliislitelnyie tehnologii [Computational Technologies]. 2005. Vol. 10, No. 1. P. 71-89.
9. Kropacheva, M.S., Legalov A.I. Formal Verification of Programs in the Pifagor Language /7 Parallel Computing Technologies (PaCT-2013) 12th International Conference, September 30 -October 4, 2013. Saint-Petersburg, Russia. LNCS. 2013. Vol. 7979. P. 80-89. DOI: 10.1007/ 978-3-642-39958-9 _ 7
10. Kropacheva, M.S. Forinalizatsiya semantiki funktsionalno-potokovogo yazyika parallelnogo
programmirovaniya Pifagor [Formalization of the Semantics for the Functional Data-Flow Parallel Language Pifagor]. Problemyi informatizatsii regiona (PIR-2011): Materialyi XII Vserossiyskoy liauclino-prakticlieskoy konferentsii (Krasnoyarsk, 22 - 23 noyabrya 2011) [The Problems of Region Informatization: 12th Russian Scientific-Practical Conference
(Krasnoyarsk, Russia, November, 22 -23, 2011)|. Krasnoyarsk, Publishing of the Siberian Federal University, 2011. P. 144 148.
11. Matkovskiy I.V. Parallelnaya sobyitiynaya mashina dlya funktsionalno-potokovogo yazyika
“Pifagor” [Parallel Event-Based Machine for Functional Dataflow Programming Language “Pifagor”]. Informatsionnyic i matcmatichcskic tehnologii v naukc i upravlcnii: Sbornik
trudov XVVII Baykalskoy Vserossiyskoy konferentsii s mezhdunarodnyim uehastiem (Irkutsk -Baykal, 30 iyuiiya - 9 ivulya 2012) [Information and Mathematical Technologies in Science and Management: Proceedings of the 17th Baikal Russian Conference with the International Participant (Irkutsk - Baikal, Russia, June, 30 - July, 9, 2012)|. Irkutsk, Publishing of the Melentiev Energy Systems Institute of Siberian Branch of the Russian Academy of Sciences, 2012. Vol. 2. P. 186 193.
12. Legalov, A.I., Savchenko G.V., Vasilev V.S. Sobyitiynaya model vyichisleniy, podderzliivayuschaya vyipolnenie funktsionalno-potokovyih parallelnyih programm [Computation Event Model Backing the Execution of Functional Data Flow Concurrent Programs] // Sistemyi. Metodyi. Tehnologii [Systems. Methods. Technologies]. 2012. Vol. 1, No. 13. P. 113 119.
Received February 11, 2015.
70
Вестник ЮУрГУ. Серия «Вычислительная математика и информатика»