sparse_insert_block_double(_:_:_:_:_:_:)
Inserts a dense block of entries into a double-precision matrix.
Declaration
func sparse_insert_block_double(_ A: sparse_matrix_double!, _ val: UnsafePointer<Double>!, _ row_stride: sparse_dimension, _ col_stride: sparse_dimension, _ bi: sparse_index, _ bj: sparse_index) -> sparse_statusParameters
- A:
The sparse matrix, A,_ _which must have been created with Sparse_matrix_block_create_double(_:_:_:_:) or Sparse_matrix_variable_block_create_double(_:_:_:_:). Sparse_illegal_parameter is returned if not met.
Aholds block dimensions (fixed or variable) set with matrix object creation routine. - val:
Pointer to block to be inserted at block index location
A[bi,bj]. The block is of dimensionk * lwherekandlare set forbi,bjat object creation time. The strides between elements for rows and columns are provided inrow_strideandcol_stride. - row_stride:
The row stride in number of elements to move from one row to the next for the block
val. - col_stride:
The column stride in number of elements to move from one column to the next for the block
val. - bi:
The block row index where
valis to be inserted. Indexing is zero based, the first block is located at0,0. Index is assumed to be within the bounds of the matrix object, undefined behavior if not met. - bj:
The block column index where
valis to be inserted. Indexing is zero based, the first block is located at0,0. Index is assumed to be within the bounds of the matrix object, undefined behavior if not met.
Return Value
On successful insertion, A has been updated with the value and SPARSE_SUCCESS is returned. If A creation requirements are not met, SPARSE_ILLEGAL_PARAMETER is returned and A is unchanged.
Discussion
Use to build a sparse matrix by providing a dense block for entry at block location A[bi,bj]. Block size is determined at object creation time. Given a block dimension of k * l and for location bi,bj, update as: A[bi,bj][i,j] = val[i*row_stride + j*col_stride] for each i in k and each j in l.
Note that matrix properties cannot be modified after value insertion begins.This includes properties such as specifying a triangular matrix.Insertion can be expensive, generally speaking it is best to do a batch update. Inserted values may be temporarily held internally within the object and only inserted into the sparse format when a later computation triggers a need to insert.
See Also
Matrix creation and population
sparse_matrix_block_create_double(_:_:_:_:)sparse_matrix_block_create_float(_:_:_:_:)sparse_matrix_variable_block_create_double(_:_:_:_:)sparse_matrix_variable_block_create_float(_:_:_:_:)sparse_insert_block_float(_:_:_:_:_:_:)sparse_matrix_block_create_double_complex(_:_:_:_:)sparse_matrix_block_create_float_complex(_:_:_:_:)