Included first development version of multilevel stuff.

psblas3-type-indexed
Salvatore Filippone 19 years ago
parent 3f49de80d9
commit 048453938b

@ -124,4 +124,4 @@
real(kind(1.d0)), parameter :: epstol=1.d-32 real(kind(1.d0)), parameter :: epstol=1.d-32
character, parameter :: psb_all_='A', psb_topdef_=' ' character, parameter :: psb_all_='A', psb_topdef_=' '
character(len=5) :: psb_fidef_='CSR' character(len=5) :: psb_fidef_='CSR'

@ -39,7 +39,7 @@ module psb_prec_mod
use psb_prec_type use psb_prec_type
implicit none implicit none
type(psb_dspmat_type), intent(in), target :: a type(psb_dspmat_type), intent(in), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_dprec_type), intent(inout) :: prec type(psb_dprec_type), intent(inout) :: prec
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in),optional :: upd character, intent(in),optional :: upd
@ -49,7 +49,7 @@ module psb_prec_mod
use psb_prec_type use psb_prec_type
implicit none implicit none
type(psb_zspmat_type), intent(in), target :: a type(psb_zspmat_type), intent(in), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_zprec_type), intent(inout) :: prec type(psb_zprec_type), intent(inout) :: prec
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in),optional :: upd character, intent(in),optional :: upd
@ -57,7 +57,7 @@ module psb_prec_mod
end interface end interface
interface psb_precset interface psb_precset
subroutine psb_dprecset(prec,ptype,info,iv,rs,rv) subroutine psb_dprecset(prec,ptype,info,iv,rs,rv,ilev,nlev)
use psb_serial_mod use psb_serial_mod
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
@ -66,6 +66,7 @@ module psb_prec_mod
character(len=*), intent(in) :: ptype character(len=*), intent(in) :: ptype
integer, intent(out) :: info integer, intent(out) :: info
integer, optional, intent(in) :: iv(:) integer, optional, intent(in) :: iv(:)
integer, optional, intent(in) :: nlev,ilev
real(kind(1.d0)), optional, intent(in) :: rs real(kind(1.d0)), optional, intent(in) :: rs
real(kind(1.d0)), optional, intent(in) :: rv(:) real(kind(1.d0)), optional, intent(in) :: rv(:)
end subroutine psb_dprecset end subroutine psb_dprecset

@ -86,16 +86,60 @@ module psb_prec_type
type(psb_dspmat_type), pointer :: av(:) => null() ! type(psb_dspmat_type), pointer :: av(:) => null() !
real(kind(1.d0)), pointer :: d(:) => null() real(kind(1.d0)), pointer :: d(:) => null()
type(psb_desc_type), pointer :: desc_data => null() ! type(psb_desc_type), pointer :: desc_data => null(), desc_ac=>null()! !
integer, pointer :: iprcparm(:) => null() ! integer, pointer :: iprcparm(:) => null() !
real(kind(1.d0)), pointer :: dprcparm(:) => null() ! real(kind(1.d0)), pointer :: dprcparm(:) => null() !
integer, pointer :: perm(:) => null(), invperm(:) => null() integer, pointer :: perm(:) => null(), invperm(:) => null()
integer, pointer :: mlia(:) => null(), nlaggr(:) => null() ! integer, pointer :: mlia(:) => null(), nlaggr(:) => null() !
type(psb_dspmat_type), pointer :: aorig => null() ! type(psb_dspmat_type), pointer :: base_a => null() !
type(psb_desc_type), pointer :: base_desc => null() !
real(kind(1.d0)), pointer :: dorig(:) => null() ! real(kind(1.d0)), pointer :: dorig(:) => null() !
end type psb_dbaseprc_type end type psb_dbaseprc_type
!
! Multilevel preconditioning
!
! To each level I there corresponds a matrix A(I) and a preconditioner K(I)
!
! A notational difference: in the DD reference above the preconditioner for
! a given level K(I) is written out as a sum over the subdomains
!
! SUM_k(R_k^T A_k R_k)
!
! whereas in this code the sum is implicit in the parallelization,
! i.e. each process takes care of one subdomain, and for each level we have
! as many subdomains as there are processes (except for the coarsest level where
! we might have a replicated index space). Thus the sum apparently disappears
! from our code, but only apparently, because it is implicit in the call
! to psb_baseprc_aply.
!
! A bit of description of the baseprecv(:) data structure:
! 1. Number of levels = NLEV = size(baseprecv(:))
! 2. baseprecv(ilev)%av(:) sparse matrices needed for the current level.
! Includes:
! 2.1.: baseprecv(ilev)%av(l_pr_) L factor of ILU preconditioners
! 2.2.: baseprecv(ilev)%av(u_pr_) U factor of ILU preconditioners
! 2.3.: baseprecv(ilev)%av(ap_nd_) Off-diagonal part of A for Jacobi sweeps
! 2.4.: baseprecv(ilev)%av(ac_) Aggregated matrix of level ILEV
! 2.5.: baseprecv(ilev)%av(sm_pr_t_) Smoother prolongator transpose; maps vectors
! (ilev-1) ---> (ilev)
! 2.6.: baseprecv(ilev)%av(sm_pr_) Smoother prolongator; maps vectors
! (ilev) ---> (ilev-1)
! Shouldn't we keep just one of them and handle transpose in the sparse BLAS? maybe
!
! 3. baseprecv(ilev)%desc_data comm descriptor for level ILEV
! 4. baseprecv(ilev)%base_a Pointer (really a pointer!) to the base matrix
! of the current level, i.e.: if ILEV=1 then A
! else the aggregated matrix av(ac_); so we have
! a unified treatment of residuals. Need this to
! avoid passing explicitly matrix A to the
! outer prec. routine
! 5. baseprecv(ilev)%mlia The aggregation map from (ilev-1)-->(ilev)
! if no smoother, it is used instead of sm_pr_
! 6. baseprecv(ilev)%nlaggr Number of aggregates on the various procs.
!
type psb_dprec_type type psb_dprec_type
type(psb_dbaseprc_type), pointer :: baseprecv(:) => null() type(psb_dbaseprc_type), pointer :: baseprecv(:) => null()
! contain type of preconditioning to be performed ! contain type of preconditioning to be performed
@ -105,14 +149,15 @@ module psb_prec_type
type psb_zbaseprc_type type psb_zbaseprc_type
type(psb_zspmat_type), pointer :: av(:) => null() ! type(psb_zspmat_type), pointer :: av(:) => null() !
complex(kind(1.d0)), pointer :: d(:) => null() complex(kind(1.d0)), pointer :: d(:) => null()
type(psb_desc_type), pointer :: desc_data => null() ! type(psb_desc_type), pointer :: desc_data => null() , desc_ac=>null()!
integer, pointer :: iprcparm(:) => null() ! integer, pointer :: iprcparm(:) => null() !
real(kind(1.d0)), pointer :: dprcparm(:) => null() ! real(kind(1.d0)), pointer :: dprcparm(:) => null() !
integer, pointer :: perm(:) => null(), invperm(:) => null() integer, pointer :: perm(:) => null(), invperm(:) => null()
integer, pointer :: mlia(:) => null(), nlaggr(:) => null() ! integer, pointer :: mlia(:) => null(), nlaggr(:) => null() !
type(psb_zspmat_type), pointer :: aorig => null() ! type(psb_zspmat_type), pointer :: base_a => null() !
complex(kind(1.d0)), pointer :: dorig(:) => null() ! type(psb_desc_type), pointer :: base_desc => null() !
complex(kind(1.d0)), pointer :: dorig(:) => null() !
end type psb_zbaseprc_type end type psb_zbaseprc_type
@ -181,6 +226,7 @@ contains
subroutine psb_file_prec_descr(iout,p) subroutine psb_file_prec_descr(iout,p)
integer, intent(in) :: iout integer, intent(in) :: iout
type(psb_dprec_type), intent(in) :: p type(psb_dprec_type), intent(in) :: p
integer :: ilev
write(iout,*) 'Preconditioner description' write(iout,*) 'Preconditioner description'
if (associated(p%baseprecv)) then if (associated(p%baseprecv)) then
@ -206,40 +252,44 @@ contains
end select end select
end if end if
if (size(p%baseprecv)>=2) then if (size(p%baseprecv)>=2) then
if (.not.associated(p%baseprecv(2)%iprcparm)) then do ilev = 2, size(p%baseprecv)
write(iout,*) 'Inconsistent MLPREC part!' if (.not.associated(p%baseprecv(ilev)%iprcparm)) then
return write(iout,*) 'Inconsistent MLPREC part!'
endif return
write(iout,*) 'Multilevel: ',ml_names(p%baseprecv(2)%iprcparm(ml_type_)) endif
if (p%baseprecv(2)%iprcparm(ml_type_)>no_ml_) then
write(iout,*) 'Multilevel aggregation: ', & write(iout,*) 'Multilevel: Level No', ilev
& aggr_names(p%baseprecv(2)%iprcparm(aggr_alg_)) write(iout,*) 'Multilevel type: ',&
write(iout,*) 'Smoother: ', & & ml_names(p%baseprecv(ilev)%iprcparm(ml_type_))
& smooth_kinds(p%baseprecv(2)%iprcparm(smth_kind_)) if (p%baseprecv(ilev)%iprcparm(ml_type_)>no_ml_) then
if (p%baseprecv(2)%iprcparm(smth_kind_) /= no_smth_) then write(iout,*) 'Multilevel aggregation: ', &
write(iout,*) 'Smoothing omega: ', p%baseprecv(2)%dprcparm(smooth_omega_) & aggr_names(p%baseprecv(ilev)%iprcparm(aggr_alg_))
write(iout,*) 'Smoothing position: ',& write(iout,*) 'Smoother: ', &
& smooth_names(p%baseprecv(2)%iprcparm(smth_pos_)) & smooth_kinds(p%baseprecv(ilev)%iprcparm(smth_kind_))
if (p%baseprecv(ilev)%iprcparm(smth_kind_) /= no_smth_) then
write(iout,*) 'Smoothing omega: ', p%baseprecv(ilev)%dprcparm(smooth_omega_)
write(iout,*) 'Smoothing position: ',&
& smooth_names(p%baseprecv(ilev)%iprcparm(smth_pos_))
end if
write(iout,*) 'Coarse matrix: ',&
& matrix_names(p%baseprecv(ilev)%iprcparm(coarse_mat_))
write(iout,*) 'Aggregation sizes: ', &
& sum( p%baseprecv(ilev)%nlaggr(:)),' : ',p%baseprecv(ilev)%nlaggr(:)
write(iout,*) 'Factorization type: ',&
& fact_names(p%baseprecv(ilev)%iprcparm(f_type_))
select case(p%baseprecv(ilev)%iprcparm(f_type_))
case(f_ilu_n_)
write(iout,*) 'Fill level :',p%baseprecv(ilev)%iprcparm(ilu_fill_in_)
case(f_ilu_e_)
write(iout,*) 'Fill threshold :',p%baseprecv(ilev)%dprcparm(fact_eps_)
case(f_slu_,f_umf_)
case default
write(iout,*) 'Should never get here!'
end select
write(iout,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(ilev)%iprcparm(jac_sweeps_))
end if end if
write(iout,*) 'Coarse matrix: ',& end do
& matrix_names(p%baseprecv(2)%iprcparm(coarse_mat_))
write(iout,*) 'Aggregation sizes: ', &
& sum( p%baseprecv(2)%nlaggr(:)),' : ',p%baseprecv(2)%nlaggr(:)
write(iout,*) 'Factorization type: ',&
& fact_names(p%baseprecv(2)%iprcparm(f_type_))
select case(p%baseprecv(2)%iprcparm(f_type_))
case(f_ilu_n_)
write(iout,*) 'Fill level :',p%baseprecv(2)%iprcparm(ilu_fill_in_)
case(f_ilu_e_)
write(iout,*) 'Fill threshold :',p%baseprecv(2)%dprcparm(fact_eps_)
case(f_slu_,f_umf_)
case default
write(iout,*) 'Should never get here!'
end select
write(iout,*) 'Number of Jacobi sweeps: ', &
& (p%baseprecv(2)%iprcparm(jac_sweeps_))
end if
end if end if
else else
@ -355,13 +405,14 @@ contains
& aggr_names(p%baseprecv(2)%iprcparm(aggr_alg_)) & aggr_names(p%baseprecv(2)%iprcparm(aggr_alg_))
write(iout,*) 'Smoother: ', & write(iout,*) 'Smoother: ', &
& smooth_kinds(p%baseprecv(2)%iprcparm(smth_kind_)) & smooth_kinds(p%baseprecv(2)%iprcparm(smth_kind_))
write(iout,*) 'Smoothing omega: ', p%baseprecv(2)%dprcparm(smooth_omega_)
if (p%baseprecv(2)%iprcparm(smth_kind_) /= no_smth_) then if (p%baseprecv(2)%iprcparm(smth_kind_) /= no_smth_) then
write(iout,*) 'Smoothing omega: ', p%baseprecv(2)%dprcparm(smooth_omega_)
write(iout,*) 'Smoothing position: ',& write(iout,*) 'Smoothing position: ',&
& smooth_names(p%baseprecv(2)%iprcparm(smth_pos_)) & smooth_names(p%baseprecv(2)%iprcparm(smth_pos_))
write(iout,*) 'Coarse matrix: ',&
& matrix_names(p%baseprecv(2)%iprcparm(coarse_mat_))
end if end if
write(iout,*) 'Coarse matrix: ',&
& matrix_names(p%baseprecv(2)%iprcparm(coarse_mat_))
write(iout,*) 'Aggregation sizes: ', & write(iout,*) 'Aggregation sizes: ', &
& sum( p%baseprecv(2)%nlaggr(:)),' : ',p%baseprecv(2)%nlaggr(:) & sum( p%baseprecv(2)%nlaggr(:)),' : ',p%baseprecv(2)%nlaggr(:)
write(iout,*) 'Factorization type: ',& write(iout,*) 'Factorization type: ',&
@ -631,12 +682,23 @@ contains
end if end if
deallocate(p%desc_data) deallocate(p%desc_data)
endif endif
if (associated(p%desc_ac)) then
if (associated(p%desc_ac%matrix_data)) then
call psb_cdfree(p%desc_ac,info)
end if
deallocate(p%desc_ac)
endif
if (associated(p%dprcparm)) then if (associated(p%dprcparm)) then
deallocate(p%dprcparm,stat=info) deallocate(p%dprcparm,stat=info)
end if end if
if (associated(p%aorig)) then if (associated(p%base_a)) then
! This is a pointer to something else, must not free it here.
nullify(p%base_a)
endif
if (associated(p%base_desc)) then
! This is a pointer to something else, must not free it here. ! This is a pointer to something else, must not free it here.
nullify(p%aorig) nullify(p%base_desc)
endif endif
if (associated(p%dorig)) then if (associated(p%dorig)) then
deallocate(p%dorig,stat=info) deallocate(p%dorig,stat=info)
@ -676,7 +738,7 @@ contains
type(psb_dbaseprc_type), intent(inout) :: p type(psb_dbaseprc_type), intent(inout) :: p
nullify(p%av,p%d,p%iprcparm,p%dprcparm,p%perm,p%invperm,p%mlia,& nullify(p%av,p%d,p%iprcparm,p%dprcparm,p%perm,p%invperm,p%mlia,&
& p%nlaggr,p%aorig,p%dorig,p%desc_data) & p%nlaggr,p%base_a,p%base_desc,p%dorig,p%desc_data, p%desc_ac)
end subroutine psb_nullify_dbaseprec end subroutine psb_nullify_dbaseprec
@ -712,12 +774,22 @@ contains
end if end if
deallocate(p%desc_data) deallocate(p%desc_data)
endif endif
if (associated(p%desc_ac)) then
if (associated(p%desc_ac%matrix_data)) then
call psb_cdfree(p%desc_ac,info)
end if
deallocate(p%desc_ac)
endif
if (associated(p%dprcparm)) then if (associated(p%dprcparm)) then
deallocate(p%dprcparm,stat=info) deallocate(p%dprcparm,stat=info)
end if end if
if (associated(p%aorig)) then if (associated(p%base_a)) then
! This is a pointer to something else, must not free it here. ! This is a pointer to something else, must not free it here.
nullify(p%aorig) nullify(p%base_a)
endif
if (associated(p%base_desc)) then
! This is a pointer to something else, must not free it here.
nullify(p%base_desc)
endif endif
if (associated(p%dorig)) then if (associated(p%dorig)) then
deallocate(p%dorig,stat=info) deallocate(p%dorig,stat=info)
@ -741,11 +813,11 @@ contains
if (associated(p%iprcparm)) then if (associated(p%iprcparm)) then
if (p%iprcparm(f_type_)==f_slu_) then if (p%iprcparm(f_type_)==f_slu_) then
!!$ call psb_zslu_free(p%iprcparm(slu_ptr_),info) call psb_zslu_free(p%iprcparm(slu_ptr_),info)
end if end if
if (p%iprcparm(f_type_)==f_umf_) then if (p%iprcparm(f_type_)==f_umf_) then
!!$ call psb_zumf_free(p%iprcparm(umf_symptr_),& call psb_zumf_free(p%iprcparm(umf_symptr_),&
!!$ & p%iprcparm(umf_numptr_),info) & p%iprcparm(umf_numptr_),info)
end if end if
deallocate(p%iprcparm,stat=info) deallocate(p%iprcparm,stat=info)
end if end if
@ -757,7 +829,7 @@ contains
type(psb_zbaseprc_type), intent(inout) :: p type(psb_zbaseprc_type), intent(inout) :: p
nullify(p%av,p%d,p%iprcparm,p%dprcparm,p%perm,p%invperm,p%mlia,& nullify(p%av,p%d,p%iprcparm,p%dprcparm,p%perm,p%invperm,p%mlia,&
& p%nlaggr,p%aorig,p%dorig,p%desc_data) & p%nlaggr,p%base_a,p%base_desc,p%dorig,p%desc_data,p%desc_ac)
end subroutine psb_nullify_zbaseprec end subroutine psb_nullify_zbaseprec

