aboutsummaryrefslogtreecommitdiff
path: root/packages/noncvs/windows/extra/Gem/pix_blobtracker.pd
diff options
context:
space:
mode:
Diffstat (limited to 'packages/noncvs/windows/extra/Gem/pix_blobtracker.pd')
-rw-r--r--packages/noncvs/windows/extra/Gem/pix_blobtracker.pd132
1 files changed, 132 insertions, 0 deletions
diff --git a/packages/noncvs/windows/extra/Gem/pix_blobtracker.pd b/packages/noncvs/windows/extra/Gem/pix_blobtracker.pd
new file mode 100644
index 00000000..dcdbf20b
--- /dev/null
+++ b/packages/noncvs/windows/extra/Gem/pix_blobtracker.pd
@@ -0,0 +1,132 @@
+#N canvas 77 45 654 552 10;
+#X declare -lib Gem -lib iemmatrix;
+#N canvas 0 0 571 399 matrix->indexlist 0;
+#X obj 133 90 inlet;
+#X obj 133 298 outlet;
+#X obj 133 163 mtx;
+#X msg 133 137 row;
+#X obj 133 109 t b a b;
+#X obj 212 227 i;
+#X obj 239 228 + 1;
+#X obj 133 248 pack 0 0 0 0;
+#X obj 133 210 t l b;
+#X msg 133 273 \$4 \$1 \$2 \$3;
+#X msg 228 206 0;
+#X msg 133 189 \$1 \$2 \$3;
+#X connect 0 0 4 0;
+#X connect 2 0 11 0;
+#X connect 3 0 2 0;
+#X connect 4 0 3 0;
+#X connect 4 1 2 1;
+#X connect 4 2 10 0;
+#X connect 5 0 6 0;
+#X connect 5 0 7 3;
+#X connect 6 0 5 1;
+#X connect 7 0 9 0;
+#X connect 8 0 7 0;
+#X connect 8 1 5 0;
+#X connect 9 0 1 0;
+#X connect 10 0 5 1;
+#X connect 11 0 8 0;
+#X restore 324 518 pd matrix->indexlist;
+#X obj 97 197 inlet gemlist;
+#X obj 97 402 outlet gemlist;
+#X obj 231 429 t a;
+#X obj 231 343 t a a;
+#X obj 324 428 mtx_mul;
+#X obj 354 490 outlet numblobs;
+#X obj 324 449 t a a;
+#X obj 354 471 mtx_size;
+#X obj 231 363 mtx_resize \$1 2;
+#N canvas 0 0 518 479 mtx_matcher 0;
+#X obj 61 200 mtx_distance2;
+#X obj 61 176 t a a;
+#X obj 61 244 t a a;
+#X obj 61 279 mtx_mul;
+#X obj 61 325 outlet matched;
+#X obj 171 325 outlet matcher;
+#X obj 147 177 inlet dest;
+#X obj 61 149 inlet source;
+#X text 25 105 both "source" and "dest" must have the same number of
+columns (dimension in feature-space);
+#N canvas 0 0 618 479 mtx_rowpermutate 0;
+#X obj 150 214 t b a;
+#X obj 150 235 mtx;
+#X obj 150 256 mtx_mul;
+#X obj 111 192 mtx_pivot -1;
+#X text 17 19 this unfortunately does not guarantee to give as a minimum
+trace of the result!;
+#X obj 150 309 outlet rowpermutator;
+#X obj 111 141 inlet permutans;
+#X connect 0 0 1 0;
+#X connect 0 1 2 1;
+#X connect 1 0 2 0;
+#X connect 2 0 5 0;
+#X connect 3 1 0 0;
+#X connect 3 2 1 1;
+#X connect 6 0 3 0;
+#X restore 61 221 pd mtx_rowpermutate;
+#X text 34 383 this algorithm is _far_ from being perfect! the [mtx_rowpermutate]
+does not really guarantee that the trace of the result is a global
+mimimum \; if it is not \, than the match will be sub-optimal! this
+will be even worse \, if there are several _equal_ (sub)minima in the
+distance-matrix.;
+#X text 158 194 greater distances have an extra penalty (^2) \; is
+this ok?;
+#X text 32 52 we calculate the euclidean distance between the vectors
+of the 2 sets and try to find a trace with minimum penalty;
+#X text 32 22 this tries to get the best (weighted) match between 2
+sets of feature-vectors.;
+#X connect 0 0 9 0;
+#X connect 1 0 0 0;
+#X connect 1 1 3 1;
+#X connect 2 0 3 0;
+#X connect 2 1 5 0;
+#X connect 3 0 4 0;
+#X connect 6 0 0 1;
+#X connect 7 0 1 0;
+#X connect 9 0 2 0;
+#X restore 231 397 pd mtx_matcher;
+#X text 91 114 this blobtracker is far from being perfect. for an explanation
+read the comments in [pd mtx_matcher];
+#X text 93 536 we don't want to output "matrix" \, but pure pd-lists
+instead;
+#X obj 324 566 outlet bloblists;
+#X text 344 402 this is the work-horse for the tracking;
+#X text 95 10 part of Gem;
+#X text 51 253 the work-horse for detection;
+#X obj 301 224 loadbang;
+#X obj 301 243 f \$1;
+#X obj 301 262 moses 1;
+#X msg 331 343 6 2;
+#X obj 301 281 t b b;
+#X text 56 155 TODO: output only those blobs that are really detected
+;
+#X obj 231 322 mtx_resize \$1 0;
+#X msg 331 302 6 0;
+#X obj 97 269 pix_multiblob \$1;
+#X obj 97 30 declare -lib Gem -lib iemmatrix;
+#X text 92 66 copyright (c) IOhannes m zmoelnig \, 2005 \; you may
+use this under the terms of the GnuGPL v2.0 or later;
+#X connect 0 0 13 0;
+#X connect 1 0 25 0;
+#X connect 3 0 10 1;
+#X connect 4 0 9 0;
+#X connect 4 1 5 1;
+#X connect 5 0 7 0;
+#X connect 7 0 0 0;
+#X connect 7 1 8 0;
+#X connect 8 0 6 0;
+#X connect 9 0 10 0;
+#X connect 10 0 3 0;
+#X connect 10 1 5 0;
+#X connect 17 0 18 0;
+#X connect 18 0 19 0;
+#X connect 19 0 21 0;
+#X connect 20 0 9 1;
+#X connect 21 0 20 0;
+#X connect 21 1 24 0;
+#X connect 23 0 4 0;
+#X connect 24 0 23 1;
+#X connect 25 0 2 0;
+#X connect 25 1 23 0;