NumMatrix
|
A Number Matrix (NumMatrix) is a Heap object containing zero or more IEEE 64 bit double precision real numbers, which are arranged in from one to three dimensions. (Note: NumMatrix objects may be dynamically arranged with one, two, or three dimensions).
This command creates a new NumMatrix of rand one with 2 elements:
(setq X (new Matrix: number: 1 2 11.433 -2.6))
11.433 |
-2.6 |
The NumMatrix is a dynamic data type: it can grow to containing new elements or contract as elements are deleted. An element is accessed by an index from 0 to n-1 where n is the number of elements in the NumMatrix. When an element is added, it is appended to the end.
11.433 |
-2.6 |
5 |
Or we might sort the NumMatrix
-2.6 |
5 |
11.433 |
Or we might delete a key by specify the index of the item to be deleted (2)
-2.6 |
5 |
The NumMatrix object is useful for storing data of the "same" type (i.e. Numbers). (homogeneous) or "different" types (heterogeneous) . The NumMatrix object is very fast and has minimum memory overhead due to the indexed access of its values. If you require a random access strategy or a keyed access strategy see the Dictionary or Structure data types.
The NumMatrix native data type has a constant form. A NumMatrix constant is enclosed in brackets and preceded by the sharp symbol (#).
For Example:
#(nummat| 0 1 2 3 4 5 6 7 8 9)
The NumMatrix is a Heap Object or an Object Data Type. The Analytic Information Server Object Types are stored in the Heap and are managed by the Heap manager. The Analytic Information Server Heap manager supports object resizing, garbage collection, and anti-fragmentation algorithms so that the user may concentrate on the analysis and modeling of data rather than on memory management. Without exception, all of the Object types are identified by an object id. The object id identifies a block of memory, managed by the Lambda Information Server memory manager, in which the Object's data is stored.
The Analytic Information Server Heap Object and Native Data types can be saved and loaded to and from persistent (disk file) storage at any time. Containers with immediate data are saved on disk in fixed length records equal to the size of the container. Containers with Heap object references are saved in fixed length records, which are automatically expanded to include the contents of the Heap object, and any objects referenced by the Heap object, etc. This feature is called Object Closure Management and is automatic with every Analytic Information Server container database save.
Analytic Information Server containers may be loaded from any database repository record at any time. If the data in the record is immediate, the database load fills the container with the immediate data. If the data in the record is an object closure, the database load fills the container with a Heap object reference, and all of the objects in the record are loaded back into the Heap with the same referential relationships they had when they were saved in the repository.
The NumMatrix object can be demonstrated by the following examples.