Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor Data.List.Relation.Binary.Permutation.* #2317

Draft
wants to merge 65 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 41 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
fff325f
complete refactoring to isolate dependency on `Homogeneous`
jamesmckinna Mar 10, 2024
f971440
further refactoring: `Setoid` instantiates `Homogeneous`; decouples `…
jamesmckinna Mar 10, 2024
75747e3
use smart transitivity
jamesmckinna Mar 10, 2024
736e1de
refactor the `CommutativeMonoid` property
jamesmckinna Mar 10, 2024
18cb5c2
refactor the `PermutationReasoning` module
jamesmckinna Mar 10, 2024
7749cbf
refactored `Propositional` through improved API for `Homogeneous`
jamesmckinna Mar 10, 2024
de26a1e
tweak imports
jamesmckinna Mar 11, 2024
a236180
refactor `setoid` and `Reasoning`
jamesmckinna Mar 11, 2024
05fde1e
remove last explicit dependency on `Homogeneous`
jamesmckinna Mar 11, 2024
d4e86d9
added length preservation
jamesmckinna Mar 11, 2024
629d3f3
added length preservation
jamesmckinna Mar 11, 2024
c01559f
reverted changes
jamesmckinna Mar 11, 2024
747666f
backport from `Propositional`
jamesmckinna Mar 12, 2024
985686b
almost all the way there
jamesmckinna Mar 12, 2024
865a962
one(inductive) bug to fix; one cosmetic fix
jamesmckinna Mar 12, 2024
159f6d6
two cosmetic knock-on fixes
jamesmckinna Mar 12, 2024
75a8414
tidy up refactoring
jamesmckinna Mar 12, 2024
89c9020
more level polymorphism in `map⁺`
jamesmckinna Mar 12, 2024
3e5230d
fixed `map⁺`
jamesmckinna Mar 12, 2024
64c26b4
updated `README`; need to refactor `PermutationReasoning` syntax
jamesmckinna Mar 12, 2024
7642add
BUG: `README`; need to refactor `PermutationReasoning` syntax?
jamesmckinna Mar 12, 2024
cbbda53
uncommitted changes
jamesmckinna Mar 12, 2024
55b4ff5
improved use of `variable`s
jamesmckinna Mar 12, 2024
7b2c46d
fixed `import`s to reflect `public` export of the relation in `Propos…
jamesmckinna Mar 12, 2024
4e2fb04
tightened the paramterisation of `↭-shift`
jamesmckinna Mar 12, 2024
e652a80
knock-on viscosity
jamesmckinna Mar 12, 2024
542caf4
knock-on viscosity
jamesmckinna Mar 12, 2024
8bda5d6
commented out bug in reasoning
jamesmckinna Mar 12, 2024
331220d
more properties needing specialised
jamesmckinna Mar 12, 2024
79e0c8f
allow unsolved metas; nearly there!
jamesmckinna Mar 12, 2024
439ef19
involutive properties of symmetry, at all levels
jamesmckinna Mar 12, 2024
7859dd2
restores `--safe` while I ponder
jamesmckinna Mar 12, 2024
6a7088f
use the import of equality primitives
jamesmckinna Mar 13, 2024
53e7eb4
refactored construction
jamesmckinna Mar 13, 2024
c7e606c
interim commit: one goal remaining!
jamesmckinna Mar 13, 2024
ec9d0f8
`Homogeneous` safe!
jamesmckinna Mar 13, 2024
0c0828e
`Setoid` safe!
jamesmckinna Mar 13, 2024
ca76072
`Propositional` safe! `equality` proofs reverted in favour of local d…
jamesmckinna Mar 13, 2024
5ab893d
tidy up `BagAndSetEquality`
jamesmckinna Mar 13, 2024
afe32c7
typo
jamesmckinna Mar 13, 2024
f98f043
bracketing fixes the bug; but surely that's not the point?
jamesmckinna Mar 13, 2024
eb904ff
cosmetics
jamesmckinna Mar 14, 2024
3856163
removed any need for `steps` or `Acc`-induction
jamesmckinna Mar 14, 2024
91cc337
knock-on changes from improvements to `Homogeneous`
jamesmckinna Mar 14, 2024
bf14b4d
tidy up `BagAndSetEquality`
jamesmckinna Mar 14, 2024
980909f
NB weird `Reasoning` problem/bug
jamesmckinna Mar 15, 2024
1d69be6
remove dependency on well-founded induction
jamesmckinna Mar 15, 2024
be52c13
further refactoring warm-ups for #1354
jamesmckinna Mar 22, 2024
dd33a4e
knock-on
jamesmckinna Mar 22, 2024
8234cfd
tidying up ahead of module reorganisation
jamesmckinna Mar 22, 2024
487cbce
more tidying up ahead of module reorganisation
jamesmckinna Mar 22, 2024
c3fc49a
more tidying up ahead of module reorganisation
jamesmckinna Mar 22, 2024
054a770
more tidying up ahead of module reorganisation
jamesmckinna Mar 22, 2024
197e483
further reorganisation
jamesmckinna Mar 26, 2024
9893dc7
module restructuring
jamesmckinna Mar 26, 2024
c9f6b8f
typechecking proofs of involutive symmetry fails to terminate after m…
jamesmckinna Mar 26, 2024
b48e06f
factored out the higher-dimensional properties
jamesmckinna Mar 26, 2024
b4fbbf9
localised proofs of the higher-dimensional properties
jamesmckinna Mar 26, 2024
eb0d50e
drastic pruning of `import`s after refactoring
jamesmckinna Mar 26, 2024
014867d
rearrangement of binding prefixes after refactoring
jamesmckinna Mar 26, 2024
9aafdf1
tightened `import`s after refactoring
jamesmckinna Mar 26, 2024
dd451bc
follow through
jamesmckinna Mar 26, 2024
55276e8
fix up parametrisation (first go)
jamesmckinna Mar 26, 2024
ba6b378
reverted use of `↭-shift`
jamesmckinna Mar 27, 2024
a07557c
reverted use of `↭--refl` and `↭--prep`
jamesmckinna Mar 27, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 18 additions & 7 deletions doc/README/Data/List/Relation/Binary/Permutation.agda
Original file line number Diff line number Diff line change
Expand Up @@ -26,18 +26,18 @@ open import Relation.Binary.PropositionalEquality
open import Data.List.Relation.Binary.Permutation.Propositional

