[PD-cvs] externals/nusmuk/msd2D 01_msd2Dtest.pd, NONE, 1.1 02_msd2Dadd.pd, NONE, 1.1 03_imsd2Dtest.pd, NONE, 1.1 04_msd2Dperf.pd, NONE, 1.1 Makefile.am, NONE, 1.1 help-msd2D.pd, NONE, 1.1 main.cpp, NONE, 1.1 package.txt, NONE, 1.1

cyrille nusmuk at users.sourceforge.net
Tue Apr 12 18:34:07 CEST 2005


Update of /cvsroot/pure-data/externals/nusmuk/msd2D
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv4342

Added Files:
	01_msd2Dtest.pd 02_msd2Dadd.pd 03_imsd2Dtest.pd 
	04_msd2Dperf.pd Makefile.am help-msd2D.pd main.cpp package.txt 
Log Message:


--- NEW FILE: 02_msd2Dadd.pd ---
#N canvas 534 65 716 776 10;
#X obj 129 376 t a;
#X obj 137 39 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1
-1;
#X msg 209 84 reset;
#X obj 52 15 loadbang;
#X obj 137 62 t b b b b b;
#X obj 313 605 print msd;
#X obj 52 583 msd2D --------------------------------;
#X msg 511 526 0 \, destroy;
#X obj 481 320 gemhead;
#X obj 481 343 world_light;
#X msg 191 106 mass fix 0 100 50 50;
#N canvas 177 95 946 729 synthese 0;
#X obj 140 66 t b f;
#X obj 55 219 print x1;
#X obj 180 139 + 1;
#X obj 160 107 f 0;
#X obj 236 45 inlet;
#X msg 214 315 \$1 50;
#X obj 214 337 line~;
#X obj 174 341 *~;
#X msg 309 315 \$1 50;
#X obj 309 337 line~;
#X obj 269 341 *~;
#X msg 402 317 \$1 50;
#X obj 402 339 line~;
#X obj 362 343 *~;
#X msg 494 315 \$1 50;
#X obj 494 337 line~;
#X obj 454 341 *~;
#X obj 311 389 dac~;
#X obj 185 255 / 200;
#X obj 311 261 / 200;
#X obj 402 263 / 200;
#X obj 499 261 / 500;
#X msg 595 318 \$1 50;
#X obj 595 340 line~;
#X obj 555 344 *~;
#X msg 690 318 \$1 50;
#X obj 690 340 line~;
#X obj 650 344 *~;
#X msg 783 320 \$1 50;
#X obj 783 342 line~;
#X obj 743 346 *~;
#X msg 875 318 \$1 50;
#X obj 875 340 line~;
#X obj 835 344 *~;
#X obj 692 392 dac~;
#X obj 172 285 osc~ 55;
#X obj 268 285 osc~ 110;
#X obj 453 286 osc~ 222;
#X obj 566 258 / 500;
#X obj 693 264 / 500;
#X obj 240 161 pack f f f;
#X obj 231 72 unpack f f;
#X obj 236 219 unpack f f;
#X obj 425 225 unpack f f;
#X obj 611 222 unpack f f;
#X obj 802 229 unpack f f;
#X obj 880 264 / 1000;
#X obj 783 266 / 1000;
#X obj 180 164 mod 8;
#X obj 517 190 route 0 2 1 3 4 5 6 7;
#X msg 204 519 \$1 50;
#X obj 204 541 line~;
#X obj 164 545 *~;
#X msg 299 519 \$1 50;
#X obj 299 541 line~;
#X obj 259 545 *~;
#X msg 392 521 \$1 50;
#X obj 392 543 line~;
#X obj 352 547 *~;
#X msg 484 519 \$1 50;
#X obj 484 541 line~;
#X obj 444 545 *~;
#X obj 301 593 dac~;
#X obj 175 459 / 200;
#X obj 301 465 / 200;
#X obj 392 467 / 200;
#X obj 489 465 / 500;
#X msg 585 522 \$1 50;
#X obj 585 544 line~;
#X obj 545 548 *~;
#X msg 680 522 \$1 50;
#X obj 680 544 line~;
#X obj 640 548 *~;
#X msg 773 524 \$1 50;
#X obj 773 546 line~;
#X obj 733 550 *~;
#X msg 865 522 \$1 50;
#X obj 865 544 line~;
#X obj 825 548 *~;
#X obj 682 596 dac~;
#X obj 162 489 osc~ 55;
#X obj 258 489 osc~ 110;
#X obj 351 491 osc~ 166;
#X obj 443 489 osc~ 222;
#X obj 544 492 osc~ 444;
#X obj 639 492 osc~ 890;
#X obj 732 494 osc~ 1113;
#X obj 824 492 osc~ 2229;
#X obj 556 462 / 500;
#X obj 683 468 / 500;
#X obj 226 423 unpack f f;
#X obj 415 429 unpack f f;
#X obj 601 426 unpack f f;
#X obj 792 433 unpack f f;
#X obj 870 468 / 1000;
#X obj 773 470 / 1000;
#X obj 361 287 osc~ 165;
#X obj 554 288 osc~ 267;
#X obj 649 288 osc~ 311;
#X obj 742 290 osc~ 444;
#X obj 834 288 osc~ 509;
#X connect 0 0 3 0;
#X connect 0 1 40 1;
#X connect 2 0 48 0;
#X connect 3 0 2 0;
#X connect 4 0 41 0;
#X connect 5 0 6 0;
#X connect 6 0 7 1;
#X connect 7 0 17 0;
#X connect 8 0 9 0;
#X connect 9 0 10 1;
#X connect 10 0 17 0;
#X connect 10 0 17 1;
#X connect 11 0 12 0;
#X connect 12 0 13 1;
#X connect 13 0 17 0;
#X connect 13 0 17 1;
#X connect 14 0 15 0;
#X connect 15 0 16 1;
#X connect 16 0 17 1;
#X connect 18 0 5 0;
#X connect 19 0 8 0;
#X connect 20 0 11 0;
#X connect 21 0 14 0;
#X connect 22 0 23 0;
#X connect 23 0 24 1;
#X connect 24 0 34 0;
#X connect 25 0 26 0;
#X connect 26 0 27 1;
#X connect 27 0 34 0;
#X connect 27 0 34 1;
#X connect 28 0 29 0;
#X connect 29 0 30 1;
#X connect 30 0 34 0;
#X connect 30 0 34 1;
#X connect 31 0 32 0;
#X connect 32 0 33 1;
#X connect 33 0 34 1;
#X connect 35 0 7 0;
#X connect 36 0 10 0;
#X connect 37 0 16 0;
#X connect 38 0 22 0;
#X connect 39 0 25 0;
#X connect 40 0 49 0;
#X connect 41 0 0 0;
#X connect 41 1 40 2;
#X connect 42 0 18 0;
#X connect 42 1 19 0;
#X connect 43 0 20 0;
#X connect 43 1 21 0;
#X connect 44 0 38 0;
#X connect 44 1 39 0;
#X connect 45 0 47 0;
#X connect 45 1 46 0;
#X connect 46 0 31 0;
#X connect 47 0 28 0;
#X connect 48 0 3 1;
#X connect 48 0 40 0;
#X connect 49 0 42 0;
#X connect 49 1 43 0;
#X connect 49 2 44 0;
#X connect 49 3 45 0;
#X connect 49 4 90 0;
#X connect 49 5 91 0;
#X connect 49 6 92 0;
#X connect 49 7 93 0;
#X connect 50 0 51 0;
#X connect 51 0 52 1;
#X connect 52 0 62 0;
#X connect 53 0 54 0;
#X connect 54 0 55 1;
#X connect 55 0 62 0;
#X connect 55 0 62 1;
#X connect 56 0 57 0;
#X connect 57 0 58 1;
#X connect 58 0 62 0;
#X connect 58 0 62 1;
#X connect 59 0 60 0;
#X connect 60 0 61 1;
#X connect 61 0 62 1;
#X connect 63 0 50 0;
#X connect 64 0 53 0;
#X connect 65 0 56 0;
#X connect 66 0 59 0;
#X connect 67 0 68 0;
#X connect 68 0 69 1;
#X connect 69 0 79 0;
#X connect 70 0 71 0;
#X connect 71 0 72 1;
#X connect 72 0 79 0;
#X connect 72 0 79 1;
#X connect 73 0 74 0;
#X connect 74 0 75 1;
#X connect 75 0 79 0;
#X connect 75 0 79 1;
#X connect 76 0 77 0;
#X connect 77 0 78 1;
#X connect 78 0 79 1;
#X connect 80 0 52 0;
#X connect 81 0 55 0;
#X connect 82 0 58 0;
#X connect 83 0 61 0;
#X connect 84 0 69 0;
#X connect 85 0 72 0;
#X connect 86 0 75 0;
#X connect 87 0 78 0;
#X connect 88 0 67 0;
#X connect 89 0 70 0;
#X connect 90 0 63 0;
#X connect 90 1 64 0;
#X connect 91 0 65 0;
#X connect 91 1 66 0;
#X connect 92 0 88 0;
#X connect 92 1 89 0;
#X connect 93 0 95 0;
#X connect 93 1 94 0;
#X connect 94 0 76 0;
#X connect 95 0 73 0;
#X connect 96 0 13 0;
#X connect 97 0 24 0;
#X connect 98 0 27 0;
#X connect 99 0 30 0;
#X connect 100 0 33 0;
#X restore 230 679 pd synthese;
#N canvas 311 224 316 299 gemmouse 0;
#X obj 114 29 gemmouse;
#X obj 114 136 pack f f;
#X obj 114 170 spigot;
#X obj 114 196 outlet;
#X obj 114 83 - 0;
#X obj 165 97 + 100;
#X obj 114 60 / 5;
#X obj 165 74 / -5;
#X obj 68 97 l;
#X obj 68 74 t b;
#X obj 36 37 inlet;
#X connect 0 0 6 0;
#X connect 0 1 7 0;
#X connect 0 2 2 1;
#X connect 1 0 2 0;
#X connect 2 0 8 1;
#X connect 4 0 1 0;
#X connect 5 0 1 1;
#X connect 6 0 4 0;
#X connect 7 0 5 0;
#X connect 8 0 3 0;
#X connect 9 0 8 0;
#X connect 10 0 9 0;
#X restore 253 493 pd gemmouse;
#X obj 253 472 gemhead;
#X msg 253 515 posX fix \$1;
#X msg 253 537 posY fix \$2;
#X msg 155 225 50 50;
#X msg 155 258 Xmax 100 \, Xmin 0 \, Ymax 100 \, Ymin 0;
#X msg 511 503 reset \, create \, lighting 1 \, 1;
#X obj 52 399 t b;
#N canvas 643 123 605 590 massrender 0;
#X obj 127 22 inlet;
#X obj 48 203 translateXYZ;
#X obj 48 229 sphere 0.1;
#X obj 127 86 / 12.5;
#X obj 127 109 - 4;
#X obj 192 87 / 12.5;
#X obj 192 110 - 4;
#X obj 64 114 gemhead;
#X obj 48 177 separator;
#X obj 48 153 any;
#X obj 127 57 unpack f f;
#X obj 125 136 t b f;
#X connect 0 0 10 0;
#X connect 1 0 2 0;
#X connect 3 0 4 0;
#X connect 4 0 11 0;
#X connect 5 0 6 0;
#X connect 6 0 1 2;
#X connect 7 0 9 1;
#X connect 8 0 1 0;
#X connect 9 0 8 0;
#X connect 10 0 3 0;
#X connect 10 1 5 0;
#X connect 11 0 9 0;
#X connect 11 1 1 1;
#X restore 141 657 pd massrender;
#N canvas 284 227 587 558 linkrender 0;
#X obj 93 25 inlet;
#X obj 93 117 / 12.5;
#X obj 93 140 - 4;
#X obj 147 118 / 12.5;
#X obj 147 141 - 4;
#X obj 35 134 gemhead;
#X obj 44 222 separator;
#X obj 44 192 any;
#X obj 93 164 t b f;
#X obj 93 69 unpack f f f f;
#X obj 44 265 curve 2;
#X obj 207 121 / 12.5;
#X obj 207 144 - 4;
#X obj 261 122 / 12.5;
#X obj 261 145 - 4;
#X obj 123 194 pack f f;
#X msg 123 217 \$1 \$2 0;
#X obj 207 193 pack f f;
#X msg 207 216 \$1 \$2 0;
#X connect 0 0 9 0;
#X connect 1 0 2 0;
#X connect 2 0 8 0;
#X connect 3 0 4 0;
#X connect 4 0 15 1;
#X connect 5 0 7 1;
#X connect 6 0 10 0;
#X connect 7 0 6 0;
#X connect 8 0 7 0;
#X connect 8 1 15 0;
#X connect 9 0 1 0;
#X connect 9 1 3 0;
#X connect 9 2 11 0;
#X connect 9 3 13 0;
#X connect 11 0 12 0;
#X connect 12 0 17 0;
#X connect 13 0 14 0;
#X connect 14 0 17 1;
#X connect 15 0 16 0;
#X connect 16 0 10 1;
#X connect 17 0 18 0;
#X connect 18 0 10 2;
#X restore 52 678 pd linkrender;
#X msg 221 231 mass mob 1 \$1 \$2 \$3;
#X obj 393 181 random 100;
#X msg 393 161 seed 1;
#X obj 318 181 random 100;
#X obj 241 163 random 100;
#X msg 318 160 seed 2;
#X msg 241 143 seed 3;
#X obj 241 183 + 100;
#X obj 221 210 pack f f f;
#X obj 79 208 t b;
#X obj 79 252 + 1;
#X obj 121 290 f;
#X obj 121 270 + 1;
#X obj 79 273 t f b;
#X msg 112 229 -1;
#X obj 79 229 f -1;
#X obj 70 317 pack f f;
#X obj 173 148 t b b b;
#X msg 129 350 link souple \$1 \$2 100 0.5 0.5;
#X obj 52 379 gemhead;
#X obj 511 547 gemwin;
#X obj 52 628 route linksPos massesPos massesSpeedsNo;
#X msg 52 499 forceX mob -200;
#X msg 52 420 bang \, get massesPos \, get linksPos \, get massesSpeeds
1 5 9 13 17 21 25 29;
#X obj 173 126 repeat 40;
#X obj 79 187 repeat 40;
#X msg 52 479 forceX mob 200;
#X text 175 41 Reset;
#X text 484 171 Random positions and masses;
#X text 370 502 1 Create window -->;
#X text 405 643 3 Drag mouse;
#X text 174 480 Add force;
#X msg 522 585 \; pd dsp 1;
#X text 396 591 2 SET DSP ON -->;
#X connect 0 0 6 0;
#X connect 1 0 4 0;
#X connect 2 0 0 0;
#X connect 3 0 4 0;
#X connect 4 0 47 0;
#X connect 4 1 16 0;
#X connect 4 1 17 0;
#X connect 4 2 46 0;
#X connect 4 3 10 0;
#X connect 4 4 2 0;
#X connect 4 4 36 0;
#X connect 4 4 28 0;
#X connect 4 4 24 0;
#X connect 4 4 27 0;
#X connect 6 0 43 0;
#X connect 6 1 5 0;
#X connect 7 0 42 0;
#X connect 8 0 9 0;
#X connect 10 0 0 0;
#X connect 12 0 14 0;
#X connect 12 0 15 0;
#X connect 13 0 12 0;
#X connect 14 0 6 0;
#X connect 15 0 6 0;
#X connect 16 0 12 0;
#X connect 17 0 0 0;
#X connect 18 0 42 0;
#X connect 19 0 45 0;
#X connect 22 0 0 0;
#X connect 23 0 30 2;
#X connect 24 0 23 0;
#X connect 25 0 30 1;
#X connect 26 0 29 0;
#X connect 27 0 25 0;
#X connect 28 0 26 0;
#X connect 29 0 30 0;
#X connect 30 0 22 0;
#X connect 31 0 37 0;
#X connect 32 0 34 0;
#X connect 32 0 35 0;
#X connect 32 0 37 1;
#X connect 33 0 38 1;
#X connect 34 0 33 1;
#X connect 35 0 38 0;
#X connect 35 1 33 0;
#X connect 36 0 37 1;
#X connect 37 0 32 0;
#X connect 38 0 40 0;
#X connect 39 0 26 0;
#X connect 39 1 25 0;
#X connect 39 2 23 0;
#X connect 40 0 0 0;
#X connect 41 0 19 0;
#X connect 43 0 21 0;
#X connect 43 1 20 0;
#X connect 43 2 11 0;
#X connect 44 0 6 0;
#X connect 45 0 6 0;
#X connect 46 0 39 0;
#X connect 47 0 31 0;
#X connect 48 0 6 0;

