(8.D.1.2) Oscillator
Overview
Numerically-controlled oscillator
Discussion
Implements a discrete-time oscillator by using the input signal to adjust the nominal frequency driving a sinusoid generator. The output is $y[n] = \sin (omega_o nT + \sum_{k=0}^n x[k] + \phi)$ where $\omega_o$ is the nominal frequency in radians/s, T is the sample period and $\phi$ is the starting phase in radians (default is 0).
The internal variable freq caches the nominal frequency in units of radians/second. phase maintains the current phase in radians between blocks
Type Definition
typedef struct _ModuleOscillator
{
ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure
FLOAT32 freqhz; // Nominal oscillator frequency in Hz
FLOAT32 startPhase; // Starting phase oscillator in multiples of pi radians
FLOAT32 freq; // Current oscillator frequency
FLOAT32* phase; // Current oscillator phase
} ModuleOscillatorClass;
Variables
Properties
Name | Type | Usage | isHidden | Default value | Range | Units |
freqhz | float | parameter | 0 | 0 | 0:5000 | Hz |
startPhase | float | parameter | 0 | 0 | -1:1 | x pi radians |
freq | float | state | 1 | 0 | Unrestricted | radians/s |
phase | float* | state | 1 | [1 x 1] | Unrestricted | radians |
Pins
Input Pins
Name: control
Description: Frequency control input
Data type: float
Channel range: 1
Block size range: Unrestricted
Sample rate range: Unrestricted
Complex support: Real
Output Pins
Name: out
Description: Oscillator output
Data type: float
MATLAB Usage
File Name: oscillator_module.m
This module implements a sinusiodal oscillator whose output frequency is
determined by the input signal. It is derived from the sine generator.
Arguments:
NAME - name of the module.
QUAD - true means the output is 2 channels in quadrature