![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)
Читая в прошедшем семестре курс матлогики, придумывал разные задачки для практики и многие решал (для себя) на Агде. Сейчас сел все это упорядочивать. Обнаружил, что сопоставление с образцом, конечно же, обыгрывает явные элиминаторы по выразительности при записи доказательств, но элиминаторы иногда сопротивляются довольно успешно.
Вот, скажем, исчисление высказываний.
Теперь можно доказывать всякие пропозициональные тавтологии. Для чистой импликации
Для дизъюнкции можно определить правила введения (они, естественно, совпадают с конструкторами)
Аналогично для конъюнкции
Теперь можно писать доказательства тавтологий на двух языках. Например, коммутативность конъюнкции: через сопоставление с образцом
УПРАЖНЕНИЕ 1. Докажите двумя способами коммутативность конъюнкции
Докажем теперь ассоциативность дизъюнкции. Сначала паттерн-матчингом:
УПРАЖНЕНИЕ 2. Докажите двумя способами ассоциативность дизъюнкции в обратном направлении
Теперь можем написать окончательную формулу (с равносильностью, а не с импликациями)
Перейдем к ассоциативности конъюнкции. Первый способ (через сопоставление с образцом), конечно, вне конкуренции
УПРАЖНЕНИЕ 3. Докажите двумя способами ассоциативность конъюнкции в обратном направлении
Исходник можно поглядеть здесь.
Вот, скажем, исчисление высказываний.
Proposition : Set₁ Proposition = Set _⇒_ : Proposition → Proposition → Proposition P ⇒ Q = P → Q data _∨_ (P Q : Proposition) : Proposition where injl : P → P ∨ Q injr : Q → P ∨ Q data _∧_ (P Q : Proposition) : Proposition where _,_ : P → Q → P ∧ Q _⇔_ : Proposition → Proposition → Proposition P ⇔ Q = (P ⇒ Q) ∧ (Q ⇒ P)
Теперь можно доказывать всякие пропозициональные тавтологии. Для чистой импликации
{- комбинатор K -} ⇒-intro : {P Q : Proposition} → P ⇒ Q ⇒ P ⇒-intro p q = p {- комбинатор S -} infixl 8 _ˢ_ _ˢ_ : {P Q R : Proposition} → (P ⇒ Q ⇒ R) ⇒ (P ⇒ Q) ⇒ P ⇒ R _ˢ_ p⇒q⇒r p⇒q p = p⇒q⇒r p (p⇒q p) {- комбинатор B, известный также как композитор -} infixr 9 _∘_ _∘_ : {P Q R : Proposition} → (Q ⇒ R) ⇒ (P ⇒ Q) ⇒ P ⇒ R _∘_ q⇒r p⇒q p = q⇒r (p⇒q p)
Для дизъюнкции можно определить правила введения (они, естественно, совпадают с конструкторами)
∨-intro₁ : {P Q : Proposition} → P ⇒ P ∨ Q ∨-intro₁ = injl ∨-intro₂ : {P Q : Proposition} → Q ⇒ P ∨ Q ∨-intro₂ = injrи правило удаления (элиминатор)
∨-elim : {P Q R : Proposition} → (P ⇒ R) ⇒ (Q ⇒ R) ⇒ P ∨ Q ⇒ R ∨-elim p⇒r q⇒r (injl p) = p⇒r p ∨-elim p⇒r q⇒r (injr q) = q⇒r qЭти правила соответствуют аксиомам гильбертовского исчисления высказываний, сопоставление с образцом дает нам инструмент для доказательства элиминаторов.
Аналогично для конъюнкции
∧-intro : {P Q : Proposition} → P ⇒ Q ⇒ P ∧ Q ∧-intro = _,_ ∧-elim₁ : {P Q : Proposition} → P ∧ Q ⇒ P ∧-elim₁ (p , _) = p ∧-elim₂ : {P Q : Proposition} → P ∧ Q ⇒ Q ∧-elim₂ (_ , q) = q(Элиминаторы эти на менее высоколобом языке носят названия fst и snd.)
Теперь можно писать доказательства тавтологий на двух языках. Например, коммутативность конъюнкции: через сопоставление с образцом
∨-comm : {P Q : Proposition} → P ∨ Q ⇒ Q ∨ P ∨-comm (injl p) = injr p ∨-comm (injr q) = injl qи через интродьюсеры-элиминаторы
∨-comm' : {P Q : Proposition} → P ∨ Q ⇒ Q ∨ P ∨-comm' = ∨-elim ∨-intro₂ ∨-intro₁
УПРАЖНЕНИЕ 1. Докажите двумя способами коммутативность конъюнкции
∧-comm : {P Q : Proposition} → P ∧ Q ⇒ Q ∧ P ∧-comm = {!!}
Докажем теперь ассоциативность дизъюнкции. Сначала паттерн-матчингом:
∨-ass₁ : {P Q R : Proposition} → (P ∨ Q) ∨ R ⇒ P ∨ (Q ∨ R) ∨-ass₁ (injl (injl p)) = injl p ∨-ass₁ (injl (injr q)) = injr (injl q) ∨-ass₁ (injr r) = injr (injr r)Перепишем теперь все это на языке интродьюсеров-элиминаторов
∨-ass₁' : {P Q R : Proposition} → (P ∨ Q) ∨ R ⇒ P ∨ (Q ∨ R) ∨-ass₁' = ∨-elim -- расщепляем (P ∨ Q) или R (∨-elim -- расщепляем P или Q ∨-intro₁ -- если P, то положить влево (∨-intro₂ ∘ ∨-intro₁) -- если Q, то положить вправо, влево ) (∨-intro₂ ∘ ∨-intro₂) -- если R, то положить вправо, вправо
УПРАЖНЕНИЕ 2. Докажите двумя способами ассоциативность дизъюнкции в обратном направлении
∨-ass₂ : {P Q R : Proposition} → P ∨ (Q ∨ R) ⇒ (P ∨ Q) ∨ R ∨-ass₂ = {!!}
Теперь можем написать окончательную формулу (с равносильностью, а не с импликациями)
∨-ass : {P Q R : Proposition} → (P ∨ Q) ∨ R ⇔ P ∨ (Q ∨ R) ∨-ass = ∨-ass₁ , ∨-ass₂
Перейдем к ассоциативности конъюнкции. Первый способ (через сопоставление с образцом), конечно, вне конкуренции
∧-ass₁ : {P Q R : Proposition} → (P ∧ Q) ∧ R ⇒ P ∧ (Q ∧ R) ∧-ass₁ ((p , q) , r) = p , (q , r)Второй способ требует нудного использования элиминаторов fst (то есть ∧-elim₁) и snd (∧-elim₂)
∧-ass₁' : {P Q R : Proposition} → (P ∧ Q) ∧ R ⇒ P ∧ (Q ∧ R) ∧-ass₁' x = ∧-intro (∧-elim₁ (∧-elim₁ x)) (∧-intro (∧-elim₂ (∧-elim₁ x)) (∧-elim₂ x) )Можно переписать это в бесточечном стиле, используя комбинаторы B и S (то есть доказанные выше теоремы)
∧-ass₁'' : {P Q R : Proposition} → (P ∧ Q) ∧ R ⇒ P ∧ (Q ∧ R) ∧-ass₁'' = ∧-intro ∘ ∧-elim₁ ∘ ∧-elim₁ ˢ (∧-intro ∘ ∧-elim₂ ∘ ∧-elim₁ ˢ ∧-elim₂)
УПРАЖНЕНИЕ 3. Докажите двумя способами ассоциативность конъюнкции в обратном направлении
∧-ass₂ : {P Q R : Proposition} → P ∧ (Q ∧ R) ⇒ (P ∧ Q) ∧ R ∧-ass₂ = {!!}
Исходник можно поглядеть здесь.
no subject
Date: 2014-01-06 09:30 am (UTC)no subject
Date: 2014-01-06 09:52 am (UTC)no subject
Date: 2014-01-06 10:24 am (UTC)no subject
Date: 2014-01-06 12:55 pm (UTC)no subject
Date: 2014-01-06 02:14 pm (UTC)no subject
Date: 2014-01-21 09:32 am (UTC)no subject
Date: 2014-01-06 02:59 pm (UTC)А потом сделайте два доказательства равности тех двух доказательств и постройте гомотопию между этими двумя равенствами...
no subject
Date: 2014-01-06 04:26 pm (UTC)И никаких гомотопий :)
no subject
Date: 2014-01-08 12:23 pm (UTC)? (кроме формы конструктора, конечно; я имею в виду именно reasoning, который Агда сможет или не сможет выполнять? Или с этой т.з. совершенно всё равно?)
no subject
Date: 2014-01-08 05:17 pm (UTC):)
Конфлюэнтность же никто не отменял. Тайпчекер приводит то, что требуется уравнять, к нормальной форме, тупо пользуясь definitional equality там, где это возможно, и сравнивает. В первом случае от делает это в трех местах
, а во втором в двух. Но нормальная форма единственна (suc x), поэтому разницы нет.
no subject
Date: 2014-01-08 11:19 pm (UTC)no subject
Date: 2014-01-08 11:50 pm (UTC)и
Хотя в первом случае в правой части можно вместо точного выражения, которое нам дает Агси (C-c C-a), написать
(Это справа вообще всегда можно делать с refl, потому что понятно, что туда пропишется NF из типа.)
no subject
Date: 2014-01-08 11:56 pm (UTC)то сообщения об ошибках для uip и uip' будут разные. Надо бы в исходники посмотреть, что там как.
no subject
Date: 2014-01-13 12:56 pm (UTC)https://lists.chalmers.se/pipermail/agda/2014/006347.html
no subject
Date: 2014-01-08 10:42 am (UTC)no subject
Date: 2014-01-08 11:16 am (UTC)no subject
Date: 2014-05-18 01:05 am (UTC)