|
|
|
@ -72,13 +72,13 @@ contains
|
|
|
|
|
use psb_base_mod, only : psb_spk_
|
|
|
|
|
real(psb_spk_) :: b1
|
|
|
|
|
real(psb_spk_), intent(in) :: x,y
|
|
|
|
|
b1=1.e0/sqrt(2.e0)
|
|
|
|
|
b1=0.e0/sqrt(2.e0)
|
|
|
|
|
end function b1
|
|
|
|
|
function b2(x,y)
|
|
|
|
|
use psb_base_mod, only : psb_spk_
|
|
|
|
|
real(psb_spk_) :: b2
|
|
|
|
|
real(psb_spk_), intent(in) :: x,y
|
|
|
|
|
b2=1.e0/sqrt(2.e0)
|
|
|
|
|
b2=0.e0/sqrt(2.e0)
|
|
|
|
|
end function b2
|
|
|
|
|
function c(x,y)
|
|
|
|
|
use psb_base_mod, only : psb_spk_
|
|
|
|
@ -90,13 +90,13 @@ contains
|
|
|
|
|
use psb_base_mod, only : psb_spk_
|
|
|
|
|
real(psb_spk_) :: a1
|
|
|
|
|
real(psb_spk_), intent(in) :: x,y
|
|
|
|
|
a1=1.e0/80
|
|
|
|
|
a1=1.e0!/80
|
|
|
|
|
end function a1
|
|
|
|
|
function a2(x,y)
|
|
|
|
|
use psb_base_mod, only : psb_spk_
|
|
|
|
|
real(psb_spk_) :: a2
|
|
|
|
|
real(psb_spk_), intent(in) :: x,y
|
|
|
|
|
a2=1.e0/80
|
|
|
|
|
a2=1.e0!/80
|
|
|
|
|
end function a2
|
|
|
|
|
function g(x,y)
|
|
|
|
|
use psb_base_mod, only : psb_spk_, sone, szero
|
|
|
|
@ -134,9 +134,9 @@ program spde2d
|
|
|
|
|
type(mld_sprec_type) :: prec
|
|
|
|
|
! descriptor
|
|
|
|
|
type(psb_desc_type) :: desc_a
|
|
|
|
|
! dense matrices
|
|
|
|
|
! dense vectors
|
|
|
|
|
type(psb_s_vect_type) :: x,b
|
|
|
|
|
! blacs parameters
|
|
|
|
|
! parallel environment
|
|
|
|
|
integer(psb_ipk_) :: ictxt, iam, np
|
|
|
|
|
|
|
|
|
|
! solver parameters
|
|
|
|
@ -153,6 +153,7 @@ program spde2d
|
|
|
|
|
character(len=16) :: prol ! prolongation over application of as
|
|
|
|
|
character(len=16) :: solve ! Solver type: ILU, SuperLU, UMFPACK.
|
|
|
|
|
integer(psb_ipk_) :: fill1 ! Fill-in for factorization 1
|
|
|
|
|
integer(psb_ipk_) :: svsweeps ! Solver sweeps for GS
|
|
|
|
|
real(psb_spk_) :: thr1 ! Threshold for fact. 1 ILU(T)
|
|
|
|
|
character(len=16) :: smther ! Smoother
|
|
|
|
|
integer(psb_ipk_) :: nlev ! Number of levels in multilevel prec.
|
|
|
|
@ -172,7 +173,7 @@ program spde2d
|
|
|
|
|
type(precdata) :: prectype
|
|
|
|
|
type(psb_s_coo_sparse_mat) :: acoo
|
|
|
|
|
! other variables
|
|
|
|
|
integer(psb_ipk_) :: info
|
|
|
|
|
integer(psb_ipk_) :: info, i
|
|
|
|
|
character(len=20) :: name,ch_err
|
|
|
|
|
|
|
|
|
|
info=psb_success_
|
|
|
|
@ -196,6 +197,7 @@ program spde2d
|
|
|
|
|
write(*,*) 'Welcome to MLD2P4 version: ',mld_version_string_
|
|
|
|
|
write(*,*) 'This is the ',trim(name),' sample program'
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
|
! get parameters
|
|
|
|
|
!
|
|
|
|
@ -206,7 +208,8 @@ program spde2d
|
|
|
|
|
!
|
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
|
t1 = psb_wtime()
|
|
|
|
|
call psb_gen_pde2d(ictxt,idim,a,b,x,desc_a,afmt,a1,a2,b1,b2,c,g,info)
|
|
|
|
|
call psb_gen_pde2d(ictxt,idim,a,b,x,desc_a,afmt,&
|
|
|
|
|
& a1,a2,b1,b2,c,g,info)
|
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
|
t2 = psb_wtime() - t1
|
|
|
|
|
if(info /= psb_success_) then
|
|
|
|
@ -227,38 +230,41 @@ program spde2d
|
|
|
|
|
if (psb_toupper(prectype%prec) == 'ML') then
|
|
|
|
|
nlv = prectype%nlev
|
|
|
|
|
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_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)
|
|
|
|
|
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_ml_type_, prectype%mltype, info)
|
|
|
|
|
call mld_precset(prec,mld_smoother_pos_, prectype%smthpos, info)
|
|
|
|
|
if (prectype%athres >= szero) &
|
|
|
|
|
& call mld_precset(prec,mld_aggr_thresh_, prectype%athres, info)
|
|
|
|
|
call mld_precset(prec,mld_coarse_solve_, prectype%csolve, info)
|
|
|
|
|
call mld_precset(prec,mld_coarse_subsolve_, prectype%csbsolve,info)
|
|
|
|
|
call mld_precset(prec,mld_coarse_mat_, prectype%cmat, 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_sweeps_, prectype%cjswp, info)
|
|
|
|
|
call mld_precset(prec,mld_coarse_aggr_size_, prectype%csize, info)
|
|
|
|
|
call mld_precset(prec,'smoother_type', prectype%smther, info)
|
|
|
|
|
call mld_precset(prec,'smoother_sweeps', prectype%jsweeps, info)
|
|
|
|
|
call mld_precset(prec,'sub_ovr', prectype%novr, info)
|
|
|
|
|
call mld_precset(prec,'sub_restr', prectype%restr, info)
|
|
|
|
|
call mld_precset(prec,'sub_prol', prectype%prol, info)
|
|
|
|
|
call mld_precset(prec,'sub_solve', prectype%solve, info)
|
|
|
|
|
call mld_precset(prec,'sub_fillin', prectype%fill1, info)
|
|
|
|
|
call mld_precset(prec,'solver_sweeps', prectype%svsweeps, info)
|
|
|
|
|
call mld_precset(prec,'sub_iluthrs', prectype%thr1, info)
|
|
|
|
|
call mld_precset(prec,'aggr_kind', prectype%aggrkind,info)
|
|
|
|
|
call mld_precset(prec,'aggr_alg', prectype%aggr_alg,info)
|
|
|
|
|
call mld_precset(prec,'ml_type', prectype%mltype, info)
|
|
|
|
|
call mld_precset(prec,'smoother_pos', prectype%smthpos, info)
|
|
|
|
|
if (prectype%athres >= dzero) &
|
|
|
|
|
& call mld_precset(prec,'aggr_thresh', prectype%athres, info)
|
|
|
|
|
call mld_precset(prec,'coarse_solve', prectype%csolve, info)
|
|
|
|
|
call mld_precset(prec,'coarse_subsolve', prectype%csbsolve,info)
|
|
|
|
|
call mld_precset(prec,'coarse_mat', prectype%cmat, info)
|
|
|
|
|
call mld_precset(prec,'coarse_fillin', prectype%cfill, info)
|
|
|
|
|
call mld_precset(prec,'coarse_iluthrs', prectype%cthres, info)
|
|
|
|
|
call mld_precset(prec,'coarse_sweeps', prectype%cjswp, info)
|
|
|
|
|
call mld_precset(prec,'coarse_aggr_size', prectype%csize, 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)
|
|
|
|
|
call mld_precset(prec,'smoother_sweeps', prectype%jsweeps, info)
|
|
|
|
|
call mld_precset(prec,'sub_ovr', prectype%novr, info)
|
|
|
|
|
call mld_precset(prec,'sub_restr', prectype%restr, info)
|
|
|
|
|
call mld_precset(prec,'sub_prol', prectype%prol, info)
|
|
|
|
|
call mld_precset(prec,'sub_solve', prectype%solve, info)
|
|
|
|
|
call mld_precset(prec,'sub_fillin', prectype%fill1, info)
|
|
|
|
|
call mld_precset(prec,'solver_sweeps', prectype%svsweeps, info)
|
|
|
|
|
call mld_precset(prec,'sub_iluthrs', prectype%thr1, info)
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
|
t1 = psb_wtime()
|
|
|
|
|
call mld_precbld(a,desc_a,prec,info)
|
|
|
|
@ -369,6 +375,7 @@ contains
|
|
|
|
|
call read_data(prectype%restr,psb_inp_unit) ! restriction over application of as
|
|
|
|
|
call read_data(prectype%prol,psb_inp_unit) ! prolongation over application of as
|
|
|
|
|
call read_data(prectype%solve,psb_inp_unit) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
|
call read_data(prectype%svsweeps,psb_inp_unit) ! Solver sweeps
|
|
|
|
|
call read_data(prectype%fill1,psb_inp_unit) ! Fill-in for factorization 1
|
|
|
|
|
call read_data(prectype%thr1,psb_inp_unit) ! Threshold for fact. 1 ILU(T)
|
|
|
|
|
call read_data(prectype%jsweeps,psb_inp_unit) ! Jacobi sweeps for PJAC
|
|
|
|
@ -407,6 +414,7 @@ contains
|
|
|
|
|
call psb_bcast(ictxt,prectype%restr) ! restriction over application of as
|
|
|
|
|
call psb_bcast(ictxt,prectype%prol) ! prolongation over application of as
|
|
|
|
|
call psb_bcast(ictxt,prectype%solve) ! Factorization type: ILU, SuperLU, UMFPACK.
|
|
|
|
|
call psb_bcast(ictxt,prectype%svsweeps) ! Sweeps for inner GS solver
|
|
|
|
|
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%jsweeps) ! Jacobi sweeps
|
|
|
|
|