|
|
@ -104,11 +104,13 @@ program spde
|
|
|
|
character(len=20) :: descr ! verbose description of the prec
|
|
|
|
character(len=20) :: descr ! verbose description of the prec
|
|
|
|
character(len=10) :: prec ! overall prectype
|
|
|
|
character(len=10) :: prec ! overall prectype
|
|
|
|
integer :: novr ! number of overlap layers
|
|
|
|
integer :: novr ! number of overlap layers
|
|
|
|
|
|
|
|
integer :: jsweeps ! Jacobi/smoother sweeps
|
|
|
|
character(len=16) :: restr ! restriction over application of as
|
|
|
|
character(len=16) :: restr ! restriction over application of as
|
|
|
|
character(len=16) :: prol ! prolongation over application of as
|
|
|
|
character(len=16) :: prol ! prolongation over application of as
|
|
|
|
character(len=16) :: solve ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
character(len=16) :: solve ! Solver type: ILU, SuperLU, UMFPACK.
|
|
|
|
integer :: fill1 ! Fill-in for factorization 1
|
|
|
|
integer :: fill1 ! Fill-in for factorization 1
|
|
|
|
real(psb_spk_) :: thr1 ! Threshold for fact. 1 ILU(T)
|
|
|
|
real(psb_spk_) :: thr1 ! Threshold for fact. 1 ILU(T)
|
|
|
|
|
|
|
|
character(len=16) :: smther ! Smoother
|
|
|
|
integer :: nlev ! Number of levels in multilevel prec.
|
|
|
|
integer :: nlev ! Number of levels in multilevel prec.
|
|
|
|
character(len=16) :: aggrkind ! smoothed/raw aggregatin
|
|
|
|
character(len=16) :: aggrkind ! smoothed/raw aggregatin
|
|
|
|
character(len=16) :: aggr_alg ! local or global aggregation
|
|
|
|
character(len=16) :: aggr_alg ! local or global aggregation
|
|
|
@ -171,17 +173,15 @@ program spde
|
|
|
|
|
|
|
|
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
nlv = prectype%nlev
|
|
|
|
nlv = prectype%nlev
|
|
|
|
else
|
|
|
|
|
|
|
|
nlv = 1
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
call mld_precinit(prec,prectype%prec, info, nlev=nlv)
|
|
|
|
call mld_precinit(prec,prectype%prec, info, nlev=nlv)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_smoother_type_, prectype%smther, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_smoother_sweeps_, prectype%jsweeps, info)
|
|
|
|
call mld_precset(prec,mld_sub_ovr_, prectype%novr, info)
|
|
|
|
call mld_precset(prec,mld_sub_ovr_, prectype%novr, info)
|
|
|
|
call mld_precset(prec,mld_sub_restr_, prectype%restr, info)
|
|
|
|
call mld_precset(prec,mld_sub_restr_, prectype%restr, info)
|
|
|
|
call mld_precset(prec,mld_sub_prol_, prectype%prol, info)
|
|
|
|
call mld_precset(prec,mld_sub_prol_, prectype%prol, info)
|
|
|
|
call mld_precset(prec,mld_sub_solve_, prectype%solve, info)
|
|
|
|
call mld_precset(prec,mld_sub_solve_, prectype%solve, info)
|
|
|
|
call mld_precset(prec,mld_sub_fillin_, prectype%fill1, info)
|
|
|
|
call mld_precset(prec,mld_sub_fillin_, prectype%fill1, info)
|
|
|
|
call mld_precset(prec,mld_sub_iluthrs_, prectype%thr1, info)
|
|
|
|
call mld_precset(prec,mld_sub_iluthrs_, prectype%thr1, info)
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_aggr_kind_, prectype%aggrkind,info)
|
|
|
|
call mld_precset(prec,mld_aggr_kind_, prectype%aggrkind,info)
|
|
|
|
call mld_precset(prec,mld_aggr_alg_, prectype%aggr_alg,info)
|
|
|
|
call mld_precset(prec,mld_aggr_alg_, prectype%aggr_alg,info)
|
|
|
|
call mld_precset(prec,mld_ml_type_, prectype%mltype, info)
|
|
|
|
call mld_precset(prec,mld_ml_type_, prectype%mltype, info)
|
|
|
@ -193,8 +193,17 @@ program spde
|
|
|
|
call mld_precset(prec,mld_coarse_fillin_, prectype%cfill, info)
|
|
|
|
call mld_precset(prec,mld_coarse_fillin_, prectype%cfill, info)
|
|
|
|
call mld_precset(prec,mld_coarse_iluthrs_, prectype%cthres, info)
|
|
|
|
call mld_precset(prec,mld_coarse_iluthrs_, prectype%cthres, info)
|
|
|
|
call mld_precset(prec,mld_coarse_sweeps_, prectype%cjswp, info)
|
|
|
|
call mld_precset(prec,mld_coarse_sweeps_, prectype%cjswp, info)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
nlv = 1
|
|
|
|
|
|
|
|
call mld_precinit(prec,prectype%prec, info, nlev=nlv)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_smoother_sweeps_, prectype%jsweeps, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_ovr_, prectype%novr, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_restr_, prectype%restr, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_prol_, prectype%prol, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_solve_, prectype%solve, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_fillin_, prectype%fill1, info)
|
|
|
|
|
|
|
|
call mld_precset(prec,mld_sub_iluthrs_, prectype%thr1, info)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
t1 = psb_wtime()
|
|
|
|
t1 = psb_wtime()
|
|
|
|
call mld_precbld(a,desc_a,prec,info)
|
|
|
|
call mld_precbld(a,desc_a,prec,info)
|
|
|
@ -305,7 +314,9 @@ contains
|
|
|
|
call read_data(prectype%solve,5) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
call read_data(prectype%solve,5) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
call read_data(prectype%fill1,5) ! Fill-in for factorization 1
|
|
|
|
call read_data(prectype%fill1,5) ! Fill-in for factorization 1
|
|
|
|
call read_data(prectype%thr1,5) ! Threshold for fact. 1 ILU(T)
|
|
|
|
call read_data(prectype%thr1,5) ! Threshold for fact. 1 ILU(T)
|
|
|
|
|
|
|
|
call read_data(prectype%jsweeps,5) ! Jacobi sweeps for PJAC
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
|
|
|
|
call read_data(prectype%smther,5) ! Smoother type.
|
|
|
|
call read_data(prectype%nlev,5) ! Number of levels in multilevel prec.
|
|
|
|
call read_data(prectype%nlev,5) ! Number of levels in multilevel prec.
|
|
|
|
call read_data(prectype%aggrkind,5) ! smoothed/raw aggregatin
|
|
|
|
call read_data(prectype%aggrkind,5) ! smoothed/raw aggregatin
|
|
|
|
call read_data(prectype%aggr_alg,5) ! local or global aggregation
|
|
|
|
call read_data(prectype%aggr_alg,5) ! local or global aggregation
|
|
|
@ -340,7 +351,9 @@ contains
|
|
|
|
call psb_bcast(ictxt,prectype%solve) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
call psb_bcast(ictxt,prectype%solve) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
call psb_bcast(ictxt,prectype%fill1) ! Fill-in for factorization 1
|
|
|
|
call psb_bcast(ictxt,prectype%fill1) ! Fill-in for factorization 1
|
|
|
|
call psb_bcast(ictxt,prectype%thr1) ! Threshold for fact. 1 ILU(T)
|
|
|
|
call psb_bcast(ictxt,prectype%thr1) ! Threshold for fact. 1 ILU(T)
|
|
|
|
|
|
|
|
call psb_bcast(ictxt,prectype%jsweeps) ! Jacobi sweeps
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
|
|
|
|
call psb_bcast(ictxt,prectype%smther) ! Smoother type.
|
|
|
|
call psb_bcast(ictxt,prectype%nlev) ! Number of levels in multilevel prec.
|
|
|
|
call psb_bcast(ictxt,prectype%nlev) ! Number of levels in multilevel prec.
|
|
|
|
call psb_bcast(ictxt,prectype%aggrkind) ! smoothed/raw aggregatin
|
|
|
|
call psb_bcast(ictxt,prectype%aggrkind) ! smoothed/raw aggregatin
|
|
|
|
call psb_bcast(ictxt,prectype%aggr_alg) ! local or global aggregation
|
|
|
|
call psb_bcast(ictxt,prectype%aggr_alg) ! local or global aggregation
|
|
|
|