--- NEW FILE: main.cpp ---


/* 
 msd2D - mass spring damper model for Pure Data or Max/MSP

 Written by Nicolas Montgermont for a Master's train in Acoustic,
 Signal processing and Computing Applied to Music (ATIAM, Paris 6) 
 at La Kitchen supervised by Cyrille Henry.

 Based on Pure Data by Miller Puckette and others
 Use FLEXT C++ Layer by Thomas Grill (xovo at gmx.net)
 Based on pmpd by Cyrille Henry 


 Contact : Nicolas Montgermont, montgermont at la-kitchen.fr
	   Cyrille Henry, Cyrille.Henry at la-kitchen.fr

 This program is free software; you can redistribute it and/or                
 modify it under the terms of the GNU General Public License                  
 as published by the Free Software Foundation; either version 2               
 of the License, or (at your option) any later version.                       
                                                                             
 This program is distributed in the hope that it will be useful,              
 but WITHOUT ANY WARRANTY; without even the implied warranty of               
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                
 GNU General Public License for more details.                           
                                                                              
 You should have received a copy of the GNU General Public License           
 along with this program; if not, write to the Free Software                  
 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

 Version 0.01, 12.04.2005

*/

// include flext header
#include <flext.h>

#include <math.h>

// define constants
#define MSD2D_VERSION 0.01
#define nb_max_link   4000
#define nb_max_mass   4000
#define Id_length   20

// check for appropriate flext version
#if !defined(FLEXT_VERSION) || (FLEXT_VERSION < 401)
#error You need at least flext version 0.4.1
#endif

#define max(a,b) ( ((a) > (b)) ? (a) : (b) ) 
#define min(a,b) ( ((a) < (b)) ? (a) : (b) )

typedef struct _mass {
	t_symbol *Id;
	t_int nbr;
	t_int mobile;
	t_float invM;
	t_float speedX;
	t_float posX;
	t_float posX2;
	t_float forceX;
	t_float out_forceX;
	t_float speedY;
	t_float posY;
	t_float posY2;
	t_float forceY;
	t_float out_forceY;
	char Id_string[Id_length];
} t_mass;

typedef struct _link {
	t_symbol *Id;
	t_int nbr;
	t_mass *mass1;
	t_mass *mass2;
	t_float K1, D1, D2;
	t_float longx, longy, longueur;
	t_float distance_old;
	char Id_string[Id_length];
} t_link;