-- The permutation relation is written as `_↭_` and has four
-- constructors. The first `refl` says that a list is always
-- a permutation of itself, the second `prep` says that if the
-- *smart* constructors. The first `↭-refl` says that a list is
-- a permutation of itself, the second `↭-prep` says that if the
-- heads of the lists are the same they can be skipped, the third
-- `swap` says that the first two elements of the lists can be
-- swapped and the fourth `trans` says that permutation proofs
-- `↭-swap` says that the first two elements of the lists can be
-- swapped and the fourth `↭-trans` says that permutation proofs
-- can be chained transitively.

-- For example a proof that two lists are a permutation of one
-- another can be written as follows:

lem₁ : 1 ∷ 2 ∷ 3 ∷ [] ↭ 3 ∷ 1 ∷ 2 ∷ []
lem₁ = trans (prep 1 (swap 2 3 refl)) (swap 1 3 refl)
lem₁ = ↭-trans (↭-prep 1 (↭-swap 2 3 ↭-refl)) (↭-swap 1 3 ↭-refl)

-- In practice it is difficult to parse the constructors in the
-- proof above and hence understand why it holds. The
Expand All @@ -48,10 +48,21 @@ open PermutationReasoning

lem₂ : 1 ∷ 2 ∷ 3 ∷ [] ↭ 3 ∷ 1 ∷ 2 ∷ []
lem₂ = begin
1 ∷ 2 ∷ 3 ∷ [] ↭⟨ prep 1 (swap 2 3 refl) ⟩
1 ∷ 3 ∷ 2 ∷ [] ↭⟨ swap 1 3 refl ⟩
1 ∷ 2 ∷ 3 ∷ [] ↭⟨ ↭-prep 1 (↭-swap 2 3 ↭-refl) ⟩
1 ∷ 3 ∷ 2 ∷ [] ↭⟨ ↭-swap 1 3 ↭-refl ⟩
3 ∷ 1 ∷ 2 ∷ [] ∎

