pol2rect

pol2rect — Conversion du format polaire au format rectangulaire.

Description

Convertit un tableau d'entrée du format module-argument au format réel-imaginaire.

Syntaxe

kout[] pol2rect kin[]
kout[] pol2rect kmags[], kphs[]

Exécution

kout[] -- tableau contenant les valeurs complexes réelles-imaginaires de sortie. Créé s'il n'existe pas.

kin[] -- tableau contenant les valeurs complexes modules-arguments d'entrée.

kmags[] -- tableau contenant les valeurs réelles des modules en entrée. Ne doit contenir que le spectre non-négatif (de 0 à la fréquence de Nyquist comprise).

kphs[] -- tableau contenant les valeurs réelles des phases en entrée. Ne doit contenir que le spectre non-négatif (de 0 à la fréquence de Nyquist comprise).

NB : la seconde version de l'opcode avec deux entrées est conçue pour produire un spectre de TFR réelle "compact" dans lequel les deux premières positions du tableau contiennent les parties réelles de zéro Hz et de la fréquence de Nyquist. Ainsi la longueur du tableau de sortie sera 2*L - 2, où L est la longueur des tableaux en entrée (qui doivent avoir la même longueur).

Exemples

Voici un exemple de l'opcode pol2rect. Il utilise le fichier pol2rect.csd.

Exemple 769. Exemple de l'opcode pol2rect.

Voir les sections Audio en temps réel et Options de la ligne de commande pour plus d'information sur l'utilisation des options de la ligne de commande.

<CsoundSynthesizer>
<CsOptions>
-d -o dac
</CsOptions>
<CsInstruments>
/* ksmps needs to be an integer div of
   hopsize */
ksmps = 64

instr 1

 ihopsize = 256   ; hopsize
 ifftsize = 1024  ; FFT size 
 iolaps = ifftsize/ihopsize ; overlaps
 ibw = sr/ifftsize ; bin bandwidth
 kcnt init 0    ; counting vars
 krow init 0

 kOla[] init ifftsize ; overlap-add buffer
 kIn[] init ifftsize  ; input buffer
 kOut[][] init iolaps, ifftsize ; output buffers

 a1 diskin2 "fox.wav",1,0,1 ; audio input

 /* every hopsize samples */
 if kcnt == ihopsize then  
   /* window and take FFT */
   kWin[] window kIn,krow*ihopsize
   kSpec[] rfft kWin
   
   kSpec rect2pol kSpec 
   
   /* reduce mags between high and low freqs */
   ilow = 0
   ihigh = 1000
   ki = int(ilow/ibw)
   until ki >= int(ihigh/ibw) do
     kSpec[ki] = kSpec[ki]*0.1
     ki += 2
   od
   
   kSpec pol2rect kSpec
   
   /* IFFT + window */
   kRow[] rifft kSpec
   kWin window kRow, krow*ihopsize
   /* place it on out buffer */
   kOut setrow kWin, krow

   /* zero the ola buffer */
   kOla = 0
   /* overlap-add */
   ki = 0
   until ki == iolaps do
     kRow getrow kOut, ki
     kOla = kOla + kRow
     ki += 1
   od
  
  /* update counters */ 
  krow = (krow+1)%iolaps
  kcnt = 0
 endif

 /* shift audio in/out of buffers */
 kIn shiftin a1
 a2 shiftout kOla
    out a2/iolaps

 /* increment counter */
 kcnt += ksmps

endin

</CsInstruments>
<CsScore>
i1 0 10
</CsScore>
</CsoundSynthesizer>

Voir aussi

Opcodes vectoriels, Opcodes de tableaux.

Crédits

Auteur : Victor Lazzarini
NUI Maynooth
2014

Nouveau dans la version 6.04