class msd2D:
	public flext_base
{
	FLEXT_HEADER_S(msd2D,flext_base,setup)	//class with setup
 
public:
	// constructor with no arguments
	msd2D(int argc,t_atom *argv)
	{
		nb_link = 0;
		nb_mass = 0;
		id_mass = 0;
		id_link = 0;

		// --- define inlets and outlets ---
		AddInAnything("bang, reset, etc."); 	// default inlet
		AddOutAnything("infos on masses");	// outlet for integer count
		AddOutAnything("control");		// outlet for bang
	}

protected:

// ---------------------------------------------------------------  RESET 

	void m_reset() 
	{ 
		t_int i;
		t_atom sortie[0];

		for (i=0; i<nb_mass; i++)	{
			delete mass[i];
			}
		for (i=0; i<nb_link; i++)	{
			delete link[i];
			}
		ToOutAnything(1,gensym("Reset"),0,sortie);
		nb_link = 0;
		nb_mass = 0;
		id_mass = 0;
		id_link = 0;
	}

// --------------------------------------------------------------  COMPUTE 

	void m_bang()
	{
		t_float F=0,Fx=0,Fy=0,distance,vitesse, X_new, Y_new;
		t_int i;
		struct _mass mass_1, mass_2;
	
		for (i=0; i<nb_link; i++)	{
		// compute link forces
			distance = sqrt(pow(link[i]->mass1->posX-link[i]->mass2->posX,2) + 
				pow(link[i]->mass1->posY-link[i]->mass2->posY,2));
			F  = link[i]->K1 * (distance - link[i]->longueur) ;	// F = k1(x1-x2)
			F += link[i]->D1 * (distance - link[i]->distance_old) ;	// F = F + D1(v1-v2)
			if (distance != 0) 	{
				Fx = F * (link[i]->mass1->posX - link[i]->mass2->posX)/distance;
				Fy = F * (link[i]->mass1->posY - link[i]->mass2->posY)/distance;
			}
			link[i]->mass1->forceX -= Fx;
			link[i]->mass1->forceX -= link[i]->D2*link[i]->mass1->speedX;
			link[i]->mass2->forceX += Fx;
			link[i]->mass2->forceX -= link[i]->D2*link[i]->mass2->speedX;
			link[i]->mass1->forceY -= Fy;
			link[i]->mass1->forceY -= link[i]->D2*link[i]->mass1->speedY;
			link[i]->mass2->forceY += Fy;
			link[i]->mass2->forceY -= link[i]->D2*link[i]->mass2->speedY;
			link[i]->distance_old = distance;
		}

		for (i=0; i<nb_mass; i++)
		// compute new masses position only if mobile = 1
			if (mass[i]->mobile == 1)  		{
				X_new = mass[i]->forceX * mass[i]->invM + 2*mass[i]->posX - mass[i]->posX2;
				mass[i]->posX2 = mass[i]->posX;
				mass[i]->posX = max(min(X_new,Xmax),Xmin);			// x = x + v
				mass[i]->speedX = mass[i]->posX - mass[i]->posX2;	// v = v + F/M
				Y_new = mass[i]->forceY * mass[i]->invM + 2*mass[i]->posY - mass[i]->posY2;
				mass[i]->posY2 = mass[i]->posY;
				mass[i]->posY = max(min(Y_new,Ymax),Ymin);			// x = x + v
				mass[i]->speedY = mass[i]->posY - mass[i]->posY2;	// v = v + F/M
				}

		for (i=0; i<nb_mass; i++)	{
		// clear forces
			mass[i]->out_forceX = mass[i]->forceX;
			mass[i]->forceX = 0;
			mass[i]->out_forceY = mass[i]->forceY;
			mass[i]->forceY = 0;
		}
	}

// --------------------------------------------------------------  MASSES

	void m_mass(int argc,t_atom *argv) 
	// add a mass
	// Id, nbr, mobile, invM, speedX, posX, forceX
	{
		t_atom sortie[6], aux[2];
		int M;

		mass[nb_mass] = new t_mass;			// new pointer
		mass[nb_mass]->Id = GetASymbol(argv[0]);	// ID
		mass[nb_mass]->mobile = GetAInt(argv[1]);	// mobile
		if (GetAInt(argv[2])==0)
			M=1;
		else M = GetAInt(argv[2]);			
		mass[nb_mass]->invM = 1/((float)M);		// invM
		mass[nb_mass]->speedX = 0;			// vx[n]
		mass[nb_mass]->posX = GetAInt(argv[3]);		// x[n]
		mass[nb_mass]->posX2 = GetAInt(argv[3]);	// x[n-1]
		mass[nb_mass]->forceX = 0;			// Fx[n]
		mass[nb_mass]->speedY = 0;			// vy[n]
		mass[nb_mass]->posY = GetAInt(argv[4]);		// y[n]
		mass[nb_mass]->posY2 = GetAInt(argv[4]);	// y[n-1]
		mass[nb_mass]->forceY = 0;			// Fy[n]
		mass[nb_mass]->nbr = id_mass;			// id_nbr
		SETSYMBOL(aux,GetASymbol(argv[0]));
		atom_string(aux,mass[nb_mass]->Id_string,Id_length);
		nb_mass++ ;
		id_mass++;
		nb_mass = min ( nb_max_mass -1, nb_mass );
		SETFLOAT(&(sortie[0]),id_mass-1);
		SETSYMBOL(&(sortie[1]),GetASymbol(argv[0]));
		SETFLOAT(&(sortie[2]),mass[nb_mass-1]->mobile);
		SETFLOAT(&(sortie[3]),M);
		SETFLOAT(&(sortie[4]),mass[nb_mass-1]->posX);
		SETFLOAT(&(sortie[5]),mass[nb_mass-1]->posY);
		ToOutAnything(1,gensym("Mass"),6,sortie);
	}

	void m_forceX(int argc,t_atom *argv) 
	{
	// add a force to mass(es) named Id
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, Id_length);
		for (i=0; i<nb_mass;i++)
		{
			aux = strcmp(buffer,mass[i]->Id_string);
			if (aux == 0)
				mass[i]->forceX += GetAFloat(argv[1]);
		}
	}

	void m_forceY(int argc,t_atom *argv) 
	{
	// add a force to mass(es) named Id
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, Id_length);
		for (i=0; i<nb_mass;i++)
		{
			aux = strcmp(buffer,mass[i]->Id_string);
			if (aux == 0)
				mass[i]->forceY += GetAFloat(argv[1]);
		}
	}

	void m_posX(int argc,t_atom *argv) 
	{
	// displace mass(es) named Id to a certain position
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		if (GetAFloat(argv[1]) < Xmax && GetAFloat(argv[1]) > Xmin)
		{
			SETSYMBOL(atom,GetASymbol(argv[0]));
			atom_string(atom, buffer, Id_length);
			for (i=0; i<nb_mass;i++)
			{
				aux = strcmp(buffer,mass[i]->Id_string);
				if (aux == 0)
					mass[i]->posX = GetAFloat(argv[1]);
			}
		}
	}

	void m_posY(int argc,t_atom *argv) 
	{
	// displace mass(es) named Id to a certain position
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		if (GetAFloat(argv[1]) < Ymax && GetAFloat(argv[1]) > Ymin)
		{
			SETSYMBOL(atom,GetASymbol(argv[0]));
			atom_string(atom, buffer, Id_length);
			for (i=0; i<nb_mass;i++)
			{
				aux = strcmp(buffer,mass[i]->Id_string);
				if (aux == 0)
					mass[i]->posY = GetAFloat(argv[1]);
			}
		}
	}

	void m_set_mobile(int argc,t_atom *argv) 
	{
	// set mass No to mobile
		t_int i,aux;
		
		aux = GetAInt(argv[0]);	
		for (i=0; i<nb_mass;i++)
			{
				if (mass[i]->nbr == aux)
					mass[i]->mobile = 1;
			}
	
	}

	void m_set_fixe(int argc,t_atom *argv) 
	{
	// set mass No to fixed
		t_int i,aux;
		
		aux = GetAInt(argv[0]);	
		for (i=0; i<nb_mass;i++)
			{
				if (mass[i]->nbr == aux)
					mass[i]->mobile = 0;
			}
	
	}

	void m_delete_mass(int argc,t_atom *argv) 
	{
	// Delete mass
	t_int i,nb_link_delete=0;
	t_atom sortie[6], aux[nb_link];
	
	for (i=0; i<nb_link;i++)	{
		if (link[i]->mass1->nbr == GetAInt(argv[0]) || link[i]->mass2->nbr == GetAInt(argv[0]))	{
			SETFLOAT(&(aux[nb_link_delete]),link[i]->nbr);
			nb_link_delete++;
		}
	}

	for (i=0; i<nb_link_delete;i++)
		m_delete_link(1,&aux[i]);


	for (i=0; i<nb_mass;i++)
		if (mass[i]->nbr == GetAInt(argv[0]))	{
			SETFLOAT(&(sortie[0]),mass[i]->nbr);
			SETSYMBOL(&(sortie[1]),mass[i]->Id);
			SETFLOAT(&(sortie[2]),mass[i]->mobile);
			SETFLOAT(&(sortie[3]),1/mass[i]->invM);
			SETFLOAT(&(sortie[4]),mass[i]->posX);
			SETFLOAT(&(sortie[5]),mass[i]->posY);
			delete mass[i];
			mass[i] = mass[nb_mass-1];
			nb_mass--;
			ToOutAnything(1,gensym("Mass deleted"),6,sortie);
			break;
		}
	}


	void m_Xmax(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
	Xmax = GetAFloat(argv[0]);
	}

	void m_Ymax(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
	Ymax = GetAFloat(argv[0]);
	}

	void m_Xmin(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
	Xmin = GetAFloat(argv[0]);
	}

	void m_Ymin(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
	Ymin = GetAFloat(argv[0]);
	}

