Commit 79508d88 authored by Georgios Dagkakis's avatar Georgios Dagkakis Committed by Jérome Perrin

MachinePreemptive code moved to Machine and MachineJobShop

parent c9e1450a
...@@ -45,6 +45,11 @@ class CoreObject(Process): ...@@ -45,6 +45,11 @@ class CoreObject(Process):
self.Blockage=[] self.Blockage=[]
self.Waiting=[] self.Waiting=[]
#default attributes set so that the CoreObject has them
self.isPreemptive=False
self.resetOnPreemption=False
def initialize(self): def initialize(self):
Process.__init__(self) Process.__init__(self)
...@@ -178,8 +183,8 @@ class CoreObject(Process): ...@@ -178,8 +183,8 @@ class CoreObject(Process):
# perform preemption when required # perform preemption when required
# if the object is not Exit # if the object is not Exit
if activeObject.receiver: if activeObject.receiver:
# if the obtained Entity is critical # if the obtained Entity is critical and the receiver is preemptive
if activeEntity.isCritical: if activeEntity.isCritical and activeObject.receiver.isPreemptive:
#if the receiver is not empty #if the receiver is not empty
if len(self.receiver.getActiveObjectQueue())>0: if len(self.receiver.getActiveObjectQueue())>0:
#if the receiver does not hold an Entity that is also critical #if the receiver does not hold an Entity that is also critical
...@@ -376,3 +381,11 @@ class CoreObject(Process): ...@@ -376,3 +381,11 @@ class CoreObject(Process):
# ======================================================================= # =======================================================================
def interruptionActions(self): def interruptionActions(self):
pass pass
# =======================================================================
# method to execute preemption
# =======================================================================
def preempt(self):
#ToDO make a generic method
pass
...@@ -20,15 +20,17 @@ ...@@ -20,15 +20,17 @@
"failures": {} "failures": {}
}, },
"M2": { "M2": {
"_class": "Dream.MachinePreemptive", "_class": "Dream.MachineJobShop",
"id": "M2", "id": "M2",
"name": "Machine2", "name": "Machine2",
"processingTime": { "processingTime": {
"distributionType": "Fixed", "distributionType": "Fixed",
"mean": "1.5" "mean": "1.5"
}, },
"failures": {}, "preemption": {
"resetOnPreemption":"0" "isPreemptive": "1",
"resetOnPreemption": "0"
}
}, },
"Q1": { "Q1": {
"_class": "Dream.QueueJobShop", "_class": "Dream.QueueJobShop",
......
...@@ -20,15 +20,17 @@ ...@@ -20,15 +20,17 @@
"failures": {} "failures": {}
}, },
"M2": { "M2": {
"_class": "Dream.MachinePreemptive", "_class": "Dream.MachineJobShop",
"id": "M2", "id": "M2",
"name": "Machine2", "name": "Machine2",
"processingTime": { "processingTime": {
"distributionType": "Fixed", "distributionType": "Fixed",
"mean": "1.5" "mean": "1.5"
}, },
"failures": {}, "preemption": {
"resetOnPreemption":"1" "isPreemptive": "1",
"resetOnPreemption": "1"
}
}, },
"Q1": { "Q1": {
"_class": "Dream.QueueJobShop", "_class": "Dream.QueueJobShop",
......
...@@ -286,6 +286,11 @@ def createObjects(): ...@@ -286,6 +286,11 @@ def createObjects():
loadStdev = float(loadTime.get('loadStdev', '0')) loadStdev = float(loadTime.get('loadStdev', '0'))
loadMin=float(loadTime.get('loadMin', '0')) loadMin=float(loadTime.get('loadMin', '0'))
loadMax=float(loadTime.get('loadMax', '0')) loadMax=float(loadTime.get('loadMax', '0'))
preemption=element.get('preemption',{})
isPreemptive=resetOnPreemption=False
if len(preemption)>0:
isPreemptive=bool(int(preemption.get('isPreemptive', 0)))
resetOnPreemption=bool(int(preemption.get('isPreemptive', 0)))
if len(G.OperatorPoolsList)>0: if len(G.OperatorPoolsList)>0:
for operatorPool in G.OperatorPoolsList: # find the operatorPool assigned to the machine for operatorPool in G.OperatorPoolsList: # find the operatorPool assigned to the machine
...@@ -314,7 +319,7 @@ def createObjects(): ...@@ -314,7 +319,7 @@ def createObjects():
loadDistribution=loadDistribution, setupDistribution=setupDistribution, loadDistribution=loadDistribution, setupDistribution=setupDistribution,
setupMean=setupMean,setupStdev=setupStdev,setupMin=setupMin,setupMax=setupMax, setupMean=setupMean,setupStdev=setupStdev,setupMin=setupMin,setupMax=setupMax,
loadMean=loadMean,loadStdev=loadStdev,loadMin=loadMin,loadMax=loadMax, loadMean=loadMean,loadStdev=loadStdev,loadMin=loadMin,loadMax=loadMax,
repairman=r) repairman=r, isPreemptive=isPreemptive, resetOnPreemption=resetOnPreemption)
M.nextIds=getSuccessorList(id) # update the nextIDs list of the machine M.nextIds=getSuccessorList(id) # update the nextIDs list of the machine
G.MachineList.append(M) # add machine to global MachineList G.MachineList.append(M) # add machine to global MachineList
if M.operatorPool!="None": if M.operatorPool!="None":
...@@ -418,6 +423,11 @@ def createObjects(): ...@@ -418,6 +423,11 @@ def createObjects():
loadStdev = float(loadTime.get('loadStdev', '0')) loadStdev = float(loadTime.get('loadStdev', '0'))
loadMin=float(loadTime.get('loadMin', '0')) loadMin=float(loadTime.get('loadMin', '0'))
loadMax=float(loadTime.get('loadMax', '0')) loadMax=float(loadTime.get('loadMax', '0'))
preemption=element.get('preemption',{})
isPreemptive=resetOnPreemption=False
if len(preemption)>0:
isPreemptive=bool(int(preemption.get('isPreemptive', 0)))
resetOnPreemption=bool(int(preemption.get('resetOnPreemption', 0)))
if len(G.OperatorPoolsList)>0: if len(G.OperatorPoolsList)>0:
for operatorPool in G.OperatorPoolsList: # find the operatorPool assigned to the machine for operatorPool in G.OperatorPoolsList: # find the operatorPool assigned to the machine
...@@ -447,7 +457,7 @@ def createObjects(): ...@@ -447,7 +457,7 @@ def createObjects():
loadDistribution=loadDistribution, setupDistribution=setupDistribution, loadDistribution=loadDistribution, setupDistribution=setupDistribution,
setupMean=setupMean,setupStdev=setupStdev,setupMin=setupMin,setupMax=setupMax, setupMean=setupMean,setupStdev=setupStdev,setupMin=setupMin,setupMax=setupMax,
loadMean=loadMean,loadStdev=loadStdev,loadMin=loadMin,loadMax=loadMax, loadMean=loadMean,loadStdev=loadStdev,loadMin=loadMin,loadMax=loadMax,
repairman=r) repairman=r, isPreemptive=isPreemptive, resetOnPreemption=resetOnPreemption)
M.nextIds=getSuccessorList(id) M.nextIds=getSuccessorList(id)
G.MachineJobShopList.append(M) G.MachineJobShopList.append(M)
G.MachineList.append(M) G.MachineList.append(M)
......
...@@ -48,7 +48,8 @@ class Machine(CoreObject): ...@@ -48,7 +48,8 @@ class Machine(CoreObject):
failureDistribution='No', MTTF=0, MTTR=0, availability=0, repairman='None',\ failureDistribution='No', MTTF=0, MTTR=0, availability=0, repairman='None',\
operatorPool='None',operationType='None',\ operatorPool='None',operationType='None',\
loadDistribution="No",loadMean=0, loadStdev=0, loadMin=0, loadMax=10, loadDistribution="No",loadMean=0, loadStdev=0, loadMin=0, loadMax=10,
setupDistribution="No",setupMean=0, setupStdev=0, setupMin=0, setupMax=10): setupDistribution="No",setupMean=0, setupStdev=0, setupMin=0, setupMax=10,
isPreemptive=False, resetOnPreemption=False):
CoreObject.__init__(self) CoreObject.__init__(self)
# hold the id, name, and type of the Machine instance # hold the id, name, and type of the Machine instance
self.id=id self.id=id
...@@ -124,6 +125,9 @@ class Machine(CoreObject): ...@@ -124,6 +125,9 @@ class Machine(CoreObject):
self.Loading = [] self.Loading = []
self.SettingUp =[] self.SettingUp =[]
self.isPreemptive=isPreemptive
self.resetOnPreemption=resetOnPreemption
# ======================================================================= # =======================================================================
# initialize the machine # initialize the machine
# ======================================================================= # =======================================================================
......
...@@ -26,7 +26,7 @@ extends the machine object so that it can act as a jobshop station. It reads the ...@@ -26,7 +26,7 @@ extends the machine object so that it can act as a jobshop station. It reads the
''' '''
from SimPy.Simulation import Process, Resource from SimPy.Simulation import Process, Resource
from SimPy.Simulation import activate, passivate, waituntil, now, hold from SimPy.Simulation import activate, passivate, waituntil, now, hold, reactivate
from Machine import Machine from Machine import Machine
# =========================================================================== # ===========================================================================
...@@ -137,5 +137,36 @@ class MachineJobShop(Machine): ...@@ -137,5 +137,36 @@ class MachineJobShop(Machine):
and activeObject.Up\ and activeObject.Up\
and (thecaller is self.receiver) and (thecaller is self.receiver)
# =======================================================================
# method to execute preemption
# =======================================================================
def preempt(self):
activeObject=self.getActiveObject()
activeEntity=self.getActiveObjectQueue()[0] #get the active Entity
#calculate the remaining processing time
#if it is reset then set it as the original processing time
if self.resetOnPreemption:
remainingProcessingTime=self.procTime
#else subtract the time that passed since the entity entered
#(may need also failure time if there was. TO BE MELIORATED)
else:
remainingProcessingTime=self.procTime-(now()-self.timeLastEntityEntered)
#update the remaining route of activeEntity
activeEntity.remainingRoute.insert(0, {'stationIdsList':[str(self.id)],\
'processingTime':\
{'distributionType':'Fixed',\
'mean':str(remainingProcessingTime)}})
# activeEntity.remainingRoute.insert(0, [self.id, remainingProcessingTime])
activeEntity.remainingRoute.insert(0, {'stationIdsList':[str(self.lastGiver.id)],\
'processingTime':\
{'distributionType':'Fixed',\
'mean':'0'}})
# activeEntity.remainingRoute.insert(0, [self.lastGiver.id, 0])
#set the receiver as the object where the active entity was preempted from
self.receiver=self.lastGiver
self.next=[self.receiver]
self.waitToDispose=True #set that I have to dispose
self.receiver.timeLastEntityEnded=now() #required to count blockage correctly in the preemptied station
reactivate(self)
\ No newline at end of file
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