Это не официальный сайт wikipedia.org 01.01.2023

Lean — Википедия

Leanинструмент интерактивного доказательства теорем. Основан на исчислении конструкций с индуктивными типами. Имеет открытый исходный код, размещенный на GitHub. Проект Lean был запущен Леонардо де Моурой в Microsoft Research в 2013 году[1].

Lean
Логотип программы Lean
Тип Proof assistant
Разработчик Microsoft Research
Написана на C++
Операционная система Cross-platform
Языки интерфейса английский
Первый выпуск 2013; 10 лет назад (2013)
Аппаратная платформа кроссплатформенность
Последняя версия 4.0.0-m4 (23 марта 2022; 10 месяцев назад (2022-03-23))
Лицензия Apache License 2.0
Сайт leanprover.github.io

Lean имеет интерфейс, который отличает его от других интерактивных средств доказательства теорем. Lean может быть скомпилирован на JavaScript и доступен в веб-браузере. Он имеет встроенную поддержку символов Юникода. (Они могут быть набраны с использованием последовательностей, подобных применяемым в системе LaTeX, таких как "\times" для "×".) Lean также имеет обширную поддержку метапрограммирования.

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

Lean привлек внимание математиков Томаса Хейлза и Кевина Базарда. Хейлз использует его для своего проекта «formalabstracts»[2]. Базард использует его для проекта Xena[3] Одна из целей проекта Xena — переписать все теоремы и доказательства в учебной программе по математике для студентов Имперского колледжа Лондона.

В рамках проекта Xena формализовано сложное доказательство из области condensed mathematics[en], развиваемой Петером Шольце[4][5][6].

Примеры кодаПравить

Определение натуральных чисел:

inductive nat : Type
| zero : nat
| succ : nat nat

Определение операции сложения для натуральных чисел:

definition add : nat nat nat
| n zero     := n
| n (succ m) := succ(add n m)

Пример простого доказательства.

theorem and_swap : p q q p :=
    assume h1 : p q,
    h1.right, h1.left

Это же доказательство:

theorem and_swap (p q : Prop) : p q q p :=
begin
    assume h : (p q), -- assume p ∧ q is true
    cases h, -- extract the individual propositions from the conjunction
    split, -- split the goal conjunction into two cases: prove p and prove q separately
    repeat { assumption }
end

См. такжеПравить

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

  1. Lean  (неопр.). Дата обращения: 30 сентября 2021. Архивировано 18 октября 2021 года.
  2. Formal Abstracts
  3. What is the Xena project? | Xena
  4. Kevin Hartnett. Proof Assistant Makes Jump to Big-League Math  (неопр.). Quanta (28 июля 2021). Дата обращения: 1 октября 2021. Архивировано 30 сентября 2021 года.
  5. Davide Castelvecchi. Mathematicians welcome computer-assisted proof in ‘grand unification’ theory // Nature. — 2021. — Vol. 595. — P. 18—19. — doi:10.1038/d41586-021-01627-2.
  6. Completion of the Liquid Tensor Experiment  (неопр.). Lean community blog (15 июля 2022). Дата обращения: 17 июля 2022.

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