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

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'.

  • No labels