|
|
@ -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()
|
|
|
|