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
647ad8f2
Commit
647ad8f2
authored
Jan 21, 2014
by
Jérome Perrin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change the "simulation class" into a configuration class passed at startup time
parent
218f2fbb
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
276 additions
and
208 deletions
+276
-208
dream/platform/__init__.py
dream/platform/__init__.py
+25
-8
dream/platform/static/src/dream_launcher.js
dream/platform/static/src/dream_launcher.js
+9
-190
dream/simulation/Default.py
dream/simulation/Default.py
+0
-9
dream/simulation/GUI/Default.py
dream/simulation/GUI/Default.py
+217
-0
dream/simulation/GUI/MouldingFactory.py
dream/simulation/GUI/MouldingFactory.py
+1
-1
dream/simulation/GUI/__init__.py
dream/simulation/GUI/__init__.py
+24
-0
No files found.
dream/platform/__init__.py
View file @
647ad8f2
...
@@ -107,26 +107,44 @@ def runSimulation():
...
@@ -107,26 +107,44 @@ def runSimulation():
return
jsonify
(
dict
(
error
=
'Timeout after %s seconds'
%
timeout
))
return
jsonify
(
dict
(
error
=
'Timeout after %s seconds'
%
timeout
))
result
=
queue
.
get
()
result
=
queue
.
get
()
app
.
logger
.
debug
(
"result
h:
\
n
%s"
%
(
json
.
dumps
(
result
,
app
.
logger
.
debug
(
"result
\
n
%s"
%
(
json
.
dumps
(
result
,
sort_keys
=
True
,
indent
=
2
)))
sort_keys
=
True
,
indent
=
2
)))
return
jsonify
(
result
)
return
jsonify
(
result
)
def
_runSimulation
(
parameter_dict
,
queue
):
def
_runSimulation
(
parameter_dict
,
queue
):
try
:
try
:
klass_name
=
'dream.simulation.%s'
%
\
result
=
getGUIInstance
().
run
(
parameter_dict
)
parameter_dict
[
'general'
][
'simulationClass'
]
klass
=
__import__
(
klass_name
,
globals
(),
{},
klass_name
)
result
=
klass
.
Simulation
(
logger
=
app
.
logger
).
run
(
parameter_dict
)
queue
.
put
(
dict
(
success
=
result
))
queue
.
put
(
dict
(
success
=
result
))
except
Exception
,
e
:
except
Exception
,
e
:
tb
=
traceback
.
format_exc
()
tb
=
traceback
.
format_exc
()
app
.
logger
.
error
(
tb
)
app
.
logger
.
error
(
tb
)
queue
.
put
(
dict
(
error
=
tb
))
queue
.
put
(
dict
(
error
=
tb
))
def
getGUIInstance
():
# XXX do not instanciate each time!
klass_name
=
'dream.simulation.GUI.Default'
if
len
(
sys
.
argv
)
>
1
:
klass_name
=
'dream.simulation.GUI.%s'
%
sys
.
argv
[
1
]
klass
=
__import__
(
klass_name
,
globals
(),
{},
klass_name
)
instance
=
klass
.
Simulation
(
logger
=
app
.
logger
)
return
instance
@
app
.
route
(
"/getConfigurationDict"
)
def
getConfigurationDict
():
return
jsonify
(
getGUIInstance
().
getConfigurationDict
())
@
app
.
route
(
"/getOutputIdList"
,
methods
=
[
"POST"
,
"OPTIONS"
])
def
getOutputIdList
():
return
jsonify
(
getGUIInstance
().
getOutputIdList
())
@
app
.
route
(
"/getInputIdList"
,
methods
=
[
"POST"
,
"OPTIONS"
])
def
getInputIdList
():
return
jsonify
(
getGUIInstance
().
getInputIdList
())
def
main
(
*
args
):
def
main
(
*
args
):
# start the server
# start the server
file_handler
=
logging
.
FileHandler
(
os
.
path
.
join
(
os
.
path
.
dirname
(
__file__
),
'..'
,
'..'
,
'log'
,
'dream.log'
))
file_handler
=
logging
.
FileHandler
(
os
.
path
.
join
(
os
.
path
.
dirname
(
__file__
),
'..'
,
'..'
,
'log'
,
'dream.log'
))
file_handler
.
setLevel
(
logging
.
DEBUG
)
file_handler
.
setLevel
(
logging
.
DEBUG
)
app
.
logger
.
addHandler
(
file_handler
)
app
.
logger
.
addHandler
(
file_handler
)
app
.
run
(
debug
=
True
)
app
.
run
(
debug
=
True
)
...
@@ -140,7 +158,6 @@ def run(*args):
...
@@ -140,7 +158,6 @@ def run(*args):
output_data
=
queue
.
get
()
output_data
=
queue
.
get
()
print
json
.
dumps
(
output_data
,
indent
=
True
)
print
json
.
dumps
(
output_data
,
indent
=
True
)
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
main
()
main
()
dream/platform/static/src/dream_launcher.js
View file @
647ad8f2
...
@@ -27,198 +27,17 @@
...
@@ -27,198 +27,17 @@
applicationname
:
"
dream
"
applicationname
:
"
dream
"
});
});
var
property_container
=
{
var
configuration
=
{
};
entity
:
{
id
:
"
entity
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
Part
"
},
// XXX is it possible not to repeat id ?
mean
:
{
id
:
"
mean
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0.9
"
},
distributionType
:
{
id
:
"
distributionType
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
Fixed
"
},
stdev
:
{
id
:
"
stdev
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0.1
"
},
min
:
{
id
:
"
min
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0.1
"
},
max
:
{
id
:
"
max
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
1
"
},
failureDistribution
:
{
id
:
"
failureDistribution
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
No
"
},
MTTF
:
{
id
:
"
MTTF
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
40
"
},
MTTR
:
{
id
:
"
MTTR
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
10
"
},
repairman
:
{
id
:
"
repairman
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
None
"
},
isDummy
:
{
id
:
"
isDummy
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0
"
},
schedulingRule
:
{
id
:
"
schedulingRule
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
FIFO
"
},
capacity
:
{
id
:
"
capacity
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
1
"
},
simulationClass
:
{
id
:
"
simulationClass
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
Default
"
},
numberOfReplications
:
{
id
:
"
numberOfReplications
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
10
"
},
maxSimTime
:
{
id
:
"
maxSimTime
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
100
"
},
confidenceLevel
:
{
id
:
"
confidenceLevel
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0.5
"
},
processTimeout
:
{
id
:
"
processTimeout
"
,
type
:
"
string
"
,
_class
:
"
Dream.Property
"
,
_default
:
"
0.5
"
}
};
property_container
[
"
interarrivalTime
"
]
=
{
id
:
"
interarrivalTime
"
,
property_list
:
[
property_container
[
"
mean
"
],
property_container
[
"
distributionType
"
]],
_class
:
"
Dream.PropertyList
"
};
property_container
[
"
processingTime
"
]
=
{
id
:
"
processingTime
"
,
property_list
:
[
property_container
[
"
mean
"
],
property_container
[
"
distributionType
"
],
property_container
[
"
stdev
"
],
property_container
[
"
min
"
],
property_container
[
"
max
"
]
],
_class
:
"
Dream.PropertyList
"
};
property_container
[
"
failures
"
]
=
{
id
:
"
failures
"
,
property_list
:
[
property_container
[
"
failureDistribution
"
],
property_container
[
"
MTTF
"
],
property_container
[
"
MTTR
"
],
property_container
[
"
repairman
"
]
],
_class
:
"
Dream.PropertyList
"
};
var
configuration
=
{
$
.
ajax
(
"
Dream-Source
"
:
{
'
/getConfigurationDict
'
,
{
property_list
:
[
property_container
[
"
interarrivalTime
"
],
success
:
function
(
data
)
{
property_container
[
"
entity
"
]
configuration
=
$
.
extend
(
configuration
,
data
);
],
console
.
log
(
configuration
);
_class
:
'
Dream.Source
'
},
"
Dream-Machine
"
:
{
property_list
:
[
property_container
[
"
processingTime
"
],
property_container
[
"
failures
"
]
],
_class
:
'
Dream.Machine
'
},
"
Dream-Queue
"
:
{
property_list
:
[
property_container
[
"
capacity
"
],
property_container
[
"
isDummy
"
],
property_container
[
"
schedulingRule
"
]
],
_class
:
'
Dream.Queue
'
},
"
Dream-Exit
"
:
{
_class
:
'
Dream.Exit
'
},
"
Dream-MachineJobShop
"
:
{
property_list
:
[
property_container
[
"
processingTime
"
],
property_container
[
"
failures
"
]
],
_class
:
'
Dream.MachineJobShop
'
},
"
Dream-QueueJobShop
"
:
{
property_list
:
[
property_container
[
"
capacity
"
],
property_container
[
"
isDummy
"
],
property_container
[
"
schedulingRule
"
]
],
_class
:
'
Dream.QueueJobShop
'
},
"
Dream-ExitJobShop
"
:
{
_class
:
'
Dream.ExitJobShop
'
},
"
Dream-Repairman
"
:
{
property_list
:
[
property_container
[
"
capacity
"
]],
_class
:
'
Dream.Repairman
'
},
"
Dream-Configuration
"
:
{
property_list
:
[
property_container
[
"
simulationClass
"
],
property_container
[
"
numberOfReplications
"
],
property_container
[
"
maxSimTime
"
],
property_container
[
"
confidenceLevel
"
],
property_container
[
"
processTimeout
"
]
],
_class
:
'
Dream.Repairman
'
}
};
dream_instance
=
Dream
(
configuration
);
dream_instance
=
Dream
(
configuration
);
dream_instance
.
start
();
dream_instance
.
start
();
$
(
"
.tool
"
).
draggable
({
$
(
"
.tool
"
).
draggable
({
containment
:
'
#main
'
,
containment
:
'
#main
'
,
opacity
:
0.7
,
opacity
:
0.7
,
...
@@ -416,11 +235,11 @@
...
@@ -416,11 +235,11 @@
$
(
window
).
resize
(
function
()
{
$
(
window
).
resize
(
function
()
{
dream_instance
.
redraw
();
dream_instance
.
redraw
();
});
});
$
(
"
#result_zone
"
).
hide
();
$
(
"
#result_zone
"
).
hide
();
$
(
"
#graph_zone
"
).
hide
();
$
(
"
#graph_zone
"
).
hide
();
$
(
"
#spreadsheet_output
"
).
hide
();
$
(
"
#spreadsheet_output
"
).
hide
();
$
(
"
#gantt_output
"
).
hide
();
$
(
"
#gantt_output
"
).
hide
();
}
});
});
});
})(
jQuery
);
})(
jQuery
);
dream/simulation/Default.py
deleted
100644 → 0
View file @
218f2fbb
import
json
from
dream.simulation.LineGenerationJSON
import
main
as
simulate_line_json
class
Simulation
:
def
__init__
(
self
,
logger
=
None
):
self
.
logger
=
logger
def
run
(
self
,
data
):
return
json
.
loads
(
simulate_line_json
(
input_data
=
json
.
dumps
(
data
)))
dream/simulation/GUI/Default.py
0 → 100644
View file @
647ad8f2
import
json
from
dream.simulation.LineGenerationJSON
import
main
as
simulate_line_json
schema
=
{
"entity"
:
{
"id"
:
"entity"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"Part"
},
"mean"
:
{
"id"
:
"mean"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0.9"
},
"distributionType"
:
{
"id"
:
"distributionType"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"Fixed"
},
"stdev"
:
{
"id"
:
"stdev"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0.1"
},
"min"
:
{
"id"
:
"min"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0.1"
},
"max"
:
{
"id"
:
"max"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"1"
},
"failureDistribution"
:
{
"id"
:
"failureDistribution"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"No"
},
"MTTF"
:
{
"id"
:
"MTTF"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"40"
},
"MTTR"
:
{
"id"
:
"MTTR"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"10"
},
"repairman"
:
{
"id"
:
"repairman"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"None"
},
"isDummy"
:
{
"id"
:
"isDummy"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0"
},
"schedulingRule"
:
{
"id"
:
"schedulingRule"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"FIFO"
},
"capacity"
:
{
"id"
:
"capacity"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"1"
},
"numberOfReplications"
:
{
"id"
:
"numberOfReplications"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"10"
},
"maxSimTime"
:
{
"id"
:
"maxSimTime"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"100"
},
"confidenceLevel"
:
{
"id"
:
"confidenceLevel"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0.5"
},
"processTimeout"
:
{
"id"
:
"processTimeout"
,
"type"
:
"string"
,
"_class"
:
"Dream.Property"
,
"_default"
:
"0.5"
}
}
schema
[
"interarrivalTime"
]
=
{
"id"
:
"interarrivalTime"
,
"property_list"
:
[
schema
[
"mean"
],
schema
[
"distributionType"
]],
"_class"
:
"Dream.PropertyList"
}
schema
[
"processingTime"
]
=
{
"id"
:
"processingTime"
,
"property_list"
:
[
schema
[
"mean"
],
schema
[
"distributionType"
],
schema
[
"stdev"
],
schema
[
"min"
],
schema
[
"max"
]
],
"_class"
:
"Dream.PropertyList"
}
schema
[
"failures"
]
=
{
"id"
:
"failures"
,
"property_list"
:
[
schema
[
"failureDistribution"
],
schema
[
"MTTF"
],
schema
[
"MTTR"
],
schema
[
"repairman"
]
],
"_class"
:
"Dream.PropertyList"
}
class
Simulation
(
object
):
def
__init__
(
self
,
logger
=
None
):
self
.
logger
=
logger
def
getConfigurationDict
(
self
):
"""Returns the possible nodes to use in the graph editor
"""
return
{
"Dream-Source"
:
{
"property_list"
:
[
schema
[
"interarrivalTime"
],
schema
[
"entity"
]
],
"_class"
:
'Dream.Source'
},
"Dream-Machine"
:
{
"property_list"
:
[
schema
[
"processingTime"
],
schema
[
"failures"
]
],
"_class"
:
'Dream.Machine'
},
"Dream-Queue"
:
{
"property_list"
:
[
schema
[
"capacity"
],
schema
[
"isDummy"
],
schema
[
"schedulingRule"
]
],
"_class"
:
'Dream.Queue'
},
"Dream-Exit"
:
{
"_class"
:
'Dream.Exit'
},
"Dream-MachineJobShop"
:
{
"property_list"
:
[
schema
[
"processingTime"
],
schema
[
"failures"
]
],
"_class"
:
'Dream.MachineJobShop'
},
"Dream-QueueJobShop"
:
{
"property_list"
:
[
schema
[
"capacity"
],
schema
[
"isDummy"
],
schema
[
"schedulingRule"
]
],
"_class"
:
'Dream.QueueJobShop'
},
"Dream-ExitJobShop"
:
{
"_class"
:
'Dream.ExitJobShop'
},
"Dream-Repairman"
:
{
"property_list"
:
[
schema
[
"capacity"
]],
"_class"
:
'Dream.Repairman'
},
"Dream-Configuration"
:
{
"property_list"
:
[
schema
[
"numberOfReplications"
],
schema
[
"maxSimTime"
],
schema
[
"confidenceLevel"
],
schema
[
"processTimeout"
]
],
"_class"
:
'Dream.Configuration'
},
}
def
getOutputIdList
(
self
):
"""Returns the enabled outputs
(the divs ?)
"""
def
getInputIdList
(
self
):
"""Returns the enabled inputs
"""
def
run
(
self
,
data
):
return
json
.
loads
(
simulate_line_json
(
input_data
=
json
.
dumps
(
data
)))
dream/simulation/MouldingFactory.py
→
dream/simulation/
GUI/
MouldingFactory.py
View file @
647ad8f2
...
@@ -4,7 +4,7 @@ import time
...
@@ -4,7 +4,7 @@ import time
import
random
import
random
import
operator
import
operator
from
dream.simulation.Default
import
Simulation
as
DefaultSimulation
from
dream.simulation.
GUI.
Default
import
Simulation
as
DefaultSimulation
# TODO:
# TODO:
# * this class is not specific to moulding anymore. Reorganize.
# * this class is not specific to moulding anymore. Reorganize.
...
...
dream/simulation/GUI/__init__.py
0 → 100644
View file @
647ad8f2
# ===========================================================================
# 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/>.
# ===========================================================================
# See http://peak.telecommunity.com/DevCenter/setuptools#namespace-packages
try
:
__import__
(
'pkg_resources'
).
declare_namespace
(
__name__
)
except
ImportError
:
from
pkgutil
import
extend_path
__path__
=
extend_path
(
__path__
,
__name__
)
\ 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