File: SimGUImanual.rst

package info (click to toggle)
python-simpy 2.3.1%2Bdfsg-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 11,864 kB
  • sloc: python: 11,171; makefile: 143
file content (440 lines) | stat: -rw-r--r-- 13,018 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440


=========================
 SimGUI Manual
=========================

:Authors: Klaus Muller <Muller@users.sourceforge.net>
:SimPy release: |release|
:Web-site: http://simpy.sourceforge.net/
:Python-Version: 2.6 and later
:Date: December 2011


.. contents:: Contents
   :depth: 2

This manual describes **SimGUI**, a GUI framework for SimPy simulation applications.

Acknowledgements
================

The initial ideas for using a Tk/Tkinter-based GUI for SimPy simulation models
and first applications came from Mike Mellor and Prof. Simon Frost of University
of California, San Diego. Simon has been a very productive co-developer of SimGUI.

Following an idea by Simon Frost, SimGUI uses a great Tkinter-based console for conversing
with the Python interpreter, developed by Ka-Ping Yee <ping@lfw.org>.

Introduction
============

SimGUI is a GUI framework for SimPy simulation programs. It provides for:

	- a standard layout of the user interface, including its menu structure
	- running a simulation
	- viewing simulation output
	- saving the output to a file
	- changing the simulation model parameters
	- viewing a model description
	- viewing the simulation program's code
	- a Python console for debugging

SimGUI is based on the Tk GUI library.

SimGUI overview
===============

Here is a minimalistic program which does nothing but show the SimGUI user interface::

    ## SimGUIminimal.py
    from SimPy.SimGUI import *
    root=Tk()
    gu=SimGUI(root,consoleHeight=20)
    gu.mainloop()

Running it produces this output:

.. image:: /_static/images/gui_manual/Minimal.png

The large frame is the **SimGUI application window**. To its right are
the standard menu items of SimGUI. To show them, the menus have been torn off by
clicking on the dotted line on all SimGUI drop-down menu items.

The SimGUI application window consists of five widgets:

	- the outside frame is a Tk Toplevel widget with a default title (which can be changed),

		- a **menu bar**, a Tk Menu widget which can be adapted by the application program (contained in toplevel)
		- the **output window**, a Tk Frame widet for SimPy program output (contained in toplevel)

			- the **status bar** for one-line status messages, a Tk Label widget (contained in output window)

			- the **output console** for application output, a Tk Text widget (contained in output window)

The **File** sub-menu is for saving or opening files and also for quitting the application. By default, it supports
saving the content of the output console.

The **Edit** sub-menu is for any editing or change operations. By default, it supports changing model parameters
and clearing the output console.

The **Run** sub-menu is for running the SimPy model. By default, it is empty, as there is no model to run.

The **View** sub-menu is for calling up any application output, e.g. plots or statistics. By default, it has the ability
to automatically show the data from any Monitor instance in the SimPy application.

The **Help** sub-menu is for viewing any information about SimGUI and the specific application behind it.
By default, it provides information about the version of SimGUI, lists the application's code and allows
the launching of a Python console for testing and debugging purposes.

To show how simple it is to interface a model to SimGUI, here is an example with a simple simulation model::

    #!/usr/bin/env python
    __doc__=""" GUIdemo.py
    This is a very basic model, demonstrating the ease
    of interfacing to SimGUI.
    """
    from __future__ import generators
    from SimPy.Simulation  import *
    from random import *
    from SimPy.SimGUI import *

    class Launcher(Process):
        nrLaunched=0
        def launch(self):
            while True:
                gui.writeConsole("Launch at %.1f"%now())
                Launcher.nrLaunched+=1
                gui.launchmonitor.observe(Launcher.nrLaunched)
                yield hold,self,uniform(1,gui.params.maxFlightTime)
                gui.writeConsole("Boom!!! Aaaah!! at %.1f"%now())

    def model():
        gui.launchmonitor=Monitor(name="Rocket counter",
                                  ylab="nr launched",tlab="time")
        initialize()
        Launcher.nrLaunched=0
        for i in range(gui.params.nrLaunchers):
            lau=Launcher()
            activate(lau,lau.launch())
        simulate(until=gui.params.duration)
        gui.noRunYet=False
        gui.writeStatusLine("%s rockets launched in %.1f minutes"%
                            (Launcher.nrLaunched,now()))

    class MyGUI(SimGUI):
        def __init__(self,win,**par):
            SimGUI.__init__(self,win,**par)
            self.run.add_command(label="Start fireworks",
                                 command=model,underline=0)
            self.params=Parameters(duration=2000,maxFlightTime=11.7,nrLaunchers=3)

    root=Tk()
    gui=MyGUI(root,title="RocketGUI",doc=__doc__,consoleHeight=40)
    gui.mainloop()


