Do not sort local indices when GLOBALCHECK=.false.

omp-threadsafe
Salvatore Filippone 2 years ago
parent cd01db132e
commit 6058b0b26f

@ -93,7 +93,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
nrt = loc_row nrt = loc_row
call psb_sum(ctxt,nrt) call psb_sum(ctxt,nrt)
call psb_max(ctxt,m) call psb_max(ctxt,m)
if (present(globalcheck)) then if (present(globalcheck)) then
check_ = globalcheck check_ = globalcheck
else else
@ -167,7 +167,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
if (check_.or.(.not.islarge)) then if (check_.or.(.not.islarge)) then
if (debug_size) & if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': Going for global checks' & write(debug_unit,*) me,' ',trim(name),': Going for global checks'
allocate(tmpgidx(m,2),stat=info) allocate(tmpgidx(m,2),stat=info)
if (info /= psb_success_) then if (info /= psb_success_) then
info=psb_err_alloc_dealloc_ info=psb_err_alloc_dealloc_
@ -210,7 +210,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
info = psb_err_inconsistent_index_lists_ info = psb_err_inconsistent_index_lists_
end if end if
end if end if
else else
novrl = 0 novrl = 0
norphan = 0 norphan = 0
@ -244,36 +244,38 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
call psb_errpush(info,name,l_err=l_err) call psb_errpush(info,name,l_err=l_err)
goto 9999 goto 9999
end if end if
if (check_) then
! Sort, eliminate duplicates, then ! Sort, eliminate duplicates, then
! scramble back into original position. ! scramble back into original position.
ix(1) = -1 ix(1) = -1
if (present(idx)) then if (present(idx)) then
if (size(idx) >= loc_row) then if (size(idx) >= loc_row) then
!$omp parallel do private(i)
do i=1, loc_row
ix(i) = idx(i)
end do
end if
end if
if (ix(1) == -1) then
!$omp parallel do private(i)
do i=1, loc_row do i=1, loc_row
ix(i) = idx(i) ix(i) = i
end do end do
end if end if
end if call psb_msort(vl,ix,flag=psb_sort_keep_idx_)
if (ix(1) == -1) then nlu = min(1,loc_row)
do i=1, loc_row do i=2,loc_row
ix(i) = i if (vl(i) /= vl(nlu)) then
nlu = nlu + 1
vl(nlu) = vl(i)
ix(nlu) = ix(i)
end if
end do end do
end if call psb_msort(ix(1:nlu),vl(1:nlu),flag=psb_sort_keep_idx_)
call psb_msort(vl,ix,flag=psb_sort_keep_idx_)
nlu = min(1,loc_row)
do i=2,loc_row
if (vl(i) /= vl(nlu)) then
nlu = nlu + 1
vl(nlu) = vl(i)
ix(nlu) = ix(i)
end if
end do
call psb_msort(ix(1:nlu),vl(1:nlu),flag=psb_sort_keep_idx_)
if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': After sort ',nlu
if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': After sort ',nlu
end if
call psb_nullify_desc(desc) call psb_nullify_desc(desc)
if (do_timings) then if (do_timings) then
call psb_barrier(ctxt) call psb_barrier(ctxt)
@ -289,7 +291,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
if (novrl > 0) then if (novrl > 0) then
if (debug_size) & if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': Check overlap ' & write(debug_unit,*) me,' ',trim(name),': Check overlap '
if (debug_level >= psb_debug_ext_) & if (debug_level >= psb_debug_ext_) &
& write(debug_unit,*) me,' ',trim(name),': code for NOVRL>0',novrl,npr_ov & write(debug_unit,*) me,' ',trim(name),': code for NOVRL>0',novrl,npr_ov
@ -335,7 +337,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
end if end if
if (debug_size) & if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': Done overlap ' & write(debug_unit,*) me,' ',trim(name),': Done overlap '
! allocate work vector ! allocate work vector
allocate(l_temp_ovrlap(max(1,2*loc_row)),desc%lprm(1),& allocate(l_temp_ovrlap(max(1,2*loc_row)),desc%lprm(1),&
@ -393,7 +395,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
end if end if
if (debug_size) & if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': Allocate indxmap' & write(debug_unit,*) me,' ',trim(name),': Allocate indxmap'
if (np == 1) then if (np == 1) then
allocate(psb_repl_map :: desc%indxmap, stat=info) allocate(psb_repl_map :: desc%indxmap, stat=info)
else else
@ -414,7 +416,7 @@ subroutine psb_cd_inloc(v, ctxt, desc, info, globalcheck,idx,usehash)
if (debug_size) & if (debug_size) &
& write(debug_unit,*) me,' ',trim(name),': Done init indxmap' & write(debug_unit,*) me,' ',trim(name),': Done init indxmap'
if (do_timings) then if (do_timings) then
call psb_barrier(ctxt) call psb_barrier(ctxt)
t4 = psb_wtime() t4 = psb_wtime()

Loading…
Cancel
Save