case object sum extends Func[LocalTerm, Func[LocalTerm, LocalTerm]] with Product with Serializable
- Alphabetic
- By Inheritance
- sum
- Serializable
- Product
- Equals
- Func
- FuncLike
- Function1
- Term
- Subs
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Type Members
Value Members
- def act(x: LocalTerm): Func[LocalTerm, LocalTerm]
the action of the function to define: define this method, but use apply.
- def andThen[A](g: (Func[LocalTerm, LocalTerm]) => A): (LocalTerm) => A
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- def apply(arg: LocalTerm): Func[LocalTerm, LocalTerm]
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: LocalTerm): Func[LocalTerm, LocalTerm]
- Definition Classes
- FuncLike
- def canApply(arg: LocalTerm): 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
- val codom: FuncTyp[LocalTerm, LocalTerm]
codomain
- def compose[A](g: (A) => LocalTerm): (A) => Func[LocalTerm, LocalTerm]
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- val depcodom: (LocalTerm) => Typ[Func[LocalTerm, LocalTerm]]
- def dependsOn(that: Term): Boolean
returns whether
this
depends onthat
returns whether
this
depends onthat
- Definition Classes
- Term
- val dom: LocalTyp.type
domain
- def indepOf(that: Term): Boolean
returns whether
this
is independent ofthat
.returns whether
this
is independent ofthat
.- Definition Classes
- Term
- def newobj: Func[LocalTerm, Func[LocalTerm, LocalTerm]]
A new object with the same type, to be used in place of a variable to avoid name clashes.
- def productElementName(n: Int): String
- Definition Classes
- Product
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- def replace(x: Term, y: Term): Func[LocalTerm, Func[LocalTerm, LocalTerm]] with Subs[Func[LocalTerm, Func[LocalTerm, LocalTerm]]]
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 subs(x: Term, y: Term): sum.type
substitute x by y recursively in
this
. - def toString(): String
- Definition Classes
- sum → Function1 → AnyRef → Any
- val typ: FuncTyp[LocalTerm, Func[LocalTerm, LocalTerm]]
the HoTT-type of the term
- 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