y_nelson 2.1.0 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/{Ruby_for_YNelson_Users_in_20_minutes.lyx → Introduction_to_Ruby_for_YNelson_Users.lyx} +1042 -55
- data/Introduction_to_Ruby_for_YNelson_Users.pdf +0 -0
- data/Introduction_to_YNelson.lyx +23 -18
- data/Introduction_to_YNelson.pdf +0 -0
- data/LICENSE.txt +1 -2
- data/Object_model_of_YNelson_and_YPetri.lyx +3806 -0
- data/Object_model_of_YNelson_and_YPetri.pdf +0 -0
- data/README.md +1 -0
- data/Rakefile +1 -0
- data/lib/y_nelson/agent.rb +57 -117
- data/lib/y_nelson/dsl.rb +3 -2
- data/lib/y_nelson/place.rb +0 -1
- data/lib/y_nelson/version.rb +1 -1
- data/lib/y_nelson/zz_point.rb +1 -1
- data/lib/y_nelson.rb +16 -2
- data/y_nelson.gemspec +3 -3
- metadata +10 -15
- data/Ruby_for_YNelson_Users_in_20_minutes.pdf +0 -0
- data/YNelson_&_YPetri_User_Manual.lyx +0 -1037
- data/YNelson_&_YPetri_User_Manual.pdf +0 -0
- data/YNelson_-_Hands-on_Tutorial.lyx +0 -3701
- data/YNelson_-_Hands-on_Tutorial.pdf +0 -0
- data/config/mongoid.yml +0 -6
- data/lib/y_nelson/zz.png +0 -0
- data/test/zz.png +0 -0
@@ -0,0 +1,3806 @@
|
|
1
|
+
#LyX 2.0 created this file. For more info see http://www.lyx.org/
|
2
|
+
\lyxformat 413
|
3
|
+
\begin_document
|
4
|
+
\begin_header
|
5
|
+
\textclass article
|
6
|
+
\use_default_options false
|
7
|
+
\maintain_unincluded_children false
|
8
|
+
\language english
|
9
|
+
\language_package default
|
10
|
+
\inputencoding auto
|
11
|
+
\fontencoding global
|
12
|
+
\font_roman default
|
13
|
+
\font_sans default
|
14
|
+
\font_typewriter default
|
15
|
+
\font_default_family default
|
16
|
+
\use_non_tex_fonts false
|
17
|
+
\font_sc false
|
18
|
+
\font_osf false
|
19
|
+
\font_sf_scale 100
|
20
|
+
\font_tt_scale 100
|
21
|
+
|
22
|
+
\graphics default
|
23
|
+
\default_output_format default
|
24
|
+
\output_sync 0
|
25
|
+
\bibtex_command default
|
26
|
+
\index_command default
|
27
|
+
\paperfontsize default
|
28
|
+
\spacing single
|
29
|
+
\use_hyperref false
|
30
|
+
\papersize default
|
31
|
+
\use_geometry true
|
32
|
+
\use_amsmath 1
|
33
|
+
\use_esint 1
|
34
|
+
\use_mhchem 1
|
35
|
+
\use_mathdots 1
|
36
|
+
\cite_engine natbib_authoryear
|
37
|
+
\use_bibtopic false
|
38
|
+
\use_indices false
|
39
|
+
\paperorientation portrait
|
40
|
+
\suppress_date false
|
41
|
+
\use_refstyle 0
|
42
|
+
\index Index
|
43
|
+
\shortcut idx
|
44
|
+
\color #008000
|
45
|
+
\end_index
|
46
|
+
\leftmargin 2.2cm
|
47
|
+
\topmargin 3cm
|
48
|
+
\rightmargin 2.2cm
|
49
|
+
\bottommargin 3cm
|
50
|
+
\secnumdepth 3
|
51
|
+
\tocdepth 3
|
52
|
+
\paragraph_separation indent
|
53
|
+
\paragraph_indentation default
|
54
|
+
\quotes_language english
|
55
|
+
\papercolumns 1
|
56
|
+
\papersides 1
|
57
|
+
\paperpagestyle default
|
58
|
+
\tracking_changes false
|
59
|
+
\output_changes false
|
60
|
+
\html_math_output 0
|
61
|
+
\html_css_as_file 0
|
62
|
+
\html_be_strict false
|
63
|
+
\end_header
|
64
|
+
|
65
|
+
\begin_body
|
66
|
+
|
67
|
+
\begin_layout Title
|
68
|
+
Object model of YNelson and YPetri
|
69
|
+
\end_layout
|
70
|
+
|
71
|
+
\begin_layout Part*
|
72
|
+
|
73
|
+
\family typewriter
|
74
|
+
YNelson
|
75
|
+
\family default
|
76
|
+
and
|
77
|
+
\family typewriter
|
78
|
+
YPetri
|
79
|
+
\end_layout
|
80
|
+
|
81
|
+
\begin_layout Standard
|
82
|
+
|
83
|
+
\family typewriter
|
84
|
+
\color blue
|
85
|
+
YNelson
|
86
|
+
\family default
|
87
|
+
\color inherit
|
88
|
+
is a Ruby library (gem) providing a domain model and a simulator of
|
89
|
+
\emph on
|
90
|
+
\color green
|
91
|
+
Nelson nets
|
92
|
+
\emph default
|
93
|
+
\color inherit
|
94
|
+
.
|
95
|
+
A
|
96
|
+
\emph on
|
97
|
+
\color green
|
98
|
+
Nelson net
|
99
|
+
\emph default
|
100
|
+
\color inherit
|
101
|
+
is a cross between a
|
102
|
+
\emph on
|
103
|
+
\color green
|
104
|
+
Petri net
|
105
|
+
\emph default
|
106
|
+
\color inherit
|
107
|
+
, and a
|
108
|
+
\emph on
|
109
|
+
\color green
|
110
|
+
ZZ structure
|
111
|
+
\emph default
|
112
|
+
\color inherit
|
113
|
+
.
|
114
|
+
For formal definition of the ZZ structure, see
|
115
|
+
\begin_inset CommandInset citation
|
116
|
+
LatexCommand citet
|
117
|
+
key "Dattolo2009fdz"
|
118
|
+
|
119
|
+
\end_inset
|
120
|
+
|
121
|
+
.
|
122
|
+
In accordance with this,
|
123
|
+
\family typewriter
|
124
|
+
YNelson
|
125
|
+
\family default
|
126
|
+
has two major dependencies:
|
127
|
+
\family typewriter
|
128
|
+
\color blue
|
129
|
+
YPetri
|
130
|
+
\family default
|
131
|
+
\color inherit
|
132
|
+
gem, providing the the domain model of Petri nets, and
|
133
|
+
\family typewriter
|
134
|
+
\color blue
|
135
|
+
Yzz
|
136
|
+
\family default
|
137
|
+
\color inherit
|
138
|
+
gem, providing the domain model of ZZ structures.
|
139
|
+
At the moment, the focus is on the Petri net part.
|
140
|
+
Up to minor conveniences,
|
141
|
+
\family typewriter
|
142
|
+
YNelson
|
143
|
+
\family default
|
144
|
+
provides the same interface as
|
145
|
+
\family typewriter
|
146
|
+
YPetri
|
147
|
+
\family default
|
148
|
+
, so this document in fact describes mostly
|
149
|
+
\family typewriter
|
150
|
+
YPetri
|
151
|
+
\family default
|
152
|
+
objects.
|
153
|
+
\end_layout
|
154
|
+
|
155
|
+
\begin_layout Standard
|
156
|
+
Whereas for the beginners, there is tutorial available to YPetri / YNelson,
|
157
|
+
and the classes are more or less fully documented, the internal workings
|
158
|
+
and the design intent might not be immediately obvious.
|
159
|
+
The purpose of is document is to make the reader faster achieve their understan
|
160
|
+
ding.
|
161
|
+
\end_layout
|
162
|
+
|
163
|
+
\begin_layout Standard
|
164
|
+
|
165
|
+
\family typewriter
|
166
|
+
YNelson
|
167
|
+
\family default
|
168
|
+
requires Ruby 2.1, and can be installed from the command line by
|
169
|
+
\family typewriter
|
170
|
+
gem install y_nelson
|
171
|
+
\family default
|
172
|
+
.
|
173
|
+
The main dependencies,
|
174
|
+
\family typewriter
|
175
|
+
Yzz
|
176
|
+
\family default
|
177
|
+
and
|
178
|
+
\family typewriter
|
179
|
+
YPetri
|
180
|
+
\family default
|
181
|
+
, should install automatically, but can be installed manually by
|
182
|
+
\family typewriter
|
183
|
+
gem install y_petri
|
184
|
+
\family default
|
185
|
+
and
|
186
|
+
\family typewriter
|
187
|
+
gem install yzz
|
188
|
+
\family default
|
189
|
+
.
|
190
|
+
\end_layout
|
191
|
+
|
192
|
+
\begin_layout Part*
|
193
|
+
Functional Petri nets
|
194
|
+
\end_layout
|
195
|
+
|
196
|
+
\begin_layout Standard
|
197
|
+
Petri nets were described by C.
|
198
|
+
A.
|
199
|
+
Petri in the middle of 20th century.
|
200
|
+
A Petri net can be used to represent various
|
201
|
+
\begin_inset Quotes eld
|
202
|
+
\end_inset
|
203
|
+
|
204
|
+
wiring diagrams
|
205
|
+
\begin_inset Quotes erd
|
206
|
+
\end_inset
|
207
|
+
|
208
|
+
– production lines, railway networks, electronic circuits, computer architectur
|
209
|
+
es, parallel execution diagrams, or chemical systems.
|
210
|
+
In fact, appliction to chemical systems was among the first, as Petri designed
|
211
|
+
Petri nets already with the specific goal of modeling chemical reactions.
|
212
|
+
\end_layout
|
213
|
+
|
214
|
+
\begin_layout Standard
|
215
|
+
A Petri net consists of
|
216
|
+
\emph on
|
217
|
+
\color green
|
218
|
+
places
|
219
|
+
\emph default
|
220
|
+
\color inherit
|
221
|
+
,
|
222
|
+
\emph on
|
223
|
+
\color green
|
224
|
+
transitions
|
225
|
+
\emph default
|
226
|
+
\color inherit
|
227
|
+
, and
|
228
|
+
\emph on
|
229
|
+
\color green
|
230
|
+
arcs
|
231
|
+
\emph default
|
232
|
+
\color inherit
|
233
|
+
.
|
234
|
+
Places are typically drawn as circles, transitions as rectangles.
|
235
|
+
Places and transitions are connected by arcs, drawn as lines or arrows.
|
236
|
+
Places may contain
|
237
|
+
\emph on
|
238
|
+
\color green
|
239
|
+
tokens
|
240
|
+
\emph default
|
241
|
+
\color inherit
|
242
|
+
.
|
243
|
+
The amount of tokens in a place(s) is called
|
244
|
+
\emph on
|
245
|
+
\color green
|
246
|
+
marking
|
247
|
+
\emph default
|
248
|
+
\color inherit
|
249
|
+
.
|
250
|
+
When a transition operates (
|
251
|
+
\emph on
|
252
|
+
\color green
|
253
|
+
fires
|
254
|
+
\emph default
|
255
|
+
\color inherit
|
256
|
+
), tokens are added to or removed from its connected places.
|
257
|
+
|
258
|
+
\emph on
|
259
|
+
\color green
|
260
|
+
State
|
261
|
+
\emph default
|
262
|
+
\color inherit
|
263
|
+
of a Petri net is fully expressed by the places' marking.
|
264
|
+
\end_layout
|
265
|
+
|
266
|
+
\begin_layout Standard
|
267
|
+
Petri nets were originally designed as
|
268
|
+
\emph on
|
269
|
+
\color green
|
270
|
+
timeless
|
271
|
+
\emph default
|
272
|
+
\color inherit
|
273
|
+
.
|
274
|
+
In such Petri nets, firing of a transition is a discrete event, whose exact
|
275
|
+
timing is not specified.
|
276
|
+
Instead, conditions are specified, under which the transition is allowed
|
277
|
+
or prohibited to fire (
|
278
|
+
\emph on
|
279
|
+
\color green
|
280
|
+
enabled
|
281
|
+
\emph default
|
282
|
+
\color inherit
|
283
|
+
or
|
284
|
+
\emph on
|
285
|
+
\color green
|
286
|
+
disabled
|
287
|
+
\emph default
|
288
|
+
\color inherit
|
289
|
+
).
|
290
|
+
Typically, transitions are enabled when their input arcs have sufficient
|
291
|
+
amount of tokens left.
|
292
|
+
However, different firing conditions may be specified.
|
293
|
+
Timeless Petri nets are used to study concurrency – race conditions, network
|
294
|
+
congestions, state reachability etc.
|
295
|
+
Interaction with timeless Petri nets is called
|
296
|
+
\emph on
|
297
|
+
\color green
|
298
|
+
token game
|
299
|
+
\emph default
|
300
|
+
\color inherit
|
301
|
+
.
|
302
|
+
\end_layout
|
303
|
+
|
304
|
+
\begin_layout Standard
|
305
|
+
In
|
306
|
+
\emph on
|
307
|
+
\color green
|
308
|
+
timed Petri nets
|
309
|
+
\emph default
|
310
|
+
\color inherit
|
311
|
+
, it is specified when (or how rapidly) firing of the transitions occurs.
|
312
|
+
Timed nets are thus not interactive and can be autonomously
|
313
|
+
\emph on
|
314
|
+
\color green
|
315
|
+
executed
|
316
|
+
\emph default
|
317
|
+
\color inherit
|
318
|
+
in time.
|
319
|
+
Timed Petri nets actually represent a wiring diagram of a dynamic system.
|
320
|
+
Under certain conditions, a set of differential equations (DE) describing
|
321
|
+
the system can be extracted from this wiring diagram.
|
322
|
+
Execution of a such Petri net is equivalent to numeric integration of its
|
323
|
+
DE system.
|
324
|
+
\family typewriter
|
325
|
+
YPetri
|
326
|
+
\family default
|
327
|
+
object model
|
328
|
+
\end_layout
|
329
|
+
|
330
|
+
\begin_layout Standard
|
331
|
+
Brief hands-on demonstration of the interface can be found in the document
|
332
|
+
|
333
|
+
\emph on
|
334
|
+
Introduction to YNelson
|
335
|
+
\emph default
|
336
|
+
.
|
337
|
+
The purpose of this chapter is to describe the Petri net object model of
|
338
|
+
|
339
|
+
\family typewriter
|
340
|
+
YPetri
|
341
|
+
\family default
|
342
|
+
gem in more detail.
|
343
|
+
\end_layout
|
344
|
+
|
345
|
+
\begin_layout Part*
|
346
|
+
Aspects of
|
347
|
+
\family typewriter
|
348
|
+
YPetri
|
349
|
+
\end_layout
|
350
|
+
|
351
|
+
\begin_layout Standard
|
352
|
+
|
353
|
+
\family typewriter
|
354
|
+
YPetri
|
355
|
+
\family default
|
356
|
+
has two main mutually intertwined concerns:
|
357
|
+
\end_layout
|
358
|
+
|
359
|
+
\begin_layout Enumerate
|
360
|
+
To provide active object model of Petri nets.
|
361
|
+
\end_layout
|
362
|
+
|
363
|
+
\begin_layout Enumerate
|
364
|
+
To provide simulation for the dynamic systems expressed as Petri nets.
|
365
|
+
\end_layout
|
366
|
+
|
367
|
+
\begin_layout Standard
|
368
|
+
Correspondingly,
|
369
|
+
\family typewriter
|
370
|
+
YPetri
|
371
|
+
\family default
|
372
|
+
has 2 aspects catering to its 2 concerns:
|
373
|
+
\end_layout
|
374
|
+
|
375
|
+
\begin_layout Enumerate
|
376
|
+
Petri net aspect.
|
377
|
+
\end_layout
|
378
|
+
|
379
|
+
\begin_layout Enumerate
|
380
|
+
Simulation aspect.
|
381
|
+
\end_layout
|
382
|
+
|
383
|
+
\begin_layout Standard
|
384
|
+
Major classes of the Petri net aspect are
|
385
|
+
\family typewriter
|
386
|
+
Place
|
387
|
+
\family default
|
388
|
+
,
|
389
|
+
\family typewriter
|
390
|
+
Transition
|
391
|
+
\family default
|
392
|
+
and
|
393
|
+
\family typewriter
|
394
|
+
Net
|
395
|
+
\family default
|
396
|
+
.
|
397
|
+
Places have their own marking attribute, transitions know their connectivity,
|
398
|
+
their functions, and they can be triggered to fire and modify marking of
|
399
|
+
their connected places.
|
400
|
+
|
401
|
+
\family typewriter
|
402
|
+
Net
|
403
|
+
\family default
|
404
|
+
is basically a specialized collection of places and transitions.
|
405
|
+
\end_layout
|
406
|
+
|
407
|
+
\begin_layout Standard
|
408
|
+
Simulation aspect is catered for by
|
409
|
+
\family typewriter
|
410
|
+
Simulation
|
411
|
+
\family default
|
412
|
+
class, representing a simulation run, and
|
413
|
+
\family typewriter
|
414
|
+
Core
|
415
|
+
\family default
|
416
|
+
class representing a simulator – a machine that runs the calculations needed
|
417
|
+
to perform the simulation steps.
|
418
|
+
\end_layout
|
419
|
+
|
420
|
+
\begin_layout Standard
|
421
|
+
Workspace (
|
422
|
+
\family typewriter
|
423
|
+
World
|
424
|
+
\family default
|
425
|
+
class, where places, transitions and nets live), and manipulator (
|
426
|
+
\family typewriter
|
427
|
+
Agent
|
428
|
+
\family default
|
429
|
+
class that represents and assists the user) are straddled across both aspects
|
430
|
+
of
|
431
|
+
\family typewriter
|
432
|
+
YPetri
|
433
|
+
\family default
|
434
|
+
.
|
435
|
+
\end_layout
|
436
|
+
|
437
|
+
\begin_layout Part*
|
438
|
+
|
439
|
+
\family typewriter
|
440
|
+
Place
|
441
|
+
\family default
|
442
|
+
class
|
443
|
+
\end_layout
|
444
|
+
|
445
|
+
\begin_layout Standard
|
446
|
+
|
447
|
+
\family typewriter
|
448
|
+
YPetri::Place
|
449
|
+
\family default
|
450
|
+
class represents Petri net places.
|
451
|
+
It includes
|
452
|
+
\family typewriter
|
453
|
+
NameMagic
|
454
|
+
\family default
|
455
|
+
and is normally used as a parametrized subclass (PS) depending on
|
456
|
+
\family typewriter
|
457
|
+
YPetri::World
|
458
|
+
\family default
|
459
|
+
.
|
460
|
+
The key attribute of a place is its marking (variable
|
461
|
+
\family typewriter
|
462
|
+
@marking
|
463
|
+
\family default
|
464
|
+
).
|
465
|
+
Interface related to marking is:
|
466
|
+
\end_layout
|
467
|
+
|
468
|
+
\begin_layout Itemize
|
469
|
+
|
470
|
+
\family typewriter
|
471
|
+
#m
|
472
|
+
\family default
|
473
|
+
, alias
|
474
|
+
\family typewriter
|
475
|
+
#value
|
476
|
+
\family default
|
477
|
+
– getter of
|
478
|
+
\family typewriter
|
479
|
+
@marking
|
480
|
+
\family default
|
481
|
+
instance variable.
|
482
|
+
\end_layout
|
483
|
+
|
484
|
+
\begin_layout Itemize
|
485
|
+
|
486
|
+
\family typewriter
|
487
|
+
#marking
|
488
|
+
\family default
|
489
|
+
– convenience method that acts as
|
490
|
+
\family typewriter
|
491
|
+
@marking
|
492
|
+
\family default
|
493
|
+
getter without arguments, but can be used to define guards if block is
|
494
|
+
supplied to it.
|
495
|
+
\end_layout
|
496
|
+
|
497
|
+
\begin_layout Itemize
|
498
|
+
|
499
|
+
\family typewriter
|
500
|
+
#marking=
|
501
|
+
\family default
|
502
|
+
, alias
|
503
|
+
\family typewriter
|
504
|
+
#value=
|
505
|
+
\family default
|
506
|
+
, alias
|
507
|
+
\family typewriter
|
508
|
+
#m=
|
509
|
+
\family default
|
510
|
+
– setter of
|
511
|
+
\family typewriter
|
512
|
+
@marking
|
513
|
+
\family default
|
514
|
+
.
|
515
|
+
\end_layout
|
516
|
+
|
517
|
+
\begin_layout Itemize
|
518
|
+
|
519
|
+
\family typewriter
|
520
|
+
#add
|
521
|
+
\family default
|
522
|
+
and
|
523
|
+
\family typewriter
|
524
|
+
#subtract
|
525
|
+
\family default
|
526
|
+
that change the value of
|
527
|
+
\family typewriter
|
528
|
+
@marking
|
529
|
+
\family default
|
530
|
+
.
|
531
|
+
\end_layout
|
532
|
+
|
533
|
+
\begin_layout Itemize
|
534
|
+
|
535
|
+
\family typewriter
|
536
|
+
#default_marking
|
537
|
+
\family default
|
538
|
+
,
|
539
|
+
\family typewriter
|
540
|
+
#default_marking=
|
541
|
+
\family default
|
542
|
+
– getter and setter of place's default marking (
|
543
|
+
\family typewriter
|
544
|
+
@default_marking
|
545
|
+
\family default
|
546
|
+
variable).
|
547
|
+
\end_layout
|
548
|
+
|
549
|
+
\begin_layout Itemize
|
550
|
+
|
551
|
+
\family typewriter
|
552
|
+
#has_default_marking?
|
553
|
+
\family default
|
554
|
+
– informs whether the place has default marking defined (
|
555
|
+
\family typewriter
|
556
|
+
@has_default_marking
|
557
|
+
\family default
|
558
|
+
variable).
|
559
|
+
\end_layout
|
560
|
+
|
561
|
+
\begin_layout Itemize
|
562
|
+
|
563
|
+
\family typewriter
|
564
|
+
#reset_marking
|
565
|
+
\family default
|
566
|
+
– sets
|
567
|
+
\family typewriter
|
568
|
+
@marking
|
569
|
+
\family default
|
570
|
+
to the default value.
|
571
|
+
\end_layout
|
572
|
+
|
573
|
+
\begin_layout Standard
|
574
|
+
Another important group of methods are those related to the place's connectivity
|
575
|
+
– arcs.
|
576
|
+
They are defined in the
|
577
|
+
\family typewriter
|
578
|
+
YPetri::Place::Arcs
|
579
|
+
\family default
|
580
|
+
mixin included by
|
581
|
+
\family typewriter
|
582
|
+
YPetri::Place
|
583
|
+
\family default
|
584
|
+
.
|
585
|
+
In Petri net diagrams, arcs are the lines that connect places and transitions.
|
586
|
+
In YPetri, there is no real
|
587
|
+
\begin_inset Quotes eld
|
588
|
+
\end_inset
|
589
|
+
|
590
|
+
arc
|
591
|
+
\begin_inset Quotes erd
|
592
|
+
\end_inset
|
593
|
+
|
594
|
+
object.
|
595
|
+
For places,
|
596
|
+
\family typewriter
|
597
|
+
#arcs
|
598
|
+
\family default
|
599
|
+
method simply returns the connected transitions, and vice versa, for transition
|
600
|
+
s,
|
601
|
+
\family typewriter
|
602
|
+
#arcs
|
603
|
+
\family default
|
604
|
+
method returns connected places.
|
605
|
+
Overview of the most important
|
606
|
+
\family typewriter
|
607
|
+
Place
|
608
|
+
\family default
|
609
|
+
instance methods inherited from the
|
610
|
+
\family typewriter
|
611
|
+
Arcs
|
612
|
+
\family default
|
613
|
+
mixin is here:
|
614
|
+
\end_layout
|
615
|
+
|
616
|
+
\begin_layout Itemize
|
617
|
+
|
618
|
+
\family typewriter
|
619
|
+
#upstream_arcs
|
620
|
+
\family default
|
621
|
+
, alias
|
622
|
+
\family typewriter
|
623
|
+
#upstream_transitions
|
624
|
+
\family default
|
625
|
+
– getter of
|
626
|
+
\family typewriter
|
627
|
+
@upstream_arcs
|
628
|
+
\family default
|
629
|
+
.
|
630
|
+
\end_layout
|
631
|
+
|
632
|
+
\begin_layout Itemize
|
633
|
+
|
634
|
+
\family typewriter
|
635
|
+
#downstream_arcs
|
636
|
+
\family default
|
637
|
+
, alias
|
638
|
+
\family typewriter
|
639
|
+
#downstream_transitions
|
640
|
+
\family default
|
641
|
+
– getter of
|
642
|
+
\family typewriter
|
643
|
+
@downstream_arcs
|
644
|
+
\family default
|
645
|
+
.
|
646
|
+
\end_layout
|
647
|
+
|
648
|
+
\begin_layout Itemize
|
649
|
+
|
650
|
+
\family typewriter
|
651
|
+
#arcs
|
652
|
+
\family default
|
653
|
+
– a union of upstream transitions and downstream transitions.
|
654
|
+
\end_layout
|
655
|
+
|
656
|
+
\begin_layout Itemize
|
657
|
+
|
658
|
+
\family typewriter
|
659
|
+
#aa
|
660
|
+
\family default
|
661
|
+
– names of the connected transitions.
|
662
|
+
\end_layout
|
663
|
+
|
664
|
+
\begin_layout Itemize
|
665
|
+
|
666
|
+
\family typewriter
|
667
|
+
#precedents
|
668
|
+
\family default
|
669
|
+
– precedents in the spreadsheet sense.
|
670
|
+
Places whose marking directly influences firing of the upstream transitions
|
671
|
+
of this place.
|
672
|
+
\end_layout
|
673
|
+
|
674
|
+
\begin_layout Itemize
|
675
|
+
|
676
|
+
\family typewriter
|
677
|
+
#dependents
|
678
|
+
\family default
|
679
|
+
– dependents in the spreadsheet sense.
|
680
|
+
Places whose marking is changed by firing of the downstream transitions
|
681
|
+
of this place.
|
682
|
+
\end_layout
|
683
|
+
|
684
|
+
\begin_layout Standard
|
685
|
+
For the remaining methods, see the class documentation.
|
686
|
+
Place can also have guards, statements that validate the marking and limit
|
687
|
+
it to only certain values.
|
688
|
+
At the moment, guards are not fully handled by the
|
689
|
+
\family typewriter
|
690
|
+
Simulation
|
691
|
+
\family default
|
692
|
+
class.
|
693
|
+
\end_layout
|
694
|
+
|
695
|
+
\begin_layout Part*
|
696
|
+
|
697
|
+
\family typewriter
|
698
|
+
Transition
|
699
|
+
\family default
|
700
|
+
class
|
701
|
+
\end_layout
|
702
|
+
|
703
|
+
\begin_layout Standard
|
704
|
+
|
705
|
+
\family typewriter
|
706
|
+
YPetri::Transition
|
707
|
+
\family default
|
708
|
+
class represents functional transitions of a (functinal) Petri net.
|
709
|
+
It includes
|
710
|
+
\family typewriter
|
711
|
+
NameMagic
|
712
|
+
\family default
|
713
|
+
and is normally used as a parametrized subclass (PS) depending on
|
714
|
+
\family typewriter
|
715
|
+
YPetri::World
|
716
|
+
\family default
|
717
|
+
.
|
718
|
+
The main attribute of a
|
719
|
+
\family typewriter
|
720
|
+
Transition
|
721
|
+
\family default
|
722
|
+
instance is its function.
|
723
|
+
There are 4 basic types of transitions in
|
724
|
+
\family typewriter
|
725
|
+
YPetri
|
726
|
+
\family default
|
727
|
+
:
|
728
|
+
\end_layout
|
729
|
+
|
730
|
+
\begin_layout Itemize
|
731
|
+
|
732
|
+
\family typewriter
|
733
|
+
ts
|
734
|
+
\family default
|
735
|
+
– timeless nonstoichiometric
|
736
|
+
\end_layout
|
737
|
+
|
738
|
+
\begin_layout Itemize
|
739
|
+
|
740
|
+
\family typewriter
|
741
|
+
tS
|
742
|
+
\family default
|
743
|
+
– timeless stoichiometric
|
744
|
+
\end_layout
|
745
|
+
|
746
|
+
\begin_layout Itemize
|
747
|
+
|
748
|
+
\family typewriter
|
749
|
+
Ts
|
750
|
+
\family default
|
751
|
+
– timed nonstoichiometric
|
752
|
+
\end_layout
|
753
|
+
|
754
|
+
\begin_layout Itemize
|
755
|
+
|
756
|
+
\family typewriter
|
757
|
+
TS
|
758
|
+
\family default
|
759
|
+
– timed stoichiometric
|
760
|
+
\end_layout
|
761
|
+
|
762
|
+
\begin_layout Standard
|
763
|
+
They arise by combining 2 basic qualities:
|
764
|
+
\end_layout
|
765
|
+
|
766
|
+
\begin_layout Itemize
|
767
|
+
|
768
|
+
\emph on
|
769
|
+
timedness
|
770
|
+
\end_layout
|
771
|
+
|
772
|
+
\begin_layout Itemize
|
773
|
+
|
774
|
+
\emph on
|
775
|
+
stoichiometricity
|
776
|
+
\end_layout
|
777
|
+
|
778
|
+
\begin_layout Standard
|
779
|
+
You can find more information in the documentation of
|
780
|
+
\family typewriter
|
781
|
+
YPetri::Transition
|
782
|
+
\family default
|
783
|
+
class.
|
784
|
+
\end_layout
|
785
|
+
|
786
|
+
\begin_layout Part*
|
787
|
+
|
788
|
+
\family typewriter
|
789
|
+
Net
|
790
|
+
\family default
|
791
|
+
class
|
792
|
+
\end_layout
|
793
|
+
|
794
|
+
\begin_layout Standard
|
795
|
+
|
796
|
+
\family typewriter
|
797
|
+
YPetri::Net
|
798
|
+
\family default
|
799
|
+
class represents functional Petri nets.
|
800
|
+
It includes
|
801
|
+
\family typewriter
|
802
|
+
NameMagic
|
803
|
+
\family default
|
804
|
+
and is normally used as a PS depending on
|
805
|
+
\family typewriter
|
806
|
+
YPetri::World
|
807
|
+
\family default
|
808
|
+
.
|
809
|
+
It is basically a specialized collection of of
|
810
|
+
\family typewriter
|
811
|
+
Place
|
812
|
+
\family default
|
813
|
+
instances and
|
814
|
+
\family typewriter
|
815
|
+
Transition
|
816
|
+
\family default
|
817
|
+
instances.
|
818
|
+
A transition may only be included in a net if all the places connected
|
819
|
+
to it belong to the same net.
|
820
|
+
|
821
|
+
\family typewriter
|
822
|
+
Net
|
823
|
+
\family default
|
824
|
+
instances own 2 parametrized subclasses:
|
825
|
+
\end_layout
|
826
|
+
|
827
|
+
\begin_layout Itemize
|
828
|
+
|
829
|
+
\family typewriter
|
830
|
+
#State
|
831
|
+
\family default
|
832
|
+
– getter of
|
833
|
+
\family typewriter
|
834
|
+
@State
|
835
|
+
\family default
|
836
|
+
, a PS of
|
837
|
+
\family typewriter
|
838
|
+
YPetri::Net::State
|
839
|
+
\end_layout
|
840
|
+
|
841
|
+
\begin_layout Itemize
|
842
|
+
|
843
|
+
\family typewriter
|
844
|
+
#Simulation
|
845
|
+
\family default
|
846
|
+
– getter of
|
847
|
+
\family typewriter
|
848
|
+
@Simulation
|
849
|
+
\family default
|
850
|
+
, a PS of
|
851
|
+
\family typewriter
|
852
|
+
YPetri::Simulation
|
853
|
+
\family default
|
854
|
+
.
|
855
|
+
\end_layout
|
856
|
+
|
857
|
+
\begin_layout Standard
|
858
|
+
Important instance methods include:
|
859
|
+
\end_layout
|
860
|
+
|
861
|
+
\begin_layout Itemize
|
862
|
+
|
863
|
+
\family typewriter
|
864
|
+
#include_place
|
865
|
+
\family default
|
866
|
+
– adds a place to the net
|
867
|
+
\end_layout
|
868
|
+
|
869
|
+
\begin_layout Itemize
|
870
|
+
|
871
|
+
\family typewriter
|
872
|
+
#include_transition
|
873
|
+
\family default
|
874
|
+
– adds a transition to the net
|
875
|
+
\end_layout
|
876
|
+
|
877
|
+
\begin_layout Itemize
|
878
|
+
|
879
|
+
\family typewriter
|
880
|
+
#exclude_place
|
881
|
+
\family default
|
882
|
+
– removes a place from the net
|
883
|
+
\end_layout
|
884
|
+
|
885
|
+
\begin_layout Itemize
|
886
|
+
|
887
|
+
\family typewriter
|
888
|
+
#exclude_transition
|
889
|
+
\family default
|
890
|
+
– removes a transition from the net
|
891
|
+
\end_layout
|
892
|
+
|
893
|
+
\begin_layout Itemize
|
894
|
+
|
895
|
+
\family typewriter
|
896
|
+
#include_net
|
897
|
+
\family default
|
898
|
+
alias
|
899
|
+
\family typewriter
|
900
|
+
#merge!
|
901
|
+
\family default
|
902
|
+
– includes another net in this net
|
903
|
+
\end_layout
|
904
|
+
|
905
|
+
\begin_layout Itemize
|
906
|
+
|
907
|
+
\family typewriter
|
908
|
+
#exclude_net
|
909
|
+
\family default
|
910
|
+
– removes the elements of another net from this net
|
911
|
+
\end_layout
|
912
|
+
|
913
|
+
\begin_layout Itemize
|
914
|
+
|
915
|
+
\family typewriter
|
916
|
+
#<<
|
917
|
+
\family default
|
918
|
+
– includes an element in the net
|
919
|
+
\end_layout
|
920
|
+
|
921
|
+
\begin_layout Itemize
|
922
|
+
|
923
|
+
\family typewriter
|
924
|
+
#+
|
925
|
+
\family default
|
926
|
+
– returns a new net containing the union of the operands' elements
|
927
|
+
\end_layout
|
928
|
+
|
929
|
+
\begin_layout Itemize
|
930
|
+
|
931
|
+
\family typewriter
|
932
|
+
#-
|
933
|
+
\family default
|
934
|
+
– returns a new net containing the elements of the receiver minus the operand
|
935
|
+
\end_layout
|
936
|
+
|
937
|
+
\begin_layout Itemize
|
938
|
+
|
939
|
+
\family typewriter
|
940
|
+
#functional?
|
941
|
+
\family default
|
942
|
+
– inquirer whether the net is functional
|
943
|
+
\end_layout
|
944
|
+
|
945
|
+
\begin_layout Itemize
|
946
|
+
|
947
|
+
\family typewriter
|
948
|
+
#timed?
|
949
|
+
\family default
|
950
|
+
– inquirer whether the net is timed
|
951
|
+
\end_layout
|
952
|
+
|
953
|
+
\begin_layout Itemize
|
954
|
+
|
955
|
+
\family typewriter
|
956
|
+
#simulation
|
957
|
+
\family default
|
958
|
+
– constructor of a new simulation of this net
|
959
|
+
\end_layout
|
960
|
+
|
961
|
+
\begin_layout Standard
|
962
|
+
A
|
963
|
+
\family typewriter
|
964
|
+
Net
|
965
|
+
\family default
|
966
|
+
instance has its own state, and can be asked about place marking, transiton
|
967
|
+
flux etc.
|
968
|
+
It is also capable of drawing a diagram with Graphviz, using
|
969
|
+
\family typewriter
|
970
|
+
#visualize
|
971
|
+
\family default
|
972
|
+
method.
|
973
|
+
For full listing of methods, see the class documentation.
|
974
|
+
\end_layout
|
975
|
+
|
976
|
+
\begin_layout Part*
|
977
|
+
|
978
|
+
\family typewriter
|
979
|
+
World
|
980
|
+
\family default
|
981
|
+
class
|
982
|
+
\end_layout
|
983
|
+
|
984
|
+
\begin_layout Standard
|
985
|
+
|
986
|
+
\family typewriter
|
987
|
+
YPetri::World
|
988
|
+
\family default
|
989
|
+
is the space where places, transitions and nets live.
|
990
|
+
Originally, this class was named
|
991
|
+
\family typewriter
|
992
|
+
Workspace
|
993
|
+
\family default
|
994
|
+
, but
|
995
|
+
\family typewriter
|
996
|
+
World
|
997
|
+
\family default
|
998
|
+
is shorter.
|
999
|
+
Owns PS of
|
1000
|
+
\family typewriter
|
1001
|
+
Place
|
1002
|
+
\family default
|
1003
|
+
,
|
1004
|
+
\family typewriter
|
1005
|
+
Transition
|
1006
|
+
\family default
|
1007
|
+
and
|
1008
|
+
\family typewriter
|
1009
|
+
Net
|
1010
|
+
\family default
|
1011
|
+
, stored respectively in
|
1012
|
+
\family typewriter
|
1013
|
+
@Place
|
1014
|
+
\family default
|
1015
|
+
,
|
1016
|
+
\family typewriter
|
1017
|
+
@Transition
|
1018
|
+
\family default
|
1019
|
+
and
|
1020
|
+
\family typewriter
|
1021
|
+
@Net
|
1022
|
+
\family default
|
1023
|
+
instance variables.
|
1024
|
+
Their instances can be constructed with:
|
1025
|
+
\end_layout
|
1026
|
+
|
1027
|
+
\begin_layout Itemize
|
1028
|
+
|
1029
|
+
\family typewriter
|
1030
|
+
#Place
|
1031
|
+
\family default
|
1032
|
+
– constructor of instances of
|
1033
|
+
\family typewriter
|
1034
|
+
Place
|
1035
|
+
\family default
|
1036
|
+
PS.
|
1037
|
+
\end_layout
|
1038
|
+
|
1039
|
+
\begin_layout Itemize
|
1040
|
+
|
1041
|
+
\family typewriter
|
1042
|
+
#Transition
|
1043
|
+
\family default
|
1044
|
+
– constructor of instances of
|
1045
|
+
\family typewriter
|
1046
|
+
Transition
|
1047
|
+
\family default
|
1048
|
+
PS.
|
1049
|
+
\end_layout
|
1050
|
+
|
1051
|
+
\begin_layout Itemize
|
1052
|
+
|
1053
|
+
\family typewriter
|
1054
|
+
#Net
|
1055
|
+
\family default
|
1056
|
+
constructor – constructor of instances of
|
1057
|
+
\family typewriter
|
1058
|
+
Net
|
1059
|
+
\family default
|
1060
|
+
PS.
|
1061
|
+
\end_layout
|
1062
|
+
|
1063
|
+
\begin_layout Standard
|
1064
|
+
World assets are divided into two mixins:
|
1065
|
+
\family typewriter
|
1066
|
+
YPetri::World::PetriNetAspect
|
1067
|
+
\family default
|
1068
|
+
and
|
1069
|
+
\family typewriter
|
1070
|
+
YPetri::World::SimulationAspect
|
1071
|
+
\family default
|
1072
|
+
.
|
1073
|
+
Important instance methods of PetriNetAspect are:
|
1074
|
+
\end_layout
|
1075
|
+
|
1076
|
+
\begin_layout Itemize
|
1077
|
+
|
1078
|
+
\family typewriter
|
1079
|
+
#place
|
1080
|
+
\family default
|
1081
|
+
–
|
1082
|
+
\family typewriter
|
1083
|
+
Place
|
1084
|
+
\family default
|
1085
|
+
PS instance finder.
|
1086
|
+
\end_layout
|
1087
|
+
|
1088
|
+
\begin_layout Itemize
|
1089
|
+
|
1090
|
+
\family typewriter
|
1091
|
+
#transition
|
1092
|
+
\family default
|
1093
|
+
–
|
1094
|
+
\family typewriter
|
1095
|
+
Transition
|
1096
|
+
\family default
|
1097
|
+
PS instance finder.
|
1098
|
+
\end_layout
|
1099
|
+
|
1100
|
+
\begin_layout Itemize
|
1101
|
+
|
1102
|
+
\family typewriter
|
1103
|
+
#net
|
1104
|
+
\family default
|
1105
|
+
–
|
1106
|
+
\family typewriter
|
1107
|
+
Net
|
1108
|
+
\family default
|
1109
|
+
PS instance finder.
|
1110
|
+
\end_layout
|
1111
|
+
|
1112
|
+
\begin_layout Itemize
|
1113
|
+
|
1114
|
+
\family typewriter
|
1115
|
+
#places
|
1116
|
+
\family default
|
1117
|
+
– returns all
|
1118
|
+
\family typewriter
|
1119
|
+
Place
|
1120
|
+
\family default
|
1121
|
+
PS instances.
|
1122
|
+
\end_layout
|
1123
|
+
|
1124
|
+
\begin_layout Itemize
|
1125
|
+
|
1126
|
+
\family typewriter
|
1127
|
+
#transitions
|
1128
|
+
\family default
|
1129
|
+
– returns all
|
1130
|
+
\family typewriter
|
1131
|
+
Transition
|
1132
|
+
\family default
|
1133
|
+
PS instances.
|
1134
|
+
\end_layout
|
1135
|
+
|
1136
|
+
\begin_layout Itemize
|
1137
|
+
|
1138
|
+
\family typewriter
|
1139
|
+
#nets
|
1140
|
+
\family default
|
1141
|
+
– returns all
|
1142
|
+
\family typewriter
|
1143
|
+
Net
|
1144
|
+
\family default
|
1145
|
+
PS instances.
|
1146
|
+
\end_layout
|
1147
|
+
|
1148
|
+
\begin_layout Standard
|
1149
|
+
Important instance methods of SimulationAspect are:
|
1150
|
+
\end_layout
|
1151
|
+
|
1152
|
+
\begin_layout Itemize
|
1153
|
+
|
1154
|
+
\family typewriter
|
1155
|
+
#new_simulation
|
1156
|
+
\family default
|
1157
|
+
– constructor of simulations.
|
1158
|
+
\end_layout
|
1159
|
+
|
1160
|
+
\begin_layout Itemize
|
1161
|
+
|
1162
|
+
\family typewriter
|
1163
|
+
#simulation
|
1164
|
+
\family default
|
1165
|
+
–
|
1166
|
+
\family typewriter
|
1167
|
+
Simulation
|
1168
|
+
\family default
|
1169
|
+
instance finder.
|
1170
|
+
\end_layout
|
1171
|
+
|
1172
|
+
\begin_layout Itemize
|
1173
|
+
|
1174
|
+
\family typewriter
|
1175
|
+
#simulations
|
1176
|
+
\family default
|
1177
|
+
– getter of
|
1178
|
+
\family typewriter
|
1179
|
+
@simulations
|
1180
|
+
\family default
|
1181
|
+
, a hash of simulation instances and their settings.
|
1182
|
+
\end_layout
|
1183
|
+
|
1184
|
+
\begin_layout Standard
|
1185
|
+
|
1186
|
+
\family typewriter
|
1187
|
+
World
|
1188
|
+
\family default
|
1189
|
+
instance has also 3 instance variables useful for simulations,
|
1190
|
+
\family typewriter
|
1191
|
+
@clamp_collections
|
1192
|
+
\family default
|
1193
|
+
,
|
1194
|
+
\family typewriter
|
1195
|
+
@initial_marking_collections
|
1196
|
+
\family default
|
1197
|
+
and
|
1198
|
+
\family typewriter
|
1199
|
+
@simulation_settings_collections
|
1200
|
+
\family default
|
1201
|
+
.
|
1202
|
+
Each simulation requires an initial marking collection, a clamp collection,
|
1203
|
+
and a hash of simulation settings.
|
1204
|
+
In a world, these collections / settings can be named and stored in the
|
1205
|
+
above mentioned instance variables for later use in simulations.
|
1206
|
+
See the class documentation for more details and the accessor methods of
|
1207
|
+
these instance variables.
|
1208
|
+
\end_layout
|
1209
|
+
|
1210
|
+
\begin_layout Part*
|
1211
|
+
|
1212
|
+
\family typewriter
|
1213
|
+
Simulation
|
1214
|
+
\family default
|
1215
|
+
class
|
1216
|
+
\end_layout
|
1217
|
+
|
1218
|
+
\begin_layout Standard
|
1219
|
+
While
|
1220
|
+
\family typewriter
|
1221
|
+
YPetri
|
1222
|
+
\family default
|
1223
|
+
places have their own marking and the transitions make it possible to play
|
1224
|
+
the token game interactively, for many reasons, it is desirable to be able
|
1225
|
+
to execute Petri nets automatically.
|
1226
|
+
|
1227
|
+
\family typewriter
|
1228
|
+
YPetri::Simulation
|
1229
|
+
\family default
|
1230
|
+
class represents such simulations.
|
1231
|
+
|
1232
|
+
\family typewriter
|
1233
|
+
Simulation
|
1234
|
+
\family default
|
1235
|
+
instances do not operate directly on the Petri nets from which they were
|
1236
|
+
constructed.
|
1237
|
+
Instead, they form a representation (
|
1238
|
+
\begin_inset Quotes eld
|
1239
|
+
\end_inset
|
1240
|
+
|
1241
|
+
mental image
|
1242
|
+
\begin_inset Quotes erd
|
1243
|
+
\end_inset
|
1244
|
+
|
1245
|
+
) of the places and transitions of the underlying net.
|
1246
|
+
|
1247
|
+
\family typewriter
|
1248
|
+
Simulation
|
1249
|
+
\family default
|
1250
|
+
instances do not change the state owned by the underlying net.
|
1251
|
+
Instead, they have their own marking vector, which they modify using a
|
1252
|
+
chosen simulation method in the way that simulates firing of the transitions.
|
1253
|
+
A simulation owns multiple parametrized subclasses:
|
1254
|
+
\end_layout
|
1255
|
+
|
1256
|
+
\begin_layout Itemize
|
1257
|
+
|
1258
|
+
\family typewriter
|
1259
|
+
#Place
|
1260
|
+
\family default
|
1261
|
+
– getter of
|
1262
|
+
\family typewriter
|
1263
|
+
@Place
|
1264
|
+
\family default
|
1265
|
+
, a PS of
|
1266
|
+
\family typewriter
|
1267
|
+
Simulation::PlaceRepresentation
|
1268
|
+
\end_layout
|
1269
|
+
|
1270
|
+
\begin_layout Itemize
|
1271
|
+
|
1272
|
+
\family typewriter
|
1273
|
+
#Transition
|
1274
|
+
\family default
|
1275
|
+
– getter of
|
1276
|
+
\family typewriter
|
1277
|
+
@Transition, a
|
1278
|
+
\family default
|
1279
|
+
PS of
|
1280
|
+
\family typewriter
|
1281
|
+
Simulation::TransitionRepresentation
|
1282
|
+
\end_layout
|
1283
|
+
|
1284
|
+
\begin_layout Itemize
|
1285
|
+
|
1286
|
+
\family typewriter
|
1287
|
+
#Places
|
1288
|
+
\family default
|
1289
|
+
– getter of
|
1290
|
+
\family typewriter
|
1291
|
+
@Places
|
1292
|
+
\family default
|
1293
|
+
, a PS of
|
1294
|
+
\family typewriter
|
1295
|
+
Simulation::Places
|
1296
|
+
\family default
|
1297
|
+
, representing a collection of place representations.
|
1298
|
+
\end_layout
|
1299
|
+
|
1300
|
+
\begin_layout Itemize
|
1301
|
+
|
1302
|
+
\family typewriter
|
1303
|
+
#Transitions
|
1304
|
+
\family default
|
1305
|
+
– getter of
|
1306
|
+
\family typewriter
|
1307
|
+
@Transitions
|
1308
|
+
\family default
|
1309
|
+
, a PS of
|
1310
|
+
\family typewriter
|
1311
|
+
Simulation::Transitions
|
1312
|
+
\family default
|
1313
|
+
, representing a collection of place representations.
|
1314
|
+
\end_layout
|
1315
|
+
|
1316
|
+
\begin_layout Itemize
|
1317
|
+
|
1318
|
+
\family typewriter
|
1319
|
+
#Elements
|
1320
|
+
\family default
|
1321
|
+
– getter of
|
1322
|
+
\family typewriter
|
1323
|
+
@Places
|
1324
|
+
\family default
|
1325
|
+
, a PS of
|
1326
|
+
\family typewriter
|
1327
|
+
Simulation::Elements
|
1328
|
+
\family default
|
1329
|
+
, representing a collection of element (either place or transition) representati
|
1330
|
+
ons.
|
1331
|
+
\end_layout
|
1332
|
+
|
1333
|
+
\begin_layout Itemize
|
1334
|
+
|
1335
|
+
\family typewriter
|
1336
|
+
#PlaceMapping
|
1337
|
+
\family default
|
1338
|
+
– getter of
|
1339
|
+
\family typewriter
|
1340
|
+
@PlaceMapping
|
1341
|
+
\family default
|
1342
|
+
, a PS of
|
1343
|
+
\family typewriter
|
1344
|
+
Simulation::PlaceMapping
|
1345
|
+
\family default
|
1346
|
+
, a specialized
|
1347
|
+
\family typewriter
|
1348
|
+
Hash
|
1349
|
+
\family default
|
1350
|
+
that maps the simulation's places to a set of some values.
|
1351
|
+
\end_layout
|
1352
|
+
|
1353
|
+
\begin_layout Itemize
|
1354
|
+
|
1355
|
+
\family typewriter
|
1356
|
+
#InitialMarking
|
1357
|
+
\family default
|
1358
|
+
– getter of
|
1359
|
+
\family typewriter
|
1360
|
+
@InitialMarking
|
1361
|
+
\family default
|
1362
|
+
, a PS of
|
1363
|
+
\family typewriter
|
1364
|
+
Simulation::InitialMarking
|
1365
|
+
\family default
|
1366
|
+
, which in turn is a subclass of
|
1367
|
+
\family typewriter
|
1368
|
+
PlaceMapping
|
1369
|
+
\family default
|
1370
|
+
.
|
1371
|
+
\end_layout
|
1372
|
+
|
1373
|
+
\begin_layout Itemize
|
1374
|
+
|
1375
|
+
\family typewriter
|
1376
|
+
#MarkingClamps
|
1377
|
+
\family default
|
1378
|
+
– getter of
|
1379
|
+
\family typewriter
|
1380
|
+
@MarkingClamps
|
1381
|
+
\family default
|
1382
|
+
, a PS of
|
1383
|
+
\family typewriter
|
1384
|
+
Simulation::MarkingClamps
|
1385
|
+
\family default
|
1386
|
+
, which in turn is a subclass of
|
1387
|
+
\family typewriter
|
1388
|
+
PlaceMapping
|
1389
|
+
\family default
|
1390
|
+
.
|
1391
|
+
\end_layout
|
1392
|
+
|
1393
|
+
\begin_layout Standard
|
1394
|
+
Simulation can be of two types: Timed or timeless.
|
1395
|
+
These two types are defined in two mixins,
|
1396
|
+
\family typewriter
|
1397
|
+
Simulation::Timed
|
1398
|
+
\family default
|
1399
|
+
and
|
1400
|
+
\family typewriter
|
1401
|
+
Simulation::Timeless
|
1402
|
+
\family default
|
1403
|
+
, with which the simulation instance is conditionally extended during its
|
1404
|
+
initialization, depending on its type.
|
1405
|
+
Simulation has a number of specialized instance methods defined in several
|
1406
|
+
mixins located inside the
|
1407
|
+
\family typewriter
|
1408
|
+
Simulation
|
1409
|
+
\family default
|
1410
|
+
namespace (
|
1411
|
+
\family typewriter
|
1412
|
+
Places::Access
|
1413
|
+
\family default
|
1414
|
+
,
|
1415
|
+
\family typewriter
|
1416
|
+
Transitions::Access
|
1417
|
+
\family default
|
1418
|
+
,
|
1419
|
+
\family typewriter
|
1420
|
+
Elements::Access
|
1421
|
+
\family default
|
1422
|
+
,
|
1423
|
+
\family typewriter
|
1424
|
+
InitialMarking::Access
|
1425
|
+
\family default
|
1426
|
+
,
|
1427
|
+
\family typewriter
|
1428
|
+
MarkingClamps::Access
|
1429
|
+
\family default
|
1430
|
+
,
|
1431
|
+
\family typewriter
|
1432
|
+
MarkingVector::Access
|
1433
|
+
\family default
|
1434
|
+
).
|
1435
|
+
You can find their complete listing in the class documentation.
|
1436
|
+
Some of the instance methods are:
|
1437
|
+
\end_layout
|
1438
|
+
|
1439
|
+
\begin_layout Itemize
|
1440
|
+
|
1441
|
+
\family typewriter
|
1442
|
+
#reset!
|
1443
|
+
\family default
|
1444
|
+
– resets the simulation.
|
1445
|
+
\end_layout
|
1446
|
+
|
1447
|
+
\begin_layout Itemize
|
1448
|
+
|
1449
|
+
\family typewriter
|
1450
|
+
#run!
|
1451
|
+
\family default
|
1452
|
+
– runs the simulation.
|
1453
|
+
\end_layout
|
1454
|
+
|
1455
|
+
\begin_layout Itemize
|
1456
|
+
|
1457
|
+
\family typewriter
|
1458
|
+
#run_upto
|
1459
|
+
\family default
|
1460
|
+
– runs the simulation to a given time (same can be achieved by
|
1461
|
+
\begin_inset Quotes eld
|
1462
|
+
\end_inset
|
1463
|
+
|
1464
|
+
|
1465
|
+
\family typewriter
|
1466
|
+
run( upto: ...
|
1467
|
+
)
|
1468
|
+
\family default
|
1469
|
+
|
1470
|
+
\begin_inset Quotes erd
|
1471
|
+
\end_inset
|
1472
|
+
|
1473
|
+
).
|
1474
|
+
\end_layout
|
1475
|
+
|
1476
|
+
\begin_layout Itemize
|
1477
|
+
|
1478
|
+
\family typewriter
|
1479
|
+
#step!
|
1480
|
+
\family default
|
1481
|
+
– steps the simulation.
|
1482
|
+
\end_layout
|
1483
|
+
|
1484
|
+
\begin_layout Itemize
|
1485
|
+
|
1486
|
+
\family typewriter
|
1487
|
+
#settings
|
1488
|
+
\family default
|
1489
|
+
– returns all the settings for this simulation.
|
1490
|
+
\end_layout
|
1491
|
+
|
1492
|
+
\begin_layout Itemize
|
1493
|
+
|
1494
|
+
\family typewriter
|
1495
|
+
#core
|
1496
|
+
\family default
|
1497
|
+
– simulator currently in use.
|
1498
|
+
\end_layout
|
1499
|
+
|
1500
|
+
\begin_layout Itemize
|
1501
|
+
|
1502
|
+
\family typewriter
|
1503
|
+
#recorder
|
1504
|
+
\family default
|
1505
|
+
– recorder instance currently in use.
|
1506
|
+
\end_layout
|
1507
|
+
|
1508
|
+
\begin_layout Itemize
|
1509
|
+
|
1510
|
+
\family typewriter
|
1511
|
+
#tS_SM
|
1512
|
+
\family default
|
1513
|
+
– stoichiometric matrix for tS transitions.
|
1514
|
+
\end_layout
|
1515
|
+
|
1516
|
+
\begin_layout Itemize
|
1517
|
+
|
1518
|
+
\family typewriter
|
1519
|
+
#TS_SM
|
1520
|
+
\family default
|
1521
|
+
– stoichiometric matrix for TS transitions.
|
1522
|
+
\end_layout
|
1523
|
+
|
1524
|
+
\begin_layout Itemize
|
1525
|
+
|
1526
|
+
\family typewriter
|
1527
|
+
#dup
|
1528
|
+
\family default
|
1529
|
+
, alias
|
1530
|
+
\family typewriter
|
1531
|
+
#at
|
1532
|
+
\family default
|
1533
|
+
– duplicate of the receiver simulation, with the possibility to change
|
1534
|
+
time and/or other simulation settings.
|
1535
|
+
\end_layout
|
1536
|
+
|
1537
|
+
\begin_layout Standard
|
1538
|
+
Defined in
|
1539
|
+
\family typewriter
|
1540
|
+
Simulation::Places::Access
|
1541
|
+
\family default
|
1542
|
+
:
|
1543
|
+
\end_layout
|
1544
|
+
|
1545
|
+
\begin_layout Itemize
|
1546
|
+
|
1547
|
+
\family typewriter
|
1548
|
+
#include_place?
|
1549
|
+
\family default
|
1550
|
+
– inquirer whether the simulation includes a specified place.
|
1551
|
+
\end_layout
|
1552
|
+
|
1553
|
+
\begin_layout Itemize
|
1554
|
+
|
1555
|
+
\family typewriter
|
1556
|
+
#p
|
1557
|
+
\family default
|
1558
|
+
– net's place identified by the argument.
|
1559
|
+
\end_layout
|
1560
|
+
|
1561
|
+
\begin_layout Itemize
|
1562
|
+
|
1563
|
+
\family typewriter
|
1564
|
+
#Pp
|
1565
|
+
\family default
|
1566
|
+
– net's places, expects single array argument.
|
1567
|
+
\end_layout
|
1568
|
+
|
1569
|
+
\begin_layout Itemize
|
1570
|
+
|
1571
|
+
\family typewriter
|
1572
|
+
#pp
|
1573
|
+
\family default
|
1574
|
+
– net's places, arbitrary number of arguments.
|
1575
|
+
If called without arguments, returns all the net's places.
|
1576
|
+
\end_layout
|
1577
|
+
|
1578
|
+
\begin_layout Itemize
|
1579
|
+
|
1580
|
+
\family typewriter
|
1581
|
+
#Free_pp
|
1582
|
+
\family default
|
1583
|
+
, alias
|
1584
|
+
\family typewriter
|
1585
|
+
#free_Pp
|
1586
|
+
\family default
|
1587
|
+
– net's free places, single array argument.
|
1588
|
+
\end_layout
|
1589
|
+
|
1590
|
+
\begin_layout Itemize
|
1591
|
+
|
1592
|
+
\family typewriter
|
1593
|
+
#free_pp
|
1594
|
+
\family default
|
1595
|
+
– net's free places, arbitrary number of arguments.
|
1596
|
+
If called without arguments, returns all of them.
|
1597
|
+
\end_layout
|
1598
|
+
|
1599
|
+
\begin_layout Itemize
|
1600
|
+
|
1601
|
+
\family typewriter
|
1602
|
+
#Clamped_pp
|
1603
|
+
\family default
|
1604
|
+
, alias
|
1605
|
+
\family typewriter
|
1606
|
+
#clamped_Pp
|
1607
|
+
\family default
|
1608
|
+
– net's free places, single array argument.
|
1609
|
+
\end_layout
|
1610
|
+
|
1611
|
+
\begin_layout Itemize
|
1612
|
+
|
1613
|
+
\family typewriter
|
1614
|
+
#clamped_pp
|
1615
|
+
\family default
|
1616
|
+
– net's free places, arbitrary number of arguments.
|
1617
|
+
If called without arguments, returns all of them.
|
1618
|
+
\end_layout
|
1619
|
+
|
1620
|
+
\begin_layout Standard
|
1621
|
+
Defined in
|
1622
|
+
\family typewriter
|
1623
|
+
Simulation::Transitions::Access
|
1624
|
+
\family default
|
1625
|
+
:
|
1626
|
+
\end_layout
|
1627
|
+
|
1628
|
+
\begin_layout Itemize
|
1629
|
+
|
1630
|
+
\family typewriter
|
1631
|
+
#include_transition?
|
1632
|
+
\family default
|
1633
|
+
– inquirer whether the simulation includes a specified place.
|
1634
|
+
\end_layout
|
1635
|
+
|
1636
|
+
\begin_layout Itemize
|
1637
|
+
|
1638
|
+
\family typewriter
|
1639
|
+
#t
|
1640
|
+
\family default
|
1641
|
+
– net's transition identified by the argument.
|
1642
|
+
\end_layout
|
1643
|
+
|
1644
|
+
\begin_layout Itemize
|
1645
|
+
|
1646
|
+
\family typewriter
|
1647
|
+
#Tt
|
1648
|
+
\family default
|
1649
|
+
– net's transitions, expects array argument.
|
1650
|
+
\end_layout
|
1651
|
+
|
1652
|
+
\begin_layout Itemize
|
1653
|
+
|
1654
|
+
\family typewriter
|
1655
|
+
#tt
|
1656
|
+
\family default
|
1657
|
+
– net's transitions, arbitrary number of arguments.
|
1658
|
+
\end_layout
|
1659
|
+
|
1660
|
+
\begin_layout Itemize
|
1661
|
+
|
1662
|
+
\family typewriter
|
1663
|
+
#ts_Tt
|
1664
|
+
\family default
|
1665
|
+
,
|
1666
|
+
\family typewriter
|
1667
|
+
#tS_Tt
|
1668
|
+
\family default
|
1669
|
+
,
|
1670
|
+
\family typewriter
|
1671
|
+
#Ts_Tt
|
1672
|
+
\family default
|
1673
|
+
,
|
1674
|
+
\family typewriter
|
1675
|
+
#TS_Tt
|
1676
|
+
\family default
|
1677
|
+
,
|
1678
|
+
\family typewriter
|
1679
|
+
#A_Tt
|
1680
|
+
\family default
|
1681
|
+
etc.
|
1682
|
+
– net's transitions of the specified type.
|
1683
|
+
As signified by capitalized
|
1684
|
+
\begin_inset Quotes eld
|
1685
|
+
\end_inset
|
1686
|
+
|
1687
|
+
|
1688
|
+
\family typewriter
|
1689
|
+
Tt
|
1690
|
+
\family default
|
1691
|
+
|
1692
|
+
\begin_inset Quotes erd
|
1693
|
+
\end_inset
|
1694
|
+
|
1695
|
+
, these methods expects a single array argument.
|
1696
|
+
\end_layout
|
1697
|
+
|
1698
|
+
\begin_layout Itemize
|
1699
|
+
|
1700
|
+
\family typewriter
|
1701
|
+
#ts_tt
|
1702
|
+
\family default
|
1703
|
+
,
|
1704
|
+
\family typewriter
|
1705
|
+
#tS_tt
|
1706
|
+
\family default
|
1707
|
+
,
|
1708
|
+
\family typewriter
|
1709
|
+
#Ts_tt
|
1710
|
+
\family default
|
1711
|
+
,
|
1712
|
+
\family typewriter
|
1713
|
+
#TS_tt
|
1714
|
+
\family default
|
1715
|
+
,
|
1716
|
+
\family typewriter
|
1717
|
+
#A_tt
|
1718
|
+
\family default
|
1719
|
+
etc.
|
1720
|
+
– versions of tnet's transitions of the specified type.
|
1721
|
+
As signified by capitalized
|
1722
|
+
\begin_inset Quotes eld
|
1723
|
+
\end_inset
|
1724
|
+
|
1725
|
+
|
1726
|
+
\family typewriter
|
1727
|
+
Tt
|
1728
|
+
\family default
|
1729
|
+
|
1730
|
+
\begin_inset Quotes erd
|
1731
|
+
\end_inset
|
1732
|
+
|
1733
|
+
, these methods expects a single array argument.
|
1734
|
+
\end_layout
|
1735
|
+
|
1736
|
+
\begin_layout Standard
|
1737
|
+
Defined in
|
1738
|
+
\family typewriter
|
1739
|
+
Simulation::Elements::Access
|
1740
|
+
\family default
|
1741
|
+
(word
|
1742
|
+
\begin_inset Quotes eld
|
1743
|
+
\end_inset
|
1744
|
+
|
1745
|
+
element
|
1746
|
+
\begin_inset Quotes erd
|
1747
|
+
\end_inset
|
1748
|
+
|
1749
|
+
simply stands for etiher place, or transition):
|
1750
|
+
\end_layout
|
1751
|
+
|
1752
|
+
\begin_layout Itemize
|
1753
|
+
|
1754
|
+
\family typewriter
|
1755
|
+
#include?
|
1756
|
+
\family default
|
1757
|
+
– inquirer whether the simulation includes a specified place or transition.
|
1758
|
+
\end_layout
|
1759
|
+
|
1760
|
+
\begin_layout Itemize
|
1761
|
+
|
1762
|
+
\family typewriter
|
1763
|
+
#e
|
1764
|
+
\family default
|
1765
|
+
– net's element identified by the argument.
|
1766
|
+
\end_layout
|
1767
|
+
|
1768
|
+
\begin_layout Itemize
|
1769
|
+
|
1770
|
+
\family typewriter
|
1771
|
+
#Ee
|
1772
|
+
\family default
|
1773
|
+
– net's elements identified by a single array argument.
|
1774
|
+
\end_layout
|
1775
|
+
|
1776
|
+
\begin_layout Itemize
|
1777
|
+
|
1778
|
+
\family typewriter
|
1779
|
+
#ee
|
1780
|
+
\family default
|
1781
|
+
– net's elements, arbitrary number of arguments.
|
1782
|
+
\end_layout
|
1783
|
+
|
1784
|
+
\begin_layout Standard
|
1785
|
+
Defined in
|
1786
|
+
\family typewriter
|
1787
|
+
Simulation::InitialMarking::Access
|
1788
|
+
\family default
|
1789
|
+
:
|
1790
|
+
\end_layout
|
1791
|
+
|
1792
|
+
\begin_layout Itemize
|
1793
|
+
|
1794
|
+
\family typewriter
|
1795
|
+
#Initial_markings
|
1796
|
+
\family default
|
1797
|
+
, alias
|
1798
|
+
\family typewriter
|
1799
|
+
#initial_Markings
|
1800
|
+
\family default
|
1801
|
+
– initial markings of given
|
1802
|
+
\emph on
|
1803
|
+
free
|
1804
|
+
\emph default
|
1805
|
+
places, single array argument.
|
1806
|
+
\end_layout
|
1807
|
+
|
1808
|
+
\begin_layout Itemize
|
1809
|
+
|
1810
|
+
\family typewriter
|
1811
|
+
#initial_markings
|
1812
|
+
\family default
|
1813
|
+
, alias
|
1814
|
+
\family typewriter
|
1815
|
+
#initial_marking
|
1816
|
+
\family default
|
1817
|
+
– initial markings, arbitrary number of arguments identifying free places.
|
1818
|
+
\end_layout
|
1819
|
+
|
1820
|
+
\begin_layout Itemize
|
1821
|
+
|
1822
|
+
\family typewriter
|
1823
|
+
#Im
|
1824
|
+
\family default
|
1825
|
+
– starting markings of an array of
|
1826
|
+
\emph on
|
1827
|
+
any
|
1828
|
+
\emph default
|
1829
|
+
(not just free) places, as they appear right after reset.
|
1830
|
+
Expects a single array argument.
|
1831
|
+
\end_layout
|
1832
|
+
|
1833
|
+
\begin_layout Itemize
|
1834
|
+
|
1835
|
+
\family typewriter
|
1836
|
+
#im
|
1837
|
+
\family default
|
1838
|
+
– starting markings of any places, arbitrary number of arguments.
|
1839
|
+
\end_layout
|
1840
|
+
|
1841
|
+
\begin_layout Standard
|
1842
|
+
Defined in
|
1843
|
+
\family typewriter
|
1844
|
+
Simulation::MarkingClamps::Access
|
1845
|
+
\family default
|
1846
|
+
:
|
1847
|
+
\end_layout
|
1848
|
+
|
1849
|
+
\begin_layout Itemize
|
1850
|
+
|
1851
|
+
\family typewriter
|
1852
|
+
#Marking_clamps
|
1853
|
+
\family default
|
1854
|
+
, alias
|
1855
|
+
\family typewriter
|
1856
|
+
#marking_Clamps
|
1857
|
+
\family default
|
1858
|
+
– marking clamp values of given
|
1859
|
+
\emph on
|
1860
|
+
clamped
|
1861
|
+
\emph default
|
1862
|
+
places, single array argument.
|
1863
|
+
\end_layout
|
1864
|
+
|
1865
|
+
\begin_layout Itemize
|
1866
|
+
|
1867
|
+
\family typewriter
|
1868
|
+
#marking_clamps
|
1869
|
+
\family default
|
1870
|
+
– initial markings, arbitrary number of arguments.
|
1871
|
+
\end_layout
|
1872
|
+
|
1873
|
+
\begin_layout Itemize
|
1874
|
+
|
1875
|
+
\family typewriter
|
1876
|
+
#marking_clamp
|
1877
|
+
\family default
|
1878
|
+
– expects a single clamped place, returns its marking clamp.
|
1879
|
+
\end_layout
|
1880
|
+
|
1881
|
+
\begin_layout Standard
|
1882
|
+
Defined in
|
1883
|
+
\family typewriter
|
1884
|
+
Simulation::MarkingVector::Access
|
1885
|
+
\family default
|
1886
|
+
:
|
1887
|
+
\end_layout
|
1888
|
+
|
1889
|
+
\begin_layout Itemize
|
1890
|
+
|
1891
|
+
\family typewriter
|
1892
|
+
#M_vector
|
1893
|
+
\family default
|
1894
|
+
alias
|
1895
|
+
\family typewriter
|
1896
|
+
#m_Vector
|
1897
|
+
\family default
|
1898
|
+
– marking of the selected places returned as a column vector.
|
1899
|
+
Expects a single array argument.
|
1900
|
+
\end_layout
|
1901
|
+
|
1902
|
+
\begin_layout Itemize
|
1903
|
+
|
1904
|
+
\family typewriter
|
1905
|
+
#state
|
1906
|
+
\family default
|
1907
|
+
– getter of the simulation's state vector (
|
1908
|
+
\family typewriter
|
1909
|
+
@m_vector
|
1910
|
+
\family default
|
1911
|
+
instance variable).
|
1912
|
+
\end_layout
|
1913
|
+
|
1914
|
+
\begin_layout Itemize
|
1915
|
+
|
1916
|
+
\family typewriter
|
1917
|
+
#m_vector
|
1918
|
+
\family default
|
1919
|
+
– marking of the selected places returned as a column vector, any number
|
1920
|
+
of arguments.
|
1921
|
+
\end_layout
|
1922
|
+
|
1923
|
+
\begin_layout Itemize
|
1924
|
+
|
1925
|
+
\family typewriter
|
1926
|
+
#M
|
1927
|
+
\family default
|
1928
|
+
,
|
1929
|
+
\family typewriter
|
1930
|
+
#m
|
1931
|
+
\family default
|
1932
|
+
– array-returning varieties of
|
1933
|
+
\family typewriter
|
1934
|
+
#M_vector
|
1935
|
+
\family default
|
1936
|
+
and
|
1937
|
+
\family typewriter
|
1938
|
+
#m
|
1939
|
+
\family default
|
1940
|
+
.
|
1941
|
+
\end_layout
|
1942
|
+
|
1943
|
+
\begin_layout Itemize
|
1944
|
+
|
1945
|
+
\family typewriter
|
1946
|
+
#p_M
|
1947
|
+
\family default
|
1948
|
+
(alias
|
1949
|
+
\family typewriter
|
1950
|
+
#P_m
|
1951
|
+
\family default
|
1952
|
+
),
|
1953
|
+
\family typewriter
|
1954
|
+
#p_m
|
1955
|
+
\family default
|
1956
|
+
– hash-returning varieties of
|
1957
|
+
\family typewriter
|
1958
|
+
#M_vector
|
1959
|
+
\family default
|
1960
|
+
and
|
1961
|
+
\family typewriter
|
1962
|
+
#m
|
1963
|
+
\family default
|
1964
|
+
.
|
1965
|
+
\end_layout
|
1966
|
+
|
1967
|
+
\begin_layout Itemize
|
1968
|
+
|
1969
|
+
\family typewriter
|
1970
|
+
#Pm
|
1971
|
+
\family default
|
1972
|
+
,
|
1973
|
+
\family typewriter
|
1974
|
+
#pm
|
1975
|
+
\family default
|
1976
|
+
– pretty printing varieties of
|
1977
|
+
\family typewriter
|
1978
|
+
#M_vector
|
1979
|
+
\family default
|
1980
|
+
and
|
1981
|
+
\family typewriter
|
1982
|
+
#m
|
1983
|
+
\family default
|
1984
|
+
.
|
1985
|
+
\end_layout
|
1986
|
+
|
1987
|
+
\begin_layout Standard
|
1988
|
+
Defined in
|
1989
|
+
\family typewriter
|
1990
|
+
Simulation::Timed
|
1991
|
+
\family default
|
1992
|
+
and
|
1993
|
+
\family typewriter
|
1994
|
+
Simulation::Timeless
|
1995
|
+
\family default
|
1996
|
+
mixins:
|
1997
|
+
\end_layout
|
1998
|
+
|
1999
|
+
\begin_layout Itemize
|
2000
|
+
|
2001
|
+
\family typewriter
|
2002
|
+
#timed?
|
2003
|
+
\family default
|
2004
|
+
– inquirer whether the simulation is timed
|
2005
|
+
\end_layout
|
2006
|
+
|
2007
|
+
\begin_layout Itemize
|
2008
|
+
|
2009
|
+
\family typewriter
|
2010
|
+
#Recorder
|
2011
|
+
\family default
|
2012
|
+
– getter of
|
2013
|
+
\family typewriter
|
2014
|
+
@Recorder
|
2015
|
+
\family default
|
2016
|
+
, a PS of
|
2017
|
+
\family typewriter
|
2018
|
+
Petri::Simulation::Recorder
|
2019
|
+
\family default
|
2020
|
+
, an object that performs sampling and recording during simulation.
|
2021
|
+
\end_layout
|
2022
|
+
|
2023
|
+
\begin_layout Itemize
|
2024
|
+
|
2025
|
+
\family typewriter
|
2026
|
+
#Core
|
2027
|
+
\family default
|
2028
|
+
– getter of
|
2029
|
+
\family typewriter
|
2030
|
+
@Core
|
2031
|
+
\family default
|
2032
|
+
, a PS of
|
2033
|
+
\family typewriter
|
2034
|
+
YPetri::Core
|
2035
|
+
\family default
|
2036
|
+
, a machine abstraction class.
|
2037
|
+
\end_layout
|
2038
|
+
|
2039
|
+
\begin_layout Standard
|
2040
|
+
Defined in
|
2041
|
+
\family typewriter
|
2042
|
+
Simulation::Timed
|
2043
|
+
\family default
|
2044
|
+
mixin:
|
2045
|
+
\end_layout
|
2046
|
+
|
2047
|
+
\begin_layout Itemize
|
2048
|
+
|
2049
|
+
\family typewriter
|
2050
|
+
#time
|
2051
|
+
\family default
|
2052
|
+
– current simulation time
|
2053
|
+
\end_layout
|
2054
|
+
|
2055
|
+
\begin_layout Itemize
|
2056
|
+
|
2057
|
+
\family typewriter
|
2058
|
+
#initial_time
|
2059
|
+
\family default
|
2060
|
+
– initial time of the simulation
|
2061
|
+
\end_layout
|
2062
|
+
|
2063
|
+
\begin_layout Itemize
|
2064
|
+
|
2065
|
+
\family typewriter
|
2066
|
+
#target_time
|
2067
|
+
\family default
|
2068
|
+
– target time of the simulation (used when
|
2069
|
+
\family typewriter
|
2070
|
+
#run!
|
2071
|
+
\family default
|
2072
|
+
is called without arguments)
|
2073
|
+
\end_layout
|
2074
|
+
|
2075
|
+
\begin_layout Itemize
|
2076
|
+
|
2077
|
+
\family typewriter
|
2078
|
+
#time_range
|
2079
|
+
\family default
|
2080
|
+
– range-returning alternative for
|
2081
|
+
\family typewriter
|
2082
|
+
#initial_time
|
2083
|
+
\family default
|
2084
|
+
and
|
2085
|
+
\family typewriter
|
2086
|
+
#target_time
|
2087
|
+
\family default
|
2088
|
+
.
|
2089
|
+
\end_layout
|
2090
|
+
|
2091
|
+
\begin_layout Itemize
|
2092
|
+
|
2093
|
+
\family typewriter
|
2094
|
+
#step
|
2095
|
+
\family default
|
2096
|
+
,
|
2097
|
+
\family typewriter
|
2098
|
+
#step=
|
2099
|
+
\family default
|
2100
|
+
– getter and setter of the simulation step size
|
2101
|
+
\end_layout
|
2102
|
+
|
2103
|
+
\begin_layout Itemize
|
2104
|
+
|
2105
|
+
\family typewriter
|
2106
|
+
#default_sampling
|
2107
|
+
\family default
|
2108
|
+
– sampling period for the simulation
|
2109
|
+
\end_layout
|
2110
|
+
|
2111
|
+
\begin_layout Itemize
|
2112
|
+
|
2113
|
+
\family typewriter
|
2114
|
+
#Fluxes
|
2115
|
+
\family default
|
2116
|
+
– takes a single array of TS transitions and returns their fluxes under
|
2117
|
+
current marking.
|
2118
|
+
\end_layout
|
2119
|
+
|
2120
|
+
\begin_layout Itemize
|
2121
|
+
|
2122
|
+
\family typewriter
|
2123
|
+
#fluxes
|
2124
|
+
\family default
|
2125
|
+
, alias
|
2126
|
+
\family typewriter
|
2127
|
+
#flux
|
2128
|
+
\family default
|
2129
|
+
– like
|
2130
|
+
\family typewriter
|
2131
|
+
#Fluxes
|
2132
|
+
\family default
|
2133
|
+
, but takes an arbitrary number of arguments.
|
2134
|
+
If no arguments are supplied, returns all of them.
|
2135
|
+
\end_layout
|
2136
|
+
|
2137
|
+
\begin_layout Itemize
|
2138
|
+
|
2139
|
+
\family typewriter
|
2140
|
+
#T_fluxes
|
2141
|
+
\family default
|
2142
|
+
(alias
|
2143
|
+
\family typewriter
|
2144
|
+
#t_Fluxes
|
2145
|
+
\family default
|
2146
|
+
),
|
2147
|
+
\family typewriter
|
2148
|
+
#t_fluxes
|
2149
|
+
\family default
|
2150
|
+
(alias
|
2151
|
+
\family typewriter
|
2152
|
+
#t_flux
|
2153
|
+
\family default
|
2154
|
+
) – hash-returning varieties of
|
2155
|
+
\family typewriter
|
2156
|
+
#Fluxes
|
2157
|
+
\family default
|
2158
|
+
and
|
2159
|
+
\family typewriter
|
2160
|
+
#fluxes
|
2161
|
+
\family default
|
2162
|
+
.
|
2163
|
+
\end_layout
|
2164
|
+
|
2165
|
+
\begin_layout Itemize
|
2166
|
+
|
2167
|
+
\family typewriter
|
2168
|
+
#pflux
|
2169
|
+
\family default
|
2170
|
+
– pretty-printing variety of
|
2171
|
+
\family typewriter
|
2172
|
+
#t_flux
|
2173
|
+
\family default
|
2174
|
+
.
|
2175
|
+
\end_layout
|
2176
|
+
|
2177
|
+
\begin_layout Standard
|
2178
|
+
The above list of methods is not exhaustive.
|
2179
|
+
For full list of methods and their documentation, see the documentation
|
2180
|
+
of the
|
2181
|
+
\family typewriter
|
2182
|
+
Simulation
|
2183
|
+
\family default
|
2184
|
+
class.
|
2185
|
+
\end_layout
|
2186
|
+
|
2187
|
+
\begin_layout Part*
|
2188
|
+
|
2189
|
+
\family typewriter
|
2190
|
+
Simulation::Recorder
|
2191
|
+
\family default
|
2192
|
+
class
|
2193
|
+
\end_layout
|
2194
|
+
|
2195
|
+
\begin_layout Standard
|
2196
|
+
|
2197
|
+
\family typewriter
|
2198
|
+
YPetri::Simulation::Recorder
|
2199
|
+
\family default
|
2200
|
+
is a class used exclusively as a PS dependent on
|
2201
|
+
\family typewriter
|
2202
|
+
YPetri::Simulation
|
2203
|
+
\family default
|
2204
|
+
instances.
|
2205
|
+
Its has tow key attributes:
|
2206
|
+
\end_layout
|
2207
|
+
|
2208
|
+
\begin_layout Enumerate
|
2209
|
+
|
2210
|
+
\family typewriter
|
2211
|
+
#features
|
2212
|
+
\family default
|
2213
|
+
– getter of
|
2214
|
+
\family typewriter
|
2215
|
+
@features
|
2216
|
+
\family default
|
2217
|
+
, containing the feature set to be recorded.
|
2218
|
+
Its class is a PS of
|
2219
|
+
\family typewriter
|
2220
|
+
Net::State::Features
|
2221
|
+
\family default
|
2222
|
+
.
|
2223
|
+
It can be specified explicitly upon initialization or via
|
2224
|
+
\family typewriter
|
2225
|
+
#reset!
|
2226
|
+
\family default
|
2227
|
+
method.
|
2228
|
+
By default, markings of the free places are used.
|
2229
|
+
\end_layout
|
2230
|
+
|
2231
|
+
\begin_layout Enumerate
|
2232
|
+
|
2233
|
+
\family typewriter
|
2234
|
+
#recording
|
2235
|
+
\family default
|
2236
|
+
– getter of
|
2237
|
+
\family typewriter
|
2238
|
+
@recording
|
2239
|
+
\family default
|
2240
|
+
, containing the recording itself.
|
2241
|
+
Its class is a PS of
|
2242
|
+
\family typewriter
|
2243
|
+
Net::DataSet
|
2244
|
+
\family default
|
2245
|
+
.
|
2246
|
+
\end_layout
|
2247
|
+
|
2248
|
+
\begin_layout Standard
|
2249
|
+
In the course of simulation, the recorder performs sampling: Upon occurence
|
2250
|
+
of certain events, it records the feature set and stores it in the
|
2251
|
+
\family typewriter
|
2252
|
+
@recording
|
2253
|
+
\family default
|
2254
|
+
object.
|
2255
|
+
For timed simulations, events are typically specified by time (
|
2256
|
+
\family typewriter
|
2257
|
+
@next_time
|
2258
|
+
\family default
|
2259
|
+
variable).
|
2260
|
+
Timeless simulations are not handled in the current version of
|
2261
|
+
\family typewriter
|
2262
|
+
YPetri
|
2263
|
+
\family default
|
2264
|
+
, but it can already be said that events will be specified as conditions
|
2265
|
+
defined on the marking vector (
|
2266
|
+
\family typewriter
|
2267
|
+
@next_event
|
2268
|
+
\family default
|
2269
|
+
variable).
|
2270
|
+
Recorder's checking for whether the sampling condition is fulfilled is
|
2271
|
+
triggered by the
|
2272
|
+
\family typewriter
|
2273
|
+
:alert!
|
2274
|
+
\family default
|
2275
|
+
message.
|
2276
|
+
|
2277
|
+
\family typewriter
|
2278
|
+
Recorder.new
|
2279
|
+
\family default
|
2280
|
+
constructor takes the following named arguments:
|
2281
|
+
\end_layout
|
2282
|
+
|
2283
|
+
\begin_layout Itemize
|
2284
|
+
|
2285
|
+
\family typewriter
|
2286
|
+
features:
|
2287
|
+
\family default
|
2288
|
+
the feature set to record.
|
2289
|
+
\end_layout
|
2290
|
+
|
2291
|
+
\begin_layout Itemize
|
2292
|
+
|
2293
|
+
\family typewriter
|
2294
|
+
recording:
|
2295
|
+
\family default
|
2296
|
+
option to plug a pre-constructed dataset to the recorder.
|
2297
|
+
\end_layout
|
2298
|
+
|
2299
|
+
\begin_layout Standard
|
2300
|
+
In timed simulations,
|
2301
|
+
\family typewriter
|
2302
|
+
Recorder.new
|
2303
|
+
\family default
|
2304
|
+
also accepts:
|
2305
|
+
\end_layout
|
2306
|
+
|
2307
|
+
\begin_layout Itemize
|
2308
|
+
|
2309
|
+
\family typewriter
|
2310
|
+
sampling:
|
2311
|
+
\family default
|
2312
|
+
sampling period
|
2313
|
+
\end_layout
|
2314
|
+
|
2315
|
+
\begin_layout Itemize
|
2316
|
+
|
2317
|
+
\family typewriter
|
2318
|
+
next_time:
|
2319
|
+
\family default
|
2320
|
+
the next sampling time
|
2321
|
+
\end_layout
|
2322
|
+
|
2323
|
+
\begin_layout Standard
|
2324
|
+
Important instance methods of
|
2325
|
+
\family typewriter
|
2326
|
+
Recorder
|
2327
|
+
\family default
|
2328
|
+
are:
|
2329
|
+
\end_layout
|
2330
|
+
|
2331
|
+
\begin_layout Itemize
|
2332
|
+
|
2333
|
+
\family typewriter
|
2334
|
+
#new_recording
|
2335
|
+
\family default
|
2336
|
+
– constructs a new recording dependent on
|
2337
|
+
\family typewriter
|
2338
|
+
@features
|
2339
|
+
\family default
|
2340
|
+
.
|
2341
|
+
\end_layout
|
2342
|
+
|
2343
|
+
\begin_layout Itemize
|
2344
|
+
|
2345
|
+
\family typewriter
|
2346
|
+
#reset!
|
2347
|
+
\family default
|
2348
|
+
– resets
|
2349
|
+
\family typewriter
|
2350
|
+
@recording
|
2351
|
+
\family default
|
2352
|
+
and optionally changes
|
2353
|
+
\family typewriter
|
2354
|
+
@features
|
2355
|
+
\family default
|
2356
|
+
.
|
2357
|
+
\end_layout
|
2358
|
+
|
2359
|
+
\begin_layout Itemize
|
2360
|
+
|
2361
|
+
\family typewriter
|
2362
|
+
#alert!
|
2363
|
+
\family default
|
2364
|
+
– recorder expects this message whenever the system state changes.
|
2365
|
+
\end_layout
|
2366
|
+
|
2367
|
+
\begin_layout Itemize
|
2368
|
+
|
2369
|
+
\family typewriter
|
2370
|
+
#sample!
|
2371
|
+
\family default
|
2372
|
+
– private method that performs sampling
|
2373
|
+
\end_layout
|
2374
|
+
|
2375
|
+
\begin_layout Part*
|
2376
|
+
|
2377
|
+
\family typewriter
|
2378
|
+
Core
|
2379
|
+
\family default
|
2380
|
+
class
|
2381
|
+
\end_layout
|
2382
|
+
|
2383
|
+
\begin_layout Standard
|
2384
|
+
|
2385
|
+
\family typewriter
|
2386
|
+
YPetri::Core
|
2387
|
+
\family default
|
2388
|
+
class is the abstraction for the simulator machine.
|
2389
|
+
Originally, it was named
|
2390
|
+
\family typewriter
|
2391
|
+
Simulator
|
2392
|
+
\family default
|
2393
|
+
, but
|
2394
|
+
\family typewriter
|
2395
|
+
Core
|
2396
|
+
\family default
|
2397
|
+
is shorter.
|
2398
|
+
When a
|
2399
|
+
\family typewriter
|
2400
|
+
Simulation
|
2401
|
+
\family default
|
2402
|
+
instance wants to proceed in time to a next state, it relies on a
|
2403
|
+
\family typewriter
|
2404
|
+
Core
|
2405
|
+
\family default
|
2406
|
+
instance to perform the computation.
|
2407
|
+
|
2408
|
+
\family typewriter
|
2409
|
+
Core
|
2410
|
+
\family default
|
2411
|
+
was separated from
|
2412
|
+
\family typewriter
|
2413
|
+
Simulation
|
2414
|
+
\family default
|
2415
|
+
for the purpose of facilitating the use of different machines to run the
|
2416
|
+
simulation.
|
2417
|
+
At the moment, plain Ruby is used to compute the simulation steps.
|
2418
|
+
|
2419
|
+
\family typewriter
|
2420
|
+
Core
|
2421
|
+
\family default
|
2422
|
+
instance is generally not directly controlled by the user.
|
2423
|
+
|
2424
|
+
\family typewriter
|
2425
|
+
Core
|
2426
|
+
\family default
|
2427
|
+
provides certain some basic interface, on which its mixins defining the
|
2428
|
+
different simulation methods rely:
|
2429
|
+
\end_layout
|
2430
|
+
|
2431
|
+
\begin_layout Itemize
|
2432
|
+
|
2433
|
+
\family typewriter
|
2434
|
+
#flux_vector
|
2435
|
+
\family default
|
2436
|
+
– flux vector for the nets with only TS transitions.
|
2437
|
+
\end_layout
|
2438
|
+
|
2439
|
+
\begin_layout Itemize
|
2440
|
+
|
2441
|
+
\family typewriter
|
2442
|
+
#flux_vector_TS
|
2443
|
+
\family default
|
2444
|
+
– for mixed nets, returns flux vector for only TS transitions.
|
2445
|
+
\end_layout
|
2446
|
+
|
2447
|
+
\begin_layout Itemize
|
2448
|
+
|
2449
|
+
\family typewriter
|
2450
|
+
#firing_vector_tS
|
2451
|
+
\family default
|
2452
|
+
– firing vector of tS transitions.
|
2453
|
+
\end_layout
|
2454
|
+
|
2455
|
+
\begin_layout Itemize
|
2456
|
+
|
2457
|
+
\family typewriter
|
2458
|
+
#delta_tS
|
2459
|
+
\family default
|
2460
|
+
– delta state caused by tS transitions.
|
2461
|
+
\end_layout
|
2462
|
+
|
2463
|
+
\begin_layout Itemize
|
2464
|
+
|
2465
|
+
\family typewriter
|
2466
|
+
#delta_ts
|
2467
|
+
\family default
|
2468
|
+
– delta state caused by ts transitions.
|
2469
|
+
\end_layout
|
2470
|
+
|
2471
|
+
\begin_layout Itemize
|
2472
|
+
|
2473
|
+
\family typewriter
|
2474
|
+
#gradient
|
2475
|
+
\family default
|
2476
|
+
– total system gradient for free places.
|
2477
|
+
\end_layout
|
2478
|
+
|
2479
|
+
\begin_layout Itemize
|
2480
|
+
|
2481
|
+
\family typewriter
|
2482
|
+
#gradient_Ts
|
2483
|
+
\family default
|
2484
|
+
– gradient contribution by Ts transitions.
|
2485
|
+
\end_layout
|
2486
|
+
|
2487
|
+
\begin_layout Itemize
|
2488
|
+
|
2489
|
+
\family typewriter
|
2490
|
+
#gradient_TS
|
2491
|
+
\family default
|
2492
|
+
– gradient contribution by TS transitions.
|
2493
|
+
\end_layout
|
2494
|
+
|
2495
|
+
\begin_layout Standard
|
2496
|
+
For the purpose of controlling the marking vector,
|
2497
|
+
\family typewriter
|
2498
|
+
Core
|
2499
|
+
\family default
|
2500
|
+
provides 2 instance methods:
|
2501
|
+
\end_layout
|
2502
|
+
|
2503
|
+
\begin_layout Itemize
|
2504
|
+
|
2505
|
+
\family typewriter
|
2506
|
+
#assignment_transitions_all_fire!
|
2507
|
+
\family default
|
2508
|
+
– fires all A (assignment) transitions.
|
2509
|
+
\end_layout
|
2510
|
+
|
2511
|
+
\begin_layout Itemize
|
2512
|
+
|
2513
|
+
\family typewriter
|
2514
|
+
#increment_marking_vector
|
2515
|
+
\family default
|
2516
|
+
– expects a delta vector of the same size as the marking vector as its
|
2517
|
+
singe argument, and increments the marking vector by it.
|
2518
|
+
\end_layout
|
2519
|
+
|
2520
|
+
\begin_layout Standard
|
2521
|
+
Simulation method mixins take flux, gradient, delta etc., and based on them,
|
2522
|
+
compute the overall delta state, change the marking vector and fire assignment
|
2523
|
+
transitions as defined by the simulation method, alerting the recorder
|
2524
|
+
when the state changes.
|
2525
|
+
At the moment, simulation methods include:
|
2526
|
+
\end_layout
|
2527
|
+
|
2528
|
+
\begin_layout Itemize
|
2529
|
+
|
2530
|
+
\family typewriter
|
2531
|
+
:euler
|
2532
|
+
\family default
|
2533
|
+
– 1st order method for nets with only T (timed) transitions.
|
2534
|
+
Mixin:
|
2535
|
+
\family typewriter
|
2536
|
+
Core::Timed::Euler
|
2537
|
+
\family default
|
2538
|
+
.
|
2539
|
+
\end_layout
|
2540
|
+
|
2541
|
+
\begin_layout Itemize
|
2542
|
+
|
2543
|
+
\family typewriter
|
2544
|
+
:pseudo_euler
|
2545
|
+
\family default
|
2546
|
+
– Euler method adaptation for nets with timeless transitions.
|
2547
|
+
Mixin:
|
2548
|
+
\family typewriter
|
2549
|
+
Core::Timed::PseudoEuler
|
2550
|
+
\family default
|
2551
|
+
.
|
2552
|
+
\end_layout
|
2553
|
+
|
2554
|
+
\begin_layout Itemize
|
2555
|
+
|
2556
|
+
\family typewriter
|
2557
|
+
:gillespie
|
2558
|
+
\family default
|
2559
|
+
– For nets with only T transitions.
|
2560
|
+
Mixin:
|
2561
|
+
\family typewriter
|
2562
|
+
Core::Timed::Gillespie
|
2563
|
+
\family default
|
2564
|
+
.
|
2565
|
+
\end_layout
|
2566
|
+
|
2567
|
+
\begin_layout Itemize
|
2568
|
+
|
2569
|
+
\family typewriter
|
2570
|
+
:runge_kutta
|
2571
|
+
\family default
|
2572
|
+
– 5th order method for nets with only T transitions.
|
2573
|
+
Mixin:
|
2574
|
+
\family typewriter
|
2575
|
+
Core::Timed::RungeKutta
|
2576
|
+
\family default
|
2577
|
+
.
|
2578
|
+
(
|
2579
|
+
\emph on
|
2580
|
+
Not working at the moment!
|
2581
|
+
\emph default
|
2582
|
+
)
|
2583
|
+
\end_layout
|
2584
|
+
|
2585
|
+
\begin_layout Part*
|
2586
|
+
|
2587
|
+
\family typewriter
|
2588
|
+
State
|
2589
|
+
\family default
|
2590
|
+
class
|
2591
|
+
\end_layout
|
2592
|
+
|
2593
|
+
\begin_layout Standard
|
2594
|
+
The state of a Petri net is entirely given by marking of its places.
|
2595
|
+
|
2596
|
+
\family typewriter
|
2597
|
+
Simulation
|
2598
|
+
\family default
|
2599
|
+
instances maintain their own marking vector holding the net state, but
|
2600
|
+
the net instance also has it's own state class, a PS of
|
2601
|
+
\family typewriter
|
2602
|
+
YPetri::Net::State
|
2603
|
+
\family default
|
2604
|
+
<
|
2605
|
+
\family typewriter
|
2606
|
+
Array
|
2607
|
+
\family default
|
2608
|
+
.
|
2609
|
+
|
2610
|
+
\family typewriter
|
2611
|
+
State
|
2612
|
+
\family default
|
2613
|
+
class is thus commonly used as a PS dependent on a
|
2614
|
+
\family typewriter
|
2615
|
+
Net
|
2616
|
+
\family default
|
2617
|
+
instance, whose array positions correspond to the net's places.
|
2618
|
+
This net is available as a public class method on the
|
2619
|
+
\family typewriter
|
2620
|
+
State
|
2621
|
+
\family default
|
2622
|
+
PS:
|
2623
|
+
\end_layout
|
2624
|
+
|
2625
|
+
\begin_layout Itemize
|
2626
|
+
|
2627
|
+
\family typewriter
|
2628
|
+
#net
|
2629
|
+
\family default
|
2630
|
+
– returns the net on which this State PS depends.
|
2631
|
+
\end_layout
|
2632
|
+
|
2633
|
+
\begin_layout Standard
|
2634
|
+
Each such
|
2635
|
+
\family typewriter
|
2636
|
+
State
|
2637
|
+
\family default
|
2638
|
+
PS in turn owns 2 dependent parametrized subclasses:
|
2639
|
+
\end_layout
|
2640
|
+
|
2641
|
+
\begin_layout Itemize
|
2642
|
+
|
2643
|
+
\family typewriter
|
2644
|
+
#Feature
|
2645
|
+
\family default
|
2646
|
+
– getter of
|
2647
|
+
\family typewriter
|
2648
|
+
@Feature
|
2649
|
+
\family default
|
2650
|
+
, containing a PS of
|
2651
|
+
\family typewriter
|
2652
|
+
State::Feature
|
2653
|
+
\family default
|
2654
|
+
.
|
2655
|
+
When called with arguments, acts as alias of
|
2656
|
+
\family typewriter
|
2657
|
+
#feature
|
2658
|
+
\family default
|
2659
|
+
.
|
2660
|
+
\end_layout
|
2661
|
+
|
2662
|
+
\begin_layout Itemize
|
2663
|
+
|
2664
|
+
\family typewriter
|
2665
|
+
#Features
|
2666
|
+
\family default
|
2667
|
+
– getter of
|
2668
|
+
\family typewriter
|
2669
|
+
@Features
|
2670
|
+
\family default
|
2671
|
+
, containing a PS of
|
2672
|
+
\family typewriter
|
2673
|
+
State::Features
|
2674
|
+
\family default
|
2675
|
+
.
|
2676
|
+
When called with a single array argument, this message acts as a feature
|
2677
|
+
set constructor / validator.
|
2678
|
+
\end_layout
|
2679
|
+
|
2680
|
+
\begin_layout Standard
|
2681
|
+
Other public class methods include:
|
2682
|
+
\end_layout
|
2683
|
+
|
2684
|
+
\begin_layout Itemize
|
2685
|
+
|
2686
|
+
\family typewriter
|
2687
|
+
#feature
|
2688
|
+
\family default
|
2689
|
+
–
|
2690
|
+
\family typewriter
|
2691
|
+
@Feature
|
2692
|
+
\family default
|
2693
|
+
instance identifier.
|
2694
|
+
\end_layout
|
2695
|
+
|
2696
|
+
\begin_layout Itemize
|
2697
|
+
|
2698
|
+
\family typewriter
|
2699
|
+
#features
|
2700
|
+
\family default
|
2701
|
+
–
|
2702
|
+
\family typewriter
|
2703
|
+
@Features
|
2704
|
+
\family default
|
2705
|
+
instance constructor.
|
2706
|
+
(See the class documentation for its full description.)
|
2707
|
+
\end_layout
|
2708
|
+
|
2709
|
+
\begin_layout Standard
|
2710
|
+
Instance methods include:
|
2711
|
+
\end_layout
|
2712
|
+
|
2713
|
+
\begin_layout Itemize
|
2714
|
+
|
2715
|
+
\family typewriter
|
2716
|
+
#to_record
|
2717
|
+
\family default
|
2718
|
+
– given clamped places, it returns a
|
2719
|
+
\family typewriter
|
2720
|
+
Record
|
2721
|
+
\family default
|
2722
|
+
instance containing the marking of the free places.
|
2723
|
+
If no set of clamped places is supplied, it is considered empty.
|
2724
|
+
\end_layout
|
2725
|
+
|
2726
|
+
\begin_layout Itemize
|
2727
|
+
|
2728
|
+
\family typewriter
|
2729
|
+
#marking
|
2730
|
+
\family default
|
2731
|
+
– returns the marking of a single given place in this
|
2732
|
+
\family typewriter
|
2733
|
+
State
|
2734
|
+
\family default
|
2735
|
+
instance.
|
2736
|
+
\end_layout
|
2737
|
+
|
2738
|
+
\begin_layout Itemize
|
2739
|
+
|
2740
|
+
\family typewriter
|
2741
|
+
#markings
|
2742
|
+
\family default
|
2743
|
+
– expects an arbitrary number of places, returns a plain array of their
|
2744
|
+
markings.
|
2745
|
+
If no arguments are given, returns all of them.
|
2746
|
+
\end_layout
|
2747
|
+
|
2748
|
+
\begin_layout Part*
|
2749
|
+
|
2750
|
+
\family typewriter
|
2751
|
+
Feature
|
2752
|
+
\family default
|
2753
|
+
class
|
2754
|
+
\end_layout
|
2755
|
+
|
2756
|
+
\begin_layout Standard
|
2757
|
+
A feature defines a measurement which can be performed on a net in some
|
2758
|
+
state to extract the feature's value.
|
2759
|
+
In
|
2760
|
+
\family typewriter
|
2761
|
+
YPetri
|
2762
|
+
\family default
|
2763
|
+
,
|
2764
|
+
\family typewriter
|
2765
|
+
Net::State::Feature
|
2766
|
+
\family default
|
2767
|
+
class is used as a PS dependent on a
|
2768
|
+
\family typewriter
|
2769
|
+
State
|
2770
|
+
\family default
|
2771
|
+
PS (not on a
|
2772
|
+
\family typewriter
|
2773
|
+
State
|
2774
|
+
\family default
|
2775
|
+
instance):
|
2776
|
+
\end_layout
|
2777
|
+
|
2778
|
+
\begin_layout Itemize
|
2779
|
+
|
2780
|
+
\family typewriter
|
2781
|
+
#State
|
2782
|
+
\family default
|
2783
|
+
– the
|
2784
|
+
\family typewriter
|
2785
|
+
State
|
2786
|
+
\family default
|
2787
|
+
PS by which this
|
2788
|
+
\family typewriter
|
2789
|
+
Feature
|
2790
|
+
\family default
|
2791
|
+
PS was parametrized.
|
2792
|
+
\end_layout
|
2793
|
+
|
2794
|
+
\begin_layout Standard
|
2795
|
+
In the present implementation, this class serves as a mother class for more
|
2796
|
+
specialized feature classes:
|
2797
|
+
\family typewriter
|
2798
|
+
Marking
|
2799
|
+
\family default
|
2800
|
+
,
|
2801
|
+
\family typewriter
|
2802
|
+
Firing
|
2803
|
+
\family default
|
2804
|
+
,
|
2805
|
+
\family typewriter
|
2806
|
+
Flux
|
2807
|
+
\family default
|
2808
|
+
,
|
2809
|
+
\family typewriter
|
2810
|
+
Gradient
|
2811
|
+
\family default
|
2812
|
+
,
|
2813
|
+
\family typewriter
|
2814
|
+
Delta
|
2815
|
+
\family default
|
2816
|
+
and
|
2817
|
+
\family typewriter
|
2818
|
+
Assignment
|
2819
|
+
\family default
|
2820
|
+
.
|
2821
|
+
These are defined as
|
2822
|
+
\family typewriter
|
2823
|
+
Feature
|
2824
|
+
\family default
|
2825
|
+
subclasses on the namespace of
|
2826
|
+
\family typewriter
|
2827
|
+
Feature
|
2828
|
+
\family default
|
2829
|
+
itself, but at the same time, a PS of each of them is owned by the Feature
|
2830
|
+
PS:
|
2831
|
+
\end_layout
|
2832
|
+
|
2833
|
+
\begin_layout Itemize
|
2834
|
+
|
2835
|
+
\family typewriter
|
2836
|
+
#Marking
|
2837
|
+
\family default
|
2838
|
+
,
|
2839
|
+
\family typewriter
|
2840
|
+
#Firing
|
2841
|
+
\family default
|
2842
|
+
,
|
2843
|
+
\family typewriter
|
2844
|
+
#Flux
|
2845
|
+
\family default
|
2846
|
+
,
|
2847
|
+
\family typewriter
|
2848
|
+
#Gradient
|
2849
|
+
\family default
|
2850
|
+
,
|
2851
|
+
\family typewriter
|
2852
|
+
#Delta
|
2853
|
+
\family default
|
2854
|
+
,
|
2855
|
+
\family typewriter
|
2856
|
+
#Assignment
|
2857
|
+
\family default
|
2858
|
+
– these public class methods defined on a PS of Feature returns the dependent
|
2859
|
+
parametrized subclasses for the classes of the same name (
|
2860
|
+
\family typewriter
|
2861
|
+
Feature::Marking
|
2862
|
+
\family default
|
2863
|
+
,
|
2864
|
+
\family typewriter
|
2865
|
+
Feature::Firing
|
2866
|
+
\family default
|
2867
|
+
, etc.)
|
2868
|
+
\end_layout
|
2869
|
+
|
2870
|
+
\begin_layout Standard
|
2871
|
+
Instance methods are defined inside these specialized feature subclasses,
|
2872
|
+
such as:
|
2873
|
+
\end_layout
|
2874
|
+
|
2875
|
+
\begin_layout Itemize
|
2876
|
+
|
2877
|
+
\family typewriter
|
2878
|
+
#extract_from
|
2879
|
+
\family default
|
2880
|
+
– extracts the receiver feature from the target object, returning the feature's
|
2881
|
+
value.
|
2882
|
+
\end_layout
|
2883
|
+
|
2884
|
+
\begin_layout Itemize
|
2885
|
+
|
2886
|
+
\family typewriter
|
2887
|
+
#type
|
2888
|
+
\family default
|
2889
|
+
– feature type
|
2890
|
+
\end_layout
|
2891
|
+
|
2892
|
+
\begin_layout Itemize
|
2893
|
+
|
2894
|
+
\family typewriter
|
2895
|
+
#label
|
2896
|
+
\family default
|
2897
|
+
– feature label (for use in graphics etc.)
|
2898
|
+
\end_layout
|
2899
|
+
|
2900
|
+
\begin_layout Part*
|
2901
|
+
|
2902
|
+
\family typewriter
|
2903
|
+
Features
|
2904
|
+
\family default
|
2905
|
+
class – feature set
|
2906
|
+
\end_layout
|
2907
|
+
|
2908
|
+
\begin_layout Standard
|
2909
|
+
A collection of features is called a feature set.
|
2910
|
+
Measurement performed for a particular feature set results in a record.
|
2911
|
+
In
|
2912
|
+
\family typewriter
|
2913
|
+
YPetri
|
2914
|
+
\family default
|
2915
|
+
,
|
2916
|
+
\family typewriter
|
2917
|
+
Net::State::Features
|
2918
|
+
\family default
|
2919
|
+
is a subclass of
|
2920
|
+
\family typewriter
|
2921
|
+
Array
|
2922
|
+
\family default
|
2923
|
+
, representing an array of features.
|
2924
|
+
Originally, it was named
|
2925
|
+
\family typewriter
|
2926
|
+
FeatureSet
|
2927
|
+
\family default
|
2928
|
+
, but
|
2929
|
+
\family typewriter
|
2930
|
+
Features
|
2931
|
+
\family default
|
2932
|
+
is shorter.
|
2933
|
+
It is used as a PS dependent on a
|
2934
|
+
\family typewriter
|
2935
|
+
State
|
2936
|
+
\family default
|
2937
|
+
PS (
|
2938
|
+
\emph on
|
2939
|
+
not
|
2940
|
+
\emph default
|
2941
|
+
on a
|
2942
|
+
\family typewriter
|
2943
|
+
State
|
2944
|
+
\family default
|
2945
|
+
instance).
|
2946
|
+
It's owning
|
2947
|
+
\family typewriter
|
2948
|
+
State
|
2949
|
+
\family default
|
2950
|
+
PS can be accessed via
|
2951
|
+
\family typewriter
|
2952
|
+
#State
|
2953
|
+
\family default
|
2954
|
+
class method.
|
2955
|
+
Such
|
2956
|
+
\family typewriter
|
2957
|
+
Features
|
2958
|
+
\family default
|
2959
|
+
PS in turn owns subclasses of
|
2960
|
+
\family typewriter
|
2961
|
+
Net::State::Features::Record
|
2962
|
+
\family default
|
2963
|
+
and
|
2964
|
+
\family typewriter
|
2965
|
+
Net::Dataset
|
2966
|
+
\family default
|
2967
|
+
, which can be accessed via
|
2968
|
+
\family typewriter
|
2969
|
+
#Record
|
2970
|
+
\family default
|
2971
|
+
and
|
2972
|
+
\family typewriter
|
2973
|
+
#Dataset
|
2974
|
+
\family default
|
2975
|
+
class methods.
|
2976
|
+
Other class methods include:
|
2977
|
+
\end_layout
|
2978
|
+
|
2979
|
+
\begin_layout Itemize
|
2980
|
+
|
2981
|
+
\family typewriter
|
2982
|
+
#Marking
|
2983
|
+
\family default
|
2984
|
+
,
|
2985
|
+
\family typewriter
|
2986
|
+
#Firing
|
2987
|
+
\family default
|
2988
|
+
,
|
2989
|
+
\family typewriter
|
2990
|
+
#Flux
|
2991
|
+
\family default
|
2992
|
+
,
|
2993
|
+
\family typewriter
|
2994
|
+
#Assignment
|
2995
|
+
\family default
|
2996
|
+
– constructors of a set of marking features, accepting single array argument.
|
2997
|
+
\end_layout
|
2998
|
+
|
2999
|
+
\begin_layout Itemize
|
3000
|
+
|
3001
|
+
\family typewriter
|
3002
|
+
#marking
|
3003
|
+
\family default
|
3004
|
+
,
|
3005
|
+
\family typewriter
|
3006
|
+
#firing
|
3007
|
+
\family default
|
3008
|
+
,
|
3009
|
+
\family typewriter
|
3010
|
+
#flux
|
3011
|
+
\family default
|
3012
|
+
,
|
3013
|
+
\family typewriter
|
3014
|
+
#assignment
|
3015
|
+
\family default
|
3016
|
+
– versions of the above constructors, that accept any number of arguments,
|
3017
|
+
and return full corresponding feature sets if no arguments are given.
|
3018
|
+
\end_layout
|
3019
|
+
|
3020
|
+
\begin_layout Itemize
|
3021
|
+
|
3022
|
+
\family typewriter
|
3023
|
+
#Gradient
|
3024
|
+
\family default
|
3025
|
+
– constructor of a set of gradient features, accepting an array and an
|
3026
|
+
optional :transitions named argument.
|
3027
|
+
\end_layout
|
3028
|
+
|
3029
|
+
\begin_layout Itemize
|
3030
|
+
|
3031
|
+
\family typewriter
|
3032
|
+
#gradient
|
3033
|
+
\family default
|
3034
|
+
– version of the above constructor accepting any number of ordered arguments,
|
3035
|
+
and returning full gradient feature set if no ordered arguments are given.
|
3036
|
+
\end_layout
|
3037
|
+
|
3038
|
+
\begin_layout Itemize
|
3039
|
+
|
3040
|
+
\family typewriter
|
3041
|
+
#Delta
|
3042
|
+
\family default
|
3043
|
+
– constructor of a set of delta features, accepting an array and an optional
|
3044
|
+
:transitions named argument.
|
3045
|
+
\end_layout
|
3046
|
+
|
3047
|
+
\begin_layout Itemize
|
3048
|
+
|
3049
|
+
\family typewriter
|
3050
|
+
#delta
|
3051
|
+
\family default
|
3052
|
+
– version of the above constructor accepting any number of ordered arguments,
|
3053
|
+
and returning full delta feature set if no ordered arguments are given.
|
3054
|
+
\end_layout
|
3055
|
+
|
3056
|
+
\begin_layout Itemize
|
3057
|
+
|
3058
|
+
\family typewriter
|
3059
|
+
#[]
|
3060
|
+
\family default
|
3061
|
+
– constructor that takes either an arbitrary number of ordered arguments,
|
3062
|
+
or a field of named arguments (
|
3063
|
+
\family typewriter
|
3064
|
+
:marking
|
3065
|
+
\family default
|
3066
|
+
,
|
3067
|
+
\family typewriter
|
3068
|
+
:firing
|
3069
|
+
\family default
|
3070
|
+
,
|
3071
|
+
\family typewriter
|
3072
|
+
:gradient
|
3073
|
+
\family default
|
3074
|
+
,
|
3075
|
+
\family typewriter
|
3076
|
+
:flux
|
3077
|
+
\family default
|
3078
|
+
,
|
3079
|
+
\family typewriter
|
3080
|
+
:delta
|
3081
|
+
\family default
|
3082
|
+
,
|
3083
|
+
\family typewriter
|
3084
|
+
:assignment
|
3085
|
+
\family default
|
3086
|
+
), identifying a (possibly) mixed set of features.
|
3087
|
+
\end_layout
|
3088
|
+
|
3089
|
+
\begin_layout Standard
|
3090
|
+
Furthermore, class method
|
3091
|
+
\family typewriter
|
3092
|
+
#new
|
3093
|
+
\family default
|
3094
|
+
is tweaked to make the returned instances own a PS of
|
3095
|
+
\family typewriter
|
3096
|
+
Record
|
3097
|
+
\family default
|
3098
|
+
and a PS of
|
3099
|
+
\family typewriter
|
3100
|
+
DataSet
|
3101
|
+
\family default
|
3102
|
+
|
3103
|
+
\emph on
|
3104
|
+
double parametrized
|
3105
|
+
\emph default
|
3106
|
+
by the instance.
|
3107
|
+
Therefore, also instance methods include:
|
3108
|
+
\end_layout
|
3109
|
+
|
3110
|
+
\begin_layout Itemize
|
3111
|
+
|
3112
|
+
\family typewriter
|
3113
|
+
#Record
|
3114
|
+
\family default
|
3115
|
+
– a PS of
|
3116
|
+
\family typewriter
|
3117
|
+
Features.Record
|
3118
|
+
\family default
|
3119
|
+
PS double parametrized by the receiver.
|
3120
|
+
\end_layout
|
3121
|
+
|
3122
|
+
\begin_layout Itemize
|
3123
|
+
|
3124
|
+
\family typewriter
|
3125
|
+
#DataSet
|
3126
|
+
\family default
|
3127
|
+
– a PS of
|
3128
|
+
\family typewriter
|
3129
|
+
Features.DataSet
|
3130
|
+
\family default
|
3131
|
+
double parametrized by the receiver.
|
3132
|
+
\end_layout
|
3133
|
+
|
3134
|
+
\begin_layout Standard
|
3135
|
+
Other instance methods are:
|
3136
|
+
\end_layout
|
3137
|
+
|
3138
|
+
\begin_layout Itemize
|
3139
|
+
|
3140
|
+
\family typewriter
|
3141
|
+
#load
|
3142
|
+
\family default
|
3143
|
+
– delegated to the
|
3144
|
+
\family typewriter
|
3145
|
+
Record
|
3146
|
+
\family default
|
3147
|
+
PS owned by the instance.
|
3148
|
+
\end_layout
|
3149
|
+
|
3150
|
+
\begin_layout Itemize
|
3151
|
+
|
3152
|
+
\family typewriter
|
3153
|
+
#extract_from
|
3154
|
+
\family default
|
3155
|
+
– extracts a feature set from the target object, returning a record.
|
3156
|
+
\end_layout
|
3157
|
+
|
3158
|
+
\begin_layout Itemize
|
3159
|
+
|
3160
|
+
\family typewriter
|
3161
|
+
#Record
|
3162
|
+
\family default
|
3163
|
+
alias
|
3164
|
+
\family typewriter
|
3165
|
+
#load
|
3166
|
+
\family default
|
3167
|
+
– constructs an instance from an array of values.
|
3168
|
+
The values must corresponds to the receiver feature set.
|
3169
|
+
\end_layout
|
3170
|
+
|
3171
|
+
\begin_layout Itemize
|
3172
|
+
|
3173
|
+
\family typewriter
|
3174
|
+
#+
|
3175
|
+
\family default
|
3176
|
+
,
|
3177
|
+
\family typewriter
|
3178
|
+
#-
|
3179
|
+
\family default
|
3180
|
+
,
|
3181
|
+
\family typewriter
|
3182
|
+
#*
|
3183
|
+
\family default
|
3184
|
+
– addition, subtraction,
|
3185
|
+
\family typewriter
|
3186
|
+
Array
|
3187
|
+
\family default
|
3188
|
+
-like multiplication for feature sets.
|
3189
|
+
\end_layout
|
3190
|
+
|
3191
|
+
\begin_layout Itemize
|
3192
|
+
|
3193
|
+
\family typewriter
|
3194
|
+
#labels
|
3195
|
+
\family default
|
3196
|
+
– array of feature labels.
|
3197
|
+
\end_layout
|
3198
|
+
|
3199
|
+
\begin_layout Itemize
|
3200
|
+
|
3201
|
+
\family typewriter
|
3202
|
+
#reduce_features
|
3203
|
+
\family default
|
3204
|
+
– expects an argument identifying a set of features that is a subset of
|
3205
|
+
the receiver feature set, and returns that feature subset.
|
3206
|
+
\end_layout
|
3207
|
+
|
3208
|
+
\begin_layout Itemize
|
3209
|
+
|
3210
|
+
\family typewriter
|
3211
|
+
#Marking
|
3212
|
+
\family default
|
3213
|
+
,
|
3214
|
+
\family typewriter
|
3215
|
+
#Firing
|
3216
|
+
\family default
|
3217
|
+
,
|
3218
|
+
\family typewriter
|
3219
|
+
#Flux
|
3220
|
+
\family default
|
3221
|
+
,
|
3222
|
+
\family typewriter
|
3223
|
+
#Assignment
|
3224
|
+
\family default
|
3225
|
+
– selectors of a subset of the receiver feature set, accepting single array
|
3226
|
+
argument.
|
3227
|
+
\end_layout
|
3228
|
+
|
3229
|
+
\begin_layout Itemize
|
3230
|
+
|
3231
|
+
\family typewriter
|
3232
|
+
#marking
|
3233
|
+
\family default
|
3234
|
+
,
|
3235
|
+
\family typewriter
|
3236
|
+
#firing
|
3237
|
+
\family default
|
3238
|
+
,
|
3239
|
+
\family typewriter
|
3240
|
+
#flux
|
3241
|
+
\family default
|
3242
|
+
,
|
3243
|
+
\family typewriter
|
3244
|
+
#assignment
|
3245
|
+
\family default
|
3246
|
+
– versions of the above selectors, that accept any number of arguments,
|
3247
|
+
and return full corresponding subsets if no arguments given.
|
3248
|
+
\end_layout
|
3249
|
+
|
3250
|
+
\begin_layout Itemize
|
3251
|
+
|
3252
|
+
\family typewriter
|
3253
|
+
#Gradient
|
3254
|
+
\family default
|
3255
|
+
,
|
3256
|
+
\family typewriter
|
3257
|
+
#Delta
|
3258
|
+
\family default
|
3259
|
+
,
|
3260
|
+
\family typewriter
|
3261
|
+
#gradient
|
3262
|
+
\family default
|
3263
|
+
,
|
3264
|
+
\family typewriter
|
3265
|
+
#delta
|
3266
|
+
\family default
|
3267
|
+
– selectors analogical to the above mentioned, but also accepting an optional
|
3268
|
+
named argument
|
3269
|
+
\family typewriter
|
3270
|
+
:transitions
|
3271
|
+
\family default
|
3272
|
+
qualifying the features to select.
|
3273
|
+
\end_layout
|
3274
|
+
|
3275
|
+
\begin_layout Standard
|
3276
|
+
Furthermore,
|
3277
|
+
\family typewriter
|
3278
|
+
:Record
|
3279
|
+
\family default
|
3280
|
+
message is overloaded in such way, that when sent with an argument, it
|
3281
|
+
acts as an alias of
|
3282
|
+
\family typewriter
|
3283
|
+
#load
|
3284
|
+
\family default
|
3285
|
+
record constructor.
|
3286
|
+
\end_layout
|
3287
|
+
|
3288
|
+
\begin_layout Part*
|
3289
|
+
|
3290
|
+
\family typewriter
|
3291
|
+
Record
|
3292
|
+
\family default
|
3293
|
+
class
|
3294
|
+
\end_layout
|
3295
|
+
|
3296
|
+
\begin_layout Standard
|
3297
|
+
A record is basically an array, that remembers the features to which its
|
3298
|
+
values correspond.
|
3299
|
+
|
3300
|
+
\family typewriter
|
3301
|
+
Net::State::Features::Record
|
3302
|
+
\family default
|
3303
|
+
class is typically used as doubly parametrized PS, dependent firstly on
|
3304
|
+
a
|
3305
|
+
\family typewriter
|
3306
|
+
Features
|
3307
|
+
\family default
|
3308
|
+
PS, and then on its particular instance.
|
3309
|
+
The owning feature set is accessible via
|
3310
|
+
\family typewriter
|
3311
|
+
#features
|
3312
|
+
\family default
|
3313
|
+
class and instance method.
|
3314
|
+
Other class methods include:
|
3315
|
+
\end_layout
|
3316
|
+
|
3317
|
+
\begin_layout Itemize
|
3318
|
+
|
3319
|
+
\family typewriter
|
3320
|
+
#load
|
3321
|
+
\family default
|
3322
|
+
– constructs a record from a given collection of values.
|
3323
|
+
\end_layout
|
3324
|
+
|
3325
|
+
\begin_layout Standard
|
3326
|
+
Other instance methods include:
|
3327
|
+
\end_layout
|
3328
|
+
|
3329
|
+
\begin_layout Itemize
|
3330
|
+
|
3331
|
+
\family typewriter
|
3332
|
+
#dump
|
3333
|
+
\family default
|
3334
|
+
– converts the record to a plain array, with optional :precision named
|
3335
|
+
argument.
|
3336
|
+
\end_layout
|
3337
|
+
|
3338
|
+
\begin_layout Itemize
|
3339
|
+
|
3340
|
+
\family typewriter
|
3341
|
+
#print
|
3342
|
+
\family default
|
3343
|
+
– pretty prints the record with feature names.
|
3344
|
+
\end_layout
|
3345
|
+
|
3346
|
+
\begin_layout Itemize
|
3347
|
+
|
3348
|
+
\family typewriter
|
3349
|
+
#fetch
|
3350
|
+
\family default
|
3351
|
+
– returns a feature.
|
3352
|
+
\end_layout
|
3353
|
+
|
3354
|
+
\begin_layout Itemize
|
3355
|
+
|
3356
|
+
\family typewriter
|
3357
|
+
#state
|
3358
|
+
\family default
|
3359
|
+
– constructs a state, using the receiver record, and a set of complementary
|
3360
|
+
marking clamps supplied in the argument.
|
3361
|
+
\end_layout
|
3362
|
+
|
3363
|
+
\begin_layout Itemize
|
3364
|
+
|
3365
|
+
\family typewriter
|
3366
|
+
#reconstruct
|
3367
|
+
\family default
|
3368
|
+
– reconstructs a simulation from the receiver record.
|
3369
|
+
\end_layout
|
3370
|
+
|
3371
|
+
\begin_layout Itemize
|
3372
|
+
|
3373
|
+
\family typewriter
|
3374
|
+
#Marking
|
3375
|
+
\family default
|
3376
|
+
,
|
3377
|
+
\family typewriter
|
3378
|
+
#Firing
|
3379
|
+
\family default
|
3380
|
+
,
|
3381
|
+
\family typewriter
|
3382
|
+
#Flux
|
3383
|
+
\family default
|
3384
|
+
,
|
3385
|
+
\family typewriter
|
3386
|
+
#Assignment
|
3387
|
+
\family default
|
3388
|
+
– selects the values of the specified feature subsets from the receiver
|
3389
|
+
record.
|
3390
|
+
Expects a single array-type argument.
|
3391
|
+
\end_layout
|
3392
|
+
|
3393
|
+
\begin_layout Itemize
|
3394
|
+
|
3395
|
+
\family typewriter
|
3396
|
+
#marking
|
3397
|
+
\family default
|
3398
|
+
,
|
3399
|
+
\family typewriter
|
3400
|
+
#firing
|
3401
|
+
\family default
|
3402
|
+
,
|
3403
|
+
\family typewriter
|
3404
|
+
#flux
|
3405
|
+
\family default
|
3406
|
+
,
|
3407
|
+
\family typewriter
|
3408
|
+
#assignment
|
3409
|
+
\family default
|
3410
|
+
– the versions of the above methods accepting any number of feature-identifying
|
3411
|
+
arguments.
|
3412
|
+
\end_layout
|
3413
|
+
|
3414
|
+
\begin_layout Itemize
|
3415
|
+
|
3416
|
+
\family typewriter
|
3417
|
+
#Gradient
|
3418
|
+
\family default
|
3419
|
+
,
|
3420
|
+
\family typewriter
|
3421
|
+
#Delta
|
3422
|
+
\family default
|
3423
|
+
,
|
3424
|
+
\family typewriter
|
3425
|
+
#gradient
|
3426
|
+
\family default
|
3427
|
+
,
|
3428
|
+
\family typewriter
|
3429
|
+
#delta
|
3430
|
+
\family default
|
3431
|
+
– selectors analogical to the above mentioned, but also accepting an optional
|
3432
|
+
named argument
|
3433
|
+
\family typewriter
|
3434
|
+
:transitions
|
3435
|
+
\family default
|
3436
|
+
qualifying the features to select.
|
3437
|
+
\end_layout
|
3438
|
+
|
3439
|
+
\begin_layout Itemize
|
3440
|
+
|
3441
|
+
\family typewriter
|
3442
|
+
#euclidean_distance
|
3443
|
+
\family default
|
3444
|
+
– takes another record of the same feature set as an argument and computes
|
3445
|
+
the Euclidean distance to it.
|
3446
|
+
\end_layout
|
3447
|
+
|
3448
|
+
\begin_layout Part*
|
3449
|
+
|
3450
|
+
\family typewriter
|
3451
|
+
DataSet
|
3452
|
+
\family default
|
3453
|
+
class
|
3454
|
+
\end_layout
|
3455
|
+
|
3456
|
+
\begin_layout Standard
|
3457
|
+
|
3458
|
+
\family typewriter
|
3459
|
+
YPetri::Net::DataSet
|
3460
|
+
\family default
|
3461
|
+
represents a sequence of records sampled from the underlying net using
|
3462
|
+
certain feature set.
|
3463
|
+
It is a subclass of
|
3464
|
+
\family typewriter
|
3465
|
+
Hash
|
3466
|
+
\family default
|
3467
|
+
, whose keys represent sampling events, and whose values are plain arrays,
|
3468
|
+
from which corresponding
|
3469
|
+
\family typewriter
|
3470
|
+
Record
|
3471
|
+
\family default
|
3472
|
+
instances can be fully reconstructed (via
|
3473
|
+
\family typewriter
|
3474
|
+
Record.load
|
3475
|
+
\family default
|
3476
|
+
method).
|
3477
|
+
It is typically used as doubly parametrized PS, dependent firstly on a
|
3478
|
+
|
3479
|
+
\family typewriter
|
3480
|
+
Features
|
3481
|
+
\family default
|
3482
|
+
PS, and then on its particular instance.
|
3483
|
+
The owning feature set is accessible via
|
3484
|
+
\family typewriter
|
3485
|
+
#features
|
3486
|
+
\family default
|
3487
|
+
class and instance method.
|
3488
|
+
Other class methods include:
|
3489
|
+
\end_layout
|
3490
|
+
|
3491
|
+
\begin_layout Itemize
|
3492
|
+
|
3493
|
+
\family typewriter
|
3494
|
+
#events
|
3495
|
+
\family default
|
3496
|
+
– alias for
|
3497
|
+
\family typewriter
|
3498
|
+
Hash#keys
|
3499
|
+
\family default
|
3500
|
+
– dataset keys represent sampling events.
|
3501
|
+
\end_layout
|
3502
|
+
|
3503
|
+
\begin_layout Itemize
|
3504
|
+
|
3505
|
+
\family typewriter
|
3506
|
+
#reduce_features
|
3507
|
+
\family default
|
3508
|
+
– selects certain columns (features) of a dataset.
|
3509
|
+
\end_layout
|
3510
|
+
|
3511
|
+
\begin_layout Itemize
|
3512
|
+
|
3513
|
+
\family typewriter
|
3514
|
+
#timed?
|
3515
|
+
\family default
|
3516
|
+
– inquirer whether the dataset is timed
|
3517
|
+
\end_layout
|
3518
|
+
|
3519
|
+
\begin_layout Itemize
|
3520
|
+
|
3521
|
+
\family typewriter
|
3522
|
+
#record
|
3523
|
+
\family default
|
3524
|
+
– reconstructs the
|
3525
|
+
\family typewriter
|
3526
|
+
Record
|
3527
|
+
\family default
|
3528
|
+
instance corresponding to the given event.
|
3529
|
+
\end_layout
|
3530
|
+
|
3531
|
+
\begin_layout Itemize
|
3532
|
+
|
3533
|
+
\family typewriter
|
3534
|
+
#floor
|
3535
|
+
\family default
|
3536
|
+
– the nearest event smaller or equal to the argument.
|
3537
|
+
\end_layout
|
3538
|
+
|
3539
|
+
\begin_layout Itemize
|
3540
|
+
|
3541
|
+
\family typewriter
|
3542
|
+
#ceiling
|
3543
|
+
\family default
|
3544
|
+
– the nearest event greater or equal than the argument.
|
3545
|
+
\end_layout
|
3546
|
+
|
3547
|
+
\begin_layout Itemize
|
3548
|
+
|
3549
|
+
\family typewriter
|
3550
|
+
#records
|
3551
|
+
\family default
|
3552
|
+
– returns an array of
|
3553
|
+
\family typewriter
|
3554
|
+
Record
|
3555
|
+
\family default
|
3556
|
+
instances revived from the receiver's values.
|
3557
|
+
\end_layout
|
3558
|
+
|
3559
|
+
\begin_layout Itemize
|
3560
|
+
|
3561
|
+
\family typewriter
|
3562
|
+
#reconstruct
|
3563
|
+
\family default
|
3564
|
+
– recreates the simulation at the given event.
|
3565
|
+
\end_layout
|
3566
|
+
|
3567
|
+
\begin_layout Itemize
|
3568
|
+
|
3569
|
+
\family typewriter
|
3570
|
+
#interpolate
|
3571
|
+
\family default
|
3572
|
+
– interpolates the recording at the given point (event).
|
3573
|
+
Return value is the Record class instance.
|
3574
|
+
\end_layout
|
3575
|
+
|
3576
|
+
\begin_layout Itemize
|
3577
|
+
|
3578
|
+
\family typewriter
|
3579
|
+
#resample
|
3580
|
+
\family default
|
3581
|
+
– resamples the recording.
|
3582
|
+
\end_layout
|
3583
|
+
|
3584
|
+
\begin_layout Itemize
|
3585
|
+
|
3586
|
+
\family typewriter
|
3587
|
+
#distance
|
3588
|
+
\family default
|
3589
|
+
– computes the distance to another dataset.
|
3590
|
+
\end_layout
|
3591
|
+
|
3592
|
+
\begin_layout Itemize
|
3593
|
+
|
3594
|
+
\family typewriter
|
3595
|
+
#series
|
3596
|
+
\family default
|
3597
|
+
– returns the data series for the specified features.
|
3598
|
+
\end_layout
|
3599
|
+
|
3600
|
+
\begin_layout Itemize
|
3601
|
+
|
3602
|
+
\family typewriter
|
3603
|
+
#reduce_features
|
3604
|
+
\family default
|
3605
|
+
– reduces the dataset into another dataset with a different set of features.
|
3606
|
+
Reduction to a subset of features is always possible.
|
3607
|
+
Reduction to a set of features that is not a subset of the receiver's set
|
3608
|
+
of features is only possible if the former can be inferred from the latter.
|
3609
|
+
Generally, this is the case if net state can be reconstructed from a receiver's
|
3610
|
+
record.
|
3611
|
+
From this net state, the desired new feature set is then extracted.
|
3612
|
+
\end_layout
|
3613
|
+
|
3614
|
+
\begin_layout Itemize
|
3615
|
+
|
3616
|
+
\family typewriter
|
3617
|
+
#Marking
|
3618
|
+
\family default
|
3619
|
+
,
|
3620
|
+
\family typewriter
|
3621
|
+
#Firing
|
3622
|
+
\family default
|
3623
|
+
,
|
3624
|
+
\family typewriter
|
3625
|
+
#Flux
|
3626
|
+
\family default
|
3627
|
+
,
|
3628
|
+
\family typewriter
|
3629
|
+
#Assignment
|
3630
|
+
\family default
|
3631
|
+
– selects the values of the specified feature subsets from the receiver
|
3632
|
+
record.
|
3633
|
+
Expects a single array-type argument.
|
3634
|
+
\end_layout
|
3635
|
+
|
3636
|
+
\begin_layout Itemize
|
3637
|
+
|
3638
|
+
\family typewriter
|
3639
|
+
#marking
|
3640
|
+
\family default
|
3641
|
+
,
|
3642
|
+
\family typewriter
|
3643
|
+
#firing
|
3644
|
+
\family default
|
3645
|
+
,
|
3646
|
+
\family typewriter
|
3647
|
+
#flux
|
3648
|
+
\family default
|
3649
|
+
,
|
3650
|
+
\family typewriter
|
3651
|
+
#assignment
|
3652
|
+
\family default
|
3653
|
+
– the versions of the above methods accepting any number of feature-identifying
|
3654
|
+
arguments.
|
3655
|
+
\end_layout
|
3656
|
+
|
3657
|
+
\begin_layout Itemize
|
3658
|
+
|
3659
|
+
\family typewriter
|
3660
|
+
#Gradient
|
3661
|
+
\family default
|
3662
|
+
,
|
3663
|
+
\family typewriter
|
3664
|
+
#Delta
|
3665
|
+
\family default
|
3666
|
+
,
|
3667
|
+
\family typewriter
|
3668
|
+
#gradient
|
3669
|
+
\family default
|
3670
|
+
,
|
3671
|
+
\family typewriter
|
3672
|
+
#delta
|
3673
|
+
\family default
|
3674
|
+
– selectors analogical to the above mentioned, but also accepting an optional
|
3675
|
+
named argument
|
3676
|
+
\family typewriter
|
3677
|
+
:transitions
|
3678
|
+
\family default
|
3679
|
+
qualifying the features to select.
|
3680
|
+
\end_layout
|
3681
|
+
|
3682
|
+
\begin_layout Itemize
|
3683
|
+
|
3684
|
+
\family typewriter
|
3685
|
+
#to_csv
|
3686
|
+
\family default
|
3687
|
+
– outputs the dataset in the CSV format.
|
3688
|
+
\end_layout
|
3689
|
+
|
3690
|
+
\begin_layout Itemize
|
3691
|
+
|
3692
|
+
\family typewriter
|
3693
|
+
#plot
|
3694
|
+
\family default
|
3695
|
+
– plots the dataset.
|
3696
|
+
\end_layout
|
3697
|
+
|
3698
|
+
\begin_layout Part*
|
3699
|
+
|
3700
|
+
\family typewriter
|
3701
|
+
Agent
|
3702
|
+
\family default
|
3703
|
+
class
|
3704
|
+
\end_layout
|
3705
|
+
|
3706
|
+
\begin_layout Standard
|
3707
|
+
|
3708
|
+
\family typewriter
|
3709
|
+
YPetri::Agent
|
3710
|
+
\family default
|
3711
|
+
/
|
3712
|
+
\family typewriter
|
3713
|
+
YNelson::Agent
|
3714
|
+
\family default
|
3715
|
+
are dumb agents that represent and assist the user.
|
3716
|
+
Originally, this class was named
|
3717
|
+
\family typewriter
|
3718
|
+
Manipulator
|
3719
|
+
\family default
|
3720
|
+
, but
|
3721
|
+
\family typewriter
|
3722
|
+
Agent
|
3723
|
+
\family default
|
3724
|
+
is shorter.
|
3725
|
+
|
3726
|
+
\family typewriter
|
3727
|
+
Agent
|
3728
|
+
\family default
|
3729
|
+
does provide textual user interface, but it does not completely encapsulate
|
3730
|
+
|
3731
|
+
\family typewriter
|
3732
|
+
YPetri
|
3733
|
+
\family default
|
3734
|
+
(
|
3735
|
+
\family typewriter
|
3736
|
+
YNelson
|
3737
|
+
\family default
|
3738
|
+
) interface.
|
3739
|
+
Rather, it defines a number of top-level DSL commands (methods) available
|
3740
|
+
upon calling '
|
3741
|
+
\family typewriter
|
3742
|
+
include YPetri
|
3743
|
+
\family default
|
3744
|
+
' / '
|
3745
|
+
\family typewriter
|
3746
|
+
include YNelson
|
3747
|
+
\family default
|
3748
|
+
'.
|
3749
|
+
|
3750
|
+
\family typewriter
|
3751
|
+
Agent
|
3752
|
+
\family default
|
3753
|
+
is not a part of the core object model of
|
3754
|
+
\family typewriter
|
3755
|
+
YPetri
|
3756
|
+
\family default
|
3757
|
+
/
|
3758
|
+
\family typewriter
|
3759
|
+
YNelson
|
3760
|
+
\family default
|
3761
|
+
, and it is hotter than other parts of
|
3762
|
+
\family typewriter
|
3763
|
+
YPetri
|
3764
|
+
\family default
|
3765
|
+
/
|
3766
|
+
\family typewriter
|
3767
|
+
YNelson
|
3768
|
+
\family default
|
3769
|
+
.
|
3770
|
+
For basic use, see the tutorial (
|
3771
|
+
\begin_inset Quotes eld
|
3772
|
+
\end_inset
|
3773
|
+
|
3774
|
+
Introduction to
|
3775
|
+
\family typewriter
|
3776
|
+
YNelson
|
3777
|
+
\family default
|
3778
|
+
|
3779
|
+
\begin_inset Quotes erd
|
3780
|
+
\end_inset
|
3781
|
+
|
3782
|
+
).
|
3783
|
+
For detailed description of
|
3784
|
+
\family typewriter
|
3785
|
+
Agent
|
3786
|
+
\family default
|
3787
|
+
's assets, see the class documentation.
|
3788
|
+
\end_layout
|
3789
|
+
|
3790
|
+
\begin_layout LyX-Code
|
3791
|
+
|
3792
|
+
\end_layout
|
3793
|
+
|
3794
|
+
\begin_layout LyX-Code
|
3795
|
+
\begin_inset CommandInset bibtex
|
3796
|
+
LatexCommand bibtex
|
3797
|
+
bibfiles "/home/boris/b/1num/num,/home/boris/b/2prp/prp,/home/boris/b/5ced/ced"
|
3798
|
+
options "plainnat"
|
3799
|
+
|
3800
|
+
\end_inset
|
3801
|
+
|
3802
|
+
|
3803
|
+
\end_layout
|
3804
|
+
|
3805
|
+
\end_body
|
3806
|
+
\end_document
|