Here’s the YouTube link to my demo.
Here’s also my Hydra code…
//hydra
let p5 = new P5()
s0.init({src: p5.canvas})
// in a browser you'll want to hide the canvas
p5.hide();
// no need for setup
p5.noFill()
p5.strokeWeight(20);
p5.stroke(255);
let circlePositions = [
{ x: p5.width / 4, y: p5.height / 2, size: 300 }, // First circle
{ x: (p5.width / 4) * 3, y: p5.height / 2, size: 300 } // Second circle
];
p5.draw = () => {
p5.background(0);
// first circle
p5.ellipse(circlePositions[0].x, circlePositions[0].y, circlePositions[0].size, circlePositions[0].size);
// second circle
p5.ellipse(circlePositions[1].x, circlePositions[1].y, circlePositions[1].size, circlePositions[1].size);
}
p5.draw = ()=>{
p5.background(0);
if (cc[1]==1){
p5.ellipse(p5.width/2,p5.height/2,600*cc[0]+300*p5.noise(cc[0]),600*cc[0]+300*p5.noise(cc[0]));
} else {
p5.ellipse(p5.noise(cc[0]*2)*p5.width,cc[0]*p5.height,300,300);
}
}
src(s0).modulate(noise(3, 0.6), 0.03).mult(osc(1, 0, 1)).diff(src(o1)).out()
src(s0).modulate(noise(2, 0.9), .3).mult(osc(10, 0, 1)).diff(src(o1)).out()
src(s0).modulate(noise(5, 5), .9).mult(osc(80, 30, 100)).diff(src(o1)).out()
// feedback effects --> .1 - .6, osc 0 - 10
src(s0).modulate(noise (4, 1.5), .6).mult(osc(0, 10, 1)).out(o2)
src(o2)
.modulate(src(o1).add(solid(0, 0), -0.5), 0.005)
.blend(src(o0).add(o0).add(o0).add(o0), 0.1)
.out(o2)
render(o2)
hush()
…and my Tidal!
//tidal
d3 $ s "superpiano" >| note (scale "major" ("[7 11 2 4 7 21 4 2]") + "15") # room 0.4
d1 $ juxBy 0.6 (slow 8) $ sound "bd cp sn hh:3" # gain 1.5
d4 $ juxBy 0.6 (slow 3) $ s "blip" # gain 1.7
-- 1 to 4, then to 8
d2 $ whenmod 16 8 (# ccv ((segment 128 (range 0 127 saw)))) $ struct "<t(8,8)>" $ ccv ((segment 128 (range 40 120 rand))) # ccn "0" # s "midi"