LiveCoding

From CCRMA Wiki
Revision as of 20:33, 21 January 2009 by Rob (Talk | contribs) (end luke code =============================)

Jump to: navigation, search

Page for Live Coding Examples from Luke's 12/21/2009 live-coding session

====================================================================
====================================================================

if you're bored...

http://www.youtube.com/watch?v=v4Wy7gRGgeA

Code Monkey by Jonathan Coulton

Code Monkey get up, get coffee
Code Monkey go to job
Code Monkey have boring meeting
Boring manager Rob
Rob say Code Monkey very diligent
But his output stink
His Code not functional or elegant
What do Code Monkey think?
Code Monkey think,
Maybe manager wanna write
Goddamn log-in page himself
Code Monkey not say it out loud
Code Monkey not crazy, just proud

Code Monkey like Fritos
Code Monkey like Tab and Mountain Dew
Code Monkey very simple man
Big, warm, fuzzy, secret heart
Code Monkey like you
Code Monkey like yooooouuuuu

Code Monkey hang around at front desk
Tell you sweater look nice
Code Monkey offer buy you soda
Bring you cup, bring you ice
You say no thank-you for the soda 'cause
Soda make you fat
Anyway, you busy with the telephone
No time for chat
Code Monkey have long walk back to cubicle
He sit down, pretend to work
Code Monkey not thinking so straight,
Code Monkey not feeling so great.

Code Monkey have every reason
To get out this place
Code Monkey just keep on working
See your soft pretty face
Much rather wake up, eat a coffee cake
Take bath, take nap
This job fulfilling and creative way
Such a load of crap
Code Monkey say someday he have everything
Even pretty girl, like you
Code Monkey just waiting, for now
Code Monkey say someday, somehow

Luke's Live Code:

// LC1: squares

// ----------------------------------------------- // bring tha noise // -----------------------------------------------

SqrOsc mosc => SqrOsc cosc => ADSR env => dac => Delay del => LPF flt => dac; 3::second => del.max; 2 => cosc.sync;

// some basic parms:

// pitch: Std.mtof(Std.rand2(20, 30)) => cosc.freq;

// pitch variation: Std.rand2f(5, 20) => mosc.gain;

// speed of pitch variation: 1 => mosc.freq;

// delay feedback (be careful here!): 0.7 => del.gain;

// length of delay: 100::ms => del.delay;

// delay filter stuff: Std.rand2f(500, 2000) => flt.freq; Std.rand2f(0.5, 1.0) => flt.Q;


// ----------------------------------------------- // make time // -----------------------------------------------

3.1::second => dur d; // how long it lasts 0.8 => float decay_frac; // what fraction is decay env.set( d*0.3, d*0.01, .5, d*decay_frac ); // attack, decay, sustain, release env.keyOn(); d*(1-decay_frac) => now; env.keyOff(); d*decay_frac + 2::second => now;

end luke code

David ==================================

/* Live Coding Test 1

   Have the user invoke different functions. */

Phasor s => Gain g => dac; 5000 => s.sfreq; 0 => s.sync; 0.5 => g.gain;

440.00 => float A; 466.16 => float Bb; 493.88 => float B; 523.25 => float C; 554.37 => float Db; 587.33 => float D; 622.25 => float Eb; 659.26 => float E; 698.46 => float F; 739.99 => float Gb; 783.99 => float G; 830.61 => float Ab;

fun void code1() {

   B => s.freq;
   0.5::second => now;
   E => s.freq;
   0.5::second => now;

}

fun void code2() {

   G => s.freq;
   0.25::second => now;
   E => s.freq;
   0.25::second => now;
   D => s.freq;
   0.25::second => now;

}

fun void code3() {

   A => s.freq;
   0.125::second => now;
   B => s.freq;
   0.125::second => now;

}

fun void code4() {

   Gb => s.freq;
   0.5::second => now;

}


/* SECTION ONE - SEQUENCING

   Any sequence of the following:
   code1();
   code2();
   code3();
   code4();
  • /

while(true) {

   code1();

}

end David code ==================================

Visda's Live code ==================================

// modulations SqrOsc mod => SinOsc car => Gain mult; // modulate the modulations Modulate vibe => mult => Envelope e => dac; // multiply 3 => mult.op; // sync 2 => car.sync; // envelope 5::second => e.duration;

//modulate between the three arrays

// an array //[ 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 2, 3, 4, 5, 6, 7, 8, 9,10 ] @=> int arri[];

// an array of melodic minor //[0,2,3,1,4,2,6,3,4,4] @=> int arri[]; //sequence data

// an array of major //[0,2,4,5,7,9,11,12] @=> int arri[]; //major scale

// vibrato 5 => vibe.gain; .1 => vibe.randomGain; .02 => vibe.vibratoRate;

while (true){

// modulator & carrier

Std.mtof( 300 + Std.rand2(0,10)* 50 + arri[Std.rand2(0, arri.cap()-3)]) => mod.freq; 5::ms => now;

// modulate it between mod 500 - car 100 for earth // or mod 100 - car 200 for space

4 => mod.gain; 100 => car.freq; 2 => car.gain;


   // go for it
   e.keyOn();
   e.duration() => now;
   e.keyOff();
   e.duration() => now;

}

second part of Visda's code ==================================

SinOsc s => JCRev r => dac; .3 => s.gain; .1 => r.mix;

// an array [ 5, 1, 5, 1, 5, 1, 5, 1, 5,1] @=> int arri[];


while (true) {

   Std.mtof( 300 + Std.rand2f(0,10)* 50 + arri[Std.rand2(0, arri.cap()-3)]) => s.freq;
   52::ms => now;
   Std.mtof( 333 + Std.rand2(1,10) * 200 + Math.sin(arri[Std.rand2(0, arri.cap()-1)])) => s.freq;
   120::ms => now;
    
   Std.mtof( 700 + Std.rand2f(0,9)* 50 + arri[Std.rand2(0, arri.cap()-6)]) => s.freq;
   3::ms => now;

}

end Visda's code ==================================

Mike Gao's Code ==================================

//MOVE DA MOUSE ON BEAT SOMETIMES SinOsc a => SinOsc b => Gain g => g => dac; 0 => int device; Hid hi; HidMsg msg; if( !hi.openMouse( device ) ) me.exit(); <<< "mouse '" + hi.name() + "' ready...", "" >>>; spork ~ mouser(); 220 => a.freq;

// TRY MULTIPLES OR FRACTIONS OF 100 100=>int duration;

for (;;) {

   Math.fabs(Math.tan(now/samp))*200 => b.freq;
   Math.fabs(Math.tan(now/ms))*100=>a.freq;
   Math.fabs(Math.tan(now/samp))=>a.gain;
   
   
   (now/ms)$int %3=>b.sync;
  
   duration::ms=>now;

}

fun void mouser() {

   for (;;) {
   while (hi.recv(msg))
   {
       if (msg.isMouseMotion())
       {
           msg.deltaX * 100=>b.freq;
           msg.deltaY * 300=>a.freq;
           //<<<msg.deltaX>>>;
           //(Math.fabs(msg.deltaX*100)+2) $ int => duration;
       }
       if (msg.isButtonDown())
       {
           0=>b.sync;
       }
       
        
   }
     hi=>now;
 }

}

End Mike's Code====================================