sparse_matrix_variable_block_create_float(_:_:_:_:)
Returns a single-precision sparse matrix object that is stored in block-entry format with a variable block size.
Declaration
func sparse_matrix_variable_block_create_float(_ Mb: sparse_dimension, _ Nb: sparse_dimension, _ K: UnsafePointer<sparse_dimension>!, _ L: UnsafePointer<sparse_dimension>!) -> sparse_matrix_float!Parameters
- Mb:
The number of rows in terms of blocks of the matrix. Must be greater than 0.
- Nb:
The number of columns in terms of blocks of the matrix. Must be greater than 0.
- K:
Array containing row dimensions of the blocks. The
i’th row in terms of blocks will have a dimensionK[i].Kis expected to holdMbelements. All values ofKare expected to be greater than 0. - L:
Array containing column dimensions of the blocks. The
j’th column in terms of blocks will have a dimensionL[j].Lis expected to hold Nb elements. All values ofLare expected to be greater than 0.
Return Value
A matrix object that is ready for receiving entries. If an error occurs, nil is returned.
Discussion
Create a sparse matrix object that is stored in block-entry format and is ready to receive values from the various block insert routines. Blocks are are of variable dimension where the i,j’th block index has a dimension K[i] * L[j]. Block-entry format means blocks of dense regions will be stored at block indices i,j. For point wise format use non block version of create. See the various insert routines for details on inserting values into this matrix object.
See Also
Matrix creation and population
sparse_matrix_block_create_double(_:_:_:_:)sparse_matrix_block_create_float(_:_:_:_:)sparse_matrix_variable_block_create_double(_:_:_:_:)sparse_insert_block_double(_:_:_:_:_:_:)sparse_insert_block_float(_:_:_:_:_:_:)sparse_matrix_block_create_double_complex(_:_:_:_:)sparse_matrix_block_create_float_complex(_:_:_:_:)