/
Rand

Rand

Overview

Random number generator using a LCG algorithm

Discussion

Generates uniformly distributed random values using a linear congruential generator. The module outputs 32-bit integer values which can be interpretted as int or fract32 values. The random values occupy the entire numerical range. Integer values are in the range of [-2^31 +2^31) and fract32 values are in the range of [-1 +1).

The seed variable specifies the starting seed of the random process. After the module processes a block of data, the seed value equals the last output sample. When the module is instantiated, the seed value is randomly set by MATLAB.

Type Definition

typedef struct _ModuleRand { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure UINT32 seed; // Initial seed value for the random number generator. } ModuleRandClass;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

seed

uint

parameter

0

random value

Unrestricted

 

Pins

Output Pins

Name: out1

Description: audio output

Data type: fract32

MATLAB Usage

File Name: rand_module.m

M=rand_module(NAME, NUMPINS, NUMCHANNELS, BLOCKSIZE, SR, DATATYPE, ISCOMPLEX) Random number generator module supporting integer and fract32 signal types. The output signal is uncorrelated random data lying within the full range of the allowable signal values. Integer values are in the range of [-2^31 +2^31) and fract32 values are in the range of [-1 +1). The module supports multiple output pins in which all of the data is uncorrelated. Arguments: NAME - name of the module. NUMPINS - number of output pins. NUMCHANNELS - number of interleaved channels in each output pin. BLOCKSIZE - number of samples per output channel. SR - sample rate of the output. DATATYPE - string specifying either, 'int' or 'fract32'. ISCOMPLEX - boolean that indicates complex data.