-- In practice it is further useful to extend `PermutationReasoning`
-- with specialised combinators `<⟨_⟩` and `<<⟨_⟩` to support the
-- distinguished use of the `↭-prep ` and `↭-swap` steps, allowing
-- the above proof to be recast in the following form:

lem₂ᵣ : 1 ∷ 2 ∷ 3 ∷ [] ↭ 3 ∷ 1 ∷ 2 ∷ []
lem₂ᵣ = begin
1 ∷ (2 ∷ (3 ∷ [])) <⟨ ↭-swap 2 3 ↭-refl ⟩
1 ∷ 3 ∷ (2 ∷ []) <<⟨ ↭-refl ⟩
3 ∷ 1 ∷ (2 ∷ []) ∎

-- As might be expected, properties of the permutation relation may be
-- found in:

Expand Down
77 changes: 33 additions & 44 deletions src/Data/List/Relation/Binary/BagAndSetEquality.agda
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ open import Data.List.Membership.Propositional using (_∈_)
open import Data.List.Membership.Propositional.Properties
open import Data.List.Relation.Binary.Subset.Propositional.Properties
using (⊆-preorder)
open import Data.List.Relation.Binary.Permutation.Propositional
open import Data.List.Relation.Binary.Permutation.Propositional.Properties
open import Data.Product.Base as Prod hiding (map)
import Data.Product.Function.Dependent.Propositional as Σ
Expand All @@ -31,7 +30,7 @@ open import Data.Sum.Properties hiding (map-cong)
open import Data.Sum.Function.Propositional using (_⊎-cong_)
open import Data.Unit.Polymorphic.Base
open import Function.Base
open import Function.Bundles using (_↔_; Inverse; Equivalence; mk↔ₛ′; mk⇔)
open import Function.Bundles using (_↔_; Inverse; Equivalence; mk↔ₛ′; mk↔; mk⇔)
open import Function.Related.Propositional as Related
using (↔⇒; ⌊_⌋; ⌊_⌋→; ⇒→; K-refl; SK-sym)
open import Function.Related.TypeIsomorphisms
Expand Down Expand Up @@ -538,21 +537,18 @@ drop-cons {x = x} {xs} {ys} x∷xs≈x∷ys =

