diff --git a/mlir/include/mlir/Dialect/SparseTensor/IR/SparseTensorOps.td b/mlir/include/mlir/Dialect/SparseTensor/IR/SparseTensorOps.td --- a/mlir/include/mlir/Dialect/SparseTensor/IR/SparseTensorOps.td +++ b/mlir/include/mlir/Dialect/SparseTensor/IR/SparseTensorOps.td @@ -846,6 +846,35 @@ tensor's element type, representing the actual value loaded from the input tensor at the given coordinates. + Note that iterations on sparse tensors are performed by the actual stored dimension + order instead the declared dimension order in types. + + For example: + ```mlir + #COL_MAJOR = #sparse_tensor.encoding<{ + dimLevelType = [ "compressed", "compressed" ], + dimOrdering = affine_map<(i,j) -> (j,i)> + }> + + // foreach on a column-major sparse tensor + sparse_tensor.foreach in %0 : tensor<2x3xf64, #COL_MAJOR> do { + ^bb0(%row: index, %col: index, %arg3: f64): + // [%row, %col] -> [0, 0], [1, 0], [2, 0], [0, 1], [1, 1], [2, 1] + } + + #ROW_MAJOR = #sparse_tensor.encoding<{ + dimLevelType = [ "compressed", "compressed" ], + }> + + // foreach on a row-major sparse tensor + sparse_tensor.foreach in %0 : tensor<2x3xf64, #ROW_MAJOR> do { + ^bb0(%row: index, %col: index, %arg3: f64): + // [%row, %col] -> [0, 0], [0, 1], [1, 0], [1, 1], [2, 0], [2, 1] + } + + ``` + + Example: ```mlir