Skip to content

Conversation

@aartbik
Copy link
Collaborator

@aartbik aartbik commented Jun 3, 2025

Since all sparse direct solvers expect X and B in column-major format, it is better to adjust our definition for solve() than to insert artificial and costly data transpositions everywhere. Also, presenting the different rhs vectors and solutions along rows is more natural for a lot of direct solver problems.

Since all sparse direct solvers expect X and B in column-major
format, it is better to adjust our definition for solve() than
to insert artificial and costly data transpositions everywhere.
Also, presenting the different rhs vectors and solutions along
rows is more natural for a lot of direct solver problems.
@aartbik aartbik requested review from cliffburdick and Copilot June 3, 2025 17:06
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull Request Overview

The PR adjusts the solve() API to treat right-hand sides and solutions as row-stacked matrices (removing costly transposes), updates the cuDSS-backed sparse solver implementation accordingly, adds a placeholder check for DIA formats, and aligns tests and examples with the new row-wise convention.

  • Redefine solve() to expect and produce row-wise RHS and solution matrices.
  • Rename and simplify the cuDSS sparse-solve backend to remove manual transpositions.
  • Add a DIA-format guard in SolveOp and update documentation and tests/examples.

Reviewed Changes

Copilot reviewed 4 out of 4 changed files in this pull request and generated 1 comment.

File Description
test/00_sparse/Solve.cu Adjust test tensor shapes, expected values, and loop bounds for row-wise RHS/solutions.
include/matx/transforms/solve/solve_cudss.h Rename sparse_solve_impl_trans to sparse_solve_impl, update comments, remove hacks.
include/matx/operators/solve.h Add DIA-format check in Exec, update doc comment to explain row-wise solve behavior.
examples/sparse_tensor.cu Update example tensor shapes and set-values to use row-wise RHS/solutions.
Comments suppressed due to low confidence (1)

include/matx/operators/solve.h:95

  • [nitpick] The error message could be more descriptive; e.g., "Direct solver does not support DIA format yet" to clearly indicate the unsupported format.
MATX_THROW(matxNotSupported, "DIA support coming soon");

@cliffburdick
Copy link
Collaborator

/build

@cliffburdick cliffburdick merged commit eecd00c into NVIDIA:main Jun 3, 2025
1 check passed
@aartbik aartbik deleted the bik branch June 3, 2025 19:31
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants