10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-12 05:58:24 +01:00

Fixed quicksort openmp

This commit is contained in:
Anthony Scemama 2018-10-15 14:49:08 +02:00
parent b3d17a6479
commit fc01113383

View File

@ -37,19 +37,21 @@ BEGIN_TEMPLATE
integer,intent(in) :: isize integer,intent(in) :: isize
$type,intent(inout) :: x(isize) $type,intent(inout) :: x(isize)
integer,intent(inout) :: iorder(isize) integer,intent(inout) :: iorder(isize)
integer :: tn integer, external :: omp_get_num_threads
integer, external :: omp_get_thread_num if (omp_get_num_threads() == 1) then
tn = omp_get_thread_num() !$OMP PARALLEL DEFAULT(SHARED)
!$OMP PARALLEL if (tn == 0) !$OMP SINGLE
!$OMP SINGLE call rec_$X_quicksort(x,iorder,isize,1,isize,nproc)
call rec_$X_quicksort(x,iorder,isize,1,isize) !$OMP END SINGLE
!$OMP END SINGLE !$OMP END PARALLEL
!$OMP END PARALLEL else
call rec_$X_quicksort(x,iorder,isize,1,isize,nproc)
endif
end end
recursive subroutine rec_$X_quicksort(x, iorder, isize, first, last) recursive subroutine rec_$X_quicksort(x, iorder, isize, first, last, level)
implicit none implicit none
integer, intent(in) :: isize, first, last integer, intent(in) :: isize, first, last, level
integer,intent(inout) :: iorder(isize) integer,intent(inout) :: iorder(isize)
$type, intent(inout) :: x(isize) $type, intent(inout) :: x(isize)
$type :: c, tmp $type :: c, tmp
@ -76,17 +78,26 @@ BEGIN_TEMPLATE
i=i+1 i=i+1
j=j-1 j=j-1
enddo enddo
if (first < i-1) then if ( ((i-first <= 10000).and.(last-j <= 10000)).or.(level<=0) ) then
!$OMP TASK DEFAULT(SHARED) FIRSTPRIVATE(isize,first,i) if (i-first > 100000) if (first < i-1) then
call rec_$X_quicksort(x, iorder, isize, first, i-1) call rec_$X_quicksort(x, iorder, isize, first, i-1,level/2)
!$OMP END TASK endif
if (j+1 < last) then
call rec_$X_quicksort(x, iorder, isize, j+1, last,level/2)
endif
else
if (first < i-1) then
!$OMP TASK DEFAULT(SHARED) FIRSTPRIVATE(isize,first,i,level)
call rec_$X_quicksort(x, iorder, isize, first, i-1,level/2)
!$OMP END TASK
endif
if (j+1 < last) then
!$OMP TASK DEFAULT(SHARED) FIRSTPRIVATE(isize,last,j,level)
call rec_$X_quicksort(x, iorder, isize, j+1, last,level/2)
!$OMP END TASK
endif
!$OMP TASKWAIT
endif endif
if (j+1 < last) then
!$OMP TASK DEFAULT(SHARED) FIRSTPRIVATE(isize,last,j) if (last-j > 100000)
call rec_$X_quicksort(x, iorder, isize, j+1, last)
!$OMP END TASK
endif
!$OMP TASKWAIT
end end
subroutine heap_$Xsort(x,iorder,isize) subroutine heap_$Xsort(x,iorder,isize)