(8.D.2.7) MatrixMultiplication
Overview
Matrix multiplication of two input pins
Discussion
The matrix multiplication module implements simple two dimensional multiplication of two matrices. Both real and complex data types are supported. Complex input matrices produces complex output matrix.
Matrix representation of the each input pin and the output pin is as follows:
    blockSize - represents the matrix rows
    numChannels - represents the matrix columns
Transposing the first, second, or both matrices is also supported through the constructor argument MATRIX_MULT_OP. This allows users to avoid explicit traspose of the input matrices if the matrix dimension not valid for multiplication. Possible options of the argument MATRIX_MULT_OP:
A*B - input matrices multiplied as it is.
(A^T)*B - first matrix is transposed before the multiplication. i.e. dimension of the first matrix is transposed.
A*(B^T) - second matrix is transposed before the multiplication. i.e. dimension of the second matrix is transposed.
(A^T)*(B^T) - both the matrices are transposed before the multiplication. i.e. dimension of both matrices are transposed.
Module bypass behavior is same as active. i.e. module process function is called when the module status is bypassed.
Type Definition
typedef struct _ModuleMatrixMultiplication
{
ModuleInstanceDescriptor instance; // Common Audio Weaver module instance structure
INT32 matrixMultOp; // Matrix multiplication operation. Supported are A*B, (A^T)*B, A*(B^T) and (A^T)*(B^T)
void * hardware_specific_struct_pointer; // This may point to a struct that varies based on the target platform
} ModuleMatrixMultiplicationClass;
Variables
Properties
Name | Type | Usage | isHidden | Default value | Range | Units |
matrixMultOp | int | const | 1 | 2 | Unrestricted | Â |
hardware_specific_struct_pointer | void * | state | 1 | Â | Unrestricted | Â |
Pins
Input Pins
Name: in1(A)
Description: Input matrix A
Data type: float
Channel range: Unrestricted
Block size range: Unrestricted
Sample rate range: Unrestricted
Complex support: Real and Complex
Â
Name: in2(B)
Description: Input matrix B
Data type: float
Channel range: Unrestricted
Block size range: Unrestricted
Sample rate range: Unrestricted
Complex support: Real and Complex
Output Pins
Name: out
Description: Output matrix
Data type: float
Scratch Pins
Channel count: 1
Block size: 34
Sample rate: 48000
MATLAB Usage
File Name: matrix_multiplication_module.m
M=matrix_multiplication_module(NAME, MATRIX_MULT_OP)
Creates a matrix multiplication module for use in the Audio Weaver environment.
The module has two input pins and one output pin. Each input pin is a
two dimensional matrix. The number of input rows and columns
per input pin is determined by the upstream audio module. Output pin
matrix dimension is determined by the multiplication operation selection
from the argument MATRIX_MULT_OP.
Arguments:
NAME - name of the module.
MATRIX_MULT_OP - matrix multiplication type. Available options are
A * B
(A^T) * B
A * (B^T)
(A^T) * (B^T)
Default operation is A * (B^T)
Â