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
e36ff081
Commit
e36ff081
authored
Nov 29, 2013
by
Georgios Dagkakis
Committed by
Jérome Perrin
Dec 02, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
main script for ACO updated to the new notations for wip
parent
61f2b4d5
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
71 additions
and
30 deletions
+71
-30
dream/simulation/LineGenerationJSONAntOptimiser.py
dream/simulation/LineGenerationJSONAntOptimiser.py
+71
-30
No files found.
dream/simulation/LineGenerationJSONAntOptimiser.py
View file @
e36ff081
...
@@ -84,6 +84,7 @@ import json
...
@@ -84,6 +84,7 @@ import json
from
random
import
Random
from
random
import
Random
import
sys
import
sys
import
os.path
import
os.path
import
Globals
# ===========================================================================
# ===========================================================================
# reads general simulation inputs
# reads general simulation inputs
...
@@ -373,34 +374,7 @@ def createObjects():
...
@@ -373,34 +374,7 @@ def createObjects():
C
=
Conveyer
(
id
,
name
,
length
,
speed
)
C
=
Conveyer
(
id
,
name
,
length
,
speed
)
C
.
nextIds
=
getSuccessorList
(
id
)
C
.
nextIds
=
getSuccessorList
(
id
)
G
.
ObjList
.
append
(
C
)
G
.
ObjList
.
append
(
C
)
G
.
ConveyerList
.
append
(
C
)
G
.
ConveyerList
.
append
(
C
)
elif
objClass
==
'Dream.Job'
:
id
=
element
.
get
(
'id'
,
'not found'
)
name
=
element
.
get
(
'name'
,
'not found'
)
priority
=
int
(
element
.
get
(
'priority'
,
'0'
))
dueDate
=
float
(
element
.
get
(
'dueDate'
,
'0'
))
orderDate
=
float
(
element
.
get
(
'orderDate'
,
'0'
))
JSONRoute
=
element
.
get
(
'route'
,
[])
# dummy variable that holds the routes of the jobs
# the route from the JSON file
# is a sequence of dictionaries
route
=
[
None
for
i
in
range
(
len
(
JSONRoute
))]
# variable that holds the argument used in the Job initiation
# hold None for each entry in the 'route' list
for
routeElement
in
JSONRoute
:
# for each 'step' dictionary in the JSONRoute
stepNumber
=
int
(
routeElement
.
get
(
'stepNumber'
,
'0'
))
# get the stepNumber
nextId
=
routeElement
.
get
(
'stationId'
,
'not found'
)
# the stationId
processingTime
=
routeElement
.
get
(
'processingTime'
,
'not found'
)
# and the 'processingTime' dictionary
distributionType
=
processingTime
.
get
(
'distributionType'
,
'not found'
)
# and from that dictionary
# get the 'mean'
mean
=
float
(
processingTime
.
get
(
'mean'
,
'not found'
))
route
[
stepNumber
]
=
[
nextId
,
mean
]
# finally add the 'nextId' and 'mean'
# to the job route
# initiate the job
J
=
Job
(
id
,
name
,
route
,
priority
=
priority
,
dueDate
=
dueDate
,
orderDate
=
orderDate
)
G
.
JobList
.
append
(
J
)
G
.
WipList
.
append
(
J
)
G
.
EntityList
.
append
(
J
)
elif
objClass
==
'Dream.BatchDecomposition'
:
elif
objClass
==
'Dream.BatchDecomposition'
:
id
=
element
.
get
(
'id'
,
'not found'
)
id
=
element
.
get
(
'id'
,
'not found'
)
...
@@ -458,6 +432,72 @@ def createObjects():
...
@@ -458,6 +432,72 @@ def createObjects():
possible_successor
.
previousIds
.
append
(
element
.
id
)
possible_successor
.
previousIds
.
append
(
element
.
id
)
# ===========================================================================
# reads the WIP of the stations
# ===========================================================================
def
createWIP
():
G
.
JobList
=
[]
G
.
WipList
=
[]
G
.
EntityList
=
[]
json_data
=
G
.
JSONData
#Read the json data
nodes
=
json_data
[
'nodes'
]
# read from the dictionary the dicts with key 'nodes'
for
(
element_id
,
element
)
in
nodes
.
iteritems
():
element
[
'id'
]
=
element_id
wip
=
element
.
get
(
'wip'
,
[])
for
entity
in
wip
:
entityClass
=
None
try
:
entityClass
=
entity
.
get
(
'_class'
,
None
)
except
IndexError
:
continue
if
entityClass
==
'Dream.Job'
:
id
=
entity
.
get
(
'id'
,
'not found'
)
name
=
entity
.
get
(
'name'
,
'not found'
)
priority
=
int
(
entity
.
get
(
'priority'
,
'0'
))
dueDate
=
float
(
entity
.
get
(
'dueDate'
,
'0'
))
orderDate
=
float
(
entity
.
get
(
'orderDate'
,
'0'
))
JSONRoute
=
entity
.
get
(
'route'
,
[])
# dummy variable that holds the routes of the jobs
# the route from the JSON file
# is a sequence of dictionaries
route
=
[
None
for
i
in
range
(
len
(
JSONRoute
))]
# variable that holds the argument used in the Job initiation
# hold None for each entry in the 'route' list
for
routeentity
in
JSONRoute
:
# for each 'step' dictionary in the JSONRoute
stepNumber
=
int
(
routeentity
.
get
(
'stepNumber'
,
'0'
))
# get the stepNumber
nextId
=
routeentity
.
get
(
'stationId'
,
'not found'
)
# the stationId
processingTime
=
routeentity
.
get
(
'processingTime'
,
'not found'
)
# and the 'processingTime' dictionary
distributionType
=
processingTime
.
get
(
'distributionType'
,
'not found'
)
# and from that dictionary
# get the 'mean'
mean
=
float
(
processingTime
.
get
(
'mean'
,
'not found'
))
route
[
stepNumber
]
=
[
nextId
,
mean
]
# finally add the 'nextId' and 'mean'
# to the job route
#Below it is to assign an exit if it was not assigned in JSON
#have to talk about it with NEX
exitAssigned
=
False
for
element
in
route
:
elementId
=
element
[
0
]
for
obj
in
G
.
ObjList
:
if
obj
.
id
==
elementId
and
obj
.
type
==
'Exit'
:
exitAssigned
=
True
if
not
exitAssigned
:
exitId
=
None
for
obj
in
G
.
ObjList
:
if
obj
.
type
==
'Exit'
:
exitId
=
obj
.
id
break
if
exitId
:
route
.
append
([
exitId
,
0
])
# initiate the job
J
=
Job
(
id
,
name
,
route
,
priority
=
priority
,
dueDate
=
dueDate
,
orderDate
=
orderDate
)
G
.
JobList
.
append
(
J
)
G
.
WipList
.
append
(
J
)
G
.
EntityList
.
append
(
J
)
# ===========================================================================
# ===========================================================================
# defines the topology (predecessors and successors for all the objects)
# defines the topology (predecessors and successors for all the objects)
# ===========================================================================
# ===========================================================================
...
@@ -560,7 +600,6 @@ def setWIP():
...
@@ -560,7 +600,6 @@ def setWIP():
# the main script that is ran
# the main script that is ran
# ===========================================================================
# ===========================================================================
def
main
(
modelJSON
,
antJSON
):
def
main
(
modelJSON
,
antJSON
):
#argv = argv or sys.argv[1:]
#create an empty list to store all the objects in
#create an empty list to store all the objects in
G
.
ObjList
=
[]
G
.
ObjList
=
[]
...
@@ -574,6 +613,7 @@ def main(modelJSON, antJSON):
...
@@ -574,6 +613,7 @@ def main(modelJSON, antJSON):
G
.
JSONData
=
json
.
loads
(
G
.
InputData
)
# create the dictionary JSONData
G
.
JSONData
=
json
.
loads
(
G
.
InputData
)
# create the dictionary JSONData
readGeneralInput
()
readGeneralInput
()
createObjects
()
createObjects
()
createWIP
()
setQueuesSchedulingRules
()
setQueuesSchedulingRules
()
setTopology
()
setTopology
()
...
@@ -585,8 +625,9 @@ def main(modelJSON, antJSON):
...
@@ -585,8 +625,9 @@ def main(modelJSON, antJSON):
G
.
Rnd
=
Random
(
G
.
seed
)
G
.
Rnd
=
Random
(
G
.
seed
)
initialize
()
#initialize the simulation
initialize
()
#initialize the simulation
createWIP
()
initializeObjects
()
initializeObjects
()
setWIP
(
)
Globals
.
setWIP
(
G
.
EntityList
)
activateObjects
()
activateObjects
()
# if the simulation is ran until no more events are scheduled,
# if the simulation is ran until no more events are scheduled,
...
...
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