module Simulation.Aivika.Lattice.LIO
(LIO,
LIOLattice,
lattice,
newRandomLattice,
newRandomLatticeWithProb,
runLIO,
latticeTimeIndex,
latticeMemberIndex,
latticeParentMemberIndex,
latticeSize,
latticeTime,
latticeTimes,
latticeTimeStep,
findLatticeTimeIndex,
enqueueEventWithLatticeTimes) where
import Simulation.Aivika.Trans
import Simulation.Aivika.Trans.Comp
import Simulation.Aivika.Trans.DES
import Simulation.Aivika.Trans.Exception
import Simulation.Aivika.Trans.Generator
import Simulation.Aivika.Trans.Event
import Simulation.Aivika.Trans.Ref.Base
import Simulation.Aivika.Trans.QueueStrategy
import Simulation.Aivika.Lattice.Internal.LIO
import Simulation.Aivika.Lattice.Event
import Simulation.Aivika.Lattice.Generator
import Simulation.Aivika.Lattice.Ref.Base.Lazy
import Simulation.Aivika.Lattice.Ref.Base.Strict
import Simulation.Aivika.Lattice.QueueStrategy
instance MonadDES LIO
instance MonadComp LIO
instance EventIOQueueing LIO where
enqueueEventIO :: Double -> Event LIO () -> Event LIO ()
enqueueEventIO = Double -> Event LIO () -> Event LIO ()
forall (m :: * -> *).
EventQueueing m =>
Double -> Event m () -> Event m ()
enqueueEvent
enqueueEventWithLatticeTimes :: Event LIO () -> Event LIO ()
enqueueEventWithLatticeTimes :: Event LIO () -> Event LIO ()
enqueueEventWithLatticeTimes Event LIO ()
m =
do [Double]
ts <- Parameter LIO [Double] -> Event LIO [Double]
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
ParameterLift t m =>
Parameter m a -> t m a
liftParameter Parameter LIO [Double]
latticeTimes
[Double] -> Event LIO () -> Event LIO ()
forall (m :: * -> *).
MonadDES m =>
[Double] -> Event m () -> Event m ()
enqueueEventWithTimes [Double]
ts Event LIO ()
m