aboutsummaryrefslogtreecommitdiff
path: root/gfsm/src
diff options
context:
space:
mode:
Diffstat (limited to 'gfsm/src')
-rw-r--r--gfsm/src/gfsm_automaton-help.pd30
-rw-r--r--gfsm/src/gfsm_markov.pd85
-rw-r--r--gfsm/src/gfsm_state-help.pd45
3 files changed, 82 insertions, 78 deletions
diff --git a/gfsm/src/gfsm_automaton-help.pd b/gfsm/src/gfsm_automaton-help.pd
index 52a2bc8..a26c7fa 100644
--- a/gfsm/src/gfsm_automaton-help.pd
+++ b/gfsm/src/gfsm_automaton-help.pd
@@ -1,4 +1,4 @@
-#N canvas 126 0 479 520 10;
+#N canvas 8 34 479 520 10;
#X text 89 7 gfsm_automaton : weighted finite state machine;
#X text 183 489 Bryan Jurish <moocow@ling.uni-potsdam.de>;
#X text 7 436 SEE ALSO:;
@@ -12,11 +12,6 @@
#X text 7 211 SUBTOPICS:;
#X text 10 114 DESCRIPTION:;
#X text 245 211 GUTS:;
-#X text 28 130 gfsm_automaton objects represent weighted finite state
-machines (acceptors or transducers) -- rooted \, acyclic graphs whose
-edges are labelled with triples (LO \, HI \, WEIGHT) \, where LO and
-HI are alphabet labels (see gfsm_alphabet) \, and WEIGHT is a floating
-point number.;
#X obj 265 272 print fsm-help-out;
#X obj 135 457 gfsm_alphabet;
#N canvas 192 14 651 458 help-automaton-flags 0;
@@ -153,11 +148,11 @@ transducer" format \, regardless of automaton flags or input file content.
#X msg 24 140 concat fsm-help;
#X text 215 141 "concat FSM2" : concatenate with automaton named FSM2
;
-#X text 187 197 "difference FSM2" : remove language of automaton named
+#X text 187 203 "difference FSM2" : remove language of automaton named
FSM2;
-#X text 194 228 "intersect FSM2" : intersect with automaton named FSM2
+#X text 194 235 "intersect FSM2" : intersect with automaton named FSM2
;
-#X text 250 266 "invert" : swap upper and lower labels;
+#X text 250 268 "invert" : swap upper and lower labels;
#X msg 24 302 project 0;
#X msg 24 319 project 1;
#X text 208 298 "project SIDE" : project one label side;
@@ -165,10 +160,10 @@ FSM2;
#X text 328 323 SIDE=1: project upper labels;
#X text 208 348 "product FSM2" : compute Cartesian product with FSM2
;
-#X text 243 407 "reverse" : reverse language of an automaton;
+#X text 243 414 "reverse" : reverse language of an automaton;
#X text 95 6 gfsm_automaton : algebraic operations;
-#X text 229 439 "rmepsilon" : remove epsilon arcs;
-#X text 222 478 "union FSM2" : compute union with automaton FSM2;
+#X text 229 444 "rmepsilon" : remove epsilon arcs;
+#X text 222 480 "union FSM2" : compute union with automaton FSM2;
#X obj 24 505 s fsm-help-in;
#X text 31 551 WARNING: these methods may block for long periods of
time for large automata.;
@@ -178,7 +173,7 @@ time for large automata.;
#X text 229 70 "closure N" : compute N-ary closure;
#X text 215 170 "determinize" : determinize an acceptor;
#X msg 24 383 connect;
-#X text 244 382 "connect" : remove useless states and arcs;
+#X text 244 385 "connect" : remove useless states and arcs;
#X connect 0 0 27 0;
#X connect 1 0 27 0;
#X connect 2 0 27 0;
@@ -336,5 +331,10 @@ package from at&t.;
#X connect 10 0 2 0;
#X connect 15 0 2 0;
#X restore 22 386 pd help-automaton-lookup;
-#X connect 21 0 28 0;
-#X connect 28 0 14 0;
+#X text 28 130 gfsm_automaton objects represent weighted finite state
+machines (acceptors or transducers) -- rooted and possibly cyclic graphs
+whose edges are labelled with triples (LO \, HI \, WEIGHT) \, where
+LO and HI are alphabet labels (see gfsm_alphabet) \, and WEIGHT is
+a floating point number.;
+#X connect 20 0 27 0;
+#X connect 27 0 13 0;
diff --git a/gfsm/src/gfsm_markov.pd b/gfsm/src/gfsm_markov.pd
index fa2ea8b..705e56f 100644
--- a/gfsm/src/gfsm_markov.pd
+++ b/gfsm/src/gfsm_markov.pd
@@ -284,63 +284,62 @@ clear fsm alph state add2;
#X connect 35 0 34 1;
#X connect 36 0 34 1;
#X restore 21 186 pd gfsm_markov_add_guts;
-#N canvas 29 370 662 532 gfsm_markov_next_guts 0;
+#N canvas 48 114 662 532 gfsm_markov_next_guts 0;
#X obj 28 4 r \$0-next;
#X obj 243 464 outlet;
#X obj 28 26 route bang;
-#X obj 167 138 * 1;
-#X obj 28 70 random 131072;
-#X obj 28 91 / 131072;
+#X obj 217 168 * 1;
#X obj 405 461 outlet;
#X obj 101 429 gfsm_alphabet \$1-alph;
#X msg 101 407 char2atom! \$1;
-#X obj 86 225 unpack 0 0 0 0;
+#X obj 70 377 unpack 0 0 0 0;
#X msg 18 411 set \$1;
#X obj 18 432 s \$0-state;
-#X obj 512 461 outlet;
+#X obj 502 461 outlet;
#X obj 263 428 gfsm_alphabet \$1-alph;
#X msg 263 406 char2atom! \$1;
-#X obj 424 101 gfsm_state \$1-fsm 0;
-#X obj 424 20 r \$0-state;
-#X obj 512 150 route bang;
-#X obj 512 172 t b;
-#X obj 424 124 route total_weight arc_gen;
+#X obj 414 234 gfsm_state \$1-fsm 0;
+#X obj 414 20 r \$0-state;
+#X obj 502 283 route bang;
+#X obj 502 305 t b;
+#X obj 414 257 route total_weight arc_gen;
#X obj 28 48 t b;
-#X obj 153 71 t b f;
-#X obj 167 115 f 0;
-#X obj 196 114 t b f;
-#X msg 167 160 arc_gen \$1;
-#X msg 153 91 arc_reset \, total_weight;
-#X obj 153 187 s \$0-state;
+#X obj 203 124 t b f;
+#X obj 217 145 f 0;
+#X obj 246 144 t b f;
+#X msg 217 190 arc_gen \$1;
+#X msg 47 190 arc_reset \, total_weight;
+#X obj 28 70 random 524287;
+#X obj 28 91 / 524287;
#X connect 0 0 2 0;
-#X connect 2 0 20 0;
-#X connect 2 1 21 0;
-#X connect 3 0 24 0;
-#X connect 4 0 5 0;
-#X connect 5 0 21 0;
-#X connect 7 1 1 0;
-#X connect 8 0 7 0;
-#X connect 9 0 10 0;
-#X connect 9 1 8 0;
-#X connect 9 2 14 0;
-#X connect 10 0 11 0;
-#X connect 13 1 6 0;
+#X connect 2 0 18 0;
+#X connect 2 1 19 0;
+#X connect 3 0 22 0;
+#X connect 5 1 1 0;
+#X connect 6 0 5 0;
+#X connect 7 0 8 0;
+#X connect 7 1 6 0;
+#X connect 7 2 12 0;
+#X connect 8 0 9 0;
+#X connect 11 1 4 0;
+#X connect 12 0 11 0;
+#X connect 13 0 17 0;
#X connect 14 0 13 0;
-#X connect 15 0 19 0;
-#X connect 16 0 15 0;
-#X connect 17 0 18 0;
-#X connect 17 1 9 0;
-#X connect 18 0 12 0;
+#X connect 15 0 16 0;
+#X connect 15 1 7 0;
+#X connect 16 0 10 0;
+#X connect 17 0 21 0;
+#X connect 17 1 15 0;
+#X connect 18 0 24 0;
#X connect 19 0 23 0;
-#X connect 19 1 17 0;
-#X connect 20 0 4 0;
-#X connect 21 0 25 0;
-#X connect 21 1 22 1;
-#X connect 22 0 3 0;
-#X connect 23 0 22 0;
-#X connect 23 1 3 1;
-#X connect 24 0 26 0;
-#X connect 25 0 26 0;
+#X connect 19 1 20 1;
+#X connect 20 0 3 0;
+#X connect 21 0 20 0;
+#X connect 21 1 3 1;
+#X connect 22 0 13 0;
+#X connect 23 0 13 0;
+#X connect 24 0 25 0;
+#X connect 25 0 19 0;
#X restore 22 216 pd gfsm_markov_next_guts;
#X obj 185 260 outlet;
#X connect 3 0 6 0;
diff --git a/gfsm/src/gfsm_state-help.pd b/gfsm/src/gfsm_state-help.pd
index 96d07b4..775780f 100644
--- a/gfsm/src/gfsm_state-help.pd
+++ b/gfsm/src/gfsm_state-help.pd
@@ -1,4 +1,4 @@
-#N canvas 154 10 651 599 10;
+#N canvas 426 16 651 599 10;
#X obj 85 569 gfsm;
#X text 15 569 SEE ALSO:;
#X text 41 6 gfsm_state : position "pointer" for finite-state automata
@@ -22,35 +22,39 @@
#X text 163 146 "automaton NAME" : use a shared machine named NAME
;
#X msg 58 212 degree;
-#X text 137 213 "degree" : get number of outgoing arcs (linear time)
+#X text 245 213 "degree" : get number of outgoing arcs (linear time)
;
-#X msg 61 325 arc_first;
-#X msg 61 342 arc_next;
-#X msg 65 412 arc_reset;
+#X msg 57 347 arc_first;
+#X msg 57 364 arc_next;
+#X msg 61 434 arc_reset;
#X obj 26 508 gfsm_state fsm-help 0;
-#X text 75 258 arcs are output as a list:;
-#X text 265 258 NEXT_STATEID LO HI WEIGHT;
-#X text 306 392 (negative labels are ignored);
-#X msg 64 376 arc_seek 202 -1;
-#X text 208 326 "arc_first" : get first outgoing arc;
-#X text 215 342 "arc_next" : get next available outgoing arc (maybe
+#X text 71 280 arcs are output as a list:;
+#X text 261 280 NEXT_STATEID LO HI WEIGHT;
+#X text 302 414 (negative labels are ignored);
+#X msg 60 398 arc_seek 202 -1;
+#X text 204 348 "arc_first" : get first outgoing arc;
+#X text 211 364 "arc_next" : get next available outgoing arc (maybe
first);
-#X text 173 377 "arc_seek LO HI" : get next arc with labels LO:HI;
-#X text 213 413 "arc_reset" : close internal arc iterator;
+#X text 169 399 "arc_seek LO HI" : get next arc with labels LO:HI;
+#X text 209 435 "arc_reset" : close internal arc iterator;
#X msg 54 467 add_weight 1 -1 101 0.9;
#X text 233 470 "add_weight ID LO HI W" : add W to 1st arc to state
ID;
#X text 416 483 with labels LO:HI;
#X text 271 499 (implicitly resets arc iterator);
#X msg 61 229 cyclic;
-#X text 137 229 "cyclic" : does this state lead to any cycles?;
-#X msg 64 359 arc_nth 0;
-#X text 208 360 "arc_nth N" : seek to n-th arc (counting from zero)
+#X text 245 229 "cyclic" : does this state lead to any cycles?;
+#X msg 60 381 arc_nth 0;
+#X text 204 382 "arc_nth N" : seek to n-th arc (counting from zero)
;
-#X msg 61 278 arc_gen 42 1;
-#X text 186 281 "arc_gen W SR" : generate an arc;
-#X text 312 295 W - weight hint (0..sum(weights(state));
-#X text 304 309 SR - boolean - whether to use gfsmSemiring;
+#X msg 57 300 arc_gen 42 1;
+#X text 182 303 "arc_gen W SR" : generate an arc;
+#X text 308 317 W - weight hint (0..sum(weights(state));
+#X text 300 331 SR - boolean - whether to use gfsmSemiring;
+#X text 181 247 "total_weight SR" : get total weight of outgoing arcs
+;
+#X text 323 261 SR - boolean: use gfsmSemiring?;
+#X msg 65 246 total_weight 1;
#X connect 12 0 25 0;
#X connect 15 0 25 0;
#X connect 16 0 25 0;
@@ -65,3 +69,4 @@ ID;
#X connect 38 0 25 0;
#X connect 40 0 25 0;
#X connect 42 0 25 0;
+#X connect 48 0 25 0;