- Что такое формальные спецификации. Абстракция, строгость (rigour), систематичность. Верификация и валидация программ и требований.
- Формальные методы разработки программ. Уточнение программ. Принцип подстановки Лисков. Функция абстракции. Диаграмма коммутативности. Design by Contract.
- Полнота спецификаций. Непротиворечивость спецификаций.
- Методы VDM и RAISE.
- Алгебраические спецификации.
- Моделеориентированные спецификации: явные и неявные.
- Исполнимые формальные спецификации: конечные автоматы, системы переходов.
- Языки спецификации, спецификационные расширения языков программирования (в том числе аннотации), библиотеки функций для описания свойств данных и операций в программе без расширения языка программирования. Примеры. Сравнение.
- Язык RSL.
- Использование формальных спецификаций в строгих (rigour) подходах к поиску ошибок в программах.
- Инструменты Spec# и Dafny. Проблема верификации программ, оперирующих с динамической памятью.
- Formal testing. Model-based testing.
- Аналитическая верификация. Понятия частичной и полной корректности.
- Основные понятия методов Флойда. Точки сечения, индуктивные утверждения, оценочные функции, фундированные множества.
- Метод индуктивных утверждений Флойда. Условия верификации и условия корректности.
- Метод оценочных функций Флойда. Условия корректности и завершимости.
- Методы Флойда для рекурсивных программ.
- Методы Флойда для программ с частичными функциями (в частности, с операциями обращения к элементам массива).
- Инструмент PVS: общая характеристика. Теоремы, вид представления доказательств, интерактивность.
- Язык спецификации инструмента PVS.
- Основные команды инструмента PVS : skolem!, flatten, split, case, induct, inst, expand, replace, lemma, assert, grind.
- ACSL – язык аннотаций для программ на языке Си. Инструмент Frama-C.
среда, 18 января 2012 г.
Список тем лекций
Советую, как минимум, иметь представление по каждому из вопросов из следующего списка (это краткий план материала лекций этого года), а лучше и знать формулировки и определения по каждому из вопросов. Фактически этот список можно воспринимать как список тем для теоретических вопросов на экзамене.
Подписаться на:
Комментарии к сообщению (Atom)
Я правильно понимаю, что, кроме как для вопросов 9, 13-16, не существует официальных материалов?
ОтветитьУдалитьНу еще частично про 1-8 написано в rslbook и методичке о RSL, про инструмены Dafny и RSL - на соответствующих сайтах. Где искать "официальный" материал, касающийся вопросов 10-12, 17-18, 22
Конечно же, ищется материал *в дополнение к конспектам лекций*, для более полного проникновения в предмет... =)
во-первых, конечно, у каждого нормального студента должны быть конспекты :) во-вторых, можно посмотреть статьи, ссылки на которые даны на http://sp.cmc.msu.ru/courses/fmsp . Ну и, в-третьих, можете попробовать посмотреть мои попытки видеозаписи лекций (http://www.youtube.com/playlist?list=PL85900B3D8F94417B), но поскольку это лишь были попытки, то и качество там неважнецкое :)
Удалить