- Changed C ScaLAPACK API indexing convention to 1-based for partial eigenspectrum. (#1248)
Not released.
- Fixed a compilation issue with ROCm. (#1241)
- Fixed missing includes of
<complex>
. (#1243)
- Added (generalized) eigensolver which computes only a part of the eigenspectrum. (#1194)
Norm
is now fully asynchronous. (#1221)
- Refactored communication to use pika's
transform_mpi
and polling support. (#1125) - Use custom coalescing heuristic for memory pools. (#1183)
- Added configuration option for number of CUDA streams and cuBLAS/SOLVER handles. (#1222, #1182)
- Some algorithmic clean-ups and improvements. (#1213, #1219, #1232)
- Fixed builds with CUDA and stdexec enabled. (#1188)
- Work around buggy HIP complex operator overloads. (#1195)
- Namespace (SCA)LAPACK CMake modules with DLAF to avoid conflicts with other packages. (#1178)
- Renamed ScaLAPACK-like generalized eigensolvers
pXsygvx
/pXhegvx
topXsygvd
/pXhegvd
. (#1168) - Introduced generalized eigensolver where the matrix B is already factorized. (#1167)
- Local eigenvector permutations in the distributed tridiagonal eigensolver are executed directly in GPU memory. (#1118)
- Fixed ScaLAPACK detection in CMake for specific uenv cases. (#1159)
- Introduced an option (*) for forcing contiguous GPU communication buffers. (#1096)
- Introduced an option (*) for enabling GPU aware MPI communication. (#1102)
- Removed special handling of Intel MKL, as it could lead to broken installations. (#1149)
- Spack installations: spack will set the correct variables.
- Manual installations: the user is responsible to correctly set variables (see BUILD.md).
(*) These options are available as spack variants.
- Don't communicate in algorithms when using single rank communicators. (#1097)
- Fixed slow performance of local version of
bt_band_to_tridiagonal
(#1144)
- Implemented a workaround for
hipMemcpyDefault
2D memcpys, due to bugs in HIP. (#1106) - Miniapps initialize HIP before MPI, as on older Cray MPICH versions initializing HIP after MPI leads to HIP not seeing any devices. (#1090)
- Update project version and export it in CMake. (#1121)
- Modified
CommunicatorGrid
to avoid blocking calls toMPI_Comm_dup
. It now returns communicator pipelines. (#993) - Added support for Intel oneMKL and the
intel-oneapi-mkl
spack package. (#1073) (*)
- Reduced the size of the matrix-matrix multiplications in the tridiagonal eigensolver to cover only the non deflated part of the eigenvectors. (#951, #967, #996, #997, #998)
- Introduced stackless threads where appropriate. (#1037)
- Use
drop_operation_state
to avoid stack overflows. (#1004)
(*) At the time of the release the spack spec blaspp~openmp ^intel-oneapi-mkl threads=openmp
doesn't build. If you rely on multithreaded BLAS we suggest to use blaspp+openmp ^intel-oneapi-mkl threads=openmp
until spack/spack#42087 gets merged.
- Fixed compilation with gcc 9.3. (#1043)
- Fixed compilation with CUDA 11.2. (#1045)
- Improved eigensolver tests. (#1039)
- Added C and ScaLAPACK API (generalized eigensolver). (#992)
- Removed pika-algorithm dependency. (#945)
- Fixed Cholesky priorities. (#999)
- Fixed a problem in
reduction_to_band
that could have produced results filled with NaNs for certain corner cases. (E.g. input matrix with all off-band elements set to 0). (#980)
- Renamed algorithms using snake case. (#942)
- Added C and ScaLAPACK API (cholesky and eigensolver). (#886)
Matrix
API:- Initial support for matrices with different tile/block-size. (#909)
- Initial support for matrix subpipelines. (#898)
- Initial support for submatrices. (#934)
- Initial support for matrix redistribution. (#933)
- Fixed a problem in
tridiagonal_eigensolver
which produced wrong results for some classes of matrices. (#960)
- Introduced busy barriers in
reduction_to_band
. (#864) - New
band_to_tridiagonal
algorithm implementation. (#938, #946) - Improved the rank1 problem solution in
tridiagonal_eigensolver
. (#904, #936)
The first release of DLA-Future.