Commit 00950a27 authored by Ioannis Papagiannopoulos's avatar Ioannis Papagiannopoulos Committed by Jérome Perrin

MouldAssembly and MachineJobShop modified following the OperatedMachine collapse

parent b3ed30f2
...@@ -181,7 +181,6 @@ class Machine(CoreObject): ...@@ -181,7 +181,6 @@ class Machine(CoreObject):
self.loadTimeCurrentEntity = 0 self.loadTimeCurrentEntity = 0
self.setupTimeCurrentEntity = 0 self.setupTimeCurrentEntity = 0
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# ======= request a resource # ======= request a resource
if(self.operatorPool!="None") and any(type=='Load' for type in self.multOperationTypeList): if(self.operatorPool!="None") and any(type=='Load' for type in self.multOperationTypeList):
# when it's ready to accept (canAcceptAndIsRequested) then inform the broker # when it's ready to accept (canAcceptAndIsRequested) then inform the broker
...@@ -213,7 +212,6 @@ class Machine(CoreObject): ...@@ -213,7 +212,6 @@ class Machine(CoreObject):
self.releaseOperator() self.releaseOperator()
# wait until the Broker has finished processing # wait until the Broker has finished processing
yield waituntil, self, self.broker.brokerIsSet yield waituntil, self, self.broker.brokerIsSet
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# get the entity # get the entity
# TODO: if there was loading time then we must solve the problem of getting an entity # TODO: if there was loading time then we must solve the problem of getting an entity
...@@ -221,7 +219,6 @@ class Machine(CoreObject): ...@@ -221,7 +219,6 @@ class Machine(CoreObject):
# may fall in failure mode (assignExit()?) # may fall in failure mode (assignExit()?)
self.currentEntity=self.getEntity() self.currentEntity=self.getEntity()
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# ======= request a resource if it is not already assigned an Operator # ======= request a resource if it is not already assigned an Operator
if(self.operatorPool!="None")\ if(self.operatorPool!="None")\
and any(type=="Processing" or type=="Setup" for type in self.multOperationTypeList)\ and any(type=="Processing" or type=="Setup" for type in self.multOperationTypeList)\
...@@ -234,14 +231,12 @@ class Machine(CoreObject): ...@@ -234,14 +231,12 @@ class Machine(CoreObject):
yield waituntil, self, self.broker.brokerIsSet yield waituntil, self, self.broker.brokerIsSet
self.timeWaitForOperatorEnded = now() self.timeWaitForOperatorEnded = now()
self.operatorWaitTimeCurrentEntity += self.timeWaitForOperatorEnded-self.timeWaitForOperatorStarted self.operatorWaitTimeCurrentEntity += self.timeWaitForOperatorEnded-self.timeWaitForOperatorStarted
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# variables dedicated to hold the processing times, the time when the Entity entered, # variables dedicated to hold the processing times, the time when the Entity entered,
# and the processing time left # and the processing time left
self.totalProcessingTimeInCurrentEntity=self.calculateProcessingTime() # get the processing time, tinMStarts holds the processing time of the machine self.totalProcessingTimeInCurrentEntity=self.calculateProcessingTime() # get the processing time, tinMStarts holds the processing time of the machine
tinM=self.totalProcessingTimeInCurrentEntity # timer to hold the processing time left tinM=self.totalProcessingTimeInCurrentEntity # timer to hold the processing time left
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# ======= setup the machine if the Setup is defined as one of the Operators' operation types # ======= setup the machine if the Setup is defined as one of the Operators' operation types
# in plantSim the setup is performed when the machine has to process a new type of Entity and only once # in plantSim the setup is performed when the machine has to process a new type of Entity and only once
if any(type=="Setup" for type in self.multOperationTypeList) and self.isOperated(): if any(type=="Setup" for type in self.multOperationTypeList) and self.isOperated():
...@@ -263,7 +258,6 @@ class Machine(CoreObject): ...@@ -263,7 +258,6 @@ class Machine(CoreObject):
# print self.objName, 'operator released', now() # print self.objName, 'operator released', now()
# wait until the Broker has finished processing # wait until the Broker has finished processing
yield waituntil, self, self.broker.brokerIsSet yield waituntil, self, self.broker.brokerIsSet
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# variables used to flag any interruptions and the end of the processing # variables used to flag any interruptions and the end of the processing
interruption=False interruption=False
...@@ -302,7 +296,7 @@ class Machine(CoreObject): ...@@ -302,7 +296,7 @@ class Machine(CoreObject):
# passivate the Machine for as long as there is no repair # passivate the Machine for as long as there is no repair
# start counting the down time at breatTime dummy variable # start counting the down time at breatTime dummy variable
breakTime=now() # dummy variable that the interruption happened breakTime=now() # dummy variable that the interruption happened
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# =============== release the operator if there is interruption # =============== release the operator if there is interruption
if (self.operatorPool!="None")\ if (self.operatorPool!="None")\
and self.isOperated()\ and self.isOperated()\
...@@ -310,7 +304,7 @@ class Machine(CoreObject): ...@@ -310,7 +304,7 @@ class Machine(CoreObject):
self.releaseOperator() self.releaseOperator()
# print self.objName, 'operator released due to failure', now() # print self.objName, 'operator released due to failure', now()
yield waituntil,self,self.broker.brokerIsSet yield waituntil,self,self.broker.brokerIsSet
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# if there is a failure in the machine it is passivated # if there is a failure in the machine it is passivated
yield passivate,self yield passivate,self
# use the timers to count the time that Machine is down and related # use the timers to count the time that Machine is down and related
...@@ -325,7 +319,6 @@ class Machine(CoreObject): ...@@ -325,7 +319,6 @@ class Machine(CoreObject):
if (len(self.getActiveObjectQueue())==0 and self.shouldPreempt): if (len(self.getActiveObjectQueue())==0 and self.shouldPreempt):
break break
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# =============== request a resource after the repair # =============== request a resource after the repair
if (self.operatorPool!="None")\ if (self.operatorPool!="None")\
and any(type=="Processing" for type in self.multOperationTypeList)\ and any(type=="Processing" for type in self.multOperationTypeList)\
...@@ -335,7 +328,6 @@ class Machine(CoreObject): ...@@ -335,7 +328,6 @@ class Machine(CoreObject):
yield waituntil,self,self.broker.brokerIsSet yield waituntil,self,self.broker.brokerIsSet
self.timeWaitForOperatorEnded = now() self.timeWaitForOperatorEnded = now()
self.operatorWaitTimeCurrentEntity += self.timeWaitForOperatorEnded-self.timeWaitForOperatorStarted self.operatorWaitTimeCurrentEntity += self.timeWaitForOperatorEnded-self.timeWaitForOperatorStarted
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# if no interruption occurred the processing in M1 is ended # if no interruption occurred the processing in M1 is ended
else: else:
...@@ -353,15 +345,12 @@ class Machine(CoreObject): ...@@ -353,15 +345,12 @@ class Machine(CoreObject):
except IndexError: except IndexError:
pass pass
# ++++++++++++++++++++++++++++++ New ++++++++++++++++++++++++++++++++++++
# =============== release resource after the end of processing # =============== release resource after the end of processing
if (self.operatorPool!='None')\ if (self.operatorPool!='None')\
and any(type=="Processing" for type in self.multOperationTypeList)\ and any(type=="Processing" for type in self.multOperationTypeList)\
and not interruption: and not interruption:
self.releaseOperator() self.releaseOperator()
yield waituntil,self,self.broker.brokerIsSet yield waituntil,self,self.broker.brokerIsSet
# +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
# set the variable that flags an Entity is ready to be disposed # set the variable that flags an Entity is ready to be disposed
self.waitToDispose=True self.waitToDispose=True
......
...@@ -77,14 +77,25 @@ class MachineJobShop(Machine): ...@@ -77,14 +77,25 @@ class MachineJobShop(Machine):
# and returns true only if the active object is the next station # and returns true only if the active object is the next station
# ======================================================================= # =======================================================================
def canAccept(self, callerObject=None): def canAccept(self, callerObject=None):
if callerObject!=None: activeObject=self.getActiveObject()
activeObjectQueue=activeObject.getActiveObjectQueue()
thecaller=callerObject
if (thecaller!=None):
#check it the caller object holds an Entity that requests for current object #check it the caller object holds an Entity that requests for current object
if len(callerObject.getActiveObjectQueue())>0: if len(thecaller.getActiveObjectQueue())>0:
activeEntity=callerObject.getActiveObjectQueue()[0] # TODO: make sure that the first entity of the callerObject is to be disposed
activeEntity=thecaller.getActiveObjectQueue()[0]
# if the machine's Id is in the list of the entity's next stations # if the machine's Id is in the list of the entity's next stations
if self.id in activeEntity.remainingRoute[0].get('stationIdsList',[]): if activeObject.id in activeEntity.remainingRoute[0].get('stationIdsList',[]):
# if activeEntity.remainingRoute[0][0]==self.id: #return according to the state of the Queue
return len(self.getActiveObjectQueue())<self.capacity #return according to the state of the Queue # also check if (if the machine is to be operated) there are available operators
if (activeObject.operatorPool!='None' and any(type=='Load' for type in activeObject.multOperationTypeList)):
return activeObject.operatorPool.checkIfResourceIsAvailable()\
and len(activeObject.getActiveObjectQueue())<activeObject.capacity\
and activeObject.Up
else:
return len(activeObject.getActiveObjectQueue())<activeObject.capacity\
and activeObject.Up
return False return False
# ======================================================================= # =======================================================================
......
...@@ -282,14 +282,25 @@ class MouldAssembly(MachinePreemptive): ...@@ -282,14 +282,25 @@ class MouldAssembly(MachinePreemptive):
# returns true if it is empty # returns true if it is empty
# ======================================================================= # =======================================================================
def canAccept(self, callerObject=None): def canAccept(self, callerObject=None):
if callerObject!=None: activeObject=self.getActiveObject()
activeObjectQueue=activeObject.getActiveObjectQueue()
thecaller=callerObject
if thecaller!=None:
#check it the caller object holds an Entity that requests for current object #check it the caller object holds an Entity that requests for current object
if len(callerObject.getActiveObjectQueue())>0: if len(thecaller.getActiveObjectQueue())>0:
activeEntity=callerObject.getActiveObjectQueue()[0] # TODO: make sure that the first entity of the callerObject is to be disposed
activeEntity=thecaller.getActiveObjectQueue()[0]
# if the machine's Id is in the list of the entity's next stations # if the machine's Id is in the list of the entity's next stations
if self.id in activeEntity.remainingRoute[0].get('stationIdsList',[]): if activeObject.id in activeEntity.remainingRoute[0].get('stationIdsList',[]):
#return according to the state of the Queue #return according to the state of the Queue
return len(self.getActiveObjectQueue())==0 # check if (if the machine is to be operated) there are available operators
if (activeObject.operatorPool!='None' and any(type=='Load' for type in activeObject.multOperationTypeList)):
return activeObject.operatorPool.checkIfResourceIsAvailable()\
and len(activeObject.getActiveObjectQueue())==0\
and activeObject.Up
else:
return len(activeObject.getActiveObjectQueue())==0\
and activeObject.Up
return False return False
# ======================================================================= # =======================================================================
...@@ -304,13 +315,27 @@ class MouldAssembly(MachinePreemptive): ...@@ -304,13 +315,27 @@ class MouldAssembly(MachinePreemptive):
activeObject=self.getActiveObject() activeObject=self.getActiveObject()
activeObjectQueue=self.getActiveObjectQueue() activeObjectQueue=self.getActiveObjectQueue()
giverObject=self.getGiverObject() giverObject=self.getGiverObject()
# if we have only one predecessor just check if the machine is empty,
# if we have only one possible giver just check if the internal queue is empty # the machine is up and the predecessor has an entity to dispose
# and if the giver has to dispose something
if(len(activeObject.previous)==1): if(len(activeObject.previous)==1):
return giverObject.haveToDispose(activeObject)\ # if the machine has to compete for an Operator that loads the entities onto it
# check if the predecessor if blocked by an other Machine
# if not then the machine has to block the predecessor giverObject to avoid conflicts
# with other competing machines
if (activeObject.operatorPool!='None' and any(type=='Load' for type in activeObject.multOperationTypeList)):
if activeObject.operatorPool.checkIfResourceIsAvailable()\
and activeObject.Up\
and len(activeObjectQueue)==0\ and len(activeObjectQueue)==0\
and giverObject.haveToDispose(activeObject)\
and not giverObject.exitIsAssigned():
activeObject.giver.assignExit()
return True
else:
return False
# otherwise, use the default behaviour
else:
return activeObject.Up and len(activeObjectQueue)==0\
and giverObject.haveToDispose(activeObject)
# dummy variables that help prioritise the objects requesting to give objects to the Machine (activeObject) # dummy variables that help prioritise the objects requesting to give objects to the Machine (activeObject)
isRequested=False # isRequested is dummyVariable checking if it is requested to accept an item isRequested=False # isRequested is dummyVariable checking if it is requested to accept an item
maxTimeWaiting=0 # dummy variable counting the time a predecessor is blocked maxTimeWaiting=0 # dummy variable counting the time a predecessor is blocked
...@@ -327,10 +352,19 @@ class MouldAssembly(MachinePreemptive): ...@@ -327,10 +352,19 @@ class MouldAssembly(MachinePreemptive):
# in any other case, it holds the time since the end of the Entity processing # in any other case, it holds the time since the end of the Entity processing
else: else:
timeWaiting=now()-object.timeLastEntityEnded timeWaiting=now()-object.timeLastEntityEnded
#if more than one predecessor have to dispose, take the part from the one that is blocked longer #if more than one predecessor have to dispose, take the part from the one that is blocked longer
if(timeWaiting>=maxTimeWaiting): if(timeWaiting>=maxTimeWaiting):
activeObject.giver=object activeObject.giver=object
maxTimeWaiting=timeWaiting maxTimeWaiting=timeWaiting
if (activeObject.operatorPool!='None' and any(type=='Load' for type in activeObject.multOperationTypeList)):
return len(activeObjectQueue)==0 and isRequested if activeObject.operatorPool.checkIfResourceIsAvailable()\
and activeObject.Up\
and len(activeObjectQueue)==0\
and isRequested\
and not activeObject.giver.exitIsAssigned():
activeObject.giver.assignExit()
return True
else:
return False
else:
return activeObject.Up and len(activeObjectQueue)==0 and isRequested
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