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