// --------------------------------------------------------------  LINKS 

	void m_link(int argc,t_atom *argv) 
	// add a link
	// Id, nbr, *mass1, *mass2, K1, D1
	{
		t_atom sortie[7], aux[2];
		t_int i;

		link[nb_link] = new t_link;
		link[nb_link]->Id = GetASymbol(argv[0]);
		for (i=0; i<nb_mass;i++)
			if (mass[i]->nbr==GetAInt(argv[1]))
				link[nb_link]->mass1 = mass[i];
			else if(mass[i]->nbr==GetAInt(argv[2]))
				link[nb_link]->mass2 = mass[i];
		link[nb_link]->K1 = GetAFloat(argv[3]);
		link[nb_link]->D1 = GetAFloat(argv[4]);	
		link[nb_link]->D2 = GetAFloat(argv[5]);
		link[nb_link]->longx = link[nb_link]->mass1->posX - link[nb_link]->mass2->posX;
		link[nb_link]->longy = link[nb_link]->mass1->posY - link[nb_link]->mass2->posY;
		link[nb_link]->longueur = sqrt( pow(link[nb_link]->longx,2) + pow(link[nb_link]->longy,2));
		link[nb_link]->nbr = id_link;
		link[nb_link]->distance_old = link[nb_link]->longueur;
		SETSYMBOL(aux,GetASymbol(argv[0]));
		atom_string(aux,(link[nb_link]->Id_string),Id_length);
		nb_link++;
		id_link++;
		nb_link = min ( nb_max_link -1, nb_link );
		SETFLOAT(&(sortie[0]),id_link-1);
		SETSYMBOL(&(sortie[1]),link[nb_link-1]->Id);
		SETFLOAT(&(sortie[2]),GetAInt(argv[1]));
		SETFLOAT(&(sortie[3]),GetAInt(argv[2]));
		SETFLOAT(&(sortie[4]),link[nb_link-1]->K1);
		SETFLOAT(&(sortie[5]),link[nb_link-1]->D1);
		SETFLOAT(&(sortie[6]),link[nb_link-1]->D2);
		ToOutAnything(1,gensym("Link"),7,sortie);
	}

	void m_ilink(int argc,t_atom *argv) 
	// add interactor link
	// Id, nbr, Id masses1, Id masses2, K1, D1
	{
		t_atom aux[2], arglist[6];
		t_int i,j, strvalue, strvalue2, imass1[nb_mass], nbmass1=0, imass2[nb_mass], nbmass2=0;
		char buffer[Id_length], buffer2[Id_length];

		ToOutAnything(1,gensym("iLink"),0,aux);
		SETSYMBOL(aux,GetASymbol(argv[1]));
		atom_string(aux, buffer, Id_length);
		SETSYMBOL(aux,GetASymbol(argv[2]));
		atom_string(aux, buffer2, Id_length);

		for (i=0;i<nb_mass;i++)	{
			strvalue=strcmp(buffer,mass[i]->Id_string);
			strvalue2=strcmp(buffer2,mass[i]->Id_string);
			if (strvalue ==0)	{
				imass1[nbmass1]=i;
				nbmass1++;
			}
			if (strvalue2 ==0)	{
				imass2[nbmass2]=i;
				nbmass2++;
			}
		}
		
		for(i=0;i<nbmass1;i++)
			for(j=0;j<nbmass2;j++)	
				if (imass1[i] != imass2[j])	{
					SETSYMBOL(&(arglist[0]),GetASymbol(argv[0]));
					SETFLOAT(&(arglist[1]),mass[imass1[i]]->nbr);
					SETFLOAT(&(arglist[2]),mass[imass2[j]]->nbr);
					SETFLOAT(&(arglist[3]),GetAInt(argv[3]));
					SETFLOAT(&(arglist[4]),GetAFloat(argv[4]));
					SETFLOAT(&(arglist[5]),GetAFloat(argv[5]));
					m_link(6,arglist);
				}
	}

	void m_setK(int argc,t_atom *argv) 
	{
	// set rigidity of link(s) named Id
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, Id_length);
		for (i=0; i<nb_link;i++)
		{
			aux = strcmp(buffer,link[i]->Id_string);
			if (aux == 0)
				link[i]->K1 = GetAFloat(argv[1]);
		}
	}

	void m_setD(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, Id_length);
		for (i=0; i<nb_link;i++)
		{
			aux = strcmp(buffer,link[i]->Id_string);
			if (aux == 0)
				link[i]->D1 = GetAFloat(argv[1]);
		}
	}

	void m_setD2(int argc,t_atom *argv) 
	{
	// set damping of link(s) named Id
		t_int i,aux;
		t_atom atom[2];
		char buffer[Id_length];

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, Id_length);
		for (i=0; i<nb_link;i++)
		{
			aux = strcmp(buffer,link[i]->Id_string);
			if (aux == 0)
				link[i]->D2 = GetAFloat(argv[1]);
		}
	}

	void m_delete_link(int argc,t_atom *argv) 
	{
	// Delete link
	t_int i;
	t_atom sortie[7];

	for (i=0; i<nb_link;i++)
		if (link[i]->nbr == GetAInt(argv[0]))	{
			SETFLOAT(&(sortie[0]),link[i]->nbr);
			SETSYMBOL(&(sortie[1]),link[i]->Id);
			SETFLOAT(&(sortie[2]),link[i]->mass1->nbr);
			SETFLOAT(&(sortie[3]),link[i]->mass2->nbr);
			SETFLOAT(&(sortie[4]),link[i]->K1);
			SETFLOAT(&(sortie[5]),link[i]->D1);
			SETFLOAT(&(sortie[6]),link[i]->D2);
			delete link[i];
			link[i]=link[nb_link-1];
			nb_link--;
			ToOutAnything(1,gensym("Link deleted"),7,sortie);
			break;
		}
	}


