---
title: "sparse_matrix_trace_double(_:_:)"
framework: accelerate
role: symbol
role_heading: Function
path: "accelerate/sparse_matrix_trace_double(_:_:)"
---

# sparse_matrix_trace_double(_:_:)

Computes the sum along the specified diagonal of the double-precision sparse matrix A.

## Declaration

```swift
func sparse_matrix_trace_double(_ A: sparse_matrix_double!, _ offset: sparse_index) -> Double
```

## Parameters

- `A`: The sparse matrix, A.
- `offset`: Specifies the diagonal to sum.

## Return Value

Return Value The computed trace.

## Discussion

Discussion The diagonal is specified by the offset parameter where zero is the main diagonal, values greater than one refer to diagonals above the main diagonal (A[i,i+offset]), and values less than one refer to diagonals below the main diagonal (A[i-offset, i]). If offset is out of the bounds of the matrix A, 0 is returned. important: Apple provides the BLAS and LAPACK libraries under the Accelerate framework to be in line with LAPACK 3.9.1. Starting with iOS 26, iPadOS 26, macOS 26, tvOS 26, visionOS 26, and watchOS 26, the libraries are in line with LAPACK 3.12.0. These new interfaces provide additional functionality, as well as a new ILP64 interface. To use the new interfaces, define ACCELERATE_NEW_LAPACK before including the Accelerate or vecLib headers. For ILP64 interfaces, also define ACCELERATE_LAPACK_ILP64. For Swift projects, specify ACCELERATE_NEW_LAPACK=1 and ACCELERATE_LAPACK_ILP64=1 as preprocessor macros in Xcode build settings under Apple Clang - Preprocessing > Preprocessor Macros.

## See Also

### Matrix-Vector Operations

- [sparse_matrix_vector_product_dense_double(_:_:_:_:_:_:_:)](accelerate/sparse_matrix_vector_product_dense_double(_:_:_:_:_:_:_:).md)
- [sparse_matrix_vector_product_dense_float(_:_:_:_:_:_:_:)](accelerate/sparse_matrix_vector_product_dense_float(_:_:_:_:_:_:_:).md)
- [sparse_vector_triangular_solve_dense_double(_:_:_:_:_:)](accelerate/sparse_vector_triangular_solve_dense_double(_:_:_:_:_:).md)
- [sparse_vector_triangular_solve_dense_float(_:_:_:_:_:)](accelerate/sparse_vector_triangular_solve_dense_float(_:_:_:_:_:).md)
- [sparse_outer_product_dense_double(_:_:_:_:_:_:_:_:_:)](accelerate/sparse_outer_product_dense_double(_:_:_:_:_:_:_:_:_:).md)
- [sparse_outer_product_dense_float(_:_:_:_:_:_:_:_:_:)](accelerate/sparse_outer_product_dense_float(_:_:_:_:_:_:_:_:_:).md)
- [sparse_permute_rows_double(_:_:)](accelerate/sparse_permute_rows_double(_:_:).md)
- [sparse_permute_rows_float(_:_:)](accelerate/sparse_permute_rows_float(_:_:).md)
- [sparse_permute_cols_double(_:_:)](accelerate/sparse_permute_cols_double(_:_:).md)
- [sparse_permute_cols_float(_:_:)](accelerate/sparse_permute_cols_float(_:_:).md)
- [sparse_elementwise_norm_double(_:_:)](accelerate/sparse_elementwise_norm_double(_:_:).md)
- [sparse_elementwise_norm_float(_:_:)](accelerate/sparse_elementwise_norm_float(_:_:).md)
- [sparse_operator_norm_double(_:_:)](accelerate/sparse_operator_norm_double(_:_:).md)
- [sparse_operator_norm_float(_:_:)](accelerate/sparse_operator_norm_float(_:_:).md)
- [sparse_matrix_trace_float(_:_:)](accelerate/sparse_matrix_trace_float(_:_:).md)
