Skip to content

Commit

Permalink
Additional memory optimizations for dense eigenvalues
Browse files Browse the repository at this point in the history
  • Loading branch information
william-dawson committed Nov 27, 2023
1 parent b2ea759 commit d5f533e
Show file tree
Hide file tree
Showing 8 changed files with 86 additions and 50 deletions.
6 changes: 3 additions & 3 deletions Source/Fortran/EigenSolversModule.F90
Original file line number Diff line number Diff line change
Expand Up @@ -122,25 +122,25 @@ END FUNCTION func

!! Convert to a triplet list, map the triplet list, fill.
CALL GetMatrixTripletList(vals, tlist)
CALL DestructMatrix(vals)
DO II = 1, tlist%CurrentSize
tlist%DATA(II)%point_value = func(tlist%DATA(II)%point_value)
END DO

!! Fill
CALL ConstructEmptyMatrix(ResultMat, this)
CALL FillMatrixFromTripletList(ResultMat, tlist, preduplicated_in = .TRUE.)
CALL DestructTripletList(tlist)

!! Multiply Back Together
CALL MatrixMultiply(vecs, ResultMat, temp, threshold_in = params%threshold)
CALL TransposeMatrix(vecs, vecsT)
CALL DestructMatrix(vecs)
CALL ConjugateMatrix(vecsT)
CALL MatrixMultiply(temp, vecsT, ResultMat, threshold_in = params%threshold)

!! Cleanup
CALL DestructMatrix(vecs)
CALL DestructMatrix(temp)
CALL DestructMatrix(vals)
CALL DestructTripletList(tlist)
CALL DestructSolverParameters(params)

END SUBROUTINE DenseMatrixFunction
Expand Down
4 changes: 2 additions & 2 deletions Source/Fortran/dense_includes/ConstructMatrixDFromS.f90
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
INTEGER :: KK ! Total element counter
INTEGER :: elements_per_inner

CALL ConstructEmptyMatrix(dense_matrix, sparse_matrix%rows, &
& sparse_matrix%columns)
CALL ConstructEmptyMatrix(dense_matrix, &
& sparse_matrix%rows, sparse_matrix%columns)
dense_matrix%DATA = 0