// --------------------------------------------------------------  GET 

	void m_get(int argc,t_atom *argv)
	// get attributes
	{
		t_int i,j, auxstring1, auxstring2, auxstring3, aux;
		t_symbol *auxarg;
		t_atom sortie[4],atom[2];
		char buffer[Id_length],masses[]="massesPos",buffer2[Id_length], forces[] = "massesForces", links[] = "linksPos";

		SETSYMBOL(atom,GetASymbol(argv[0]));
		atom_string(atom, buffer, 20);
		auxstring1 = strcmp(buffer,masses);	//auxstring1 : 0 masses, 1 else
		auxstring2 = strcmp(buffer,forces);	//auxstring2 : 0 forces, 1 else
		auxstring3 = strcmp(buffer,links);	//auxstring2 : 0 links, 1 else
		auxarg = GetASymbol(argv[1]);		//auxarg : & symbol, 0 else
		if (argc == 1)
		{
			if (auxstring1 == 0)// get all masses positions
				for (i=0; i<nb_mass; i++)
				{
					SETFLOAT(&sortie[0],mass[i]->posX);
					SETFLOAT(&sortie[1],mass[i]->posY);
					ToOutAnything(0,gensym("massesPos"),2,sortie);
				}
			else if (auxstring2 == 0)// get all masses forces
				for (i=0; i<nb_mass; i++)
				{
					SETFLOAT(&sortie[0],mass[i]->out_forceX);
					SETFLOAT(&sortie[1],mass[i]->out_forceY);
					ToOutAnything(0,gensym("massesForces"),2,sortie);
				}
			else if (auxstring3 == 0)// get all links positions
				for (i=0; i<nb_link; i++)
				{
					SETFLOAT(&sortie[0],link[i]->mass1->posX);
					SETFLOAT(&sortie[1],link[i]->mass1->posY);
					SETFLOAT(&sortie[2],link[i]->mass2->posX);
					SETFLOAT(&sortie[3],link[i]->mass2->posY);
					ToOutAnything(0,gensym("linksPos"),4,sortie);
				}
			else 		// get all masses speeds
				for (i=0; i<nb_mass; i++)
				{
					SETFLOAT(&sortie[0],mass[i]->speedX);
					SETFLOAT(&sortie[1],mass[i]->speedY);
					ToOutAnything(0,gensym("massesSpeeds"),2,sortie);
				}
		}
		else if (auxstring1 == 0) // get mass positions
		{
			if (auxarg == 0) // No
			{
				for (j = 1; j<argc; j++)
					for (i=0;i<nb_mass;i++)
						if (mass[i]->nbr==GetAInt(argv[j]))
						{
							SETFLOAT(&sortie[0],mass[i]->posX);
							SETFLOAT(&sortie[1],mass[i]->posY);
							ToOutAnything(0,gensym("massesPosNo"),2,sortie);
						}
			}
			else 		//string
			{
				for (j = 1; j<argc; j++)
				{
					SETSYMBOL(&atom[1],GetASymbol(argv[j]));
					atom_string(&atom[1], buffer2, Id_length);
					for (i=0;i<nb_mass;i++)	
					{
						
						aux = strcmp(buffer2,mass[i]->Id_string);
						if (aux==0)
						{
							SETFLOAT(&sortie[0],mass[i]->posX);
							SETFLOAT(&sortie[1],mass[i]->posY);
							ToOutAnything(0,gensym("massesPosId"),2,sortie);
						}
					}
				}
			}
		}
		else if (auxstring2 == 0)			 // get mass forces
		{
			if (auxarg == 0) // No
			{
				for (j = 1; j<argc; j++)
					for (i=0;i<nb_mass;i++)
						if (mass[i]->nbr==GetAInt(argv[j]))
						{
							SETFLOAT(&sortie[0],mass[i]->out_forceX);
							SETFLOAT(&sortie[1],mass[i]->out_forceY);
							ToOutAnything(0,gensym("massesForcesNo"),2,sortie);
						}
			}
			else 		//string
			{
				for (j = 1; j<argc; j++)
				{
					SETSYMBOL(&atom[1],GetASymbol(argv[j]));
					atom_string(&atom[1], buffer2, Id_length);
					for (i=0;i<nb_mass;i++)	
					{
		
						aux = strcmp(buffer2,mass[i]->Id_string);
						if (aux==0)
						{
							SETFLOAT(&sortie[0],mass[i]->out_forceX);
							SETFLOAT(&sortie[1],mass[i]->out_forceY);
							ToOutAnything(0,gensym("massesForcesId"),2,sortie);
						}
					}
				}
			}
		}
		else if (auxstring3 == 0)			 // get links positions
		{
			if (auxarg == 0) // No
			{
				for (j = 1; j<argc; j++)
					for (i=0;i<nb_link;i++)
						if (link[i]->nbr==GetAInt(argv[j]))
						{
							SETFLOAT(&sortie[0],link[i]->mass1->posX);
							SETFLOAT(&sortie[1],link[i]->mass1->posY);
							SETFLOAT(&sortie[2],link[i]->mass2->posX);
							SETFLOAT(&sortie[3],link[i]->mass2->posY);
							ToOutAnything(0,gensym("linksPosNo"),4,sortie);
						}
			}
			else 		//string
			{
				for (j = 1; j<argc; j++)
				{
					SETSYMBOL(&atom[1],GetASymbol(argv[j]));
					atom_string(&atom[1], buffer2, Id_length);
					for (i=0;i<nb_link;i++)	
					{
		
						aux = strcmp(buffer2,link[i]->Id_string);
						if (aux==0)
						{
							SETFLOAT(&sortie[0],link[i]->mass1->posX);
							SETFLOAT(&sortie[1],link[i]->mass1->posY);
							SETFLOAT(&sortie[2],link[i]->mass2->posX);
							SETFLOAT(&sortie[3],link[i]->mass2->posY);
							ToOutAnything(0,gensym("linksPosId"),4,sortie);
						}
					}
				}
			}
		}
		else 			 // get mass speeds
		{
			if (auxarg == 0) // No
			{
				for (j = 1; j<argc; j++)
					for (i=0;i<nb_mass;i++)
						if (mass[i]->nbr==GetAInt(argv[j]))
						{
							SETFLOAT(&sortie[0],mass[i]->speedX);
							SETFLOAT(&sortie[1],mass[i]->speedY);
							ToOutAnything(0,gensym("massesSpeedsNo"),2,sortie);
						}
			}
			else 		//string
			{
				for (j = 1; j<argc; j++)
				{
					SETSYMBOL(&atom[1],GetASymbol(argv[j]));
					atom_string(&atom[1], buffer2, Id_length);
					for (i=0;i<nb_mass;i++)	
					{
		
						aux = strcmp(buffer2,mass[i]->Id_string);
						if (aux==0)
						{
							SETFLOAT(&sortie[0],mass[i]->speedX);
							SETFLOAT(&sortie[1],mass[i]->speedY);
							ToOutAnything(0,gensym("massesSpeedsId"),2,sortie);
						}
					}
				}
			}
		}
		

	}

	void m_mass_dumpl()
	// List of masses positions on first outlet
	{	
		t_atom sortie[2*nb_mass];
		t_int i;
	
		for (i=0; i<nb_mass; i++)	{
			SETFLOAT(&(sortie[2*i]),mass[i]->posX);
			SETFLOAT(&(sortie[2*i+1]),mass[i]->posY);
		}
		ToOutAnything(0, gensym("massesPosL"), 2*nb_mass, sortie);
	}

	void m_force_dumpl()
	// List of masses positions on first outlet
	{	
		t_atom sortie[2*nb_mass];
		t_int i;
	
		for (i=0; i<nb_mass; i++)	{
			SETFLOAT(&(sortie[2*i]),mass[i]->out_forceX);
			SETFLOAT(&(sortie[2*i+1]),mass[i]->out_forceY);
		}
		ToOutAnything(0, gensym("massesForcesL"), 2*nb_mass, sortie);
	}

	void m_link_dumpl()
	// List of masses positions on first outlet
	{	
		t_atom sortie[2*nb_link];
		t_int i;
	
		for (i=0; i<nb_link; i++)	{
			SETFLOAT(&(sortie[2*i]),link[i]->mass1->nbr);
			SETFLOAT(&(sortie[2*i+1]),link[i]->mass2->nbr);
		}
		ToOutAnything(0, gensym("linksMassesL"), 2*nb_link, sortie);
	}

	void m_info_dumpl()
	// List of masses positions on first outlet
	{	
		t_atom sortie[7];
		t_int i;
	
		for (i=0; i<nb_mass; i++)	{
			SETFLOAT(&(sortie[0]),mass[i]->nbr);
			SETSYMBOL(&(sortie[1]),mass[i]->Id);
			SETFLOAT(&(sortie[2]),mass[i]->mobile);
			SETFLOAT(&(sortie[3]),1/mass[i]->invM);
			SETFLOAT(&(sortie[4]),mass[i]->posX);
			SETFLOAT(&(sortie[5]),mass[i]->posY);
		ToOutAnything(1, gensym("Mass"), 6, sortie);
		}

		for (i=0; i<nb_link; i++)	{
			SETFLOAT(&(sortie[0]),link[i]->nbr);
			SETSYMBOL(&(sortie[1]),link[i]->Id);
			SETFLOAT(&(sortie[2]),link[i]->mass1->nbr);
			SETFLOAT(&(sortie[3]),link[i]->mass2->nbr);
			SETFLOAT(&(sortie[4]),link[i]->K1);
			SETFLOAT(&(sortie[5]),link[i]->D1);
			SETFLOAT(&(sortie[6]),link[i]->D2);
		ToOutAnything(1, gensym("Link"), 7, sortie);
		}

	}

// --------------------------------------------------------------  GLOBAL VARIABLES 

	t_link * link[nb_max_link];
	t_mass * mass[nb_max_mass];
	t_float Xmin, Xmax, Ymin, Ymax;
	int nb_link, nb_mass, id_mass, id_link;

// --------------------------------------------------------------  SETUP

private:

	static void setup(t_classid c)
	{
		// --- set up meth(i=0; i<nb_link;i++)ods (class scope) ---

		// register a bang method to the default inlet (0)
		FLEXT_CADDBANG(c,0,m_bang);

		// set up tagged methods for the default inlet (0)
		// the underscore _ after CADDMETHOD indicates that a message tag is used
		// no, variable list or anything and all single arguments are recognized automatically, ...
		FLEXT_CADDMETHOD_(c,0,"reset",m_reset);
		FLEXT_CADDMETHOD_(c,0,"forceX",m_forceX);
		FLEXT_CADDMETHOD_(c,0,"forceY",m_forceY);
		FLEXT_CADDMETHOD_(c,0,"posX",m_posX);
		FLEXT_CADDMETHOD_(c,0,"Xmax",m_Xmax);
		FLEXT_CADDMETHOD_(c,0,"Xmin",m_Xmin);
		FLEXT_CADDMETHOD_(c,0,"Ymax",m_Ymax);
		FLEXT_CADDMETHOD_(c,0,"Ymin",m_Ymin);
		FLEXT_CADDMETHOD_(c,0,"posY",m_posY);
		FLEXT_CADDMETHOD_(c,0,"setK",m_setK);
		FLEXT_CADDMETHOD_(c,0,"setD",m_setD);
		FLEXT_CADDMETHOD_(c,0,"setD2",m_setD2);
		FLEXT_CADDMETHOD_(c,0,"mass",m_mass);
		FLEXT_CADDMETHOD_(c,0,"link",m_link);
		FLEXT_CADDMETHOD_(c,0,"iLink",m_ilink);
		FLEXT_CADDMETHOD_(c,0,"get",m_get);
		FLEXT_CADDMETHOD_(c,0,"deleteLink",m_delete_link);
		FLEXT_CADDMETHOD_(c,0,"deleteMass",m_delete_mass);
		FLEXT_CADDMETHOD_(c,0,"massesPosL",m_mass_dumpl);
		FLEXT_CADDMETHOD_(c,0,"infosL",m_info_dumpl);
		FLEXT_CADDMETHOD_(c,0,"linksMassesL",m_link_dumpl);
		FLEXT_CADDMETHOD_(c,0,"massesForcesL",m_force_dumpl);
		FLEXT_CADDMETHOD_(c,0,"setMobile",m_set_mobile);
		FLEXT_CADDMETHOD_(c,0,"setFixed",m_set_fixe);
	}

	// for every registered method a callback has to be declared
	FLEXT_CALLBACK(m_bang)
	FLEXT_CALLBACK(m_mass_dumpl)
	FLEXT_CALLBACK(m_force_dumpl)
	FLEXT_CALLBACK(m_link_dumpl)
	FLEXT_CALLBACK(m_info_dumpl)
	FLEXT_CALLBACK(m_reset)
	FLEXT_CALLBACK_V(m_mass)
	FLEXT_CALLBACK_V(m_link)
	FLEXT_CALLBACK_V(m_ilink)
	FLEXT_CALLBACK_V(m_set_mobile)
	FLEXT_CALLBACK_V(m_set_fixe)
	FLEXT_CALLBACK_V(m_Xmax)
	FLEXT_CALLBACK_V(m_Xmin)
	FLEXT_CALLBACK_V(m_Ymax)
	FLEXT_CALLBACK_V(m_Ymin)
	FLEXT_CALLBACK_V(m_setK)
	FLEXT_CALLBACK_V(m_setD)
	FLEXT_CALLBACK_V(m_setD2)
	FLEXT_CALLBACK_V(m_forceX)
	FLEXT_CALLBACK_V(m_forceY)
	FLEXT_CALLBACK_V(m_posX)
	FLEXT_CALLBACK_V(m_posY)
	FLEXT_CALLBACK_V(m_get)
	FLEXT_CALLBACK_V(m_delete_link)
	FLEXT_CALLBACK_V(m_delete_mass)
};

