From dcb051d0599f46678a368a15a2347a5dbe45ddd4 Mon Sep 17 00:00:00 2001 From: Salvatore Filippone Date: Sat, 11 Aug 2018 18:02:54 +0100 Subject: [PATCH] Use a CSR buffer in soc1_map_bld --- mlprec/impl/aggregator/mld_c_soc1_map_bld.f90 | 57 +++++++++++-------- mlprec/impl/aggregator/mld_d_soc1_map_bld.f90 | 57 +++++++++++-------- mlprec/impl/aggregator/mld_s_soc1_map_bld.f90 | 57 +++++++++++-------- mlprec/impl/aggregator/mld_z_soc1_map_bld.f90 | 57 +++++++++++-------- 4 files changed, 136 insertions(+), 92 deletions(-) diff --git a/mlprec/impl/aggregator/mld_c_soc1_map_bld.f90 b/mlprec/impl/aggregator/mld_c_soc1_map_bld.f90 index 89f3703c..50440770 100644 --- a/mlprec/impl/aggregator/mld_c_soc1_map_bld.f90 +++ b/mlprec/impl/aggregator/mld_c_soc1_map_bld.f90 @@ -109,7 +109,8 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) ncol = desc_a%get_local_cols() nr = a%get_nrows() - allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),irow(nr),icol(nr),val(nr),stat=info) + allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),& + & icol(nr),val(nr),stat=info) if(info /= psb_success_) then info=psb_err_alloc_request_ call psb_errpush(info,name,i_err=(/2*nr,izero,izero,izero,izero/),& @@ -124,18 +125,17 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) goto 9999 end if + call a%cp_to(acsr) if (iorder == mld_aggr_ord_nat_) then do i=1, nr ilaggr(i) = -(nr+1) idxs(i) = i end do else - call a%cp_to(acsr) do i=1, nr ilaggr(i) = -(nr+1) ideg(i) = acsr%irp(i+1) - acsr%irp(i) end do - call acsr%free() call psb_msort(ideg,ix=idxs,dir=psb_sort_down_) end if @@ -148,13 +148,16 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) step1: do ii=1, nr i = idxs(ii) - if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='csget') - goto 9999 - end if + if (ilaggr(i) == -(nr+1)) then + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='csget') +!!$ goto 9999 +!!$ end if ! ! Build the set of all strongly coupled nodes @@ -201,12 +204,15 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find the most strongly connected neighbour that is ! already aggregated, if any, and join its aggregate @@ -237,12 +243,15 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) < 0) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find its strongly connected neighbourhood not ! already aggregated, and make it into a new aggregate. @@ -285,7 +294,7 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) endif if (naggr > ncol) then - write(0,*) name,'Error : naggr > ncol',naggr,ncol + !write(0,*) name,'Error : naggr > ncol',naggr,ncol info=psb_err_internal_error_ call psb_errpush(info,name,a_err='Fatal error: naggr>ncol') goto 9999 @@ -311,6 +320,8 @@ subroutine mld_c_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) nlaggr(me+1) = naggr call psb_sum(ictxt,nlaggr(1:np)) + call acsr%free() + call psb_erractionrestore(err_act) return diff --git a/mlprec/impl/aggregator/mld_d_soc1_map_bld.f90 b/mlprec/impl/aggregator/mld_d_soc1_map_bld.f90 index 8bf12435..9b999c74 100644 --- a/mlprec/impl/aggregator/mld_d_soc1_map_bld.f90 +++ b/mlprec/impl/aggregator/mld_d_soc1_map_bld.f90 @@ -109,7 +109,8 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) ncol = desc_a%get_local_cols() nr = a%get_nrows() - allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),irow(nr),icol(nr),val(nr),stat=info) + allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),& + & icol(nr),val(nr),stat=info) if(info /= psb_success_) then info=psb_err_alloc_request_ call psb_errpush(info,name,i_err=(/2*nr,izero,izero,izero,izero/),& @@ -124,18 +125,17 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) goto 9999 end if + call a%cp_to(acsr) if (iorder == mld_aggr_ord_nat_) then do i=1, nr ilaggr(i) = -(nr+1) idxs(i) = i end do else - call a%cp_to(acsr) do i=1, nr ilaggr(i) = -(nr+1) ideg(i) = acsr%irp(i+1) - acsr%irp(i) end do - call acsr%free() call psb_msort(ideg,ix=idxs,dir=psb_sort_down_) end if @@ -148,13 +148,16 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) step1: do ii=1, nr i = idxs(ii) - if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='csget') - goto 9999 - end if + if (ilaggr(i) == -(nr+1)) then + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='csget') +!!$ goto 9999 +!!$ end if ! ! Build the set of all strongly coupled nodes @@ -201,12 +204,15 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find the most strongly connected neighbour that is ! already aggregated, if any, and join its aggregate @@ -237,12 +243,15 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) < 0) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find its strongly connected neighbourhood not ! already aggregated, and make it into a new aggregate. @@ -285,7 +294,7 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) endif if (naggr > ncol) then - write(0,*) name,'Error : naggr > ncol',naggr,ncol + !write(0,*) name,'Error : naggr > ncol',naggr,ncol info=psb_err_internal_error_ call psb_errpush(info,name,a_err='Fatal error: naggr>ncol') goto 9999 @@ -311,6 +320,8 @@ subroutine mld_d_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) nlaggr(me+1) = naggr call psb_sum(ictxt,nlaggr(1:np)) + call acsr%free() + call psb_erractionrestore(err_act) return diff --git a/mlprec/impl/aggregator/mld_s_soc1_map_bld.f90 b/mlprec/impl/aggregator/mld_s_soc1_map_bld.f90 index d1ad4e6f..7c36341e 100644 --- a/mlprec/impl/aggregator/mld_s_soc1_map_bld.f90 +++ b/mlprec/impl/aggregator/mld_s_soc1_map_bld.f90 @@ -109,7 +109,8 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) ncol = desc_a%get_local_cols() nr = a%get_nrows() - allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),irow(nr),icol(nr),val(nr),stat=info) + allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),& + & icol(nr),val(nr),stat=info) if(info /= psb_success_) then info=psb_err_alloc_request_ call psb_errpush(info,name,i_err=(/2*nr,izero,izero,izero,izero/),& @@ -124,18 +125,17 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) goto 9999 end if + call a%cp_to(acsr) if (iorder == mld_aggr_ord_nat_) then do i=1, nr ilaggr(i) = -(nr+1) idxs(i) = i end do else - call a%cp_to(acsr) do i=1, nr ilaggr(i) = -(nr+1) ideg(i) = acsr%irp(i+1) - acsr%irp(i) end do - call acsr%free() call psb_msort(ideg,ix=idxs,dir=psb_sort_down_) end if @@ -148,13 +148,16 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) step1: do ii=1, nr i = idxs(ii) - if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='csget') - goto 9999 - end if + if (ilaggr(i) == -(nr+1)) then + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='csget') +!!$ goto 9999 +!!$ end if ! ! Build the set of all strongly coupled nodes @@ -201,12 +204,15 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find the most strongly connected neighbour that is ! already aggregated, if any, and join its aggregate @@ -237,12 +243,15 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) < 0) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find its strongly connected neighbourhood not ! already aggregated, and make it into a new aggregate. @@ -285,7 +294,7 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) endif if (naggr > ncol) then - write(0,*) name,'Error : naggr > ncol',naggr,ncol + !write(0,*) name,'Error : naggr > ncol',naggr,ncol info=psb_err_internal_error_ call psb_errpush(info,name,a_err='Fatal error: naggr>ncol') goto 9999 @@ -311,6 +320,8 @@ subroutine mld_s_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) nlaggr(me+1) = naggr call psb_sum(ictxt,nlaggr(1:np)) + call acsr%free() + call psb_erractionrestore(err_act) return diff --git a/mlprec/impl/aggregator/mld_z_soc1_map_bld.f90 b/mlprec/impl/aggregator/mld_z_soc1_map_bld.f90 index aa175f9a..06bc77b1 100644 --- a/mlprec/impl/aggregator/mld_z_soc1_map_bld.f90 +++ b/mlprec/impl/aggregator/mld_z_soc1_map_bld.f90 @@ -109,7 +109,8 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) ncol = desc_a%get_local_cols() nr = a%get_nrows() - allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),irow(nr),icol(nr),val(nr),stat=info) + allocate(ilaggr(nr),neigh(nr),ideg(nr),idxs(nr),& + & icol(nr),val(nr),stat=info) if(info /= psb_success_) then info=psb_err_alloc_request_ call psb_errpush(info,name,i_err=(/2*nr,izero,izero,izero,izero/),& @@ -124,18 +125,17 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) goto 9999 end if + call a%cp_to(acsr) if (iorder == mld_aggr_ord_nat_) then do i=1, nr ilaggr(i) = -(nr+1) idxs(i) = i end do else - call a%cp_to(acsr) do i=1, nr ilaggr(i) = -(nr+1) ideg(i) = acsr%irp(i+1) - acsr%irp(i) end do - call acsr%free() call psb_msort(ideg,ix=idxs,dir=psb_sort_down_) end if @@ -148,13 +148,16 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) step1: do ii=1, nr i = idxs(ii) - if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='csget') - goto 9999 - end if + if (ilaggr(i) == -(nr+1)) then + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='csget') +!!$ goto 9999 +!!$ end if ! ! Build the set of all strongly coupled nodes @@ -201,12 +204,15 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) == -(nr+1)) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find the most strongly connected neighbour that is ! already aggregated, if any, and join its aggregate @@ -237,12 +243,15 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) i = idxs(ii) if (ilaggr(i) < 0) then - call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) - if (info /= psb_success_) then - info=psb_err_from_subroutine_ - call psb_errpush(info,name,a_err='psb_sp_getrow') - goto 9999 - end if + nz = (acsr%irp(i+1)-acsr%irp(i)) + icol(1:nz) = acsr%ja(acsr%irp(i):acsr%irp(i+1)-1) + val(1:nz) = acsr%val(acsr%irp(i):acsr%irp(i+1)-1) +!!$ call a%csget(i,i,nz,irow,icol,val,info,chksz=.false.) +!!$ if (info /= psb_success_) then +!!$ info=psb_err_from_subroutine_ +!!$ call psb_errpush(info,name,a_err='psb_sp_getrow') +!!$ goto 9999 +!!$ end if ! ! Find its strongly connected neighbourhood not ! already aggregated, and make it into a new aggregate. @@ -285,7 +294,7 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) endif if (naggr > ncol) then - write(0,*) name,'Error : naggr > ncol',naggr,ncol + !write(0,*) name,'Error : naggr > ncol',naggr,ncol info=psb_err_internal_error_ call psb_errpush(info,name,a_err='Fatal error: naggr>ncol') goto 9999 @@ -311,6 +320,8 @@ subroutine mld_z_soc1_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info) nlaggr(me+1) = naggr call psb_sum(ictxt,nlaggr(1:np)) + call acsr%free() + call psb_erractionrestore(err_act) return