-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathphysigs.pd
980 lines (980 loc) · 24.6 KB
/
physigs.pd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
#N canvas 322 77 863 456 10;
#N canvas 592 15 774 709 physigs-linkforces 0;
#X obj 71 21 inlet;
#X obj 220 58 outlet;
#X obj 71 160 switch~;
#X text 289 172 get state;
#X obj 220 29 bang~;
#X text 143 646 set new forces;
#X text 390 45 Formula: F = -[k*(|p2-p1|- len) + D*(vel2-vel1)]*(p2-p1)/|p2-p1|
;
#X obj 99 522 tabreceive~ \$1-link-k;
#X obj 72 522 *~;
#X text 21 419 substract length;
#X obj 172 450 /~;
#X obj 272 441 /~;
#X text 313 443 normalized difference vector (x \, y);
#X obj 146 570 *~;
#X obj 409 575 *~;
#X text 407 640 set new forces;
#X obj 506 273 tabread~ \$1-pos-y;
#X obj 367 271 tabread~ \$1-pos-y;
#X obj 232 270 tabread~ \$1-pos-x;
#X obj 72 268 tabread~ \$1-pos-x;
#X obj 145 625 tabsend~ \$1-link-force-x;
#X obj 410 619 tabsend~ \$1-link-force-y;
#X text 121 492 TODO: why not negative?;
#N canvas 0 0 687 386 velocity-difference 0;
#X obj 71 178 -~;
#X obj 344 179 -~;
#X obj 71 143 tabread~ \$1-vel-x;
#X obj 231 145 tabread~ \$1-vel-x;
#X obj 343 144 tabread~ \$1-vel-y;
#X obj 482 146 tabread~ \$1-vel-y;
#X obj 71 30 inlet~;
#X obj 231 30 inlet~;
#X obj 72 233 outlet~;
#X obj 344 232 outlet~;
#X obj 474 37 inlet~;
#X obj 71 205 *~;
#X obj 345 207 *~;
#X text 485 19 damping;
#X connect 0 0 11 0;
#X connect 1 0 12 0;
#X connect 2 0 0 0;
#X connect 3 0 0 1;
#X connect 4 0 1 0;
#X connect 5 0 1 1;
#X connect 6 0 4 0;
#X connect 6 0 2 0;
#X connect 7 0 5 0;
#X connect 7 0 3 0;
#X connect 10 0 12 1;
#X connect 10 0 11 1;
#X connect 11 0 8 0;
#X connect 12 0 9 0;
#X restore 444 406 pd velocity-difference;
#X obj 610 406 tabreceive~ \$1-link-D;
#X obj 454 499 *~;
#X obj 390 497 *~;
#X obj 72 217 tabreceive~ \$1-link-m2;
#X obj 232 217 tabreceive~ \$1-link-m1;
#X obj 72 438 -~;
#X msg 85 133 set \$1 1 1;
#X obj 85 112 r \$0-num-links;
#X obj 90 399 tabreceive~ \$1-link-length;
#N canvas 0 0 543 306 get-link-force-y 0;
#X obj 109 45 inlet~;
#X obj 108 173 outlet~;
#X obj 150 105 tabreceive~ \$1-link-force-y;
#X text 186 43 order forcing;
#X connect 0 0 1 0;
#X connect 2 0 1 0;
#X restore 409 595 pd get-link-force-y;
#N canvas 0 0 543 306 get-link-force-x 0;
#X obj 109 45 inlet~;
#X obj 108 173 outlet~;
#X text 186 43 order forcing;
#X obj 149 105 tabreceive~ \$1-link-force-x;
#X connect 0 0 1 0;
#X connect 3 0 1 0;
#X restore 145 594 pd get-link-force-x;
#N canvas 292 57 436 349 get-vector-length-and-diff 0;
#X obj 81 64 inlet~;
#X obj 134 64 inlet~;
#X obj 221 65 inlet~;
#X obj 273 65 inlet~;
#X text 86 43 x1;
#X text 135 44 x2;
#X text 220 46 y1;
#X text 274 49 y2;
#X obj 82 128 -~;
#X obj 221 98 -~;
#X obj 220 126 *~;
#X obj 82 152 *~;
#X obj 81 186 +~;
#X obj 81 216 sqrt~;
#X text 27 217 |p2-p1|;
#X obj 81 246 outlet~;
#X obj 174 247 outlet~;
#X obj 267 245 outlet~;
#X connect 0 0 8 0;
#X connect 1 0 8 1;
#X connect 2 0 9 0;
#X connect 3 0 9 1;
#X connect 8 0 11 0;
#X connect 8 0 11 1;
#X connect 8 0 16 0;
#X connect 9 0 10 0;
#X connect 9 0 10 1;
#X connect 9 0 17 0;
#X connect 10 0 12 1;
#X connect 11 0 12 0;
#X connect 12 0 13 0;
#X connect 13 0 15 0;
#X restore 71 324 pd get-vector-length-and-diff;
#N canvas 0 0 456 205 dsp-guard 0;
#X obj 105 49 r pd;
#X obj 105 70 route dsp;
#X obj 66 91 spigot;
#X obj 66 26 inlet;
#X obj 66 119 outlet;
#X text 123 26 blocks messages while dsp is off;
#X msg 121 91 1;
#X connect 0 0 1 0;
#X connect 1 0 2 1;
#X connect 2 0 4 0;
#X connect 3 0 2 0;
#X connect 6 0 2 1;
#X restore 71 90 pd dsp-guard;
#X obj 71 62 b;
#X connect 0 0 37 0;
#X connect 4 0 1 0;
#X connect 7 0 8 1;
#X connect 8 0 13 0;
#X connect 8 0 14 0;
#X connect 10 0 13 1;
#X connect 10 0 26 0;
#X connect 11 0 14 1;
#X connect 11 0 25 0;
#X connect 13 0 34 0;
#X connect 14 0 33 0;
#X connect 16 0 35 3;
#X connect 17 0 35 2;
#X connect 18 0 35 1;
#X connect 19 0 35 0;
#X connect 23 0 26 1;
#X connect 23 1 25 1;
#X connect 24 0 23 2;
#X connect 25 0 14 0;
#X connect 26 0 13 0;
#X connect 27 0 19 0;
#X connect 27 0 17 0;
#X connect 27 0 23 0;
#X connect 28 0 18 0;
#X connect 28 0 16 0;
#X connect 28 0 23 1;
#X connect 29 0 8 0;
#X connect 30 0 2 0;
#X connect 31 0 30 0;
#X connect 32 0 29 1;
#X connect 33 0 21 0;
#X connect 34 0 20 0;
#X connect 35 0 11 1;
#X connect 35 0 10 1;
#X connect 35 0 29 0;
#X connect 35 1 10 0;
#X connect 35 2 11 0;
#X connect 36 0 2 0;
#X connect 37 0 36 0;
#X restore 199 72 pd physigs-linkforces;
#N canvas 286 16 1080 630 linkforces-to-mass-forces 0;
#X obj 195 196 f 0;
#X obj 224 197 + 1;
#X obj 195 172 until;
#X obj 195 88 t b b;
#X obj 245 23 bng 15 250 50 0 empty empty empty 17 7 0 10 -262144 -1
-1;
#X text 275 219 go through all links;
#X obj 195 16 inlet;
#X msg 233 173 0;
#X obj 195 217 t f f f f;
#X obj 539 442 +;
#X obj 608 443 tabread \$1-link-force-x;
#X obj 539 416 tabread \$1-force-x;
#X obj 539 465 tabwrite \$1-force-x;
#X text 802 311 get mass id;
#X text 723 281 link id;
#X text 755 335 mass id;
#X obj 777 442 +;
#X obj 777 416 tabread \$1-force-y;
#X obj 777 465 tabwrite \$1-force-y;
#X obj 846 443 tabread \$1-link-force-y;
#X obj 668 310 tabread \$1-link-m2;
#X obj 808 442 * -1;
#X obj 572 443 * -1;
#X obj 195 151 max;
#X obj 195 130 f 64;
#X obj 220 108 r \$0-num-links;
#X obj 668 283 t f f f;
#X obj 668 337 t f f f f;
#X obj 102 444 tabread \$1-link-force-x;
#X obj 66 417 tabread \$1-force-x;
#X obj 66 466 tabwrite \$1-force-x;
#X text 329 312 get mass id;
#X text 250 282 link id;
#X text 282 336 mass id;
#X obj 304 443 +;
#X obj 304 417 tabread \$1-force-y;
#X obj 304 466 tabwrite \$1-force-y;
#X obj 343 444 tabread \$1-link-force-y;
#X obj 195 284 t f f f;
#X obj 195 338 t f f f f;
#X obj 195 311 tabread \$1-link-m1;
#X obj 66 444 +;
#X connect 0 0 1 0;
#X connect 0 0 8 0;
#X connect 1 0 0 1;
#X connect 2 0 0 0;
#X connect 3 0 24 0;
#X connect 3 1 7 0;
#X connect 4 0 3 0;
#X connect 6 0 3 0;
#X connect 7 0 0 1;
#X connect 8 0 38 0;
#X connect 8 2 26 0;
#X connect 9 0 12 0;
#X connect 10 0 22 0;
#X connect 11 0 9 0;
#X connect 16 0 18 0;
#X connect 17 0 16 0;
#X connect 19 0 21 0;
#X connect 20 0 27 0;
#X connect 21 0 16 1;
#X connect 22 0 9 1;
#X connect 23 0 2 0;
#X connect 24 0 23 0;
#X connect 25 0 24 1;
#X connect 26 0 20 0;
#X connect 26 1 10 0;
#X connect 26 2 19 0;
#X connect 27 0 11 0;
#X connect 27 1 12 1;
#X connect 27 2 17 0;
#X connect 27 3 18 1;
#X connect 28 0 41 1;
#X connect 29 0 41 0;
#X connect 34 0 36 0;
#X connect 35 0 34 0;
#X connect 37 0 34 1;
#X connect 38 0 40 0;
#X connect 38 1 28 0;
#X connect 38 2 37 0;
#X connect 39 0 29 0;
#X connect 39 1 30 1;
#X connect 39 2 35 0;
#X connect 39 3 36 1;
#X connect 40 0 39 0;
#X connect 41 0 30 0;
#X restore 199 104 pd linkforces-to-mass-forces;
#N canvas 0 0 648 516 make-link 0;
#X obj 227 56 inlet;
#X msg 227 274 \$1 \$2;
#X obj 227 298 s \$1-link-m1;
#X msg 227 334 \$1 \$3;
#X obj 227 358 s \$1-link-m2;
#X obj 228 409 s \$1-link-k;
#X msg 228 385 \$1 \$4;
#X obj 116 261 list split 1;
#X floatatom 116 284 5 0 0 0 last_link-id - -;
#X obj 439 150 inlet;
#X obj 439 178 b;
#X text 239 36 m1 \, m2 \, k \, D;
#X text 234 239 lid \, m1 \, m2 \, k \, D;
#X msg 228 432 \$1 \$5;
#X obj 228 456 s \$1-link-D;
#N canvas 0 0 386 287 enumerate 0;
#N canvas 473 338 450 300 count 0;
#X obj 131 154 f 0;
#X obj 156 153 + 1;
#X obj 131 183 outlet;
#X obj 131 59 inlet;
#X obj 131 96 b;
#X obj 178 61 inlet;
#X obj 178 98 b;
#X msg 147 133 0;
#X connect 0 0 1 0;
#X connect 0 0 2 0;
#X connect 1 0 0 1;
#X connect 3 0 4 0;
#X connect 4 0 0 0;
#X connect 5 0 6 0;
#X connect 6 0 7 0;
#X connect 7 0 0 1;
#X restore 137 130 pd count;
#X obj 56 155 list prepend;
#X obj 56 100 t a b;
#X obj 56 71 inlet;
#X obj 190 76 inlet;
#X obj 56 191 outlet;
#X connect 0 0 1 1;
#X connect 1 0 5 0;
#X connect 2 0 1 0;
#X connect 2 1 0 0;
#X connect 3 0 2 0;
#X connect 4 0 0 1;
#X restore 227 218 pd enumerate;
#X obj 308 177 r \$0-reset-links;
#X connect 0 0 15 0;
#X connect 1 0 2 0;
#X connect 3 0 4 0;
#X connect 6 0 5 0;
#X connect 7 0 8 0;
#X connect 9 0 10 0;
#X connect 10 0 15 1;
#X connect 13 0 14 0;
#X connect 15 0 1 0;
#X connect 15 0 3 0;
#X connect 15 0 6 0;
#X connect 15 0 7 0;
#X connect 15 0 13 0;
#X connect 16 0 15 1;
#X restore 42 228 pd make-link;
#X msg 142 206 reset;
#N canvas 380 81 780 444 particle-system-state 0;
#X obj 62 117 table \$1-mass 64;
#X obj 62 41 table \$1-pos-x 64;
#X obj 62 63 table \$1-vel-x 64;
#X obj 62 85 table \$1-force-x 64;
#X obj 217 41 table \$1-pos-y 64;
#X obj 217 63 table \$1-vel-y 64;
#X obj 217 85 table \$1-force-y 64;
#X text 67 17 Mass tables;
#X text 60 168 Link tables;
#X obj 60 187 table \$1-link-m1 64;
#X obj 60 209 table \$1-link-m2 64;
#X obj 60 231 table \$1-link-k 64;
#X obj 60 253 table \$1-link-D 64;
#X obj 59 276 table \$1-link-force-x 64;
#X obj 59 295 table \$1-link-force-y 64;
#X text 209 185 index of connected mass 1;
#X text 210 208 index of connected mass 2;
#X obj 62 138 table \$1-mobile 64;
#X text 371 41 position;
#X text 369 62 velocity;
#X text 183 117 mass;
#X text 220 139 mobile = 1 \, immobile = 0;
#X text 210 233 k of link;
#X text 209 252 D of link (velocity dependent damping in link direction)
;
#X text 245 276 link forces;
#X text 384 85 force accumulators;
#X obj 59 319 table \$1-link-length 64;
#X text 242 319 link lengths;
#X restore 265 185 pd particle-system-state;
#X obj 24 49 inlet;
#X obj 199 50 inlet;
#X obj 483 49 inlet;
#X text 24 29 bang masses;
#X text 187 24 bang links;
#X text 483 29 ctl;
#N canvas 185 0 1057 657 physigs-masses 0;
#X obj 71 21 inlet;
#X obj 383 106 outlet;
#X text 278 369 friction;
#X obj 403 370 tabreceive~ \$1-mass;
#X text 419 388 vdot = f/m;
#X obj 387 389 /~;
#X text 242 264 xdot = v;
#X text 71 260 get state;
#X obj 71 473 +~;
#X text 99 476 x + xdot;
#X obj 227 473 +~;
#X text 255 472 v + vdot;
#X text 70 622 set new position;
#X text 165 586 set new velocity;
#X obj 310 52 bang~;
#N canvas 181 14 631 450 checkbounds 0;
#X obj 32 57 inlet~;
#X obj 462 95 inlet~;
#X text 465 71 velocity;
#X text 25 33 position;
#X obj 110 320 outlet~;
#X obj 110 298 *~;
#X obj 158 72 r \$0-xmin;
#X obj 222 72 r \$0-xmax;
#X obj 110 251 -~ 1;
#X obj 109 225 *~ 2;
#X obj 134 129 r \$0-bounce;
#X msg 167 193 2;
#X msg 191 223 1;
#X obj 134 169 select 0 1;
#X msg 134 192 1;
#X msg 156 222 0;
#X obj 33 321 outlet~;
#X obj 109 101 between~ -500 500;
#X connect 0 0 16 0;
#X connect 0 0 17 0;
#X connect 1 0 5 1;
#X connect 5 0 4 0;
#X connect 6 0 17 1;
#X connect 7 0 17 2;
#X connect 8 0 5 0;
#X connect 9 0 8 0;
#X connect 10 0 13 0;
#X connect 11 0 9 1;
#X connect 12 0 8 1;
#X connect 13 0 14 0;
#X connect 13 0 15 0;
#X connect 13 1 11 0;
#X connect 13 1 12 0;
#X connect 14 0 9 1;
#X connect 15 0 8 1;
#X connect 17 0 9 0;
#X restore 70 539 pd checkbounds;
#X obj 228 370 *~ 0.99;
#X text 770 369 friction;
#X obj 895 370 tabreceive~ \$1-mass;
#X text 911 388 vdot = f/m;
#X obj 879 389 /~;
#X text 734 264 xdot = v;
#X text 565 260 get state;
#X obj 563 473 +~;
#X text 591 472 x + xdot;
#X obj 719 469 +~;
#X text 747 472 v + vdot;
#X text 570 622 set new position;
#X text 659 572 set new velocity;
#N canvas 181 14 631 450 checkbounds 0;
#X obj 46 61 inlet~;
#X obj 480 86 inlet~;
#X text 483 62 velocity;
#X text 39 37 position;
#X obj 110 360 outlet~;
#X obj 110 348 *~;
#X obj 111 260 -~ 1;
#X obj 110 234 *~ 2;
#X obj 222 72 r \$0-ymax;
#X obj 158 72 r \$0-ymin;
#X obj 135 138 r \$0-bounce;
#X msg 168 202 2;
#X msg 192 232 1;
#X obj 135 178 select 0 1;
#X msg 135 201 1;
#X msg 157 231 0;
#X obj 46 360 outlet~;
#X obj 109 101 between~ -500 500;
#X connect 0 0 16 0;
#X connect 0 0 17 0;
#X connect 1 0 5 1;
#X connect 5 0 4 0;
#X connect 6 0 5 0;
#X connect 7 0 6 0;
#X connect 8 0 17 2;
#X connect 9 0 17 1;
#X connect 10 0 13 0;
#X connect 11 0 7 1;
#X connect 12 0 6 1;
#X connect 13 0 14 0;
#X connect 13 0 15 0;
#X connect 13 1 11 0;
#X connect 13 1 12 0;
#X connect 14 0 7 1;
#X connect 15 0 6 1;
#X connect 17 0 7 0;
#X restore 564 528 pd checkbounds;
#X obj 720 370 *~ 0.99;
#X obj 71 280 tabreceive~ \$1-pos-x;
#X obj 227 288 tabreceive~ \$1-vel-x;
#X obj 387 288 tabreceive~ \$1-force-x;
#X obj 310 128 s \$1-force-x;
#X obj 310 153 s \$1-force-y;
#X obj 165 565 tabsend~ \$1-vel-x;
#X obj 70 601 tabsend~ \$1-pos-x;
#X obj 565 280 tabreceive~ \$1-pos-y;
#X obj 719 288 tabreceive~ \$1-vel-y;
#X obj 879 288 tabreceive~ \$1-force-y;
#X obj 564 598 tabsend~ \$1-pos-y;
#X obj 659 551 tabsend~ \$1-vel-y;
#X msg 310 106 const 0;
#X obj 310 179 s \$1-link-force-x;
#X obj 310 202 s \$1-link-force-y;
#X obj 879 343 *~;
#X obj 388 343 *~;
#X obj 404 312 tabreceive~ \$1-mobile;
#X obj 897 312 tabreceive~ \$1-mobile;
#X obj 267 343 r \$0-drag;
#X obj 759 343 r \$0-drag;
#N canvas 0 0 744 646 clip-x 0;
#X obj 151 165 clip~ -500 500;
#X obj 191 139 r \$0-xmin;
#X obj 256 139 r \$0-xmax;
#X obj 152 89 inlet~;
#X obj 152 210 outlet~;
#X connect 0 0 4 0;
#X connect 1 0 0 1;
#X connect 2 0 0 2;
#X connect 3 0 0 0;
#X restore 70 561 pd clip-x;
#N canvas 0 0 589 427 clip-y 0;
#X obj 151 165 clip~ -500 500;
#X obj 152 89 inlet~;
#X obj 152 210 outlet~;
#X obj 198 122 r \$0-ymin;
#X obj 246 141 r \$0-ymax;
#X connect 0 0 2 0;
#X connect 1 0 0 0;
#X connect 3 0 0 1;
#X connect 4 0 0 2;
#X restore 564 576 pd clip-y;
#X obj 720 329 *~;
#X obj 227 329 *~;
#X obj 71 176 switch~;
#X msg 85 150 set \$1 1 1;
#N canvas 0 0 456 205 dsp-guard 0;
#X obj 105 49 r pd;
#X obj 105 70 route dsp;
#X obj 66 91 spigot;
#X obj 66 26 inlet;
#X obj 66 119 outlet;
#X text 123 26 blocks messages while dsp is off;
#X msg 121 91 1;
#X connect 0 0 1 0;
#X connect 1 0 2 1;
#X connect 2 0 4 0;
#X connect 3 0 2 0;
#X connect 6 0 2 1;
#X restore 71 100 pd dsp-guard;
#X obj 71 78 b;
#X obj 85 128 r \$0-num-masses;
#X text 310 32 clean up after dsp block;
#X text 418 152 reset forces;
#X connect 0 0 59 0;
#X connect 3 0 5 1;
#X connect 5 0 10 1;
#X connect 8 0 15 0;
#X connect 10 0 15 1;
#X connect 14 0 43 0;
#X connect 14 0 1 0;
#X connect 15 0 52 0;
#X connect 15 1 36 0;
#X connect 16 0 8 1;
#X connect 16 0 10 0;
#X connect 18 0 20 1;
#X connect 20 0 25 1;
#X connect 23 0 29 0;
#X connect 25 0 29 1;
#X connect 29 0 53 0;
#X connect 29 1 42 0;
#X connect 30 0 23 1;
#X connect 30 0 25 0;
#X connect 31 0 8 0;
#X connect 32 0 55 0;
#X connect 33 0 47 0;
#X connect 38 0 23 0;
#X connect 39 0 54 0;
#X connect 40 0 46 0;
#X connect 43 0 35 0;
#X connect 43 0 34 0;
#X connect 43 0 44 0;
#X connect 43 0 45 0;
#X connect 46 0 20 0;
#X connect 47 0 5 0;
#X connect 48 0 47 1;
#X connect 48 0 55 1;
#X connect 49 0 46 1;
#X connect 49 0 54 1;
#X connect 50 0 16 1;
#X connect 51 0 30 1;
#X connect 52 0 37 0;
#X connect 53 0 41 0;
#X connect 54 0 30 0;
#X connect 55 0 16 0;
#X connect 57 0 56 0;
#X connect 58 0 56 0;
#X connect 59 0 58 0;
#X connect 60 0 57 0;
#X restore 24 90 pd physigs-masses;
#X obj 483 71 physigs_dispatch \$0 reset;
#X text 33 184 m1 \, m2 \, k \, D;
#X obj 483 159 physigs_dispatch \$0 drag;
#X obj 483 181 physigs_dispatch \$0 bounce;
#X obj 483 93 physigs_dispatch \$0 reset-links;
#X obj 483 115 physigs_dispatch \$0 reset-masses;
#X obj 483 203 physigs_dispatch \$0 xbounds;
#X obj 483 225 physigs_dispatch \$0 ybounds;
#N canvas 126 0 1028 544 init-and-reset 0;
#X obj 530 145 s \$0-num-masses;
#X obj 636 81 f \$3;
#X obj 530 79 f \$2;
#X obj 530 101 select 0;
#X msg 530 120 64;
#X obj 636 103 select 0;
#X msg 636 122 64;
#X obj 636 147 s \$0-num-links;
#N canvas 287 93 748 439 resize-tables 0;
#X obj 329 71 s \$1-link-m1;
#X obj 329 115 s \$1-link-k;
#X obj 329 92 s \$1-link-m2;
#X obj 329 137 s \$1-link-D;
#X obj 328 160 s \$1-link-force-x;
#X obj 328 179 s \$1-link-force-y;
#X obj 328 203 s \$1-link-length;
#X msg 292 43 resize \$1;
#X obj 292 16 r \$0-num-links;
#X obj 187 91 s \$1-pos-y;
#X obj 187 113 s \$1-vel-y;
#X obj 187 135 s \$1-force-y;
#X obj 62 91 s \$1-pos-x;
#X obj 62 113 s \$1-vel-x;
#X obj 62 135 s \$1-force-x;
#X obj 62 167 s \$1-mass;
#X obj 62 188 s \$1-mobile;
#X msg 35 43 resize \$1;
#X obj 35 16 r \$0-num-masses;
#X connect 7 0 0 0;
#X connect 7 0 2 0;
#X connect 7 0 1 0;
#X connect 7 0 3 0;
#X connect 7 0 4 0;
#X connect 7 0 5 0;
#X connect 7 0 6 0;
#X connect 8 0 7 0;
#X connect 17 0 12 0;
#X connect 17 0 13 0;
#X connect 17 0 14 0;
#X connect 17 0 9 0;
#X connect 17 0 10 0;
#X connect 17 0 11 0;
#X connect 17 0 15 0;
#X connect 17 0 16 0;
#X connect 18 0 17 0;
#X restore 530 170 pd resize-tables;
#X obj 530 37 r \$0-lb0;
#X obj 800 25 loadbang;
#X obj 800 52 t b b b b b;
#X obj 888 74 s \$0-lb0;
#X obj 877 95 s \$0-lb1;
#X obj 848 117 s \$0-lb2;
#X obj 822 136 s \$0-lb3;
#X obj 800 166 s \$0-lb4;
#N canvas 287 93 748 439 reset-link-tables 0;
#X obj 303 147 s \$1-link-m1;
#X obj 436 152 s \$1-link-k;
#X obj 303 168 s \$1-link-m2;
#X obj 436 174 s \$1-link-D;
#X obj 435 197 s \$1-link-force-x;
#X obj 435 216 s \$1-link-force-y;
#X obj 435 240 s \$1-link-length;
#X obj 285 9 inlet;
#X msg 285 116 const -1;
#X msg 395 117 const 0;
#X obj 285 30 b;
#X connect 7 0 10 0;
#X connect 8 0 0 0;
#X connect 8 0 2 0;
#X connect 9 0 1 0;
#X connect 9 0 4 0;
#X connect 9 0 5 0;
#X connect 9 0 3 0;
#X connect 9 0 6 0;
#X connect 10 0 8 0;
#X connect 10 0 9 0;
#X restore 59 125 pd reset-link-tables;
#N canvas 287 93 770 383 reset-mass-tables 0;
#X obj 279 183 s \$1-pos-y;
#X obj 279 205 s \$1-vel-y;
#X obj 279 227 s \$1-force-y;
#X obj 154 183 s \$1-pos-x;
#X obj 154 205 s \$1-vel-x;
#X obj 154 227 s \$1-force-x;
#X obj 379 227 s \$1-mass;
#X obj 444 227 s \$1-mobile;
#X obj 284 34 inlet;
#X msg 226 121 const 0;
#X obj 284 55 b;
#X msg 444 191 const 1 \, 0 0;
#X text 443 248 default masses are mobile \, except the first one.
;
#X msg 379 188 const 100;
#X connect 8 0 10 0;
#X connect 9 0 0 0;
#X connect 9 0 1 0;
#X connect 9 0 2 0;
#X connect 9 0 3 0;
#X connect 9 0 4 0;
#X connect 9 0 5 0;
#X connect 10 0 9 0;
#X connect 10 0 13 0;
#X connect 10 0 11 0;
#X connect 11 0 7 0;
#X connect 13 0 6 0;
#X restore 22 77 pd reset-mass-tables;
#X obj 59 103 r \$0-reset-links;
#X obj 22 55 r \$0-reset-masses;
#X obj 301 31 r \$0-reset;
#X obj 301 92 s \$0-reset-masses;
#X obj 328 71 s \$0-reset-links;
#X obj 301 51 t b b;
#X obj 397 27 r \$0-lb1;
#X obj 397 49 s \$0-reset;
#X text 864 25 pool of loadbangs;
#X obj 221 203 r \$0-lb2;
#X obj 221 253 s \$0-drag;
#X msg 221 226 0.99;
#X obj 175 300 r \$0-xbounds;
#X obj 175 327 unpack 0 0;
#X obj 175 374 s \$0-xmin;
#X obj 232 350 s \$0-xmax;
#X obj 302 328 unpack 0 0;
#X obj 302 301 r \$0-ybounds;
#X obj 359 350 s \$0-ymax;
#X obj 302 375 s \$0-ymin;
#X connect 1 0 5 0;
#X connect 2 0 3 0;
#X connect 3 0 4 0;
#X connect 3 1 0 0;
#X connect 4 0 0 0;
#X connect 5 0 6 0;
#X connect 5 1 7 0;
#X connect 6 0 7 0;
#X connect 9 0 2 0;
#X connect 9 0 1 0;
#X connect 10 0 11 0;
#X connect 11 0 16 0;
#X connect 11 1 15 0;
#X connect 11 2 14 0;
#X connect 11 3 13 0;
#X connect 11 4 12 0;
#X connect 19 0 17 0;
#X connect 20 0 18 0;
#X connect 21 0 24 0;
#X connect 24 0 22 0;
#X connect 24 1 23 0;
#X connect 25 0 26 0;
#X connect 28 0 30 0;
#X connect 30 0 29 0;
#X connect 31 0 32 0;
#X connect 32 0 33 0;
#X connect 32 1 34 0;
#X connect 35 0 38 0;
#X connect 35 1 37 0;
#X connect 36 0 35 0;
#X restore 42 250 pd init-and-reset;
#X obj 483 137 physigs_dispatch \$0 add-link;
#N canvas 281 74 666 313 stuff 0;
#X msg 90 159 0;
#X msg 123 159 0.5;
#X msg 156 159 0.85;
#X msg 244 160 1;
#X msg 203 159 0.95;
#X msg 104 142 0.1;
#X msg 137 141 0.3;
#X obj 200 106 s \$1-link-k;
#X msg 200 85 const \$1 \, 0 0 \, 63 0;
#X floatatom 200 65 5 0 0 0 - - -;
#X obj 203 45 hsl 128 15 0 10 0 0 empty empty empty -2 -8 0 10 -262144
-1 -1 0 1;
#X obj 55 104 hsl 128 15 1 0 0 0 empty empty empty -2 -8 0 10 -262144
-1 -1 0 1;
#X floatatom 52 126 5 0 0 0 - - -;
#X obj 306 160 s \$1-link-length;
#X floatatom 306 121 5 0 0 0 - - -;
#X obj 444 121 s \$1-link-D;
#X msg 444 94 const \$1;
#X floatatom 444 73 5 0 0 0 - - -;
#X obj 444 52 / 100;
#X floatatom 444 35 5 0 0 0 - - -;
#X obj 90 186 s \$0-drag;
#X msg 306 139 const \$1;
#X connect 0 0 20 0;
#X connect 1 0 20 0;
#X connect 2 0 20 0;
#X connect 3 0 20 0;
#X connect 4 0 20 0;
#X connect 5 0 20 0;
#X connect 6 0 20 0;
#X connect 8 0 7 0;
#X connect 9 0 8 0;
#X connect 10 0 9 0;
#X connect 11 0 12 0;
#X connect 12 0 20 0;
#X connect 14 0 21 0;
#X connect 16 0 15 0;
#X connect 17 0 16 0;
#X connect 18 0 17 0;
#X connect 19 0 18 0;
#X connect 21 0 13 0;
#X restore 482 349 pd stuff;
#X obj 42 206 r \$0-add-link;
#X obj 483 247 physigs_dispatch \$0 table;
#N canvas 0 0 450 300 send-table 0;
#X obj 153 36 r \$0-table;
#X obj 153 63 list split 1;
#X obj 272 126 makefilename \$1-%d;
#X obj 153 92 route symbol float;
#X obj 153 126 makefilename \$1-%s;
#X obj 153 169 t b a;
#X obj 153 264 send;
#X obj 153 203 list append;
#X obj 153 228 list trim;
#X connect 0 0 1 0;
#X connect 1 0 3 0;
#X connect 1 1 7 1;
#X connect 2 0 5 0;
#X connect 3 0 4 0;
#X connect 4 0 5 0;
#X connect 5 0 7 0;
#X connect 5 1 6 1;
#X connect 7 0 8 0;
#X connect 8 0 6 0;
#X restore 43 289 pd send-table;
#N canvas 0 0 818 508 auto-link-length 0;
#X obj 71 21 inlet;
#X obj 321 142 outlet;
#X obj 103 185 switch~;
#X msg 103 124 1;
#X msg 150 122 0;
#N canvas 0 0 450 300 print-it 0;
#X obj 77 77 inlet;
#X obj 77 198 outlet;
#X obj 113 159 print switch;
#X obj 208 102 tgl 15 0 empty empty empty 17 7 0 10 -262144 -1 -1 0
1;
#X obj 113 136 spigot;
#X connect 0 0 4 0;
#X connect 0 0 1 0;
#X connect 3 0 4 1;
#X connect 4 0 2 0;
#X coords 0 -1 1 1 130 20 1 100 100;
#X restore 103 161 pd print-it;
#X obj 71 62 t b b;
#X text 148 46 switch off after one block;
#X obj 150 67 bang~;
#X obj 506 313 tabread~ \$1-pos-y;
#X obj 367 311 tabread~ \$1-pos-y;
#X obj 232 310 tabread~ \$1-pos-x;
#X obj 72 308 tabread~ \$1-pos-x;
#X obj 71 215 spigot;
#X obj 120 215 tgl 15 0 empty empty empty 17 7 0 10 -262144 -1 -1 0
1;
#X obj 72 257 tabreceive~ \$1-link-m2;
#X obj 232 257 tabreceive~ \$1-link-m1;
#X msg 167 206 set \$1 1 1;
#X obj 167 185 r \$0-num-links;
#N canvas 292 57 436 349 get-vector-length-and-diff 0;
#X obj 81 64 inlet~;
#X obj 134 64 inlet~;
#X obj 221 65 inlet~;
#X obj 273 65 inlet~;
#X text 86 43 x1;
#X text 135 44 x2;
#X text 220 46 y1;
#X text 274 49 y2;
#X obj 82 128 -~;
#X obj 221 98 -~;
#X obj 220 126 *~;
#X obj 82 152 *~;
#X obj 81 186 +~;
#X obj 81 216 sqrt~;
#X text 27 217 |p2-p1|;
#X obj 81 246 outlet~;
#X obj 174 247 outlet~;
#X obj 267 245 outlet~;
#X connect 0 0 8 0;
#X connect 1 0 8 1;
#X connect 2 0 9 0;
#X connect 3 0 9 1;
#X connect 8 0 11 0;
#X connect 8 0 11 1;
#X connect 8 0 16 0;
#X connect 9 0 10 0;
#X connect 9 0 10 1;
#X connect 9 0 17 0;
#X connect 10 0 12 1;
#X connect 11 0 12 0;
#X connect 12 0 13 0;
#X connect 13 0 15 0;
#X restore 71 364 pd get-vector-length-and-diff;
#X obj 72 428 tabsend~ \$1-link-length;
#X connect 0 0 6 0;
#X connect 3 0 5 0;
#X connect 4 0 5 0;
#X connect 5 0 2 0;
#X connect 6 0 13 0;
#X connect 6 1 3 0;
#X connect 8 0 4 0;
#X connect 8 0 1 0;
#X connect 9 0 19 3;
#X connect 10 0 19 2;
#X connect 11 0 19 1;
#X connect 12 0 19 0;
#X connect 14 0 13 1;
#X connect 15 0 12 0;
#X connect 15 0 10 0;
#X connect 16 0 11 0;
#X connect 16 0 9 0;
#X connect 17 0 2 0;
#X connect 18 0 17 0;
#X connect 19 0 20 0;
#X restore 232 351 pd auto-link-length;
#X obj 232 326 r \$0-auto-link-length;
#X obj 483 270 physigs_dispatch \$0 auto-link-length;
#X obj 483 293 physigs_dispatch \$0 save;
#X obj 483 315 physigs_dispatch \$0 load;
#N canvas 280 161 979 443 save-load 1;
#X msg 87 131 pos-x \, pos-y \, mass \, mobile \, link-m1 \, link-m2
\, link-k \, link-d \, link-length;
#X text 274 108 This is what we save;
#X obj 87 61 r \$0-save;
#X obj 87 89 list;
#X obj 87 109 t b a;
#X text 162 60 must be a directory name!;
#X obj 87 198 list prepend \$1;
#X obj 87 167 t a a;
#X obj 87 231 list append;
#X msg 87 252 write \$3/\$2.dat \$1-\$2;
#X obj 87 282 list split 2;
#X obj 87 314 list trim;
#X obj 87 341 send;
#X text 249 251 tbalename last!;
#X msg 517 125 pos-x \, pos-y \, mass \, mobile \, link-m1 \, link-m2
\, link-k \, link-d \, link-length;
#X text 704 102 This is what we save;
#X obj 517 83 list;
#X obj 517 103 t b a;
#X text 592 54 must be a directory name!;
#X obj 517 192 list prepend \$1;
#X obj 517 161 t a a;
#X obj 517 225 list append;
#X obj 517 276 list split 2;
#X obj 517 308 list trim;
#X obj 517 335 send;
#X text 679 245 tbalename last!;
#X obj 517 55 r \$0-load;
#X msg 517 246 read \$3/\$2.dat \$1-\$2;
#X msg 451 49 DIRNAME;
#X connect 0 0 7 0;
#X connect 2 0 3 0;
#X connect 3 0 4 0;
#X connect 4 0 0 0;
#X connect 4 1 8 1;
#X connect 6 0 8 0;
#X connect 7 0 6 0;
#X connect 8 0 9 0;
#X connect 9 0 10 0;
#X connect 10 0 11 0;
#X connect 10 1 12 1;
#X connect 11 0 12 0;
#X connect 14 0 20 0;
#X connect 16 0 17 0;
#X connect 17 0 14 0;
#X connect 17 1 21 1;
#X connect 19 0 21 0;
#X connect 20 0 19 0;
#X connect 21 0 27 0;
#X connect 22 0 23 0;
#X connect 22 1 24 1;
#X connect 23 0 24 0;
#X connect 26 0 16 0;
#X connect 27 0 22 0;
#X connect 28 0 16 0;
#X restore 552 349 pd save-load;
#X connect 0 0 1 0;
#X connect 3 0 2 1;
#X connect 5 0 11 0;
#X connect 6 0 0 0;
#X connect 7 0 12 0;
#X connect 12 0 16 0;
#X connect 14 0 15 0;
#X connect 15 0 18 0;
#X connect 16 0 17 0;
#X connect 17 0 21 0;
#X connect 18 0 19 0;
#X connect 19 0 24 0;
#X connect 21 0 14 0;
#X connect 23 0 2 0;
#X connect 24 0 28 0;
#X connect 27 0 26 0;
#X connect 28 0 29 0;
#X connect 29 0 30 0;