Trait

scalan

SigmaLibrary

Related Doc: package scalan

Permalink

trait SigmaLibrary extends Scalan with Library with WrappersModule with SigmaDslModule with CostedObjectsModule

Linear Supertypes
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SigmaLibrary
  2. CostedObjectsModule
  3. CostedObjectsDefs
  4. CostedObjects
  5. SigmaDslModule
  6. SigmaDslDefs
  7. SigmaDsl
  8. WrappersModule
  9. Library
  10. CostedOptionsModule
  11. CostedOptionsDefs
  12. CostedOptions
  13. MonoidInstancesModule
  14. MonoidInstancesDefs
  15. MonoidInstances
  16. MonoidsModule
  17. MonoidsDefs
  18. Monoids
  19. ConcreteCostsModule
  20. ConcreteCostsDefs
  21. ConcreteCosts
  22. ConcreteSizesModule
  23. ConcreteSizesDefs
  24. ConcreteSizes
  25. CostsModule
  26. CostsDefs
  27. Costs
  28. SizesModule
  29. SizesDefs
  30. Sizes
  31. CollsModule
  32. CollsDefs
  33. Colls
  34. WrappersSpecModule
  35. WrappersSpecDefs
  36. WrappersSpec
  37. WrappersModule
  38. WRTypesModule
  39. WRTypesDefs
  40. WRTypes
  41. WOptionsModule
  42. WOptionsDefs
  43. WOptions
  44. WSpecialPredefsModule
  45. WSpecialPredefsDefs
  46. WSpecialPredefs
  47. Scalan
  48. DefRewriting
  49. Modules
  50. Entities
  51. Thunks
  52. IfThenElse
  53. Functions
  54. ProgramGraphs
  55. AstGraphs
  56. Transforming
  57. UniversalOps
  58. Equal
  59. OrderingOps
  60. LogicalOps
  61. UnBinOps
  62. NumericOps
  63. Tuples
  64. MethodCalls
  65. GraphVizExport
  66. TypeDescs
  67. Base
  68. AnyRef
  69. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. case class Abs[T](n: ExactNumeric[T])(implicit evidence$8: Scalan.Elem[T]) extends Scalan.UnOp[T, T] with Product with Serializable

    Permalink

    Descriptor of unary abs operation.

    Descriptor of unary abs operation.

    Definition Classes
    NumericOps
  2. trait AnyValue extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.AnyValue]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  3. trait AnyValueCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  4. case class Apply[A, B](f: Scalan.Ref[(A) ⇒ B], arg: Scalan.Ref[A], mayInline: Boolean = true) extends Scalan.Node with Scalan.Def[B] with Product with Serializable

    Permalink
    Definition Classes
    Functions
  5. case class ApplyBinOp[A, R](op: Scalan.BinOp[A, R], lhs: Scalan.Ref[A], rhs: Scalan.Ref[A]) extends Scalan.BaseDef[R] with Product with Serializable

    Permalink

    Graph node which represents application of the given binary operation to the given arguments.

    Graph node which represents application of the given binary operation to the given arguments.

    Definition Classes
    UnBinOps
  6. case class ApplyBinOpLazy[A, R](op: Scalan.BinOp[A, R], lhs: Scalan.Ref[A], rhs: Scalan.Ref[Scalan.Thunk[A]]) extends Scalan.BaseDef[R] with Product with Serializable

    Permalink

    Graph node which represents application of the given binary operation to the given arguments where the second argument is lazy.

    Graph node which represents application of the given binary operation to the given arguments where the second argument is lazy.

    Definition Classes
    UnBinOps
  7. case class ApplyUnOp[A, R](op: Scalan.UnOp[A, R], arg: Scalan.Ref[A]) extends Scalan.BaseDef[R] with Product with Serializable

    Permalink

    Graph node which represents application of the given unary operation to the given argument.

    Graph node which represents application of the given unary operation to the given argument.

    Definition Classes
    UnBinOps
  8. abstract class AstGraph extends Scalan.Node

    Permalink

    Base class for all compound nodes with schedule (e.g.

    Base class for all compound nodes with schedule (e.g. Lambda, ThunkDef). The graph is directed acyclic (i.e. DAG) in which edges go from boundVars down to roots.

    Definition Classes
    AstGraphs
  9. trait AvlTree extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.AvlTree]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable()
  10. trait AvlTreeCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  11. abstract class BaseDef[+T] extends Scalan.Node with Scalan.Def[T]

    Permalink

    Base class for most predefined operations.

    Base class for most predefined operations.

    Definition Classes
    Base
  12. abstract class BaseElem[A] extends Scalan.Elem[A] with Serializable with Equals

    Permalink
    Definition Classes
    TypeDescs
  13. class BaseElemLiftable[A] extends Scalan.BaseElem[A]

    Permalink

    Type descriptor for primitive types.

    Type descriptor for primitive types. There is implicit val declaration for each primitive type.

    Definition Classes
    TypeDescs
  14. trait BigInt extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.BigInt]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  15. trait BigIntCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  16. abstract class BinOp[A, R] extends AnyRef

    Permalink

    Base class for descriptors of binary operations.

    Base class for descriptors of binary operations.

    Definition Classes
    UnBinOps
  17. trait Box extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.Box]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  18. trait BoxCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  19. abstract class CCostedBuilder extends scalan.Library.Node with scalan.Library.CostedBuilder

    Permalink
    Definition Classes
    ConcreteCosts
  20. trait CCostedBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteCosts
  21. abstract class CCostedColl[Item] extends scalan.Library.Node with scalan.Library.CostedColl[Item]

    Permalink
    Definition Classes
    ConcreteCosts
  22. trait CCostedCollCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteCosts
  23. abstract class CCostedFunc[Env, Arg, Res] extends scalan.Library.Node with scalan.Library.CostedFunc[Env, Arg, Res]

    Permalink
    Definition Classes
    ConcreteCosts
  24. trait CCostedFuncCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteCosts
  25. abstract class CCostedOption[T] extends scalan.Library.Node with scalan.Library.CostedOption[T]

    Permalink
    Definition Classes
    CostedOptions
  26. trait CCostedOptionCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedOptions
  27. abstract class CCostedPair[L, R] extends scalan.Library.Node with scalan.Library.CostedPair[L, R]

    Permalink
    Definition Classes
    ConcreteCosts
  28. trait CCostedPairCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteCosts
  29. abstract class CCostedPrim[Val] extends scalan.Library.Node with scalan.Library.CostedPrim[Val]

    Permalink
    Definition Classes
    ConcreteCosts
  30. trait CCostedPrimCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteCosts
  31. abstract class CSizeColl[Item] extends scalan.Library.Node with scalan.Library.SizeColl[Item]

    Permalink
    Definition Classes
    ConcreteSizes
  32. trait CSizeCollCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteSizes
  33. abstract class CSizeFunc[Env, Arg, Res] extends scalan.Library.Node with scalan.Library.SizeFunc[Env, Arg, Res]

    Permalink
    Definition Classes
    ConcreteSizes
  34. trait CSizeFuncCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteSizes
  35. abstract class CSizeOption[Item] extends scalan.Library.Node with scalan.Library.SizeOption[Item]

    Permalink
    Definition Classes
    ConcreteSizes
  36. trait CSizeOptionCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteSizes
  37. abstract class CSizePair[L, R] extends scalan.Library.Node with scalan.Library.SizePair[L, R]

    Permalink
    Definition Classes
    ConcreteSizes
  38. trait CSizePairCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteSizes
  39. abstract class CSizePrim[Val] extends scalan.Library.Node with scalan.Library.SizePrim[Val]

    Permalink
    Definition Classes
    ConcreteSizes
  40. trait CSizePrimCompanion extends AnyRef

    Permalink
    Definition Classes
    ConcreteSizes
  41. trait Coll[A] extends scalan.Library.Node with scalan.Library.Def[scalan.Library.Coll[A]]

    Permalink
    Definition Classes
    Colls
    Annotations
    @ContainerType() @FunctorType() @Liftable() @WithMethodCallRecognizers()
  42. trait CollBuilder extends scalan.Library.Node with scalan.Library.Def[scalan.Library.CollBuilder]

    Permalink
    Definition Classes
    Colls
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  43. trait CollBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    Colls
  44. trait CollCompanion extends AnyRef

    Permalink
    Definition Classes
    Colls
  45. abstract class CompanionDef[T] extends Scalan.Node with Scalan.Def[T]

    Permalink

    Base class for virtualized instances of type companions.

    Base class for virtualized instances of type companions. Each virtualized entity type (trait or class) may have virtualized companion class.

    Definition Classes
    Base
  46. abstract class CompanionElem[T] extends Scalan.Elem[T]

    Permalink

    Base class for all descriptors of staged companions

    Base class for all descriptors of staged companions

    Definition Classes
    Entities
  47. trait ConcreteElem[TData, TClass] extends Scalan.EntityElem[TClass]

    Permalink

    Base class for all descriptors of staged classes.

    Base class for all descriptors of staged classes.

    Definition Classes
    Entities
  48. trait ConcreteElem1[A, TData, TClass, C[_]] extends Scalan.EntityElem1[A, TClass, C]

    Permalink

    Base class for all descriptors of staged classes with one type parameter.

    Base class for all descriptors of staged classes with one type parameter. Note, it doesn't inherit from ConcreteElem

    Definition Classes
    Entities
  49. case class Const[T](x: T)(implicit eT: Scalan.Elem[T]) extends Scalan.BaseDef[T] with Product with Serializable

    Permalink

    Default node type for embedding of literal values to graph IR.

    Default node type for embedding of literal values to graph IR. This can be used or those types T when Elem[T] is defined, but Liftable[_,T] is not, i.e. for non-liftable types.

    x

    literal value

    eT

    type descriptor of IR type T

    Definition Classes
    Base
  50. abstract class Cont[F[_]] extends Scalan.TypeDesc

    Permalink

    Descriptor of type constructor of * -> * kind.

    Descriptor of type constructor of * -> * kind. Type constructor is not a type, but rather a function from type to type. It contains methods which abstract relationship between types T, F[T] etc.

    Definition Classes
    TypeDescs
    Annotations
    @implicitNotFound( "No Cont available for ${F}." )
  51. trait Context extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.Context]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  52. trait ContextCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  53. case class Convert[From, To](eFrom: Scalan.Elem[From], eTo: Scalan.Elem[To], x: Scalan.Ref[Scalan.Def[_]], conv: Scalan.Ref[(From) ⇒ To]) extends Scalan.BaseDef[To] with Product with Serializable

    Permalink
    Definition Classes
    UniversalOps
  54. trait CostModel extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.CostModel]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable()
  55. trait CostModelCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  56. trait Costed[Val] extends scalan.Library.Node with scalan.Library.Def[scalan.Library.Costed[Val]]

    Permalink
    Definition Classes
    Costs
    Annotations
    @WithMethodCallRecognizers()
  57. trait CostedBuilder extends scalan.Library.Node with scalan.Library.Def[scalan.Library.CostedBuilder]

    Permalink
    Definition Classes
    Costs
    Annotations
    @WithMethodCallRecognizers()
  58. trait CostedBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  59. trait CostedColl[Item] extends scalan.Library.Node with scalan.Library.Costed[scalan.Library.Coll[Item]]

    Permalink
    Definition Classes
    Costs
    Annotations
    @WithMethodCallRecognizers()
  60. trait CostedCollCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  61. trait CostedCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  62. trait CostedFunc[Env, Arg, Res] extends scalan.Library.Node with scalan.Library.Costed[(Arg) ⇒ Res]

    Permalink
    Definition Classes
    Costs
  63. trait CostedFuncCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  64. trait CostedOption[T] extends scalan.Library.Node with scalan.Library.Costed[scalan.Library.WOption[T]]

    Permalink
    Definition Classes
    Costs
  65. trait CostedOptionCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  66. trait CostedPair[L, R] extends scalan.Library.Node with scalan.Library.Costed[(L, R)]

    Permalink
    Definition Classes
    Costs
  67. trait CostedPairCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  68. trait CostedPrim[Val] extends scalan.Library.Node with scalan.Library.Costed[Val]

    Permalink
    Definition Classes
    Costs
  69. trait CostedPrimCompanion extends AnyRef

    Permalink
    Definition Classes
    Costs
  70. type DataEnv = Map[Sym, AnyRef]

    Permalink

    Immutable data environment used to assign data values to graph nodes.

    Immutable data environment used to assign data values to graph nodes.

    Definition Classes
    TypeDescs
  71. trait Def[+T] extends Scalan.Node

    Permalink

    Base type for all graph nodes (aka computable value definitions).

    Base type for all graph nodes (aka computable value definitions). Each graph node or definition represent one operation node of the data flow graph.

    Definition Classes
    Base
  72. class DefaultPass extends Scalan.Pass

    Permalink

    Default pass to be used when IR is used without special compiler configuration.

    Default pass to be used when IR is used without special compiler configuration.

    Definition Classes
    Transforming
  73. abstract class DivOp[T] extends Scalan.EndoBinOp[T]

    Permalink

    Base class for descriptors of binary division operations.

    Base class for descriptors of binary division operations.

    Definition Classes
    NumericOps
  74. case class Downcast[From, To](input: Scalan.Ref[From], eTo: Scalan.Elem[To]) extends Scalan.BaseDef[To] with Product with Serializable

    Permalink
    Definition Classes
    UniversalOps
  75. abstract class Elem[A] extends Scalan.TypeDesc

    Permalink

    Type descriptor of staged types, which correspond to source (unstaged) RTypes defined outside of IR cake.

    Type descriptor of staged types, which correspond to source (unstaged) RTypes defined outside of IR cake.

    A

    the type represented by this descriptor

    Definition Classes
    TypeDescs
    Annotations
    @implicitNotFound( "No Elem available for ${A}." )
  76. class ElemCacheEntry extends AnyRef

    Permalink

    Elements cache information for each Elem class.

    Elements cache information for each Elem class.

    Definition Classes
    TypeDescs
  77. class ElseIfBranch[T] extends AnyRef

    Permalink

    Defines syntax available after IF (cond) THEN thenp ELSEIF (cond1)

    Defines syntax available after IF (cond) THEN thenp ELSEIF (cond1)

    Definition Classes
    IfThenElse
  78. type EndoBinOp[A] = BinOp[A, A]

    Permalink
    Definition Classes
    UnBinOps
  79. type EndoUnOp[A] = UnOp[A, A]

    Permalink
    Definition Classes
    UnBinOps
  80. abstract class EntityElem[A] extends Scalan.Elem[A] with Equals

    Permalink

    Base class for all descriptors of staged traits.

    Base class for all descriptors of staged traits. See derived classes in impl packages.

    Definition Classes
    Entities
  81. abstract class EntityElem1[A, To, C[_]] extends Scalan.EntityElem[To]

    Permalink

    Base class for all descriptors of staged traits with one type parameter.

    Base class for all descriptors of staged traits with one type parameter.

    Definition Classes
    Entities
  82. class EntityObject extends AnyRef

    Permalink

    Base class for all objects generated for virtualized types to support staged evaluation machinery.

    Base class for all objects generated for virtualized types to support staged evaluation machinery. Each object contains definitions which can be imported when necessary. All that objects are registered in entityObjects hash map, which is done while IR cake is constructed.

    Definition Classes
    Base
  83. case class EntityObjectOwner(obj: Scalan.EntityObject) extends Scalan.OwnerKind with Product with Serializable

    Permalink
    Definition Classes
    Base
  84. case class EnvRep[A](run: (Scalan.DataEnv) ⇒ (Scalan.DataEnv, Scalan.Ref[A])) extends Product with Serializable

    Permalink

    State monad for symbols computed in a data environment.

    State monad for symbols computed in a data environment. DataEnv is used as the state of the state monad.

    Definition Classes
    TypeDescs
  85. implicit class EqualOps[A] extends AnyRef

    Permalink

    Extension methods to construct ApplyBinOp nodes

    Extension methods to construct ApplyBinOp nodes

    Definition Classes
    Equal
  86. case class Equals[A]()(implicit evidence$1: Scalan.Elem[A]) extends Scalan.BinOp[A, Boolean] with Product with Serializable

    Permalink

    Binary operation representing structural equality between arguments.

    Binary operation representing structural equality between arguments.

    Definition Classes
    Equal
  87. case class First[A, B](pair: Scalan.Ref[(A, B)]) extends Scalan.Node with Scalan.Def[A] with Product with Serializable

    Permalink
    Definition Classes
    Tuples
  88. case class FuncElem[A, B](eDom: Scalan.Elem[A], eRange: Scalan.Elem[B]) extends Scalan.Elem[(A) ⇒ B] with Product with Serializable

    Permalink

    Type descriptor for A => B type where descriptors for A and B are given as arguments.

    Type descriptor for A => B type where descriptors for A and B are given as arguments.

    Definition Classes
    TypeDescs
  89. implicit class FuncExtensions[A, B] extends AnyRef

    Permalink
    Definition Classes
    Functions
  90. trait Functor[F[_]] extends Scalan.Cont[F]

    Permalink
    Definition Classes
    TypeDescs
  91. case class GraphFile(file: File, fileType: String) extends Product with Serializable

    Permalink
    Definition Classes
    GraphVizExport
  92. case class GraphNode(sym: Scalan.Sym, usages: Buffer[Int]) extends Product with Serializable

    Permalink

    GraphNode is created for each symbol of the AstGraph and represents graph linking structure

    GraphNode is created for each symbol of the AstGraph and represents graph linking structure

    Definition Classes
    AstGraphs
  93. trait GroupElement extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.GroupElement]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  94. trait GroupElementCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  95. case class HashCode[A]() extends Scalan.UnOp[A, Int] with Product with Serializable

    Permalink
    Definition Classes
    UniversalOps
  96. trait Header extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.Header]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable()
  97. trait HeaderCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  98. class IfBranch extends AnyRef

    Permalink

    Defines syntax available after IF (cond)

    Defines syntax available after IF (cond)

    Definition Classes
    IfThenElse
  99. case class IfThenElseLazy[T](cond: Scalan.Ref[Boolean], thenp: Scalan.Ref[Scalan.Thunk[T]], elsep: Scalan.Ref[Scalan.Thunk[T]]) extends Scalan.Node with Scalan.Def[T] with Product with Serializable

    Permalink

    IR node to represent IF condition with lazy branches.

    IR node to represent IF condition with lazy branches.

    Definition Classes
    IfThenElse
  100. abstract class IntPlusMonoid extends scalan.Library.Node with scalan.Library.Monoid[Int]

    Permalink
    Definition Classes
    MonoidInstances
  101. trait IntPlusMonoidCompanion extends AnyRef

    Permalink
    Definition Classes
    MonoidInstances
  102. case class IntegralDivide[T](i: ExactIntegral[T])(implicit elem: Scalan.Elem[T]) extends Scalan.DivOp[T] with Product with Serializable

    Permalink

    Descriptor of binary / operation (integral division).

    Descriptor of binary / operation (integral division).

    Definition Classes
    NumericOps
  103. case class IntegralMod[T](i: ExactIntegral[T])(implicit elem: Scalan.Elem[T]) extends Scalan.DivOp[T] with Product with Serializable

    Permalink

    Descriptor of binary % operation (reminder of integral division).

    Descriptor of binary % operation (reminder of integral division).

    Definition Classes
    NumericOps
  104. implicit class IntegralOpsCls[T] extends AnyRef

    Permalink

    Extension methods over Ref[T] where T is instance of ExactIntegral type-class.

    Extension methods over Ref[T] where T is instance of ExactIntegral type-class.

    Definition Classes
    NumericOps
  105. case class InvokeFailure(exception: Throwable) extends Scalan.InvokeResult with Product with Serializable

    Permalink

    Exception thrown during MethodCall invocation.

    Exception thrown during MethodCall invocation.

    Definition Classes
    MethodCalls
  106. sealed abstract class InvokeResult extends AnyRef

    Permalink

    Result of MethodCall invocation.

    Result of MethodCall invocation.

    Definition Classes
    MethodCalls
    See also

    tryInvoke

  107. case class InvokeSuccess(result: Scalan.Ref[_]) extends Scalan.InvokeResult with Product with Serializable

    Permalink

    Successful MethodCall invocation with the given result.

    Successful MethodCall invocation with the given result.

    Definition Classes
    MethodCalls
  108. type LElem[A] = Lazy[Elem[A]]

    Permalink

    Type descriptor which is computed lazily on demand.

    Type descriptor which is computed lazily on demand.

    Definition Classes
    TypeDescs
  109. class Lambda[A, B] extends Scalan.AstGraph with Scalan.Def[(A) ⇒ B]

    Permalink

    Represent lambda expression as IR node.

    Represent lambda expression as IR node.

    Definition Classes
    Functions
  110. type LambdaData[A, B] = (Lambda[A, B], Nullable[(Ref[A]) ⇒ Ref[B]], Ref[A], Ref[B])

    Permalink
    Definition Classes
    Functions
  111. implicit class LambdaOps[A, B] extends AnyRef

    Permalink
    Definition Classes
    Functions
  112. class LambdaStack extends AnyRef

    Permalink
    Definition Classes
    Functions
  113. type LazyRep[T] = MutableLazy[Ref[T]]

    Permalink
    Definition Classes
    Library
  114. case class LiftableThunk[ST, T](lT: Base.Liftables.Liftable[ST, T]) extends Base.Liftables.Liftable[Scalan.SThunk[ST], Scalan.Thunk[T]] with Product with Serializable

    Permalink

    Implementation of Liftable type class for Thunk[T] given liftable for T.

    Implementation of Liftable type class for Thunk[T] given liftable for T.

    Definition Classes
    Thunks
  115. implicit class ListOps[A, B] extends AnyRef

    Permalink
    Definition Classes
    Tuples
  116. abstract class LongPlusMonoid extends scalan.Library.Node with scalan.Library.Monoid[Long]

    Permalink
    Definition Classes
    MonoidInstances
  117. trait LongPlusMonoidCompanion extends AnyRef

    Permalink
    Definition Classes
    MonoidInstances
  118. case class MapTransformer(subst: HashMap[Scalan.Sym, Scalan.Sym]) extends Scalan.Transformer with Product with Serializable

    Permalink

    Concrete and default implementation of Transformer using underlying HashMap.

    Concrete and default implementation of Transformer using underlying HashMap.

    Definition Classes
    Transforming
  119. case class MethodCall extends Scalan.Node with Scalan.Def[Any] with Product with Serializable

    Permalink

    Graph node to represent invocation of the method of some class.

    Graph node to represent invocation of the method of some class.

    Definition Classes
    MethodCalls
  120. sealed abstract class MethodDesc extends AnyRef

    Permalink
    Definition Classes
    TypeDescs
  121. abstract class Mirror extends AnyRef

    Permalink

    Base class for mirrors of graph nodes.

    Base class for mirrors of graph nodes. Provides default implementations which can be overriden if special logic is required.

    Definition Classes
    Transforming
  122. trait Monoid[T] extends scalan.Library.Node with scalan.Library.Def[scalan.Library.Monoid[T]]

    Permalink
    Definition Classes
    Monoids
  123. trait MonoidBuilder extends scalan.Library.Node with scalan.Library.Def[scalan.Library.MonoidBuilder]

    Permalink
    Definition Classes
    Monoids
    Annotations
    @WithMethodCallRecognizers()
  124. trait MonoidBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    Monoids
  125. abstract class MonoidBuilderInst extends scalan.Library.Node with scalan.Library.MonoidBuilder

    Permalink
    Definition Classes
    MonoidInstances
  126. trait MonoidBuilderInstCompanion extends AnyRef

    Permalink
    Definition Classes
    MonoidInstances
  127. trait MonoidCompanion extends AnyRef

    Permalink
    Definition Classes
    Monoids
  128. case class NewObject[A](eA: Scalan.Elem[A], args: Seq[Any]) extends Scalan.BaseDef[A] with Product with Serializable

    Permalink

    Represents invocation of constructor of the class described by eA.

    Represents invocation of constructor of the class described by eA.

    eA

    class descriptor for new instance

    args

    arguments of class constructor

    Definition Classes
    MethodCalls
  129. abstract class Node extends Product

    Permalink

    Base class for all IR nodes/operations/definitions.

    Base class for all IR nodes/operations/definitions.

    Definition Classes
    Base
  130. case class NotEquals[A]()(implicit evidence$2: Scalan.Elem[A]) extends Scalan.BinOp[A, Boolean] with Product with Serializable

    Permalink

    Binary operation representing structural inequality between arguments.

    Binary operation representing structural inequality between arguments.

    Definition Classes
    Equal
  131. class NotImplementedStagingException extends Scalan.StagingException

    Permalink
    Definition Classes
    Base
  132. case class NumericMinus[T](n: ExactNumeric[T])(implicit evidence$4: Scalan.Elem[T]) extends Scalan.EndoBinOp[T] with Product with Serializable

    Permalink

    Descriptor of binary - operation.

    Descriptor of binary - operation.

    Definition Classes
    NumericOps
  133. case class NumericNegate[T](n: ExactNumeric[T])(implicit evidence$7: Scalan.Elem[T]) extends Scalan.UnOp[T, T] with Product with Serializable

    Permalink

    Descriptor of unary - operation.

    Descriptor of unary - operation.

    Definition Classes
    NumericOps
  134. implicit class NumericOpsCls[T] extends AnyRef

    Permalink

    Extension methods over Ref[T] where T is instance of ExactNumeric type-class.

    Extension methods over Ref[T] where T is instance of ExactNumeric type-class.

    Definition Classes
    NumericOps
  135. case class NumericPlus[T](n: ExactNumeric[T])(implicit evidence$3: Scalan.Elem[T]) extends Scalan.EndoBinOp[T] with Product with Serializable

    Permalink

    Descriptor of binary + operation.

    Descriptor of binary + operation.

    Definition Classes
    NumericOps
  136. case class NumericTimes[T](n: ExactNumeric[T])(implicit evidence$5: Scalan.Elem[T]) extends Scalan.EndoBinOp[T] with Product with Serializable

    Permalink

    Descriptor of binary * operation.

    Descriptor of binary * operation.

    Definition Classes
    NumericOps
  137. case class NumericToDouble[T](n: ExactNumeric[T]) extends Scalan.UnOp[T, Double] with Product with Serializable

    Permalink

    Descriptor of unary ToDouble conversion operation.

    Descriptor of unary ToDouble conversion operation.

    Definition Classes
    NumericOps
  138. case class NumericToFloat[T](n: ExactNumeric[T]) extends Scalan.UnOp[T, Float] with Product with Serializable

    Permalink

    Descriptor of unary ToFloat conversion operation.

    Descriptor of unary ToFloat conversion operation.

    Definition Classes
    NumericOps
  139. case class NumericToInt[T](n: ExactNumeric[T]) extends Scalan.UnOp[T, Int] with Product with Serializable

    Permalink

    Descriptor of unary ToInt conversion operation.

    Descriptor of unary ToInt conversion operation.

    Definition Classes
    NumericOps
  140. case class NumericToLong[T](n: ExactNumeric[T]) extends Scalan.UnOp[T, Long] with Product with Serializable

    Permalink

    Descriptor of unary ToLong conversion operation.

    Descriptor of unary ToLong conversion operation.

    Definition Classes
    NumericOps
  141. case class OpCost(lambdaVar: Scalan.Sym, costedValueId: Int, args: Seq[Scalan.Ref[Int]], opCost: Scalan.Ref[Int]) extends Scalan.BaseDef[Int] with Product with Serializable

    Permalink

    Special graph node to represent accumulation of the operation costs.

    Special graph node to represent accumulation of the operation costs. In general, due to node sharing it is incorrect to just sum up all the args costs and add resCost to that value. Example:
    val x = .. val y = op1(x) val z = op2(x) val res = op3(y, z) The naive summation will lead to the cost of x is accumulated both into cost of y and into cost of z, so in the cost of res it is accumulated twice. To avoid this problem OpCost nodes require special handling in during evaluation.

    lambdaVar

    the variable of the lambda in which scope this node is created. This makes this node belong to the lambda body, even if it doesn't otherwise depend on lambda argument.

    costedValueId

    The id of the node for which this node represents cost

    args

    costs of the arguments, which are here represent dependency information.

    opCost

    operation cost, which should be added to the current scope accumulated cost

    Definition Classes
    UniversalOps
  142. trait OptionWrapSpec extends scalan.Library.Node with scalan.Library.WrapSpecBase

    Permalink
    Definition Classes
    WrappersSpec
  143. trait OptionWrapSpecCompanion extends AnyRef

    Permalink
    Definition Classes
    WrappersSpec
  144. case class OrderingCompare[T](ord: ExactOrdering[T]) extends Scalan.BinOp[T, Int] with Product with Serializable

    Permalink

    Descriptor of binary compare operation.

    Descriptor of binary compare operation.

    Definition Classes
    OrderingOps
  145. case class OrderingGT[T](ord: ExactOrdering[T]) extends Scalan.BinOp[T, Boolean] with Product with Serializable

    Permalink

    Descriptor of binary > operation.

    Descriptor of binary > operation.

    Definition Classes
    OrderingOps
  146. case class OrderingGTEQ[T](ord: ExactOrdering[T]) extends Scalan.BinOp[T, Boolean] with Product with Serializable

    Permalink

    Descriptor of binary >= operation.

    Descriptor of binary >= operation.

    Definition Classes
    OrderingOps
  147. case class OrderingLT[T](ord: ExactOrdering[T]) extends Scalan.BinOp[T, Boolean] with Product with Serializable

    Permalink

    Descriptor of binary < operation.

    Descriptor of binary < operation.

    Definition Classes
    OrderingOps
  148. case class OrderingLTEQ[T](ord: ExactOrdering[T]) extends Scalan.BinOp[T, Boolean] with Product with Serializable

    Permalink

    Descriptor of binary <= operation.

    Descriptor of binary <= operation.

    Definition Classes
    OrderingOps
  149. case class OrderingMax[T](ord: ExactOrdering[T])(implicit evidence$1: Scalan.Elem[T]) extends Scalan.BinOp[T, T] with Product with Serializable

    Permalink

    Descriptor of binary max operation.

    Descriptor of binary max operation.

    Definition Classes
    OrderingOps
  150. case class OrderingMin[T](ord: ExactOrdering[T])(implicit evidence$2: Scalan.Elem[T]) extends Scalan.BinOp[T, T] with Product with Serializable

    Permalink

    Descriptor of binary min operation.

    Descriptor of binary min operation.

    Definition Classes
    OrderingOps
  151. class OrderingOpsCls[T] extends AnyRef

    Permalink

    Extension method over Ref[T] given an instance of ExactOrdering for T.

    Extension method over Ref[T] given an instance of ExactOrdering for T.

    Definition Classes
    OrderingOps
  152. sealed abstract class OwnerKind extends AnyRef

    Permalink

    Variants of owner parameter of constructors of nested classes: 1) predefined node classes are owned by IR cake (ScalanOwner) 2) entity classes are owned by enclosing EntityObject

    Variants of owner parameter of constructors of nested classes: 1) predefined node classes are owned by IR cake (ScalanOwner) 2) entity classes are owned by enclosing EntityObject

    Definition Classes
    Base
  153. type PGraph = ProgramGraph

    Permalink
    Definition Classes
    ProgramGraphs
  154. class PGraphUsages extends DFunc[Int, Buffer[Int]]

    Permalink

    Deboxed function to obtain usages of a given node.

    Deboxed function to obtain usages of a given node. Represents adjacency matrix of the reversed graph g.

    Definition Classes
    ProgramGraphs
  155. trait PairColl[L, R] extends scalan.Library.Node with scalan.Library.Coll[(L, R)]

    Permalink
    Definition Classes
    Colls
    Annotations
    @WithMethodCallRecognizers()
  156. trait PairCollCompanion extends AnyRef

    Permalink
    Definition Classes
    Colls
  157. case class PairElem[A, B](eFst: Scalan.Elem[A], eSnd: Scalan.Elem[B]) extends Scalan.Elem[(A, B)] with Product with Serializable

    Permalink

    Type descriptor for (A, B) type where descriptors for A and B are given as arguments.

    Type descriptor for (A, B) type where descriptors for A and B are given as arguments.

    Definition Classes
    TypeDescs
  158. implicit class PartialRewriter extends Scalan.Rewriter

    Permalink

    Turns partial function into rewriter (i.e.

    Turns partial function into rewriter (i.e. set of rewriting rules)

    Definition Classes
    Transforming
  159. abstract class Pass extends AnyRef

    Permalink

    Descriptor of a current compiler pass.

    Descriptor of a current compiler pass. Compiler can be configured to perform one pass after another. Each pass has name, configuration parameters, finalizaton logic etc.

    Definition Classes
    Transforming
  160. case class PassConfig(shouldUnpackTuples: Boolean = false, shouldExtractFields: Boolean = true, constantPropagation: Boolean = true, shouldSlice: Boolean = false) extends Product with Serializable

    Permalink

    Configuration parameters of the Pass descriptor.

    Configuration parameters of the Pass descriptor.

    Definition Classes
    Transforming
  161. case class Placeholder[T](eT: Scalan.LElem[T]) extends Scalan.Node with Scalan.Def[T] with Product with Serializable

    Permalink

    Symbols may temporary refer to this node until their target node is updated.

    Symbols may temporary refer to this node until their target node is updated.

    Definition Classes
    Base
  162. trait PreHeader extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.PreHeader]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable()
  163. trait PreHeaderCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  164. case class ProgramGraph(roots: Seq[Scalan.Sym], mapping: Nullable[Scalan.Transformer], filterNode: Nullable[(Scalan.Sym) ⇒ Boolean]) extends Scalan.AstGraph with Product with Serializable

    Permalink

    Immutable graph collected from roots following Ref.node.deps links.

    Immutable graph collected from roots following Ref.node.deps links.

    Definition Classes
    ProgramGraphs
  165. type RCosted[A] = Ref[Costed[A]]

    Permalink
    Definition Classes
    Library
  166. type RFunc[-A, +B] = Ref[(A) ⇒ B]

    Permalink
    Definition Classes
    Base
  167. case class RMethodDesc(method: Method) extends Scalan.MethodDesc with Product with Serializable

    Permalink
    Definition Classes
    TypeDescs
  168. type RPair[+A, +B] = Ref[(A, B)]

    Permalink
    Definition Classes
    Base
  169. type RSize[Val] = Ref[Size[Val]]

    Permalink
    Definition Classes
    Library
  170. trait RTypeWrapSpec extends scalan.Library.Node with scalan.Library.WrapSpecBase

    Permalink
    Definition Classes
    WrappersSpec
  171. trait RTypeWrapSpecCompanion extends AnyRef

    Permalink
    Definition Classes
    WrappersSpec
  172. abstract class Ref[+T] extends AnyRef

    Permalink

    Abstract representation of a computable value.

    Abstract representation of a computable value. Default implementation is a simple lightweight reference to the corresponding definition. Every Ref have direct access to its Def via node property. Every Ref is typed, and the type is avaliable via elem property.

    Definition Classes
    Base
    See also

    SingleRep

  173. implicit class RepBooleanOps extends AnyRef

    Permalink

    Extension methods over Ref[Boolean].

    Extension methods over Ref[Boolean].

    Definition Classes
    LogicalOps
  174. implicit class RepThunkOps[T] extends AnyRef

    Permalink

    Extension methods on Ref[Thunk[T]] values.

    Extension methods on Ref[Thunk[T]] values.

    Definition Classes
    Thunks
  175. implicit class RepUniversalOps[A] extends AnyRef

    Permalink
    Definition Classes
    UniversalOps
  176. trait ReplColl[A] extends scalan.Library.Node with scalan.Library.Coll[A]

    Permalink
    Definition Classes
    Colls
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  177. trait ReplCollCompanion extends AnyRef

    Permalink
    Definition Classes
    Colls
  178. abstract class Rewriter extends AnyRef

    Permalink
    Definition Classes
    Transforming
  179. type SThunk[T] = () ⇒ T

    Permalink

    Runtime representation of lazy values.

    Runtime representation of lazy values. Each Thunk typed graph node evaluates to a value of this type.

    Definition Classes
    Thunks
  180. type Schedule = Seq[Sym]

    Permalink

    Type synonim for graph schedules.

    Type synonim for graph schedules.

    Definition Classes
    AstGraphs
  181. type ScheduleIds = Buffer[Int]

    Permalink

    Alternative representation of schedules using node ids.

    Alternative representation of schedules using node ids.

    Definition Classes
    AstGraphs
  182. case class Second[A, B](pair: Scalan.Ref[(A, B)]) extends Scalan.Node with Scalan.Def[B] with Product with Serializable

    Permalink
    Definition Classes
    Tuples
  183. implicit class SeqExpExtensionsForEmitGraph extends AnyRef

    Permalink
    Definition Classes
    GraphVizExport
  184. trait SigmaContract extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.SigmaContract]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable()
  185. trait SigmaContractCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  186. trait SigmaDslBuilder extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.SigmaDslBuilder]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  187. trait SigmaDslBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  188. trait SigmaProp extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.SigmaProp]

    Permalink
    Definition Classes
    SigmaDsl
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  189. trait SigmaPropCompanion extends AnyRef

    Permalink
    Definition Classes
    SigmaDsl
  190. final class SingleRef[+T] extends Scalan.Ref[T]

    Permalink

    A Ref is a symbolic reference used internally to refer to graph nodes.

    A Ref is a symbolic reference used internally to refer to graph nodes. Light weight stateless immutable reference to a graph node (Def[T]). Two symbols are equal if they refer to the nodes with the same id, which is due to Def unification means equal symbols refer to the same instance of Def.

    Definition Classes
    Base
  191. trait Size[Val] extends scalan.Library.Node with scalan.Library.Def[scalan.Library.Size[Val]]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  192. trait SizeAnyValue extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Size[scalan.SigmaLibrary.AnyValue]

    Permalink
    Definition Classes
    CostedObjects
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  193. trait SizeAnyValueCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedObjects
  194. trait SizeBox extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Size[scalan.SigmaLibrary.Box]

    Permalink
    Definition Classes
    CostedObjects
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  195. trait SizeBoxCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedObjects
  196. trait SizeBuilder extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Def[scalan.SigmaLibrary.SizeBuilder]

    Permalink
    Definition Classes
    CostedObjects
    Annotations
    @Liftable()
  197. trait SizeBuilderCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedObjects
  198. trait SizeColl[Item] extends scalan.Library.Node with scalan.Library.Size[scalan.Library.Coll[Item]]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  199. trait SizeCollCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  200. trait SizeCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  201. trait SizeContext extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Size[scalan.SigmaLibrary.Context]

    Permalink
    Definition Classes
    CostedObjects
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  202. trait SizeContextCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedObjects
  203. trait SizeFunc[Env, Arg, Res] extends scalan.Library.Node with scalan.Library.Size[(Arg) ⇒ Res]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  204. trait SizeFuncCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  205. case class SizeOf[T](value: Scalan.Ref[T]) extends Scalan.BaseDef[Long] with Product with Serializable

    Permalink

    Represents calculation of size in bytes of the given value.

    Represents calculation of size in bytes of the given value. The descriptor value.elem can be used to decompose value into components.

    Definition Classes
    UniversalOps
  206. trait SizeOption[T] extends scalan.Library.Node with scalan.Library.Size[scalan.Library.WOption[T]]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  207. trait SizeOptionCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  208. trait SizePair[L, R] extends scalan.Library.Node with scalan.Library.Size[(L, R)]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  209. trait SizePairCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  210. trait SizePrim[Val] extends scalan.Library.Node with scalan.Library.Size[Val]

    Permalink
    Definition Classes
    Sizes
    Annotations
    @Liftable()
  211. trait SizePrimCompanion extends AnyRef

    Permalink
    Definition Classes
    Sizes
  212. trait SizeSigmaProp extends scalan.SigmaLibrary.Node with scalan.SigmaLibrary.Size[scalan.SigmaLibrary.SigmaProp]

    Permalink
    Definition Classes
    CostedObjects
    Annotations
    @Liftable() @WithMethodCallRecognizers()
  213. trait SizeSigmaPropCompanion extends AnyRef

    Permalink
    Definition Classes
    CostedObjects
  214. trait SpecialPredefWrapSpec extends scalan.Library.Node with scalan.Library.WrapSpecBase

    Permalink
    Definition Classes
    WrappersSpec
  215. trait SpecialPredefWrapSpecCompanion extends AnyRef

    Permalink
    Definition Classes
    WrappersSpec
  216. class StagingException extends RuntimeException

    Permalink
    Definition Classes
    Base
  217. type Subst = HashMap[Sym, Sym]

    Permalink
    Definition Classes
    Functions
  218. case class SumElem[A, B](eLeft: Scalan.Elem[A], eRight: Scalan.Elem[B]) extends Scalan.Elem[Scalan.|[A, B]] with Product with Serializable

    Permalink

    Type descriptor for A | B type where descriptors for A and B are given as arguments.

    Type descriptor for A | B type where descriptors for A and B are given as arguments.

    Definition Classes
    TypeDescs
  219. type Sym = Ref[_]

    Permalink

    Untyped shortcut sinonim of Ref, which is used as untyped reference to graph nodes (definitions).

    Untyped shortcut sinonim of Ref, which is used as untyped reference to graph nodes (definitions). Following a tradition in compiler engineering we call references to definitions as symbols.

    Definition Classes
    Base
  220. type Th[+T] = Ref[Thunk[T]]

    Permalink
    Definition Classes
    Thunks
  221. class ThenIfBranch[T] extends AnyRef

    Permalink

    Defines syntax available after IF (cond) THEN thenp

    Defines syntax available after IF (cond) THEN thenp

    Definition Classes
    IfThenElse
  222. trait Thunk[+A] extends AnyRef

    Permalink

    Phantom type to define thunk-typed graph nodes and thunk based lazy operations.

    Phantom type to define thunk-typed graph nodes and thunk based lazy operations. Usually used inside Ref, see for example Th. See also for details http://gigiigig.github.io/tlp-step-by-step/phantom-types.html

    Definition Classes
    Thunks
  223. class ThunkCompanion extends AnyRef

    Permalink

    A class of factory to create new Thunks by use Thunk { ... } expressions.

    A class of factory to create new Thunks by use Thunk { ... } expressions.

    Definition Classes
    Thunks
  224. case class ThunkConst[ST, T](constValue: Scalan.SThunk[ST], lT: Base.Liftables.Liftable[ST, T]) extends Scalan.BaseDef[Scalan.Thunk[T]] with LiftedConst[Scalan.SThunk[ST], Scalan.Thunk[T]] with Product with Serializable

    Permalink

    Graph node to represent constants of type Thunk.

    Graph node to represent constants of type Thunk.

    Definition Classes
    Thunks
    See also

    scalan.Base.Liftables.Liftable

  225. class ThunkDef[A] extends Scalan.AstGraph with Scalan.Def[Scalan.Thunk[A]]

    Permalink

    Graph node representing thunk with reified body.

    Graph node representing thunk with reified body. Each thunk node is a specialized implementation of AstGraph abstract class.

    Definition Classes
    Thunks
  226. case class ThunkElem[A](eItem: Scalan.Elem[A]) extends Scalan.EntityElem1[A, Scalan.Thunk[A], Scalan.Thunk] with Product with Serializable

    Permalink

    Implements a type descriptor of Thunk[A] type given the instance of A.

    Implements a type descriptor of Thunk[A] type given the instance of A.

    Definition Classes
    Thunks
  227. case class ThunkForce[A](thunk: Scalan.Ref[Scalan.Thunk[A]]) extends Scalan.Node with Scalan.Def[A] with Product with Serializable

    Permalink

    Graph node to represent thunk forcing operation.

    Graph node to represent thunk forcing operation.

    Definition Classes
    Thunks
  228. class ThunkScope extends AnyRef

    Permalink

    Helper object to handle construction of nested thunks.

    Helper object to handle construction of nested thunks. One instance is created for each ThunkDef under construction. This corresponds to syntactic nesting of thunks.

    Definition Classes
    Thunks
  229. class ThunkStack extends AnyRef

    Permalink

    The stack of nested thunks during graph construction.

    The stack of nested thunks during graph construction.

    Definition Classes
    Thunks
  230. case class ToString[A]() extends Scalan.UnOp[A, String] with Product with Serializable

    Permalink
    Definition Classes
    UniversalOps
  231. abstract class Transformer extends AnyRef

    Permalink

    Base class for Ref to Ref transformations.

    Base class for Ref to Ref transformations. Each transformer keeps a mapping data between references to original nodes and references to the corresponding transformed nodes.

    Definition Classes
    Base
  232. case class Tup[A, B](a: Scalan.Ref[A], b: Scalan.Ref[B]) extends Scalan.Node with Scalan.Def[(A, B)] with Product with Serializable

    Permalink
    Definition Classes
    Tuples
  233. implicit class TupleOps2[A, B] extends AnyRef

    Permalink
    Definition Classes
    Tuples
  234. implicit class TupleOps3[A, B, C] extends AnyRef

    Permalink
    Definition Classes
    Tuples
  235. implicit class TupleOps4[A, B, C, D] extends AnyRef

    Permalink
    Definition Classes
    Tuples
  236. implicit class TupleOps5[A, B, C, D, E] extends AnyRef

    Permalink
    Definition Classes
    Tuples
  237. abstract class TypeDesc extends Serializable

    Permalink
    Definition Classes
    TypeDescs
  238. abstract class UnOp[A, R] extends AnyRef

    Permalink

    Base class for descriptors of unary operations.

    Base class for descriptors of unary operations.

    Definition Classes
    UnBinOps
  239. case class Upcast[From, To](input: Scalan.Ref[From], eTo: Scalan.Elem[To]) extends Scalan.BaseDef[To] with Product with Serializable

    Permalink
    Definition Classes
    UniversalOps
  240. case class Variable[T](varId: Int)(implicit eT: Scalan.LElem[T]) extends Scalan.Node with Scalan.Def[T] with Product with Serializable

    Permalink

    Node class for typed variables.

    Node class for typed variables. In particular for lambda-bound variables.

    varId

    is independent from nodeId, shouldn't be used as node id.

    eT

    type descriptor of the variable type

    Definition Classes
    Base
  241. case class WMethodDesc(wrapSpec: WrapSpec, method: Method) extends Scalan.MethodDesc with Product with Serializable

    Permalink
    Definition Classes
    TypeDescs
  242. trait WOption[A] extends special.wrappers.WrappersModule.Node with special.wrappers.WrappersModule.Def[special.wrappers.WrappersModule.WOption[A]]

    Permalink
    Definition Classes
    WOptions
    Annotations
    @External() @ContainerType() @FunctorType() @Liftable() @WithMethodCallRecognizers()
  243. trait WOptionCompanion extends AnyRef

    Permalink
    Definition Classes
    WOptions
  244. trait WRType[A] extends special.wrappers.WrappersModule.Node with special.wrappers.WrappersModule.Def[special.wrappers.WrappersModule.WRType[A]]

    Permalink
    Definition Classes
    WRTypes
    Annotations
    @External() @Liftable() @WithMethodCallRecognizers()
  245. trait WRTypeCompanion extends AnyRef

    Permalink
    Definition Classes
    WRTypes
  246. trait WSpecialPredef extends special.wrappers.WrappersModule.Node with special.wrappers.WrappersModule.Def[special.wrappers.WrappersModule.WSpecialPredef]

    Permalink
    Definition Classes
    WSpecialPredefs
    Annotations
    @External() @WithMethodCallRecognizers()
  247. trait WSpecialPredefCompanion extends AnyRef

    Permalink
    Definition Classes
    WSpecialPredefs
  248. trait WrapSpecBase extends scalan.Library.Node with scalan.Library.Def[scalan.Library.WrapSpecBase] with WrapSpec

    Permalink
    Definition Classes
    WrappersSpec
  249. trait WrapSpecBaseCompanion extends AnyRef

    Permalink
    Definition Classes
    WrappersSpec
  250. type |[+A, +B] = Either[A, B]

    Permalink
    Definition Classes
    Base

