Packages

  • package root
    Definition Classes
    root
  • package be
    Definition Classes
    root
  • package opimedia
    Definition Classes
    be
  • package scala_par_am
    Definition Classes
    opimedia
  • class SeqAAM[Exp, Abs, Addr, Time] extends EvalKontMachine[Exp, Abs, Addr, Time]

    SeqAAM: Sequential AAM (with list)

    SeqAAM: Sequential AAM (with list)

    This is a reimplementation of the AAM class of Scala-AM written by Quentin Stiévenart. A fork of the original version of Scala-AM used is available here: https://bitbucket.org/OPiMedia/scala-am. The subsumption part has been removed. So this class corresponds in fact to the AAMNS (AAM No Subsumption) class of Scala-AM in this copy repository.

    Compared to AAMNS of Scala-AM this class used Set Scala native data structures instead to specific WorkList and VisitedSet. The recursive loop has been replaced by a for loop.

    The worklist is implemented by an immutable list of states.

    This sequential machine (or the SeqAAMS and SeqAAMLS alternative) is the comparison point for the different version of parallel machines implemented in Scala-Par-AM.

    The original description by Quentin Stiévenart: Implementation of a CESK machine following the AAM approach (Van Horn, David, and Matthew Might. "Abstracting abstract machines." ACM Sigplan Notices. Vol. 45. No. 9. ACM, 2010).

    A difference with the paper is that we separate the continuation store (KontStore) from the value store (Store). That simplifies the implementation of both stores, and the only change it induces is that we are not able to support first-class continuation as easily (we don't support them at all, but they could be added).

    Also, in the paper, a CESK state is made of 4 components: Control, Environment, Store, and Kontinuation. Here, we include the environment in the control component, and we distinguish "eval" states from "continuation" states. An eval state has an attached environment, as an expression needs to be evaluated within this environment, whereas a continuation state only contains the value reached.

    Source https://bitbucket.org/OPiMedia/scala-par-am/src/master/scala-par-am/src/main/scala/machine/SeqAAM.scala

    Definition Classes
    scala_par_am
  • AbstractMachineStats
  • AbstractMachineStatsDisabledTrait
  • AbstractMachineStatsEnabledTrait
  • Control
  • ControlError
  • ControlEval
  • ControlKont
  • KontAddr
  • Output
  • SeqAAMOutput
  • SeqAAMStats
  • SeqAAMStatsDisabled
  • SeqAAMStatsEnabled
  • State
c

be.opimedia.scala_par_am.SeqAAM

SeqAAMStatsEnabled

final class SeqAAMStatsEnabled extends SeqAAMStats with AbstractMachineStatsEnabledTrait

Attributes
protected
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SeqAAMStatsEnabled
  2. AbstractMachineStatsEnabledTrait
  3. SeqAAMStats
  4. AbstractMachineStats
  5. AnyRef
  6. Any
Implicitly
  1. by any2stringadd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new SeqAAMStatsEnabled()

Value Members

  1. val alreadyVisitedNb: Int
  2. def incAlreadyVisitedNb(): Unit
  3. def incLoopIterNb(): Unit
  4. val loopIterNb: Int
  5. val newStateMaxNb: Int
  6. val newStateNbs: Map[Int, Int]
  7. def newStates(nb: ⇒ Int): Unit
  8. def pickStates(nb: ⇒ Int): Unit
  9. def println(): Unit
  10. def toString(escaped: ⇒ Boolean): String
  11. def toString(): String
    Definition Classes
    AbstractMachineStatsEnabledTrait → AnyRef → Any
  12. def toTsv: String
  13. val workListMaxSize: Int
  14. val workListReverseSizes: List[Int]

    Sizes of the worklist on each pick operation, in the reverse order.

    Sizes of the worklist on each pick operation, in the reverse order.

    Definition Classes
    AbstractMachineStatsEnabledTrait
  15. val workListSize: Int
  16. val workListSumSize: Int