/
PresetArrayHandlerV2

PresetArrayHandlerV2

Overview

Updates module array from different preset tables.

Discussion

This module updates the array of any other module from the values in presetsArray. The presetsArray is a 3-D array of numArrays, each with size numRows x numCols. The 3-D array is arranged as cascaded 2-D arrays For example, 3 arrays with size 2 x 3 each is arranged as 0 0 0 0 0 0 1 1 1 1 1 1 2 2 2 2 2 2 where 2x3 array with zeros is one array, 2x3 array with ones is second array and so on. The cascaded 2-D array is multiplied or added element by element to create one 2-D array of size numRows x numCols, which is then used to update the array of the other module. The math operation is controlled by the operation argument, either multiplication or addition. This module also has additional pointers in to the presetArray memory, useful for standalone tuning

Type Definition

typedef struct _ModulePresetArrayHandlerV2 { ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure INT32 numArrays; // number of presets. INT32 numRows; // the number of vectors. INT32 numCols; // the size of each vector. INT32 operation; // math operation on presets. 0 - multiplication and 1 - addition. INT32 initialFlag; // boolean flag which handles initial setup. FLOAT32* presetsArray; // 3-D presets array table. FLOAT32* pg1; // Points to the 1st preset group elements in the presetsArray. FLOAT32* pg2; // Points to the 2nd preset group elements in the presetsArray. FLOAT32* pg3; // Points to the 3rd preset group elements in the presetsArray. FLOAT32* pg4; // Points to the 4th preset group elements in the presetsArray. FLOAT32* pg5; // Points to the 5th preset group elements in the presetsArray. FLOAT32* pg6; // Points to the 6th preset group elements in the presetsArray. FLOAT32* pg7; // Points to the 7th preset group elements in the presetsArray. FLOAT32* pg8; // Points to the 8th preset group elements in the presetsArray. FLOAT32* pg9; // Points to the 9th preset group elements in the presetsArray. FLOAT32* pg10; // Points to the 10th preset group elements in the presetsArray. void * modPtr; // Points to the module to set. void * varPtr; // Points to the variable to set within the module instance structure. } ModulePresetArrayHandlerV2Class;

Variables

Properties

Name

Type

Usage

isHidden

Default value

Range

Units

numArrays

int

const

0

2

Unrestricted

 

numRows

int

const

0

1

Unrestricted

 

numCols

int

const

0

5

Unrestricted

 

operation

int

const

0

0

Unrestricted

 

initialFlag

int

state

0

1

Unrestricted

 

presetsArray

float*

parameter

0

[2 x 5]

Unrestricted

 

pg1

float*

state

1

[1 x 1]

Unrestricted

 

pg2

float*

state

1

[1 x 1]

Unrestricted

 

pg3

float*

state

1

[1 x 1]

Unrestricted

 

pg4

float*

state

1

[1 x 1]

Unrestricted

 

pg5

float*

state

1

[1 x 1]

Unrestricted

 

pg6

float*

state

1

[1 x 1]

Unrestricted

 

pg7

float*

state

1

[1 x 1]

Unrestricted

 

pg8

float*

state

1

[1 x 1]

Unrestricted

 

pg9

float*

state

1

[1 x 1]

Unrestricted

 

pg10

float*

state

1

[1 x 1]

Unrestricted

 

modPtr

void *

parameter

1

 

Unrestricted

 

varPtr

void *

parameter

1

 

Unrestricted

 

MATLAB Usage

File Name: preset_array_handler_v2_module.m

M=preset_array_handler_v2_module(NAME, NUMARRAYS, NUMROWS, NUMCOLS, OPERATION, MODVAR) Array set module. This module can reach into the instance structure of other modules and set array values. Arguments: NAME - name of the module. NUMARRAYS - number of presets, the Z dimension of internal table. NUMROWS - the dimension X of internal table. NUMCOLS - the dimension Y of internal table. OPERATION - operation to be performed on presets (multiply or addition). 0 - Multiplication 1 - Addition VARNAME - specifies the module and variable name using the form: 'MOD.VAR' where MOD is the module name and VAR is the variable name. You can also specify internal subsystems using 'SUBSYS.MOD.VAR'.