It produces the following output when the model run command is selected:

.. image:: /_static/images/gui_manual/GUIdemo.png

class MyGUI adds one menu item under the Run menu. It also defines three parameters
(duration, maxFlighTime and nrLaunchers) with their initial values which the user can
change interactively before each run. The MyGUI instance named gui sets the
window title, the model description (the __doc__ string) and the height of the
output window.

The simulation part of the program writes to the output console and to the status line.

The model uses a Monitor for keeping track of the number of rockets launched over
time. Because it is made an attribute of the MyGUI instance, the super class
(SimGUI) can output the Monitor after a run. This requires no application code.
When the menu item 'Collected data' under the View menu is selected, this
results in:

.. image:: /_static/images/gui_manual/GUIdemoMoni.png

The SimGUI API
===============

Structure
---------
The SimGUI module exposes the following API to the applications programmer::

	class SimGUI(object)
		def __init__
			self.doc = doc
			self.noRunYet=True
			self.top = Menu
			self.file = Menu
			self.edit = Menu
			self.run = Menu
			self.view = Menu
			self.help = Menu
		def makeFileMenu
		def makeEditMenu
		def makeRunMenu
		def makeViewMenu
		def makeHelpMenu
		def writeConsole
		def saveConsole
		def clearConsole
		def writeStatusLine
		def about
		def notdone
		def showTextBox
		def mainloop

	class Parameters
		def __init__
		def show


**class SimGUI, __init__ constructor**
--------------------------------------
Encapsulates the SimGUI functionality.

Call:
	**<variable>.SimGUI(win[,optional parameters])**

Mandatory parameters:
	- **win** : the master widget in which the SimGUI widgets are embedded

Optional parameters:
	- **title=SimGUI** : the title of the top level window (string)
	- **doc=None** : the model description (string)
	- **consoleHeight=50** : the height of the output console in lines (positive integer)

Return value:
	Returns a reference to the SimGUI instance.

**SimGUI instance fields**
---------------------------------------------------
In addition to the constructor parameters, the SimGUI fields of interest
to the applications programmer are:

	- **self.noRunYet=True** : a predicate indicating whether the model has been run yet; must be set to True after each model run; should be tested by application program before any run-dependent output is produced (boolean)
	- **self.top = Menu** : the top level menu widget (menu bar)
	- **self.file = Menu** : the 'File' menu widger
	- **self.edit = Menu** : the 'Edit' menu widget
	- **self.run = Menu** : the 'Run' menu widget
	- **self.view = Menu** : the 'View' menu widget
	- **self.help = Menu** : the 'Help' menu widget

**Adding menu items**
----------------------
Menu items can be added to SimGUI submenus by:

	**<menufield>.add_command(label= <string,command=<callable>, underline=<integer>)**

E.g. *self.run.add_command(label="Start fireworks",command=model,underline=0)*. This is all
standard Tk/Tkinter syntax -- read any Tk/Tkinter manual or book.

**Changing menus**
--------------------
Any of the submenus provided by SimGUI can be replaced by overloading one or
more of the methods **makeFileMenu, makeEditMenu, makeRunMenu, makeViewMenu,
makeHelpMenu**. This is done by defining the methods to be overloaded in the SimGUI
subclass.

The overloading method should look like::

	def makeFileMenu():
		self.file = Menu(self.top)
		self.file.add_command(label='Save some results',
                              command=self.saveResults, underline=0)
		self.file.add_command(label='Get out of here',
                         command=self.win.quit,underline=0)
		self.top.add_cascade(label='File',menu=self.file,underline=0)

