Commit 713789ea authored by Jérome Perrin's avatar Jérome Perrin

Merge branch 'ulbranch'

parents ffa22d43 7ef38f88
# ===========================================================================
# Copyright 2013 University of Limerick
#
# This file is part of DREAM.
#
# DREAM is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# DREAM is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with DREAM. If not, see <http://www.gnu.org/licenses/>.
# ===========================================================================
'''
Created on 14 11 2013
@author: George
'''
'''
Customization of the BatchDecomposition so that it sets the start time in the Batch.
Custom object. Maybe we should have a generic method that the objects can call in order to set that
'''
from BatchDecomposition import BatchDecomposition
from SimPy.Simulation import now
class BatchDecompositionStartTime(BatchDecomposition):
'''
#gets an entity from the predecessor
def getEntity(self):
activeEntity=BatchDecomposition.getEntity(self)
activeEntity.startTime=now()
return activeEntity
'''
#removes an entity from the object
def removeEntity(self):
# if it is the first sub-batch of the parent batch that leaves
# assign it as the batch start time
if len(self.getActiveObjectQueue())==self.numberOfSubBatches:
batch=self.getActiveObjectQueue()[0].parentBatch
batch.startTime=now()
activeEntity=BatchDecomposition.removeEntity(self)
return activeEntity
...@@ -55,7 +55,7 @@ class Job(Entity): # inherits from the Entity c ...@@ -55,7 +55,7 @@ class Job(Entity): # inherits from the Entity c
json['_class'] = 'Dream.Job' json['_class'] = 'Dream.Job'
json['id'] = str(self.id) json['id'] = str(self.id)
json['results'] = {} json['results'] = {}
json['extraPropertyDict'] = self.extraPropertyDict #json['extraPropertyDict'] = self.extraPropertyDict
#if the Job has reached an exit, input completion time in the results #if the Job has reached an exit, input completion time in the results
if self.schedule[-1][0].type=='Exit': if self.schedule[-1][0].type=='Exit':
......
# ===========================================================================
# Copyright 2013 University of Limerick
#
# This file is part of DREAM.
#
# DREAM is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# DREAM is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with DREAM. If not, see <http://www.gnu.org/licenses/>.
# ===========================================================================
'''
Created on 14 11 2013
@author: George
'''
'''
Customization of BatchScrapMachine so that it gets blocked if the succeeding BatchDecomposition is blocked.
Custom object, not too much of generic use. Maybe in the future there should be a composite
BatchScrapMachine->BatchDecomposition
'''
from BatchScrapMachine import BatchScrapMachine
from SimPy.Simulation import now
class M3(BatchScrapMachine):
# =======================================================================
# This is only for a BatchScrapMachine that is followed by a BatchDecomposition
# We consider that since this is in essence one station, the BatchScrapMachine should be blocked if the
# should be blocked if the BatchDecomposition is blocked
# =======================================================================
def canAcceptAndIsRequested(self):
# get active and giver objects
activeObject=self.getActiveObject()
activeObjectQueue=self.getActiveObjectQueue()
giverObject=self.getGiverObject()
nextObject=self.next[0]
batchReassemblyHoldsBatch=False
if len(nextObject.getActiveObjectQueue())>0:
if nextObject.getActiveObjectQueue()[0].type=='Batch' or len(nextObject.getActiveObjectQueue())==4:
batchReassemblyHoldsBatch=True
# if we have only one predecessor just check if there is a place,
# the machine is up and the predecessor has an entity to dispose
# this is done to achieve better (cpu) processing time
if(len(activeObject.previous)==1):
return activeObject.Up and len(activeObjectQueue)<activeObject.capacity\
and giverObject.haveToDispose(activeObject) and (not batchReassemblyHoldsBatch)
\ No newline at end of file
...@@ -31,11 +31,16 @@ from SimPy.Simulation import Resource ...@@ -31,11 +31,16 @@ from SimPy.Simulation import Resource
# =========================================================================== # ===========================================================================
class ObjectResource(object): class ObjectResource(object):
def __init__(self):
self.initialized = False
def initialize(self): def initialize(self):
self.totalWorkingTime=0 #holds the total working time self.totalWorkingTime=0 #holds the total working time
self.totalWaitingTime=0 #holds the total waiting time self.totalWaitingTime=0 #holds the total waiting time
self.timeLastOperationStarted=0 #holds the time that the last repair was started self.timeLastOperationStarted=0 #holds the time that the last repair was started
self.Res=Resource(self.capacity) self.Res=Resource(self.capacity)
# variable that checks weather the resource is already initialized
self.initialized = True
# ======================================================================= # =======================================================================
# checks if the worker is available # checks if the worker is available
...@@ -91,3 +96,9 @@ class ObjectResource(object): ...@@ -91,3 +96,9 @@ class ObjectResource(object):
def getResourceQueue(self): def getResourceQueue(self):
return self.Res.activeQ return self.Res.activeQ
# =======================================================================
# check if the resource is already initialized
# =======================================================================
def isInitialized(self):
return self.initialized
...@@ -80,7 +80,10 @@ class OperatorPool(ObjectResource): ...@@ -80,7 +80,10 @@ class OperatorPool(ObjectResource):
# self.timeLastOperationStarted=0 #holds the time that the last operation was started # self.timeLastOperationStarted=0 #holds the time that the last operation was started
# initialize the operators # initialize the operators
# an operator that may have been initialized by an other operator pool, is initiated again
# reconsider
for operator in self.operators: for operator in self.operators:
if not operator.isInitialized():
operator.initialize() operator.initialize()
# ======================================================================= # =======================================================================
......
...@@ -37,6 +37,7 @@ from ObjectResource import ObjectResource ...@@ -37,6 +37,7 @@ from ObjectResource import ObjectResource
class Repairman(ObjectResource): class Repairman(ObjectResource):
def __init__(self, id, name, capacity=1): def __init__(self, id, name, capacity=1):
ObjectResource.__init__(self)
self.id=id self.id=id
self.objName=name self.objName=name
self.capacity=capacity # repairman is an instance of resource self.capacity=capacity # repairman is an instance of resource
......
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