Математическая логика (318, 319/2, 241, 242)
Обязательный курс для студентов групп 318 и 319/2, а также 241 и 242 (Математическая логика и теория алгоритмов). Курс читает В. В. Подымов.
Актуальность информации: весенний семестр 2023/2024 учебного года.
Содержание
Слайды лекций
Слайды будут появляться по мере чтения лекций.
Прошлогодние слайды
Блок 1 (вводный). Что такое логика. Несколько логических парадоксов. Чего ожидать в курсе.
Блок 2. Логика высказываний: синтаксис, семантика.
Блок 3. Логика предикатов: синтаксис, семантика.
Блок 4. Как формализовать предложение на языке логики предикатов (пример).
Блок 5. Логика высказываний: выполнимые и общезначимые формулы.
Блок 6. Логика предикатов: выполнимые и общезначимые формулы; модели формул; логическое следствие; проблема общезначимости формул (постановка).
Блок 7. Логика предикатов: можно ли проверить общезначимость формулы "в лоб"?
Блок 8. Метод семантических таблиц: семантические таблицы.
Блок 9. Подстановки (основные определения).
Блок 10. Метод семантических таблиц: табличный вывод.
Блок 11. Метод семантических таблиц: корректность табличного вывода.
Блок 12. Метод семантических таблиц: полнота табличного вывода.
Блок 13. Теорема Лёвенгейма-Сколема. Теорема компактности Мальцева. Автоматизация доказательства теорем.
Блок 14. Общая схема метода резолюций.
Блок 15. Равносильность формул.
Блок 16. Предварённая нормальная форма (ПНФ).
Блок 17. Сколемовская стандартная форма (ССФ).
Блок 18. Системы дизъюнктов.
Блок 19. Композиция подстановок. Постановка задачи унификации.
Блок 20. Алгоритм унификации атомарных формул.
Блок 21. Монотонность и транзитивность отношения логического следования.
Блок 22. Резолютивный вывод. Корректность резолютивного вывода.
Блок 23. Обоснование общезначимости формулы методом резолюций (пример).
Блок 24. Эрбрановские интерпретации. Теорема об эрбрановских интерпретациях.
Блок 25. Теорема Эрбрана. Полнота резолютивного вывода.
Блок 26. Даша, Саша, Паша, пиво и метод семантических таблиц с методом резолюций.
Блок 27. Как устроены математические доказательства. Логические исчисления.
Блок 28. Натуральное исчисление высказываний: основные определения.
Блок 29. Натуральное исчисление высказываний: правило монотонности, закон исключённого третьего, корректность.
Блок 30. Натуральное исчисление высказываний: правило сечения, правило полного перебора, правило приведения к абсурду, полнота.
Блок 31. Натуральное исчисление предикатов: основные определения, корректность.
Блок 32. Гильбертовское исчисление предикатов. Теорема Гёделя о полноте (формулировка).
Блок 33. Натуральное исчисление предикатов: полнота.
Блок 34. Задачи и проблемы. Алгоритмы. Разрешимость. M-сводимость.
Блок 35. Машины Тьюринга (МТ).
Блок 36. Теорема Чёрча.
Блок 37. Аксиоматические теории первого порядка. Проблема общезначимости формул в теории.
Блок 38. Основные свойства аксиоматических теорий.
Блок 39. Арифметические интерпретации и теории.
Блок 40. Определения и выразимость.
Блок 41. Формальная арифметика. Теорема Гёделя о неполноте.
Блок 42. Арифметика Пресбургера.
Блок 43. Модальные логики.
Блок 44. Эпистемические логики.
Блок 45. Темпоральные логики.
Блок 46. Интуиционистская логика.
Блок 47. Формальная верификация.
Блок 48. Модельные императивные программы. Постановка задачи верификации программ.
Блок 49. Логика Хоара. Автоматизация проверки правильности программ.
Блок 50. Проверка правильности распределённых систем. Пара слов о методе model checking.
Блок 51. Размеченные системы переходов.
Блок 52. Спецификация систем при помощи темпоральных логик.
Блок 53. Алгоритм model checking для CTL.
Семинары
Материалы семинаров будут обновляться по мере проведения занятий
Семинары 1-4 проводятся по этому сборнику задач.
Желающие более глубоко проработать материал первых четырёх семинаров могут обратиться к расширенному сборнику задач
Материалы семинара 5-6 (натуральное исчисление).
Контрольные работы
Контрольные работы проводятся письменно, длительность каждой - 90 минут.
В контрольных работах встретятся 4 типовые задачи со следующими темами:
- Формализовать в логике предикатов предложение, записанное на естественном языке.
- Обосновать общезначимость формулы логики предикатов методом семантических таблиц.
- Обосновать общезначимость формулы логики предикатов методом резолюций.
- Доказать формулу в натуральном исчислении предикатов.
Оценка решений типовых задач:
- Максимальная оценка - 4 балла.
- Если решение в целом верно, но содержит редкие ошибки серьёзнее опечаток, то оно оценивается в 3 балла.
- Если решение содержит серьёзные ошибки, но имеет структуру, в целом разумно соотносящуюся с правильной, то задача оценивается в 2 балла.
- Если в решении обнаружены правильные элементы, в заметном, но всё же малом количестве, то задача оценивается в 1 балл.
Теоретические вопросы даются в форме теста с множественным выбором: из предложенных вариантов ответа требуется выбрать правильные (один, несколько или ни одного), обоснование не требуется. Правильно решённый теоретический вопрос оценивается в 1 балл.
Первая контрольная работа будет содержать
- 3 типовые задачи по темам 1-3 и
- 9 теоретических вопросов по прочитанным лекциям.
Вторая контрольная работа будет содержать
- 4 типовые задачи по всем темам и
- 5 теоретических вопросов по лекциям, не попавшим в первую контрольную работу.
Остальные контрольные работы будут содержать
- 4 типовые задачи по всем темам и
- 14 теоретических вопросов по всем лекциям.
Зачёт
На зачёте оцениваются результаты, относящиеся к решению типовых задач, знанию теории и работе в семестре. При проставлении зачёта учитывается 6 технических оценок:
- Четыре оценки за типовые задачи, по одной за каждую задачу.
- Оценка за знание теории. Максимум - 14 баллов.
- Оценка за решение премиальных задач.
Для получения зачёта требуется получить два результата:
- Набрать хотя бы 11 баллов за типовые задачи.
- Набрать хотя бы 20 баллов суммарно за всё (типовые задачи, теория, премиальные задачи).
Баллы за типовые задачи и за теорию набираются на контрольных работах.
Для решения каждой типовой задачи будет предложено несколько попыток. При проставлении зачёта учитывается максимальная оценка за задачу среди всех попыток её решить.
При проставлении зачёта учитывается максимальная оценка за теорию среди полученных
- суммарно за первые две контрольные работы и
- за каждую из следующих контрольных работ.
Экзамен
Формат проведения и длительность экзамена: письменно, 120 минут.
Экзаменационная работа содержит 10 задач и оценивается по шкале от 0 до 37 технических баллов. К этим техническим баллам прибавляются баллы за выполнение премиальных задач и поощрение/штраф за контрольную работу. Согласно набранной сумме технических баллов выставляется оценка:
- хотя бы 30: отлично;
- хотя бы 23, но менее 30: хорошо;
- хотя бы 16, но менее 23: удовлетворительно;
- менее 16: неудовлетворительно.
Баллы за экзаменационную работу складываются из баллов за каждую задачу, предложенную в работе:
- Каждая из задач 1-4 оценивается в 4 балла. Темы задач:
- Формализовать в логике предикатов предложение, записанное на естественном языке.
- Обосновать общезначимость формулы логики предикатов методом семантических таблиц.
- Обосновать общезначимость формулы логики предикатов методом резолюций.
- Доказать формулу в натуральном исчислении предикатов.
- Каждая из задач 5-7 оценивается в 3 балла и состоит из трёх частей:
- Сформулировать утверждение, определение и т.п.
- Ответить на вопрос "на понимание", так или иначе связанный с формулировкой.
- Аргументировать (обосновать) ответ на вопрос.
- Каждая из задач 8-10 оценивается в 4 балла и устроена так:
- Из нескольких предложенных вариантов ответа выбрать правильные (один, несколько или ни одного) и обосновать выбранные ответы.
- Невыбранные ответы обосновывать не нужно.
Контрольная работа
На оценку за экзамен влияет первая контрольная работа. Максимальная техническая оценка за эту работу - 21 балл. В зависимости от технических баллов, набранных за первую контрольную работу, определяется поощрение или штраф к техническим баллам за экзамен:
- Набрано хотя бы 19 баллов: бонус +3 балла;
- Набрано хотя бы 16, но менее 19 баллов: бонус +2 балла;
- Набрано хотя бы 13, но менее 16 баллов: бонус +1 балл;
- Набрано хотя бы 10, но менее 13 баллов: 0 баллов;
- Набрано хотя бы 7, но менее 10 баллов: штраф -1 балл;
- Набрано хотя бы 4, но менее 7 баллов: штраф -2 балла;
- Набрано менее 4 баллов: штраф -3 балла;
- Неявка без уважительной причины: штраф -3 балла;
- Неявка по уважительной причине: 0 баллов.
Премиальные задачи
Общие условия сдачи решений премиальных задач:
- Можно как прислать письменное решение, так и обсудить решение устно. Если прислано письменное решение и к нему есть вопросы, то для ответов на эти вопросы может потребоваться дополнительное устное обсуждение.
- При подготовке решения и во время его сдачи можно пользоваться любыми материалами.
- При сдаче может быть проверено понимание каждой детали предложенного решения - следует быть к этому готовым.
- Решение принимается, когда по нему не остаётся неотвеченных вопросов.
Бонусы за решение задач формулируются для одной учебной группы и распределяются внутри одной группы независимо от другой. Например, "первый" трактуется как "первый в группе 318, а также первый в группе 319/2, а также ...".
Условия задач и статистика принятых решений будут обновляться и доводиться до слушателей по мере чтения курса.
Программа курса
Программа будет обновляться согласно фактически прочитанному материалу
Классические логики
- Логика высказываний: синтаксис, семантика; выполнимость и общезначимость формул. Проблема общезначимости формул логики высказываний.
- Метод семантических таблиц в логике высказываний: семантическая таблица, табличный вывод, теорема о табличном выводе.
- Логика предикатов: синтаксис (термы, формулы, свободные и связанные переменные), семантика (интерпретации, отношение выполнимости).
- Выполнимость и общезначимость формул логики предикатов. Модели. Логическое следование. Теорема о логическом следствии. Проблема общезначимости формул логики предикатов.
- Пример выполнимой формулы логики предикатов, не имеющей конечных моделей.
- Метод семантических таблиц в логике предикатов: семантическая таблица, табличный вывод, теорема о табличной проверке общезначимости, теоремы о корректности и полноте табличного вывода.
- Теорема Лёвенгейма-Сколема. Теорема компактности Мальцева.
- Машины Тьюринга. Теорема Чёрча.
- Равносильные формулы. Теорема о равносильной замене.
Метод резолюций в логике предикатов
- Предварённая нормальная форма. Теорема о предварённой нормальной форме.
- Сколемовская стандартная форма. Алгоритм сколемизации предварённой нормальной формы. Теорема о сколемизации.
- Дизъюнкты. Сведение проблемы общезначимости формул к проблеме невыполнимости систем дизъюнктов.
- Подстановки. Композиция подстановок. Унификатор. Наиболее общий унификатор. Задача унификации выражений логики предикатов.
- Лемма о связке. Алгоритм унификации. Теорема об унификации.
- Правило резолюции. Правило склейки. Резолютивный вывод. Теорема о корректности резолютивного вывода.
- Эрбрановский универсум. Эрбрановский базис. Эрбрановские интерпретации. Теорема об эрбрановских интерпретациях. Теорема Эрбрана.
- Лемма об основных дизъюнктах. Лемма о подъёме. Теорема о полноте резолютивного вывода.
- Метод резолюций: общая схема, применение.
Логические исчисления
- Логические исчисления. Исчисления высказываний и исчисления предикатов. Выводимость и доказуемость формул.
- Натуральное исчисление высказываний. Правило монотонности. Закон исключённого третьего. Правило сечения. Правило полного перебора. Правило приведения к абсурду. Корректность и полнота исчисления.
- Натуральное исчисление предикатов. Корректность и полнота исчисления.
- Исчисление предикатов гильбертовского типа. Теорема Гёделя о полноте (формулировка).
Аксиоматические теории
- Аксиоматические теории первого порядка: основные определения, проблема общезначимости формул в теории.
- Основные свойства аксиоматических теорий: непротиворечивость, элементарность, полнота, разрешимость.
- Определения и выразимость в интерпретациях. Теорема о подстановке определения.
- Формальная арифметика. Теорема Гёделя о неполноте (формулировка и схема доказательства).
- Арифметика Пресбургера, её разрешимость и выразительность.
Неклассические прикладные логики
- Модальные логики. Шкалы и модели Крипке для модальных логик. Эпистемические логики. Темпоральные логики. Логика линейного времени. Логика деревьев вычислений.
- Интуиционистская логика.
- Формальная верификация программ. Модель императивных программ: синтаксис, операционная семантика. Предусловия и постусловия. Полная и частичная корректность программ. Тройки Хоара. Логика Хоара. Корректность вывода в логике Хоара. Слабейшее предусловие. Инвариант цикла.
- Размеченные системы переходов. Моделирование программ системами переходов. Логика деревьев вычислений (CTL): синтаксис, семантика, основные равносильности, применение для спецификации поведения распределённых систем. Задача проверки моделей (model checking) относительно CTL: формулировка, решающий алгоритм.
Рекомендованная литература
Основная литература
- Клини С. Математическая логика. М.:Мир, 1973, 480 с.
- Чень Ч., Ли Р. Математическая логика и автоматическое доказательство теорем. М.:Мир, 1983. 360 с.
- Лавров И.А., Максимова Л.Л. Задачи по теории множеств, математической логике и теории алгоритмов. Москва, "Физико-математическая литература", 1995 г., 250 с.
- Метакидес Г., Нероуд А., Принципы логики и логического программирования. Москва, "Факториал", 1998, 288 с.
- Братко И. Программирование на Прологе для искусственного интеллекта. М.:Мир, 1990, 560 с.
- Набебин А.А. Логика и Пролог в дискретной математике. М., Изд-во МЭИ, 1997.
- Кларк Э.М., Грамберг О., Пелед Д. Верификация моделей программ: model checking. Изд-во МЦНМО, Москва, 2002, 405 с.
Дополнительная литература
- Мендельсон Э. Введение в математическую логику. М.:Наука, 1984. 319 с.
- Верещагин Н.К., Шень А. Языки и исчисления. 2004.
- Успенский В.А., Верещагин Н.К., Плиско В.Е. Вводный курс математической логики. 2004. 128 с.
- Лавров И.А. Математическая логика. Учебное пособие для вузов. М.: Академия, 2006.
- Колмогоров А.Н., Драгалин А.Г. Математическая логика. Серия "Классический университетский учебник". Изд.3, 2006, 240 с.
- Ершов Ю.Л., Палютин Е.А. Математическая логика - М.: 1979.
- Непейвода Н. Н. Прикладная логика. Новосибирск. 2000 г.
- Хоггер К., Введение в логическое программирование. М.:Мир, 1988. 348 с.
- Клоксин У., Меллиш К. Программирование на языке Пролог. М.:Мир, 1987. 336 с.
- Кларк К.Л., Маккейб Ф.Г. Микро-Пролог: введение в логическое программирование. Москва, "Радио и связь". 1987, 311 с.
- Стерлинг Л., Шапиро Э., Искусство программирования на языке ПРОЛОГ. Москва, "Мир", 1990, 235 с.
- Ковальский Р. Логика в решении проблем. М.: Наука, 1990. 277 с.
- Логический подход к искусственному интеллекту (от модальной логики к логике баз данных). М.:Мир, 1998. 495 с.