Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: MPU9150_Example fir_f32 fir_f32 MPU9150_nucleo_noni2cdev ... more
Matrix Functions
This set of functions provides basic matrix math operations. More...
| Modules | |
| Matrix Addition | |
| Adds two matrices. | |
| Complex Matrix Multiplication | |
| Complex Matrix multiplication is only defined if the number of columns of the first matrix equals the number of rows of the second matrix. | |
| Matrix Initialization | |
| Initializes the underlying matrix data structure. | |
| Matrix Inverse | |
| Computes the inverse of a matrix. | |
| Matrix Multiplication | |
| Multiplies two matrices. | |
| Matrix Scale | |
| Multiplies a matrix by a scalar. | |
| Matrix Subtraction | |
| Subtract two matrices. | |
| Matrix Transpose | |
| Tranposes a matrix. | |
Detailed Description
This set of functions provides basic matrix math operations.
The functions operate on matrix data structures. For example, the type definition for the floating-point matrix structure is shown below:
     typedef struct
     {
       uint16_t numRows;     // number of rows of the matrix.
       uint16_t numCols;     // number of columns of the matrix.
       float32_t *pData;     // points to the data of the matrix.
     } arm_matrix_instance_f32;
 There are similar definitions for Q15 and Q31 data types.
The structure specifies the size of the matrix and then points to an array of data. The array is of size numRows X numCols and the values are arranged in row order. That is, the matrix element (i, j) is stored at: 
pData[i*numCols + j]
- Init Functions
- There is an associated initialization function for each type of matrix data structure. The initialization function sets the values of the internal structure fields. Refer to the function arm_mat_init_f32(),arm_mat_init_q31()andarm_mat_init_q15()for floating-point, Q31 and Q15 types, respectively.
- Use of the initialization function is optional. However, if initialization function is used then the instance structure cannot be placed into a const data section. To place the instance structure in a const data section, manually initialize the data structure. For example: 
 wherearm_matrix_instance_f32 S = {nRows, nColumns, pData};arm_matrix_instance_q31 S = {nRows, nColumns, pData};arm_matrix_instance_q15 S = {nRows, nColumns, pData};nRowsspecifies the number of rows,nColumnsspecifies the number of columns, andpDatapoints to the data array.
- Size Checking
- By default all of the matrix functions perform size checking on the input and output matrices. For example, the matrix addition function verifies that the two input matrices and the output matrix all have the same number of rows and columns. If the size check fails the functions return: ARM_MATH_SIZE_MISMATCH Otherwise the functions returnARM_MATH_SUCCESS There is some overhead associated with this matrix size checking. The matrix size checking is enabled via the #defineARM_MATH_MATRIX_CHECK within the library project settings. By default this macro is defined and size checking is enabled. By changing the project settings and undefining this macro size checking is eliminated and the functions run a bit faster. With size checking disabled the functions always returnARM_MATH_SUCCESS.
Generated on Tue Jul 12 2022 19:48:46 by
 1.7.2
 1.7.2