case class LambdaTerm[X <: Term with Subs[X], Y <: Term with Subs[Y]](variable: X, value: Y) extends LambdaLike[X, Y] with Product with Serializable
functions given by lambda, which may be dependent; even if it is pure, the scala type does not show this; one should usually not use the constructor of this case class, instead use the function lmbda or the syntactic sugar for this, e.g.
val f = x :~> y
Note the :~>
, not :->
These create a new variable to avoid name collisions.
- Alphabetic
- By Inheritance
- LambdaTerm
- Serializable
- Product
- Equals
- LambdaLike
- FuncLike
- Function1
- Term
- Subs
- AnyRef
- Any
- by UnliftOps
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- Protected
Instance Constructors
- new LambdaTerm(variable: X, value: Y)
Type Members
- type Cod = Y
- Definition Classes
- LambdaLike
- type D = X
- Definition Classes
- LambdaLike
- abstract type Obj <: FuncLike[X, Y]
- Definition Classes
- FuncLike
Value Members
- def act(arg: X): Y
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
- LambdaLike → FuncLike
- def andThen[A](g: (Y) => A): (X) => A
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- def andthen[Z <: Term with Subs[Z]](f: (Y) => Z): LambdaTerm[X, Z]
- Definition Classes
- LambdaLike
- def apply(arg: X): Y
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: X): Y
- Definition Classes
- FuncLike
- def canApply(arg: X): 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
- LambdaLike → FuncLike
- def compose[A](g: (A) => X): (A) => Y
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- val dep: Boolean
- Definition Classes
- LambdaTerm → LambdaLike
- val depcodom: (X) => Typ[Y]
- Definition Classes
- LambdaTerm → FuncLike
- def dependsOn(that: Term): Boolean
returns whether
this
depends onthat
returns whether
this
depends onthat
- Definition Classes
- Term
- lazy val dom: Typ[X]
- Definition Classes
- LambdaLike → FuncLike
- def equals(that: Any): Boolean
- Definition Classes
- LambdaLike → AnyRef → Any
- lazy val hashCode: Int
- Definition Classes
- LambdaLike → AnyRef → Any
- def indepOf(that: Term): Boolean
returns whether
this
is independent ofthat
.returns whether
this
is independent ofthat
.- Definition Classes
- Term
- def newobj: LambdaTerm[X, Y]
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
- LambdaTerm → Subs
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- def replace(x: Term, y: Term): FuncLike[X, Y] with Subs[FuncLike[X, Y]]
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): LambdaLike[X, Y]
substitute x by y recursively in
this
.substitute x by y recursively in
this
.- Definition Classes
- LambdaLike → FuncLike → Subs
- def toString(): String
- Definition Classes
- LambdaLike → Function1 → AnyRef → Any
- lazy val typ: Typ[FuncLike[X, Y]]
the HoTT-type of the term
the HoTT-type of the term
- Definition Classes
- LambdaLike → FuncLike → Term
- def unlift: PartialFunction[X, B]
- Implicit
- This member is added by an implicit conversion from LambdaTerm[X, Y] toUnliftOps[X, B] performed by method UnliftOps in scala.Function1.This conversion will take place only if Y is a subclass of Option[B] (Y <: 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
- LambdaLike → Term
- val value: Y
the value
y
in the lambda definitionx mapsto y
the value
y
in the lambda definitionx mapsto y
- Definition Classes
- LambdaTerm → LambdaLike
- val variable: X
the variable
x
in the lambda definitionx \mapsto y
the variable
x
in the lambda definitionx \mapsto y
- Definition Classes
- LambdaTerm → LambdaLike