#N canvas 2 1 650 610 12;
#X obj 114 560 pddp;
#X obj 8 3 cnv 15 90 578 empty empty empty 20 12 0 14 -233017 -66577
0;
#X text 14 223 ARGUMENTS:;
#X text 20 303 EXAMPLES:;
#X text 22 471 SEE ALSO:;
#N canvas 58 0 407 256 Related_Objects 0;
#X text 25 11 Native Pd Objects;
#X text 16 166 Externals and other object libraries;
#X obj 16 41 tabread~;
#X obj 90 41 tabread4;
#X obj 240 41 tabwrite~;
#X obj 16 67 tabsend~;
#X obj 92 67 tabreceive~;
#X obj 192 67 tabplay~;
#X obj 269 67 table;
#X text 15 124 [array];
#X obj 16 94 soundfiler;
#X text 78 124 and fft objects.;
#X text 21 187 [tabdump];
#X obj 112 94 tabread4~;
#X text 20 207 [tabenv];
#X obj 203 94 getsize;
#X obj 274 94 setsize;
#X text 238 207 [arraysize];
#X text 238 186 [score];
#X text 114 186 [linear_path];
#X text 114 207 [plot];
#X obj 165 41 tabread;
#X restore 114 508 pd Related_Objects;
#N canvas 80 0 661 319 More_Info 0;
#X text 28 257 Also See:;
#X obj 107 257 pddp_open all_about_arrays;
#X text 26 21 In this help document \, the [tabwrite] object is set
to write values to one of the two arrays you see on your screen. The
[tabwrite] will just as easily write values to tables buried in the
[table] object. This terminology is somewhat confusing \, but the objects
"array" and "table" exist separately because they offer different speeds
of performance.;
#X text 25 150 For example \, the;
#X obj 163 150 tabread;
#X text 229 150 documentation shows similar;
#X text 24 169 functionality using [table] instead of array. In this
particular document \, I chose to sacrifice speed for the sake of visually
displaying the effectiveness of [tabwrite].;
#X restore 114 534 pd More_Info;
#X obj 32 10 tabread;
#X floatatom 303 407 0 0 99 1 index - -;
#X text 29 278 OUTLETS:;
#X text 107 303 Open the tables and use your mouse to draw new values
in the arrays - otherwise [tabread] will always output "0".;
#X text 39 34 INLETS:;
#X text 112 470 doc/2.control.examples/15.arrays.pd;
#X text 113 489 doc/2.control.examples/16.more.arrays.pd;
#X text 111 10 - WRITE NUMBERS TO A TABLE;
#X text 38 50 - LEFT:;
#X text 107 51 Float - A float at the left inlet will become the new
value of the chosen index (whichever index is currently selected at
the right inlet).;
#X text 105 101 List - The left inlet also accepts pairs of floats
(longer lists will be truncated). A number pair represents "value"
and "index" - corresponding to "left" and "right" inlets.;
#X text 105 151 Set - the "set <arrayname>" message allows you to write
to dynamic locations. You can change the table at any time using the
"set" message.;
#X text 158 561 - Dave Sabine \, April 29 \, 2003;
#X text 29 203 - RIGHT:;
#X text 104 203 Float - selects which index in which to write the new
value.;
#X text 105 223 One - the argument informs [tabwrite] which array to
write to. The array must exist in an open Pd patch/canvas or an error
message will appear in the terminal window.;
#X text 104 277 None.;
#X obj 161 437 tabwrite davids_array;
#X msg 220 375 set another_array;
#X msg 204 346 set davids_array;
#X floatatom 148 381 0 0 0 0 value - -;
#N canvas 0 0 450 300 graph12 0;
#X array davids_array 100 float 1;
#A 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 2.75 0 0 0 0 0
0 0 0;
#X coords 0 1 99 -1 100 70 1;
#X restore 528 343 graph;
#N canvas 0 0 450 300 graph12 0;
#X array another_array 100 float 1;
#A 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 -0.67 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0;
#X coords 0 1 99 -1 100 70 1;
#X restore 528 417 graph;
#X connect 8 0 24 1;
#X connect 25 0 24 0;
#X connect 26 0 24 0;
#X connect 27 0 24 0;