Abstract Value Members

  1. abstract def colBuilder: Ref[CollBuilder]

    Permalink
    Definition Classes
    Library
  2. abstract def costedBuilder: Ref[CostedBuilder]

    Permalink
    Definition Classes
    Library
  3. abstract def intPlusMonoid: Ref[Monoid[Int]]

    Permalink
    Definition Classes
    Library
  4. abstract def longPlusMonoid: Ref[Monoid[Long]]

    Permalink
    Definition Classes
    Library
  5. abstract def sigmaDslBuilder: Ref[SigmaDslBuilder]

    Permalink

Concrete Value Members

  1. def !!!(msg: String, e: Throwable, syms: Ref[_]*): Nothing

    Permalink
    Definition Classes
    Base
  2. def !!!(msg: String, syms: Ref[_]*): Nothing

    Permalink
    Definition Classes
    Base
  3. def !!!: Nothing

    Permalink

    Helper methods to throw errors

    Helper methods to throw errors

    Definition Classes
    Base
  4. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  5. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  6. object &&

    Permalink

    Logical AND between two pattern matches of the save value x.

    Logical AND between two pattern matches of the save value x. Can be used to construct patterns like case P1 && P2 => ...

    Definition Classes
    Base
  7. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  8. def ???(value: Any, syms: Ref[_]*): Nothing

    Permalink
    Definition Classes
    Base
  9. def ???: Nothing

    Permalink
    Definition Classes
    Base
  10. val And: EndoBinOp[Boolean]

    Permalink

    Logical AND binary operation.

    Logical AND binary operation.

    Definition Classes
    LogicalOps
  11. val AnyElement: Elem[Any]

    Permalink

    Type descriptor for Any, cannot be used implicitly.

    Type descriptor for Any, cannot be used implicitly.

    Definition Classes
    TypeDescs
  12. val AnyRefElement: Elem[AnyRef]

    Permalink

    Type descriptor for AnyRef, cannot be used implicitly.

    Type descriptor for AnyRef, cannot be used implicitly.

    Definition Classes
    TypeDescs
  13. object AnyValue extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  14. object AvlTree extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  15. object BigInt extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  16. val BinaryXorOp: EndoBinOp[Boolean]

    Permalink

    Logical XOR binary operation.

    Logical XOR binary operation.

    Definition Classes
    LogicalOps
  17. implicit val BooleanElement: Elem[Boolean]

    Permalink
    Definition Classes
    TypeDescs
  18. val BooleanToInt: UnOp[Boolean, Int]

    Permalink

    Boolean to Int conversion unary operation.

    Boolean to Int conversion unary operation.

    Definition Classes
    LogicalOps
  19. object Box extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  20. implicit val ByteElement: Elem[Byte]

    Permalink
    Definition Classes
    TypeDescs
  21. object CCostedBuilder extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteCostsDefs
  22. object CCostedColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteCostsDefs
  23. object CCostedFunc extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteCostsDefs
  24. object CCostedOption extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostedOptionsDefs
  25. object CCostedPair extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteCostsDefs
  26. object CCostedPrim extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteCostsDefs
  27. val CM: CollMethods.type

    Permalink
    Definition Classes
    Library
  28. object CSizeColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteSizesDefs
  29. object CSizeFunc extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteSizesDefs
  30. object CSizeOption extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteSizesDefs
  31. object CSizePair extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteSizesDefs
  32. object CSizePrim extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    ConcreteSizesDefs
  33. implicit val CharElement: Elem[Char]

    Permalink
    Definition Classes
    TypeDescs
  34. object Coll extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CollsDefs
  35. object CollBuilder extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CollsDefs
  36. object ConstantLambda

    Permalink

    Matcher for lambdas which don't depend on their arguments (but can close over other expressions, unlike VeryConstantLambda).

    Matcher for lambdas which don't depend on their arguments (but can close over other expressions, unlike VeryConstantLambda).

    Definition Classes
    Functions
  37. object ConstantThunk

    Permalink
    Definition Classes
    Thunks
  38. object Context extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  39. object CostModel extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  40. object Costed extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  41. object CostedBuilder extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  42. object CostedColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  43. object CostedFunc extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  44. object CostedOption extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  45. object CostedPair extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  46. object CostedPrim extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CostsDefs
  47. object Def

    Permalink
    Definition Classes
    Base
  48. val DefaultMirror: Mirror

    Permalink

    Default Mirror instance which is used in core IR methods.

    Default Mirror instance which is used in core IR methods.

    Definition Classes
    Transforming
  49. implicit val DoubleElement: Elem[Double]

    Permalink
    Definition Classes
    TypeDescs
  50. object Elem extends Serializable

    Permalink
    Definition Classes
    TypeDescs
  51. val EmptyArrayOfSym: Array[Sym]

    Permalink

    Immutable empty array of symbols, can be used to avoid unnecessary allocations.

    Immutable empty array of symbols, can be used to avoid unnecessary allocations.

    Definition Classes
    Base
  52. val EmptyDSetOfInt: Set[Int]

    Permalink

    Used internally in IR and should be used with care since it is mutable.

    Used internally in IR and should be used with care since it is mutable. At the same time, it is used in the hotspot and allows to avoid roughly tens of thousands of allocations per second. WARNING: Mutations of this instance can lead to undefined behavior.

    Attributes
    protected
    Definition Classes
    Base
  53. val EmptySeqOfSym: Seq[Sym]

    Permalink

    Immutable empty Seq, can be used to avoid unnecessary allocations.

    Immutable empty Seq, can be used to avoid unnecessary allocations.

    Definition Classes
    Base
  54. val EmptyTypeArgs: ListMap[String, (TypeDesc, Variance)]

    Permalink

    Since ListMap is immutable this empty map can be shared by all other maps created from it.

    Since ListMap is immutable this empty map can be shared by all other maps created from it.

    Definition Classes
    TypeDescs
  55. object EnvRep extends Serializable

    Permalink
    Definition Classes
    TypeDescs
  56. object ExpWithElem

    Permalink
    Definition Classes
    Base
  57. implicit val FloatElement: Elem[Float]

    Permalink
    Definition Classes
    TypeDescs
  58. implicit final def FuncElemExtensions[A, B](eAB: Elem[(A) ⇒ B]): FuncElem[A, B]

    Permalink
    Definition Classes
    TypeDescs
  59. object GroupElement extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  60. object Header extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  61. def IF(cond: Ref[Boolean]): IfBranch

    Permalink

    If c then t else e construction with standard lazy evaluation of branches.

    If c then t else e construction with standard lazy evaluation of branches. The representation uses Thunk for each branch

    Definition Classes
    IfThenElse
  62. object IdentityLambda

    Permalink
    Definition Classes
    Functions
  63. implicit val IntElement: Elem[Int]

    Permalink
    Definition Classes
    TypeDescs
  64. object IntPlusMonoid extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    MonoidInstancesDefs
  65. final def IntZero: Ref[Int]

    Permalink

    Zero literal node, which is lazily created and can be efficiently reused.

    Zero literal node, which is lazily created and can be efficiently reused. Much faster alternative to (0: Rep[Int]) or toRep(0).

    Definition Classes
    Base
    Annotations
    @inline()
  66. object InvokeImpossible extends Scalan.InvokeResult with Product with Serializable

    Permalink

    Invocation is not possible, e.g.

    Invocation is not possible, e.g. when receiver doesn't implemented the method.

    Definition Classes
    MethodCalls
  67. object IsNumericToInt

    Permalink
    Definition Classes
    Library
  68. object IsNumericToLong

    Permalink
    Definition Classes
    Library
  69. object IsPair

    Permalink
    Definition Classes
    Tuples
  70. object Lambda

    Permalink
    Definition Classes
    Functions
  71. val LazyAnyElement: Lazy[Elem[Any]]

    Permalink

    Predefined Lazy value saved here to be used in hotspot code.

    Predefined Lazy value saved here to be used in hotspot code.

    Definition Classes
    TypeDescs
  72. object Liftables

    Permalink

    Data type ST is liftable is there is Liftable[ST, T] instance for some type T.

    Data type ST is liftable is there is Liftable[ST, T] instance for some type T. Liftable typeclass allows to define which types can have values embedded as literals into graph IR.

    Definition Classes
    Base
  73. implicit val LongElement: Elem[Long]

    Permalink
    Definition Classes
    TypeDescs
  74. object LongPlusMonoid extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    MonoidInstancesDefs
  75. object MapTransformer extends Serializable

    Permalink
    Definition Classes
    Transforming
  76. object Monoid extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    MonoidsDefs
  77. object MonoidBuilder extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    MonoidsDefs
  78. object MonoidBuilderInst extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    MonoidInstancesDefs
  79. object NoOwner extends Scalan.OwnerKind with Product with Serializable

    Permalink
    Definition Classes
    Base
  80. val NoRewriting: Rewriter

    Permalink

    Identity rewriter, i.e.

    Identity rewriter, i.e. doesn't change the graph when applied.

    Definition Classes
    Transforming
  81. val Not: EndoUnOp[Boolean]

    Permalink

    Logical NOT unary operation.

    Logical NOT unary operation.

    Definition Classes
    LogicalOps
  82. val NothingElement: Elem[Nothing]

    Permalink
    Definition Classes
    TypeDescs
  83. object OptionWrapSpec extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    WrappersSpecDefs
  84. val Or: EndoBinOp[Boolean]

    Permalink

    Logical AND binary operation.

    Logical AND binary operation.

    Definition Classes
    LogicalOps
  85. implicit def OrderingToOrderingOps[T](x: T)(implicit n: ExactOrdering[T], et: Elem[T]): OrderingOpsCls[T]

    Permalink
    Definition Classes
    OrderingOps
  86. object Pair

    Permalink
    Definition Classes
    Tuples
  87. object PairColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CollsDefs
  88. implicit final def PairElemExtensions[A, B](eAB: Elem[(A, B)]): PairElem[A, B]

    Permalink
    Definition Classes
    TypeDescs
  89. object Pass

    Permalink
    Definition Classes
    Transforming
  90. object PreHeader extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  91. object ProgramGraph extends Serializable

    Permalink
    Definition Classes
    ProgramGraphs
  92. object RTypeWrapSpec extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    WrappersSpecDefs
  93. object ReplColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    CollsDefs
  94. object ScalanOwner extends Scalan.OwnerKind with Product with Serializable

    Permalink
    Definition Classes
    Base
  95. implicit val ShortElement: Elem[Short]

    Permalink
    Definition Classes
    TypeDescs
  96. object SigmaContract extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  97. object SigmaDslBuilder extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  98. object SigmaProp extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    SigmaDslDefs
  99. object Size extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  100. object SizeAnyValue extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    CostedObjectsDefs
  101. object SizeBox extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    CostedObjectsDefs
  102. object SizeBuilder extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    CostedObjectsDefs
  103. object SizeColl extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  104. object SizeContext extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    CostedObjectsDefs
  105. object SizeFunc extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  106. object SizeOption extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  107. object SizePair extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  108. object SizePrim extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    SizesDefs
  109. object SizeSigmaProp extends scalan.SigmaLibrary.EntityObject

    Permalink
    Definition Classes
    CostedObjectsDefs
  110. object SpecialPredefWrapSpec extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    WrappersSpecDefs
  111. implicit val StringElement: Elem[String]

    Permalink
    Definition Classes
    TypeDescs
  112. implicit final def SumElemExtensions[A, B](eAB: Elem[|[A, B]]): SumElem[A, B]

    Permalink
    Definition Classes
    TypeDescs
  113. val Thunk: ThunkCompanion

    Permalink

    Allow expressions like Thunk { ... } to create new Thunks.

    Allow expressions like Thunk { ... } to create new Thunks.

    Definition Classes
    Thunks
  114. object ThunkDef

    Permalink
    Definition Classes
    Thunks
  115. final def TypeArgs(descs: (String, (TypeDesc, Variance))*): ListMap[String, (TypeDesc, Variance)]

    Permalink
    Definition Classes
    TypeDescs
  116. implicit val UnitElement: Elem[Unit]

    Permalink
    Definition Classes
    TypeDescs
  117. object VeryConstantLambda

    Permalink

    Matcher for lambdas which return staging-time constants.

    Matcher for lambdas which return staging-time constants. VeryConstantLambda(x) should be equivalent to ConstantLambda(Def(Const(x)))

    Definition Classes
    Functions
  118. object WOption extends special.wrappers.WrappersModule.EntityObject

    Permalink
    Definition Classes
    WOptionsDefs
  119. object WRType extends special.wrappers.WrappersModule.EntityObject

    Permalink
    Definition Classes
    WRTypesDefs
  120. object WSpecialPredef extends special.wrappers.WrappersModule.EntityObject

    Permalink
    Definition Classes
    WSpecialPredefsDefs
  121. object WrapSpecBase extends scalan.Library.EntityObject

    Permalink
    Definition Classes
    WrappersSpecDefs
  122. var _currentPass: Pass

    Permalink
    Definition Classes
    Transforming
  123. def alphaEqual(s1: Sym, s2: Sym): Boolean

    Permalink
    Definition Classes
    Functions
  124. def applyBinOp[A, R](op: BinOp[A, R], lhs: Ref[A], rhs: Ref[A]): Ref[R]

    Permalink

    Overridable constructor of a binary operation node.

    Overridable constructor of a binary operation node.

    Definition Classes
    UnBinOps
  125. def applyBinOpLazy[A, R](op: BinOp[A, R], lhs: Ref[A], rhs: Ref[Thunk[A]]): Ref[R]

    Permalink

    Overridable constructor of a binary operation node with lazy argument.

    Overridable constructor of a binary operation node with lazy argument.

    Definition Classes
    UnBinOps
  126. def applyUnOp[A, R](op: UnOp[A, R], arg: Ref[A]): Ref[R]

    Permalink

    Overridable constructor of an unary operation node.

    Overridable constructor of an unary operation node.

    Definition Classes
    UnBinOps
  127. final def asElem[T](d: TypeDesc): Elem[T]

    Permalink

    Helper type case method.

    Helper type case method.

    Definition Classes
    TypeDescs
    Annotations
    @inline()
  128. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  129. final def asRep[T](x: Ref[_]): Ref[T]

    Permalink

    Helper to type cast node references.

    Helper to type cast node references.

    Definition Classes
    Base
    Annotations
    @inline()
  130. def assertElem(value: Ref[_], elem: Elem[_], hint: ⇒ String): Unit

    Permalink
    Definition Classes
    TypeDescs
  131. def assertElem(value: Ref[_], elem: Elem[_]): Unit

    Permalink
    Definition Classes
    TypeDescs
  132. def assertEqualElems[A](e1: Elem[A], e2: Elem[A], m: ⇒ String): Unit

    Permalink
    Definition Classes
    TypeDescs
  133. def assertValueIdForOpCost[A, B](value: Ref[A], cost: Ref[B]): Unit

    Permalink
    Definition Classes
    UniversalOps
  134. def beginPass(pass: Pass): Unit

    Permalink

    Called to setup IR before the new pass is executed.

    Called to setup IR before the new pass is executed.

    Definition Classes
    Transforming
  135. val cacheElems: Boolean

    Permalink

    Whether IR type descriptors should be cached.

    Whether IR type descriptors should be cached.

    Definition Classes
    Base
  136. val cachePairs: Boolean

    Permalink

    Whether Tup instances should be cached.

    Whether Tup instances should be cached.

    Definition Classes
    Base
  137. final def cachedElemByClass[E <: Elem[_]](args: AnyRef*)(implicit clazz: Class[E]): E

    Permalink

    Retrieve an instance of the given Elem class by either looking up in the cache or creating a new one.

    Retrieve an instance of the given Elem class by either looking up in the cache or creating a new one. We assume that all Elem instances are uniquely defined by (clazz, args)

    args

    arguments of Elem class constructor

    clazz

    Elem class

    Definition Classes
    TypeDescs
  138. def canBeInvoked(d: Def[_], m: Method, args: Array[AnyRef]): Boolean

    Permalink

    Method invocation checker.

    Method invocation checker.

    Attributes
    protected
    Definition Classes
    MethodCalls
  139. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  140. def clusterColor(g: AstGraph): Option[String]

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  141. def clusterSchedule(g: AstGraph): Seq[Sym]

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  142. def compose[A, B, C](f: Ref[(B) ⇒ C], g: Ref[(A) ⇒ B]): Ref[(A) ⇒ C]

    Permalink

    Composition of two functions (in mathematical notation), where first g is applied and them f.

    Composition of two functions (in mathematical notation), where first g is applied and them f.

    Definition Classes
    Functions
  143. def constFun[A, B](x: Ref[B])(implicit e: Elem[A]): Ref[(A) ⇒ B]

    Permalink
    Definition Classes
    Functions
  144. final def container[F[_]](implicit arg0: Cont[F]): Cont[F]

    Permalink
    Definition Classes
    TypeDescs
  145. implicit final def containerElem[F[_], A](implicit arg0: Cont[F], arg1: Elem[A]): Elem[F[A]]

    Permalink
    Definition Classes
    TypeDescs
  146. def createDefinition[T](optScope: Nullable[ThunkScope], s: Ref[T], d: Def[T]): Ref[T]

    Permalink

    Create new definition entry in either given Thunk or in the global hash table.

    Create new definition entry in either given Thunk or in the global hash table.

    optScope

    optional thunk scope to put given definition

    s

    symbol refering to d

    d

    definition node to add to the scope of globally

    returns

    reference to d (which is s)

    Attributes
    protected
    Definition Classes
    Base
  147. def currentPass: Pass

    Permalink

    IR global current Pass, changes when the compier switches from one pass to the next one.

    IR global current Pass, changes when the compier switches from one pass to the next one. Should remain constant during the whole pass execution.

    Definition Classes
    Transforming
  148. val debugModeSanityChecks: Boolean

    Permalink

    Whether to perform extended checks of correctness, expected invariants and data consistency.

    Whether to perform extended checks of correctness, expected invariants and data consistency. NOTE: Since it may add substantial overhead, set it to false before using in production.

    Definition Classes
    Base
  149. def defCount: Int

    Permalink

    Returns a number of definitions added to this IR context.

    Returns a number of definitions added to this IR context.

    Definition Classes
    Base
  150. def def_unapply[T](e: Ref[T]): Nullable[Def[T]]

    Permalink
    Definition Classes
    Base
  151. def defaultGraphVizConfig: GraphVizConfig

    Permalink
    Definition Classes
    GraphVizExport
  152. def delayInvoke: Nothing

    Permalink
    Definition Classes
    MethodCalls
  153. def downcast[To](value: Ref[_])(implicit arg0: Elem[To]): Ref[To]

    Permalink
    Definition Classes
    UniversalOps
  154. val elemCache: AVHashMap[Class[_], ElemCacheEntry]

    Permalink
    Attributes
    protected
    Definition Classes
    TypeDescs
  155. final def element[A](implicit ea: Elem[A]): Elem[A]

    Permalink
    Definition Classes
    TypeDescs
  156. def emitDepGraph(exceptionOrGraph: Either[Throwable, AstGraph], directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  157. def emitDepGraph(graph: AstGraph, directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  158. def emitDepGraph(ss: Seq[Sym], directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  159. def emitDepGraph(start: Sym, directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  160. def emitDepGraph(d: Def[_], directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  161. def emitDot(dotText: String, directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  162. def emitExceptionGraph(e: Throwable, directory: File, fileName: String)(implicit config: GraphVizConfig): Option[GraphFile]

    Permalink
    Definition Classes
    GraphVizExport
  163. final def emptyDBufferOfSym: Buffer[Sym]

    Permalink

    Create a new empty buffer around pre-allocated empty array.

    Create a new empty buffer around pre-allocated empty array. This method is preferred, rather that creating empty debox.Buffer directly because it allows to avoid allocation of the empty array.

    Definition Classes
    Base
    Annotations
    @inline()
  164. def emptyMatchSubst: Subst

    Permalink
    Definition Classes
    Functions
    Annotations
    @inline()
  165. def endPass(pass: Pass): Unit

    Permalink

    Called to let this IR context to finalized the given pass.

    Called to let this IR context to finalized the given pass.

    Definition Classes
    Transforming
  166. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  167. def equalValues[A](x: Any, y: Any)(implicit eA: Elem[A]): Boolean

    Permalink
    Attributes
    protected
    Definition Classes
    Equal
  168. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  169. implicit def extendThunkElement[T](elem: Elem[Thunk[T]]): ThunkElem[T]

    Permalink

    Implicit conversion (downcast) to access ThunkElem.eItem field.

    Implicit conversion (downcast) to access ThunkElem.eItem field.

    Definition Classes
    Thunks
  170. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  171. def findGlobalDefinition[T](d: Def[T]): Ref[T]

    Permalink

    Lookup definition in this IR context's hash table of definitions.

    Lookup definition in this IR context's hash table of definitions.

    returns

    node reference to an instance stored in hash table, which is equal to d and null if there is no definition which is equal to d

    Definition Classes
    Base
  172. def findOrCreateDefinition[T](d: Def[T], newSym: ⇒ Ref[T]): Ref[T]

    Permalink

    Lookup d in the heap of nodes.

    Lookup d in the heap of nodes. If the lookup is successfull, then its reference is returned. If the node is not found in the heap, then it is added and d.self reference is returned.

    d

    node to be added to the head of nodes

    newSym

    producer of the reference to be used as the reference to d node.

    returns

    return a reference to d node in the heap

    Definition Classes
    Base
  173. def forceThunkByMirror[A](thunk: Th[A], subst: MapTransformer = MapTransformer.empty()): Ref[A]

    Permalink

    Inlines the given thunk by cloning all its nodes and applying the given substitution (transformer).

    Inlines the given thunk by cloning all its nodes and applying the given substitution (transformer).

    thunk

    reference to the thunk node

    subst

    transformer to be applied for each mirrored (cloned) node.

    returns

    the reference to the graph node, which represents the resulting value of the thunk

    Definition Classes
    Thunks
  174. def forceThunkDefByMirror[A](th: ThunkDef[A], subst: MapTransformer = MapTransformer.empty()): Ref[A]

    Permalink

    Inlines the given thunk by cloning all its nodes and applying the given substitution (transformer).

    Inlines the given thunk by cloning all its nodes and applying the given substitution (transformer).

    th

    the thunk node

    subst

    transformer to be applied for each mirrored (cloned) node.

    returns

    the reference to the graph node, which represents the resulting value of the thunk

    Definition Classes
    Thunks
  175. def formatConst(x: Any): String

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  176. def formatDef(d: Def[_])(implicit config: GraphVizConfig): String

    Permalink
    Attributes
    protected
    Definition Classes
    ThunksGraphVizExport
  177. def formatMetadata(s: Sym): List[String]

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  178. final def freshId: Int

    Permalink

    Get next fresh node id

    Get next fresh node id

    Definition Classes
    Base
    Annotations
    @inline()
  179. final def freshSym[T](d: Def[T]): Ref[T]

    Permalink

    Lookup of create reference to the given definition.

    Lookup of create reference to the given definition. To lookup d.nodeId is used as the index in the _symbolTable. If Ref is not found in _symbolTable, then new Ref instance is created and stored in _symbolTable at d.nodeId index.

    Definition Classes
    Base
    Annotations
    @inline()
  180. implicit final def fun[A, B](f: (Ref[A]) ⇒ Ref[B])(implicit eA: LElem[A]): Ref[(A) ⇒ B]

    Permalink

    Executes given lambda to construct Lambda node.

    Executes given lambda to construct Lambda node. The function f can be called with any symbol and has an effect of growing a graph starting from the argument symbol. If a reference to Variable node is passed as argument, then the constructed graph nodes can be collected to Lambda node forming its body and schedule.

    f

    function which execution will create body nodes

    eA

    arguments type descriptor

    Definition Classes
    Functions
  181. implicit final def fun2[A, B, C](f: (Ref[A], Ref[B]) ⇒ Ref[C])(implicit eA: LElem[A], eB: LElem[B]): Ref[((A, B)) ⇒ C]

    Permalink
    Definition Classes
    Functions
  182. implicit final def funcElement[A, B](implicit ea: Elem[A], eb: Elem[B]): Elem[(A) ⇒ B]

    Permalink
    Definition Classes
    TypeDescs
  183. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  184. def getEntityObject(name: String): Nullable[EntityObject]

    Permalink
    Definition Classes
    Base
    Annotations
    @inline()
  185. def getOwnerKind(constructor: java.lang.reflect.Constructor[_]): OwnerKind

    Permalink

    Returns OwnerKind for the given constructor, using its first parameter.

    Returns OwnerKind for the given constructor, using its first parameter.

    Attributes
    protected
    Definition Classes
    Base
  186. final def getSourceValues(dataEnv: DataEnv, forWrapper: Boolean, stagedValues: AnyRef*): Seq[AnyRef]

    Permalink
    Definition Classes
    TypeDescs
  187. final def getSym(id: Int): Sym

    Permalink

    Lookup node reference by its id.

    Lookup node reference by its id. This is simple array access by index O(1) operation.

    Definition Classes
    Base
    Annotations
    @inline()
  188. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  189. def identityFun[A](implicit e: Elem[A]): Ref[(A) ⇒ A]

    Permalink
    Definition Classes
    Functions
  190. def ifThenElseLazy[T](cond: Ref[Boolean], thenp: ⇒ Ref[T], elsep: ⇒ Ref[T]): Ref[T]

    Permalink

    Constructs IfThenElse node wrapping by-name args into ThunkDef nodes.

    Constructs IfThenElse node wrapping by-name args into ThunkDef nodes.

    Definition Classes
    IfThenElse
  191. val intPlusMonoidValue: special.collection.IntPlusMonoid

    Permalink
    Definition Classes
    Library
  192. def integral[T](implicit arg0: ExactIntegral[T]): ExactIntegral[T]

    Permalink

    Return an ExactIntegral for a given type T.

    Return an ExactIntegral for a given type T.

    Definition Classes
    NumericOps
  193. def invokeUnlifted(e: Elem[_], mc: MethodCall, dataEnv: DataEnv): AnyRef

    Permalink

    Invoke source type method corresponding to the given MethodCall node.

    Invoke source type method corresponding to the given MethodCall node. This method delegated the work to the given element instance.

    e

    type descriptor of receiver node

    mc

    IR node representing method invocation

    dataEnv

    environment where each symbol of 'mc' has associated data value

    returns

    data value returned from invoked method

    Definition Classes
    LibraryTypeDescs
  194. var isInlineThunksOnForce: Boolean

    Permalink

    Specifies thunk staging strategy with respect to handling thunk_force operation.

    Specifies thunk staging strategy with respect to handling thunk_force operation.

    Definition Classes
    Thunks
    See also

    thunk_force

  195. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  196. def isInvokeEnabled(d: Def[_], m: Method): Boolean

    Permalink

    Method invocation enabler.

    Method invocation enabler.

    returns

    true if the given method can be invoked on the given node.

    Definition Classes
    MethodCalls
  197. final def isOne[T](x: T, n: ExactNumeric[T]): Boolean

    Permalink

    Compares the given value with 1 of the given ExactNumeric instance.

    Compares the given value with 1 of the given ExactNumeric instance.

    Definition Classes
    NumericOps
    Annotations
    @inline()
  198. final def isZero[T](x: T, n: ExactNumeric[T]): Boolean

    Permalink

    Compares the given value with zero of the given ExactNumeric instance.

    Compares the given value with zero of the given ExactNumeric instance.

    Definition Classes
    NumericOps
    Annotations
    @inline()
  199. var keepOriginalFunc: Boolean

    Permalink

    Global flag governing lambda reification in fun and mkLambda.

    Global flag governing lambda reification in fun and mkLambda. If this flag is true then original f: Ref[A] => Ref[B] function is stored in Lambda node. As a consequence if f is not stored, then unfoldLambda is done by mirrorLambda.

    Definition Classes
    Functions
  200. var lambdaStack: List[Lambda[_, _]]

    Permalink
    Definition Classes
    Functions
  201. implicit def liftElem[T](eT: Elem[T]): Ref[WRType[T]]

    Permalink
    Definition Classes
    Library
  202. implicit def liftToRep[A](x: A)(implicit arg0: Elem[A]): Ref[A]

    Permalink
    Definition Classes
    Base
    Annotations
    @inline()
  203. implicit def liftableThunk[ST, T](implicit lT: Base.Liftables.Liftable[ST, T]): Base.Liftables.Liftable[SThunk[ST], Thunk[T]]

    Permalink
    Definition Classes
    Thunks
  204. def logWarn(msg: ⇒ String): Unit

    Permalink

    Log warning message to the log.

    Log warning message to the log. This is default and simple implementation, which can be overriden.

    Definition Classes
    Base
  205. val longPlusMonoidValue: special.collection.LongPlusMonoid

    Permalink
    Definition Classes
    Library
  206. def matchAny(a1: Any, a2: Any, allowInexactMatch: Boolean, subst: Subst): Nullable[Subst]

    Permalink
    Attributes
    protected
    Definition Classes
    Functions
  207. def matchDefs(d1: Def[_], d2: Def[_], allowInexactMatch: Boolean, subst: Subst): Nullable[Subst]

    Permalink
    Attributes
    protected
    Definition Classes
    ThunksFunctions
  208. def matchExps(s1: Sym, s2: Sym, allowInexactMatch: Boolean, subst: Subst): Nullable[Subst]

    Permalink
    Attributes
    protected
    Definition Classes
    Functions
  209. def matchIterators(i1: Iterator[_], i2: Iterator[_], allowInexactMatch: Boolean, subst: Subst): Nullable[Subst]

    Permalink
    Attributes
    protected
    Definition Classes
    Functions
  210. def mirrorApply[A, B](lam: Lambda[A, B], s: Ref[A]): Ref[B]

    Permalink
    Definition Classes
    Functions
  211. def mkApply[A, B](f: Ref[(A) ⇒ B], x: Ref[A]): Ref[B]

    Permalink
    Definition Classes
    Functions
  212. def mkLambda[A, B, C](f: (Ref[A], Ref[B]) ⇒ Ref[C])(implicit eA: LElem[A], eB: LElem[B]): Ref[((A, B)) ⇒ C]

    Permalink
    Definition Classes
    Functions
  213. def mkLambda[A, B, C](f: (Ref[A]) ⇒ (Ref[B]) ⇒ Ref[C])(implicit eA: LElem[A], eB: Elem[B]): Ref[(A) ⇒ (B) ⇒ C]

    Permalink
    Definition Classes
    Functions
  214. def mkLambda[A, B](f: (Ref[A]) ⇒ Ref[B], mayInline: Boolean, alphaEquality: Boolean, keepOriginalFunc: Boolean)(implicit eA: LElem[A]): Ref[(A) ⇒ B]

    Permalink
    Definition Classes
    Functions
  215. def mkMethodCall(receiver: Sym, method: Method, args: Seq[AnyRef], neverInvoke: Boolean, isAdapterCall: Boolean, resultElem: Elem[_]): Sym

    Permalink

    Creates new MethodCall node and returns its node ref.

    Creates new MethodCall node and returns its node ref.

    Definition Classes
    MethodCalls
  216. val nInitialDefs: Int

    Permalink
    Definition Classes
    Base
  217. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  218. def newObjEx[A](args: Any*)(implicit eA: Elem[A]): Ref[A]

    Permalink

    Creates new NewObject node and returns its node ref.

    Creates new NewObject node and returns its node ref.

    Definition Classes
    MethodCalls
  219. def nodeColor(td: TypeDesc, d: Def[_])(implicit config: GraphVizConfig): String

    Permalink
    Attributes
    protected
    Definition Classes
    ThunksGraphVizExport
  220. def nodeColor(td: TypeDesc): String

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  221. final def nodeLabel(parts: String*)(implicit config: GraphVizConfig): String

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  222. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  223. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  224. def numeric[T](implicit arg0: ExactNumeric[T]): ExactNumeric[T]

    Permalink

    Return an ExactNumeric for a given type T.

    Return an ExactNumeric for a given type T.

    Definition Classes
    NumericOps
  225. def okRegisterModules: Boolean

    Permalink

    Whether staged modules should be registered when cake is constructed and initialized.

    Whether staged modules should be registered when cake is constructed and initialized.

    Definition Classes
    Modules
  226. def onReset(): Unit

    Permalink

    Called during resetContext() operation after the core context state has been reset.

    Called during resetContext() operation after the core context state has been reset. Derived classes can override to define application specific initialization. Don't forget to call super method in the beginning of your overriding method.

    Attributes
    protected
    Definition Classes
    LibraryBase
  227. def opCost(costedValue: Sym, args: Seq[Ref[Int]], opCost: Ref[Int]): Ref[Int]

    Permalink
    Definition Classes
    UniversalOps
  228. implicit final def pairElement[A, B](implicit ea: Elem[A], eb: Elem[B]): Elem[(A, B)]

    Permalink
    Definition Classes
    TypeDescs
  229. def partsIterator(td: TypeDesc): TraversableOnce[TypeDesc] { def seq: scala.collection.TraversableOnce[SigmaLibrary.this.TypeDesc]{def seq: scala.collection.TraversableOnce[SigmaLibrary.this.TypeDesc]{def seq: scala.collection.TraversableOnce[SigmaLibrary.this.TypeDesc]}} }

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  230. def patternMatch(s1: Sym, s2: Sym): Nullable[Subst]

    Permalink
    Definition Classes
    Functions
  231. def placeholder[T](implicit eT: LElem[T]): Ref[T]

    Permalink
    Definition Classes
    Base
    Annotations
    @inline()
  232. def propagateBinOp[T, R](op: BinOp[T, R], x: Ref[T], y: Ref[T]): Ref[R]

    Permalink

    Perform constant propagation if enabled and both arguments are Const.

    Perform constant propagation if enabled and both arguments are Const.

    returns

    null if propagation is not done

    Definition Classes
    DefRewriting
  233. def propagateUnOp[T, R](op: UnOp[T, R], x: Ref[T]): Ref[R]

    Permalink

    Perform constant propagation if enabled and argument is Const.

    Perform constant propagation if enabled and argument is Const.

    returns

    null if propagation is not done

    Definition Classes
    DefRewriting
  234. def registerEntityObject(name: String, obj: EntityObject): Unit

    Permalink
    Attributes
    protected
    Definition Classes
    Base
  235. def registerModule(moduleInfo: ModuleInfo): Unit

    Permalink

    Called once for each staged module during this cake initialization.

    Called once for each staged module during this cake initialization.

    Attributes
    protected
    Definition Classes
    Modules
  236. implicit def reifyObject[A](obj: Def[A]): Ref[A]

    Permalink

    Implicit injection of new definition (graph node) into universum of nodes with collapsing semantics.

    Implicit injection of new definition (graph node) into universum of nodes with collapsing semantics. If there exists node n in this IR such that obj equals n, then the value of n.self is returned, i.e. the new node obj is collapsed with already existing one. This has an effect of Common Subexpression Elimination (CSE) when an expression tree is transformed to the graph and identical subtrees are collapsed. After a reference to the node is obtained, global rewriting rules are examined and the reference may be replaced with a new one.

    Definition Classes
    Base
  237. implicit def repOrderingToOrderingOps[T](x: Ref[T])(implicit n: ExactOrdering[T]): OrderingOpsCls[T]

    Permalink
    Definition Classes
    OrderingOps
  238. implicit def repToThunk[A](block: Ref[A]): Ref[Thunk[A]]

    Permalink
    Definition Classes
    Thunks
  239. def resetContext(): Unit

    Permalink
    Definition Classes
    CostedObjectsDefsBase
  240. final def rewriteBinOp[A, R](op: BinOp[A, R], x: Ref[A], y: Ref[A]): Ref[_]

    Permalink

    Rewrites application of given binary operation to the given arguments.

    Rewrites application of given binary operation to the given arguments.

    returns

    null if no rewriting is defined.

    Definition Classes
    DefRewriting
  241. final def rewriteBoolConsts(lhs: Sym, rhs: Sym, ifTrue: (Sym) ⇒ Sym, ifFalse: (Sym) ⇒ Sym, ifEqual: (Sym) ⇒ Sym, ifNegated: (Sym) ⇒ Sym): Sym

    Permalink

    Helper method which defines rewriting rules with boolean constants.

    Helper method which defines rewriting rules with boolean constants.

    Definition Classes
    LogicalOps
    Annotations
    @inline()
  242. def rewriteDef[T](d: Def[T]): Ref[Any]

    Permalink

    Rewrites given node to another equivalent node and returns its reference.

    Rewrites given node to another equivalent node and returns its reference.

    d

    node to be matched against rewrite patterns

    returns

    reference of new node if RW pattern is found and applied null if no rewriting is defined.

    Definition Classes
    LibraryDefRewriting
  243. def rewriteNonInvokableMethodCall(mc: MethodCall): Ref[_]

    Permalink

    This method is called for each MethodCall node which is about to be added to the graph.

    This method is called for each MethodCall node which is about to be added to the graph. This means mc has been examined by all the rewrite rules, but has not need rewritten. Now, if this method returns null, then mc will be added to the graph. However, in this method, mc can be examined by a second set of RW rules (kind of lower priority rules). These rules kind of context dependent, because at this point we know that the first RW set didn't triggered any rewrite.

    Definition Classes
    MethodCalls
  244. final def rewriteUnOp[A, R](op: UnOp[A, R], x: Ref[A]): Ref[_]

    Permalink

    Rewrites application of given unary operation to the given argument.

    Rewrites application of given unary operation to the given argument.

    returns

    null if no rewriting is defined.

    Definition Classes
    DefRewriting
  245. def shouldEmitCluster(g: AstGraph): Boolean

    Permalink
    Attributes
    protected
    Definition Classes
    GraphVizExport
  246. def showGraphs(graph: AstGraph)(implicit config: GraphVizConfig): Unit

    Permalink
    Definition Classes
    GraphVizExport
  247. def showGraphs(roots: Sym*)(implicit config: GraphVizConfig): Unit

    Permalink
    Definition Classes
    GraphVizExport
  248. implicit lazy val sizeAnyElement: Elem[Size[Any]]

    Permalink
  249. def sizeOf[T](value: Ref[T]): Ref[Long]

    Permalink
    Definition Classes
    UniversalOps
  250. def specialPredef: Ref[WSpecialPredefCompanionCtor]

    Permalink
    Definition Classes
    Library
  251. def stagingExceptionMessage(message: String, syms: Seq[Ref[_]]): String

    Permalink

    Prettyprint exception message

    Prettyprint exception message

    Attributes
    protected
    Definition Classes
    Base
  252. implicit final def sumElement[A, B](implicit ea: Elem[A], eb: Elem[B]): Elem[|[A, B]]

    Permalink
    Definition Classes
    TypeDescs
  253. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  254. def throwInvocationException(whatFailed: String, cause: Throwable, receiver: Sym, m: Method, args: Seq[Any]): Nothing

    Permalink
    Definition Classes
    MethodCalls
  255. implicit val thunkCont: Cont[Thunk]

    Permalink

    Thunk is an instance of container type class Cont.

    Thunk is an instance of container type class Cont.

    Definition Classes
    Thunks
  256. implicit def thunkElement[T](implicit eItem: Elem[T]): Elem[Thunk[T]]

    Permalink
    Definition Classes
    Thunks
  257. val thunkStack: ThunkStack

    Permalink
    Attributes
    protected
    Definition Classes
    Thunks
  258. def thunk_create[A](block: ⇒ Ref[A]): Ref[Thunk[A]]

    Permalink

    Constructs a new thunk node by executing the given block and collecting all the graph node created along the way.

    Constructs a new thunk node by executing the given block and collecting all the graph node created along the way. This methods: 1) starts a new nested ThunkScope, 2) executes the block to obtain resulting graph node 3) schedule thunk body for execution order 4) adds a new ThunkDef node and returns its reference.

    returns

    a reference to the newly created ThunkDef node

    Definition Classes
    Thunks
  259. def thunk_force[A](t: Th[A]): Ref[A]

    Permalink

    Logical force of the thunk.

    Logical force of the thunk. Depending on isInlineThunksOnForce it either inlines the thunk body or creates a new ThunkForce node.

    returns

    a reference to the graph node, which represent the result of the thunk's evaluation.

    Definition Classes
    Thunks
  260. def thunk_map[A, B](t: Th[A], f: Ref[(A) ⇒ B]): Th[B]

    Permalink
    Definition Classes
    Thunks
  261. def thunk_map1[A, B](t: Th[A], f: (Ref[A]) ⇒ Ref[B]): Th[B]

    Permalink
    Definition Classes
    Thunks
  262. def toExp[T](d: Def[T], newSym: ⇒ Ref[T]): Ref[T]

    Permalink

    Updates the universe of symbols and definitions, then rewrites until fix-point

    Updates the universe of symbols and definitions, then rewrites until fix-point

    d

    A new graph node to add to the universe

    newSym

    A symbol that will be used if d doesn't exist in the universe

    returns

    The symbol of the graph which is semantically(up to rewrites) equivalent to d

    Attributes
    protected[scalan]
    Definition Classes
    Base
  263. implicit final def toLazyElem[A](implicit eA: Elem[A]): LElem[A]

    Permalink
    Definition Classes
    TypeDescs
  264. def toRep[A](x: A)(implicit eA: Elem[A]): Ref[A]

    Permalink

    Lifting of data values to IR nodes.

    Lifting of data values to IR nodes.

    Definition Classes
    Base
  265. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  266. def transformProductParam(x: Any, t: Transformer): Any

    Permalink

    Transforms this object into new one by applying t to every Ref inside its structure.

    Transforms this object into new one by applying t to every Ref inside its structure. The structure is build out of Seq, Array, Option and Def values. Other structure items remain unchanged and copied to the new instance.

    Attributes
    protected
    Definition Classes
    Base
  267. def tryConvert[From, To](eFrom: Elem[From], eTo: Elem[To], x: Ref[Def[_]], conv: Ref[(From) ⇒ To]): Ref[To]

    Permalink
    Definition Classes
    UniversalOps
  268. val tuplesCache: AVHashMap[Ref[_], (Ref[_], Ref[_])]

    Permalink
    Definition Classes
    Tuples
  269. def unfoldLambda[A, B](f: Ref[(A) ⇒ B], x: Ref[A]): Ref[B]

    Permalink
    Definition Classes
    Functions
  270. def unfoldLambda[A, B](lam: Lambda[A, B], x: Ref[A]): Ref[B]

    Permalink
    Definition Classes
    Functions
  271. var unfoldWithOriginalFunc: Boolean

    Permalink

    Turns on/off lambda unfolding using original function f stored in the Lambda node.

    Turns on/off lambda unfolding using original function f stored in the Lambda node. If this flag is false then this function cannot be used even if it is present in the node.

    Definition Classes
    Functions
  272. def unrefDelegate[T <: AnyRef](x: Ref[T])(implicit ct: ClassTag[T]): T

    Permalink

    Create delegate instance suitable for method invocation.

    Create delegate instance suitable for method invocation. It is used when T is a class or a trait and the node referred by x doesn't conform to T. This method returns dynamically constructed instance, which conforms to T. Whenever a method of T is called on that instance, the call is intercepted and DelegatedInterceptionHandler.invoke method is called, then a new MethodCall can be constructed (which is befavior by default).

    Attributes
    protected
    Definition Classes
    MethodCalls
  273. def unzipPair[A, B](p: Ref[(A, B)]): (Ref[A], Ref[B])

    Permalink
    Definition Classes
    Tuples
  274. def upcast[To](value: Ref[_])(implicit arg0: Elem[To]): Ref[To]

    Permalink
    Definition Classes
    UniversalOps
  275. def upcastFun[A, B >: A](implicit arg0: Elem[A]): Ref[(A) ⇒ B]

    Permalink
    Definition Classes
    Functions
  276. final def updateSymbolTable[T](s: Ref[T], d: Def[T]): Ref[T]

    Permalink

    Create or find symbol (node Ref) which refers to the given node in the table of all created symbols.

    Create or find symbol (node Ref) which refers to the given node in the table of all created symbols. The d.nodeId is the index in the _symbolTable which is DBuffer (backed by Array)

    returns

    new of existing symbol

    Definition Classes
    Base
  277. var useAlphaEquality: Boolean

    Permalink

    Global lambda equality mode used by default.

    Global lambda equality mode used by default. It is used in fun and fun2 lambda builders. If this flag is true then Lambda nodes are equal if they are the same up to renaming of symbols. (see Lambda.equals()). Each Lambda node has independent equality mode flag which is setup in the constructor.

    Definition Classes
    Functions
  278. final def valueFromRep[A](x: Ref[A]): A

    Permalink

    Extract data value from Const node or throw an exception.

    Extract data value from Const node or throw an exception.

    Definition Classes
    Base
    Annotations
    @inline()
  279. def variable[T](implicit eT: LElem[T]): Ref[T]

    Permalink
    Definition Classes
    Base
    Annotations
    @inline()
  280. implicit lazy val wRTypeAnyElement: Elem[WRType[Any]]

    Permalink
  281. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  282. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  283. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  284. def zeroSize[V](eVal: Elem[V]): RSize[V]

    Permalink
    Definition Classes
    Library
  285. implicit def zipPair[A, B](p: (Ref[A], Ref[B])): Ref[(A, B)]

    Permalink
    Definition Classes
    Tuples

Inherited from CostedObjectsModule

Inherited from CostedObjectsDefs

Inherited from CostedObjects

Inherited from SigmaDslModule

Inherited from SigmaDslDefs

Inherited from SigmaDsl

Inherited from WrappersModule

Inherited from Library

Inherited from CostedOptionsModule

Inherited from CostedOptionsDefs

Inherited from CostedOptions

Inherited from MonoidInstancesModule

Inherited from MonoidInstancesDefs

Inherited from MonoidInstances

Inherited from MonoidsModule

Inherited from MonoidsDefs

Inherited from Monoids

Inherited from ConcreteCostsModule

Inherited from ConcreteCostsDefs

Inherited from ConcreteCosts

Inherited from ConcreteSizesModule

Inherited from ConcreteSizesDefs

Inherited from ConcreteSizes

Inherited from CostsModule

Inherited from CostsDefs

Inherited from Costs

Inherited from SizesModule

Inherited from SizesDefs

Inherited from Sizes

Inherited from CollsModule

Inherited from CollsDefs

Inherited from Colls

Inherited from WrappersSpecModule

Inherited from WrappersSpecDefs

Inherited from WrappersSpec

Inherited from WrappersModule

Inherited from WRTypesModule

Inherited from WRTypesDefs

Inherited from WRTypes

Inherited from WOptionsModule

Inherited from WOptionsDefs

Inherited from WOptions

Inherited from WSpecialPredefsModule

Inherited from WSpecialPredefsDefs

Inherited from WSpecialPredefs

Inherited from Scalan

Inherited from DefRewriting

Inherited from Modules

Inherited from Entities

Inherited from Thunks

Inherited from IfThenElse

Inherited from Functions

Inherited from ProgramGraphs

Inherited from AstGraphs

Inherited from Transforming

Inherited from UniversalOps

Inherited from Equal

Inherited from OrderingOps

Inherited from LogicalOps

Inherited from UnBinOps

Inherited from NumericOps

Inherited from Tuples

Inherited from MethodCalls

Inherited from GraphVizExport

Inherited from TypeDescs

Inherited from Base

Inherited from AnyRef

Inherited from Any

Ungrouped