| Copyright | Copyright (c) 2009-2017 David Sorokin <david.sorokin@gmail.com> | 
|---|---|
| License | BSD3 | 
| Maintainer | David Sorokin <david.sorokin@gmail.com> | 
| Stability | experimental | 
| Safe Haskell | None | 
| Language | Haskell2010 | 
Simulation.Aivika.Parameter
Description
Tested with: GHC 8.0.1
The module defines the Parameter monad that allows representing the model
 parameters. For example, they can be used when running the Monte-Carlo simulation.
In general, this monad is very useful for representing a computation which is external relative to the model itself.
- data Parameter a
- class ParameterLift m where
- runParameter :: Parameter a -> Specs -> IO a
- runParameters :: Parameter a -> Specs -> Int -> [IO a]
- catchParameter :: Exception e => Parameter a -> (e -> Parameter a) -> Parameter a
- finallyParameter :: Parameter a -> Parameter b -> Parameter a
- throwParameter :: Exception e => e -> Parameter a
- simulationIndex :: Parameter Int
- simulationCount :: Parameter Int
- simulationSpecs :: Parameter Specs
- generatorParameter :: Parameter Generator
- starttime :: Parameter Double
- stoptime :: Parameter Double
- dt :: Parameter Double
- memoParameter :: Parameter a -> IO (Parameter a)
- tableParameter :: Array Int a -> Parameter a
Parameter
The Parameter monad that allows specifying the model parameters.
 For example, they can be used when running the Monte-Carlo simulation.
In general, this monad is very useful for representing a computation which is external relative to the model itself.
Instances
| Monad Parameter Source # | |
| Functor Parameter Source # | |
| MonadFix Parameter Source # | |
| Applicative Parameter Source # | |
| MonadIO Parameter Source # | |
| ParameterLift Parameter Source # | |
| ResultComputing Parameter Source # | |
| Eq (Parameter a) Source # | |
| Floating a => Floating (Parameter a) Source # | |
| Fractional a => Fractional (Parameter a) Source # | |
| Num a => Num (Parameter a) Source # | |
| Show (Parameter a) Source # | |
| ResultItemable (ResultValue a) => ResultProvider (Parameter a) Source # | |
| (Ix i, Show i, ResultItemable (ResultValue [e])) => ResultProvider (Parameter (Array i e)) Source # | |
| ResultItemable (ResultValue [e]) => ResultProvider (Parameter (Vector e)) Source # | |
| (ResultItemable (ResultValue a), ResultItemable (ResultValue (TimingStats a))) => ResultProvider (Parameter (TimingCounter a)) Source # | |
| (ResultItemable (ResultValue a), ResultItemable (ResultValue (SamplingStats a))) => ResultProvider (Parameter (SamplingCounter a)) Source # | |
class ParameterLift m where Source #
A type class to lift the parameters to other computations.
Minimal complete definition
Methods
liftParameter :: Parameter a -> m a Source #
Lift the specified Parameter computation to another computation.
runParameters :: Parameter a -> Specs -> Int -> [IO a] Source #
Run the given number of parameters using the specified specs, 
   where each parameter is distinguished by its index parameterIndex.
Error Handling
catchParameter :: Exception e => Parameter a -> (e -> Parameter a) -> Parameter a Source #
Exception handling within Parameter computations.
finallyParameter :: Parameter a -> Parameter b -> Parameter a Source #
A computation with finalization part like the finally function.
Predefined Parameters
simulationIndex :: Parameter Int Source #
Return the run index for the current simulation.
simulationCount :: Parameter Int Source #
Return the number of simulations currently run.
simulationSpecs :: Parameter Specs Source #
Return the simulation specs.
generatorParameter :: Parameter Generator Source #
Return the random number generator for the simulation run.
Memoization
memoParameter :: Parameter a -> IO (Parameter a) Source #
Memoize the Parameter computation, always returning the same value
 within a simulation run. However, the value will be recalculated for other
 simulation runs. Also it is thread-safe when different simulation runs
 are executed in parallel on physically different operating system threads.
Utilities
tableParameter :: Array Int a -> Parameter a Source #
Return a parameter which value is taken consequently from the specified table based on the run index of the current simulation starting from zero. After all values from the table are used, it takes again the first value of the table, then the second one and so on.