:orphan: # MATSELL MATSELL = "sell" - A matrix type to be used for sparse matrices. This matrix type is identical to `MATSEQSELL` when constructed with a single process communicator, and `MATMPISELL` otherwise. As a result, for single process communicators, `MatSeqSELLSetPreallocation()` is supported, and similarly `MatMPISELLSetPreallocation()` is supported for communicators controlling multiple processes. It is recommended that you call both of the above preallocation routines for simplicity. ## Options Database Key - ***-mat_type sell -*** sets the matrix type to "sell" during a call to MatSetFromOptions() ## Notes This format is only supported for real scalars, double precision, and 32-bit indices (the defaults). It can provide better performance on Intel and AMD processes with AVX2 or AVX512 support for matrices that have a similar number of non-zeros in contiguous groups of rows. However if the computation is memory bandwidth limited it may not provide much improvement. ## Developer Notes On Intel (and AMD) systems some of the matrix operations use SIMD (AVX) instructions to achieve higher performance. The sparse matrix format is as follows. For simplicity we assume a slice size of 2, it is actually 8 ```none (2 0 3 4) Consider the matrix A = (5 0 6 0) (0 0 7 8) (0 0 9 9) symbolically the Ellpack format can be written as (2 3 4 |) (0 2 3 |) v = (5 6 0 |) colidx = (0 2 2 |) -------- --------- (7 8 |) (2 3 |) (9 9 |) (2 3 |) The data for 2 contiguous rows of the matrix are stored together (in column-major format) (with any left-over rows handled as a special case). Any of the rows in a slice fewer columns than the rest of the slice (row 1 above) are padded with a previous valid column in their "extra" colidx[] locations and zeros in their "extra" v locations so that the matrix operations do not need special code to handle different length rows within the 2 rows in a slice. The one-dimensional representation of v used in the code is (2 5 3 6 4 0 7 9 8 9) and for colidx is (0 0 2 2 3 2 2 2 3 3) ``` See MatMult_SeqSELL() for how this format is used with the SIMD operations to achieve high performance. ## References - **** -*** Hong Zhang, Richard T. Mills, Karl Rupp, and Barry F. Smith, Vectorized Parallel Sparse Matrix-Vector Multiplication in {PETSc} Using {AVX-512}, Proceedings of the 47th International Conference on Parallel Processing, 2018. ## See Also `Mat`, `MatCreateSeqSELL()`, `MatCreateSeqAIJ()`, `MatCreateSell()`, `MATSEQSELL`, `MATMPISELL`, `MATSEQAIJ`, `MATMPIAIJ`, `MATAIJ` ## Level beginner ## Location src/mat/impls/sell/seq/sell.c --- [Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/src/mat/impls/sell/seq/sell.c) [Index of all Mat routines](index.md) [Table of Contents for all manual pages](/manualpages/index.md) [Index of all manual pages](/manualpages/singleindex.md)