// instantiate the class (constructor has a variable argument list)
FLEXT_NEW_V("msd2D",msd2D)



--- NEW FILE: help-msd2D.pd ---
#N canvas 0 0 823 885 10;
#X obj 51 13 cnv 15 610 305 empty empty CREATION 20 12 0 14 -262131
-66577 0;
#X msg 68 42 reset;
#X text 238 73 Add a mass;
#X text 324 74 \$1 : Id (symbol);
#X text 323 94 \$2 : fixed or mobile (0/1);
#X text 323 112 \$3 : mass;
#X text 323 150 \$1 : Id (symbol);
#X text 235 150 Add a link;
#X text 322 170 \$2 : creation No of mass1;
#X text 322 188 \$3 : creation No of mass2;
#X text 321 206 \$4 : rigidity;
#X text 240 43 Delete all masses and links;
#X text 321 224 \$5 : viscosity;
#X text 321 241 \$6 : damping;
#X obj 51 323 cnv 15 610 60 empty empty COMPUTATION 20 12 0 14 -261689
-66577 0;
#X msg 71 352 bang;
#X text 224 352 Compute new masses positions;
#X obj 50 387 cnv 15 610 220 empty empty DYNAMIC_SETTING 20 12 0 14
-262131 -66577 0;
#X msg 158 409 setD \$1 \$2;
#X text 343 427 \$1 : Id (symbol);
#X text 343 445 \$2 : New value;
#X msg 76 409 setK \$1 \$2;
#X text 339 481 \$1 : Id (symbol);
#X text 339 499 \$2 : New value;
#X text 337 538 \$1 : Id (symbol);
#X text 337 556 \$2 : New value;
#X msg 76 461 posX \$1 \$2;
#X text 339 463 Set position of mass(es);
#X text 336 521 Add force on mass(es);
#X msg 74 520 forceX \$1 \$2;
#X msg 244 409 setD2 \$1 \$2;
#X text 343 409 Set rigidity \, viscosity or damping of link(s);
#X obj 49 616 cnv 15 610 198 empty empty GET_ATTRIBUTES 20 12 0 14
-261689 -66577 0;
#X msg 135 643 massePosL;
#X msg 135 671 masseForcesL;
#X text 236 643 output all masses positions in a list on outlet No
1;
#X text 235 672 output all masses forces in a list on outlet No 1;
#X msg 134 709 get \$1 \$2;
#X text 237 710 Get specific attribute;
#X text 237 735 \$1 : Attribute type ( massesPos / massesSpeeds / massesForces
/ linksPos );
#X text 237 772 \$2 : Id (symbol or creations numbers);
#X msg 65 150 link \$1 \$2 \$3 \$4 \$5 \$6;
#X msg 64 257 deleteMass \$1;
#X text 229 259 Delete a mass and associated links;
#X text 319 276 \$1 : Creation No of mass;
#X msg 63 293 deleteLink \$1;
#X text 228 295 Delete a link;
#X text 329 295 \$1 : Creation No of link;
#X msg 132 792 infosL;
#X text 235 792 Get infos on all masses and links on outlet No 2;
#X text 336 592 \$1 : Value;
#X obj 22 820 msd2D;
#X msg 169 519 forceY \$1 \$2;
#X msg 158 461 posY \$1 \$2;
#X msg 68 73 mass \$1 \$2 \$3 \$4 \$5;
#X text 323 130 \$4 \, \$5 : position;
#X msg 73 572 Xmin \$1 \, Xmax \$1 \, Ymin \$1 \, Ymax \$1;
#X text 336 575 Set minimimum and maximum of masses positions;
#X connect 1 0 51 0;
#X connect 15 0 51 0;
#X connect 21 0 51 0;
#X connect 26 0 51 0;
#X connect 29 0 51 0;
#X connect 33 0 51 0;
#X connect 34 0 51 0;
#X connect 37 0 51 0;
#X connect 41 0 51 0;
#X connect 42 0 51 0;
#X connect 45 0 51 0;
#X connect 48 0 51 0;
#X connect 54 0 51 0;

--- NEW FILE: 01_msd2Dtest.pd ---
#N canvas 396 84 839 834 10;
#X obj 52 15 loadbang;
#X obj 314 524 print msd;
#X obj 633 647 gemwin;
#X msg 633 625 0 \, destroy;
#X obj 553 709 gemhead;
#X obj 553 732 world_light;
#X msg 633 562 reset \, create \, lighting 1 \, 1;
#X obj 53 499 msd2D --------------------------------;
#X obj 122 15 cnv 15 500 270 empty empty empty 20 12 0 14 -262131 -66577
0;
#X obj 135 261 t a;
#X obj 135 20 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262131 -1
-1;
#X msg 207 71 reset;
#X text 173 21 reset;
#X obj 135 42 t b b b b b;
#X msg 153 160 50 50;
#X msg 135 235 link souple \$1 \$2 \$3 \$4 \$5;
#X msg 170 140 mass mob 1 \$1 \$2 \$3;
#X msg 189 91 mass fix 0 100 50 50;
#X msg 171 116 100 20 10 \, 200 20 25;
#X msg 153 181 Xmax 100 \, Xmin 0 \, Ymax 100 \, Ymin 0;
#X obj 50 292 cnv 15 572 80 empty empty empty 20 12 0 14 -261689 -66577
0;
#X obj 53 300 gemhead;
#X obj 53 323 t b;
#X msg 53 345 bang \, get massesPos \, get linksPos;
#X text 413 87 CREATION : 3 MASSES \, 2 LINKS;
#X text 292 313 COMPUTE AND GET ALL MASSES AND LINKS POSITIONS;
#X obj 50 376 cnv 15 572 110 empty empty empty 20 12 0 14 -262131 -66577
0;
#X msg 82 442 forceX mob 100;
#X msg 85 383 setD souple 0.01;
#X msg 216 384 setK souple 1;
#X msg 85 403 setD souple 1;
#X msg 216 404 setK souple 2;
#X msg 208 443 forceY mob 100;
#X text 351 396 SET RIGIDITY AND VISCOSITY OF LINKS;
#X text 367 442 ADD FORCE ON ALL MOBILE MASSES;
#X obj 47 547 cnv 15 400 200 empty empty empty 20 12 0 14 -261689 -66577
0;
#N canvas 643 123 605 590 massrender 0;
#X obj 127 22 inlet;
#X obj 48 203 translateXYZ;
#X obj 48 229 sphere 0.1;
#X obj 127 86 / 12.5;
#X obj 127 109 - 4;
#X obj 192 87 / 12.5;
#X obj 192 110 - 4;
#X obj 64 114 gemhead;
#X obj 48 177 separator;
#X obj 48 153 any;
#X obj 127 57 unpack f f;
#X obj 125 136 t b f;
#X connect 0 0 10 0;
#X connect 1 0 2 0;
#X connect 3 0 4 0;
#X connect 4 0 11 0;
#X connect 5 0 6 0;
#X connect 6 0 1 2;
#X connect 7 0 9 1;
#X connect 8 0 1 0;
#X connect 9 0 8 0;
#X connect 10 0 3 0;
#X connect 10 1 5 0;
#X connect 11 0 9 0;
#X connect 11 1 1 1;
#X restore 134 591 pd massrender;
#N canvas 284 227 587 558 linkrender 0;
#X obj 93 25 inlet;
#X obj 93 117 / 12.5;
#X obj 93 140 - 4;
#X obj 147 118 / 12.5;
#X obj 147 141 - 4;
#X obj 35 134 gemhead;
#X obj 44 222 separator;
#X obj 44 192 any;
#X obj 93 164 t b f;
#X obj 93 69 unpack f f f f;
#X obj 44 265 curve 2;
#X obj 207 121 / 12.5;
#X obj 207 144 - 4;
#X obj 261 122 / 12.5;
#X obj 261 145 - 4;
#X obj 123 194 pack f f;
#X msg 123 217 \$1 \$2 0;
#X obj 207 193 pack f f;
#X msg 207 216 \$1 \$2 0;
#X connect 0 0 9 0;
#X connect 1 0 2 0;
#X connect 2 0 8 0;
#X connect 3 0 4 0;
#X connect 4 0 15 1;
#X connect 5 0 7 1;
#X connect 6 0 10 0;
#X connect 7 0 6 0;
#X connect 8 0 7 0;
#X connect 8 1 15 0;
#X connect 9 0 1 0;
#X connect 9 1 3 0;
#X connect 9 2 11 0;
#X connect 9 3 13 0;
#X connect 11 0 12 0;
#X connect 12 0 17 0;
#X connect 13 0 14 0;
#X connect 14 0 17 1;
#X connect 15 0 16 0;
#X connect 16 0 10 1;
#X connect 17 0 18 0;
#X connect 18 0 10 2;
#X restore 53 612 pd linkrender;
#X obj 53 562 route linksPos massesPos;
#X text 261 572 DISPLAY MASSES AND LINKS;
#X text 309 594 WITH GEM;
#X text 465 563 1 CREATE WINDOW -->;
#X text 464 626 3 AND DESTROY IT! -->;
#X text 464 594 2 DRAG THE STRUCTURE WITH THE MOUSE;
#X msg 135 213 0 1 5 0.5 0.5 \, 1 2 1 0.5 0;
#N canvas 731 296 450 300 gemmouse 0;
#X obj 189 77 gemmouse;
#X obj 189 184 pack f f;
#X obj 189 218 spigot;
#X obj 103 244 outlet;
#X obj 189 131 - 0;
#X obj 216 131 + 100;
#X obj 189 108 / 5;
#X obj 216 108 / -5;
#X obj 79 51 inlet;
#X obj 140 75 inlet;
#X obj 141 120 l;
#X obj 109 98 t b;
#X connect 0 0 6 0;
#X connect 0 1 7 0;
#X connect 0 2 2 1;
#X connect 1 0 2 0;
#X connect 2 0 10 1;
#X connect 4 0 1 0;
#X connect 5 0 1 1;
#X connect 6 0 4 0;
#X connect 7 0 5 0;
#X connect 8 0 11 0;
#X connect 9 0 10 1;
#X connect 10 0 3 0;
#X connect 11 0 10 0;
#X restore 53 674 pd gemmouse;
#X obj 53 653 gemhead;
#X msg 53 695 posX fix \$1;
#X msg 53 716 posY fix \$2;
#X text 204 677 SET FIXED MASS TO MOUSE POSITION;
#X connect 0 0 13 0;
#X connect 3 0 2 0;
#X connect 4 0 5 0;
#X connect 6 0 2 0;
#X connect 7 0 38 0;
#X connect 7 1 1 0;
#X connect 9 0 7 0;
#X connect 10 0 13 0;
#X connect 11 0 9 0;
#X connect 13 0 44 0;
#X connect 13 1 14 0;
#X connect 13 1 19 0;
#X connect 13 2 18 0;
#X connect 13 3 17 0;
#X connect 13 4 11 0;
#X connect 14 0 45 1;
#X connect 15 0 9 0;
#X connect 16 0 9 0;
#X connect 17 0 9 0;
#X connect 18 0 16 0;
#X connect 19 0 9 0;
#X connect 21 0 22 0;
#X connect 22 0 23 0;
#X connect 23 0 7 0;
#X connect 27 0 7 0;
#X connect 28 0 7 0;
#X connect 29 0 7 0;
#X connect 30 0 7 0;
#X connect 31 0 7 0;
#X connect 32 0 7 0;
#X connect 38 0 37 0;
#X connect 38 1 36 0;
#X connect 44 0 15 0;
#X connect 45 0 47 0;
#X connect 45 0 48 0;
#X connect 46 0 45 0;
#X connect 47 0 7 0;
#X connect 48 0 7 0;

