|
|
|
@ -41,14 +41,16 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_csrws
|
|
|
|
|
subroutine psb_dcsrws(rw,a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a
|
|
|
|
|
real(psb_dpk_), allocatable :: rw(:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_dcsrws
|
|
|
|
|
subroutine psb_zcsrws(rw,a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a
|
|
|
|
|
complex(psb_dpk_), allocatable :: rw(:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -58,7 +60,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_cssm
|
|
|
|
|
subroutine psb_scssm(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: t
|
|
|
|
|
real(psb_spk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -66,7 +69,8 @@ module psb_serial_mod
|
|
|
|
|
real(psb_spk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_scssm
|
|
|
|
|
subroutine psb_scssv(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: t
|
|
|
|
|
real(psb_spk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -74,7 +78,8 @@ module psb_serial_mod
|
|
|
|
|
real(psb_spk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_scssv
|
|
|
|
|
subroutine psb_dcssm(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: t
|
|
|
|
|
real(psb_dpk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -82,7 +87,8 @@ module psb_serial_mod
|
|
|
|
|
real(psb_dpk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_dcssm
|
|
|
|
|
subroutine psb_dcssv(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: t
|
|
|
|
|
real(psb_dpk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -90,7 +96,8 @@ module psb_serial_mod
|
|
|
|
|
real(psb_dpk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_dcssv
|
|
|
|
|
subroutine psb_ccssm(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: t
|
|
|
|
|
complex(psb_spk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -98,7 +105,8 @@ module psb_serial_mod
|
|
|
|
|
complex(psb_spk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_ccssm
|
|
|
|
|
subroutine psb_ccssv(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: t
|
|
|
|
|
complex(psb_spk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -106,7 +114,8 @@ module psb_serial_mod
|
|
|
|
|
complex(psb_spk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_ccssv
|
|
|
|
|
subroutine psb_zcssm(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: t
|
|
|
|
|
complex(psb_dpk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -114,7 +123,8 @@ module psb_serial_mod
|
|
|
|
|
complex(psb_dpk_), optional, target :: d(:)
|
|
|
|
|
end subroutine psb_zcssm
|
|
|
|
|
subroutine psb_zcssv(alpha,t,b,beta,c,info,trans,unitd,d)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: t
|
|
|
|
|
complex(psb_dpk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -125,56 +135,64 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_csmm
|
|
|
|
|
subroutine psb_scsmv(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a
|
|
|
|
|
real(psb_spk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_scsmv
|
|
|
|
|
subroutine psb_scsmm(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a
|
|
|
|
|
real(psb_spk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_scsmm
|
|
|
|
|
subroutine psb_dcsmv(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a
|
|
|
|
|
real(psb_dpk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_dcsmv
|
|
|
|
|
subroutine psb_dcsmm(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a
|
|
|
|
|
real(psb_dpk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_dcsmm
|
|
|
|
|
subroutine psb_ccsmv(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a
|
|
|
|
|
complex(psb_spk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_ccsmv
|
|
|
|
|
subroutine psb_ccsmm(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a
|
|
|
|
|
complex(psb_spk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_ccsmm
|
|
|
|
|
subroutine psb_zcsmv(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a
|
|
|
|
|
complex(psb_dpk_) :: alpha, beta, b(:), c(:)
|
|
|
|
|
integer :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
end subroutine psb_zcsmv
|
|
|
|
|
subroutine psb_zcsmm(alpha,a,b,beta,c,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a
|
|
|
|
|
complex(psb_dpk_) :: alpha, beta, b(:,:), c(:,:)
|
|
|
|
|
integer :: info
|
|
|
|
@ -192,7 +210,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_spcnv
|
|
|
|
|
subroutine psb_sspcnv2(ain, a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent (in) :: ain
|
|
|
|
|
type(psb_sspmat_type), intent (out) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -200,14 +219,16 @@ module psb_serial_mod
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_sspcnv2
|
|
|
|
|
subroutine psb_sspcnv1(a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent (inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer,optional, intent(in) :: dupl, upd
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_sspcnv1
|
|
|
|
|
subroutine psb_dspcnv2(ain, a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent (in) :: ain
|
|
|
|
|
type(psb_dspmat_type), intent (out) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -215,14 +236,16 @@ module psb_serial_mod
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_dspcnv2
|
|
|
|
|
subroutine psb_dspcnv1(a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent (inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer,optional, intent(in) :: dupl, upd
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_dspcnv1
|
|
|
|
|
subroutine psb_cspcnv2(ain, a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent (in) :: ain
|
|
|
|
|
type(psb_cspmat_type), intent (out) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -230,14 +253,16 @@ module psb_serial_mod
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_cspcnv2
|
|
|
|
|
subroutine psb_cspcnv1(a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent (inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer,optional, intent(in) :: dupl, upd
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_cspcnv1
|
|
|
|
|
subroutine psb_zspcnv2(ain, a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent (in) :: ain
|
|
|
|
|
type(psb_zspmat_type), intent (out) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -245,7 +270,8 @@ module psb_serial_mod
|
|
|
|
|
character(len=*), optional, intent(in) :: afmt
|
|
|
|
|
end subroutine psb_zspcnv2
|
|
|
|
|
subroutine psb_zspcnv1(a, info, afmt, upd, dupl)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent (inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer,optional, intent(in) :: dupl, upd
|
|
|
|
@ -257,25 +283,29 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_fixcoo
|
|
|
|
|
subroutine psb_sfixcoo(a,info,idir)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer, intent(in), optional :: idir
|
|
|
|
|
end subroutine psb_sfixcoo
|
|
|
|
|
subroutine psb_dfixcoo(a,info,idir)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer, intent(in), optional :: idir
|
|
|
|
|
end subroutine psb_dfixcoo
|
|
|
|
|
subroutine psb_cfixcoo(a,info,idir)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer, intent(in), optional :: idir
|
|
|
|
|
end subroutine psb_cfixcoo
|
|
|
|
|
subroutine psb_zfixcoo(a,info,idir)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
integer, intent(in), optional :: idir
|
|
|
|
@ -284,25 +314,29 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_ipcoo2csr
|
|
|
|
|
subroutine psb_sipcoo2csr(a,info,rwshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: rwshr
|
|
|
|
|
end subroutine psb_sipcoo2csr
|
|
|
|
|
subroutine psb_dipcoo2csr(a,info,rwshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: rwshr
|
|
|
|
|
end subroutine psb_dipcoo2csr
|
|
|
|
|
subroutine psb_cipcoo2csr(a,info,rwshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: rwshr
|
|
|
|
|
end subroutine psb_cipcoo2csr
|
|
|
|
|
subroutine psb_zipcoo2csr(a,info,rwshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: rwshr
|
|
|
|
@ -311,25 +345,29 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_ipcoo2csc
|
|
|
|
|
subroutine psb_sipcoo2csc(a,info,clshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: clshr
|
|
|
|
|
end subroutine psb_sipcoo2csc
|
|
|
|
|
subroutine psb_dipcoo2csc(a,info,clshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: clshr
|
|
|
|
|
end subroutine psb_dipcoo2csc
|
|
|
|
|
subroutine psb_cipcoo2csc(a,info,clshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: clshr
|
|
|
|
|
end subroutine psb_cipcoo2csc
|
|
|
|
|
subroutine psb_zipcoo2csc(a,info,clshr)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
logical, optional :: clshr
|
|
|
|
@ -338,22 +376,26 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_ipcsr2coo
|
|
|
|
|
subroutine psb_sipcsr2coo(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_sipcsr2coo
|
|
|
|
|
subroutine psb_dipcsr2coo(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dipcsr2coo
|
|
|
|
|
subroutine psb_cipcsr2coo(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_cipcsr2coo
|
|
|
|
|
subroutine psb_zipcsr2coo(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_zipcsr2coo
|
|
|
|
@ -361,7 +403,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_csprt
|
|
|
|
|
subroutine psb_scsprt(iout,a,iv,irs,ics,head,ivr,ivc)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: iout
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in), optional :: iv(:)
|
|
|
|
@ -370,7 +413,8 @@ module psb_serial_mod
|
|
|
|
|
integer, intent(in), optional :: ivr(:),ivc(:)
|
|
|
|
|
end subroutine psb_scsprt
|
|
|
|
|
subroutine psb_dcsprt(iout,a,iv,irs,ics,head,ivr,ivc)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: iout
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in), optional :: iv(:)
|
|
|
|
@ -379,7 +423,8 @@ module psb_serial_mod
|
|
|
|
|
integer, intent(in), optional :: ivr(:),ivc(:)
|
|
|
|
|
end subroutine psb_dcsprt
|
|
|
|
|
subroutine psb_ccsprt(iout,a,iv,irs,ics,head,ivr,ivc)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: iout
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in), optional :: iv(:)
|
|
|
|
@ -388,7 +433,8 @@ module psb_serial_mod
|
|
|
|
|
integer, intent(in), optional :: ivr(:),ivc(:)
|
|
|
|
|
end subroutine psb_ccsprt
|
|
|
|
|
subroutine psb_zcsprt(iout,a,iv,irs,ics,head,ivr,ivc)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: iout
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in), optional :: iv(:)
|
|
|
|
@ -400,7 +446,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_neigh
|
|
|
|
|
subroutine psb_sneigh(a,idx,neigh,n,info,lev)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: idx
|
|
|
|
|
integer, intent(out) :: n
|
|
|
|
@ -409,7 +456,8 @@ module psb_serial_mod
|
|
|
|
|
integer, optional, intent(in) :: lev
|
|
|
|
|
end subroutine psb_sneigh
|
|
|
|
|
subroutine psb_dneigh(a,idx,neigh,n,info,lev)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: idx
|
|
|
|
|
integer, intent(out) :: n
|
|
|
|
@ -418,7 +466,8 @@ module psb_serial_mod
|
|
|
|
|
integer, optional, intent(in) :: lev
|
|
|
|
|
end subroutine psb_dneigh
|
|
|
|
|
subroutine psb_cneigh(a,idx,neigh,n,info,lev)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: idx
|
|
|
|
|
integer, intent(out) :: n
|
|
|
|
@ -427,7 +476,8 @@ module psb_serial_mod
|
|
|
|
|
integer, optional, intent(in) :: lev
|
|
|
|
|
end subroutine psb_cneigh
|
|
|
|
|
subroutine psb_zneigh(a,idx,neigh,n,info,lev)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: idx
|
|
|
|
|
integer, intent(out) :: n
|
|
|
|
@ -439,7 +489,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_coins
|
|
|
|
|
subroutine psb_scoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nz, imin,imax,jmin,jmax
|
|
|
|
|
integer, intent(in) :: ia(:),ja(:)
|
|
|
|
|
real(psb_spk_), intent(in) :: val(:)
|
|
|
|
@ -449,7 +500,8 @@ module psb_serial_mod
|
|
|
|
|
logical, optional, intent(in) :: rebuild
|
|
|
|
|
end subroutine psb_scoins
|
|
|
|
|
subroutine psb_dcoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nz, imin,imax,jmin,jmax
|
|
|
|
|
integer, intent(in) :: ia(:),ja(:)
|
|
|
|
|
real(psb_dpk_), intent(in) :: val(:)
|
|
|
|
@ -459,7 +511,8 @@ module psb_serial_mod
|
|
|
|
|
logical, optional, intent(in) :: rebuild
|
|
|
|
|
end subroutine psb_dcoins
|
|
|
|
|
subroutine psb_ccoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nz, imin,imax,jmin,jmax
|
|
|
|
|
integer, intent(in) :: ia(:),ja(:)
|
|
|
|
|
complex(psb_spk_), intent(in) :: val(:)
|
|
|
|
@ -469,7 +522,8 @@ module psb_serial_mod
|
|
|
|
|
logical, optional, intent(in) :: rebuild
|
|
|
|
|
end subroutine psb_ccoins
|
|
|
|
|
subroutine psb_zcoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nz, imin,imax,jmin,jmax
|
|
|
|
|
integer, intent(in) :: ia(:),ja(:)
|
|
|
|
|
complex(psb_dpk_), intent(in) :: val(:)
|
|
|
|
@ -483,22 +537,26 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_symbmm
|
|
|
|
|
subroutine psb_ssymbmm(a,b,c,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a,b,c
|
|
|
|
|
integer :: info
|
|
|
|
|
end subroutine psb_ssymbmm
|
|
|
|
|
subroutine psb_dsymbmm(a,b,c,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a,b,c
|
|
|
|
|
integer :: info
|
|
|
|
|
end subroutine psb_dsymbmm
|
|
|
|
|
subroutine psb_csymbmm(a,b,c,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a,b,c
|
|
|
|
|
integer :: info
|
|
|
|
|
end subroutine psb_csymbmm
|
|
|
|
|
subroutine psb_zsymbmm(a,b,c,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a,b,c
|
|
|
|
|
integer :: info
|
|
|
|
|
end subroutine psb_zsymbmm
|
|
|
|
@ -506,72 +564,80 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_numbmm
|
|
|
|
|
subroutine psb_snumbmm(a,b,c)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a,b,c
|
|
|
|
|
end subroutine psb_snumbmm
|
|
|
|
|
subroutine psb_dnumbmm(a,b,c)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a,b,c
|
|
|
|
|
end subroutine psb_dnumbmm
|
|
|
|
|
subroutine psb_cnumbmm(a,b,c)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a,b,c
|
|
|
|
|
end subroutine psb_cnumbmm
|
|
|
|
|
subroutine psb_znumbmm(a,b,c)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a,b,c
|
|
|
|
|
end subroutine psb_znumbmm
|
|
|
|
|
end interface
|
|
|
|
|
|
|
|
|
|
interface psb_transp
|
|
|
|
|
subroutine psb_stransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_sspmat_type), intent(out) :: b
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_stransp
|
|
|
|
|
subroutine psb_dtransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_dtransp
|
|
|
|
|
subroutine psb_ctransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ctransp
|
|
|
|
|
subroutine psb_ztransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ztransp
|
|
|
|
|
subroutine psb_stransp1(a,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type) :: a
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_stransp1
|
|
|
|
|
subroutine psb_dtransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_dspmat_type), intent(out) :: b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_dtransp
|
|
|
|
|
subroutine psb_dtransp1(a,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type) :: a
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_dtransp1
|
|
|
|
|
subroutine psb_ctransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_cspmat_type), intent(out) :: b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ctransp
|
|
|
|
|
subroutine psb_ctransp1(a,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ctransp1
|
|
|
|
|
subroutine psb_ztransp(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_zspmat_type), intent(out) :: b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ztransp
|
|
|
|
|
subroutine psb_ztransp1(a,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
@ -580,16 +646,16 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_transc
|
|
|
|
|
subroutine psb_ctransc(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_cspmat_type), intent(out) :: b
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ctransc
|
|
|
|
|
subroutine psb_ztransc(a,b,c,fmt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_zspmat_type), intent(out) :: b
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type) :: a,b
|
|
|
|
|
integer, optional :: c
|
|
|
|
|
character(len=*), optional :: fmt
|
|
|
|
|
end subroutine psb_ztransc
|
|
|
|
@ -597,7 +663,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_rwextd
|
|
|
|
|
subroutine psb_srwextd(nr,a,info,b,rowscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nr
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -605,7 +672,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rowscale
|
|
|
|
|
end subroutine psb_srwextd
|
|
|
|
|
subroutine psb_drwextd(nr,a,info,b,rowscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nr
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -613,7 +681,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rowscale
|
|
|
|
|
end subroutine psb_drwextd
|
|
|
|
|
subroutine psb_crwextd(nr,a,info,b,rowscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nr
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -621,7 +690,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rowscale
|
|
|
|
|
end subroutine psb_crwextd
|
|
|
|
|
subroutine psb_zrwextd(nr,a,info,b,rowscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
integer, intent(in) :: nr
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -632,28 +702,32 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_csnmi
|
|
|
|
|
function psb_scsnmi(a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
real(psb_spk_) :: psb_scsnmi
|
|
|
|
|
end function psb_scsnmi
|
|
|
|
|
function psb_dcsnmi(a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
real(psb_dpk_) :: psb_dcsnmi
|
|
|
|
|
end function psb_dcsnmi
|
|
|
|
|
function psb_ccsnmi(a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
|
real(psb_spk_) :: psb_ccsnmi
|
|
|
|
|
end function psb_ccsnmi
|
|
|
|
|
function psb_zcsnmi(a,info,trans)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
character, optional :: trans
|
|
|
|
@ -663,7 +737,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_clip
|
|
|
|
|
subroutine psb_sspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_sspmat_type), intent(out) :: b
|
|
|
|
@ -672,7 +747,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rscale,cscale
|
|
|
|
|
end subroutine psb_sspclip
|
|
|
|
|
subroutine psb_dspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_dspmat_type), intent(out) :: b
|
|
|
|
@ -681,7 +757,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rscale,cscale
|
|
|
|
|
end subroutine psb_dspclip
|
|
|
|
|
subroutine psb_cspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_cspmat_type), intent(out) :: b
|
|
|
|
@ -690,7 +767,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: rscale,cscale
|
|
|
|
|
end subroutine psb_cspclip
|
|
|
|
|
subroutine psb_zspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_zspmat_type), intent(out) :: b
|
|
|
|
@ -702,25 +780,29 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_getdiag
|
|
|
|
|
subroutine psb_sspgtdiag(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
real(psb_spk_), intent(inout) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_sspgtdiag
|
|
|
|
|
subroutine psb_dspgtdiag(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
real(psb_dpk_), intent(inout) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspgtdiag
|
|
|
|
|
subroutine psb_cspgtdiag(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
complex(psb_spk_), intent(inout) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_cspgtdiag
|
|
|
|
|
subroutine psb_zspgtdiag(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
complex(psb_dpk_), intent(inout) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -729,49 +811,57 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_scal
|
|
|
|
|
subroutine psb_sspscals(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
real(psb_spk_), intent(in) :: d
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_sspscals
|
|
|
|
|
subroutine psb_sspscal(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: a
|
|
|
|
|
real(psb_spk_), intent(in) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_sspscal
|
|
|
|
|
subroutine psb_dspscals(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
real(psb_dpk_), intent(in) :: d
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspscals
|
|
|
|
|
subroutine psb_dspscal(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
real(psb_dpk_), intent(in) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspscal
|
|
|
|
|
subroutine psb_cspscals(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
complex(psb_spk_), intent(in) :: d
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_cspscals
|
|
|
|
|
subroutine psb_cspscal(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: a
|
|
|
|
|
complex(psb_spk_), intent(in) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_cspscal
|
|
|
|
|
subroutine psb_zspscals(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
complex(psb_dpk_), intent(in) :: d
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_zspscals
|
|
|
|
|
subroutine psb_zspscal(a,d,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
complex(psb_dpk_), intent(in) :: d(:)
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -781,23 +871,27 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_setbld
|
|
|
|
|
subroutine psb_dspsetbld1(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspsetbld1
|
|
|
|
|
subroutine psb_dspsetbld2(a,b,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_dspmat_type), intent(out) :: b
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspsetbld2
|
|
|
|
|
subroutine psb_zspsetbld1(a,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_zspsetbld1
|
|
|
|
|
subroutine psb_zspsetbld2(a,b,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_zspmat_type), intent(out) :: b
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
@ -806,14 +900,16 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_shift
|
|
|
|
|
subroutine psb_dspshift(alpha,a,beta,b,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_dspmat_type), intent(out) :: b
|
|
|
|
|
real(psb_dpk_), intent(in) :: alpha, beta
|
|
|
|
|
integer, intent(out) :: info
|
|
|
|
|
end subroutine psb_dspshift
|
|
|
|
|
subroutine psb_zspshift(alpha,a,beta,b,info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
type(psb_zspmat_type), intent(out) :: b
|
|
|
|
|
complex(psb_dpk_), intent(in) :: alpha, beta
|
|
|
|
@ -823,7 +919,8 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_sp_getblk
|
|
|
|
|
subroutine psb_sspgtblk(irw,a,b,info,append,iren,lrw,srt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: irw
|
|
|
|
|
type(psb_sspmat_type), intent(inout) :: b
|
|
|
|
@ -834,7 +931,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: srt
|
|
|
|
|
end subroutine psb_sspgtblk
|
|
|
|
|
subroutine psb_dspgtblk(irw,a,b,info,append,iren,lrw,srt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: irw
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: b
|
|
|
|
@ -845,7 +943,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: srt
|
|
|
|
|
end subroutine psb_dspgtblk
|
|
|
|
|
subroutine psb_cspgtblk(irw,a,b,info,append,iren,lrw,srt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: irw
|
|
|
|
|
type(psb_cspmat_type), intent(inout) :: b
|
|
|
|
@ -856,7 +955,8 @@ module psb_serial_mod
|
|
|
|
|
logical, intent(in), optional :: srt
|
|
|
|
|
end subroutine psb_cspgtblk
|
|
|
|
|
subroutine psb_zspgtblk(irw,a,b,info,append,iren,lrw,srt)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
|
integer, intent(in) :: irw
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: b
|
|
|
|
@ -871,7 +971,8 @@ module psb_serial_mod
|
|
|
|
|
interface psb_sp_getrow
|
|
|
|
|
subroutine psb_sspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
|
|
|
|
|
! Output is always in COO format
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
type(psb_sspmat_type), intent(in) :: a
|
|
|
|
@ -886,7 +987,8 @@ module psb_serial_mod
|
|
|
|
|
end subroutine psb_sspgetrow
|
|
|
|
|
subroutine psb_dspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
|
|
|
|
|
! Output is always in COO format
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
type(psb_dspmat_type), intent(in) :: a
|
|
|
|
@ -901,7 +1003,8 @@ module psb_serial_mod
|
|
|
|
|
end subroutine psb_dspgetrow
|
|
|
|
|
subroutine psb_cspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
|
|
|
|
|
! Output is always in COO format
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
type(psb_cspmat_type), intent(in) :: a
|
|
|
|
@ -916,7 +1019,8 @@ module psb_serial_mod
|
|
|
|
|
end subroutine psb_cspgetrow
|
|
|
|
|
subroutine psb_zspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
|
|
|
|
|
! Output is always in COO format
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
type(psb_zspmat_type), intent(in) :: a
|
|
|
|
@ -935,13 +1039,15 @@ module psb_serial_mod
|
|
|
|
|
|
|
|
|
|
interface psb_csrp
|
|
|
|
|
subroutine psb_dcsrp(trans,iperm,a, info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_dspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(inout) :: iperm(:), info
|
|
|
|
|
character, intent(in) :: trans
|
|
|
|
|
end subroutine psb_dcsrp
|
|
|
|
|
subroutine psb_zcsrp(trans,iperm,a, info)
|
|
|
|
|
use psb_spmat_type
|
|
|
|
|
use psb_spmat_type, only : psb_sspmat_type, psb_dspmat_type,&
|
|
|
|
|
& psb_cspmat_type, psb_zspmat_type, psb_spk_, psb_dpk_
|
|
|
|
|
type(psb_zspmat_type), intent(inout) :: a
|
|
|
|
|
integer, intent(inout) :: iperm(:), info
|
|
|
|
|
character, intent(in) :: trans
|
|
|
|
|