File: partial.alg

package info (click to toggle)
nyquist 3.12%2Bds-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 58,036 kB
  • sloc: ansic: 74,355; lisp: 20,485; java: 9,390; cpp: 6,695; sh: 207; xml: 58; makefile: 40
file content (20 lines) | stat: -rw-r--r-- 600 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
(PARTIAL-ALG
(NAME "partial")
(ARGUMENTS ("rate_type" "sr") ("double" "hz") ("sound_type" "env"))
(SUPPORT-FUNCTIONS "
#include \"sine.h\"
")
(START (MIN env))
(STATE ("long" "phase" "0")
       ("long" "ph_incr" "ROUND32((hz * SINE_TABLE_LEN) * (1 << SINE_TABLE_SHIFT) / sr)"))
(TERMINATE (MIN env))
(LOGICAL-STOP (MIN env))
(INNER-LOOP "output = sine_table[phase >> SINE_TABLE_SHIFT] * env;
            phase += ph_incr;
            phase &= SINE_TABLE_MASK;")
(MAINTAIN ("phase" 
 "susp->phase = (susp->phase + susp->ph_incr * togo) & SINE_TABLE_MASK"))
(CONSTANT "ph_incr")
(SAMPLE-RATE "sr")
)