Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Current »

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

  • No labels