Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
dream
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
1
Issues
1
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
dream
Commits
354c1b08
Commit
354c1b08
authored
Sep 25, 2014
by
Ioannis Papagiannopoulos
Committed by
Georgios Dagkakis
Oct 07, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
isInRoute method renamed; isInRouteOf
parent
d9c8ac69
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
23 additions
and
35 deletions
+23
-35
dream/simulation/CoreObject.py
dream/simulation/CoreObject.py
+1
-1
dream/simulation/ExitJobShop.py
dream/simulation/ExitJobShop.py
+1
-1
dream/simulation/Machine.py
dream/simulation/Machine.py
+3
-3
dream/simulation/MachineJobShop.py
dream/simulation/MachineJobShop.py
+5
-5
dream/simulation/MouldAssemblyBufferManaged.py
dream/simulation/MouldAssemblyBufferManaged.py
+3
-3
dream/simulation/OperatorRouter.py
dream/simulation/OperatorRouter.py
+1
-1
dream/simulation/OrderDecomposition.py
dream/simulation/OrderDecomposition.py
+2
-2
dream/simulation/Queue.py
dream/simulation/Queue.py
+2
-2
dream/simulation/QueueJobShop.py
dream/simulation/QueueJobShop.py
+4
-4
dream/simulation/QueueManagedJob.py
dream/simulation/QueueManagedJob.py
+0
-12
dream/simulation/RoutingQueue.py
dream/simulation/RoutingQueue.py
+1
-1
No files found.
dream/simulation/CoreObject.py
View file @
354c1b08
...
@@ -673,7 +673,7 @@ class CoreObject(ManPyObject):
...
@@ -673,7 +673,7 @@ class CoreObject(ManPyObject):
#===========================================================================
#===========================================================================
# method used to check whether the station is a successor of the caller
# method used to check whether the station is a successor of the caller
#===========================================================================
#===========================================================================
def
isInRoute
(
self
,
callerObject
=
None
):
def
isInRoute
Of
(
self
,
callerObject
=
None
):
thecaller
=
callerObject
thecaller
=
callerObject
# if the caller is not defined then return True. We are only interested in checking whether
# if the caller is not defined then return True. We are only interested in checking whether
# the station can accept whatever entity from whichever giver
# the station can accept whatever entity from whichever giver
...
...
dream/simulation/ExitJobShop.py
View file @
354c1b08
...
@@ -47,7 +47,7 @@ class ExitJobShop(Exit):
...
@@ -47,7 +47,7 @@ class ExitJobShop(Exit):
# method used to check whether the station is in the entity-to-be-received route
# method used to check whether the station is in the entity-to-be-received route
# TODO: consider giving the activeEntity as attribute
# TODO: consider giving the activeEntity as attribute
#===========================================================================
#===========================================================================
def
isInRoute
(
self
,
callerObject
=
None
):
def
isInRoute
Of
(
self
,
callerObject
=
None
):
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
activeObject
.
getActiveObjectQueue
()
activeObjectQueue
=
activeObject
.
getActiveObjectQueue
()
thecaller
=
callerObject
thecaller
=
callerObject
...
...
dream/simulation/Machine.py
View file @
354c1b08
...
@@ -965,14 +965,14 @@ class Machine(CoreObject):
...
@@ -965,14 +965,14 @@ class Machine(CoreObject):
return
self
.
operatorPool
.
checkIfResourceIsAvailable
()
\
return
self
.
operatorPool
.
checkIfResourceIsAvailable
()
\
and
self
.
checkIfMachineIsUp
()
\
and
self
.
checkIfMachineIsUp
()
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
self
.
isInRoute
(
thecaller
)
\
and
self
.
isInRoute
Of
(
thecaller
)
\
and
not
self
.
entryIsAssignedTo
()
and
not
self
.
entryIsAssignedTo
()
else
:
else
:
# the operator doesn't have to be present for the loading of the machine as the load operation
# the operator doesn't have to be present for the loading of the machine as the load operation
# is not assigned to operators
# is not assigned to operators
return
self
.
checkIfMachineIsUp
()
\
return
self
.
checkIfMachineIsUp
()
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
self
.
isInRoute
(
thecaller
)
\
and
self
.
isInRoute
Of
(
thecaller
)
\
and
not
self
.
entryIsAssignedTo
()
and
not
self
.
entryIsAssignedTo
()
# =======================================================================
# =======================================================================
...
@@ -1079,7 +1079,7 @@ class Machine(CoreObject):
...
@@ -1079,7 +1079,7 @@ class Machine(CoreObject):
thecaller
=
callerObject
thecaller
=
callerObject
return
len
(
activeObjectQueue
)
>
0
\
return
len
(
activeObjectQueue
)
>
0
\
and
self
.
waitToDispose
\
and
self
.
waitToDispose
\
and
thecaller
.
isInRoute
(
self
)
\
and
thecaller
.
isInRoute
Of
(
self
)
\
and
(
self
.
canDeliverOnInterruption
and
(
self
.
canDeliverOnInterruption
or
self
.
timeLastEntityEnded
==
self
.
env
.
now
or
self
.
timeLastEntityEnded
==
self
.
env
.
now
or
self
.
checkIfActive
())
or
self
.
checkIfActive
())
...
...
dream/simulation/MachineJobShop.py
View file @
354c1b08
...
@@ -117,18 +117,18 @@ class MachineJobShop(Machine):
...
@@ -117,18 +117,18 @@ class MachineJobShop(Machine):
return
self
.
operatorPool
.
checkIfResourceIsAvailable
()
\
return
self
.
operatorPool
.
checkIfResourceIsAvailable
()
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
self
.
checkIfMachineIsUp
()
\
and
self
.
checkIfMachineIsUp
()
\
and
self
.
isInRoute
(
thecaller
)
\
and
self
.
isInRoute
Of
(
thecaller
)
\
and
not
self
.
entryIsAssignedTo
()
and
not
self
.
entryIsAssignedTo
()
else
:
else
:
return
len
(
activeObjectQueue
)
<
self
.
capacity
\
return
len
(
activeObjectQueue
)
<
self
.
capacity
\
and
self
.
checkIfMachineIsUp
()
\
and
self
.
checkIfMachineIsUp
()
\
and
self
.
isInRoute
(
thecaller
)
\
and
self
.
isInRoute
Of
(
thecaller
)
\
and
not
self
.
entryIsAssignedTo
()
and
not
self
.
entryIsAssignedTo
()
#===========================================================================
#===========================================================================
# method used to check whether the station is in the entity-to-be-received route
# method used to check whether the station is in the entity-to-be-received route
#===========================================================================
#===========================================================================
def
isInRoute
(
self
,
callerObject
=
None
):
def
isInRoute
Of
(
self
,
callerObject
=
None
):
activeObjectQueue
=
self
.
Res
.
users
activeObjectQueue
=
self
.
Res
.
users
thecaller
=
callerObject
thecaller
=
callerObject
# if the caller is not defined then return True. We are only interested in checking whether
# if the caller is not defined then return True. We are only interested in checking whether
...
@@ -161,7 +161,7 @@ class MachineJobShop(Machine):
...
@@ -161,7 +161,7 @@ class MachineJobShop(Machine):
return
len
(
activeObjectQueue
)
>
0
\
return
len
(
activeObjectQueue
)
>
0
\
and
self
.
waitToDispose
\
and
self
.
waitToDispose
\
and
self
.
checkIfActive
()
\
and
self
.
checkIfActive
()
\
and
thecaller
.
isInRoute
(
self
)
and
thecaller
.
isInRoute
Of
(
self
)
# =======================================================================
# =======================================================================
# method to execute preemption
# method to execute preemption
...
@@ -205,7 +205,7 @@ class MachineJobShop(Machine):
...
@@ -205,7 +205,7 @@ class MachineJobShop(Machine):
def
canAcceptAndIsRequested
(
self
,
callerObject
):
def
canAcceptAndIsRequested
(
self
,
callerObject
):
giverObject
=
callerObject
giverObject
=
callerObject
assert
giverObject
,
'there must be a caller for canAcceptAndIsRequested'
assert
giverObject
,
'there must be a caller for canAcceptAndIsRequested'
if
self
.
isInRoute
(
giverObject
):
if
self
.
isInRoute
Of
(
giverObject
):
if
Machine
.
canAcceptAndIsRequested
(
self
,
giverObject
):
if
Machine
.
canAcceptAndIsRequested
(
self
,
giverObject
):
self
.
readLoadTime
(
giverObject
)
self
.
readLoadTime
(
giverObject
)
return
True
return
True
...
...
dream/simulation/MouldAssemblyBufferManaged.py
View file @
354c1b08
...
@@ -171,15 +171,15 @@ class MouldAssemblyBufferManaged(QueueManagedJob):
...
@@ -171,15 +171,15 @@ class MouldAssemblyBufferManaged(QueueManagedJob):
# TODO: the activeEntity is already checked for the flag componentsReadyForAssembly
# TODO: the activeEntity is already checked for the flag componentsReadyForAssembly
if
len
(
thecaller
.
getActiveObjectQueue
())
==
0
:
if
len
(
thecaller
.
getActiveObjectQueue
())
==
0
:
if
activeEntity
.
type
==
'Mould'
:
if
activeEntity
.
type
==
'Mould'
:
return
thecaller
.
isInRoute
(
activeObject
)
return
thecaller
.
isInRoute
Of
(
activeObject
)
else
:
else
:
return
thecaller
.
isInRoute
(
activeObject
)
\
return
thecaller
.
isInRoute
Of
(
activeObject
)
\
and
activeEntity
.
order
.
componentsReadyForAssembly
and
activeEntity
.
order
.
componentsReadyForAssembly
# otherwise, check additionally if the receiver holds orderComponents of the same order
# otherwise, check additionally if the receiver holds orderComponents of the same order
# TODO: should revise, this check may be redundant, as the receiver (assembler must be empty in order to start receiving
# TODO: should revise, this check may be redundant, as the receiver (assembler must be empty in order to start receiving
# It is therefore needed that the control is performed by the assembler's getEntity()
# It is therefore needed that the control is performed by the assembler's getEntity()
else
:
else
:
return
thecaller
.
isInRoute
(
activeObject
)
\
return
thecaller
.
isInRoute
Of
(
activeObject
)
\
and
thecaller
.
getActiveObjectQueue
()[
0
].
order
is
activeEntity
.
order
\
and
thecaller
.
getActiveObjectQueue
()[
0
].
order
is
activeEntity
.
order
\
and
activeEntity
.
order
.
componentsReadyForAssembly
and
activeEntity
.
order
.
componentsReadyForAssembly
...
...
dream/simulation/OperatorRouter.py
View file @
354c1b08
...
@@ -381,7 +381,7 @@ class Router(ObjectInterruption):
...
@@ -381,7 +381,7 @@ class Router(ObjectInterruption):
operator
.
candidateEntities
.
append
(
station
.
currentEntity
)
operator
.
candidateEntities
.
append
(
station
.
currentEntity
)
else
:
else
:
for
predecessor
in
station
.
previous
:
for
predecessor
in
station
.
previous
:
if
predecessor
in
self
.
pendingQueues
and
not
station
in
occupiedStations
and
station
.
isInRoute
(
predecessor
):
if
predecessor
in
self
.
pendingQueues
and
not
station
in
occupiedStations
and
station
.
isInRoute
Of
(
predecessor
):
if
predecessor
.
getActiveObjectQueue
()[
0
]
in
self
.
pending
\
if
predecessor
.
getActiveObjectQueue
()[
0
]
in
self
.
pending
\
and
not
predecessor
.
getActiveObjectQueue
()[
0
]
in
occupiedEntities
:
and
not
predecessor
.
getActiveObjectQueue
()[
0
]
in
occupiedEntities
:
operator
.
candidateEntities
.
append
(
predecessor
.
getActiveObjectQueue
()[
0
])
operator
.
candidateEntities
.
append
(
predecessor
.
getActiveObjectQueue
()[
0
])
...
...
dream/simulation/OrderDecomposition.py
View file @
354c1b08
...
@@ -157,13 +157,13 @@ class OrderDecomposition(CoreObject):
...
@@ -157,13 +157,13 @@ class OrderDecomposition(CoreObject):
return
True
return
True
#return True if the OrderDecomposition in the state of disposing and the caller is the receiver
#return True if the OrderDecomposition in the state of disposing and the caller is the receiver
return
self
.
Up
and
thecaller
.
isInRoute
(
activeObject
)
return
self
.
Up
and
thecaller
.
isInRoute
Of
(
activeObject
)
#===========================================================================
#===========================================================================
# method used to check whether the station is in the entity-to-be-received route
# method used to check whether the station is in the entity-to-be-received route
# TODO: consider giving the activeEntity as attribute
# TODO: consider giving the activeEntity as attribute
#===========================================================================
#===========================================================================
def
isInRoute
(
self
,
callerObject
=
None
):
def
isInRoute
Of
(
self
,
callerObject
=
None
):
activeObject
=
self
.
getActiveObject
()
activeObject
=
self
.
getActiveObject
()
activeObjectQueue
=
activeObject
.
getActiveObjectQueue
()
activeObjectQueue
=
activeObject
.
getActiveObjectQueue
()
thecaller
=
callerObject
thecaller
=
callerObject
...
...
dream/simulation/Queue.py
View file @
354c1b08
...
@@ -148,7 +148,7 @@ class Queue(CoreObject):
...
@@ -148,7 +148,7 @@ class Queue(CoreObject):
if
(
callerObject
==
None
):
if
(
callerObject
==
None
):
return
len
(
activeObjectQueue
)
<
self
.
capacity
return
len
(
activeObjectQueue
)
<
self
.
capacity
thecaller
=
callerObject
thecaller
=
callerObject
return
len
(
activeObjectQueue
)
<
self
.
capacity
and
(
self
.
isInRoute
(
thecaller
))
return
len
(
activeObjectQueue
)
<
self
.
capacity
and
(
self
.
isInRoute
Of
(
thecaller
))
# =======================================================================
# =======================================================================
# checks if the Queue can dispose an entity to the following object
# checks if the Queue can dispose an entity to the following object
...
@@ -162,7 +162,7 @@ class Queue(CoreObject):
...
@@ -162,7 +162,7 @@ class Queue(CoreObject):
if
(
callerObject
==
None
):
if
(
callerObject
==
None
):
return
len
(
activeObjectQueue
)
>
0
return
len
(
activeObjectQueue
)
>
0
thecaller
=
callerObject
thecaller
=
callerObject
return
len
(
activeObjectQueue
)
>
0
and
thecaller
.
isInRoute
(
self
)
return
len
(
activeObjectQueue
)
>
0
and
thecaller
.
isInRoute
Of
(
self
)
# =======================================================================
# =======================================================================
# removes an entity from the Object
# removes an entity from the Object
...
...
dream/simulation/QueueJobShop.py
View file @
354c1b08
...
@@ -53,13 +53,13 @@ class QueueJobShop(Queue):
...
@@ -53,13 +53,13 @@ class QueueJobShop(Queue):
#return according to the state of the Queue
#return according to the state of the Queue
#check it the caller object holds an Entity that requests for current object
#check it the caller object holds an Entity that requests for current object
return
len
(
self
.
Res
.
users
)
<
self
.
capacity
\
return
len
(
self
.
Res
.
users
)
<
self
.
capacity
\
and
self
.
isInRoute
(
callerObject
)
and
self
.
isInRoute
Of
(
callerObject
)
#===========================================================================
#===========================================================================
# method used to check whether the station is in the entity-to-be-received route
# method used to check whether the station is in the entity-to-be-received route
# TODO: consider giving the activeEntity as attribute
# TODO: consider giving the activeEntity as attribute
#===========================================================================
#===========================================================================
def
isInRoute
(
self
,
callerObject
=
None
):
def
isInRoute
Of
(
self
,
callerObject
=
None
):
activeObjectQueue
=
self
.
Res
.
users
activeObjectQueue
=
self
.
Res
.
users
thecaller
=
callerObject
thecaller
=
callerObject
# if the caller is not defined then return True. We are only interested in checking whether
# if the caller is not defined then return True. We are only interested in checking whether
...
@@ -88,7 +88,7 @@ class QueueJobShop(Queue):
...
@@ -88,7 +88,7 @@ class QueueJobShop(Queue):
#return True if the Queue has Entities and the caller is in the self.next list
#return True if the Queue has Entities and the caller is in the self.next list
return
len
(
activeObjectQueue
)
>
0
\
return
len
(
activeObjectQueue
)
>
0
\
and
thecaller
.
isInRoute
(
self
)
and
thecaller
.
isInRoute
Of
(
self
)
#===========================================================================
#===========================================================================
# extend the default behaviour to check if whether the station
# extend the default behaviour to check if whether the station
...
@@ -97,7 +97,7 @@ class QueueJobShop(Queue):
...
@@ -97,7 +97,7 @@ class QueueJobShop(Queue):
def
canAcceptAndIsRequested
(
self
,
callerObject
=
None
):
def
canAcceptAndIsRequested
(
self
,
callerObject
=
None
):
giverObject
=
callerObject
giverObject
=
callerObject
assert
giverObject
,
'there must be a caller for canAcceptAndIsRequested'
assert
giverObject
,
'there must be a caller for canAcceptAndIsRequested'
if
self
.
isInRoute
(
giverObject
):
if
self
.
isInRoute
Of
(
giverObject
):
return
Queue
.
canAcceptAndIsRequested
(
self
,
giverObject
)
return
Queue
.
canAcceptAndIsRequested
(
self
,
giverObject
)
# =======================================================================
# =======================================================================
...
...
dream/simulation/QueueManagedJob.py
View file @
354c1b08
...
@@ -80,10 +80,6 @@ class QueueManagedJob(QueueJobShop):
...
@@ -80,10 +80,6 @@ class QueueManagedJob(QueueJobShop):
else
:
else
:
haveEntityWithAvailableManager
=
True
haveEntityWithAvailableManager
=
True
break
break
# for entity in [x for x in activeObjectQueue if x.manager]:
# if entity.manager.checkIfResourceIsAvailable(thecaller):
# haveEntityWithAvailableManager=True
# break
#if none of the Entities has an available manager return False
#if none of the Entities has an available manager return False
if
not
haveEntityWithAvailableManager
:
if
not
haveEntityWithAvailableManager
:
return
False
return
False
...
@@ -95,14 +91,6 @@ class QueueManagedJob(QueueJobShop):
...
@@ -95,14 +91,6 @@ class QueueManagedJob(QueueJobShop):
# and then perform the default behaviour
# and then perform the default behaviour
return
QueueJobShop
.
haveToDispose
(
self
,
thecaller
)
return
QueueJobShop
.
haveToDispose
(
self
,
thecaller
)
# #if we have only one possible receiver just check if the Queue holds one or more entities
# if(thecaller==None):
# return len(activeObjectQueue)>0
#
# #return True if the Queue has Entities and the caller is the receiver
# return len(activeObjectQueue)>0\
# and (thecaller in activeObject.next)\
# and thecaller.isInRoute(activeObject)
#===========================================================================
#===========================================================================
# signalRouter method
# signalRouter method
...
...
dream/simulation/RoutingQueue.py
View file @
354c1b08
...
@@ -60,7 +60,7 @@ class RoutingQueue(Queue):
...
@@ -60,7 +60,7 @@ class RoutingQueue(Queue):
# if yes then that entity can proceed
# if yes then that entity can proceed
isInRouting
=
True
isInRouting
=
True
break
break
return
len
(
activeObjectQueue
)
>
0
and
thecaller
.
isInRoute
(
self
)
and
isInRouting
return
len
(
activeObjectQueue
)
>
0
and
thecaller
.
isInRoute
Of
(
self
)
and
isInRouting
#===========================================================================
#===========================================================================
# sort the entities of the queue for the receiver
# sort the entities of the queue for the receiver
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment