Added L1-JACOBI and L1-BJAC as simple preconditioners in PRECINIT

pizdaint-runs
Salvatore Filippone 5 years ago
parent 8f60a49fc6
commit 4d1a87e5d8

@ -50,10 +50,15 @@
! !
! 'DIAG', 'JACOBI' - diagonal/Jacobi ! 'DIAG', 'JACOBI' - diagonal/Jacobi
! !
! 'L1-DIAG', 'L1-JACOBI' - diagonal/Jacobi with L1 norm correction
!
! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized ! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized
! !
! 'BJAC' - block Jacobi preconditioner, with ILU(0) ! 'BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks ! on the local blocks
!
! 'L1-BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks and L1 correction for off-diag blocks
! !
! 'AS' - Additive Schwarz (AS), with ! 'AS' - Additive Schwarz (AS), with
! overlap 1 and ILU(0) on the local submatrices ! overlap 1 and ILU(0) on the local submatrices
@ -140,6 +145,15 @@ subroutine mld_cprecinit(ictxt,prec,ptype,info)
allocate(mld_c_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_c_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-DIAG','L1-JACOBI','L1_DIAG','L1_JACOBI')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_c_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_c_l1_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('GS','FWGS') case ('GS','FWGS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1
@ -174,6 +188,15 @@ subroutine mld_cprecinit(ictxt,prec,ptype,info)
allocate(mld_c_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_c_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-BJAC','L1_BJAC')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_c_l1_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_c_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('AS') case ('AS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1

@ -50,10 +50,15 @@
! !
! 'DIAG', 'JACOBI' - diagonal/Jacobi ! 'DIAG', 'JACOBI' - diagonal/Jacobi
! !
! 'L1-DIAG', 'L1-JACOBI' - diagonal/Jacobi with L1 norm correction
!
! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized ! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized
! !
! 'BJAC' - block Jacobi preconditioner, with ILU(0) ! 'BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks ! on the local blocks
!
! 'L1-BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks and L1 correction for off-diag blocks
! !
! 'AS' - Additive Schwarz (AS), with ! 'AS' - Additive Schwarz (AS), with
! overlap 1 and ILU(0) on the local submatrices ! overlap 1 and ILU(0) on the local submatrices
@ -143,6 +148,15 @@ subroutine mld_dprecinit(ictxt,prec,ptype,info)
allocate(mld_d_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_d_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-DIAG','L1-JACOBI','L1_DIAG','L1_JACOBI')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_d_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_d_l1_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('GS','FWGS') case ('GS','FWGS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1
@ -177,6 +191,15 @@ subroutine mld_dprecinit(ictxt,prec,ptype,info)
allocate(mld_d_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_d_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-BJAC','L1_BJAC')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_d_l1_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_d_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('AS') case ('AS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1

@ -50,10 +50,15 @@
! !
! 'DIAG', 'JACOBI' - diagonal/Jacobi ! 'DIAG', 'JACOBI' - diagonal/Jacobi
! !
! 'L1-DIAG', 'L1-JACOBI' - diagonal/Jacobi with L1 norm correction
!
! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized ! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized
! !
! 'BJAC' - block Jacobi preconditioner, with ILU(0) ! 'BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks ! on the local blocks
!
! 'L1-BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks and L1 correction for off-diag blocks
! !
! 'AS' - Additive Schwarz (AS), with ! 'AS' - Additive Schwarz (AS), with
! overlap 1 and ILU(0) on the local submatrices ! overlap 1 and ILU(0) on the local submatrices
@ -140,6 +145,15 @@ subroutine mld_sprecinit(ictxt,prec,ptype,info)
allocate(mld_s_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_s_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-DIAG','L1-JACOBI','L1_DIAG','L1_JACOBI')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_s_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_s_l1_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('GS','FWGS') case ('GS','FWGS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1
@ -174,6 +188,15 @@ subroutine mld_sprecinit(ictxt,prec,ptype,info)
allocate(mld_s_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_s_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-BJAC','L1_BJAC')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_s_l1_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_s_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('AS') case ('AS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1

@ -50,10 +50,15 @@
! !
! 'DIAG', 'JACOBI' - diagonal/Jacobi ! 'DIAG', 'JACOBI' - diagonal/Jacobi
! !
! 'L1-DIAG', 'L1-JACOBI' - diagonal/Jacobi with L1 norm correction
!
! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized ! 'GS', 'FBGS' - Hybrid Gauss-Seidel, also symmetrized
! !
! 'BJAC' - block Jacobi preconditioner, with ILU(0) ! 'BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks ! on the local blocks
!
! 'L1-BJAC' - block Jacobi preconditioner, with ILU(0)
! on the local blocks and L1 correction for off-diag blocks
! !
! 'AS' - Additive Schwarz (AS), with ! 'AS' - Additive Schwarz (AS), with
! overlap 1 and ILU(0) on the local submatrices ! overlap 1 and ILU(0) on the local submatrices
@ -143,6 +148,15 @@ subroutine mld_zprecinit(ictxt,prec,ptype,info)
allocate(mld_z_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_z_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-DIAG','L1-JACOBI','L1_DIAG','L1_JACOBI')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_z_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_z_l1_diag_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('GS','FWGS') case ('GS','FWGS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1
@ -177,6 +191,15 @@ subroutine mld_zprecinit(ictxt,prec,ptype,info)
allocate(mld_z_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info) allocate(mld_z_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default() call prec%precv(ilev_)%default()
case ('L1-BJAC','L1_BJAC')
nlev_ = 1
ilev_ = 1
allocate(prec%precv(nlev_),stat=info)
allocate(mld_z_l1_jac_smoother_type :: prec%precv(ilev_)%sm, stat=info)
if (info /= psb_success_) return
allocate(mld_z_ilu_solver_type :: prec%precv(ilev_)%sm%sv, stat=info)
call prec%precv(ilev_)%default()
case ('AS') case ('AS')
nlev_ = 1 nlev_ = 1
ilev_ = 1 ilev_ = 1

Loading…
Cancel
Save