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

Low frequency noise generator

Discussion

Generates slowly varying random noise using by linearly interpolating between random values. The underlying random noise lies in the range [-1 +1). The module computes a new random value at the rate specified by .freq. If isSmoothed = 1, then linear interpolation is used between values. If isSmoothed = 0, then the output changes instantly effectively generating a square wave with constant period but random amplitudes.

Internally, the module uses a 32-bit linear congruential generator to generate random values. The initial seed of the random number generator is specified by .seed. If .fixCurrentSeed is 1, then the seed is fixed. This means that the prebuild function will not generate a new seed. By default, .fixCurrentSeed equals 0, and thus instances of the generator will produce different outputs.

Type Definition

typedef struct _ModuleRandi
{
    ModuleInstanceDescriptor instance;            // Common Audio Weaver module instance structure
    FLOAT32 freq;                                 // Rate at which random values are generated.
    INT32 isSmoothed;                             // Determines whether the random signal interpolates between random values (isSmoothed=1) or steps between random values (isSmoothed=0).
    FLOAT32 slope;                                // Slope value for linear interpolation between random values.
    FLOAT32 level;                                // The current value of the random signal.
    INT32 rate;                                   // Starting value for counter, dependent on freq.
    UINT32 seed;                                  // State of the random number generator.
    INT32 fixCurrentSeed;                         // Whether the prebuild function resets the seed or not. 0 = reset, 1 = no reset.
    INT32 counter;                                // Counter value is used in slewing between random values.
    FLOAT32 oneOverRate;                          // Used in calculating the slope value.
} ModuleRandiClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

freq

float

parameter

0

1000

0.01:24000

Hz

isSmoothed

int

parameter

0

1

0:1

slope

float

state

0

random value

Unrestricted

level

float

state

0

0

Unrestricted

rate

int

state

0

48

Unrestricted

seed

uint

state

0

random value

Unrestricted

fixCurrentSeed

int

parameter

0

0

0:1

counter

int

state

1

48

Unrestricted

oneOverRate

float

derived

1

0.02083

Unrestricted

Pins

Output Pins

Name: out

Description: audio output

Data type: float

MATLAB Usage

File Name: randi_module.m

 M=randi_module(NAME, SR, BLOCKSIZE)
 Creates a slowly varying random generator based on linear interpolation.
 This module has a single 1 channel output pin with controllable 
 frequency. The output of the module changes instantly when the 
 frequency is updated.  
 
 Arguments:
    NAME - name of the module.
    SR - sample rate.
    BLOCKSIZE - number of samples per output channel.

  • No labels