Commit 1bd4eeef authored by Jérome Perrin's avatar Jérome Perrin

Display change in station status

parent 5022baef
...@@ -356,11 +356,17 @@ ...@@ -356,11 +356,17 @@
displayEntities(destination, message.destination); displayEntities(destination, message.destination);
} }
})() })()
}
function changeStatus(message, queue) {
} var obj = dream_instance.getElementId(message.object);
dream_instance.updateElementData(message.object,
{status: message.status})
$("#now").text(message.time.toFixed(2));
$(queue).dequeue()
}
function notifyEndSimulation(message){ function notifyEndSimulation(message, queue){
$("#json_result").val(JSON.stringify(message['success'], $("#json_result").val(JSON.stringify(message['success'],
undefined, " ")); undefined, " "));
$("#loading_spinner").hide(); $("#loading_spinner").hide();
...@@ -381,17 +387,25 @@ ...@@ -381,17 +387,25 @@
); );
}); });
dream_instance.displayResult(0); dream_instance.displayResult(0);
$(queue).dequeue()
} }
function onWebSocketMessage(e) { function onWebSocketMessage(e) {
var message = JSON.parse(e.data) var message = JSON.parse(e.data)
// XXX queue process message ?
if (message.action === "move_entity"){ if (message.action === "move_entity"){
$("#main").queue(function() { $("#main").queue(function() {
moveEntity(message, this); moveEntity(message, this);
}) })
} }
if (message.action === "status_change"){
$("#main").queue(function() {
changeStatus(message, this);
})
}
if (message['success']) { if (message['success']) {
$("#main").queue(function() { $("#main").queue(function() {
notifyEndSimulation(message, this); notifyEndSimulation(message, this);
......
...@@ -181,7 +181,15 @@ class CoreObject(Process): ...@@ -181,7 +181,15 @@ class CoreObject(Process):
self.offShiftTimeTryingToReleaseCurrentEntity=self.timeLastShiftStarted-self.timeLastShiftEnded self.offShiftTimeTryingToReleaseCurrentEntity=self.timeLastShiftStarted-self.timeLastShiftEnded
blockage=now()-(self.timeLastEntityEnded+self.downTimeInTryingToReleaseCurrentEntity+self.offShiftTimeTryingToReleaseCurrentEntity) blockage=now()-(self.timeLastEntityEnded+self.downTimeInTryingToReleaseCurrentEntity+self.offShiftTimeTryingToReleaseCurrentEntity)
self.totalBlockageTime+=blockage self.totalBlockageTime+=blockage
def changeStatus(self, new_status):
self.status = new_status
from Globals import send
send({"action": "status_change",
"object": self.id,
"status": new_status,
"time": now()})
# ======================================================================= # =======================================================================
# gets an entity from the giver # gets an entity from the giver
# ======================================================================= # =======================================================================
......
...@@ -86,6 +86,10 @@ class Machine(CoreObject): ...@@ -86,6 +86,10 @@ class Machine(CoreObject):
self.MTTF=MTTF self.MTTF=MTTF
self.MTTR=MTTR self.MTTR=MTTR
self.availability=availability self.availability=availability
self.changeStatus('waiting') # Can be 'failure', 'working', 'waiting',
# 'blocked' or 'offshift'
''' sets the operator resource of the Machine ''' sets the operator resource of the Machine
check if the operatorPool is a List or a OperatorPool type Object check if the operatorPool is a List or a OperatorPool type Object
if it is a list then initiate a OperatorPool type object containing if it is a list then initiate a OperatorPool type object containing
...@@ -143,6 +147,7 @@ class Machine(CoreObject): ...@@ -143,6 +147,7 @@ class Machine(CoreObject):
def initialize(self): def initialize(self):
# using the Process __init__ and not the CoreObject __init__ # using the Process __init__ and not the CoreObject __init__
CoreObject.initialize(self) CoreObject.initialize(self)
self.changeStatus('waiting')
# initialize the internal Queue (type Resource) of the Machine # initialize the internal Queue (type Resource) of the Machine
self.Res=Resource(self.capacity) self.Res=Resource(self.capacity)
# initiate the Broker responsible to control the request/release # initiate the Broker responsible to control the request/release
...@@ -199,6 +204,7 @@ class Machine(CoreObject): ...@@ -199,6 +204,7 @@ class Machine(CoreObject):
def run(self): def run(self):
# execute all through simulation time # execute all through simulation time
while 1: while 1:
self.changeStatus('waiting')
# wait until the machine can accept an entity and one predecessor requests it # wait until the machine can accept an entity and one predecessor requests it
# canAcceptAndIsRequested is invoked to check when the machine requested to receive an entity # canAcceptAndIsRequested is invoked to check when the machine requested to receive an entity
yield waituntil, self, self.canAcceptAndIsRequested yield waituntil, self, self.canAcceptAndIsRequested
...@@ -297,6 +303,7 @@ class Machine(CoreObject): ...@@ -297,6 +303,7 @@ class Machine(CoreObject):
# 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():
self.timeSetupStarted = now() self.timeSetupStarted = now()
self.changeStatus('working')
yield hold,self,self.calculateSetupTime() yield hold,self,self.calculateSetupTime()
# if self.interrupted(): There is the issue of failure during the setup # if self.interrupted(): There is the issue of failure during the setup
self.timeSetupEnded = now() self.timeSetupEnded = now()
...@@ -323,6 +330,7 @@ class Machine(CoreObject): ...@@ -323,6 +330,7 @@ class Machine(CoreObject):
self.downTimeInCurrentEntity=0 #holds the total time that the self.downTimeInCurrentEntity=0 #holds the total time that the
#object was down while holding current entity #object was down while holding current entity
self.changeStatus('working')
# this loop is repeated until the processing time is expired with no failure # this loop is repeated until the processing time is expired with no failure
# check when the processingEndedFlag switched to false # check when the processingEndedFlag switched to false
while processingNotFinished: while processingNotFinished:
...@@ -360,6 +368,7 @@ class Machine(CoreObject): ...@@ -360,6 +368,7 @@ class Machine(CoreObject):
self.releaseOperator() self.releaseOperator()
yield waituntil,self,self.broker.brokerIsSet yield waituntil,self,self.broker.brokerIsSet
self.changeStatus('failure')
# 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
...@@ -425,6 +434,7 @@ class Machine(CoreObject): ...@@ -425,6 +434,7 @@ class Machine(CoreObject):
self.timeLastEntityEnded=now() # this holds the time that the last entity ended processing in Machine self.timeLastEntityEnded=now() # this holds the time that the last entity ended processing in Machine
self.nameLastEntityEnded=self.currentEntity.name # this holds the name of the last entity that ended processing in Machine self.nameLastEntityEnded=self.currentEntity.name # this holds the name of the last entity that ended processing in Machine
self.completedJobs+=1 # Machine completed one more Job self.completedJobs+=1 # Machine completed one more Job
self.changeStatus('blocked')
# =============== release resource after the end of processing # =============== release resource after the end of processing
......
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