MX_SLFS – Save or load a Matrix/Vector into file or string
Block SymbolLicensing group: STANDARD
Function Description
The block allows to convert a matrix or vector into text form and vice versa. The matrix is
supplied as a reference to the uMV input. The yMV output refers to the same matrix as the uMV
input, and is intended to chain matrix blocks in the correct order, as is common with all
MATRIX blocks. The text can be either in the input uStr (or output yStr for the
opposite direction of conversion) or in the file. If the text is in a file, its name is
the string connected to the uStr input. The usual REXYGENsystem file name rules
applies , ie it is relative to datadir and ../ is not allowed to leave the directory. If the
uStr input is unattached (or empty string), the path name of the file is used with
the full path (that is, including the task name and all subsystems) with the .dat
extension.
The format of a matrix in a text file or in text input and output is determined by the format parameter. Supported English and Czech CSV (i.e., columns separated by comma or semicolon), JSON format (created by Google and often used in web applications) and the format used by MATLAB (for entering a matrix in MATLAB scripts).
Conversion from text to matrix/vector or vice versa can be performed at each step of the algorithm or is triggered by the LOAD and SAVE inputs. The exact method is determined by the mode parameter and is explained in detail in the description of this parameter. If an error occurs, it is signaled to the iE output and in the log. After a fatal error, the conversion from/to the matrix stops. Error reset for mode = 1 .. 4 is done by setting LOAD = SAVE = off, resetting fatal error cannot be performed for mode = 5 .. 8 (must switch to mode = 1 .. 4 and then back).
The nmax parameter is used to alocate the output string. If nmax> 0, it is allocated specified number of chars during initialization. If this amount is insufficient, the block reports an error. If nmax = 0, the block increases the length of the output string as needed. If user don’t specify the nmax parameter it can lead to full RAM memory in extreme situations and unpredictable behaviour of entire system.
Inputs
uMV | Input reference to a matrix or vector | Reference |
uStr | Input string (to convert into matrix) or filename | String |
LOAD | Trigger to move data to matrix/vector | Bool |
SAVE | Trigger to move data from matrix/vector | Bool |
Parameters
mode | Triggering mode 2 | Long (I32) |
|
|
|
format | String/file format 1 | Long (I32) |
|
|
|
prec | Number of digits for single value 0 20 6 | Long (I32) |
TRN | Transposition flag | Bool |
nmax | Allocated size of string 0 | Long (I32) |
Outputs
yMV | Output reference to a matrix or vector | Reference |
yStr | String representation of the matrix/vector | String |
iE | Error code | Error |
[Previous] [Back to top] [Up] [Next]
2024 © REX Controls s.r.o., www.rexygen.com