rsc3/doc/help/ugen/analysis/pitch.help.scrbl
2022-08-28 12:27:01 +02:00

52 lines
1.6 KiB
Racket

#lang scribble/manual
@(require (for-label racket))
@title{(pitch in initFreq minFreq maxFreq execFreq maxBinsPerOctave}
median ampThreshold peakThreshold downSample)
Autocorrelation pitch follower
This is a better pitch follower than zero-crossing, but more costly
of CPU. For most purposes the default settings can be used and only
in needs to be supplied. pitch returns two values (via an Array of
outputProxys, see the outputProxy help file), a freq which is the
pitch estimate and hasFreq, which tells whether a pitch was
found. Some vowels are still problematic, for instance a wide open
mouth sound somewhere between a low pitched short 'a' sound as in
'sat', and long 'i' sound as in 'fire', contains enough overtone
energy to confuse the algorithm.
sclang default argument values are: in = 0.0, initFreq = 440.0,
minFreq = 60.0, maxFreq = 4000.0, execFreq = 100.0,
maxBinsPerOctave = 16, median = 1, ampThreshold = 0.01,
peakThreshold = 0.5, downSample = 1.
@racketblock[
(define (pitch* in median ampThreshold)
(pitch in 444.0 60.0 4000.0 100.0 16 median ampThreshold 0.5 1))
]
@racketblock[
(let* ((in (mul (sin-osc ar (mouse-x kr 220 660 0 0.1) 0)
(mouse-y kr 0.05 0.25 0 0.1)))
(amp (amplitude kr in 0.05 0.05))
(freq+ (pitch* in 7 0.02))
(f (fdiv (car (mce-channels freq+)) 2))
(o (mul (sin-osc ar f 0) amp)))
(audition (out 0 (mce2 in o))))
]
@racketblock[
(let* ((in (sound-in 0))
(amp (amplitude kr in 0.05 0.05))
(freq+ (pitch* in 7 0.02))
(f (car (mce-channels freq+)))
(o (mul (sin-osc ar f 0) amp)))
(audition (out 0 (mce2 in o))))
]