BatchSource and Decomposition updated

parent 5ee8dce0
...@@ -26,8 +26,9 @@ BatchDecomposition is a Core Object that takes a batch and decomposes to sub-bat ...@@ -26,8 +26,9 @@ BatchDecomposition is a Core Object that takes a batch and decomposes to sub-bat
''' '''
from SimPy.Simulation import Process, Resource # from SimPy.Simulation import Process, Resource
from SimPy.Simulation import waituntil, now, hold, waitevent # from SimPy.Simulation import waituntil, now, hold, waitevent
import simpy
from Globals import G from Globals import G
from CoreObject import CoreObject from CoreObject import CoreObject
...@@ -69,7 +70,7 @@ class BatchDecomposition(CoreObject): ...@@ -69,7 +70,7 @@ class BatchDecomposition(CoreObject):
from Globals import G from Globals import G
G.BatchWaitingList = [] # batches waiting to be reassembled G.BatchWaitingList = [] # batches waiting to be reassembled
CoreObject.initialize(self) # using the default CoreObject Functionality CoreObject.initialize(self) # using the default CoreObject Functionality
self.Res=Resource(self.numberOfSubBatches) # initialize the Internal resource (Queue) functionality self.Res=simpy.Resource(self.env, self.numberOfSubBatches) # initialize the Internal resource (Queue) functionality
# ======================================================================= # =======================================================================
# the run method of the BatchDecomposition # the run method of the BatchDecomposition
...@@ -80,28 +81,32 @@ class BatchDecomposition(CoreObject): ...@@ -80,28 +81,32 @@ class BatchDecomposition(CoreObject):
while 1: while 1:
# wait for an event or an interruption # wait for an event or an interruption
while 1: while 1:
yield waitevent, self, [self.isRequested, self.interruptionStart] receivedEvent=yield self.isRequested | self.interruptionStart
# if an interruption has occurred # if an interruption has occurred
if self.interruptionStart.signalparam==now(): if self.interruptionStart in receivedEvent:
assert self.interruptionStart.value==self.env.now, 'the interruption received by batchDecomposition was created earlier'
self.interruptionStart=self.env.event()
# wait till it is over # wait till it is over
yield waitevent, self, self.interruptionEnd yield self.interruptionEnd
assert self==self.interruptionEnd.signalparam, 'the victim of the failure is not the object that received the interruptionEnd event' assert self==self.interruptionEnd.value, 'the victim of the failure is not the object that received the interruptionEnd event'
self.interruptionEnd=self.env.event()
if self.signalGiver(): if self.signalGiver():
break break
# otherwise proceed with getEntity # otherwise proceed with getEntity
else: else:
break break
requestingObject=self.isRequested.signalparam requestingObject=self.isRequested.value
assert requestingObject==self.giver, 'the giver is not the requestingObject' assert requestingObject==self.giver, 'the giver is not the requestingObject'
self.isRequested=self.env.event()
self.currentEntity=self.getEntity() self.currentEntity=self.getEntity()
# set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered # set the currentEntity as the Entity just received and initialize the timer timeLastEntityEntered
self.nameLastEntityEntered=self.currentEntity.name # this holds the name of the last entity that got into Machine self.nameLastEntityEntered=self.currentEntity.name # this holds the name of the last entity that got into Machine
self.timeLastEntityEntered=now() #this holds the last time that an entity got into Machine self.timeLastEntityEntered=self.env.now #this holds the last time that an entity got into Machine
self.totalProcessingTimeInCurrentEntity=self.calculateProcessingTime() self.totalProcessingTimeInCurrentEntity=self.calculateProcessingTime()
yield hold,self,self.totalProcessingTimeInCurrentEntity yield self.env.timeout(self.totalProcessingTimeInCurrentEntity)
self.decompose() self.decompose()
# TODO: add failure control # TODO: add failure control
...@@ -117,7 +122,8 @@ class BatchDecomposition(CoreObject): ...@@ -117,7 +122,8 @@ class BatchDecomposition(CoreObject):
if not signaling: if not signaling:
# if there was no success wait till the receiver is available # if there was no success wait till the receiver is available
while 1: while 1:
yield waitevent, self, self.canDispose yield self.canDispose
self.canDispose=self.env.event()
# signal the receiver again and break # signal the receiver again and break
if self.signalReceiver(): if self.signalReceiver():
break break
...@@ -125,7 +131,8 @@ class BatchDecomposition(CoreObject): ...@@ -125,7 +131,8 @@ class BatchDecomposition(CoreObject):
# we know that the receiver is occupied with the previous sub-batch # we know that the receiver is occupied with the previous sub-batch
else: else:
while 1: while 1:
yield waitevent,self,self.canDispose yield self.canDispose
self.canDispose=self.env.event()
signaling=self.signalReceiver() signaling=self.signalReceiver()
if signaling: if signaling:
break break
...@@ -173,7 +180,7 @@ class BatchDecomposition(CoreObject): ...@@ -173,7 +180,7 @@ class BatchDecomposition(CoreObject):
self.outputTrace(subBatch.name,'was created from '+ activeEntity.name) self.outputTrace(subBatch.name,'was created from '+ activeEntity.name)
#=================================================================== #===================================================================
# TESTING # TESTING
# print now(), subBatch.name,'was created from '+ activeEntity.name # print self.env.now, subBatch.name,'was created from '+ activeEntity.name
#=================================================================== #===================================================================
G.EntityList.append(subBatch) G.EntityList.append(subBatch)
activeObjectQueue.append(subBatch) #append the sub-batch to the active object Queue activeObjectQueue.append(subBatch) #append the sub-batch to the active object Queue
...@@ -184,7 +191,7 @@ class BatchDecomposition(CoreObject): ...@@ -184,7 +191,7 @@ class BatchDecomposition(CoreObject):
G.pendingEntities.append(subBatch) G.pendingEntities.append(subBatch)
G.pendingEntities.remove(activeEntity) G.pendingEntities.remove(activeEntity)
activeEntity.numberOfSubBatches=self.numberOfSubBatches activeEntity.numberOfSubBatches=self.numberOfSubBatches
self.timeLastEntityEnded=now() self.timeLastEntityEnded=self.env.now
# ======================================================================= # =======================================================================
# canAccept logic # canAccept logic
...@@ -192,7 +199,6 @@ class BatchDecomposition(CoreObject): ...@@ -192,7 +199,6 @@ class BatchDecomposition(CoreObject):
def canAccept(self,callerObject=None): def canAccept(self,callerObject=None):
activeObject=self.getActiveObject() activeObject=self.getActiveObject()
activeObjectQueue=self.getActiveObjectQueue() activeObjectQueue=self.getActiveObjectQueue()
# giverObject=self.getGiverObject()
if(len(activeObject.previous)==1 or callerObject==None): if(len(activeObject.previous)==1 or callerObject==None):
return activeObject.Up and len(activeObjectQueue)==0 return activeObject.Up and len(activeObjectQueue)==0
thecaller=callerObject thecaller=callerObject
...@@ -223,7 +229,6 @@ class BatchDecomposition(CoreObject): ...@@ -223,7 +229,6 @@ class BatchDecomposition(CoreObject):
# get the active and the giver objects # get the active and the giver objects
activeObject=self.getActiveObject() activeObject=self.getActiveObject()
activeObjectQueue=self.getActiveObjectQueue() activeObjectQueue=self.getActiveObjectQueue()
# giverObject=self.getGiverObject()
giverObject=callerObject giverObject=callerObject
assert giverObject, 'there must be a caller for canAcceptAndIsRequested' assert giverObject, 'there must be a caller for canAcceptAndIsRequested'
return activeObject.Up and len(activeObjectQueue)==0 and giverObject.haveToDispose(activeObject) return activeObject.Up and len(activeObjectQueue)==0 and giverObject.haveToDispose(activeObject)
...@@ -26,7 +26,8 @@ models the source object that generates the Batches Entities ...@@ -26,7 +26,8 @@ models the source object that generates the Batches Entities
''' '''
from Source import Source from Source import Source
from Globals import G from Globals import G
from SimPy.Simulation import Process # from SimPy.Simulation import Process
import simpy
from RandomNumberGenerator import RandomNumberGenerator from RandomNumberGenerator import RandomNumberGenerator
class BatchSource(Source): class BatchSource(Source):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment