File: NEWS

package info (click to toggle)
maria 1.3.5-2
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 3,980 kB
  • ctags: 5,458
  • sloc: cpp: 43,402; yacc: 8,080; ansic: 436; sh: 404; lisp: 395; makefile: 291; perl: 21
file content (253 lines) | stat: -rw-r--r-- 8,843 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
Maria NEWS -- history of user-visible changes.  29th July 2005
Copyright  2002,2003,2004,2005 Marko Mkel
See the end for copying conditions.

* Maria 1.3.5 is a maintenance release with performance and portability fixes

** Identified performance bottlenecks with OProfile on GNU/Linux x86

*** Wrote non-looping log() functions for systems with 32-bit card_t.
The function is 2 to 3 times faster than the original.  This improvement
may reduce the time for state space exploration by a couple of percent.

*** In interpreter-based operation, dynamic memory management consumes
almost half the execution time.  This is a fundamental problem of the
expression evaluator, which makes extensive use of dynamic memory allocation.

*** In compiler-based operation, decoding and encoding states may consume
80% of the time spent in compiled code, depending on the data types used in
place markings and the number and complexity of the transitions.  This may
amount to 10-20% of the total execution time, depending on the state storage
method and other options chosen.

*** The built-in LTL formula translator has been updated to lbt-1.2.2.

** Portability fixes

*** Replaced the non-standard slist template with std::list.

** Bug fixes

*** The output of error traces in graphless search leaked memory.

*** Memory could be leaked when an error was detected during
transition instance analysis.

*** Transition identifiers were improperly encoded by generated C code
in modular state space exploration.

*** The output of "dump" differed from "visual dump".
Thanks to Charles Lakos for pointing out the problem.

* Maria 1.3.4 is a maintenance release with bug fixes
mainly for modular state space exploration

** New features

*** The C code generator supports modular nets.

*** The graphical browser (maria-vis) supports multiple modular state spaces.

** Bug fixes

*** Clearing the common subexpression cache caused problems with modular nets.
It is not cleared any more.

*** The root node of B-trees was split incorrectly when USE_MMAP is disabled.

*** The lexical order of marking expressions was not total.  Now it should be.

*** "reject" states will not be expanded by default.
In graph-based analysis, the "succ" command will still expand them.

*** If an error occurs in a prioritised transition, transitions with other
priority levels will not be explored.  In other words, the faulty transition
instance is treated as if it were enabled, although it does not generate any
successor state.

*** LSTS output is now disabled for modular state spaces.

*** Modular nets are implicitly flattened in the following circumstances:
**** non-modular state space exploration
**** unfolding
**** pretty-printing ("dump" command)

*** In modular nets, the synchronisation transition can now have input
and output arcs and define functions.  Thanks to Charles Lakos for
contributing an elegant patch.

*** Transitions in modules can now synchronise on multiple labels.

*** Graph files can now be reopened also when memory-mapped I/O is not used.
In other words, the -g option now works on Win32.

* Maria 1.3.3 is a maintenance release mainly with improved portability.

** Bug fixes

*** Possible memory leak in the computation of strongly connected components

** New targets
*** Debian GNU/Linux on Digital Alpha
*** Debian GNU/Linux on HP-PA
*** IBM AIX 4.3.2 with gcc 3.2.1 (use Makefile.BSD)

* Maria 1.3.2 is a maintenance release mainly with Win32 improvements.

** New features

*** The [VISUAL] DUMPGRAPH command exports the reachability graph.

** Bug fixes

*** The -Y option fix in Maria 1.3.1 introduced another bug.  It is now fixed.

** Win32 inter-process communication bug work-arounds

*** lbt 1.2.1 is built-in when the compile-time option BUILTIN_LTL is enabled.

*** The "visual" commands write the graphs to a file "maria-vis.out".

* Maria 1.3.1 is a maintenance release mainly with bug fixes and optimisations.

** Optimisations

*** The generated of the C code was slightly optimised.

*** Multi-set operations (SetExpression) are simplified and canonised.

** New targets
*** HP-UX 11.22 with aCC: HP ANSI C++/C B3910B A.05.36 [May 20 2002]
*** FreeBSD, NetBSD, OpenBSD with gcc 2.95 (Makefile.BSD)

** Bug fixes

*** Modular analysis did not really work.  Now the supplied "modular.pn" works.

*** Comparisons "A subset B" with A==empty did not always work.

*** Multi-set operations can now be used on input arcs.

*** The -Y option now produces correct arc labels for reachability graphs.

*** Memory leaks in transition fusion code were eliminated.

* Maria 1.3

** New features

*** Automatic interruption at too many errors (-t, --tolerance=NUMBER)

*** Modular analysis (-R, --modular) of nested SUBNETs reduces state spaces.
The synchronisation labels for transitions are indicated with
transition fusion.  Each transition participating in a synchronisation
must "call" the "label" transition in its parent net.

** Bug fixes

*** "deadlock true" in an empty net (broken in version 1.1) works again

* Maria 1.2

** New features

*** Added options for transition declarations

**** Constantly disabled transition instances belonging to an ENABLED
set are reported at the end of each state space exploration run.  The
enabledness sets are defined in an analogous way to fairness sets.

**** The HIDE keyword controls the omission of hidden states (-Y).
States that are reached via a hidden transition instance are omitted
from the state space, but safety properties are checked also in such
states.  With some knowledge in the application, this reduction easily
outperforms path compression (-Z).

**** Prioritised transitions can share priority classes

**** Transition fusion eases the modular construction of models

*** Rewritten interfaces for generating state spaces
**** All reductions can also be applied to reachability graphs,
and with some caution to general LTL model checking.
**** The executable has become smaller.

** Bug fixes
*** Transitions accept "fatal" and "undefined" in gate expressions
*** Multi-set quantification conditions are now allocated properly

* Maria 1.1

** New features

*** Improved checker for safety properties
**** Properties can be input as finite automata (translated from LTL).
**** Counterexample traces are generated from the initial state to the error.
**** Lossless storage of the reachable state set (option -L) avoids omissions.
**** Path compression reduction (option -Z) minimises the memory usage.
**** Works on multi-processor computers (-j) and TCP/IP networks (-k).

*** Statistics for encoded state vector sizes are maintained and reported.

*** The multiplicity mapping operation for multi-sets was made more generic.

** Bug fixes
*** C code generation
**** The generated code was made compatible with the IRIX and Darwin.
**** The translation errors for multi-set mappings were corrected.
*** The n-ary selection operator ?: now handles multi-sets.

** The following targets have been successfully tested:
*** Apple Darwin 5.3 (Mac OS X 10.1)
*** Digital UNIX 4.0F (cxx V6.3-010)
*** GNU/Linux on IA-32 (GCC 2.95.4 and GCC 3.0.4)
*** SGI IRIX 6.5
**** GCC (32-bit)
**** native CC -n32 or CC -64
*** SunOS 5.x (Solaris)
**** GCC (32-bit)
**** Sun WorkShop 6 update 2 C 5.3 2001/05/15 for sparcv9 (64-bit)
*** Win32 (GCC 2.95.2 for mingw or Cygwin)

* Maria 1.0.1 is a maintenance release mainly with bug fixes and optimisations.

** Additions to the query language
*** The PRED! and SUCC! commands list all predecessors or successors of a state
until a branch is found, making it easier to follow deterministic behaviour.
*** Anonymous transitions can be fired in the reachability graph.

** Bug fixes
*** States may now have more than 65535 successors.
*** Some bugs in the liveness property checker were fixed.
*** Functions can take multi-sets as parameters.

** New targets
*** The Sun compiler is now supported.
*** Preliminary support for SGI IRIX was added.

** Optimisations
*** The computation of strongly connected components was optimised.
*** The liveness property checker was slightly optimised.

* Maria 1.0 was the first official release.


----------------------------------------------------------------------
Copyright information:

Copyright  2002,2003,2004,2005 Marko Mkel

   Permission is granted to anyone to make or distribute verbatim copies
   of this document as received, in any medium, provided that the
   copyright notice and this permission notice are preserved,
   thus giving the recipient permission to redistribute in turn.

   Permission is granted to distribute modified versions
   of this document, or of portions of it,
   under the above conditions, provided also that they
   carry prominent notices stating who last changed them.

Local variables:
mode: outline
paragraph-separate: "[ 	]*$"
end: