lean4-htt/tests/lean/run/setStructInstNotation.lean
Matthew Robert Ballard b54a9ec9b9
feat: swap arguments to Membership.mem (#5020)
We swap the arguments for `Membership.mem` so that when proceeded by a
`SetLike` coercion, as is often the case in Mathlib, the resulting
expression is recognized as eta expanded and reduce for many
computations. The most beneficial outcome is that the discrimination
tree keys for instances and simp lemmas concerning subsets become more
robust resulting in more efficient searches.

Closes `RFC` #4932

---------

Co-authored-by: Kim Morrison <kim@tqft.net>
Co-authored-by: Henrik Böving <hargonix@gmail.com>
2024-08-26 12:35:47 +00:00

75 lines
1.3 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

structure Foo where
a : Nat
b : Nat
def bla (x : Foo) : IO Unit := do
let { a, b } := x
def Set (α : Type u) := α → Prop
def setOf {α : Type u} (p : α → Prop) : Set α :=
p
namespace Set
protected def mem (s : Set α) (a : α) :=
s a
instance : Membership α (Set α) :=
⟨Set.mem⟩
protected def subset (s₁ s₂ : Set α) :=
∀ {a}, a ∈ s₁ → a ∈ s₂
instance : EmptyCollection (Set α) :=
⟨λ a => false⟩
protected def insert (a : α) (s : Set α) : Set α :=
fun b => b = a b ∈ s
protected def singleton (a : α) : Set α :=
fun b => b = a
instance : Insert α (Set α) := ⟨Set.insert⟩
instance : Singleton α (Set α) := ⟨Set.singleton⟩
set_option pp.mvars false in
/-- info: {1, 2} : ?_ -/
#guard_msgs in
#check { 1, 2 }
end Set
def f1 (a b : Nat) : Set Nat :=
{ a, b }
def f2 (a b : Nat) : Foo :=
{ a, b }
def f3 (a b : Nat) : Set Nat :=
{ a, b }
/-- info: f3 (a b : Nat) : Set Nat -/
#guard_msgs in
#check f3
def f4 (a b : α) : Set α :=
{ a, b }
/-- info: @f4 : {α : Type u_1} → αα → Set α -/
#guard_msgs in
#check @f4
def f5 (a b : Nat) :=
{ a, b : Foo }
def boo1 (x : Foo) : IO Unit :=
let { a, b } := x
pure ()
def boo2 (x : Foo) : IO Unit := do
let { a, b } := x
pure ()
def boo3 (x : Nat → IO Foo) : IO Nat := do
let { a, b } ← x 0
return a + b