case class PlusExtendedFunction[V <: Term with Subs[V]](first: Typ[Term], second: Typ[Term], codom: Typ[V], firstfn: Func[Term, V], scndfn: Func[Term, V]) extends Func[Term, V] with Subs[PlusExtendedFunction[V]] with Product with Serializable
- Alphabetic
- By Inheritance
- PlusExtendedFunction
- Serializable
- Product
- Equals
- Func
- FuncLike
- Function1
- Term
- Subs
- AnyRef
- Any
- by UnliftOps
- by RichTerm
- by any2stringadd
- by StringFormat
- by Ensuring
- by ArrowAssoc
- Hide All
- Show All
- Public
- Protected
Instance Constructors
Value Members
- def :->[V <: Term with Subs[V]](that: V): Func[PlusExtendedFunction[V], V]
constructor for (pure) lambda functions, see lmbda
constructor for (pure) lambda functions, see lmbda
- Implicit
- This member is added by an implicit conversion from PlusExtendedFunction[V] toRichTerm[PlusExtendedFunction[V]] performed by method RichTerm in provingground.HoTT.
- Definition Classes
- RichTerm
- def :~>[V <: Term with Subs[V]](that: V): FuncLike[PlusExtendedFunction[V], V]
constructor for (in general dependent) lambda functions, see lambda
constructor for (in general dependent) lambda functions, see lambda
- Implicit
- This member is added by an implicit conversion from PlusExtendedFunction[V] toRichTerm[PlusExtendedFunction[V]] performed by method RichTerm in provingground.HoTT.
- Definition Classes
- RichTerm
- def =:=(rhs: PlusExtendedFunction[V]): IdentityTyp[PlusExtendedFunction[V]]
equality type 'term = rhs'
equality type 'term = rhs'
- Implicit
- This member is added by an implicit conversion from PlusExtendedFunction[V] toRichTerm[PlusExtendedFunction[V]] performed by method RichTerm in provingground.HoTT.
- Definition Classes
- RichTerm
- def act(u: Term): V
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
- PlusExtendedFunction → Func → FuncLike
- def andThen[A](g: (V) => A): (Term) => A
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- def apply(arg: Term): V
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: Term): V
- Definition Classes
- FuncLike
- def canApply(arg: Term): 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: Typ[V]
codomain
codomain
- Definition Classes
- PlusExtendedFunction → Func
- def compose[A](g: (A) => Term): (A) => V
- Definition Classes
- Function1
- Annotations
- @unspecialized()
- val depcodom: (Term) => Typ[V]
- def dependsOn(that: Term): Boolean
returns whether
this
depends onthat
returns whether
this
depends onthat
- Definition Classes
- Term
- val dom: ProdTyp[Term, Term]
domain
domain
- Definition Classes
- PlusExtendedFunction → Func → FuncLike
- val first: Typ[Term]
- val firstfn: Func[Term, V]
- def indepOf(that: Term): Boolean
returns whether
this
is independent ofthat
.returns whether
this
is independent ofthat
.- Definition Classes
- Term
- def newobj: Nothing
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
- PlusExtendedFunction → Subs
- def productElementNames: Iterator[String]
- Definition Classes
- Product
- def refl: Refl[PlusExtendedFunction[V]]
reflexivity term
refl : term = term
reflexivity term
refl : term = term
- Implicit
- This member is added by an implicit conversion from PlusExtendedFunction[V] toRichTerm[PlusExtendedFunction[V]] performed by method RichTerm in provingground.HoTT.
- Definition Classes
- RichTerm
- def replace(x: Term, y: Term): PlusExtendedFunction[V] with Subs[PlusExtendedFunction[V]]
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
- val scndfn: Func[Term, V]
- val second: Typ[Term]
- def subs(x: Term, y: Term): PlusExtendedFunction[V]
substitute x by y recursively in
this
.substitute x by y recursively in
this
.- Definition Classes
- PlusExtendedFunction → Func → FuncLike → Subs
- def toString(): String
- Definition Classes
- Function1 → AnyRef → Any
- val typ: FuncTyp[Term, V]
the HoTT-type of the term
the HoTT-type of the term
- Definition Classes
- PlusExtendedFunction → Func → FuncLike → Term
- def unlift: PartialFunction[Term, B]
- Implicit
- This member is added by an implicit conversion from PlusExtendedFunction[V] toUnliftOps[Term, B] performed by method UnliftOps in scala.Function1.This conversion will take place only if V is a subclass of Option[B] (V <: 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