lemma : ∀ {xs ys} (inv : x ∷ xs ∼[ bag ] x ∷ ys) {z} →
Well-behaved (Inverse.to (∼→⊎↔⊎ inv {z}))
lemma {xs} inv {b = z∈xs} {a = p} {a′ = q} hyp₁ hyp₂ with
zero ≡⟨⟩
index-of {xs = x ∷ xs} (here p) ≡⟨⟩
index-of {xs = x ∷ xs} (to (∷↔ _) $ inj₁ p) ≡⟨ ≡.cong (index-of ∘ (to (∷↔ (_ ≡_)))) $ ≡.sym $
to-from (∼→⊎↔⊎ inv) {x = inj₁ p} hyp₂ ⟩
lemma {xs} inv {b = z∈xs} {a = p} {a′ = q} hyp₁ hyp₂ with begin
zero ≡⟨⟩
index-of {xs = x ∷ xs} (here p) ≡⟨⟩
index-of {xs = x ∷ xs} (to (∷↔ _) $ inj₁ p) ≡⟨ ≡.cong (index-of ∘ (to (∷↔ (_ ≡_)))) $ ≡.sym $ to-from (∼→⊎↔⊎ inv) {x = inj₁ p} hyp₂ ⟩
index-of {xs = x ∷ xs} (to (∷↔ _) $ (from (∼→⊎↔⊎ inv) $ inj₁ q)) ≡⟨ ≡.cong index-of $
strictlyInverseˡ (∷↔ _) (from inv (here q)) ⟩
index-of {xs = x ∷ xs} (to (SK-sym inv) $ here q) ≡⟨ index-equality-preserved (SK-sym inv) refl ⟩
index-of {xs = x ∷ xs} (to (SK-sym inv) $ here p) ≡⟨ ≡.cong index-of $ ≡.sym $
strictlyInverseˡ (∷↔ _) (from inv (here p)) ⟩
index-of {xs = x ∷ xs} (to (∷↔ _) (from (∼→⊎↔⊎ inv) $ inj₁ p)) ≡⟨ ≡.cong (index-of ∘ (to (∷↔ (_ ≡_)))) $
to-from (∼→⊎↔⊎ inv) {x = inj₂ z∈xs} hyp₁ ⟩
index-of {xs = x ∷ xs} (to (∷↔ _) $ inj₂ z∈xs) ≡⟨⟩
index-of {xs = x ∷ xs} (there z∈xs) ≡⟨⟩
suc (index-of {xs = xs} z∈xs) ∎
index-of {xs = x ∷ xs} (to (SK-sym inv) $ here q) ≡⟨ index-equality-preserved (SK-sym inv) refl ⟩
index-of {xs = x ∷ xs} (to (SK-sym inv) $ here p) ≡⟨ ≡.cong index-of $ ≡.sym $ strictlyInverseˡ (∷↔ _) (from inv (here p)) ⟩
index-of {xs = x ∷ xs} (to (∷↔ _) (from (∼→⊎↔⊎ inv) $ inj₁ p)) ≡⟨ ≡.cong (index-of ∘ (to (∷↔ (_ ≡_)))) $ to-from (∼→⊎↔⊎ inv) {x = inj₂ z∈xs} hyp₁ ⟩
index-of {xs = x ∷ xs} (to (∷↔ _) $ inj₂ z∈xs) ≡⟨⟩
index-of {xs = x ∷ xs} (there z∈xs) ≡⟨⟩
suc (index-of {xs = xs} z∈xs) ∎
where
open Inverse
open ≡-Reasoning
Expand All @@ -562,38 +558,31 @@ drop-cons {x = x} {xs} {ys} x∷xs≈x∷ys =
-- Relationships to other relations

↭⇒∼bag : _↭_ {A = A} ⇒ _∼[ bag ]_
↭⇒∼bag {A = A} xs↭ys {v} = mk↔ₛ′ (to xs↭ys) (from xs↭ys) (to∘from xs↭ys) (from∘to xs↭ys)
↭⇒∼bag {A = A} xs↭ys {v} = mk↔ (from∘to xs↭ys , to∘from xs↭ys)
--mk↔ₛ′ (to xs↭ys) (from xs↭ys) (to∘from xs↭ys) (from∘to xs↭ys)
where
to : ∀ {xs ys} → xs ↭ ys → v ∈ xs → v ∈ ys
to xs↭ys = Any-resp-↭ {A = A} xs↭ys

from : ∀ {xs ys} → xs ↭ ys → v ∈ ys → v ∈ xs
from xs↭ys = Any-resp-↭ (↭-sym xs↭ys)

from∘to : ∀ {xs ys} (p : xs ↭ ys) (q : v ∈ xs) → from p (to p q) ≡ q
from∘to refl v∈xs = refl
from∘to (prep _ _) (here refl) = refl
from∘to (prep _ p) (there v∈xs) = ≡.cong there (from∘to p v∈xs)
from∘to (swap x y p) (here refl) = refl
from∘to (swap x y p) (there (here refl)) = refl
from∘to (swap x y p) (there (there v∈xs)) = ≡.cong (there ∘ there) (from∘to p v∈xs)
from∘to (trans p₁ p₂) v∈xs
rewrite from∘to p₂ (Any-resp-↭ p₁ v∈xs)
| from∘to p₁ v∈xs = refl