*Note: It is advisable to keep the basic the SimGUI menu structure in order
to maintain the SimGUI look-and-feel.*

**writeConsole**
----------------

Writes a string into the output console Text widget, with newline at end.

Call:

	**<SimGUI instance>.writeConsole(text)**

Mandatory parameters:
	None.

Optional parameters:
	- **text=''** : text to write (string)

Return value:
	None.

**saveConsole**
---------------
Saves output console to a text file which the user is prompted to name.

Call:
	**<SimGUI instance>.saveConsole()**

Mandatory parameters:
	None

Optional parameters:
	None

Return value:
	None

**clearConsole**
----------------
Clears output console.

Call:
	**<SimGUI instance>.clearConsole()**

Mandatory parameters:
	None

Optional parameters:
	None

Return value:
	None

**writeStatusLine**
--------------------
Writes a one-line string to the status line.

Call:

	**<SimGUI instance>.writeStatusLine(text)**

Mandatory parameters:
	None.

Optional parameters:
	- **text=''** : text to write (string, not longer than 80 character)

Return value:
	None.

**notdone**
-----------

Brings up a warning box staing that a feature is not implemented yet.
Useful during development of application.

Call:

	**<SimGUI instance>.notdone()**

Mandatory parameters:
	None.

Optional parameters:
	None.

Return value:
	None.

**showTextBox**
---------------
Pops up a text box (Text widget)with a text in it.

Call:

	**<SimGUI instance>.showTextBox(optional parameters)**

Mandatory parameters:
	None.

Optional parameters:
	- **title=''** : title of text box (string)
	- **text=''** : text to write (string)
	- **width=80** : width of box in characters (positive integer)
	- **height=10** : height of box in lines (positive integer)

Return value:
	None.

**mainloop**
------------
Starts up SimGUI execution.

Call:
	**<SimGUI instance>.mainloop()**

Mandatory parameters:
	None.

Optional parameters:
	None.

Return value:
	None

**class Parameters, __init__ constructor and adding parameters**
----------------------------------------------------------------
This class provides for interactive user changes of model parameters. Any user-input
is checked against the type of the original (default) value of the parameter.In this version,
parameters of type integer, floating point, text and list are supported.
Boolean parameters can be implemented by using 0 for False and 1 for True.

Example:
	gui.params=Parameters(endtime=2000,
	numberCustomers=50,
	interval=10.0,
	trace=0)

	This results in parameters gui.params.numberCustomers, gui.params.interval and gui.params.trace.

Call:
	**<SimGUI instance>.params=Parameters(par)** (constructor)
	**<SimGUI instance>.params.<name>=<value>** (adding parameters)

Mandatory parameters:
	- **par** : one or more pairs *<name>=<value>*, separated by commas. <value> must be one of the four types supported.

	- **<name>** : the parameter name (any legal Python identifier)

	- **<value>** : the parameter's initial value (must be one of the four types supported, i.e. integer/boolean, floating point, text and list)
Optional parameters:
	None.

Return value:
	A Parameter instance.

**show**
--------
Returns the parameter name/value pairs of a Parameter instance in pretty-printed form
(one pair per line).

Call:
	**<Parameter instance>.show()**

Mandatory parameters:
	None.

Optional parameters:
	None.

Return value:
	A string with the name/value pairs separated by newline ('\n').

Miscellaneous SimGUI capabilities
=================================

**Source code listing**
-----------------------------
The 'Model code' item of the 'Help' submenu lists the application code
of a running SimGUI application by outputting the content of sys.argv[0].
No user programming is required for this.

**Automatic display of Monitor instances**
----------------------------------------------
After a model run, any Monitor instance which is referred to by a SimGUI (sub)class instance
is shown in the output console by the 'Collected data' item on the 'View'
submenu. Just e.g. **gui.waitMon=Monitor("Waiting times")**, where gui refers to
a SimGUI (sub)class instance, is enough to facilitate this.


$Revision: 297 $ $Date: 2009-03-31 02:24:46 +1300 (Tue, 31 Mar 2009) $ kgm