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
ca168320
Commit
ca168320
authored
Dec 22, 2014
by
Georgios Dagkakis
Committed by
Jérome Perrin
Feb 04, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
changes to create random numbers based on the new format
parent
902c86dd
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
34 additions
and
45 deletions
+34
-45
dream/simulation/Machine.py
dream/simulation/Machine.py
+7
-19
dream/simulation/RandomNumberGenerator.py
dream/simulation/RandomNumberGenerator.py
+17
-15
dream/simulation/Source.py
dream/simulation/Source.py
+10
-11
No files found.
dream/simulation/Machine.py
View file @
ca168320
...
...
@@ -70,7 +70,7 @@ class Machine(CoreObject):
# sets the repairman resource of the Machine
self
.
repairman
=
repairman
# Sets the attributes of the processing (and failure) time(s)
self
.
rng
=
RandomNumberGenerator
(
self
,
**
processingTime
)
self
.
rng
=
RandomNumberGenerator
(
self
,
processingTime
)
# check whether the operators are provided with a skills set
# check whether the operators are provided with a skills set
self
.
dedicatedOperator
=
self
.
checkForDedicatedOperators
()
...
...
@@ -102,11 +102,11 @@ class Machine(CoreObject):
# boolean to check whether the machine is being operated
self
.
toBeOperated
=
False
# define the load times
self
.
loadRng
=
RandomNumberGenerator
(
self
,
**
loadTime
)
self
.
loadRng
=
RandomNumberGenerator
(
self
,
loadTime
)
# XX variable that informs on the need for setup
self
.
setUp
=
True
# define the setup times
self
.
stpRng
=
RandomNumberGenerator
(
self
,
**
setupTime
)
self
.
stpRng
=
RandomNumberGenerator
(
self
,
setupTime
)
# examine if there are multiple operation types performed by the operator
# there can be Setup/Processing operationType
# or the combination of both (MT-Load-Setup-Processing)
...
...
@@ -192,25 +192,13 @@ class Machine(CoreObject):
@
staticmethod
def
getOperationTime
(
time
):
def
refactorTime
(
time
):
if
time
:
if
time
[
"distribution"
]:
time
[
"distributionType"
]
=
time
[
"distribution"
]
for
key
in
time
[
time
[
"distribution"
]]:
time
[
key
]
=
time
[
time
[
"distribution"
]][
key
]
del
time
[
time
[
"distribution"
]]
del
time
[
"distribution"
]
return
time
# XXX update time to comply with old definition
time
=
refactorTime
(
time
)
'''returns the dictionary updated'''
if
not
time
:
time
=
{
'distributionType'
:
'Fixed'
,
'mean'
:
0
}
if
time
[
'distributionType'
]
==
'Normal'
and
\
time
.
get
(
'max'
,
None
)
is
None
:
time
[
'max'
]
=
float
(
time
[
'mean'
])
+
5
*
float
(
time
[
'stdev'
])
time
=
{
'Fixed'
:{
'mean'
:
0
}}
if
'Normal'
in
time
.
keys
()
and
\
time
[
'Normal'
].
get
(
'max'
,
None
)
is
None
:
time
[
'Normal'
][
'max'
]
=
float
(
time
[
'Normal'
][
'mean'
])
+
5
*
float
(
time
[
'Normal'
][
'stdev'
])
return
time
#===========================================================================
...
...
dream/simulation/RandomNumberGenerator.py
View file @
ca168320
...
...
@@ -29,22 +29,24 @@ holds methods for generations of numbers from different distributions
import
math
class
RandomNumberGenerator
(
object
):
def
__init__
(
self
,
obj
,
distribution
Type
,
mean
=
0
,
stdev
=
0
,
min
=
0
,
max
=
0
,
alpha
=
0
,
beta
=
0
,
def
__init__
(
self
,
obj
,
distribution
,
mean
=
0
,
stdev
=
0
,
min
=
0
,
max
=
0
,
alpha
=
0
,
beta
=
0
,
logmean
=
0
,
logsd
=
0
,
probability
=
0
,
shape
=
0
,
scale
=
0
,
location
=
0
,
rate
=
0
,
**
kw
):
self
.
distributionType
=
distributionType
self
.
mean
=
float
(
mean
or
0
)
self
.
stdev
=
float
(
stdev
or
0
)
self
.
min
=
float
(
min
or
0
)
self
.
max
=
float
(
max
or
0
)
self
.
alpha
=
float
(
alpha
or
0
)
self
.
beta
=
float
(
beta
or
0
)
self
.
logmean
=
float
(
logmean
or
0
)
self
.
logsd
=
float
(
logsd
or
0
)
self
.
probability
=
float
(
probability
or
0
)
self
.
shape
=
float
(
shape
or
0
)
self
.
scale
=
float
(
scale
or
0
)
self
.
location
=
float
(
location
or
0
)
self
.
rate
=
float
(
rate
or
0
)
self
.
distribution
=
distribution
self
.
distributionType
=
distribution
.
keys
()[
0
]
parameters
=
distribution
[
self
.
distributionType
]
self
.
mean
=
float
(
parameters
.
get
(
'mean'
,
0
))
self
.
stdev
=
float
(
parameters
.
get
(
'stdev'
,
0
))
self
.
min
=
float
(
parameters
.
get
(
'min'
,
0
))
self
.
max
=
float
(
parameters
.
get
(
'max'
,
0
))
self
.
alpha
=
float
(
parameters
.
get
(
'alpha'
,
0
))
self
.
beta
=
float
(
parameters
.
get
(
'beta'
,
0
))
self
.
logmean
=
float
(
parameters
.
get
(
'logmean'
,
0
))
self
.
logsd
=
float
(
parameters
.
get
(
'logsd'
,
0
))
self
.
probability
=
float
(
parameters
.
get
(
'probability'
,
0
))
self
.
shape
=
float
(
parameters
.
get
(
'shape'
,
0
))
self
.
scale
=
float
(
parameters
.
get
(
'scale'
,
0
))
self
.
location
=
float
(
parameters
.
get
(
'location'
,
0
))
self
.
rate
=
float
(
parameters
.
get
(
'rate'
,
0
))
self
.
obj
=
obj
def
generateNumber
(
self
):
...
...
dream/simulation/Source.py
View file @
ca168320
...
...
@@ -72,7 +72,7 @@ class EntityGenerator(object):
entityCounter
=
G
.
numberOfEntities
+
len
(
self
.
victim
.
scheduledEntities
)
# this is used just ot output the trace correctly
self
.
victim
.
scheduledEntities
.
append
(
self
.
env
.
now
)
self
.
victim
.
outputTrace
(
self
.
victim
.
item
.
type
+
str
(
entityCounter
),
"generated"
)
# output the trace
yield
self
.
env
.
timeout
(
self
.
victim
.
calculateInter
a
rrivalTime
())
# wait until the next arrival
yield
self
.
env
.
timeout
(
self
.
victim
.
calculateInter
A
rrivalTime
())
# wait until the next arrival
#============================================================================
# The Source object is a Process
...
...
@@ -81,22 +81,21 @@ class Source(CoreObject):
#===========================================================================
# the __init__method of the Source class
#===========================================================================
def
__init__
(
self
,
id
,
name
,
inter
a
rrivalTime
=
None
,
entity
=
'Dream.Part'
,
**
kw
):
def
__init__
(
self
,
id
,
name
,
inter
A
rrivalTime
=
None
,
entity
=
'Dream.Part'
,
**
kw
):
# Default values
if
not
inter
a
rrivalTime
:
inter
a
rrivalTime
=
{
'distributionType'
:
'Fixed'
,
'mean'
:
1
}
if
interarrivalTime
[
'distributionType'
]
==
'Normal'
and
\
inter
arrivalTime
.
get
(
'max'
,
None
)
is
None
:
inter
arrivalTime
[
'max'
]
=
interarrivalTime
[
'mean'
]
+
5
*
interarrivalTime
[
'stdev'
]
if
not
inter
A
rrivalTime
:
inter
A
rrivalTime
=
{
'distributionType'
:
'Fixed'
,
'mean'
:
1
}
if
'Normal'
in
interArrivalTime
.
keys
()
and
\
inter
ArrivalTime
[
'Normal'
]
.
get
(
'max'
,
None
)
is
None
:
inter
ArrivalTime
[
'Normal'
][
'max'
]
=
interArrivalTime
[
'Normal'
][
'mean'
]
+
5
*
interArrivalTime
[
'Normal'
]
[
'stdev'
]
CoreObject
.
__init__
(
self
,
id
,
name
)
# properties used for statistics
self
.
total
I
nterArrivalTime
=
0
# the total interarrival time
self
.
total
i
nterArrivalTime
=
0
# the total interarrival time
self
.
numberOfArrivals
=
0
# the number of entities that were created
self
.
type
=
"Source"
#String that shows the type of object
self
.
rng
=
RandomNumberGenerator
(
self
,
**
interarrivalTime
)
self
.
rng
=
RandomNumberGenerator
(
self
,
interArrivalTime
)
self
.
item
=
Globals
.
getClassFromName
(
entity
)
#the type of object that the Source will generate
...
...
@@ -186,7 +185,7 @@ class Source(CoreObject):
#============================================================================
# calculates the processing time
#============================================================================
def
calculateInter
a
rrivalTime
(
self
):
def
calculateInter
A
rrivalTime
(
self
):
return
self
.
rng
.
generateNumber
()
#this is if we have a default interarrival time for all the entities
# =======================================================================
...
...
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