Skip to content

Commit

Permalink
Add all⊆concat (#2513)
Browse files Browse the repository at this point in the history
* Fixes #2509

* remove parentheses
  • Loading branch information
jamesmckinna authored Dec 9, 2024
1 parent 1fdafef commit 6633371
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 3 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -315,6 +315,11 @@ Additions to existing modules
([] , [])
```

* In `Data.List.Relation.Unary.All.Properties`:
```agda
all⊆concat : (xss : List (List A)) → All (Sublist._⊆ concat xss) xss
```

* In `Data.List.Relation.Unary.Any.Properties`:
```agda
concatMap⁺ : Any (Any P ∘ f) xs → Any P (concatMap f xs)
Expand Down
14 changes: 11 additions & 3 deletions src/Data/List/Relation/Unary/All/Properties.agda
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,10 @@ import Data.List.Membership.Setoid as SetoidMembership
import Data.List.Properties as List
import Data.List.Relation.Binary.Equality.Setoid as ≋
open import Data.List.Relation.Binary.Pointwise.Base using (Pointwise; []; _∷_)
open import Data.List.Relation.Binary.Subset.Propositional using (_⊆_)
import Data.List.Relation.Binary.Sublist.Propositional as Sublist
import Data.List.Relation.Binary.Sublist.Propositional.Properties
as Sublist
import Data.List.Relation.Binary.Subset.Propositional as Subset
open import Data.List.Relation.Unary.All as All using
( All; []; _∷_; lookup; updateAt
; _[_]=_; here; there
Expand Down Expand Up @@ -385,6 +388,11 @@ concat⁻ : ∀ {xss} → All P (concat xss) → All (All P) xss
concat⁻ {xss = []} [] = []
concat⁻ {xss = xs ∷ xss} pxs = ++⁻ˡ xs pxs ∷ concat⁻ (++⁻ʳ xs pxs)

all⊆concat : (xss : List (List A)) All (Sublist._⊆ concat xss) xss
all⊆concat [] = []
all⊆concat (xs ∷ xss) =
Sublist.++⁺ʳ (concat xss) Sublist.⊆-refl ∷ All.map (Sublist.++⁺ˡ xs) (all⊆concat xss)

------------------------------------------------------------------------
-- snoc

Expand Down Expand Up @@ -675,10 +683,10 @@ module _ (p : A → Bool) where
------------------------------------------------------------------------
-- All is anti-monotone.

anti-mono : xs ⊆ ys All P ys All P xs
anti-mono : xs Subset.⊆ ys All P ys All P xs
anti-mono xs⊆ys pys = All.tabulate (lookup pys ∘ xs⊆ys)

all-anti-mono : (p : A Bool) xs ⊆ ys T (all p ys) T (all p xs)
all-anti-mono : (p : A Bool) xs Subset.⊆ ys T (all p ys) T (all p xs)
all-anti-mono p xs⊆ys = all⁻ p ∘ anti-mono xs⊆ys ∘ all⁺ p _

------------------------------------------------------------------------
Expand Down

0 comments on commit 6633371

Please sign in to comment.