rsc3/doc/help/ugen/panners/rotate2.help.scrbl

49 lines
1.6 KiB
Racket

#lang scribble/manual
@(require (for-label racket))
@title{(rotate2 x y pos)}
Rotate a sound field. rotate2 can be used for rotating an
ambisonic B-format sound field around an axis. rotate2 does an
equal power rotation so it also works well on stereo sounds. It
takes two audio inputs (x, y) and an angle control (pos). It
outputs two channels (x, y).
It computes:
xout = cos(angle) * xin + sin(angle) * yin
yout = cos(angle) * yin - sin(angle) * xin
where angle = pos * pi, so that -1 becomes -pi and +1 becomes +pi.
This allows you to use an lf-saw to do continuous rotation around a
circle.
The control pos is the angle to rotate around the circle from -1
to +1. -1 is 180 degrees, -0.5 is left, 0 is forward, +0.5 is
right, +1 is behind.
(let* ((p (mul (white-noise ar) 0.05))
(q (mul (mix (lf-saw ar (make-mce (list 200 200.37 201)) 0)) 0.03))
(encoded (add (pan-b2 p -0.5 1) (pan-b2 q -0.5 1)))
(rotated (rotate2 (mce-channel encoded 1)
(mce-channel encoded 2)
(mouse-x kr -1 1 0 0.1)))
(decoded (decode-b2 4
(mce-channel encoded 0)
(mce-channel rotated 0)
(mce-channel rotated 1)
0.5)))
(audition (out 0 decoded)))
Rotation of stereo sound, via LFO.
(let ((x (mul (pink-noise ar) 0.4))
(y (mul (lf-tri ar 800 0) (mul (lf-pulse kr 3 0 0.3) 0.2))))
(audition (out 0 (rotate2 x y (lf-saw kr 0.1 0)))))
Rotation of stereo sound, via mouse.
(let ((x (mix-fill 4 (lambda (_) (mul (lf-saw ar (rand 198 202) 0) 0.1))))
(y (mul (sin-osc ar 900 0) (mul (lf-pulse kr 3 0 0.3) 0.2))))
(audition (out 0 (rotate2 x y (mouse-x kr 0 2 0 0.1)))))