Commit f3fd097a authored by Georgios Dagkakis's avatar Georgios Dagkakis

Failure to sort only the tie with end of processing

parent 4852e21f
...@@ -170,7 +170,9 @@ class Failure(ObjectInterruption): ...@@ -170,7 +170,9 @@ class Failure(ObjectInterruption):
# this is done so that if processing finishes exactly at the time of interruption # this is done so that if processing finishes exactly at the time of interruption
# the processing will finish first (if this mode is selected) # the processing will finish first (if this mode is selected)
if self.waitOnTie: if self.waitOnTie:
yield self.env.timeout(0) if hasattr(self.victim, 'timeToEndCurrentOperation'):
if float(self.victim.timeToEndCurrentOperation)==float(self.env.now):
yield self.env.timeout(0)
# interrupt the victim # interrupt the victim
self.interruptVictim() # interrupt the victim self.interruptVictim() # interrupt the victim
......
...@@ -421,7 +421,8 @@ class Machine(CoreObject): ...@@ -421,7 +421,8 @@ class Machine(CoreObject):
# 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=self.calculateTime(type) 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
self.timeToEndCurrentOperation=self.env.now+self.tinM
# variables used to flag any interruptions and the end of the processing # variables used to flag any interruptions and the end of the processing
self.interruption=False self.interruption=False
# local variable that is used to check whether the operation is concluded # local variable that is used to check whether the operation is concluded
...@@ -914,6 +915,7 @@ class Machine(CoreObject): ...@@ -914,6 +915,7 @@ class Machine(CoreObject):
# recalculate the processing time left tinM # recalculate the processing time left tinM
if self.timeLastOperationStarted>=0: if self.timeLastOperationStarted>=0:
self.tinM=self.tinM-(self.env.now-self.timeLastOperationStarted) self.tinM=self.tinM-(self.env.now-self.timeLastOperationStarted)
self.timeToEndCurrentOperation=self.env.now+self.tinM
if(self.tinM==0): # sometimes the failure may happen exactly at the time that the processing would finish if(self.tinM==0): # sometimes the failure may happen exactly at the time that the processing would finish
# this may produce disagreement with the simul8 because in both SimPy and Simul8 # this may produce disagreement with the simul8 because in both SimPy and Simul8
# it seems to be random which happens 1st # it seems to be random which happens 1st
......
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