--- NEW FILE: 03_imsd2Dtest.pd ---
#N canvas 483 96 839 834 10;
#X obj 52 15 loadbang;
#X obj 314 524 print msd;
#X obj 633 647 gemwin;
#X msg 633 625 0 \, destroy;
#X obj 553 709 gemhead;
#X obj 553 732 world_light;
#X msg 633 562 reset \, create \, lighting 1 \, 1;
#X obj 53 499 msd2D --------------------------------;
#X obj 122 15 cnv 15 500 270 empty empty empty 20 12 0 14 -262131 -66577
0;
#X obj 135 261 t a;
#X obj 135 20 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262131 -1
-1;
#X msg 221 71 reset;
#X text 173 21 reset;
#X msg 153 170 50 50;
#X msg 203 91 mass fix 0 100 50 50;
#X msg 169 192 Xmax 100 \, Xmin 0 \, Ymax 100 \, Ymin 0;
#X obj 50 292 cnv 15 572 80 empty empty empty 20 12 0 14 -261689 -66577
0;
#X obj 53 300 gemhead;
#X obj 53 323 t b;
#X obj 50 376 cnv 15 572 110 empty empty empty 20 12 0 14 -262131 -66577
0;
#X msg 82 442 forceX mob 100;
#X msg 85 383 setD souple 0.01;
#X msg 216 384 setK souple 1;
#X msg 85 403 setD souple 1;
#X msg 216 404 setK souple 2;
#X msg 208 443 forceY mob 100;
#X text 351 396 SET RIGIDITY AND VISCOSITY OF LINKS;
#X text 367 442 ADD FORCE ON ALL MOBILE MASSES;
#X obj 47 547 cnv 15 400 200 empty empty empty 20 12 0 14 -261689 -66577
0;
#N canvas 643 123 605 590 massrender 0;
#X obj 127 22 inlet;
#X obj 48 203 translateXYZ;
#X obj 127 86 / 12.5;
#X obj 127 109 - 4;
#X obj 192 87 / 12.5;
#X obj 192 110 - 4;
#X obj 64 114 gemhead;
#X obj 48 177 separator;
#X obj 48 153 any;
#X obj 127 57 unpack f f;
#X obj 125 136 t b f;
#X obj 48 229 sphere 0.2;
#X connect 0 0 9 0;
#X connect 1 0 11 0;
#X connect 2 0 3 0;
#X connect 3 0 10 0;
#X connect 4 0 5 0;
#X connect 5 0 1 2;
#X connect 6 0 8 1;
#X connect 7 0 1 0;
#X connect 8 0 7 0;
#X connect 9 0 2 0;
#X connect 9 1 4 0;
#X connect 10 0 8 0;
#X connect 10 1 1 1;
#X restore 134 591 pd massrender;
#N canvas 284 227 587 558 linkrender 0;
#X obj 93 25 inlet;
#X obj 93 117 / 12.5;
#X obj 93 140 - 4;
#X obj 147 118 / 12.5;
#X obj 147 141 - 4;
#X obj 35 134 gemhead;
#X obj 44 222 separator;
#X obj 44 192 any;
#X obj 93 164 t b f;
#X obj 93 69 unpack f f f f;
#X obj 44 265 curve 2;
#X obj 207 121 / 12.5;
#X obj 207 144 - 4;
#X obj 261 122 / 12.5;
#X obj 261 145 - 4;
#X obj 123 194 pack f f;
#X msg 123 217 \$1 \$2 0;
#X obj 207 193 pack f f;
#X msg 207 216 \$1 \$2 0;
#X connect 0 0 9 0;
#X connect 1 0 2 0;
#X connect 2 0 8 0;
#X connect 3 0 4 0;
#X connect 4 0 15 1;
#X connect 5 0 7 1;
#X connect 6 0 10 0;
#X connect 7 0 6 0;
#X connect 8 0 7 0;
#X connect 8 1 15 0;
#X connect 9 0 1 0;
#X connect 9 1 3 0;
#X connect 9 2 11 0;
#X connect 9 3 13 0;
#X connect 11 0 12 0;
#X connect 12 0 17 0;
#X connect 13 0 14 0;
#X connect 14 0 17 1;
#X connect 15 0 16 0;
#X connect 16 0 10 1;
#X connect 17 0 18 0;
#X connect 18 0 10 2;
#X restore 53 614 pd linkrender;
#X text 465 563 1 CREATE WINDOW -->;
#X text 464 626 3 AND DESTROY IT! -->;
#X text 464 594 2 DRAG THE STRUCTURE WITH THE MOUSE;
#N canvas 731 296 450 300 gemmouse 0;
#X obj 189 77 gemmouse;
#X obj 189 184 pack f f;
#X obj 189 218 spigot;
#X obj 103 244 outlet;
#X obj 189 131 - 0;
#X obj 216 131 + 100;
#X obj 189 108 / 5;
#X obj 216 108 / -5;
#X obj 79 51 inlet;
#X obj 140 75 inlet;
#X obj 141 120 l;
#X obj 109 98 t b;
#X connect 0 0 6 0;
#X connect 0 1 7 0;
#X connect 0 2 2 1;
#X connect 1 0 2 0;
#X connect 2 0 10 1;
#X connect 4 0 1 0;
#X connect 5 0 1 1;
#X connect 6 0 4 0;
#X connect 7 0 5 0;
#X connect 8 0 11 0;
#X connect 9 0 10 1;
#X connect 10 0 3 0;
#X connect 11 0 10 0;
#X restore 53 674 pd gemmouse;
#X obj 53 653 gemhead;
#X msg 53 695 posX fix \$1;
#X msg 53 716 posY fix \$2;
#X text 204 677 SET FIXED MASS TO MOUSE POSITION;
#X msg 186 150 mass mob 1 100 \$1 \$2;
#X obj 135 42 t b b b b b b;
#X msg 135 234 iLink inter mob mob 1 2.5 0.5;
#X msg 186 116 20 50 \, 23 61 \, 29 71 \, 39 77 \, 50 80 \, 61 77 \,
71 71 \, 77 61 \, 80 50 \, 77 39 \, 71 29 \, 61 23 \, 50 20 \, 39 23
\, 29 29 \, 23 39;
#X text 413 87 CREATION : 17 MASSES \, 2 iLINKS;
#X msg 152 215 iLink intf fix mob 10 2.5 0.5;
#X msg 625 711 0.9 0.9 0.9;
#X obj 53 562 route linksPos;
#X msg 53 345 bang \, get linksPos;
#X text 292 313 COMPUTE AND GET ALL LINKS POSITIONS;
#X text 260 572 DISPLAY LINKS WITH GEM;
#X connect 0 0 40 0;
#X connect 3 0 2 0;
#X connect 4 0 5 0;
#X connect 6 0 2 0;
#X connect 7 0 46 0;
#X connect 7 1 1 0;
#X connect 9 0 7 0;
#X connect 10 0 40 0;
#X connect 11 0 9 0;
#X connect 13 0 34 1;
#X connect 14 0 9 0;
#X connect 15 0 9 0;
#X connect 17 0 18 0;
#X connect 18 0 47 0;
#X connect 20 0 7 0;
#X connect 21 0 7 0;
#X connect 22 0 7 0;
#X connect 23 0 7 0;
#X connect 24 0 7 0;
#X connect 25 0 7 0;
#X connect 34 0 36 0;
#X connect 34 0 37 0;
#X connect 35 0 34 0;
#X connect 36 0 7 0;
#X connect 37 0 7 0;
#X connect 39 0 9 0;
#X connect 40 0 41 0;
#X connect 40 1 44 0;
#X connect 40 2 13 0;
#X connect 40 2 15 0;
#X connect 40 3 42 0;
#X connect 40 4 14 0;
#X connect 40 5 11 0;
#X connect 41 0 9 0;
#X connect 42 0 39 0;
#X connect 44 0 9 0;
#X connect 45 0 5 1;
#X connect 46 0 30 0;
#X connect 47 0 7 0;