@ -359,13 +359,15 @@ module psb_serial_mod
interface psb_symbmm interface psb_symbmm
subroutine psb_dsymbmm(a,b,c) subroutine psb_dsymbmm(a,b,c,info)
use psb_spmat_type use psb_spmat_type
type(psb_dspmat_type) :: a,b,c type(psb_dspmat_type) :: a,b,c
integer :: info
end subroutine psb_dsymbmm end subroutine psb_dsymbmm
subroutine psb_zsymbmm(a,b,c) subroutine psb_zsymbmm(a,b,c,info)
use psb_spmat_type use psb_spmat_type
type(psb_zspmat_type) :: a,b,c type(psb_zspmat_type) :: a,b,c
integer :: info
end subroutine psb_zsymbmm end subroutine psb_zsymbmm
end interface end interface

@ -34,9 +34,9 @@
!!$ POSSIBILITY OF SUCH DAMAGE. !!$ POSSIBILITY OF SUCH DAMAGE.
!!$ !!$
!!$ !!$
subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_dbaseprc_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
! !
! Compute Y <- beta*Y + K^-1 X ! Compute Y <- beta*Y + alpha*K^-1 X
! where K is a a basic preconditioner stored in prec ! where K is a a basic preconditioner stored in prec
! !
@ -52,7 +52,7 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_dbaseprc_type), intent(in) :: prec type(psb_dbaseprc_type), intent(in) :: prec
real(kind(0.d0)),intent(inout) :: x(:), y(:) real(kind(0.d0)),intent(inout) :: x(:), y(:)
real(kind(0.d0)),intent(in) :: beta real(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
real(kind(0.d0)),target :: work(:) real(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -68,17 +68,17 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
interface psb_bjac_aply interface psb_bjac_aply
subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_dbjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type), intent(in) :: desc_data type(psb_desc_type), intent(in) :: desc_data
type(psb_dbaseprc_type), intent(in) :: prec type(psb_dbaseprc_type), intent(in) :: prec
real(kind(0.d0)),intent(inout) :: x(:), y(:) real(kind(0.d0)),intent(inout) :: x(:), y(:)
real(kind(0.d0)),intent(in) :: beta real(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
real(kind(0.d0)),target :: work(:) real(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
end subroutine psb_dbjac_aply end subroutine psb_dbjac_aply
end interface end interface
name='psb_dbaseprc_aply' name='psb_dbaseprc_aply'
@ -105,33 +105,35 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
case(noprec_) case(noprec_)
n_row=desc_data%matrix_data(psb_n_row_) call psb_geaxpby(alpha,x,beta,y,desc_data,info)
if (beta==dzero) then
y(1:n_row) = x(1:n_row)
else if (beta==done) then
y(1:n_row) = x(1:n_row) + y(1:n_row)
else if (beta==-done) then
y(1:n_row) = x(1:n_row) - y(1:n_row)
else
y(1:n_row) = x(1:n_row) + beta*y(1:n_row)
end if
case(diagsc_) case(diagsc_)
n_row=desc_data%matrix_data(psb_n_row_) if (size(work) >= size(x)) then
if (beta==dzero) then ww => work
y(1:n_row) = x(1:n_row)*prec%d(1:n_row)
else if (beta==done) then
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) + y(1:n_row)
else if (beta==-done) then
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) - y(1:n_row)
else else
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) + beta*y(1:n_row) allocate(ww(size(x)),stat=info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Allocate')
goto 9999
end if
end if
n_row=desc_data%matrix_data(psb_n_row_)
ww(1:n_row) = x(1:n_row)*prec%d(1:n_row)
call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
if (size(work) < size(x)) then
deallocate(ww,stat=info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Deallocate')
goto 9999
end if
end if end if
case(bja_) case(bja_)
call psb_bjac_aply(prec,x,beta,y,desc_data,trans,work,info) call psb_bjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjac_aply' ch_err='psb_bjac_aply'
@ -142,7 +144,7 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
if (prec%iprcparm(n_ovr_)==0) then if (prec%iprcparm(n_ovr_)==0) then
! shortcut: this fixes performance for RAS(0) == BJA ! shortcut: this fixes performance for RAS(0) == BJA
call psb_bjac_aply(prec,x,beta,y,desc_data,trans,work,info) call psb_bjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjacaply' ch_err='psb_bjacaply'
@ -214,7 +216,7 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
end if end if
endif endif
call psb_bjac_aply(prec,tx,dzero,ty,prec%desc_data,trans,aux,info) call psb_bjac_aply(done,prec,tx,dzero,ty,prec%desc_data,trans,aux,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjac_aply' ch_err='psb_bjac_aply'
@ -250,18 +252,7 @@ subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
& prec%iprcparm(prol_) & prec%iprcparm(prol_)
end select end select
if (beta == dzero) then call psb_geaxpby(alpha,ty,beta,y,desc_data,info)
y(1:desc_data%matrix_data(psb_n_row_)) = ty(1:desc_data%matrix_data(psb_n_row_))
else if (beta == done) then
y(1:desc_data%matrix_data(psb_n_row_)) = y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
else if (beta == -done) then
y(1:desc_data%matrix_data(psb_n_row_)) = -y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
else
y(1:desc_data%matrix_data(psb_n_row_)) = beta*y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
end if
if ((6*isz) <= size(work)) then if ((6*isz) <= size(work)) then

@ -49,7 +49,7 @@ subroutine psb_dbaseprc_bld(a,desc_a,p,info,upd)
Implicit None Implicit None
type(psb_dspmat_type), target :: a type(psb_dspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_dbaseprc_type),intent(inout) :: p type(psb_dbaseprc_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
@ -169,7 +169,13 @@ subroutine psb_dbaseprc_bld(a,desc_a,p,info,upd)
select case(p%iprcparm(p_type_)) select case(p%iprcparm(p_type_))
case (noprec_) case (noprec_)
! Do nothing. ! Do nothing.
call psb_cdcpy(desc_a,p%desc_data,info)
if(info /= 0) then
info=4010
ch_err='psb_cdcpy'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
case (diagsc_) case (diagsc_)
@ -256,7 +262,8 @@ subroutine psb_dbaseprc_bld(a,desc_a,p,info,upd)
end select end select
p%base_a => a
p%base_desc => desc_a
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -34,9 +34,9 @@
!!$ POSSIBILITY OF SUCH DAMAGE. !!$ POSSIBILITY OF SUCH DAMAGE.
!!$ !!$
!!$ !!$
subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_dbjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
! !
! Compute Y <- beta*Y + K^-1 X ! Compute Y <- beta*Y + alpha*K^-1 X
! where K is a a Block Jacobi preconditioner stored in prec ! where K is a a Block Jacobi preconditioner stored in prec
! Note that desc_data may or may not be the same as prec%desc_data, ! Note that desc_data may or may not be the same as prec%desc_data,
! but since both are INTENT(IN) this should be legal. ! but since both are INTENT(IN) this should be legal.
@ -54,7 +54,7 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
type(psb_desc_type), intent(in) :: desc_data type(psb_desc_type), intent(in) :: desc_data
type(psb_dbaseprc_type), intent(in) :: prec type(psb_dbaseprc_type), intent(in) :: prec
real(kind(0.d0)),intent(inout) :: x(:), y(:) real(kind(0.d0)),intent(inout) :: x(:), y(:)
real(kind(0.d0)),intent(in) :: beta real(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
real(kind(0.d0)),target :: work(:) real(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -125,7 +125,7 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
& trans='N',unit=diagl,choice=psb_none_,work=aux) & trans='N',unit=diagl,choice=psb_none_,work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row) ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row)
call psb_spsm(done,prec%av(u_pr_),ww,beta,y,desc_data,info,& call psb_spsm(alpha,prec%av(u_pr_),ww,beta,y,desc_data,info,&
& trans='N',unit=diagu,choice=psb_none_, work=aux) & trans='N',unit=diagu,choice=psb_none_, work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
@ -134,7 +134,7 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
& trans=trans,unit=diagu,choice=psb_none_, work=aux) & trans=trans,unit=diagu,choice=psb_none_, work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row) ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row)
call psb_spsm(done,prec%av(l_pr_),ww,beta,y,desc_data,info,& call psb_spsm(alpha,prec%av(l_pr_),ww,beta,y,desc_data,info,&
& trans=trans,unit=diagl,choice=psb_none_,work=aux) & trans=trans,unit=diagl,choice=psb_none_,work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
@ -152,16 +152,8 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
end select end select
if(info /=0) goto 9999 if(info /=0) goto 9999
call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
if (beta == dzero) then
y(1:n_row) = ww(1:n_row)
else if (beta==done) then
y(1:n_row) = ww(1:n_row) + y(1:n_row)
else if (beta==-done) then
y(1:n_row) = ww(1:n_row) - y(1:n_row)
else
y(1:n_row) = ww(1:n_row) + beta*y(1:n_row)
endif
case (f_umf_) case (f_umf_)
@ -174,15 +166,7 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
if(info /=0) goto 9999 if(info /=0) goto 9999
if (beta == dzero) then call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
y(1:n_row) = ww(1:n_row)
else if (beta==dzero) then
y(1:n_row) = ww(1:n_row) + y(1:n_row)
else if (beta==-dzero) then
y(1:n_row) = ww(1:n_row) - y(1:n_row)
else
y(1:n_row) = ww(1:n_row) + beta*y(1:n_row)
endif
case default case default
write(0,*) 'Unknown factorization type in bjac_aply',prec%iprcparm(f_type_) write(0,*) 'Unknown factorization type in bjac_aply',prec%iprcparm(f_type_)
@ -253,15 +237,8 @@ subroutine psb_dbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
end select end select
if (beta == dzero) then call psb_geaxpby(alpha,tx,beta,y,desc_data,info)
y(1:n_row) = tx(1:n_row)
else if (beta==done) then
y(1:n_row) = tx(1:n_row) + y(1:n_row)
else if (beta==-done) then
y(1:n_row) = tx(1:n_row) - y(1:n_row)
else
y(1:n_row) = tx(1:n_row) + beta*y(1:n_row)
endif
deallocate(tx,ty) deallocate(tx,ty)

@ -75,13 +75,14 @@ subroutine psb_dbldaggrmat(a,desc_a,ac,p,desc_p,info)
if (aggr_dump) call psb_csprt(90+me,ac,head='% Raw aggregate.') if (aggr_dump) call psb_csprt(90+me,ac,head='% Raw aggregate.')
case(smth_omg_,smth_biz_) case(smth_omg_,smth_biz_)
if (aggr_dump) call psb_csprt(70+me,a,head='% Input matrix')
call smooth_aggregate(info) call smooth_aggregate(info)
if(info /= 0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='smooth_aggregate') call psb_errpush(4010,name,a_err='smooth_aggregate')
goto 9999 goto 9999
end if end if
if (aggr_dump) call psb_csprt(90+me,ac,head='% Smooth aggregate.')
case default case default
call psb_errpush(4010,name,a_err=name) call psb_errpush(4010,name,a_err=name)
goto 9999 goto 9999
@ -117,6 +118,7 @@ contains
integer :: ictxt, nrow, nglob, ncol, ntaggr, nzbg, ip, ndx,& integer :: ictxt, nrow, nglob, ncol, ntaggr, nzbg, ip, ndx,&
& naggr, np, me, nzt,irs,jl,nzl,nlr,& & naggr, np, me, nzt,irs,jl,nzl,nlr,&
& icomm,naggrm1, i, j, k, err_act & icomm,naggrm1, i, j, k, err_act
name='raw_aggregate' name='raw_aggregate'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus().ne.0) return
info=0 info=0
@ -228,11 +230,6 @@ contains
enddo enddo
end if end if
call psb_fixcoo(b,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='fixcoo')
goto 9999
end if
irs = b%infoa(psb_nnz_) irs = b%infoa(psb_nnz_)
call psb_sp_reall(b,irs,info) call psb_sp_reall(b,irs,info)
@ -523,8 +520,6 @@ contains
endif endif
if (test_dump) call &
& psb_csprt(20+me,am4,head='% Operator Ptilde.',ivr=desc_a%loc_to_glob)
call psb_ipcoo2csr(am4,info) call psb_ipcoo2csr(am4,info)
@ -542,7 +537,7 @@ contains
! !
! WARNING: the cycles below assume that AM3 does have ! WARNING: the cycles below assume that AM3 does have
! its diagonal elements stored explicitly!!! ! its diagonal elements stored explicitly!!!
! Should we swicth to something safer? ! Should we switch to something safer?
! !
call psb_spscal(am3,p%dorig,info) call psb_spscal(am3,p%dorig,info)
if(info /= 0) goto 9999 if(info /= 0) goto 9999
@ -604,12 +599,15 @@ contains
am3%aspk(j) = done - omega*am3%aspk(j) am3%aspk(j) = done - omega*am3%aspk(j)
endif endif
end do end do
call psb_ipcoo2csr(am3,info)
else else
write(0,*) 'Missing implementation of I sum' write(0,*) 'Missing implementation of I sum'
call psb_errpush(4010,name) call psb_errpush(4010,name)
goto 9999 goto 9999
end if end if
if (test_dump) call &
& psb_csprt(20+me,am4,head='% Operator Ptilde.',ivr=desc_a%loc_to_glob)
if (test_dump) call psb_csprt(40+me,am3,head='% (I-wDA)',ivr=desc_a%loc_to_glob,& if (test_dump) call psb_csprt(40+me,am3,head='% (I-wDA)',ivr=desc_a%loc_to_glob,&
& ivc=desc_a%loc_to_glob) & ivc=desc_a%loc_to_glob)
if (debug) write(0,*) me,'Done gather, going for SYMBMM 1' if (debug) write(0,*) me,'Done gather, going for SYMBMM 1'
@ -620,7 +618,15 @@ contains
! Doing it this way means to consider diag(Ai) ! Doing it this way means to consider diag(Ai)
! !
! !
call psb_symbmm(am3,am4,am1) call psb_symbmm(am3,am4,am1,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm 1')
goto 9999
end if
am1%aspk(:) = 0.d0
if (test_dump) &
& call psb_csprt(50+me,am1,head='% (I-wDA)Pt symbmm ')
call psb_numbmm(am3,am4,am1) call psb_numbmm(am3,am4,am1)
if (debug) write(0,*) me,'Done NUMBMM 1' if (debug) write(0,*) me,'Done NUMBMM 1'
@ -667,7 +673,12 @@ contains
if (test_dump) & if (test_dump) &
& call psb_csprt(60+me,am1,head='% (I-wDA)Pt',ivr=desc_a%loc_to_glob) & call psb_csprt(60+me,am1,head='% (I-wDA)Pt',ivr=desc_a%loc_to_glob)
call psb_symbmm(a,am1,am3) call psb_symbmm(a,am1,am3,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm 2')
goto 9999
end if
call psb_numbmm(a,am1,am3) call psb_numbmm(a,am1,am3)
if (debug) write(0,*) me,'Done NUMBMM 2' if (debug) write(0,*) me,'Done NUMBMM 2'
@ -724,7 +735,12 @@ contains
endif endif
if (debug) write(0,*) me,'starting symbmm 3' if (debug) write(0,*) me,'starting symbmm 3'
call psb_symbmm(am2,am3,b) call psb_symbmm(am2,am3,b,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm 3')
goto 9999
end if
if (debug) write(0,*) me,'starting numbmm 3' if (debug) write(0,*) me,'starting numbmm 3'
call psb_numbmm(am2,am3,b) call psb_numbmm(am2,am3,b)
if (debug) write(0,*) me,'Done NUMBMM 3' if (debug) write(0,*) me,'Done NUMBMM 3'
@ -1018,6 +1034,7 @@ contains
deallocate(nzbr,idisp) deallocate(nzbr,idisp)
end select end select
call psb_ipcoo2csr(bg,info)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -98,6 +98,11 @@ subroutine psb_ddiagsc_bld(a,desc_a,p,upd,info)
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
call psb_cdcpy(desc_a,p%desc_Data,info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='psb_cdcpy')
goto 9999
end if
if (debug) write(ilout+me,*) 'VDIAG ',n_row if (debug) write(ilout+me,*) 'VDIAG ',n_row
do i=1,n_row do i=1,n_row

@ -92,7 +92,7 @@ subroutine psb_dgenaggrmap(aggr_type,a,desc_a,nlaggr,ilaggr,info)
! Very simple minded strategy. ! Very simple minded strategy.
! !
naggr = 0 naggr = 0
nlp = 0 nlp = 0
do do
icnt = 0 icnt = 0
do i=1, nr do i=1, nr

File diff suppressed because it is too large Load Diff

@ -135,8 +135,6 @@ subroutine psb_dmlprc_bld(a,desc_a,p,info)
p%aorig => a
nullify(p%d) nullify(p%d)
@ -167,7 +165,7 @@ subroutine psb_dmlprc_bld(a,desc_a,p,info)
call psb_baseprc_bld(ac,desc_p,p,info) call psb_baseprc_bld(ac,desc_p,p,info)
if (debug) write(0,*) 'Out from basaeprcbld',info if (debug) write(0,*) 'Out from baseprcbld',info
if(info /= 0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_baseprc_bld' ch_err='psb_baseprc_bld'
@ -180,13 +178,13 @@ subroutine psb_dmlprc_bld(a,desc_a,p,info)
! We have used a separate ac because: ! We have used a separate ac because:
! 1. We want to reuse the same routines psb_ilu_bld etc. ! 1. We want to reuse the same routines psb_ilu_bld etc.
! 2. We do NOT want to pass an argument twice to them ! 2. We do NOT want to pass an argument twice to them
! p%av(ac_) and p ! p%av(ac_) and p, as this would violate the Fortran standard
! Hence a separate AC and a TRANSFER function. ! Hence a separate AC and a TRANSFER function at the end.
! !
call psb_sp_transfer(ac,p%av(ac_),info) call psb_sp_transfer(ac,p%av(ac_),info)
p%base_a => p%av(ac_)
call psb_cdfree(desc_p,info) p%desc_ac => desc_p
deallocate(desc_p) nullify(desc_p)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -61,13 +61,13 @@ subroutine psb_dprc_aply(prec,x,y,desc_data,info,trans, work)
character(len=20) :: name character(len=20) :: name
interface psb_baseprc_aply interface psb_baseprc_aply
subroutine psb_dbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_dbaseprc_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_dbaseprc_type), intent(in) :: prec type(psb_dbaseprc_type), intent(in) :: prec
real(kind(0.d0)),intent(inout) :: x(:), y(:) real(kind(0.d0)),intent(inout) :: x(:), y(:)
real(kind(0.d0)),intent(in) :: beta real(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
real(kind(0.d0)),target :: work(:) real(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -75,12 +75,12 @@ subroutine psb_dprc_aply(prec,x,y,desc_data,info,trans, work)
end interface end interface
interface psb_mlprc_aply interface psb_mlprc_aply
subroutine psb_dmlprc_aply(baseprecv,x,beta,y,desc_data,trans,work,info) subroutine psb_dmlprc_aply(alpha,baseprecv,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_dbaseprc_type), intent(in) :: baseprecv(:) type(psb_dbaseprc_type), intent(in) :: baseprecv(:)
real(kind(0.d0)),intent(in) :: beta real(kind(0.d0)),intent(in) :: alpha,beta
real(kind(0.d0)),intent(inout) :: x(:), y(:) real(kind(0.d0)),intent(inout) :: x(:), y(:)
character :: trans character :: trans
real(kind(0.d0)),target :: work(:) real(kind(0.d0)),target :: work(:)
@ -117,14 +117,14 @@ subroutine psb_dprc_aply(prec,x,y,desc_data,info,trans, work)
end if end if
if (size(prec%baseprecv) >1) then if (size(prec%baseprecv) >1) then
if (debug) write(0,*) 'Into mlprc_aply',size(x),size(y) if (debug) write(0,*) 'Into mlprc_aply',size(x),size(y)
call psb_mlprc_aply(prec%baseprecv,x,dzero,y,desc_data,trans_,work_,info) call psb_mlprc_aply(done,prec%baseprecv,x,dzero,y,desc_data,trans_,work_,info)
if(info /= 0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='psb_dmlprc_aply') call psb_errpush(4010,name,a_err='psb_dmlprc_aply')
goto 9999 goto 9999
end if end if
else if (size(prec%baseprecv) == 1) then else if (size(prec%baseprecv) == 1) then
call psb_baseprc_aply(prec%baseprecv(1),x,dzero,y,desc_data,trans_, work_,info) call psb_baseprc_aply(done,prec%baseprecv(1),x,dzero,y,desc_data,trans_, work_,info)
else else
write(0,*) 'Inconsistent preconditioner: size of baseprecv???' write(0,*) 'Inconsistent preconditioner: size of baseprecv???'
endif endif

@ -48,19 +48,19 @@ subroutine psb_dprecbld(a,desc_a,p,info,upd)
use psb_penv_mod use psb_penv_mod
Implicit None Implicit None
type(psb_dspmat_type), target :: a type(psb_dspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_dprec_type),intent(inout) :: p type(psb_dprec_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
interface psb_baseprc_bld interface psb_baseprc_bld
subroutine psb_dbaseprc_bld(a,desc_a,p,info,upd) subroutine psb_dbaseprc_bld(a,desc_a,p,info,upd)
Use psb_spmat_type Use psb_spmat_type
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_dspmat_type) :: a type(psb_dspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_dbaseprc_type),intent(inout) :: p type(psb_dbaseprc_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
@ -149,29 +149,8 @@ subroutine psb_dprecbld(a,desc_a,p,info,upd)
endif endif
if (size(p%baseprecv) > 1) then if (size(p%baseprecv) > 1) then
call init_baseprc_av(p%baseprecv(2),info)
if (info /= 0) then
info=4010
ch_err='allocate'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
endif
call psb_mlprc_bld(a,desc_a,p%baseprecv(2),info) do i=2, size(p%baseprecv)
if(info /= 0) then
info=4010
ch_err='psb_mlprc_bld'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
!
! Note: this here has not been tried out. We probably need
! a different baseprc field %desc_ac, in case we try RAS on lev. 2 of
! a 3-level prec.
!
do i=3, size(p%baseprecv)
call init_baseprc_av(p%baseprecv(i),info) call init_baseprc_av(p%baseprecv(i),info)
if (info /= 0) then if (info /= 0) then
info=4010 info=4010
@ -180,8 +159,17 @@ subroutine psb_dprecbld(a,desc_a,p,info,upd)
goto 9999 goto 9999
endif endif
call psb_mlprc_bld(p%baseprecv(i-1)%av(ac_),p%baseprecv(i-1)%desc_data,& call psb_mlprc_bld(p%baseprecv(i-1)%base_a,p%baseprecv(i-1)%base_desc,&
& p%baseprecv(i),info) & p%baseprecv(i),info)
if (info /= 0) then
info=4010
call psb_errpush(info,name)
goto 9999
endif
if (debug) then
write(0,*) 'Return from ',i-1,' call to mlprcbld ',info
endif
end do end do
endif endif
@ -206,7 +194,7 @@ contains
! Have not decided what to do yet ! Have not decided what to do yet
end if end if
allocate(p%av(max_avsz),stat=info) allocate(p%av(max_avsz),stat=info)
if (info /= 0) return !!$ if (info /= 0) return
do k=1,size(p%av) do k=1,size(p%av)
call psb_nullify_sp(p%av(k)) call psb_nullify_sp(p%av(k))
end do end do

@ -34,33 +34,57 @@
!!$ POSSIBILITY OF SUCH DAMAGE. !!$ POSSIBILITY OF SUCH DAMAGE.
!!$ !!$
!!$ !!$
subroutine psb_dprecset(p,ptype,info,iv,rs,rv) subroutine psb_dprecset(p,ptype,info,iv,rs,rv,ilev,nlev)
use psb_serial_mod use psb_serial_mod
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
implicit none implicit none
type(psb_dprec_type), intent(inout) :: p type(psb_dprec_type), intent(inout) :: p
character(len=*), intent(in) :: ptype character(len=*), intent(in) :: ptype
integer, intent(out) :: info integer, intent(out) :: info
integer, optional, intent(in) :: iv(:) integer, optional, intent(in) :: iv(:)
integer, optional, intent(in) :: nlev,ilev
real(kind(1.d0)), optional, intent(in) :: rs real(kind(1.d0)), optional, intent(in) :: rs
real(kind(1.d0)), optional, intent(in) :: rv(:) real(kind(1.d0)), optional, intent(in) :: rv(:)
type(psb_dbaseprc_type), pointer :: bpv(:)=>null() type(psb_dbaseprc_type), pointer :: bpv(:)=>null()
character(len=len(ptype)) :: typeup character(len=len(ptype)) :: typeup
integer :: isz, err integer :: isz, err, nlev_, ilev_, i
info = 0 info = 0
if (present(ilev)) then
ilev_ = max(1, ilev)
else
ilev_ = 1
end if
if (present(nlev)) then
if (associated(p%baseprecv)) then
write(0,*) 'Warning: NLEV is ignored when P is already associated'
end if
nlev_ = max(1, nlev)
else
nlev_ = 1
end if
if (.not.associated(p%baseprecv)) then if (.not.associated(p%baseprecv)) then
allocate(p%baseprecv(1),stat=err) allocate(p%baseprecv(nlev_),stat=err)
call psb_nullify_baseprec(p%baseprecv(1)) do i=1, nlev_
call psb_nullify_baseprec(p%baseprecv(i))
end do
else
nlev_ = size(p%baseprecv)
endif endif
if (.not.associated(p%baseprecv(1)%iprcparm)) then if ((ilev_<1).or.(ilev_ > nlev_)) then
allocate(p%baseprecv(1)%iprcparm(ifpsz),stat=err) write(0,*) 'PRECSET ERRROR: ilev out of bounds'
info = -1
return
endif
if (.not.associated(p%baseprecv(ilev_)%iprcparm)) then
allocate(p%baseprecv(ilev_)%iprcparm(ifpsz),&
& p%baseprecv(ilev_)%dprcparm(dfpsz),stat=err)
if (err/=0) then if (err/=0) then
write(0,*)'Precset Memory Failure',err write(0,*)'Precset Memory Failure',err
endif endif
@ -68,124 +92,103 @@ subroutine psb_dprecset(p,ptype,info,iv,rs,rv)
select case(toupper(ptype(1:len_trim(ptype)))) select case(toupper(ptype(1:len_trim(ptype))))
case ('NONE','NOPREC') case ('NONE','NOPREC')
p%baseprecv(1)%iprcparm(:) = 0 p%baseprecv(ilev_)%iprcparm(:) = 0
p%baseprecv(1)%iprcparm(p_type_) = noprec_ p%baseprecv(ilev_)%iprcparm(p_type_) = noprec_
p%baseprecv(1)%iprcparm(f_type_) = f_none_ p%baseprecv(ilev_)%iprcparm(f_type_) = f_none_
p%baseprecv(1)%iprcparm(restr_) = psb_none_ p%baseprecv(ilev_)%iprcparm(restr_) = psb_none_
p%baseprecv(1)%iprcparm(prol_) = psb_none_ p%baseprecv(ilev_)%iprcparm(prol_) = psb_none_
p%baseprecv(1)%iprcparm(iren_) = 0 p%baseprecv(ilev_)%iprcparm(iren_) = 0
p%baseprecv(1)%iprcparm(n_ovr_) = 0 p%baseprecv(ilev_)%iprcparm(n_ovr_) = 0
p%baseprecv(1)%iprcparm(jac_sweeps_) = 1 p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = 1
case ('DIAG','DIAGSC') case ('DIAG','DIAGSC')
p%baseprecv(1)%iprcparm(:) = 0 p%baseprecv(ilev_)%iprcparm(:) = 0
p%baseprecv(1)%iprcparm(p_type_) = diagsc_ p%baseprecv(ilev_)%iprcparm(p_type_) = diagsc_
p%baseprecv(1)%iprcparm(f_type_) = f_none_ p%baseprecv(ilev_)%iprcparm(f_type_) = f_none_
p%baseprecv(1)%iprcparm(restr_) = psb_none_ p%baseprecv(ilev_)%iprcparm(restr_) = psb_none_
p%baseprecv(1)%iprcparm(prol_) = psb_none_ p%baseprecv(ilev_)%iprcparm(prol_) = psb_none_
p%baseprecv(1)%iprcparm(iren_) = 0 p%baseprecv(ilev_)%iprcparm(iren_) = 0
p%baseprecv(1)%iprcparm(n_ovr_) = 0 p%baseprecv(ilev_)%iprcparm(n_ovr_) = 0
p%baseprecv(1)%iprcparm(jac_sweeps_) = 1 p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = 1
case ('BJA','ILU') case ('BJA','ILU')
p%baseprecv(1)%iprcparm(:) = 0 p%baseprecv(ilev_)%iprcparm(:) = 0
p%baseprecv(1)%iprcparm(p_type_) = bja_ p%baseprecv(ilev_)%iprcparm(p_type_) = bja_
p%baseprecv(1)%iprcparm(f_type_) = f_ilu_n_ p%baseprecv(ilev_)%iprcparm(f_type_) = f_ilu_n_
p%baseprecv(1)%iprcparm(restr_) = psb_none_ p%baseprecv(ilev_)%iprcparm(restr_) = psb_none_
p%baseprecv(1)%iprcparm(prol_) = psb_none_ p%baseprecv(ilev_)%iprcparm(prol_) = psb_none_
p%baseprecv(1)%iprcparm(iren_) = 0 p%baseprecv(ilev_)%iprcparm(iren_) = 0
p%baseprecv(1)%iprcparm(n_ovr_) = 0 p%baseprecv(ilev_)%iprcparm(n_ovr_) = 0
p%baseprecv(1)%iprcparm(ilu_fill_in_) = 0 p%baseprecv(ilev_)%iprcparm(ilu_fill_in_) = 0
p%baseprecv(1)%iprcparm(jac_sweeps_) = 1 p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = 1
case ('ASM','AS') case ('ASM','AS')
p%baseprecv(1)%iprcparm(:) = 0 p%baseprecv(ilev_)%iprcparm(:) = 0
! Defaults first ! Defaults first
p%baseprecv(1)%iprcparm(p_type_) = asm_ p%baseprecv(ilev_)%iprcparm(p_type_) = asm_
p%baseprecv(1)%iprcparm(f_type_) = f_ilu_n_ p%baseprecv(ilev_)%iprcparm(f_type_) = f_ilu_n_
p%baseprecv(1)%iprcparm(restr_) = psb_halo_ p%baseprecv(ilev_)%iprcparm(restr_) = psb_halo_
p%baseprecv(1)%iprcparm(prol_) = psb_none_ p%baseprecv(ilev_)%iprcparm(prol_) = psb_none_
p%baseprecv(1)%iprcparm(iren_) = 0 p%baseprecv(ilev_)%iprcparm(iren_) = 0
p%baseprecv(1)%iprcparm(n_ovr_) = 1 p%baseprecv(ilev_)%iprcparm(n_ovr_) = 1
p%baseprecv(1)%iprcparm(ilu_fill_in_) = 0 p%baseprecv(ilev_)%iprcparm(ilu_fill_in_) = 0
p%baseprecv(1)%iprcparm(jac_sweeps_) = 1 p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = 1
if (present(iv)) then if (present(iv)) then
isz = size(iv) isz = size(iv)
if (isz >= 1) p%baseprecv(1)%iprcparm(n_ovr_) = iv(1) if (isz >= 1) p%baseprecv(ilev_)%iprcparm(n_ovr_) = iv(1)
if (isz >= 2) p%baseprecv(1)%iprcparm(restr_) = iv(2) if (isz >= 2) p%baseprecv(ilev_)%iprcparm(restr_) = iv(2)
if (isz >= 3) p%baseprecv(1)%iprcparm(prol_) = iv(3) if (isz >= 3) p%baseprecv(ilev_)%iprcparm(prol_) = iv(3)
if (isz >= 4) p%baseprecv(1)%iprcparm(f_type_) = iv(4) if (isz >= 4) p%baseprecv(ilev_)%iprcparm(f_type_) = iv(4)
! Do not consider renum for the time being. ! Do not consider renum for the time being.
!!$ if (isz >= 5) p%baseprecv(1)%iprcparm(iren_) = iv(5) !!$ if (isz >= 5) p%baseprecv(ilev_)%iprcparm(iren_) = iv(5)
end if end if
case ('ML', '2L', '2LEV') case ('ML', '2L', '2LEV')
select case (size(p%baseprecv)) !!$ allocate(p%baseprecv(ilev_)%iprcparm(ifpsz),stat=err)
case(1) !!$ if (err/=0) then
! Reallocate !!$ write(0,*)'Precset Memory Failure 2l:2',err
allocate(bpv(2),stat=err) !!$ endif
if (err/=0) then !!$ allocate(p%baseprecv(ilev_)%dprcparm(dfpsz),stat=err)
write(0,*)'Precset Memory Failure 2l:1',err !!$ if (err/=0) then
endif !!$ write(0,*)'Precset Memory Failure 2l:3',err
bpv(1) = p%baseprecv(1) !!$ endif
call psb_nullify_baseprec(bpv(2))
deallocate(p%baseprecv) p%baseprecv(ilev_)%iprcparm(:) = 0
p%baseprecv => bpv
nullify(bpv) p%baseprecv(ilev_)%iprcparm(p_type_) = bja_
p%baseprecv(ilev_)%iprcparm(restr_) = psb_none_
case(2) p%baseprecv(ilev_)%iprcparm(prol_) = psb_none_
! Do nothing p%baseprecv(ilev_)%iprcparm(iren_) = 0
p%baseprecv(ilev_)%iprcparm(n_ovr_) = 0
case default p%baseprecv(ilev_)%iprcparm(ml_type_) = mult_ml_prec_
! Error p%baseprecv(ilev_)%iprcparm(aggr_alg_) = loc_aggr_
p%baseprecv(ilev_)%iprcparm(smth_kind_) = smth_omg_
end select p%baseprecv(ilev_)%iprcparm(coarse_mat_) = mat_distr_
p%baseprecv(ilev_)%iprcparm(smth_pos_) = post_smooth_
allocate(p%baseprecv(2)%iprcparm(ifpsz),stat=err) p%baseprecv(ilev_)%iprcparm(glb_smth_) = 1
if (err/=0) then p%baseprecv(ilev_)%iprcparm(om_choice_) = lib_choice_
write(0,*)'Precset Memory Failure 2l:2',err p%baseprecv(ilev_)%iprcparm(f_type_) = f_ilu_n_
endif p%baseprecv(ilev_)%iprcparm(ilu_fill_in_) = 0
allocate(p%baseprecv(2)%dprcparm(dfpsz),stat=err) p%baseprecv(ilev_)%dprcparm(smooth_omega_) = 4.d0/3.d0
if (err/=0) then p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = 1
write(0,*)'Precset Memory Failure 2l:3',err
endif
p%baseprecv(2)%iprcparm(:) = 0
p%baseprecv(2)%iprcparm(p_type_) = bja_
p%baseprecv(2)%iprcparm(restr_) = psb_none_
p%baseprecv(2)%iprcparm(prol_) = psb_none_
p%baseprecv(2)%iprcparm(iren_) = 0
p%baseprecv(2)%iprcparm(n_ovr_) = 0
p%baseprecv(2)%iprcparm(ml_type_) = mult_ml_prec_
p%baseprecv(2)%iprcparm(aggr_alg_) = loc_aggr_
p%baseprecv(2)%iprcparm(smth_kind_) = smth_omg_
p%baseprecv(2)%iprcparm(coarse_mat_) = mat_distr_
p%baseprecv(2)%iprcparm(smth_pos_) = post_smooth_
p%baseprecv(2)%iprcparm(glb_smth_) = 1
p%baseprecv(2)%iprcparm(om_choice_) = lib_choice_
p%baseprecv(2)%iprcparm(f_type_) = f_ilu_n_
p%baseprecv(2)%iprcparm(ilu_fill_in_) = 0
p%baseprecv(2)%dprcparm(smooth_omega_) = 4.d0/3.d0
p%baseprecv(2)%iprcparm(jac_sweeps_) = 1
if (present(iv)) then if (present(iv)) then
isz = size(iv) isz = size(iv)
if (isz >= 1) p%baseprecv(2)%iprcparm(ml_type_) = iv(1) if (isz >= 1) p%baseprecv(ilev_)%iprcparm(ml_type_) = iv(1)
if (isz >= 2) p%baseprecv(2)%iprcparm(aggr_alg_) = iv(2) if (isz >= 2) p%baseprecv(ilev_)%iprcparm(aggr_alg_) = iv(2)
if (isz >= 3) p%baseprecv(2)%iprcparm(smth_kind_) = iv(3) if (isz >= 3) p%baseprecv(ilev_)%iprcparm(smth_kind_) = iv(3)
if (isz >= 4) p%baseprecv(2)%iprcparm(coarse_mat_) = iv(4) if (isz >= 4) p%baseprecv(ilev_)%iprcparm(coarse_mat_) = iv(4)
if (isz >= 5) p%baseprecv(2)%iprcparm(smth_pos_) = iv(5) if (isz >= 5) p%baseprecv(ilev_)%iprcparm(smth_pos_) = iv(5)
if (isz >= 6) p%baseprecv(2)%iprcparm(f_type_) = iv(6) if (isz >= 6) p%baseprecv(ilev_)%iprcparm(f_type_) = iv(6)
if (isz >= 7) p%baseprecv(2)%iprcparm(jac_sweeps_) = iv(7) if (isz >= 7) p%baseprecv(ilev_)%iprcparm(jac_sweeps_) = iv(7)
end if end if
if (present(rs)) then if (present(rs)) then
p%baseprecv(2)%iprcparm(om_choice_) = user_choice_ p%baseprecv(ilev_)%iprcparm(om_choice_) = user_choice_
p%baseprecv(2)%dprcparm(smooth_omega_) = rs p%baseprecv(ilev_)%dprcparm(smooth_omega_) = rs
end if end if

@ -34,9 +34,9 @@
!!$ POSSIBILITY OF SUCH DAMAGE. !!$ POSSIBILITY OF SUCH DAMAGE.
!!$ !!$
!!$ !!$
subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_zbaseprc_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
! !
! Compute Y <- beta*Y + K^-1 X ! Compute Y <- beta*Y + alpha*K^-1 X
! where K is a a basic preconditioner stored in prec ! where K is a a basic preconditioner stored in prec
! !
@ -52,7 +52,7 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_zbaseprc_type), intent(in) :: prec type(psb_zbaseprc_type), intent(in) :: prec
complex(kind(0.d0)),intent(inout) :: x(:), y(:) complex(kind(0.d0)),intent(inout) :: x(:), y(:)
complex(kind(0.d0)),intent(in) :: beta complex(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
complex(kind(0.d0)),target :: work(:) complex(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -68,13 +68,13 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
interface psb_bjac_aply interface psb_bjac_aply
subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_zbjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type), intent(in) :: desc_data type(psb_desc_type), intent(in) :: desc_data
type(psb_zbaseprc_type), intent(in) :: prec type(psb_zbaseprc_type), intent(in) :: prec
complex(kind(0.d0)),intent(inout) :: x(:), y(:) complex(kind(0.d0)),intent(inout) :: x(:), y(:)
complex(kind(0.d0)),intent(in) :: beta complex(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
complex(kind(0.d0)),target :: work(:) complex(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -105,33 +105,35 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
case(noprec_) case(noprec_)
n_row=desc_data%matrix_data(psb_n_row_) call psb_geaxpby(alpha,x,beta,y,desc_data,info)
if (beta==zzero) then
y(1:n_row) = x(1:n_row)
else if (beta==zone) then
y(1:n_row) = x(1:n_row) + y(1:n_row)
else if (beta==-zone) then
y(1:n_row) = x(1:n_row) - y(1:n_row)
else
y(1:n_row) = x(1:n_row) + beta*y(1:n_row)
end if
case(diagsc_) case(diagsc_)
n_row=desc_data%matrix_data(psb_n_row_) if (size(work) >= size(x)) then
if (beta==zzero) then ww => work
y(1:n_row) = x(1:n_row)*prec%d(1:n_row)
else if (beta==zone) then
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) + y(1:n_row)
else if (beta==-zone) then
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) - y(1:n_row)
else else
y(1:n_row) = x(1:n_row)*prec%d(1:n_row) + beta*y(1:n_row) allocate(ww(size(x)),stat=info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Allocate')
goto 9999
end if
end if
n_row=desc_data%matrix_data(psb_n_row_)
ww(1:n_row) = x(1:n_row)*prec%d(1:n_row)
call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
if (size(work) < size(x)) then
deallocate(ww,stat=info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Deallocate')
goto 9999
end if
end if end if
case(bja_) case(bja_)
call psb_bjac_aply(prec,x,beta,y,desc_data,trans,work,info) call psb_bjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjac_aply' ch_err='psb_bjac_aply'
@ -142,7 +144,7 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
if (prec%iprcparm(n_ovr_)==0) then if (prec%iprcparm(n_ovr_)==0) then
! shortcut: this fixes performance for RAS(0) == BJA ! shortcut: this fixes performance for RAS(0) == BJA
call psb_bjac_aply(prec,x,beta,y,desc_data,trans,work,info) call psb_bjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjacaply' ch_err='psb_bjacaply'
@ -214,7 +216,7 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
end if end if
endif endif
call psb_bjac_aply(prec,tx,zzero,ty,prec%desc_data,trans,aux,info) call psb_bjac_aply(zone,prec,tx,zzero,ty,prec%desc_data,trans,aux,info)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010
ch_err='psb_bjac_aply' ch_err='psb_bjac_aply'
@ -250,18 +252,7 @@ subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info)
& prec%iprcparm(prol_) & prec%iprcparm(prol_)
end select end select
if (beta == zzero) then call psb_geaxpby(alpha,ty,beta,y,desc_data,info)
y(1:desc_data%matrix_data(psb_n_row_)) = ty(1:desc_data%matrix_data(psb_n_row_))
else if (beta == zone) then
y(1:desc_data%matrix_data(psb_n_row_)) = y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
else if (beta == -zone) then
y(1:desc_data%matrix_data(psb_n_row_)) = -y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
else
y(1:desc_data%matrix_data(psb_n_row_)) = beta*y(1:desc_data%matrix_data(psb_n_row_)) + &
& ty(1:desc_data%matrix_data(psb_n_row_))
end if
if ((6*isz) <= size(work)) then if ((6*isz) <= size(work)) then

@ -49,7 +49,7 @@ subroutine psb_zbaseprc_bld(a,desc_a,p,info,upd)
Implicit None Implicit None
type(psb_zspmat_type), target :: a type(psb_zspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_zbaseprc_type),intent(inout) :: p type(psb_zbaseprc_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
@ -88,7 +88,7 @@ subroutine psb_zbaseprc_bld(a,desc_a,p,info,upd)
use psb_const_mod use psb_const_mod
implicit none implicit none
type(psb_zspmat_type), intent(in) :: a type(psb_zspmat_type), intent(inout) :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in) :: desc_a
type(psb_zbaseprc_type), intent(inout) :: p type(psb_zbaseprc_type), intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
@ -169,7 +169,13 @@ subroutine psb_zbaseprc_bld(a,desc_a,p,info,upd)
select case(p%iprcparm(p_type_)) select case(p%iprcparm(p_type_))
case (noprec_) case (noprec_)
! Do nothing. ! Do nothing.
call psb_cdcpy(desc_a,p%desc_data,info)
if(info /= 0) then
info=4010
ch_err='psb_cdcpy'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
case (diagsc_) case (diagsc_)
@ -256,7 +262,8 @@ subroutine psb_zbaseprc_bld(a,desc_a,p,info,upd)
end select end select
p%base_a => a
p%base_desc => desc_a
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -34,9 +34,9 @@
!!$ POSSIBILITY OF SUCH DAMAGE. !!$ POSSIBILITY OF SUCH DAMAGE.
!!$ !!$
!!$ !!$
subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_zbjac_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
! !
! Compute Y <- beta*Y + K^-1 X ! Compute Y <- beta*Y + alpha*K^-1 X
! where K is a a Block Jacobi preconditioner stored in prec ! where K is a a Block Jacobi preconditioner stored in prec
! Note that desc_data may or may not be the same as prec%desc_data, ! Note that desc_data may or may not be the same as prec%desc_data,
! but since both are INTENT(IN) this should be legal. ! but since both are INTENT(IN) this should be legal.
@ -54,7 +54,7 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
type(psb_desc_type), intent(in) :: desc_data type(psb_desc_type), intent(in) :: desc_data
type(psb_zbaseprc_type), intent(in) :: prec type(psb_zbaseprc_type), intent(in) :: prec
complex(kind(0.d0)),intent(inout) :: x(:), y(:) complex(kind(0.d0)),intent(inout) :: x(:), y(:)
complex(kind(0.d0)),intent(in) :: beta complex(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
complex(kind(0.d0)),target :: work(:) complex(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -125,7 +125,7 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
& trans='N',unit=diagl,choice=psb_none_,work=aux) & trans='N',unit=diagl,choice=psb_none_,work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row) ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row)
call psb_spsm(zone,prec%av(u_pr_),ww,beta,y,desc_data,info,& call psb_spsm(alpha,prec%av(u_pr_),ww,beta,y,desc_data,info,&
& trans='N',unit=diagu,choice=psb_none_, work=aux) & trans='N',unit=diagu,choice=psb_none_, work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
@ -134,7 +134,7 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
& trans=trans,unit=diagu,choice=psb_none_, work=aux) & trans=trans,unit=diagu,choice=psb_none_, work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row) ww(1:n_row) = ww(1:n_row)*prec%d(1:n_row)
call psb_spsm(zone,prec%av(l_pr_),ww,beta,y,desc_data,info,& call psb_spsm(alpha,prec%av(l_pr_),ww,beta,y,desc_data,info,&
& trans=trans,unit=diagl,choice=psb_none_,work=aux) & trans=trans,unit=diagl,choice=psb_none_,work=aux)
if(info /=0) goto 9999 if(info /=0) goto 9999
@ -152,16 +152,8 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
end select end select
if(info /=0) goto 9999 if(info /=0) goto 9999
call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
if (beta == zzero) then
y(1:n_row) = ww(1:n_row)
else if (beta==zone) then
y(1:n_row) = ww(1:n_row) + y(1:n_row)
else if (beta==-zone) then
y(1:n_row) = ww(1:n_row) - y(1:n_row)
else
y(1:n_row) = ww(1:n_row) + beta*y(1:n_row)
endif
case (f_umf_) case (f_umf_)
@ -174,15 +166,7 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
if(info /=0) goto 9999 if(info /=0) goto 9999
if (beta == zzero) then call psb_geaxpby(alpha,ww,beta,y,desc_data,info)
y(1:n_row) = ww(1:n_row)
else if (beta==zone) then
y(1:n_row) = ww(1:n_row) + y(1:n_row)
else if (beta==-zone) then
y(1:n_row) = ww(1:n_row) - y(1:n_row)
else
y(1:n_row) = ww(1:n_row) + beta*y(1:n_row)
endif
case default case default
write(0,*) 'Unknown factorization type in bjac_aply',prec%iprcparm(f_type_) write(0,*) 'Unknown factorization type in bjac_aply',prec%iprcparm(f_type_)
@ -253,15 +237,8 @@ subroutine psb_zbjac_aply(prec,x,beta,y,desc_data,trans,work,info)
end select end select
if (beta == zzero) then call psb_geaxpby(alpha,tx,beta,y,desc_data,info)
y(1:n_row) = tx(1:n_row)
else if (beta==zone) then
y(1:n_row) = tx(1:n_row) + y(1:n_row)
else if (beta==-zone) then
y(1:n_row) = tx(1:n_row) - y(1:n_row)
else
y(1:n_row) = tx(1:n_row) + beta*y(1:n_row)
endif
deallocate(tx,ty) deallocate(tx,ty)

@ -620,7 +620,12 @@ contains
! Doing it this way means to consider diag(Ai) ! Doing it this way means to consider diag(Ai)
! !
! !
call psb_symbmm(am3,am4,am1) call psb_symbmm(am3,am4,am1,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm')
goto 9999
end if
call psb_numbmm(am3,am4,am1) call psb_numbmm(am3,am4,am1)
if (debug) write(0,*) me,'Done NUMBMM 1' if (debug) write(0,*) me,'Done NUMBMM 1'
@ -667,7 +672,12 @@ contains
if (test_dump) & if (test_dump) &
& call psb_csprt(60+me,am1,head='% (I-wDA)Pt',ivr=desc_a%loc_to_glob) & call psb_csprt(60+me,am1,head='% (I-wDA)Pt',ivr=desc_a%loc_to_glob)
call psb_symbmm(a,am1,am3) call psb_symbmm(a,am1,am3,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm')
goto 9999
end if
call psb_numbmm(a,am1,am3) call psb_numbmm(a,am1,am3)
if (debug) write(0,*) me,'Done NUMBMM 2' if (debug) write(0,*) me,'Done NUMBMM 2'
@ -724,7 +734,12 @@ contains
endif endif
if (debug) write(0,*) me,'starting symbmm 3' if (debug) write(0,*) me,'starting symbmm 3'
call psb_symbmm(am2,am3,b) call psb_symbmm(am2,am3,b,info)
if(info /= 0) then
call psb_errpush(4010,name,a_err='symbmm')
goto 9999
end if
if (debug) write(0,*) me,'starting numbmm 3' if (debug) write(0,*) me,'starting numbmm 3'
call psb_numbmm(am2,am3,b) call psb_numbmm(am2,am3,b)
if (debug) write(0,*) me,'Done NUMBMM 3' if (debug) write(0,*) me,'Done NUMBMM 3'

File diff suppressed because it is too large Load Diff

@ -135,8 +135,6 @@ subroutine psb_zmlprc_bld(a,desc_a,p,info)
p%aorig => a
nullify(p%d) nullify(p%d)
@ -180,8 +178,8 @@ subroutine psb_zmlprc_bld(a,desc_a,p,info)
! We have used a separate ac because: ! We have used a separate ac because:
! 1. We want to reuse the same routines psb_ilu_bld etc. ! 1. We want to reuse the same routines psb_ilu_bld etc.
! 2. We do NOT want to pass an argument twice to them ! 2. We do NOT want to pass an argument twice to them
! p%av(ac_) and p ! p%av(ac_) and p, as this would violate the Fortran standard
! Hence a separate AC and a TRANSFER function. ! Hence a separate AC and a TRANSFER function at the end.
! !
call psb_sp_transfer(ac,p%av(ac_),info) call psb_sp_transfer(ac,p%av(ac_),info)

@ -61,13 +61,13 @@ subroutine psb_zprc_aply(prec,x,y,desc_data,info,trans, work)
character(len=20) :: name character(len=20) :: name
interface psb_baseprc_aply interface psb_baseprc_aply
subroutine psb_zbaseprc_aply(prec,x,beta,y,desc_data,trans,work,info) subroutine psb_zbaseprc_aply(alpha,prec,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_zbaseprc_type), intent(in) :: prec type(psb_zbaseprc_type), intent(in) :: prec
complex(kind(0.d0)),intent(inout) :: x(:), y(:) complex(kind(0.d0)),intent(inout) :: x(:), y(:)
complex(kind(0.d0)),intent(in) :: beta complex(kind(0.d0)),intent(in) :: alpha,beta
character(len=1) :: trans character(len=1) :: trans
complex(kind(0.d0)),target :: work(:) complex(kind(0.d0)),target :: work(:)
integer, intent(out) :: info integer, intent(out) :: info
@ -75,12 +75,12 @@ subroutine psb_zprc_aply(prec,x,y,desc_data,info,trans, work)
end interface end interface
interface psb_mlprc_aply interface psb_mlprc_aply
subroutine psb_zmlprc_aply(baseprecv,x,beta,y,desc_data,trans,work,info) subroutine psb_zmlprc_aply(alpha,baseprecv,x,beta,y,desc_data,trans,work,info)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_desc_type),intent(in) :: desc_data type(psb_desc_type),intent(in) :: desc_data
type(psb_zbaseprc_type), intent(in) :: baseprecv(:) type(psb_zbaseprc_type), intent(in) :: baseprecv(:)
complex(kind(0.d0)),intent(in) :: beta complex(kind(0.d0)),intent(in) :: alpha,beta
complex(kind(0.d0)),intent(inout) :: x(:), y(:) complex(kind(0.d0)),intent(inout) :: x(:), y(:)
character :: trans character :: trans
complex(kind(0.d0)),target :: work(:) complex(kind(0.d0)),target :: work(:)
@ -117,14 +117,14 @@ subroutine psb_zprc_aply(prec,x,y,desc_data,info,trans, work)
end if end if
if (size(prec%baseprecv) >1) then if (size(prec%baseprecv) >1) then
if (debug) write(0,*) 'Into mlprc_aply',size(x),size(y) if (debug) write(0,*) 'Into mlprc_aply',size(x),size(y)
call psb_mlprc_aply(prec%baseprecv,x,zzero,y,desc_data,trans_,work_,info) call psb_mlprc_aply(zone,prec%baseprecv,x,zzero,y,desc_data,trans_,work_,info)
if(info /= 0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='psb_zmlprc_aply') call psb_errpush(4010,name,a_err='psb_zmlprc_aply')
goto 9999 goto 9999
end if end if
else if (size(prec%baseprecv) == 1) then else if (size(prec%baseprecv) == 1) then
call psb_baseprc_aply(prec%baseprecv(1),x,zzero,y,desc_data,trans_, work_,info) call psb_baseprc_aply(zone,prec%baseprecv(1),x,zzero,y,desc_data,trans_, work_,info)
else else
write(0,*) 'Inconsistent preconditioner: size of baseprecv???' write(0,*) 'Inconsistent preconditioner: size of baseprecv???'
endif endif

@ -49,7 +49,7 @@ subroutine psb_zprecbld(a,desc_a,p,info,upd)
Implicit None Implicit None
type(psb_zspmat_type), target :: a type(psb_zspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_zprec_type),intent(inout) :: p type(psb_zprec_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
@ -60,7 +60,7 @@ subroutine psb_zprecbld(a,desc_a,p,info,upd)
use psb_descriptor_type use psb_descriptor_type
use psb_prec_type use psb_prec_type
type(psb_zspmat_type), target :: a type(psb_zspmat_type), target :: a
type(psb_desc_type), intent(in) :: desc_a type(psb_desc_type), intent(in), target :: desc_a
type(psb_zbaseprc_type),intent(inout) :: p type(psb_zbaseprc_type),intent(inout) :: p
integer, intent(out) :: info integer, intent(out) :: info
character, intent(in), optional :: upd character, intent(in), optional :: upd
@ -149,29 +149,8 @@ subroutine psb_zprecbld(a,desc_a,p,info,upd)
endif endif
if (size(p%baseprecv) > 1) then if (size(p%baseprecv) > 1) then
call init_baseprc_av(p%baseprecv(2),info)
if (info /= 0) then
info=4010
ch_err='allocate'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
endif
call psb_mlprc_bld(a,desc_a,p%baseprecv(2),info) do i=2, size(p%baseprecv)
if(info /= 0) then
info=4010
ch_err='psb_mlprc_bld'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
!
! Note: this here has not been tried out. We probably need
! a different baseprc field %desc_ac, in case we try RAS on lev. 2 of
! a 3-level prec.
!
do i=3, size(p%baseprecv)
call init_baseprc_av(p%baseprecv(i),info) call init_baseprc_av(p%baseprecv(i),info)
if (info /= 0) then if (info /= 0) then
info=4010 info=4010
@ -180,8 +159,17 @@ subroutine psb_zprecbld(a,desc_a,p,info,upd)
goto 9999 goto 9999
endif endif
call psb_mlprc_bld(p%baseprecv(i-1)%av(ac_),p%baseprecv(i-1)%desc_data,& call psb_mlprc_bld(p%baseprecv(i-1)%base_a,p%baseprecv(i-1)%base_desc,&
& p%baseprecv(i),info) & p%baseprecv(i),info)
if (info /= 0) then
info=4010
call psb_errpush(info,name)
goto 9999
endif
if (debug) then
write(0,*) 'Return from ',i-1,' call to mlprcbld ',info
endif
end do end do
endif endif

@ -51,7 +51,7 @@ C Local scalars
NNZ = NZ NNZ = NZ
LIMIT = INT(DIM_BLOCK*PSB_PERCENT_) c$$$ LIMIT = INT(DIM_BLOCK*PSB_PERCENT_)
DO BLOCK = 1, NG DO BLOCK = 1, NG
DIM_BLOCK = IA(1,BLOCK+1)-IA(1,BLOCK) DIM_BLOCK = IA(1,BLOCK+1)-IA(1,BLOCK)

@ -24,10 +24,21 @@ c
* index(*) * index(*)
integer, pointer :: ic(:),jc(:) integer, pointer :: ic(:),jc(:)
integer :: nze, info integer :: nze, info
integer, save :: iunit=11
c c
c symbolic matrix multiply c=a*b c symbolic matrix multiply c=a*b
c c
c$$$ write(0,*) 'SYMBMM: ',n,m,l,ib(m+1)-1,jb(ib(m+1)-1) c$$$ open(iunit)
c$$$ write(iunit,*) 'SYMBMM: ',n,m,l
c$$$ write(iunit,*) 'SYMBMM: A:'
c$$$ do i=1,n
c$$$ write(iunit,*) 'Row:',i,' : ',ja(ia(i):ia(i+1)-1)
c$$$ enddo
c$$$ write(iunit,*) 'SYMBMM: B:'
c$$$ do i=1,m
c$$$ write(iunit,*) 'Row:',i,' : ',jb(ib(i):ib(i+1)-1)
c$$$ enddo
if (size(ic) < n+1) then if (size(ic) < n+1) then
call psb_realloc(n+1,ic,info) call psb_realloc(n+1,ic,info)
endif endif
@ -71,7 +82,7 @@ c b = d + ...
endif endif
do 20 k=ib(j),ib(j+1)-1 do 20 k=ib(j),ib(j+1)-1
if ((jb(k)<1).or.(jb(k)>maxlmn)) then if ((jb(k)<1).or.(jb(k)>maxlmn)) then
write(0,*) 'Problem in SYMBMM 1:',j,k,jb(k),maxlmn write(0,*) 'Problem in SYMBMM 1:',j,k,jb(k),maxlmn
else else
if(index(jb(k)).eq.0) then if(index(jb(k)).eq.0) then
index(jb(k))=istart index(jb(k))=istart
@ -95,6 +106,7 @@ c
endif endif
call psb_realloc(nze,jc,info) call psb_realloc(nze,jc,info)
end if end if
do 40 j= ic(i),ic(i+1)-1 do 40 j= ic(i),ic(i+1)-1
if (diagc.eq.1 .and. istart.eq.i) then if (diagc.eq.1 .and. istart.eq.i) then
istart = index(istart) istart = index(istart)
@ -105,8 +117,11 @@ c
index(jc(j))=0 index(jc(j))=0
40 continue 40 continue
call isr(length,jc(ic(i))) call isr(length,jc(ic(i)))
c$$$ write(iunit,*) length,' : ',jc(ic(i):ic(i)+length-1)
index(i) = 0 index(i) = 0
50 continue 50 continue
c$$$ close(iunit)
c$$$ iunit = iunit + 1
c$$$ write(0,*) 'SYMBMM: on exit',ic(n+1)-1,jc(ic(n+1)-1) c$$$ write(0,*) 'SYMBMM: on exit',ic(n+1)-1,jc(ic(n+1)-1)
return return
end end

@ -49,7 +49,7 @@ C .. External routines ..
PNG = IA(1) PNG = IA(1)
PIA = IA(2) PIA = IA(2)
PJA = IA(3) PJA = IA(3)
djdnrmi = 0.d0
IF (DESCRA(1:1).EQ.'G') THEN IF (DESCRA(1:1).EQ.'G') THEN
DJDNRMI = DJADNR(TRANS,M,N,IA(PNG), DJDNRMI = DJADNR(TRANS,M,N,IA(PNG),
+ A,JA,IA(PJA),IA(PIA), + A,JA,IA(PJA),IA(PIA),

@ -66,7 +66,7 @@ subroutine psb_cest(afmt, m,n,nnz, lia1, lia2, lar, iup, info)
lar = nnz lar = nnz
else else
info = 136 info = 136
call psb_errpush(info,name,a_err=afmt) call psb_errpush(info,name,a_err=toupper(afmt))
goto 9999 goto 9999
endif endif
@ -86,7 +86,7 @@ subroutine psb_cest(afmt, m,n,nnz, lia1, lia2, lar, iup, info)
lar = nnz lar = nnz
else else
info = 136 info = 136
call psb_errpush(info,name,a_err=afmt) call psb_errpush(info,name,a_err=toupper(afmt))
goto 9999 goto 9999
endif endif

@ -70,11 +70,12 @@ subroutine psb_dcsprt(iout,a,iv,eirs,eics,head,ivr,ivc)
else else
ics = 0 ics = 0
endif endif
open(iout)
if (present(head)) then if (present(head)) then
write(iout,'(a)') '%%MatrixMarket matrix coordinate real general' write(iout,'(a)') '%%MatrixMarket matrix coordinate real general'
write(iout,'(a,a)') '% ',head write(iout,'(a,a)') '% ',head
write(iout,'(a)') '%' write(iout,'(a)') '%'
write(iout,'(a,a)') '% ',toupper(a%fida)
endif endif
select case(toupper(a%fida)) select case(toupper(a%fida))
@ -181,4 +182,5 @@ subroutine psb_dcsprt(iout,a,iv,eirs,eics,head,ivr,ivc)
case default case default
write(0,*) 'Feeling lazy today, format not implemented: "',a%fida,'"' write(0,*) 'Feeling lazy today, format not implemented: "',a%fida,'"'
end select end select
close(iout)
end subroutine psb_dcsprt end subroutine psb_dcsprt

@ -38,8 +38,9 @@
! rewritten in Fortran 95 making use of our sparse matrix facilities. ! rewritten in Fortran 95 making use of our sparse matrix facilities.
! !
subroutine psb_dsymbmm(a,b,c) subroutine psb_dsymbmm(a,b,c,info)
use psb_spmat_type use psb_spmat_type
use psb_string_mod
implicit none implicit none
type(psb_dspmat_type) :: a,b,c type(psb_dspmat_type) :: a,b,c
@ -54,7 +55,6 @@ subroutine psb_dsymbmm(a,b,c)
integer, pointer :: ic(:),jc(:) integer, pointer :: ic(:),jc(:)
end subroutine symbmm end subroutine symbmm
end interface end interface
interface psb_sp_getrow interface psb_sp_getrow
subroutine psb_dspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw) subroutine psb_dspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw)
use psb_spmat_type use psb_spmat_type
@ -69,6 +69,28 @@ subroutine psb_dsymbmm(a,b,c)
end subroutine psb_dspgetrow end subroutine psb_dspgetrow
end interface end interface
character(len=20) :: name, ch_err
integer :: err_act
name='psb_symbmm'
call psb_erractionsave(err_act)
select case(toupper(a%fida(1:3)))
case ('CSR')
case default
info=135
ch_err=a%fida(1:3)
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end select
select case(toupper(b%fida(1:3)))
case ('CSR')
case default
info=136
ch_err=b%fida(1:3)
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end select
if (b%m /= a%k) then if (b%m /= a%k) then
write(0,*) 'Mismatch in SYMBMM: ',a%m,a%k,b%m,b%k write(0,*) 'Mismatch in SYMBMM: ',a%m,a%k,b%m,b%k
endif endif
@ -78,7 +100,6 @@ subroutine psb_dsymbmm(a,b,c)
endif endif
nze = max(a%m+1,2*a%m) nze = max(a%m+1,2*a%m)
call psb_sp_reall(c,nze,info) call psb_sp_reall(c,nze,info)
!!$ write(0,*) 'SYMBMM90 ',size(c%pl),size(c%pr)
! !
! Note: we need to test whether there is a performance impact ! Note: we need to test whether there is a performance impact
! in not using the original Douglas & Bank code. ! in not using the original Douglas & Bank code.
@ -97,6 +118,15 @@ subroutine psb_dsymbmm(a,b,c)
c%fida='CSR' c%fida='CSR'
c%descra='GUN' c%descra='GUN'
deallocate(itemp) deallocate(itemp)
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act.eq.act_abort) then
call psb_error()
return
end if
return return
contains contains

@ -38,8 +38,9 @@
! rewritten in Fortran 95 making use of our sparse matrix facilities. ! rewritten in Fortran 95 making use of our sparse matrix facilities.
! !
subroutine psb_zsymbmm(a,b,c) subroutine psb_zsymbmm(a,b,c,info)
use psb_spmat_type use psb_spmat_type
use psb_string_mod
implicit none implicit none
type(psb_zspmat_type) :: a,b,c type(psb_zspmat_type) :: a,b,c
@ -68,6 +69,27 @@ subroutine psb_zsymbmm(a,b,c)
integer, intent(out) :: info integer, intent(out) :: info
end subroutine psb_zspgetrow end subroutine psb_zspgetrow
end interface end interface
character(len=20) :: name, ch_err
integer :: err_act
name='psb_symbmm'
call psb_erractionsave(err_act)
select case(toupper(a%fida(1:3)))
case ('CSR')
case default
info=135
ch_err=a%fida(1:3)
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end select
select case(toupper(b%fida(1:3)))
case ('CSR')
case default
info=136
ch_err=b%fida(1:3)
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end select
if (b%m /= a%k) then if (b%m /= a%k) then
write(0,*) 'Mismatch in SYMBMM: ',a%m,a%k,b%m,b%k write(0,*) 'Mismatch in SYMBMM: ',a%m,a%k,b%m,b%k
@ -97,6 +119,15 @@ subroutine psb_zsymbmm(a,b,c)
c%fida='CSR' c%fida='CSR'
c%descra='GUN' c%descra='GUN'
deallocate(itemp) deallocate(itemp)
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act.eq.act_abort) then
call psb_error()
return
end if
return return
contains contains

@ -235,7 +235,6 @@ subroutine psb_cdalv(m, v, ictxt, desc_a, info, flag)
endif endif
! estimate local cols number ! estimate local cols number
!!$ loc_col = int((psb_colrow_+1.d0)*loc_row)+1
loc_col = min(2*loc_row,m) loc_col = min(2*loc_row,m)
allocate(desc_a%loc_to_glob(loc_col),& allocate(desc_a%loc_to_glob(loc_col),&
&desc_a%lprm(1),stat=info) &desc_a%lprm(1),stat=info)

@ -245,7 +245,6 @@ program df_sample
call psb_precset(pre,'asm',info,iv=(/novr,halo_,none_/)) call psb_precset(pre,'asm',info,iv=(/novr,halo_,none_/))
case(rash_) case(rash_)
call psb_precset(pre,'asm',info,iv=(/novr,nohalo_,none_/)) call psb_precset(pre,'asm',info,iv=(/novr,nohalo_,none_/))
case default case default
call psb_precset(pre,'ilu',info) call psb_precset(pre,'ilu',info)
end select end select

Loading…
Cancel
Save