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
62646a29
Commit
62646a29
authored
Dec 06, 2013
by
Ioannis Papagiannopoulos
Committed by
Sebastien Robin
Dec 11, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
First test for OperatedMachine added
parent
29e6b786
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
230 additions
and
4 deletions
+230
-4
dream/simulation/JSONInputs/Topology28.json
dream/simulation/JSONInputs/Topology28.json
+96
-0
dream/simulation/LineGenerationJSON.py
dream/simulation/LineGenerationJSON.py
+96
-0
dream/simulation/OperatedMachine.py
dream/simulation/OperatedMachine.py
+1
-4
dream/test/dump/Topology28.result
dream/test/dump/Topology28.result
+37
-0
No files found.
dream/simulation/JSONInputs/Topology28.json
0 → 100644
View file @
62646a29
{
"_class"
:
"Dream.Simulation"
,
"edges"
:
{
"0"
:
[
"O1"
,
"M1"
,
{}
],
"1"
:
[
"O1"
,
"M2"
,
{}
],
"2"
:
[
"S1"
,
"M1"
,
{}
],
"3"
:
[
"M1"
,
"M2"
,
{}
],
"4"
:
[
"M2"
,
"E1"
,
{}
]
},
"general"
:
{
"_class"
:
"Dream.Configuration"
,
"confidenceLevel"
:
"0.95"
,
"maxSimTime"
:
"1440"
,
"numberOfReplications"
:
"1"
,
"trace"
:
"No"
},
"nodes"
:
{
"E1"
:
{
"_class"
:
"Dream.Exit"
,
"left"
:
0.7083333333333333
,
"top"
:
0.05688622754491013
},
"S1"
:
{
"_class"
:
"Dream.Source"
,
"entity"
:
"Part"
,
"interarrivalTime"
:
{
"distributionType"
:
"Fixed"
,
"mean"
:
"1.5"
},
"left"
:
0.30208333333333337
,
"name"
:
"Source"
,
"top"
:
0.9431137724550899
},
"M1"
:
{
"_class"
:
"Dream.OperatedMachine"
,
"name"
:
"Machine1"
,
"failures"
:
{
},
"setupTime"
:
{
},
"loadTime"
:
{
},
"processingTime"
:
{
"distributionType"
:
"Fixed"
,
"mean"
:
"17"
},
"operationType"
:
"Processing"
,
"left"
:
0.5625
,
"top"
:
0.5
},
"M2"
:
{
"_class"
:
"Dream.OperatedMachine"
,
"name"
:
"Machine2"
,
"failures"
:
{
},
"setupTime"
:
{
},
"loadTime"
:
{
},
"processingTime"
:
{
"distributionType"
:
"Fixed"
,
"mean"
:
"2"
},
"operationType"
:
"Processing"
,
"top"
:
0.2784431137724551
,
"left"
:
0.7083333333333333
},
"O1"
:
{
"_class"
:
"Dream.Operator"
,
"capacity"
:
"1"
,
"left"
:
0.8489583333333334
,
"name"
:
"Operator1"
,
"top"
:
0.721556886227545
}
}
}
dream/simulation/LineGenerationJSON.py
View file @
62646a29
...
...
@@ -78,6 +78,10 @@ from BatchReassembly import BatchReassembly
from
BatchScrapMachine
import
BatchScrapMachine
from
LineClearance
import
LineClearance
from
EventGenerator
import
EventGenerator
from
Operator
import
Operator
from
OperatorPool
import
OperatorPool
from
OperatedPoolBroker
import
Broker
from
OperatedMachine
import
OperatedMachine
import
ExcelHandler
import
time
...
...
@@ -145,6 +149,10 @@ def createObjects():
G
.
LineClearanceList
=
[]
G
.
BatchScrapMachine
=
[]
G
.
EventGeneratorList
=
[]
G
.
OperatorsList
=
[]
G
.
OperatorPoolsList
=
[]
G
.
BrokersList
=
[]
G
.
OperatedMachineList
=
[]
# -----------------------------------------------------------------------
# loop through all the model resources
...
...
@@ -165,6 +173,36 @@ def createObjects():
R
.
coreObjectIds
=
getSuccessorList
(
id
)
# update the list of objects that the repairman repairs
# calling the getSuccessorList() method on the repairman
G
.
RepairmanList
.
append
(
R
)
# add the repairman to the RepairmanList
elif
resourceClass
==
'Dream.Operator'
:
id
=
element
.
get
(
'id'
,
'not found'
)
# get the id of the element / default 'not_found'
name
=
element
.
get
(
'name'
,
'not found'
)
# get the name of the element / default 'not_found'
capacity
=
int
(
element
.
get
(
'capacity'
,
'1'
))
# get the capacity of the el. / defautl '1'
O
=
Operator
(
element_id
,
name
,
capacity
)
# create an operator object
try
:
O
.
coreObjectIds
=
getSuccessorList
(
id
)
# update the list of objects that the operator operates
except
:
# calling the getSuccessorList() method on the operator
pass
G
.
OperatorsList
.
append
(
O
)
# add the repairman to the RepairmanList
elif
resourceClass
==
'Dream.OperatorPool'
:
id
=
element
.
get
(
'id'
,
'not found'
)
# get the id of the element / default 'not_found'
name
=
element
.
get
(
'name'
,
'not found'
)
# get the name of the element / default 'not_found'
capacity
=
int
(
element
.
get
(
'capacity'
,
'1'
))
# get the capacity of the el. / defautl '1'
operatorsList
=
[]
for
operator
in
G
.
OperatorsList
:
# find the operators assigned to the operatorPool
if
id
in
operator
.
coreObjectIds
:
operatorsList
.
append
(
operator
)
# operatorsList = element.get('operatorsList', 'not found')
if
len
(
operatorsList
)
==
0
:
# if the operatorsList is empty then assign no operators
OP
=
OperatorPool
(
element_id
,
name
,
capacity
)
# create a operatorPool object
else
:
OP
=
OperatorPool
(
element_id
,
name
,
capacity
,
operatorsList
)
# create a operatorPool object
OP
.
coreObjectIds
=
getSuccessorList
(
id
)
# update the list of objects that the operators of the operatorPool operate
try
:
for
operator
in
operatorsList
.
values
():
operator
.
coreObjectIds
=
OP
.
coreObjectIds
# update the list of objects that the operators operate
except
:
pass
G
.
OperatorPoolsList
.
append
(
OP
)
# add the repairman to the RepairmanList
# -----------------------------------------------------------------------
# loop through all the elements
# read the data and create them
...
...
@@ -420,6 +458,64 @@ def createObjects():
G
.
LineClearanceList
.
append
(
LC
)
G
.
ObjList
.
append
(
LC
)
elif
objClass
==
'Dream.OperatedMachine'
:
id
=
element
.
get
(
'id'
,
'not found'
)
name
=
element
.
get
(
'name'
,
'not found'
)
processingTime
=
element
.
get
(
'processingTime'
,
'not found'
)
distributionType
=
processingTime
.
get
(
'distributionType'
,
'not found'
)
mean
=
float
(
processingTime
.
get
(
'mean'
,
'0'
))
stdev
=
float
(
processingTime
.
get
(
'stdev'
,
'0'
))
min
=
float
(
processingTime
.
get
(
'min'
,
'0'
))
max
=
float
(
processingTime
.
get
(
'max'
,
'0'
))
failures
=
element
.
get
(
'failures'
,
'not found'
)
failureDistribution
=
failures
.
get
(
'failureDistribution'
,
'not found'
)
MTTF
=
float
(
failures
.
get
(
'MTTF'
,
'0'
))
MTTR
=
float
(
failures
.
get
(
'MTTR'
,
'0'
))
availability
=
float
(
failures
.
get
(
'availability'
,
'0'
))
operationType
=
element
.
get
(
'operationType'
,
'not found'
)
setupTime
=
element
.
get
(
'setupTime'
,
'not found'
)
setupDistribution
=
setupTime
.
get
(
'setupDistribution'
,
'not found'
)
setupMean
=
float
(
setupTime
.
get
(
'setupMean'
,
'0'
))
setupStdev
=
float
(
setupTime
.
get
(
'setupStdev'
,
'0'
))
setupMin
=
float
(
setupTime
.
get
(
'setupMin'
,
'0'
))
setupMax
=
float
(
setupTime
.
get
(
'setupMax'
,
'0'
))
loadTime
=
element
.
get
(
'loadTime'
,
'not found'
)
loadDistribution
=
loadTime
.
get
(
'loadDistribution'
,
'not found'
)
loadMean
=
float
(
loadTime
.
get
(
'loadMean'
,
'0'
))
loadStdev
=
float
(
loadTime
.
get
(
'loadStdev'
,
'0'
))
loadMin
=
float
(
loadTime
.
get
(
'loadMin'
,
'0'
))
loadMax
=
float
(
loadTime
.
get
(
'loadMax'
,
'0'
))
# machineOpertorPoolList=[]
try
:
for
operatorPool
in
G
.
operatorPoolsList
:
# find the operatorPool assigned to the machine
if
(
id
in
operatorPool
.
coreObjectIds
):
# and add it to the machine's operatorPool
machineOperatorPoolList
=
operatorPool
# there must only one operator pool assigned to the machine,
# otherwise only one of them will be taken into account
except
:
# pass
# if len(machineOperatorPoolList)==None: # if there is no operatorPool assigned to the machine
machineOperatorPoolList
=
[]
# find the operators assigned to it and add them to a list
for
operator
in
G
.
OperatorsList
:
# check which operator in the G.OperatorsList
if
(
id
in
operator
.
coreObjectIds
):
# (if any) is assigned to operate
machineOperatorPoolList
.
append
(
operator
)
# the machine with ID equal to id
# if there is no operator assigned then the list will be empty
OM
=
OperatedMachine
(
id
,
name
,
1
,
distribution
=
distributionType
,
failureDistribution
=
failureDistribution
,
MTTF
=
MTTF
,
MTTR
=
MTTR
,
availability
=
availability
,
#repairman=r,
mean
=
mean
,
stdev
=
stdev
,
min
=
min
,
max
=
max
,
operatorPool
=
machineOperatorPoolList
,
operationType
=
operationType
,
loadDistribution
=
loadDistribution
,
setupDistribution
=
setupDistribution
,
setupMean
=
setupMean
,
setupStdev
=
setupStdev
,
setupMin
=
setupMin
,
setupMax
=
setupMax
,
loadMean
=
loadMean
,
loadStdev
=
loadStdev
,
loadMin
=
loadMin
,
loadMax
=
loadMax
)
OM
.
nextIds
=
getSuccessorList
(
id
)
# update the nextIDs list of the machine
G
.
OperatedMachineList
.
append
(
OM
)
# add the machine to the operatedMachines List
G
.
MachineList
.
append
(
OM
)
# add machine to global MachineList
G
.
ObjList
.
append
(
OM
)
# add machine to ObjList
# -----------------------------------------------------------------------
# loop through all the nodes to
# search for Event Generator and create them
...
...
dream/simulation/OperatedMachine.py
View file @
62646a29
...
...
@@ -64,7 +64,7 @@ class OperatedMachine(Machine):
name
=
self
.
objName
+
'_operatorPool'
self
.
operatorPool
=
OperatorPool
(
id
,
name
,
operatorsList
=
operatorPool
)
else
:
self
.
operatorPool
=
ope
ar
torPool
self
.
operatorPool
=
ope
ra
torPool
# update the operatorPool coreObjects list
self
.
operatorPool
.
coreObjectIds
.
append
(
self
.
id
)
self
.
operatorPool
.
coreObjects
.
append
(
self
)
...
...
@@ -106,9 +106,6 @@ class OperatedMachine(Machine):
self
.
Loading
=
[]
self
.
SettingUp
=
[]
# =======================================================================
# initialize the machine
# =======================================================================
...
...
dream/test/dump/Topology28.result
0 → 100644
View file @
62646a29
{
"elementList": [
{
"_class": "Dream.Exit",
"id": "E1",
"results": {
"throughput": 75,
"takt_time": 19.0,
"lifespan": 666.5
}
},
{
"_class": "Dream.Machine",
"id": "M1",
"results": {
"working_ratio": 89.58333333333333,
"blockage_ratio": 0.0,
"failure_ratio": 0.0,
"waiting_ratio": 10.416666666666666
}
},
{
"_class": "Dream.Machine",
"id": "M2",
"results": {
"working_ratio": 10.416666666666666,
"blockage_ratio": 0.0,
"failure_ratio": 0.0,
"waiting_ratio": 89.58333333333333
}
}
],
"_class": "Dream.Simulation",
"general": {
"_class": "Dream.Configuration"
}
}
\ No newline at end of file
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