to∘from : ∀ {xs ys} (p : xs ↭ ys) (q : v ∈ ys) → to p (from p q) ≡ q
to∘from p with from∘to (↭-sym p)
... | res rewrite ↭-sym-involutive p = res
to : xs ↭ ys → v ∈ xs → v ∈ ys
to = ∈-resp-↭

from : xs ↭ ys → v ∈ ys → v ∈ xs
from = ∈-resp-↭ ∘ ↭-sym

from∘to : (p : xs ↭ ys) {ix : v ∈ xs} {iy : v ∈ ys} →
ix ≡ from p iy → to p ix ≡ iy
from∘to = ∈-resp-↭-sym⁻¹

to∘from : (p : ys ↭ xs) {iy : v ∈ ys} {ix : v ∈ xs} →
ix ≡ to p iy → from p ix ≡ iy
to∘from = ∈-resp-↭-sym

∼bag⇒↭ : _∼[ bag ]_ ⇒ _↭_ {A = A}
∼bag⇒↭ {A = A} {[]} eq with empty-unique (↔-sym eq)
... | refl = refl
∼bag⇒↭ {A = A} {x ∷ xs} eq with ∈-∃++ (Inverse.to (eq {x}) (here ≡.refl))
... | zs₁ , zs₂ , p rewrite p = begin
x ∷ xs <⟨ ∼bag⇒↭ (drop-cons (↔-trans eq (comm zs₁ (x ∷ zs₂)))) ⟩
x ∷ (zs₂ ++ zs₁) <⟨ ++-comm zs₂ zs₁ ⟩
x ∷ (zs₁ ++ zs₂) ↭⟨ shift x zs₁ zs₂ ⟨
zs₁ ++ x ∷ zs₂ ∎
∼bag⇒↭ {A = A} {[]} eq with refl ← empty-unique (↔-sym eq) = ↭-refl
∼bag⇒↭ {A = A} {x ∷ xs} eq
with zs₁ , zs₂ , refl ← ∈-∃++ (Inverse.to (eq {x}) (here ≡.refl)) = begin
x ∷ xs <⟨ ∼bag⇒↭ (drop-cons (↔-trans eq (comm zs₁ (x ∷ zs₂)))) ⟩
x ∷ (zs₂ ++ zs₁) <⟨ ++-comm zs₂ zs₁ ⟩
x ∷ (zs₁ ++ zs₂) ↭⟨ ↭-shift zs₁ ⟨
zs₁ ++ x ∷ zs₂ ∎
where
open CommutativeMonoid (commutativeMonoid bag A)
open PermutationReasoning
4 changes: 2 additions & 2 deletions src/Data/List/Relation/Binary/Equality/Propositional.agda
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ open import Relation.Binary.Core using (_⇒_)

module Data.List.Relation.Binary.Equality.Propositional {a} {A : Set a} where

open import Data.List.Base
import Data.List.Base as List
import Data.List.Relation.Binary.Equality.Setoid as SetoidEquality
open import Relation.Binary.PropositionalEquality.Core using (_≡_; refl; cong)
import Relation.Binary.PropositionalEquality.Properties as ≡
Expand All @@ -29,7 +29,7 @@ open SetoidEquality (≡.setoid A) public

≋⇒≡ : _≋_ ⇒ _≡_
≋⇒≡ [] = refl
≋⇒≡ (refl ∷ xs≈ys) = cong (_ ∷_) (≋⇒≡ xs≈ys)
≋⇒≡ (refl ∷ xs≈ys) = cong (_ List.∷_) (≋⇒≡ xs≈ys)

≡⇒≋ : _≡_ ⇒ _≋_
≡⇒≋ refl = ≋-refl
Loading
Loading