beadsynt — Band-Enhanced Oscillator-Bank
Plugin opcode in beosc.
Band-Enhanced oscillator-bank, a port of Loris' oscillator (based on Supercollider's Beadsynt). Can work both with arrays and tables. The band-enhanced family of opcodes (beosc, beadsynt) implement sound modeling and synthesis that preserves the elegance and malleability of a sinusoidal model, while accommodating sounds with noisy (non-sinusoidal) components. Analysis is done offline, with an enhanced McAulay-Quatieri (MQ) style analysis that extracts bandwidth information in addition to the sinusoidal parameters for each partial. To produce noisy components, we synthesize with sine wave oscillators that have been modified to allow the introduction of variable bandwidth.
The synthesis can be controlled via a set of flags (see iflags), allowing to switch between unifrom or gaussian noise for the noise components, wavetable interpolation (switch off to save cpu), and freq. interpolation between k-cycles (switch off to save cpu)
| ![[Note]](images/note.png)  | Note | 
|---|---|
| The original implementation (Loris) uses gaussian (normal) noise for the non-sinusoidal components, which if implemented naively, as in loris, is very cpu intensive. The supercollider port uses simple uniform noise. We implement both, with a very efficient implementation of gaussian noise (using a precomputed table), which makes it as efficient as uniform noise. | 
aout beadsynt kFreqs[], kAmps[], kBws[] \
                   [, inumosc, iflags, kfreq, kbw, ifn, iphs ]
        aout beadsynt ifreqft, iampft, ibwft, inumosc \
                   [, iflags, kfreq, kbw, ifn, iphs ]
      ifreqft - A table holding the frequencies for each partial
iampft - A table holding the amplitudes for each partial
ibwft - A table holding the bandwidths for each partial
inumosc - the number of partials to resynthesize. In the array case, it can be left unset.
iflags - 0: uniform noise, 1:gaussian noise, +2: oscil linear interpolation, +4: freq. interpolation (default=1)
ifn - A table holding a sine wave (or -1 to use the builtin table) (default = -1)
iphs - Initial phase. -1: randomized, 0-1: initial phase, >1: table number holding the phases (default = -1)
aout - The generated sound
kFreqs[] - An array holding the frequencies of each partial
kAmps[] - An array holding the amplitudes of each partial
kBws[] - An array holding the bandwidths of each partial
kfreq - Freq. scaling, all frequencies are multiplied by this (default = 1)
kbw - Bandwidth scaling, all bandwidths are multiplied by this (default = 1)
| ![[Note]](images/note.png)  | Note | 
|---|---|
| 
       | 
Here is an example of the beadsynt opcode. It uses the file beadsynt.csd.
Example 94. Example of the beadsynt opcode.
See the sections Real-time Audio and Command Line Flags for more information on using command line flags.
<CsoundSynthesizer> <CsOptions> -odac </CsOptions> <CsInstruments> /* This is the example file for beadsynt beadsynt ======== Band-enhanced additive synthesis. A port of Loris' band-enhanced resynthesis algorithms (basen on Supercollider's BEOsc) The band-enhanced family of opcodes (beosc, beadsynt) implement sound modeling and synthesis that preserves the elegance and malleability of a sinusoidal model, while accommodating sounds with noisy (non-sinusoidal) components. Analysis is done offline, with an enhanced McAulay-Quatieri (MQ) style analysis that extracts bandwidth information in addition to the sinusoidal parameters for each partial. To produce noisy components, we synthesize with sine wave oscillators that have been modified to allow the introduction of variable bandwidth. Syntax ====== beadsynt exists in two forms, one using arrays, the other using f-tables aout beadsynt kFreqs[], kAmps[], kBws[], inumosc=-1, iflags=1, kfreq=1, kbw=1, ifn=-1, iphs=-1 aout beadsynt ifreqft, iampft, ibwft, inumosc, iflags=1, kfreq=1, kbw=1, ifn=-1, iphs=-1 kFreqs[]: an array holding the frequencies of each partial kAmps[]: an array holding the amplitudes of each partial kBws[]: an array holding the bandwidths of each partial ifreqft: a table holding the frequencies of each partial iampft: a table holding the amplitudes of each partial ibwft: a table holding the bandwidths of each partial inumosc: the number of partials to resynthesize (-1 to synthesize all) iflags: 0: uniform noise 1: gaussian noise +2: use linear interpolation for the oscil (similar to oscili) +4: freq interpolation kfreq: freq. scaling factor kbw: bandwidth scaling factor ifn: a table holding a sine wave (or -1 to use builtin sine) iphs: initial phase of the oscillators. -1: randomize phase (default) 0-1: initial phase >=1: table holding the phase for each oscillator (size>=inumosc) NB: kFreqs, kAmps and kBws must all be the same size (this also holds true for ifreqft, iampfr and ibwft) This example uses the analysis file fox.mtx.wav which was produced with loristrck_pack, see https://github.com/gesellkammer/loristrck */ sr = 44100 ksmps = 128 nchnls = 2 0dbfs = 1.0 gispectrum ftgen 0, 0, 0, -1, "fox.mtx.wav", 0, 0, 0 instr 1 ifn = gispectrum iskip tab_i 0, ifn idt tab_i 1, ifn inumcols tab_i 2, ifn inumrows tab_i 3, ifn itimestart tab_i 4, ifn inumpartials = inumcols / 3 imaxrow = inumrows - 2 it = ksmps / sr igain init 1 ispeed init 1 idur = imaxrow * idt / ispeed kGains[] init inumpartials kfilter init 0 ifreqscale init 1 kt timeinsts kplayhead = phasor:k(ispeed/idur)*idur krow = kplayhead / idt kF[] getrowlin krow, ifn, inumcols, iskip, 0, 0, 3 kA[] getrowlin krow, ifn, inumcols, iskip, 1, 0, 3 kB[] getrowlin krow, ifn, inumcols, iskip, 2, 0, 3 if(kt > idur*0.5) then kfilter = 1 endif if (kfilter == 1) then kGains bpf kF, 300, 0.001, 400, 1, 1000, 1, 1100, 0.001 kA *= kGains endif iflags = 0 ; uniform noise, no interpolation aout beadsynt kF, kA, kB, -1, iflags, ifreqscale if(kt > idur) then event "e", 0, 0, 0 endif aenv cosseg 0, 0.02, igain, idur-0.02-0.1, igain, 0.1, 0 aout *= aenv outs aout, aout endin schedule 1, 0, -1 </CsInstruments> <CsScore> </CsScore> </CsoundSynthesizer>