Commit 9f3c0897 authored by Ioannis Papagiannopoulos's avatar Ioannis Papagiannopoulos Committed by Georgios Dagkakis

calculateLoad/SetupTime removed. calculateTime(type) relplaces them (only in...

calculateLoad/SetupTime removed. calculateTime(type) relplaces them (only in machine). calculateProcessingTime still used under calculateTime (only in machine)
parent 4b07a369
...@@ -760,6 +760,16 @@ class CoreObject(ManPyObject): ...@@ -760,6 +760,16 @@ class CoreObject(ManPyObject):
return initialWIPrng.generateNumber() return initialWIPrng.generateNumber()
return self.rng.generateNumber() # this is if we have a default processing time for all the entities return self.rng.generateNumber() # this is if we have a default processing time for all the entities
#===========================================================================
# calculates time (running through a dictionary) according to the type of processing given as argument
#===========================================================================
def calculateTime(self,type='Processing'):
return {
'Load': self.loadRng.generateNumber,
'Setup': self.stpRng.generateNumber,
'Processing': self.calculateProcessingTime
}[type]()
# ======================================================================= # =======================================================================
# checks if the object is blocked # checks if the object is blocked
# ======================================================================= # =======================================================================
......
...@@ -413,22 +413,13 @@ class Machine(CoreObject): ...@@ -413,22 +413,13 @@ class Machine(CoreObject):
assert type in set(['Processing','Setup']), 'the operation type provided is not yet defined' assert type in set(['Processing','Setup']), 'the operation type provided is not yet defined'
# identify the method to get the operation time and initialise the totalOperationTime # identify the method to get the operation time and initialise the totalOperationTime
if type=='Setup': if type=='Setup':
method='calculateSetupTime'
self.totalOperationTime=self.totalSetupTime self.totalOperationTime=self.totalSetupTime
elif type=='Processing': elif type=='Processing':
method='calculateProcessingTime'
self.totalOperationTime=self.totalWorkingTime self.totalOperationTime=self.totalWorkingTime
from Globals import getMethodFromName
try:
classMethod=getMethodFromName('Dream.'+str(self.__class__.__name__)+'.'+method)
except:
# if there is no module name as the self.__class__.__name__
parents=self.__class__.__bases__
classMethod=getMethodFromName('Dream.'+str(parents[-1].__name__)+'.'+method)
# 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
# get the operation time, tinMStarts holds the processing time of the machine # get the operation time, tinMStarts holds the processing time of the machine
self.totalOperationTimeInCurrentEntity=classMethod(self) self.totalOperationTimeInCurrentEntity=self.calculateTime(type)
# timer to hold the operation time left # timer to hold the operation time left
self.tinM=self.totalOperationTimeInCurrentEntity self.tinM=self.totalOperationTimeInCurrentEntity
# variables used to flag any interruptions and the end of the processing # variables used to flag any interruptions and the end of the processing
...@@ -623,7 +614,7 @@ class Machine(CoreObject): ...@@ -623,7 +614,7 @@ class Machine(CoreObject):
# ======= Load the machine if the Load is defined as one of the Operators' operation types # ======= Load the machine if the Load is defined as one of the Operators' operation types
if any(type=="Load" for type in self.multOperationTypeList) and self.isOperated(): if any(type=="Load" for type in self.multOperationTypeList) and self.isOperated():
self.timeLoadStarted = self.env.now self.timeLoadStarted = self.env.now
yield self.env.timeout(self.calculateLoadTime()) yield self.env.timeout(self.calculateTime(type='Load'))
# TODO: if self.interrupted(): There is the issue of failure during the Loading # TODO: if self.interrupted(): There is the issue of failure during the Loading
self.timeLoadEnded = self.env.now self.timeLoadEnded = self.env.now
self.loadTimeCurrentEntity = self.timeLoadEnded-self.timeLoadStarted self.loadTimeCurrentEntity = self.timeLoadEnded-self.timeLoadStarted
...@@ -637,12 +628,6 @@ class Machine(CoreObject): ...@@ -637,12 +628,6 @@ class Machine(CoreObject):
#=================================================================== #===================================================================
#=================================================================== #===================================================================
# #===================================================================
# # # release a resource if the only operation type is Load
# #===================================================================
# if self.shouldYield(operationTypes={"Load":1, "Processing":0,"Setup":0},methods={'isOperated':1}):
# yield self.env.process(self.release())
#=================================================================== #===================================================================
#=================================================================== #===================================================================
#=================================================================== #===================================================================
...@@ -1105,17 +1090,26 @@ class Machine(CoreObject): ...@@ -1105,17 +1090,26 @@ class Machine(CoreObject):
or self.timeLastEntityEnded==self.env.now or self.timeLastEntityEnded==self.env.now
or self.checkIfActive()) or self.checkIfActive())
# ======================================================================= # # =======================================================================
# calculates the setup time # # calculates the setup time
# ======================================================================= # # =======================================================================
def calculateSetupTime(self): # def calculateSetupTime(self):
return self.stpRng.generateNumber() # return self.stpRng.generateNumber()
# ======================================================================= # # =======================================================================
# calculates the Load time # # calculates the Load time
# ======================================================================= # # =======================================================================
def calculateLoadTime(self): # def calculateLoadTime(self):
return self.loadRng.generateNumber() # return self.loadRng.generateNumber()
# # =======================================================================
# # calculates the Load time
# # =======================================================================
# def calculateTime(self, type='Processing'):
# if type=='Setup':
# return self.stpRng.generateNumber()
# elif type=='Load':
# return self.loadRng.generateNumber()
#=========================================================================== #===========================================================================
# checks whether the entity can proceed to a successor object # checks whether the entity can proceed to a successor object
......
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