Function types of a given heterogeneous arity #
This provides Function.FromTypes
, such that FromTypes ![α, β] τ = α → β → τ
.
Note that it is often preferable to use ((i : Fin n) → p i) → τ
in place of FromTypes p τ
.
Main definitions #
Function.FromTypes p τ
:n
-ary functionp 0 → p 1 → ... → p (n - 1) → β
.
The type of n
-ary functions p 0 → p 1 → ... → p (n - 1) → τ
.
Equations
- Function.FromTypes x_3 x✝ = x✝
- Function.FromTypes p x✝ = (Matrix.vecHead p → Function.FromTypes (Matrix.vecTail p) x✝)
Instances For
theorem
Function.fromTypes_succ
{n : ℕ}
(p : Fin (n + 1) → Type u)
(τ : Type u)
:
FromTypes p τ = (Matrix.vecHead p → FromTypes (Matrix.vecTail p) τ)
The definitional equality between 0
-ary heterogeneous functions into τ
and τ
.
Equations
Instances For
@[simp]
theorem
Function.fromTypes_zero_equiv_symm_apply
(p : Fin 0 → Type u)
(τ : Type u)
(a : FromTypes p τ)
:
(fromTypes_zero_equiv p τ).symm a = a
@[simp]
theorem
Function.fromTypes_zero_equiv_apply
(p : Fin 0 → Type u)
(τ : Type u)
(a : FromTypes p τ)
:
(fromTypes_zero_equiv p τ) a = a
The definitional equality between ![]
-ary heterogeneous functions into τ
and τ
.
Equations
Instances For
@[simp]
theorem
Function.fromTypes_nil_equiv_symm_apply
(τ : Type u)
(a : FromTypes ![] τ)
:
(fromTypes_nil_equiv τ).symm a = a
@[simp]
theorem
Function.fromTypes_nil_equiv_apply
(τ : Type u)
(a : FromTypes ![] τ)
:
(fromTypes_nil_equiv τ) a = a
def
Function.fromTypes_succ_equiv
{n : ℕ}
(p : Fin (n + 1) → Type u)
(τ : Type u)
:
FromTypes p τ ≃ (Matrix.vecHead p → FromTypes (Matrix.vecTail p) τ)
The definitional equality between p
-ary heterogeneous functions into τ
and function from vecHead p
to (vecTail p)
-ary heterogeneous functions into τ
.
Equations
Instances For
@[simp]
theorem
Function.fromTypes_succ_equiv_apply
{n : ℕ}
(p : Fin (n + 1) → Type u)
(τ : Type u)
(a : FromTypes p τ)
:
(fromTypes_succ_equiv p τ) a = a
@[simp]
theorem
Function.fromTypes_succ_equiv_symm_apply
{n : ℕ}
(p : Fin (n + 1) → Type u)
(τ : Type u)
(a : FromTypes p τ)
:
(fromTypes_succ_equiv p τ).symm a = a
def
Function.fromTypes_cons_equiv
{n : ℕ}
(α : Type u)
(p : Fin n → Type u)
(τ : Type u)
:
FromTypes (Matrix.vecCons α p) τ ≃ (α → FromTypes p τ)
The definitional equality between (vecCons α p)
-ary heterogeneous functions into τ
and function from α
to p
-ary heterogeneous functions into τ
.
Equations
Instances For
@[simp]
theorem
Function.fromTypes_cons_equiv_apply
{n : ℕ}
(α : Type u)
(p : Fin n → Type u)
(τ : Type u)
(a : FromTypes (Matrix.vecCons α p) τ)
:
(fromTypes_cons_equiv α p τ) a = a
@[simp]
theorem
Function.fromTypes_cons_equiv_symm_apply
{n : ℕ}
(α : Type u)
(p : Fin n → Type u)
(τ : Type u)
(a : FromTypes (Matrix.vecCons α p) τ)
:
(fromTypes_cons_equiv α p τ).symm a = a
Constant n
-ary function with value t
.
Equations
- Function.FromTypes.const x_4 x✝ = x✝
- Function.FromTypes.const p x✝ = fun (x : Matrix.vecHead p) => Function.FromTypes.const (Matrix.vecTail p) x✝
Instances For
@[simp]
theorem
Function.FromTypes.const_succ
{n : ℕ}
(p : Fin (n + 1) → Type u)
{τ : Type u}
(t : τ)
:
const p t = fun (x : Matrix.vecHead p) => const (Matrix.vecTail p) t
Equations
- Function.FromTypes.inhabited = { default := Function.FromTypes.const p default }