Commit fdd0be2b authored by Georgios Dagkakis's avatar Georgios Dagkakis Committed by Sebastien Robin

Conveyer code cleaned with the use of new supplementary methods

parent b899a133
...@@ -101,6 +101,9 @@ class Assembly(CoreObject): ...@@ -101,6 +101,9 @@ class Assembly(CoreObject):
self.Res.activeQ=[] self.Res.activeQ=[]
self.Res.waitQ=[] self.Res.waitQ=[]
self.predecessorIndex=0 #holds the index of the predecessor from which the Assembly will take an entity next
self.successorIndex=0 #holds the index of the successor where the Assembly will dispose an entity next
def run(self): def run(self):
while 1: while 1:
......
...@@ -51,6 +51,9 @@ class Conveyer(CoreObject): ...@@ -51,6 +51,9 @@ class Conveyer(CoreObject):
self.Working=[] self.Working=[]
self.Blockage=[] self.Blockage=[]
self.predecessorIndex=0 #holds the index of the predecessor from which the Conveyer will take an entity next
self.successorIndex=0 #holds the index of the successor where the Queue Conveyer dispose an entity next
def initialize(self): def initialize(self):
Process.__init__(self) Process.__init__(self)
self.Res=Resource(capacity=infinity) self.Res=Resource(capacity=infinity)
...@@ -100,6 +103,9 @@ class Conveyer(CoreObject): ...@@ -100,6 +103,9 @@ class Conveyer(CoreObject):
self.currentRequestedLength=0 #the length of the entity that last requested the conveyer self.currentRequestedLength=0 #the length of the entity that last requested the conveyer
self.currentAvailableLength=self.length #the available length in the end of the conveyer self.currentAvailableLength=self.length #the available length in the end of the conveyer
self.predecessorIndex=0 #holds the index of the predecessor from which the Conveyer will take an entity next
self.successorIndex=0 #holds the index of the successor where the Queue Conveyer dispose an entity next
def run(self): def run(self):
#these are just for the first Entity #these are just for the first Entity
...@@ -148,7 +154,7 @@ class Conveyer(CoreObject): ...@@ -148,7 +154,7 @@ class Conveyer(CoreObject):
#for the other entities #for the other entities
for i in range(1,len(self.Res.activeQ)): for i in range(1,len(self.Res.activeQ)):
#if it does not reach the preceding entity move it according to speed #if it does not reach the preceding entity move it according to speed
if self.position[i]+interval*self.speed<self.position[i-1]-self.Res.activeQ[i].length: if self.position[i]+interval*self.speed<self.position[i-1]-self.getActiveObjectQueue()[i].length:
moveTime2=interval moveTime2=interval
self.position[i]=self.position[i]+interval*self.speed self.position[i]=self.position[i]+interval*self.speed
#else move it right before the preceding entity #else move it right before the preceding entity
...@@ -156,31 +162,38 @@ class Conveyer(CoreObject): ...@@ -156,31 +162,38 @@ class Conveyer(CoreObject):
mTime=(self.position[i-1]-self.Res.activeQ[i].length-self.position[i])/self.speed mTime=(self.position[i-1]-self.Res.activeQ[i].length-self.position[i])/self.speed
if mTime>moveTime2: if mTime>moveTime2:
moveTime2=mTime moveTime2=mTime
self.position[i]=self.position[i-1]-self.Res.activeQ[i-1].length self.position[i]=self.position[i-1]-self.getActiveObjectQueue()[i-1].length
self.timeLastMoveHappened=now() #assign this time as the time of last move self.timeLastMoveHappened=now() #assign this time as the time of last move
self.totalWorkingTime+=max(moveTime1/60.0, moveTime2/60.0) #all the time of moving (the max since things move in parallel) self.totalWorkingTime+=max(moveTime1/60.0, moveTime2/60.0) #all the time of moving (the max since things move in parallel)
#is considered as working time #is considered as working time
#checks if the Conveyer can accept an entity #checks if the Conveyer can accept an entity
def canAccept(self, callerObject=None): def canAccept(self, callerObject=None):
activeObjectQueue=self.getActiveObjectQueue()
giverObject=self.getGiverObject()
giverObjectQueue=self.getGiverObjectQueue()
#if there is no object in the predecessor just return false and set the current requested length to zero #if there is no object in the predecessor just return false and set the current requested length to zero
if len(self.previous[0].Res.activeQ)==0: if len(giverObjectQueue)==0:
self.currentRequestedLength=0 self.currentRequestedLength=0
return False return False
requestedLength=self.previous[0].Res.activeQ[0].length #read what length the entity has activeEntity=giverObjectQueue[0]
requestedLength=activeEntity.length #read what length the entity has
self.moveEntities() #move the entities so that the available length can be calculated self.moveEntities() #move the entities so that the available length can be calculated
#in plant an entity can be accepted even if the available length is exactly zero #in plant an entity can be accepted even if the available length is exactly zero
#eg if the conveyer has 8m length and the entities 1m length it can have up to 9 entities. #eg if the conveyer has 8m length and the entities 1m length it can have up to 9 entities.
#i do not know if this is good but I kept is #i do not know if this is good but I kept is
if len(self.Res.activeQ)==0: if len(activeObjectQueue)==0:
availableLength=self.length availableLength=self.length
else: else:
availableLength=self.position[-1] availableLength=self.position[-1]
self.currentAvailableLength=availableLength self.currentAvailableLength=availableLength
self.currentRequestedLength=requestedLength self.currentRequestedLength=requestedLength
#if requestedLength<=availableLength:
if availableLength-requestedLength>-0.00000001: if availableLength-requestedLength>-0.00000001:
return True return True
else: else:
...@@ -188,14 +201,20 @@ class Conveyer(CoreObject): ...@@ -188,14 +201,20 @@ class Conveyer(CoreObject):
#checks if the Conveyer can accept an entity and there is a Frame waiting for it #checks if the Conveyer can accept an entity and there is a Frame waiting for it
def canAcceptAndIsRequested(self): def canAcceptAndIsRequested(self):
return self.canAccept(self) and self.previous[0].haveToDispose(self) return self.canAccept(self) and self.getGiverObject().haveToDispose(self)
#gets an entity from the predecessor #gets an entity from the predecessor
def getEntity(self): def getEntity(self):
self.Res.activeQ.append(self.previous[0].Res.activeQ[0]) #get the entity from the predecessor activeObjectQueue=self.getActiveObjectQueue()
giverObject=self.getGiverObject()
giverObjectQueue=self.getGiverObjectQueue()
giverObject.sortEntities() #sort the Entities of the giver according to the scheduling rule if applied
activeEntity=giverObjectQueue[0]
activeObjectQueue.append(activeEntity) #get the entity from the predecessor
self.position.append(0) #the entity is placed in the start of the conveyer self.position.append(0) #the entity is placed in the start of the conveyer
self.previous[0].removeEntity() #remove the entity from the previous object giverObject.removeEntity() #remove the entity from the previous object
self.outputTrace(self.Res.activeQ[-1].name, "got into "+ self.objName) self.outputTrace(activeEntity.name, "got into "+ self.objName)
#check if the conveyer became full to start counting blockage #check if the conveyer became full to start counting blockage
if self.isFull(): if self.isFull():
self.timeBlockageStarted=now() self.timeBlockageStarted=now()
...@@ -203,8 +222,11 @@ class Conveyer(CoreObject): ...@@ -203,8 +222,11 @@ class Conveyer(CoreObject):
#removes an entity from the Conveyer #removes an entity from the Conveyer
def removeEntity(self): def removeEntity(self):
self.outputTrace(self.Res.activeQ[0].name, "releases "+ self.objName) activeObjectQueue=self.getActiveObjectQueue()
self.Res.activeQ.pop(0) activeEntity=activeObjectQueue[0]
self.outputTrace(activeEntity.name, "releases "+ self.objName)
activeObjectQueue.pop(0)
self.position.pop(0) self.position.pop(0)
self.waitToDispose=False self.waitToDispose=False
#if the conveyer was full, it means that it also was blocked #if the conveyer was full, it means that it also was blocked
...@@ -221,8 +243,7 @@ class Conveyer(CoreObject): ...@@ -221,8 +243,7 @@ class Conveyer(CoreObject):
def haveToDispose(self, callerObject=None): def haveToDispose(self, callerObject=None):
#it has meaning only if there are one or more entities in the conveyer #it has meaning only if there are one or more entities in the conveyer
if len(self.position)>0: if len(self.position)>0:
return len(self.Res.activeQ)>0 and self.length-self.position[0]<0.000001 #the conveyer can dispose an object return len(self.getActiveObjectQueue())>0 and self.length-self.position[0]<0.000001 #the conveyer can dispose an object #only when an entity is at the end of it
#only when an entity is at the end of it
else: else:
return False return False
...@@ -230,8 +251,8 @@ class Conveyer(CoreObject): ...@@ -230,8 +251,8 @@ class Conveyer(CoreObject):
#the conveyer full even when it has one place #the conveyer full even when it has one place
def isFull(self): def isFull(self):
totalLength=0 totalLength=0
for i in range(len(self.Res.activeQ)): for entity in self.getActiveObjectQueue():
totalLength+=self.Res.activeQ[i].length totalLength+=entity.length
return self.length<totalLength return self.length<totalLength
#checks if the Mover should be called so that the move is performed #checks if the Mover should be called so that the move is performed
...@@ -241,9 +262,9 @@ class Conveyer(CoreObject): ...@@ -241,9 +262,9 @@ class Conveyer(CoreObject):
#checks if the conveyer is ready to receive or dispose an entity #checks if the conveyer is ready to receive or dispose an entity
def canAcceptAndIsRequestedORwaitToDispose(self): def canAcceptAndIsRequestedORwaitToDispose(self):
if(len(self.position)>0): if(len(self.position)>0):
if(self.length-self.position[0]<0.000001) and (not self.entityLastReachedEnd==self.Res.activeQ[0]): if(self.length-self.position[0]<0.000001) and (not self.entityLastReachedEnd==self.getActiveObjectQueue()[0]):
self.waitToDispose=True self.waitToDispose=True
self.entityLastReachedEnd=self.Res.activeQ[0] self.entityLastReachedEnd=self.getActiveObjectQueue()[0]
return True return True
else: else:
return self.canAcceptAndIsRequested() return self.canAcceptAndIsRequested()
......
...@@ -102,6 +102,9 @@ class Dismantle(CoreObject): ...@@ -102,6 +102,9 @@ class Dismantle(CoreObject):
self.Res.activeQ=[] self.Res.activeQ=[]
self.Res.waitQ=[] self.Res.waitQ=[]
self.predecessorIndex=0 #holds the index of the predecessor from which the Dismantle will take an entity next
self.successorIndex=0 #holds the index of the successor where the Dismantle will dispose an entity next
def run(self): def run(self):
while 1: while 1:
......
...@@ -106,6 +106,9 @@ class Machine(CoreObject): ...@@ -106,6 +106,9 @@ class Machine(CoreObject):
self.Res=Resource(self.capacity) self.Res=Resource(self.capacity)
self.predecessorIndex=0 #holds the index of the predecessor from which the Machine will take an entity next
self.successorIndex=0 #holds the index of the successor where the Machine will dispose an entity next
#the main process of the machine #the main process of the machine
def run(self): def run(self):
#execute all through simulation time #execute all through simulation time
......
...@@ -85,6 +85,9 @@ class Queue(CoreObject): ...@@ -85,6 +85,9 @@ class Queue(CoreObject):
self.waitToDispose=False #shows if the object waits to dispose an entity self.waitToDispose=False #shows if the object waits to dispose an entity
self.predecessorIndex=0 #holds the index of the predecessor from which the Queue will take an entity next
self.successorIndex=0 #holds the index of the successor where the Queue will dispose an entity next
def run(self): def run(self):
activeObjectQueue=self.getActiveObjectQueue() activeObjectQueue=self.getActiveObjectQueue()
......
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