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
7ab76d15
Commit
7ab76d15
authored
9 years ago
by
panos
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Tests added for the KE tool examples
parent
9c84c898
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
169 additions
and
2 deletions
+169
-2
dream/tests/testKEExamples.py
dream/tests/testKEExamples.py
+169
-2
No files found.
dream/tests/testKEExamples.py
View file @
7ab76d15
...
@@ -57,12 +57,179 @@ class KnowledgeExtractionExamples(TestCase):
...
@@ -57,12 +57,179 @@ class KnowledgeExtractionExamples(TestCase):
elementList
=
result_data
.
get
(
'elementList'
,[])
elementList
=
result_data
.
get
(
'elementList'
,[])
for
element
in
elementList
:
for
element
in
elementList
:
if
element
[
'id'
]
==
'E1'
:
if
element
[
'id'
]
==
'E1'
:
self
.
assertTrue
(
240
<
element
[
'results'
][
'throughput'
][
0
]
<
2
5
0
)
self
.
assertTrue
(
240
<
element
[
'results'
][
'throughput'
][
0
]
<
2
6
0
)
if
element
[
'id'
]
==
'M2'
:
if
element
[
'id'
]
==
'M2'
:
self
.
assertTrue
(
1
1.00
<
element
[
'results'
][
'working_ratio'
][
0
]
<
12
.00
)
self
.
assertTrue
(
1
0.00
<
element
[
'results'
][
'working_ratio'
][
0
]
<
13
.00
)
if
element
[
'id'
]
==
'M1'
:
if
element
[
'id'
]
==
'M1'
:
self
.
assertTrue
(
91.90
<
element
[
'results'
][
'working_ratio'
][
0
]
<
92.90
)
self
.
assertTrue
(
91.90
<
element
[
'results'
][
'working_ratio'
][
0
]
<
92.90
)
jsonFile
.
close
()
jsonFile
.
close
()
def
testAssembleDismantle
(
self
):
from
dream.KnowledgeExtraction.KEtool_examples.AssembleDismantle.AssembleDismantle_example
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtool_examples"
,
"AssembleDismantle"
)
workbook
=
xlrd
.
open_workbook
(
os
.
path
.
join
(
filepath
,
'inputData.xls'
))
jsonFile
=
open
(
os
.
path
.
join
(
filepath
,
'JSON_AssembleDismantle.json'
))
result
=
main
(
test
=
1
,
workbook
=
workbook
,
jsonFile
=
jsonFile
)
result_data
=
json
.
loads
(
result
)
result_data
=
result_data
[
'result'
][
'result_list'
][
0
]
elementList
=
result_data
.
get
(
'elementList'
,[])
for
element
in
elementList
:
if
element
[
'id'
]
==
'M1'
:
self
.
assertTrue
(
96.1
<
element
[
'results'
][
'failure_ratio'
][
0
]
<
97.1
)
if
element
[
'id'
]
==
'M1'
:
self
.
assertTrue
(
0.02
<
element
[
'results'
][
'working_ratio'
][
0
]
<
0.09
)
jsonFile
.
close
()
def
testConveyerLine
(
self
):
from
dream.KnowledgeExtraction.KEtool_examples.ConveyerLine.KEtool_MainScript
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtool_examples"
,
"ConveyerLine"
)
csvFile1
=
open
(
os
.
path
.
join
(
filepath
,
'InterArrivalData.csv'
))
csvFile2
=
open
(
os
.
path
.
join
(
filepath
,
'DataSet.csv'
))
jsonFile
=
open
(
os
.
path
.
join
(
filepath
,
'JSON_ConveyerLine.json'
))
result
=
main
(
test
=
1
,
csvFile1
=
csvFile1
,
csvFile2
=
csvFile2
,
jsonFile
=
jsonFile
)
result_data
=
result
result_data
=
result_data
[
'graph'
]
nodes
=
result_data
.
get
(
'node'
,{})
for
element_id
,
element
in
nodes
.
iteritems
():
if
element_id
==
'M1'
:
self
.
assertEquals
(
element
[
'processingTime'
].
keys
()[
0
],
'Logistic'
)
if
element_id
==
'M2'
:
self
.
assertEquals
(
element
[
'processingTime'
].
keys
()[
0
],
'Logistic'
)
if
element_id
==
'S1'
:
self
.
assertEquals
(
element
[
'interarrivalTime'
].
keys
()[
0
],
'Exp'
)
jsonFile
.
close
()
def
testConfidenceIntervals
(
self
):
from
dream.KnowledgeExtraction.KEtool_examples.ConfidenceIntervals.ConfidenceIntervals_example
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtool_examples"
,
"ConfidenceIntervals"
)
csvFile
=
open
(
os
.
path
.
join
(
filepath
,
'DataSet.csv'
))
result1
,
result2
,
result3
=
main
(
test
=
1
,
csvFile
=
csvFile
)
self
.
assertEquals
(
result1
[
0
],
0.0
)
self
.
assertEquals
(
result1
[
1
],
1.0
)
self
.
assertEquals
(
result2
[
0
],
0.4719902587261917
)
self
.
assertEquals
(
result2
[
1
],
0.5545222108338084
)
self
.
assertEquals
(
result3
[
0
],
1.0
)
self
.
assertEquals
(
result3
[
1
],
1.0
)
def
testSingleServer
(
self
):
from
dream.KnowledgeExtraction.KEtoolSimul8_examples.SingleServer.SingleServer
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtoolSimul8_examples"
,
"SingleServer"
)
workbook1
=
xlrd
.
open_workbook
(
os
.
path
.
join
(
filepath
,
'InterarrivalsData.xls'
))
workbook2
=
xlrd
.
open_workbook
(
os
.
path
.
join
(
filepath
,
'ProcData.xls'
))
simul8XMLFile
=
open
(
os
.
path
.
join
(
filepath
,
'SingleServer.xml'
))
result
=
main
(
test
=
1
,
workbook1
=
workbook1
,
workbook2
=
workbook2
,
simul8XMLFile
=
simul8XMLFile
)
root
=
result
.
getroot
()
for
objects
in
root
.
findall
(
'./SimulationObjects/SimulationObject'
):
if
objects
.
attrib
[
'Type'
]
==
'Work Entry Point'
and
objects
.
attrib
[
'Name'
]
==
'Source'
:
procDist
=
objects
.
find
(
'./InterArrivalTimeSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./InterArrivalTimeSampleData/DistParam1'
)
self
.
assertEquals
(
procDist
.
text
,
'7'
)
self
.
assertEquals
(
procPar1
.
text
,
'3.72710330863'
)
if
objects
.
attrib
[
'Type'
]
==
'Work Center'
and
objects
.
attrib
[
'Name'
]
==
"Activity 1"
:
procDist
=
objects
.
find
(
'./OperationTimeSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./OperationTimeSampleData/DistParam1'
)
procPar2
=
objects
.
find
(
'./OperationTimeSampleData/DistParam2'
)
self
.
assertEquals
(
procDist
.
text
,
'10'
)
self
.
assertEquals
(
procPar1
.
text
,
'14.4634502422'
)
self
.
assertEquals
(
procPar2
.
text
,
'1.03221368006'
)
def
testTopology1
(
self
):
from
dream.KnowledgeExtraction.KEtoolSimul8_examples.Topology1.Topology1
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtoolSimul8_examples"
,
"Topology1"
)
workbook
=
xlrd
.
open_workbook
(
os
.
path
.
join
(
filepath
,
'DataSet.xlsx'
))
csvFile
=
open
(
os
.
path
.
join
(
filepath
,
'ProcTimesData.csv'
))
simul8XMLFile
=
open
(
os
.
path
.
join
(
filepath
,
'Topology1.xml'
))
result
=
main
(
test
=
1
,
workbook
=
workbook
,
csvFile
=
csvFile
,
simul8XMLFile
=
simul8XMLFile
)
root
=
result
.
getroot
()
for
objects
in
root
.
findall
(
'./SimulationObjects/SimulationObject'
):
if
objects
.
attrib
[
'Type'
]
==
'Work Entry Point'
and
objects
.
attrib
[
'Name'
]
==
'Source'
:
procDist
=
objects
.
find
(
'./InterArrivalTimeSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./InterArrivalTimeSampleData/DistParam1'
)
self
.
assertEquals
(
procDist
.
text
,
'7'
)
self
.
assertEquals
(
procPar1
.
text
,
'3.81461051661'
)
if
objects
.
attrib
[
'Type'
]
==
'Work Center'
and
objects
.
attrib
[
'Name'
]
==
"Activity 1"
:
procDist
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistParam1'
)
procPar2
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistParam2'
)
self
.
assertEquals
(
procDist
.
text
,
'3'
)
self
.
assertEquals
(
procPar1
.
text
,
'60.241674662'
)
self
.
assertEquals
(
procPar2
.
text
,
'13.6343562616'
)
procDist
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistParam1'
)
procPar2
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistParam2'
)
self
.
assertEquals
(
procDist
.
text
,
'9'
)
self
.
assertEquals
(
procPar1
.
text
,
'2.49625391491'
)
self
.
assertEquals
(
procPar2
.
text
,
'0.0808226713028'
)
def
testParallelStations
(
self
):
from
dream.KnowledgeExtraction.KEtool_examples.ParallelStations_withfailures.ParallelStations_example
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtool_examples"
,
"ParallelStations_withfailures"
)
DBFilePath
=
(
"C:
\
Use
r
s
\
P
a
nos
\
Docume
n
ts
\
KE
t
ool_documentation"
)
jsonFile
=
open
(
os
.
path
.
join
(
filepath
,
'JSON_example.json'
))
result
=
main
(
test
=
1
,
DBFilePath
=
DBFilePath
,
jsonFile
=
jsonFile
)
result_data
=
result
result_data
=
result_data
[
'graph'
]
nodes
=
result_data
.
get
(
'node'
,{})
for
element_id
,
element
in
nodes
.
iteritems
():
if
element_id
==
'M1'
:
self
.
assertEquals
(
element
[
'processingTime'
].
keys
()[
0
],
'Logistic'
)
self
.
assertEquals
(
element
[
'processingTime'
].
values
()[
0
][
'scale'
],
5.943555041732533
)
self
.
assertEquals
(
element
[
'processingTime'
].
values
()[
0
][
'location'
],
51.57623425532299
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTR'
].
keys
()[
0
],
'Poisson'
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTR'
].
values
()[
0
][
'lambda'
],
0.1053658536585366
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
keys
()[
0
],
'Weibull'
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
values
()[
0
][
'shape'
],
3.1671825421393747
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
values
()[
0
][
'scale'
],
0.7571939493062068
)
if
element_id
==
'M2'
:
self
.
assertEquals
(
element
[
'processingTime'
].
keys
()[
0
],
'Cauchy'
)
self
.
assertEquals
(
element
[
'processingTime'
].
values
()[
0
][
'scale'
],
1.7219415441266923
)
self
.
assertEquals
(
element
[
'processingTime'
].
values
()[
0
][
'location'
],
49.732494067271205
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTR'
].
keys
()[
0
],
'Poisson'
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTR'
].
values
()[
0
][
'lambda'
],
0.1423076923076923
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
keys
()[
0
],
'Weibull'
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
values
()[
0
][
'shape'
],
3.1975046230623905
)
self
.
assertEquals
(
element
[
'interruptions'
][
'failure'
][
'TTF'
].
values
()[
0
][
'scale'
],
0.6805471087485552
)
jsonFile
.
close
()
def
testParallelStationsFailures
(
self
):
from
dream.KnowledgeExtraction.KEtoolSimul8_examples.ParallelStationsFailures.ParallelStationsFailures
import
main
filepath
=
os
.
path
.
join
(
project_path
,
"dream"
,
"KnowledgeExtraction"
,
"KEtoolSimul8_examples"
,
"ParallelStationsFailures"
)
DBFilePath
=
(
"C:
\
Use
r
s
\
P
a
nos
\
Docume
n
ts
\
KE
t
ool_documentation"
)
simul8XMLFile
=
open
(
os
.
path
.
join
(
filepath
,
'ParallelStations.xml'
))
result
=
main
(
test
=
1
,
DBFilePath
=
DBFilePath
,
simul8XMLFile
=
simul8XMLFile
)
root
=
result
.
getroot
()
for
objects
in
root
.
findall
(
'./SimulationObjects/SimulationObject'
):
if
objects
.
attrib
[
'Type'
]
==
'Work Center'
and
objects
.
attrib
[
'Name'
]
==
"MILL1"
:
procDist
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistParam1'
)
procPar2
=
objects
.
find
(
'./BreakDowns/MTBFSampleData/DistParam2'
)
self
.
assertEquals
(
procDist
.
text
,
'7'
)
self
.
assertEquals
(
procPar1
.
text
,
'1.47747747748'
)
procDist
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistribType'
)
procPar1
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistParam1'
)
procPar2
=
objects
.
find
(
'./BreakDowns/MTTRSampleData/DistParam2'
)
self
.
assertEquals
(
procDist
.
text
,
'3'
)
self
.
assertEquals
(
procPar1
.
text
,
'0.105365853659'
)
self
.
assertEquals
(
procPar2
.
text
,
'0.0566050743643'
)
\ No newline at end of file
This diff is collapsed.
Click to expand it.
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