stdBLAS
kokkos-kernels
stdBLAS | kokkos-kernels | |
---|---|---|
4 | 1 | |
104 | 278 | |
8.7% | 1.8% | |
5.0 | 9.1 | |
about 1 month ago | 3 days ago | |
C++ | C++ | |
GNU General Public License v3.0 or later | GNU General Public License v3.0 or later |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
stdBLAS
-
Which is the best way to work with matrices and linear algebra using c++?
You can have a look at https://github.com/kokkos/stdBLAS (it's an implementation of the proposed linear algebra extensions for future C++).
-
C++23: Near The Finish Line
It has the same BSD license as Kokkos: https://github.com/kokkos/stdBLAS/blob/main/LICENSE
-
Linear Algebra Library Reccomendations?
The BLAS and LAPACK have C interfaces, and they generally don't allocate memory unless you ask them. (Some BLAS implementations allocate internal storage for rearranging matrix data.) There are a few C++ BLAS wrappers; here is one of them.
-
Is there an OOP-wrapper library for cublas?
The second one is stdBLAS by kokkos. It doesn't even use cuBLAS but it's a reference implementation of P1673. This paper describe what could be a blas API in the std. I would recommend trying to do something equivalent on your side.
kokkos-kernels
-
Is there an OOP-wrapper library for cublas?
It’s a work in progress, but Kokkos and the associated Kokkos Kernels are probably the closest thing to what you’re asking for.
What are some alternatives?
mdspan - Reference implementation of mdspan targeting C++23
oneMKL - oneAPI Math Kernel Library (oneMKL) Interfaces
kokkos - Kokkos C++ Performance Portability Programming Ecosystem: The Programming Model - Parallel Execution and Memory Abstraction
plf_hive - plf::hive is a fork of plf::colony to match the current C++ standards proposal.
rocBLAS - Next generation BLAS implementation for ROCm platform
LEWG - Project planning for the C++ Library Evolution Working Group
kronmult993 - CPU and GPU implementations of kronmult.
plf_colony - An unordered C++ data container providing fast iteration/insertion/erasure while maintaining pointer/iterator validity to non-erased elements regardless of insertions/erasures. Provides higher-performance than std:: library containers for high-modification scenarios with unordered data.
cu - package cu provides an idiomatic interface to the CUDA Driver API.
papers - ISO/IEC JTC1 SC22 WG21 paper scheduling and management