module Simulation.Aivika.Trans.GPSS.Results () where
import Control.Monad
import Control.Monad.Trans
import Simulation.Aivika.Trans
import qualified Simulation.Aivika.Trans.GPSS.Queue as Q
import Simulation.Aivika.Trans.GPSS.Facility
import Simulation.Aivika.Trans.GPSS.Storage
import Simulation.Aivika.Trans.GPSS.Results.Locale
queueResultSource :: MonadDES m
=> ResultContainer (Q.Queue m) m
-> ResultSource m
queueResultSource c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = queueId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = queueResultSummary c,
resultObjectProperties = [
resultContainerProperty c "queueNull" queueNullId Q.queueNull Q.queueNullChanged_,
resultContainerProperty c "queueContent" queueContentId Q.queueContent Q.queueContentChanged_,
resultContainerProperty c "queueContentStats" queueContentStatsId Q.queueContentStats Q.queueContentChanged_,
resultContainerProperty c "enqueueCount" enqueueCountId Q.enqueueCount Q.enqueueCountChanged_,
resultContainerProperty c "enqueueZeroEntryCount" enqueueZeroEntryCountId Q.enqueueZeroEntryCount Q.enqueueZeroEntryCountChanged_,
resultContainerProperty c "queueWaitTime" queueWaitTimeId Q.queueWaitTime Q.queueWaitTimeChanged_,
resultContainerProperty c "queueNonZeroEntryWaitTime" queueNonZeroEntryWaitTimeId Q.queueNonZeroEntryWaitTime Q.queueNonZeroEntryWaitTimeChanged_,
resultContainerProperty c "queueRate" queueRateId Q.queueRate Q.queueRateChanged_ ] }
queueResultSummary :: MonadDES m =>
ResultContainer (Q.Queue m) m
-> ResultSource m
queueResultSummary c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = queueId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = queueResultSummary c,
resultObjectProperties = [
resultContainerProperty c "queueContentStats" queueContentStatsId Q.queueContentStats Q.queueContentChanged_,
resultContainerProperty c "enqueueCount" enqueueCountId Q.enqueueCount Q.enqueueCountChanged_,
resultContainerProperty c "enqueueZeroEntryCount" enqueueZeroEntryCountId Q.enqueueZeroEntryCount Q.enqueueZeroEntryCountChanged_,
resultContainerProperty c "queueWaitTime" queueWaitTimeId Q.queueWaitTime Q.queueWaitTimeChanged_,
resultContainerProperty c "queueNonZeroEntryWaitTime" queueNonZeroEntryWaitTimeId Q.queueNonZeroEntryWaitTime Q.queueNonZeroEntryWaitTimeChanged_,
resultContainerProperty c "queueRate" queueRateId Q.queueRate Q.queueRateChanged_ ] }
facilityResultSource :: MonadDES m =>
ResultContainer (Facility m a) m
-> ResultSource m
facilityResultSource c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = facilityId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = facilityResultSummary c,
resultObjectProperties = [
resultContainerProperty c "queueCount" facilityQueueCountId facilityQueueCount facilityQueueCountChanged_,
resultContainerProperty c "queueCountStats" facilityQueueCountStatsId facilityQueueCountStats facilityQueueCountChanged_,
resultContainerProperty c "totalWaitTime" facilityTotalWaitTimeId facilityTotalWaitTime facilityWaitTimeChanged_,
resultContainerProperty c "waitTime" facilityWaitTimeId facilityWaitTime facilityWaitTimeChanged_,
resultContainerProperty c "totalHoldingTime" facilityTotalHoldingTimeId facilityTotalHoldingTime facilityHoldingTimeChanged_,
resultContainerProperty c "holdingTime" facilityHoldingTimeId facilityHoldingTime facilityHoldingTimeChanged_,
resultContainerIntegProperty c "interrupted" facilityInterruptedId facilityInterrupted,
resultContainerProperty c "count" facilityCountId facilityCount facilityCountChanged_,
resultContainerProperty c "countStats" facilityCountStatsId facilityCountStats facilityCountChanged_,
resultContainerProperty c "captureCount" facilityCaptureCountId facilityCaptureCount facilityCaptureCountChanged_,
resultContainerProperty c "utilisationCount" facilityUtilisationCountId facilityUtilisationCount facilityUtilisationCountChanged_,
resultContainerProperty c "utilisationCountStats" facilityUtilisationCountStatsId facilityUtilisationCountStats facilityUtilisationCountChanged_ ] }
facilityResultSummary :: MonadDES m =>
ResultContainer (Facility m a) m
-> ResultSource m
facilityResultSummary c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = facilityId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = facilityResultSummary c,
resultObjectProperties = [
resultContainerProperty c "queueCountStats" facilityQueueCountStatsId facilityQueueCountStats facilityQueueCountChanged_,
resultContainerProperty c "waitTime" facilityWaitTimeId facilityWaitTime facilityWaitTimeChanged_,
resultContainerProperty c "holdingTime" facilityHoldingTimeId facilityHoldingTime facilityHoldingTimeChanged_,
resultContainerProperty c "countStats" facilityCountStatsId facilityCountStats facilityCountChanged_,
resultContainerProperty c "captureCount" facilityCaptureCountId facilityCaptureCount facilityCaptureCountChanged_,
resultContainerProperty c "utilisationCountStats" facilityUtilisationCountStatsId facilityUtilisationCountStats facilityUtilisationCountChanged_ ] }
storageResultSource :: MonadDES m
=> ResultContainer (Storage m) m
-> ResultSource m
storageResultSource c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = storageId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = storageResultSummary c,
resultObjectProperties = [
resultContainerConstProperty c "capacity" storageCapacityId storageCapacity,
resultContainerIntegProperty c "empty" storageEmptyId storageEmpty,
resultContainerIntegProperty c "full" storageFullId storageFull,
resultContainerProperty c "queueCount" storageQueueCountId storageQueueCount storageQueueCountChanged_,
resultContainerProperty c "queueCountStats" storageQueueCountStatsId storageQueueCountStats storageQueueCountChanged_,
resultContainerProperty c "totalWaitTime" storageTotalWaitTimeId storageTotalWaitTime storageWaitTimeChanged_,
resultContainerProperty c "waitTime" storageWaitTimeId storageWaitTime storageWaitTimeChanged_,
resultContainerIntegProperty c "averageHoldingTime" storageAverageHoldingTimeId storageAverageHoldingTime,
resultContainerProperty c "content" storageContentId storageContent storageContentChanged_,
resultContainerProperty c "contentStats" storageContentStatsId storageContentStats storageContentChanged_,
resultContainerProperty c "useCount" storageUseCountId storageUseCount storageUseCountChanged_,
resultContainerProperty c "usedContent" storageUsedContentId storageUsedContent storageUsedContentChanged_,
resultContainerProperty c "utilisationCount" storageUtilisationCountId storageUtilisationCount storageUtilisationCountChanged_,
resultContainerProperty c "utilisationCountStats" storageUtilisationCountStatsId storageUtilisationCountStats storageUtilisationCountChanged_ ] }
storageResultSummary :: MonadDES m
=> ResultContainer (Storage m) m
-> ResultSource m
storageResultSummary c =
ResultObjectSource $
ResultObject {
resultObjectName = resultContainerName c,
resultObjectId = resultContainerId c,
resultObjectTypeId = storageId,
resultObjectSignal = resultContainerSignal c,
resultObjectSummary = storageResultSummary c,
resultObjectProperties = [
resultContainerConstProperty c "capacity" storageCapacityId storageCapacity,
resultContainerProperty c "queueCountStats" storageQueueCountStatsId storageQueueCountStats storageQueueCountChanged_,
resultContainerProperty c "waitTime" storageWaitTimeId storageWaitTime storageWaitTimeChanged_,
resultContainerIntegProperty c "averageHoldingTime" storageAverageHoldingTimeId storageAverageHoldingTime,
resultContainerProperty c "contentStats" storageContentStatsId storageContentStats storageContentChanged_,
resultContainerProperty c "useCount" storageUseCountId storageUseCount storageUseCountChanged_,
resultContainerProperty c "usedContent" storageUsedContentId storageUsedContent storageUsedContentChanged_,
resultContainerProperty c "utilisationCountStats" storageUtilisationCountStatsId storageUtilisationCountStats storageUtilisationCountChanged_ ] }
instance MonadDES m => ResultProvider (Q.Queue m) m where
resultSource' name i m =
queueResultSource $ ResultContainer name i m (ResultSignal $ Q.queueChanged_ m)
instance MonadDES m => ResultProvider (Facility m a) m where
resultSource' name i m =
facilityResultSource $ ResultContainer name i m (ResultSignal $ facilityChanged_ m)
instance MonadDES m => ResultProvider (Storage m) m where
resultSource' name i m =
storageResultSource $ ResultContainer name i m (ResultSignal $ storageChanged_ m)