!! Loop over elements.
Expand Down
49 changes: 26 additions & 23 deletions Source/Fortran/distributed_algebra_includes/MatrixMultiply.f90
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
TYPE(ReduceHelper_t), DIMENSION(:), ALLOCATABLE :: column_helper
TYPE(ReduceHelper_t), DIMENSION(:, :), ALLOCATABLE :: slice_helper
!! For Iterating Over Local Blocks
INTEGER :: II, II2
INTEGER :: JJ, JJ2
INTEGER :: II, II2, II2_range
INTEGER :: JJ, JJ2, JJ2_range
INTEGER :: duplicate_start_column, duplicate_offset_column
INTEGER :: duplicate_start_row, duplicate_offset_row
REAL(NTREAL) :: working_threshold
Expand Down Expand Up @@ -93,11 +93,11 @@
SELECT CASE (ATasks(II))
CASE(LocalGatherA)
ATasks(II) = TaskRunningA
!$OMP TASK DEFAULT(SHARED), PRIVATE(JJ2), FIRSTPRIVATE(II)
!$OMP TASK DEFAULT(SHARED), PRIVATE(JJ2, JJ2_range), FIRSTPRIVATE(II)
!! First Align The Data We Are Working With
DO JJ2 = 1, &
& matAB%process_grid%number_of_blocks_columns / &
& matAB%process_grid%num_process_slices
JJ2_range = matAB%process_grid%number_of_blocks_columns / &
& matAB%process_grid%num_process_slices
DO JJ2 = 1, JJ2_range
CALL CopyMatrix(matA%LMAT(II, &
& duplicate_start_column + &
& duplicate_offset_column * (JJ2 - 1)),&
Expand All @@ -106,9 +106,7 @@
!! Then Do A Local Gather and Cleanup
CALL ComposeMatrixColumns(AdjacentABlocks(II, :), &
& LocalRowContribution(II))
DO JJ2 = 1, &
& matAB%process_grid%number_of_blocks_columns / &
& matAB%process_grid%num_process_slices
DO JJ2 = 1, JJ2_range
CALL DestructMatrix(AdjacentABlocks(II, JJ2))
END DO
ATasks(II) = SendSizeA
Expand Down Expand Up @@ -139,8 +137,10 @@
!$OMP TASK DEFAULT(SHARED), FIRSTPRIVATE(II)
CALL ReduceAndComposeMatrixCleanup(LocalRowContribution(II), &
& GatheredRowContribution(II), row_helper(II))
CALL DestructMatrix(LocalRowContribution(II))
CALL TransposeMatrix(GatheredRowContribution(II), &
& GatheredRowContributionT(II))
CALL DestructMatrix(GatheredRowContribution(II))
ATasks(II) = CleanupA
!$OMP END TASK
CASE(CleanupA)
Expand All @@ -153,19 +153,19 @@
SELECT CASE (BTasks(JJ))
CASE(LocalGatherB)
BTasks(JJ) = TaskRunningB
!$OMP TASK DEFAULT(SHARED), PRIVATE(II2), FIRSTPRIVATE(JJ)
!$OMP TASK DEFAULT(SHARED), PRIVATE(II2, II2_range), FIRSTPRIVATE(JJ)
!! First Transpose The Data We Are Working With
DO II2 = 1, matAB%process_grid%number_of_blocks_rows / &
& matAB%process_grid%num_process_slices
II2_range = matAB%process_grid%number_of_blocks_rows / &
& matAB%process_grid%num_process_slices
DO II2 = 1, II2_range
CALL TransposeMatrix(matB%LMAT(duplicate_start_row + &
& duplicate_offset_row * (II2 - 1), JJ), &
& TransposedBBlocks(II2, JJ))
END DO
!! Then Do A Local Gather and Cleanup
CALL ComposeMatrixColumns(TransposedBBlocks(:, JJ), &
& LocalColumnContribution(JJ))
DO II2 = 1, matAB%process_grid%number_of_blocks_rows / &
& matAB%process_grid%num_process_slices
DO II2 = 1, II2_range
CALL DestructMatrix(TransposedBBlocks(II2, JJ))
END DO
BTasks(JJ) = SendSizeB
Expand Down Expand Up @@ -196,6 +196,7 @@
!$OMP TASK DEFAULT(SHARED), FIRSTPRIVATE(JJ)
CALL ReduceAndComposeMatrixCleanup(LocalColumnContribution(JJ), &
& GatheredColumnContribution(JJ), column_helper(JJ))
CALL DestructMatrix(LocalColumnContribution(JJ))
BTasks(JJ) = CleanupB
!$OMP END TASK
CASE(CleanupB)
Expand Down Expand Up @@ -225,6 +226,7 @@
IF (matAB%process_grid%num_process_slices .EQ. 1) THEN
ABTasks(II,JJ) = CleanupAB
CALL CopyMatrix(SliceContribution(II, JJ), matAB%LMAT(II, JJ))
CALL DestructMatrix(SliceContribution(II, JJ))
ELSE
ABTasks(II, JJ) = SendSizeAB
END IF
Expand Down Expand Up @@ -254,6 +256,7 @@
!$OMP TASK DEFAULT(SHARED), FIRSTPRIVATE(II, JJ)
CALL ReduceAndSumMatrixCleanup(SliceContribution(II, JJ), &
& matAB%LMAT(II, JJ), threshold, slice_helper(II, JJ))
CALL DestructMatrix(SliceContribution(II, JJ))
ABTasks(II, JJ) = CleanupAB
!$OMP END TASK
CASE(CleanupAB)
Expand All @@ -270,16 +273,7 @@
!$OMP END MASTER
!$OMP END PARALLEL

!! Copy to output matrix.
IF (ABS(beta) .LT. TINY(beta)) THEN
CALL CopyMatrix(matAB, matC)
ELSE
CALL ScaleMatrix(MatC, beta)
CALL IncrementMatrix(MatAB, MatC)
END IF

!! Cleanup
CALL DestructMatrix(matAB)
DEALLOCATE(row_helper)
DEALLOCATE(column_helper)
DEALLOCATE(slice_helper)
Expand Down Expand Up @@ -325,3 +319,12 @@
END DO
END DO
DEALLOCATE(SliceContribution)

!! Copy to output matrix.
IF (ABS(beta) .LT. TINY(beta)) THEN
CALL CopyMatrix(matAB, matC)
ELSE
CALL ScaleMatrix(MatC, beta)
CALL IncrementMatrix(MatAB, MatC)
END IF
CALL DestructMatrix(matAB)
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
CALL ShiftTripletList(shifted, 1 - this%start_row, 1 - this%start_column)
CALL SortTripletList(shifted, this%local_columns, &
& this%local_rows, sorted_tlist)
CALL DestructTripletList(shifted)
!! Build
CALL ConstructMatrixFromTripletList(local_matrix, sorted_tlist, &
& this%local_rows, this%local_columns)
Expand Down Expand Up @@ -46,5 +47,4 @@
END IF

CALL DestructMatrix(local_matrix)
CALL DestructTripletList(shifted)
CALL DestructTripletList(sorted_tlist)
32 changes: 23 additions & 9 deletions Source/Fortran/distributed_includes/TransposeMatrix.f90
Original file line number Diff line number Diff line change
@@ -1,22 +1,36 @@
!! Local Data
INTEGER :: II

CALL ConstructTripletList(new_list)
INTEGER :: II, KK

CALL GetMatrixTripletList(AMat, tlist)

!! Determine the size.
!! these loops could be merged using append but I choose not to for the
!! sake of memory.
KK = 0
DO II = 1, tlist%CurrentSize
IF (MOD(II, AMat%process_grid%num_process_slices) .EQ. &
& AMat%process_grid%my_slice) THEN
KK = KK + 1
END IF
END DO
CALL ConstructTripletList(new_list, KK)

!! Fill the Triplet List
KK = 0
DO II = 1, tlist%CurrentSize
IF (MOD(II, AMat%process_grid%num_process_slices) .EQ. &
& AMat%process_grid%my_slice) THEN
KK = KK + 1
CALL GetTripletAt(tlist, II, trip)
trip_t%index_row = trip%index_column
trip_t%index_column = trip%index_row
trip_t%point_value = trip%point_value
CALL AppendToTripletList(new_list, trip_t)
new_list%data(KK)%index_row = trip%index_column
new_list%data(KK)%index_column = trip%index_row
new_list%data(KK)%point_value = trip%point_value
END IF
END DO
CALL DestructTripletList(tlist)

!! Create the matrix
CALL DestructMatrix(TransMat)
CALL ConstructEmptyMatrix(TransMat, AMat)
CALL FillMatrixFromTripletList(TransMat, new_list)
CALL DestructTripletList(new_list)
CALL DestructTripletList(tlist)
CALL DestructTripletList(new_list)
4 changes: 2 additions & 2 deletions Source/Fortran/eigenexa_includes/EigenSerial.f90
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
!! Gather as dense
CALL GatherMatrixToProcess(this, local_s)
CALL ConstructMatrixDFromS(local_s, local_d)
CALL DestructMatrix(local_s)

!! Decompose
CALL EigenDecomposition(local_d, V, W)
CALL DestructMatrix(local_d)

!! Filter if necessary
IF (nvals+1 .LE. V%rows) THEN
Expand Down Expand Up @@ -35,7 +37,5 @@
END IF

!! Cleanup
CALL DestructMatrix(local_s)
CALL DestructMatrix(local_d)
CALL DestructTripletList(V_t)
CALL DestructTripletList(W_t)
33 changes: 25 additions & 8 deletions Source/Fortran/eigenexa_includes/EigenToNT.f90
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
!! Local Variables
INTEGER :: row_start, row_end, col_start, col_end
INTEGER :: II, JJ, ilookup, jlookup
INTEGER :: II, JJ, KK, ilookup, jlookup
INTEGER :: ind

!! Get The Eigenvectors
Expand All @@ -13,23 +13,40 @@
ALLOCATE(VD1(SIZE(VD, DIM = 1)*SIZE(VD, DIM = 2)))
VD1(:) = PACK(VD, .TRUE.)

CALL ConstructTripletList(triplet_v)
!! First loop: count how many elements are needed
!! originally I used Append to eliminate this loop but we need to save
!! memory here.
KK = 0
ind = 1
DO JJ = col_start, col_end
DO II = row_start, row_end
IF (ABS(VD1(ind + II -1)) .GT. params%threshold) THEN
KK = KK + 1
END IF
END DO
ind = ind + exa%offset
END DO

!! Construct The Triplet List
CALL ConstructTripletList(triplet_v, KK)

!! Reset indices and do the actual filling
ind = 1
KK = 0
DO JJ = col_start, col_end
jlookup = eigen_translate_l2g(JJ, exa%proc_cols, exa%colid)
DO II = row_start, row_end
IF (ABS(VD1(ind + II -1)) .GT. params%threshold) THEN
KK = KK + 1
ilookup = eigen_translate_l2g(II, exa%proc_rows, exa%rowid)
CALL SetTriplet(trip, jlookup, ilookup, VD1(ind + II -1))
CALL AppendToTripletList(triplet_v, trip)
CALL SetTriplet(triplet_v%data(KK), jlookup, ilookup, &
& VD1(ind + II -1))
END IF
END DO
ind = ind + exa%offset
END DO
DEALLOCATE(VD1)

!! Fill and Clean Up
CALL FillMatrixFromTripletList(V, triplet_v)

!! Cleanup
CALL DestructTripletList(triplet_v)

DEALLOCATE(VD1)
6 changes: 4 additions & 2 deletions Source/Fortran/sparse_includes/DenseBranch.f90
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,13 @@
CALL MultiplyMatrix(DenseA, DenseB, DenseC, &
& IsATransposed_in = IsATransposed, IsBTransposed_in = IsBTransposed)

!! Cleanup Intermediate
CALL DestructMatrix(DenseA)
CALL DestructMatrix(DenseB)

!! Convert Back
CALL ConstructMatrixSFromD(DenseC, matC, threshold)
CALL ScaleMatrix(matC, alpha)

!! Cleanup
CALL DestructMatrix(DenseA)
CALL DestructMatrix(DenseB)
CALL DestructMatrix(DenseC)

0 comments on commit d5f533e

Please sign in to comment.