trait IndInducFuncLike[W <: Term with Subs[W], +U <: Term with Subs[U], F <: Term with Subs[F], IDFT <: Term with Subs[IDFT]] extends FuncLike[W, U]
common trait for indexed induction functions, for serialization and pretty printing.
- Alphabetic
- By Inheritance
- IndInducFuncLike
- FuncLike
- Function1
- Term
- Subs
- AnyRef
- Any
- by UnliftOps
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- Protected
Abstract Value Members
- abstract def act(arg: W): U
the action of the function to define: define this method, but use apply.
the action of the function to define: define this method, but use apply.
- Definition Classes
- FuncLike
- abstract val codXs: IDFT
the dependent codomain on the family.
- abstract val defnData: Vector[Term]
the definition data for all the introduction rules
- abstract val depcodom: (W) => Typ[U]
- Definition Classes
- FuncLike
- abstract val dom: Typ[W]
- Definition Classes
- FuncLike
- abstract val domW: F
the domain family, e.g.
the domain family, e.g.
Vec
- abstract val index: Vector[Term]
indices of the introduction rules.
- abstract val intros: Vector[Term]
- abstract def newobj: FuncLike[W, U] with Subs[FuncLike[W, U]]
A new object with the same type, to be used in place of a variable to avoid name clashes.
A new object with the same type, to be used in place of a variable to avoid name clashes. Should throw exception when invoked for constants.
- Definition Classes
- Subs
- abstract def subs(x: Term, y: Term): FuncLike[W, U]
substitute x by y recursively in
this
. - abstract val typ: Typ[FuncLike[W, U]]
the HoTT-type of the term
Concrete Value Members
- def andThen[A](g: (U) => A): (W) => A
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- def apply(arg: W): U
application of the function: use this but define the act method; checks HoTT-type of argument is in the domain and throws exception if it fails.
- def applyUnchecked(arg: W): U
- Definition Classes
- FuncLike
- def canApply(arg: W): Boolean
checks if application is valid; can override to allow for example resizing universes
checks if application is valid; can override to allow for example resizing universes
- arg
the argument
- returns
whether the argument has the correct type.
- Definition Classes
- FuncLike
- def compose[A](g: (A) => W): (A) => U
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- def dependsOn(that: Term): Boolean
returns whether
this
depends onthat
returns whether
this
depends onthat
- Definition Classes
- Term
- def equals(that: Any): Boolean
- Definition Classes
- IndInducFuncLike → AnyRef → Any
- lazy val fullIndData: (F, Vector[Term], IDFT, Vector[Term])
- def hashCode(): Int
- Definition Classes
- IndInducFuncLike → AnyRef → Any
- def indepOf(that: Term): Boolean
returns whether
this
is independent ofthat
.returns whether
this
is independent ofthat
.- Definition Classes
- Term
- def replace(x: Term, y: Term): FuncLike[W, U] with Subs[FuncLike[W, U]]
refine substitution so if x and y are both of certain forms such as pairs or formal applications, components are substituted.
refine substitution so if x and y are both of certain forms such as pairs or formal applications, components are substituted.
- Definition Classes
- Subs
- def toString(): String
- Definition Classes
- IndInducFuncLike → Function1 → AnyRef → Any
- def unlift: PartialFunction[W, B]
- Implicit
- This member is added by an implicit conversion from IndInducFuncLike[W, U, F, IDFT] toUnliftOps[W, B] performed by method UnliftOps in scala.Function1.This conversion will take place only if U is a subclass of Option[B] (U <: Option[B]).
- Definition Classes
- UnliftOps
- def usesVar(t: Term): Boolean
returns whether the variable
t
is used as a variable in a lambda definition.returns whether the variable
t
is used as a variable in a lambda definition.- Definition Classes
- Term