|
|
@ -36,7 +36,7 @@
|
|
|
|
!
|
|
|
|
!
|
|
|
|
!
|
|
|
|
!
|
|
|
|
subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
& coo_prol,desc_ac,coo_restr,info)
|
|
|
|
& coo_prol,desc_ac,coo_restr,info,desc_ax)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_c_inner_mod
|
|
|
|
use mld_c_inner_mod
|
|
|
|
use mld_c_base_aggregator_mod, mld_protect_name => mld_c_ptap
|
|
|
|
use mld_c_base_aggregator_mod, mld_protect_name => mld_c_ptap
|
|
|
@ -44,13 +44,14 @@ subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
|
|
|
|
|
|
|
|
! Arguments
|
|
|
|
! Arguments
|
|
|
|
type(psb_c_csr_sparse_mat), intent(inout) :: a_csr
|
|
|
|
type(psb_c_csr_sparse_mat), intent(inout) :: a_csr
|
|
|
|
type(psb_desc_type), intent(in) :: desc_a
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_a
|
|
|
|
integer(psb_lpk_), intent(inout) :: nlaggr(:)
|
|
|
|
integer(psb_lpk_), intent(inout) :: nlaggr(:)
|
|
|
|
type(mld_sml_parms), intent(inout) :: parms
|
|
|
|
type(mld_sml_parms), intent(inout) :: parms
|
|
|
|
type(psb_lc_coo_sparse_mat), intent(inout) :: coo_prol, coo_restr
|
|
|
|
type(psb_lc_coo_sparse_mat), intent(inout) :: coo_prol, coo_restr
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_ac
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_ac
|
|
|
|
type(psb_lcspmat_type), intent(out) :: ac
|
|
|
|
type(psb_lcspmat_type), intent(out) :: ac
|
|
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
|
|
|
|
type(psb_desc_type), intent(inout), optional :: desc_ax
|
|
|
|
|
|
|
|
|
|
|
|
! Local variables
|
|
|
|
! Local variables
|
|
|
|
integer(psb_ipk_) :: err_act
|
|
|
|
integer(psb_ipk_) :: err_act
|
|
|
@ -115,6 +116,47 @@ subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! Ok first product done.
|
|
|
|
! Ok first product done.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (present(desc_ax)) then
|
|
|
|
|
|
|
|
block
|
|
|
|
|
|
|
|
type(psb_c_coo_sparse_mat) :: icoo_restr
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
call coo_prol%cp_to_icoo(icoo_restr,info)
|
|
|
|
|
|
|
|
call icoo_restr%set_ncols(desc_ac%get_local_cols())
|
|
|
|
|
|
|
|
call icoo_restr%set_nrows(desc_a%get_local_rows())
|
|
|
|
|
|
|
|
call psb_c_coo_glob_transpose(icoo_restr,desc_a,info,desc_c=desc_ac,desc_rx=desc_ax)
|
|
|
|
|
|
|
|
call icoo_restr%set_nrows(desc_ac%get_local_rows())
|
|
|
|
|
|
|
|
call icoo_restr%set_ncols(desc_ax%get_local_cols())
|
|
|
|
|
|
|
|
write(0,*) me,' ',trim(name),' check on glob_transpose 1: ',&
|
|
|
|
|
|
|
|
& desc_a%get_local_cols(),desc_ax%get_local_cols(),icoo_restr%get_nzeros()
|
|
|
|
|
|
|
|
if (desc_a%get_local_cols()<desc_ax%get_local_cols()) then
|
|
|
|
|
|
|
|
write(0,*) me,' ',trim(name),' WARNING: GLOB_TRANSPOSE NEW INDICES '
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
call coo_restr%cp_from_icoo(icoo_restr,info)
|
|
|
|
|
|
|
|
end block
|
|
|
|
|
|
|
|
call csr_restr%cp_from_lcoo(coo_restr,info)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!$ write(0,*)me,' ',name,' after transposition ',coo_restr%get_nrows(),coo_restr%get_ncols(),coo_restr%get_nzeros()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (info /= psb_success_) then
|
|
|
|
|
|
|
|
call psb_errpush(psb_err_from_subroutine_,name,a_err='spcnv coo_restr')
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
if (debug_level >= psb_debug_outer_) &
|
|
|
|
|
|
|
|
& write(debug_unit,*) me,' ',trim(name),&
|
|
|
|
|
|
|
|
& 'starting sphalo/ rwxtd'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (debug) write(0,*) me,trim(name),' Product RESTRxAP ',&
|
|
|
|
|
|
|
|
& csr_restr%get_nrows(),csr_restr%get_ncols(), &
|
|
|
|
|
|
|
|
& desc_ac%get_local_rows(),desc_a%get_local_cols(),&
|
|
|
|
|
|
|
|
& acsr3%get_nrows(),acsr3%get_ncols()
|
|
|
|
|
|
|
|
if (do_timings) call psb_tic(idx_spspmm)
|
|
|
|
|
|
|
|
call psb_par_spspmm(csr_restr,desc_ax,acsr3,ac_csr,desc_ac,info)
|
|
|
|
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
|
|
|
|
call acsr3%free()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! Remember that RESTR must be built from PROL after halo extension,
|
|
|
|
! Remember that RESTR must be built from PROL after halo extension,
|
|
|
|
! which is done above in psb_par_spspmm
|
|
|
|
! which is done above in psb_par_spspmm
|
|
|
@ -166,6 +208,7 @@ subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
call psb_par_spspmm(csr_restr,desc_a,acsr3,ac_csr,desc_ac,info)
|
|
|
|
call psb_par_spspmm(csr_restr,desc_a,acsr3,ac_csr,desc_ac,info)
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
call acsr3%free()
|
|
|
|
call acsr3%free()
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_cdasb(desc_ac,info)
|
|
|
|
call psb_cdasb(desc_ac,info)
|
|
|
|
|
|
|
|
|
|
|
@ -175,11 +218,10 @@ subroutine mld_c_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
call ac%set_asb()
|
|
|
|
call ac%set_asb()
|
|
|
|
|
|
|
|
|
|
|
|
if (debug) write(0,*) me,' ',trim(name),' After mv_from',psb_get_errstatus()
|
|
|
|
if (debug) write(0,*) me,' ',trim(name),' After mv_from',psb_get_errstatus()
|
|
|
|
if (debug) write(0,*) me,' ',trim(name),' ',ac%get_fmt(),ac%get_nrows(),&
|
|
|
|
if (debug) write(0,*) me,' ',trim(name),' ',ac%get_fmt(),ac%get_nrows(),ac%get_ncols(),ac%get_nzeros(),naggr,ntaggr
|
|
|
|
& ac%get_ncols(),ac%get_nzeros(),naggr,ntaggr
|
|
|
|
! write(0,*) me,' ',trim(name),' Final AC newstyle ',ac%get_fmt(),ac%get_nrows(),ac%get_ncols(),ac%get_nzeros()
|
|
|
|
|
|
|
|
|
|
|
|
call coo_prol%set_ncols(desc_ac%get_local_cols())
|
|
|
|
call coo_prol%set_ncols(desc_ac%get_local_cols())
|
|
|
|
|
|
|
|
|
|
|
|
if (debug) call check_coo(me,trim(name)//' Check 3 on coo_restr:',coo_restr)
|
|
|
|
if (debug) call check_coo(me,trim(name)//' Check 3 on coo_restr:',coo_restr)
|
|
|
|
|
|
|
|
|
|
|
|
if (debug_level >= psb_debug_outer_) &
|
|
|
|
if (debug_level >= psb_debug_outer_) &
|
|
|
@ -211,7 +253,7 @@ contains
|
|
|
|
end subroutine mld_c_ptap
|
|
|
|
end subroutine mld_c_ptap
|
|
|
|
|
|
|
|
|
|
|
|
subroutine mld_lc_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
subroutine mld_lc_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
& coo_prol,desc_ac,coo_restr,info)
|
|
|
|
& coo_prol,desc_ac,coo_restr,info,desc_ax)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_c_inner_mod
|
|
|
|
use mld_c_inner_mod
|
|
|
|
use mld_c_base_aggregator_mod, mld_protect_name => mld_lc_ptap
|
|
|
|
use mld_c_base_aggregator_mod, mld_protect_name => mld_lc_ptap
|
|
|
@ -219,13 +261,14 @@ subroutine mld_lc_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
|
|
|
|
|
|
|
|
! Arguments
|
|
|
|
! Arguments
|
|
|
|
type(psb_lc_csr_sparse_mat), intent(inout) :: a_csr
|
|
|
|
type(psb_lc_csr_sparse_mat), intent(inout) :: a_csr
|
|
|
|
type(psb_desc_type), intent(in) :: desc_a
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_a
|
|
|
|
integer(psb_lpk_), intent(inout) :: nlaggr(:)
|
|
|
|
integer(psb_lpk_), intent(inout) :: nlaggr(:)
|
|
|
|
type(mld_sml_parms), intent(inout) :: parms
|
|
|
|
type(mld_sml_parms), intent(inout) :: parms
|
|
|
|
type(psb_lc_coo_sparse_mat), intent(inout) :: coo_prol, coo_restr
|
|
|
|
type(psb_lc_coo_sparse_mat), intent(inout) :: coo_prol, coo_restr
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_ac
|
|
|
|
type(psb_desc_type), intent(inout) :: desc_ac
|
|
|
|
type(psb_lcspmat_type), intent(out) :: ac
|
|
|
|
type(psb_lcspmat_type), intent(out) :: ac
|
|
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
|
|
|
|
type(psb_desc_type), intent(inout), optional :: desc_ax
|
|
|
|
|
|
|
|
|
|
|
|
! Local variables
|
|
|
|
! Local variables
|
|
|
|
integer(psb_ipk_) :: err_act
|
|
|
|
integer(psb_ipk_) :: err_act
|
|
|
@ -290,6 +333,47 @@ subroutine mld_lc_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! Ok first product done.
|
|
|
|
! Ok first product done.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (present(desc_ax)) then
|
|
|
|
|
|
|
|
block
|
|
|
|
|
|
|
|
type(psb_c_coo_sparse_mat) :: icoo_restr
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
call coo_prol%cp_to_icoo(icoo_restr,info)
|
|
|
|
|
|
|
|
call icoo_restr%set_ncols(desc_ac%get_local_cols())
|
|
|
|
|
|
|
|
call icoo_restr%set_nrows(desc_a%get_local_rows())
|
|
|
|
|
|
|
|
call psb_c_coo_glob_transpose(icoo_restr,desc_a,info,desc_c=desc_ac,desc_rx=desc_ax)
|
|
|
|
|
|
|
|
call icoo_restr%set_nrows(desc_ac%get_local_rows())
|
|
|
|
|
|
|
|
call icoo_restr%set_ncols(desc_ax%get_local_cols())
|
|
|
|
|
|
|
|
write(0,*) me,' ',trim(name),' check on glob_transpose 1: ',&
|
|
|
|
|
|
|
|
& desc_a%get_local_cols(),desc_ax%get_local_cols(),icoo_restr%get_nzeros()
|
|
|
|
|
|
|
|
if (desc_a%get_local_cols()<desc_ax%get_local_cols()) then
|
|
|
|
|
|
|
|
write(0,*) me,' ',trim(name),' WARNING: GLOB_TRANSPOSE NEW INDICES '
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
call coo_restr%cp_from_icoo(icoo_restr,info)
|
|
|
|
|
|
|
|
end block
|
|
|
|
|
|
|
|
call csr_restr%cp_from_coo(coo_restr,info)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!$ write(0,*)me,' ',name,' after transposition ',coo_restr%get_nrows(),coo_restr%get_ncols(),coo_restr%get_nzeros()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (info /= psb_success_) then
|
|
|
|
|
|
|
|
call psb_errpush(psb_err_from_subroutine_,name,a_err='spcnv coo_restr')
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
if (debug_level >= psb_debug_outer_) &
|
|
|
|
|
|
|
|
& write(debug_unit,*) me,' ',trim(name),&
|
|
|
|
|
|
|
|
& 'starting sphalo/ rwxtd'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (debug) write(0,*) me,trim(name),' Product RESTRxAP ',&
|
|
|
|
|
|
|
|
& csr_restr%get_nrows(),csr_restr%get_ncols(), &
|
|
|
|
|
|
|
|
& desc_ac%get_local_rows(),desc_a%get_local_cols(),&
|
|
|
|
|
|
|
|
& acsr3%get_nrows(),acsr3%get_ncols()
|
|
|
|
|
|
|
|
if (do_timings) call psb_tic(idx_spspmm)
|
|
|
|
|
|
|
|
call psb_par_spspmm(csr_restr,desc_ax,acsr3,ac_csr,desc_ac,info)
|
|
|
|
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
|
|
|
|
call acsr3%free()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! Remember that RESTR must be built from PROL after halo extension,
|
|
|
|
! Remember that RESTR must be built from PROL after halo extension,
|
|
|
|
! which is done above in psb_par_spspmm
|
|
|
|
! which is done above in psb_par_spspmm
|
|
|
@ -341,6 +425,7 @@ subroutine mld_lc_ptap(a_csr,desc_a,nlaggr,parms,ac,&
|
|
|
|
call psb_par_spspmm(csr_restr,desc_a,acsr3,ac_csr,desc_ac,info)
|
|
|
|
call psb_par_spspmm(csr_restr,desc_a,acsr3,ac_csr,desc_ac,info)
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
if (do_timings) call psb_toc(idx_spspmm)
|
|
|
|
call acsr3%free()
|
|
|
|
call acsr3%free()
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_cdasb(desc_ac,info)
|
|
|
|
call psb_cdasb(desc_ac,info)
|
|
|
|
|
|
|
|
|
|
|
|