私はこの問題に対してしばらくの間頭を打っていました。従属フィールドを持つレコードタイプがあり、レコード変換の等価性を証明したいと思います。私は私の問題の要点を小さな例にしてみようとしました。従属レコードタイプの等価性
module Bar where
open import Data.Nat
open import Relation.Binary.PropositionalEquality as PE
open import Relation.Binary.HeterogeneousEquality as HE
record Rec : Set where
field val : ℕ
inc : {n : ℕ} -> ℕ
succ : inc {0} ≡ val
open Rec
succ
財産状態、他の2つのフィールド間の関係:そのinc {0}
戻りval
フィールド間の依存関係を持って、次のレコード型Rec
を、考えてみましょう。次の関数incR
は、それらの相互作用を保持固定値m
によって値とインクリメンタをインクリメントRec
トランス定義:ここ
succPrf : {x : Rec} {m : ℕ} -> (inc x {0} + m) ≡ val x + m
succPrf {x} {m} rewrite (PE.cong (\x -> x + m) (succ x)) = refl
incR : Rec -> ℕ -> Rec
incR x m = record {
val = val x + m
; inc = λ{n} -> inc x {n} + m
; succ = succPrf {x} {m} }
をsuccPrf
inc
/val
関係が成り立つことの証明を与えます。
は今、私は次のことを証明したい:
incR0 : forall {x : Rec} -> incR x 0 ≡ x
incR0 {x} = {!!}
これは、レコード内の依存関係のが非常に困難であることが判明しました。
私は戻って一緒にそれを置くために合同を使用する目的で、フィールド上の個々の等式にそれを破壊しようとした:私がかなり遠くに得ることができるようだ:
postulate
ext : {A : Set} {B : Set}
{f g : {a : A} -> B} ->
(forall {n : A} -> f {n} ≡ g {n})
-> (λ {n : A} -> f {n}) ≡ (λ {n : A} -> g {n})
-- Trivial, but for tersity just postulated
runit : {n : ℕ} -> n + 0 ≡ n
incRVal : forall {x : Rec} -> val (incR x 0) ≡ val x
incRVal {x} rewrite runit {val x} = refl
incRinc : forall {x : Rec} -> (λ{n : ℕ} -> inc (incR x 0) {n}) ≡ (λ{n : ℕ} -> inc x {n})
incRinc {x} rewrite ext (λ{n : ℕ} -> runit {inc x {n}}) = refl
そしてsucc
フィールド上の
succIncR : {x : Rec} -> (inc (incR x 0) {0} ≡ val (incR x 0) + 0)
≡ (inc x {0} ≡ val x)
succIncR {x} rewrite runit {inc x {0}} | runit {val x} | incRVal {x}
= refl
incRsucc : forall {x : Rec} -> succ (incR x 0) ≅ succ x
incRsucc {x} rewrite succIncR {x} | succ x | runit {val x}
= HE.reflexive refl
しかし、私はこれらを十分に組み合わせることに苦労しています。私は実際には、incRinc
とincRsucc
を一度につなげることができるように、Piタイプのためにいくつかの合同が必要ですが、これを構築することに失敗しました。私は木の木が見えないほどのところにいるので、私はそれが何を考えているのか分かりました。私はここで簡単な技術が欠けていますか?