aivika-6.1.1: A multi-method simulation library
CopyrightCopyright (c) 2009-2017 David Sorokin <david.sorokin@gmail.com>
LicenseBSD3
MaintainerDavid Sorokin <david.sorokin@gmail.com>
Stabilityexperimental
Safe HaskellSafe-Inferred
LanguageHaskell2010

Simulation.Aivika.Internal.Simulation

Description

Tested with: GHC 8.0.1

This is an internal implementation module that should never be used directly.

The module defines the Simulation monad that represents a computation within the simulation run.

Synopsis

Simulation

newtype Simulation a Source #

A value in the Simulation monad represents a computation within the simulation run.

Constructors

Simulation (Run -> IO a) 

Instances

Instances details
ParameterLift Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

SimulationLift Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

ResultComputing Simulation Source # 
Instance details

Defined in Simulation.Aivika.Results

MonadFail Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

fail :: String -> Simulation a #

MonadFix Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

mfix :: (a -> Simulation a) -> Simulation a #

MonadIO Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

liftIO :: IO a -> Simulation a #

Applicative Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

pure :: a -> Simulation a #

(<*>) :: Simulation (a -> b) -> Simulation a -> Simulation b #

liftA2 :: (a -> b -> c) -> Simulation a -> Simulation b -> Simulation c #

(*>) :: Simulation a -> Simulation b -> Simulation b #

(<*) :: Simulation a -> Simulation b -> Simulation a #

Functor Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

fmap :: (a -> b) -> Simulation a -> Simulation b #

(<$) :: a -> Simulation b -> Simulation a #

Monad Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

(>>=) :: Simulation a -> (a -> Simulation b) -> Simulation b #

(>>) :: Simulation a -> Simulation b -> Simulation b #

return :: a -> Simulation a #

MonadCatch Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

catch :: (HasCallStack, Exception e) => Simulation a -> (e -> Simulation a) -> Simulation a #

MonadMask Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

mask :: HasCallStack => ((forall a. Simulation a -> Simulation a) -> Simulation b) -> Simulation b #

uninterruptibleMask :: HasCallStack => ((forall a. Simulation a -> Simulation a) -> Simulation b) -> Simulation b #

generalBracket :: HasCallStack => Simulation a -> (a -> ExitCase b -> Simulation c) -> (a -> Simulation b) -> Simulation (b, c) #

MonadThrow Simulation Source # 
Instance details

Defined in Simulation.Aivika.Internal.Simulation

Methods

throwM :: (HasCallStack, Exception e) => e -> Simulation a #

(ResultItemable (ResultValue a), ResultItemable (ResultValue (SamplingStats a))) => ResultProvider (Simulation (SamplingCounter a)) Source # 
Instance details

Defined in Simulation.Aivika.Results

(ResultItemable (ResultValue a), ResultItemable (ResultValue (TimingStats a))) => ResultProvider (Simulation (TimingCounter a)) Source # 
Instance details

Defined in Simulation.Aivika.Results

(Ix i, Show i, ResultItemable (ResultValue [e])) => ResultProvider (Simulation (Array i e)) Source # 
Instance details

Defined in Simulation.Aivika.Results

ResultItemable (ResultValue [e]) => ResultProvider (Simulation (Vector e)) Source # 
Instance details

Defined in Simulation.Aivika.Results

ResultItemable (ResultValue a) => ResultProvider (Simulation a) Source # 
Instance details

Defined in Simulation.Aivika.Results

class SimulationLift m where Source #

A type class to lift the simulation computations to other computations.

Methods

liftSimulation :: Simulation a -> m a Source #

Lift the specified Simulation computation to another computation.

invokeSimulation :: Run -> Simulation a -> IO a Source #

Invoke the Simulation computation.

runSimulation :: Simulation a -> Specs -> IO a Source #

Run the simulation using the specified specs.

runSimulations :: Simulation a -> Specs -> Int -> [IO a] Source #

Run the given number of simulations using the specified specs, where each simulation is distinguished by its index simulationIndex.

runSimulationByIndex Source #

Arguments

:: Simulation a

the simulation model

-> Specs

the simulation specs

-> Int

the number of runs in series

-> Int

the index of the current run (started from 1)

-> IO a 

Run the simulation by the specified specs and run index in series.

Error Handling

catchSimulation :: Exception e => Simulation a -> (e -> Simulation a) -> Simulation a Source #

Exception handling within Simulation computations.

finallySimulation :: Simulation a -> Simulation b -> Simulation a Source #

A computation with finalization part like the finally function.

throwSimulation :: Exception e => e -> Simulation a Source #

Like the standard throw function.

Utilities

Memoization

memoSimulation :: Simulation a -> Simulation (Simulation a) Source #

Memoize the Simulation computation, always returning the same value within a simulation run.

Exceptions

data SimulationAbort Source #

An exception that signals of aborting the simulation.

Constructors

SimulationAbort String

The exception to abort the simulation.

data SimulationRetry Source #

An exception that signals that the current computation should be retried as possible, which feature may be supported by the simulation engine or not.

Constructors

SimulationRetry String

The exception to retry the computation.