default values for proc/setup/load times are corrected. Operation process s...

default values for proc/setup/load times are corrected. Operation process s shouldYield arguments corrected. operation process used for Setup operation
parent 2381852f
...@@ -103,7 +103,7 @@ class Machine(CoreObject): ...@@ -103,7 +103,7 @@ class Machine(CoreObject):
self.toBeOperated = False self.toBeOperated = False
# define the load times # define the load times
self.loadRng = RandomNumberGenerator(self, **loadTime) self.loadRng = RandomNumberGenerator(self, **loadTime)
# variable that informs on the need for setup # XX variable that informs on the need for setup
self.setUp=True self.setUp=True
# define the setup times # define the setup times
self.stpRng = RandomNumberGenerator(self, **setupTime) self.stpRng = RandomNumberGenerator(self, **setupTime)
...@@ -196,7 +196,7 @@ class Machine(CoreObject): ...@@ -196,7 +196,7 @@ class Machine(CoreObject):
'''returns the processingTime dictionary updated''' '''returns the processingTime dictionary updated'''
if not processingTime: if not processingTime:
processingTime = { 'distributionType': 'Fixed', processingTime = { 'distributionType': 'Fixed',
'mean': 1, } 'mean': 0, }
if processingTime['distributionType'] == 'Normal' and\ if processingTime['distributionType'] == 'Normal' and\
processingTime.get('max', None) is None: processingTime.get('max', None) is None:
processingTime['max'] = float(processingTime['mean']) + 5 * float(processingTime['stdev']) processingTime['max'] = float(processingTime['mean']) + 5 * float(processingTime['stdev'])
...@@ -207,7 +207,7 @@ class Machine(CoreObject): ...@@ -207,7 +207,7 @@ class Machine(CoreObject):
'''returns the setupTime dictionary updated''' '''returns the setupTime dictionary updated'''
if not setupTime: if not setupTime:
setupTime = { 'distributionType': 'Fixed', setupTime = { 'distributionType': 'Fixed',
'mean': 1, } 'mean': 0, }
if setupTime['distributionType'] == 'Normal' and\ if setupTime['distributionType'] == 'Normal' and\
setupTime.get('max', None) is None: setupTime.get('max', None) is None:
setupTime['max'] = float(setupTime['mean']) + 5 * float(setupTime['stdev']) setupTime['max'] = float(setupTime['mean']) + 5 * float(setupTime['stdev'])
...@@ -218,7 +218,7 @@ class Machine(CoreObject): ...@@ -218,7 +218,7 @@ class Machine(CoreObject):
'''returns the loadTime dictionary updated''' '''returns the loadTime dictionary updated'''
if not loadTime: if not loadTime:
loadTime = { 'distributionType': 'Fixed', loadTime = { 'distributionType': 'Fixed',
'mean': 1, } 'mean': 0, }
if loadTime['distributionType'] == 'Normal' and\ if loadTime['distributionType'] == 'Normal' and\
loadTime.get('max', None) is None: loadTime.get('max', None) is None:
loadTime['max'] = float(loadTime['mean']) + 5 * float(loadTime['stdev']) loadTime['max'] = float(loadTime['mean']) + 5 * float(loadTime['stdev'])
...@@ -491,7 +491,7 @@ class Machine(CoreObject): ...@@ -491,7 +491,7 @@ class Machine(CoreObject):
#=========================================================== #===========================================================
# # release the operator if there is interruption # # release the operator if there is interruption
#=========================================================== #===========================================================
if self.shouldYield(operationTypes={"Processing":1},methods={'isOperated':1}): if self.shouldYield(operationTypes={str(self.currentlyPerforming):1},methods={'isOperated':1}):
yield self.env.process(self.release()) yield self.env.process(self.release())
# loop until we reach at a state that there is no interruption # loop until we reach at a state that there is no interruption
while 1: while 1:
...@@ -506,7 +506,7 @@ class Machine(CoreObject): ...@@ -506,7 +506,7 @@ class Machine(CoreObject):
#=========================================================== #===========================================================
# # request a resource after the repair # # request a resource after the repair
#=========================================================== #===========================================================
if self.shouldYield(operationTypes={"Processing":1}, methods={"isInterrupted":0}): if self.shouldYield(operationTypes={str(self.currentlyPerforming):1}, methods={"isInterrupted":0}):
self.timeWaitForOperatorStarted = self.env.now self.timeWaitForOperatorStarted = self.env.now
yield self.env.process(self.request()) yield self.env.process(self.request())
self.timeWaitForOperatorEnded = self.env.now self.timeWaitForOperatorEnded = self.env.now
...@@ -547,7 +547,7 @@ class Machine(CoreObject): ...@@ -547,7 +547,7 @@ class Machine(CoreObject):
#=========================================================== #===========================================================
# # release the operator if there is interruption # # release the operator if there is interruption
#=========================================================== #===========================================================
if self.shouldYield(operationTypes={"Processing":1},methods={'isOperated':1}): if self.shouldYield(operationTypes={str(self.currentlyPerforming):1},methods={'isOperated':1}):
yield self.env.process(self.release()) yield self.env.process(self.release())
self.postInterruptionActions() # execute interruption actions self.postInterruptionActions() # execute interruption actions
break break
...@@ -804,16 +804,18 @@ class Machine(CoreObject): ...@@ -804,16 +804,18 @@ class Machine(CoreObject):
#=================================================================== #===================================================================
#=================================================================== #===================================================================
#=================================================================== #===================================================================
yield self.env.process(self.operation(type='Setup'))
# ======= setup the machine if the Setup is defined as one of the Operators' operation types self.endOperationActions(type='Setup')
# 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(): # # ======= setup the machine if the Setup is defined as one of the Operators' operation types
self.timeSetupStarted = self.env.now # # in plantSim the setup is performed when the machine has to process a new type of Entity and only once
yield self.env.timeout(self.calculateSetupTime()) # if any(type=="Setup" for type in self.multOperationTypeList) and self.isOperated():
# TODO: if self.interrupted(): There is the issue of failure during the setup # self.timeSetupStarted = self.env.now
self.timeSetupEnded = self.env.now # yield self.env.timeout(self.calculateSetupTime())
self.setupTimeCurrentEntity = self.timeSetupEnded-self.timeSetupStarted # # TODO: if self.interrupted(): There is the issue of failure during the setup
self.totalSetupTime += self.setupTimeCurrentEntity # self.timeSetupEnded = self.env.now
# self.setupTimeCurrentEntity = self.timeSetupEnded-self.timeSetupStarted
# self.totalSetupTime += self.setupTimeCurrentEntity
#=================================================================== #===================================================================
#=================================================================== #===================================================================
......
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