|
|
@ -1,12 +1,12 @@
|
|
|
|
module mld_dprec_cbind_mod
|
|
|
|
module amg_dprec_cbind_mod
|
|
|
|
|
|
|
|
|
|
|
|
use iso_c_binding
|
|
|
|
use iso_c_binding
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
use psb_base_cbind_mod
|
|
|
|
use psb_base_cbind_mod
|
|
|
|
|
|
|
|
|
|
|
|
type, bind(c) :: mld_c_dprec
|
|
|
|
type, bind(c) :: amg_c_dprec
|
|
|
|
type(c_ptr) :: item = c_null_ptr
|
|
|
|
type(c_ptr) :: item = c_null_ptr
|
|
|
|
end type mld_c_dprec
|
|
|
|
end type amg_c_dprec
|
|
|
|
|
|
|
|
|
|
|
|
contains
|
|
|
|
contains
|
|
|
|
|
|
|
|
|
|
|
@ -17,22 +17,22 @@ contains
|
|
|
|
#define MLDC_DEBUG(MSG)
|
|
|
|
#define MLDC_DEBUG(MSG)
|
|
|
|
#define MLDC_ERROR(MSG)
|
|
|
|
#define MLDC_ERROR(MSG)
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#define mld_success_ 0
|
|
|
|
#define amg_success_ 0
|
|
|
|
!#define MLDC_ERR_FILTER(INFO) min(0,INFO)
|
|
|
|
!#define MLDC_ERR_FILTER(INFO) min(0,INFO)
|
|
|
|
#define MLDC_ERR_FILTER(INFO) (INFO)
|
|
|
|
#define MLDC_ERR_FILTER(INFO) (INFO)
|
|
|
|
#define MLDC_ERR_HANDLE(INFO) if(INFO/=mld_success_)MLDC_ERROR("ERROR!")
|
|
|
|
#define MLDC_ERR_HANDLE(INFO) if(INFO/=amg_success_)MLDC_ERROR("ERROR!")
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecinit(cctxt,ph,ptype) bind(c) result(res)
|
|
|
|
function amg_c_dprecinit(cctxt,ph,ptype) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(mld_c_dprec) :: ph
|
|
|
|
type(amg_c_dprec) :: ph
|
|
|
|
integer(psb_c_ipk_), value :: cctxt
|
|
|
|
integer(psb_c_ipk_), value :: cctxt
|
|
|
|
character(c_char) :: ptype(*)
|
|
|
|
character(c_char) :: ptype(*)
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
character(len=80) :: fptype
|
|
|
|
character(len=80) :: fptype
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
@ -48,16 +48,16 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
call stringc2f(ptype,fptype)
|
|
|
|
call stringc2f(ptype,fptype)
|
|
|
|
|
|
|
|
|
|
|
|
call precp%init(cctxt,fptype,info)
|
|
|
|
call precp%init(psb_c2f_ctxt(cctxt),fptype,info)
|
|
|
|
|
|
|
|
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecinit
|
|
|
|
end function amg_c_dprecinit
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecseti(ph,what,val) bind(c) result(res)
|
|
|
|
function amg_c_dprecseti(ph,what,val) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
@ -66,7 +66,7 @@ contains
|
|
|
|
integer(psb_c_ipk_), value :: val
|
|
|
|
integer(psb_c_ipk_), value :: val
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
character(len=80) :: fwhat
|
|
|
|
character(len=80) :: fwhat
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
@ -77,17 +77,17 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
|
|
|
|
|
|
|
|
call mld_precset(precp,fwhat,val,info)
|
|
|
|
call amg_precset(precp,fwhat,val,info)
|
|
|
|
|
|
|
|
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecseti
|
|
|
|
end function amg_c_dprecseti
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecsetr(ph,what,val) bind(c) result(res)
|
|
|
|
function amg_c_dprecsetr(ph,what,val) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
@ -96,7 +96,7 @@ contains
|
|
|
|
real(c_double), value :: val
|
|
|
|
real(c_double), value :: val
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
character(len=80) :: fwhat
|
|
|
|
character(len=80) :: fwhat
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
@ -107,16 +107,16 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
|
|
|
|
|
|
|
|
call mld_precset(precp,fwhat,val,info)
|
|
|
|
call amg_precset(precp,fwhat,val,info)
|
|
|
|
|
|
|
|
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecsetr
|
|
|
|
end function amg_c_dprecsetr
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecsetc(ph,what,val) bind(c) result(res)
|
|
|
|
function amg_c_dprecsetc(ph,what,val) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
@ -124,7 +124,7 @@ contains
|
|
|
|
character(c_char) :: what(*), val(*)
|
|
|
|
character(c_char) :: what(*), val(*)
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
character(len=80) :: fwhat,fval
|
|
|
|
character(len=80) :: fwhat,fval
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
|
if (c_associated(ph%item)) then
|
|
|
@ -136,22 +136,22 @@ contains
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
call stringc2f(what,fwhat)
|
|
|
|
call stringc2f(val,fval)
|
|
|
|
call stringc2f(val,fval)
|
|
|
|
|
|
|
|
|
|
|
|
call mld_precset(precp,fwhat,fval,info)
|
|
|
|
call amg_precset(precp,fwhat,fval,info)
|
|
|
|
|
|
|
|
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecsetc
|
|
|
|
end function amg_c_dprecsetc
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecbld(ah,cdh,ph) bind(c) result(res)
|
|
|
|
function amg_c_dprecbld(ah,cdh,ph) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
character(len=80) :: fptype
|
|
|
|
character(len=80) :: fptype
|
|
|
@ -174,23 +174,23 @@ contains
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call mld_precbld(ap,descp,precp,info)
|
|
|
|
call amg_precbld(ap,descp,precp,info)
|
|
|
|
|
|
|
|
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecbld
|
|
|
|
end function amg_c_dprecbld
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dhierarchy_build(ah,cdh,ph) bind(c) result(res)
|
|
|
|
function amg_c_dhierarchy_build(ah,cdh,ph) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
character(len=80) :: fptype
|
|
|
|
character(len=80) :: fptype
|
|
|
@ -219,17 +219,17 @@ contains
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dhierarchy_build
|
|
|
|
end function amg_c_dhierarchy_build
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dsmoothers_build(ah,cdh,ph) bind(c) result(res)
|
|
|
|
function amg_c_dsmoothers_build(ah,cdh,ph) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
type(psb_c_object_type) :: ph,ah,cdh
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
character(len=80) :: fptype
|
|
|
|
character(len=80) :: fptype
|
|
|
@ -258,9 +258,9 @@ contains
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dsmoothers_build
|
|
|
|
end function amg_c_dsmoothers_build
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dkrylov(methd,&
|
|
|
|
function amg_c_dkrylov(methd,&
|
|
|
|
& ah,ph,bh,xh,cdh,options) bind(c) result(res)
|
|
|
|
& ah,ph,bh,xh,cdh,options) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_prec_mod
|
|
|
|
use psb_prec_mod
|
|
|
@ -273,15 +273,15 @@ contains
|
|
|
|
character(c_char) :: methd(*)
|
|
|
|
character(c_char) :: methd(*)
|
|
|
|
type(solveroptions) :: options
|
|
|
|
type(solveroptions) :: options
|
|
|
|
|
|
|
|
|
|
|
|
res= mld_c_dkrylov_opt(methd, ah, ph, bh, xh, options%eps,cdh, &
|
|
|
|
res= amg_c_dkrylov_opt(methd, ah, ph, bh, xh, options%eps,cdh, &
|
|
|
|
& itmax=options%itmax, iter=options%iter,&
|
|
|
|
& itmax=options%itmax, iter=options%iter,&
|
|
|
|
& itrace=options%itrace, istop=options%istop,&
|
|
|
|
& itrace=options%itrace, istop=options%istop,&
|
|
|
|
& irst=options%irst, err=options%err)
|
|
|
|
& irst=options%irst, err=options%err)
|
|
|
|
|
|
|
|
|
|
|
|
end function mld_c_dkrylov
|
|
|
|
end function amg_c_dkrylov
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dkrylov_opt(methd,&
|
|
|
|
function amg_c_dkrylov_opt(methd,&
|
|
|
|
& ah,ph,bh,xh,eps,cdh,itmax,iter,err,itrace,irst,istop) bind(c) result(res)
|
|
|
|
& ah,ph,bh,xh,eps,cdh,itmax,iter,err,itrace,irst,istop) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_prec_mod
|
|
|
|
use psb_prec_mod
|
|
|
@ -299,7 +299,7 @@ contains
|
|
|
|
character(c_char) :: methd(*)
|
|
|
|
character(c_char) :: methd(*)
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(psb_dspmat_type), pointer :: ap
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
type(psb_d_vect_type), pointer :: xp, bp
|
|
|
|
type(psb_d_vect_type), pointer :: xp, bp
|
|
|
|
|
|
|
|
|
|
|
|
integer :: info,fitmax,fitrace,first,fistop,fiter
|
|
|
|
integer :: info,fitmax,fitrace,first,fistop,fiter
|
|
|
@ -349,17 +349,17 @@ contains
|
|
|
|
err = ferr
|
|
|
|
err = ferr
|
|
|
|
res = min(info,0)
|
|
|
|
res = min(info,0)
|
|
|
|
|
|
|
|
|
|
|
|
end function mld_c_dkrylov_opt
|
|
|
|
end function amg_c_dkrylov_opt
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_dprecfree(ph) bind(c) result(res)
|
|
|
|
function amg_c_dprecfree(ph) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_object_type) :: ph
|
|
|
|
type(psb_c_object_type) :: ph
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
character(len=80) :: fptype
|
|
|
|
character(len=80) :: fptype
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
@ -375,17 +375,17 @@ contains
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_dprecfree
|
|
|
|
end function amg_c_dprecfree
|
|
|
|
|
|
|
|
|
|
|
|
function mld_c_ddescr(ph) bind(c) result(res)
|
|
|
|
function amg_c_ddescr(ph) bind(c) result(res)
|
|
|
|
use psb_base_mod
|
|
|
|
use psb_base_mod
|
|
|
|
use mld_prec_mod
|
|
|
|
use amg_prec_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_object_type) :: ph
|
|
|
|
type(psb_c_object_type) :: ph
|
|
|
|
integer :: info
|
|
|
|
integer :: info
|
|
|
|
type(mld_dprec_type), pointer :: precp
|
|
|
|
type(amg_dprec_type), pointer :: precp
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
info = -1
|
|
|
|
info = -1
|
|
|
@ -403,6 +403,6 @@ contains
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
res = MLDC_ERR_FILTER(info)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
MLDC_ERR_HANDLE(res)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function mld_c_ddescr
|
|
|
|
end function amg_c_ddescr
|
|
|
|
|
|
|
|
|
|
|
|
end module mld_dprec_cbind_mod
|
|
|
|
end module amg_dprec_cbind_mod
|
|
|
|