--- NEW FILE: package.txt ---
NAME=msd2D
SRCS=main.cpp

--- NEW FILE: 04_msd2Dperf.pd ---
#N canvas 291 84 827 783 10;
#X obj 167 310 t a;
#X obj 167 33 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1
-1;
#X msg 239 84 reset;
#X obj 52 15 loadbang;
#X text 205 34 reset;
#X msg 281 402 forceX mob 100;
#X obj 167 55 t b b b b b;
#X obj 313 658 print msd;
#X obj 52 583 msd2D --------------------------------;
#X msg 461 409 0 \, destroy;
#X obj 481 320 gemhead;
#X obj 481 343 world_light;
#X msg 221 104 mass fix 0 100 50 50;
#N canvas 311 224 450 300 gemmouse 0;
#X obj 31 26 gemmouse;
#X obj 31 133 pack f f;
#X obj 31 167 spigot;
#X obj 31 193 outlet;
#X obj 31 80 - 0;
#X obj 82 94 + 100;
#X obj 31 57 / 5;
#X obj 82 71 / -5;
#X connect 0 0 6 0;
#X connect 0 1 7 0;
#X connect 0 2 2 1;
#X connect 1 0 2 0;
#X connect 2 0 3 0;
#X connect 4 0 1 0;
#X connect 5 0 1 1;
#X connect 6 0 4 0;
#X connect 7 0 5 0;
#X restore 393 540 pd gemmouse;
#X obj 360 524 gemhead;
#X obj 360 575 l;
#X obj 360 552 t b;
#X msg 360 602 posX fix \$1;
#X msg 360 623 posY fix \$2;
#X msg 185 192 50 50;
#X msg 167 261 Xmax 100 \, Xmin 0 \, Ymax 100 \, Ymin 0;
#X msg 460 386 reset \, create \, lighting 1 \, 1;
#X obj 52 301 t b;
#N canvas 643 123 605 590 massrender 0;
#X obj 127 22 inlet;
#X obj 48 203 translateXYZ;
#X obj 48 229 sphere 0.1;
#X obj 127 86 / 12.5;
#X obj 127 109 - 4;
#X obj 192 87 / 12.5;
#X obj 192 110 - 4;
#X obj 64 114 gemhead;
#X obj 48 177 separator;
#X obj 48 153 any;
#X obj 127 57 unpack f f;
#X obj 125 136 t b f;
#X connect 0 0 10 0;
#X connect 1 0 2 0;
#X connect 3 0 4 0;
#X connect 4 0 11 0;
#X connect 5 0 6 0;
#X connect 6 0 1 2;
#X connect 7 0 9 1;
#X connect 8 0 1 0;
#X connect 9 0 8 0;
#X connect 10 0 3 0;
#X connect 10 1 5 0;
#X connect 11 0 9 0;
#X connect 11 1 1 1;
#X restore 133 635 pd massrender;
#N canvas 284 227 587 558 linkrender 0;
#X obj 93 25 inlet;
#X obj 93 117 / 12.5;
#X obj 93 140 - 4;
#X obj 147 118 / 12.5;
#X obj 147 141 - 4;
#X obj 35 134 gemhead;
#X obj 44 222 separator;
#X obj 44 192 any;
#X obj 93 164 t b f;
#X obj 93 69 unpack f f f f;
#X obj 44 265 curve 2;
#X obj 207 121 / 12.5;
#X obj 207 144 - 4;
#X obj 261 122 / 12.5;
#X obj 261 145 - 4;
#X obj 123 194 pack f f;
#X msg 123 217 \$1 \$2 0;
#X obj 207 193 pack f f;
#X msg 207 216 \$1 \$2 0;
#X connect 0 0 9 0;
#X connect 1 0 2 0;
#X connect 2 0 8 0;
#X connect 3 0 4 0;
#X connect 4 0 15 1;
#X connect 5 0 7 1;
#X connect 6 0 10 0;
#X connect 7 0 6 0;
#X connect 8 0 7 0;
#X connect 8 1 15 0;
#X connect 9 0 1 0;
#X connect 9 1 3 0;
#X connect 9 2 11 0;
#X connect 9 3 13 0;
#X connect 11 0 12 0;
#X connect 12 0 17 0;
#X connect 13 0 14 0;
#X connect 14 0 17 1;
#X connect 15 0 16 0;
#X connect 16 0 10 1;
#X connect 17 0 18 0;
#X connect 18 0 10 2;
#X restore 52 656 pd linkrender;
#X msg 211 170 mass mob 1 \$1 \$2 \$3;
#X obj 379 180 random 100;
#X msg 380 158 seed 1;
#X obj 379 221 random 100;
#X obj 470 179 random 100;
#X msg 379 200 seed 2;
#X msg 470 157 seed 3;
#X obj 470 201 + 100;
#X obj 219 140 pack f f f;
#X obj 591 127 t b;
#X obj 591 171 + 1;
#X obj 627 221 f;
#X obj 628 196 + 1;
#X obj 568 204 t f b;
#X msg 622 148 -1;
#X obj 591 148 f -1;
#X obj 582 248 pack f f;
#X obj 380 134 t b b b;
#X msg 167 284 link souple \$1 \$2 100 0.5 0.5;
#X obj 52 278 gemhead;
#X obj 413 432 gemwin;
#X msg 52 335 bang \, get massesPos \, get linksPos;
#X obj 52 606 route linksPos massesPos;
#X msg 465 433 view 0 0 4 0 0 0 0 1 0;
#X msg 281 425 forceX mob -100;
#X obj 380 109 repeat 500;
#X obj 592 105 repeat 500;
#X msg 445 53 500;
#X text 478 52 change number of mass to test performance;
#X connect 0 0 8 0;
#X connect 1 0 6 0;
#X connect 2 0 0 0;
#X connect 3 0 6 0;
#X connect 5 0 8 0;
#X connect 6 0 51 0;
#X connect 6 1 19 0;
#X connect 6 1 20 0;
#X connect 6 2 50 0;
#X connect 6 3 12 0;
#X connect 6 4 2 0;
#X connect 6 4 39 0;
#X connect 6 4 31 0;
#X connect 6 4 27 0;
#X connect 6 4 30 0;
#X connect 8 0 47 0;
#X connect 8 1 7 0;
#X connect 9 0 45 0;
#X connect 10 0 11 0;
#X connect 12 0 0 0;
#X connect 13 0 15 1;
#X connect 14 0 16 0;
#X connect 15 0 17 0;
#X connect 15 0 18 0;
#X connect 16 0 15 0;
#X connect 17 0 8 0;
#X connect 18 0 8 0;
#X connect 19 0 15 0;
#X connect 20 0 0 0;
#X connect 21 0 45 0;
#X connect 22 0 46 0;
#X connect 25 0 0 0;
#X connect 26 0 33 2;
#X connect 27 0 26 0;
#X connect 28 0 33 1;
#X connect 29 0 32 0;
#X connect 30 0 28 0;
#X connect 31 0 29 0;
#X connect 32 0 33 0;
#X connect 33 0 25 0;
#X connect 34 0 40 0;
#X connect 35 0 37 0;
#X connect 35 0 38 0;
#X connect 35 0 40 1;
#X connect 36 0 41 1;
#X connect 37 0 36 1;
#X connect 38 0 41 0;
#X connect 38 1 36 0;
#X connect 39 0 40 1;
#X connect 40 0 35 0;
#X connect 41 0 43 0;
#X connect 42 0 29 0;
#X connect 42 1 28 0;
#X connect 42 2 26 0;
#X connect 43 0 0 0;
#X connect 44 0 22 0;
#X connect 46 0 8 0;
#X connect 47 0 24 0;
#X connect 47 1 23 0;
#X connect 48 0 45 0;
#X connect 49 0 8 0;
#X connect 50 0 42 0;
#X connect 51 0 34 0;
#X connect 52 0 50 1;
#X connect 52 0 51 1;

--- NEW FILE: Makefile.am ---
#
# automake template
# added by tim blechmann
#

NAME = msd2

BUILT_SOURCES = main.cpp

EXTRA_DIST = main.cpp \
	$(NAME).mcp \
	$(NAME).vcproj

CXXFLAGS  = @CXXFLAGS@ \
	@OPT_FLAGS@ \
	@INCLUDEDIR@ \
	-I../../source \
	$(DEFS) \
	-DFLEXT_SHARED

LDFLAGS = @DYNAMIC_LDFLAGS@ @LDFLAGS@ \
	$(patsubst %,-framework %,$(FRAMEWORKS))

LIBS = @LIBS@ -lflext-pd

FRAMEWORKS = @FRAMEWORKS@

TARGETDIR = @TARGETDIR@

TARGET =$(NAME). at EXTENSION@

OBJECTS = $(patsubst %.cpp,./%. at OBJEXT@,$(BUILT_SOURCES))

SYSDIR = @SYSDIR@


# ----------------------------- targets --------------------------------

all-local: $(OBJECTS)
	$(CXX) $(LDFLAGS) ./*. at OBJEXT@ $(LIBS) -o ../$(TARGETDIR)/$(TARGET)
	strip --strip-unneeded ../$(TARGETDIR)/$(TARGET)

./%. at OBJEXT@ : %.cpp 
	$(CXX) -c $(CXXFLAGS) $< -o $@

clean-local:
	rm -f ../$(TARGETDIR)/$(TARGET)
	rm -f ./$(OBJECTS)

install-exec-local:
	install ../$(TARGET) $(SYSDIR)extra





More information about the Pd-cvs mailing list