partidx fixes.

Fixed 2/3D bug in test/pargen.
pull/6/head
Salvatore Filippone 7 years ago
parent 62748d3e8f
commit df94b86d93

@ -1,7 +1,7 @@
\section{Utilities} \section{Utilities}
\label{sec:util} \label{sec:util}
We have some utitlities available for input and output of We have some utilities available for input and output of
sparse matrices; the interfaces to these routines are available in the sparse matrices; the interfaces to these routines are available in the
module \verb|psb_util_mod|. module \verb|psb_util_mod|.

@ -145,7 +145,7 @@ contains
! deltah dimension of each grid cell ! deltah dimension of each grid cell
! deltat discretization time ! deltat discretization time
real(psb_dpk_) :: deltah, sqdeltah, deltah2 real(psb_dpk_) :: deltah, sqdeltah, deltah2
real(psb_dpk_), parameter :: rhs=0.d0,one=1.d0,zero=0.d0 real(psb_dpk_), parameter :: rhs=dzero,one=done,zero=dzero
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb
integer(psb_ipk_) :: err_act integer(psb_ipk_) :: err_act
procedure(d_func_2d), pointer :: f_ procedure(d_func_2d), pointer :: f_
@ -164,9 +164,9 @@ contains
f_ => d_null_func_2d f_ => d_null_func_2d
end if end if
deltah = 1.d0/(idim+2) deltah = done/(idim+2)
sqdeltah = deltah*deltah sqdeltah = deltah*deltah
deltah2 = 2.d0* deltah deltah2 = (2*done)* deltah
if (present(partition)) then if (present(partition)) then
if ((1<= partition).and.(partition <= 3)) then if ((1<= partition).and.(partition <= 3)) then
@ -269,7 +269,7 @@ contains
! Now, let's generate the list of indices I own ! Now, let's generate the list of indices I own
nr = 0 nr = 0
do i=bndx(iamx),bndx(iamx+1)-1 do i=bndx(iamx),bndx(iamx+1)-1
do j=bndy(iamy),bndx(iamy+1)-1 do j=bndy(iamy),bndy(iamy+1)-1
nr = nr + 1 nr = nr + 1
call ijk2idx(myidx(nr),i,j,idim,idim) call ijk2idx(myidx(nr),i,j,idim,idim)
end do end do
@ -367,7 +367,7 @@ contains
endif endif
! term depending on (x,y) ! term depending on (x,y)
val(icoeff)=2.d0*(a1(x,y) + a2(x,y))/sqdeltah + c(x,y) val(icoeff)=(2*done)*(a1(x,y) + a2(x,y))/sqdeltah + c(x,y)
icol(icoeff) = (ix-1)*idim+iy icol(icoeff) = (ix-1)*idim+iy
irow(icoeff) = glob_row irow(icoeff) = glob_row
icoeff = icoeff+1 icoeff = icoeff+1
@ -481,7 +481,7 @@ program psb_d_pde2d
integer(psb_ipk_) :: idim integer(psb_ipk_) :: idim
! miscellaneous ! miscellaneous
real(psb_dpk_), parameter :: one = 1.d0 real(psb_dpk_), parameter :: one = done
real(psb_dpk_) :: t1, t2, tprec real(psb_dpk_) :: t1, t2, tprec
! sparse matrix and preconditioner ! sparse matrix and preconditioner
@ -749,13 +749,13 @@ contains
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: b1 real(psb_dpk_) :: b1
real(psb_dpk_), intent(in) :: x,y real(psb_dpk_), intent(in) :: x,y
b1=1.d0/sqrt(2.d0) b1=done/sqrt((2*done))
end function b1 end function b1
function b2(x,y) function b2(x,y)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: b2 real(psb_dpk_) :: b2
real(psb_dpk_), intent(in) :: x,y real(psb_dpk_), intent(in) :: x,y
b2=1.d0/sqrt(2.d0) b2=done/sqrt((2*done))
end function b2 end function b2
function c(x,y) function c(x,y)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
@ -767,13 +767,13 @@ contains
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: a1 real(psb_dpk_) :: a1
real(psb_dpk_), intent(in) :: x,y real(psb_dpk_), intent(in) :: x,y
a1=1.d0/80 a1=done/80
end function a1 end function a1
function a2(x,y) function a2(x,y)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: a2 real(psb_dpk_) :: a2
real(psb_dpk_), intent(in) :: x,y real(psb_dpk_), intent(in) :: x,y
a2=1.d0/80 a2=done/80
end function a2 end function a2
function g(x,y) function g(x,y)
use psb_base_mod, only : psb_dpk_, done, dzero use psb_base_mod, only : psb_dpk_, done, dzero

@ -146,7 +146,7 @@ contains
! deltah dimension of each grid cell ! deltah dimension of each grid cell
! deltat discretization time ! deltat discretization time
real(psb_dpk_) :: deltah, sqdeltah, deltah2 real(psb_dpk_) :: deltah, sqdeltah, deltah2
real(psb_dpk_), parameter :: rhs=0.d0,one=1.d0,zero=0.d0 real(psb_dpk_), parameter :: rhs=dzero,one=done,zero=dzero
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb
integer(psb_ipk_) :: err_act integer(psb_ipk_) :: err_act
procedure(d_func_3d), pointer :: f_ procedure(d_func_3d), pointer :: f_
@ -165,9 +165,9 @@ contains
f_ => d_null_func_3d f_ => d_null_func_3d
end if end if
deltah = 1.d0/(idim+2) deltah = done/(idim+2)
sqdeltah = deltah*deltah sqdeltah = deltah*deltah
deltah2 = 2.d0* deltah deltah2 = (2*done)* deltah
if (present(partition)) then if (present(partition)) then
if ((1<= partition).and.(partition <= 3)) then if ((1<= partition).and.(partition <= 3)) then
@ -273,7 +273,7 @@ contains
! Now, let's generate the list of indices I own ! Now, let's generate the list of indices I own
nr = 0 nr = 0
do i=bndx(iamx),bndx(iamx+1)-1 do i=bndx(iamx),bndx(iamx+1)-1
do j=bndy(iamy),bndx(iamy+1)-1 do j=bndy(iamy),bndy(iamy+1)-1
do k=bndz(iamz),bndz(iamz+1)-1 do k=bndz(iamz),bndz(iamz+1)-1
nr = nr + 1 nr = nr + 1
call ijk2idx(myidx(nr),i,j,k,idim,idim,idim) call ijk2idx(myidx(nr),i,j,k,idim,idim,idim)
@ -382,7 +382,7 @@ contains
endif endif
! term depending on (x,y,z) ! term depending on (x,y,z)
val(icoeff)=2.d0*(a1(x,y,z)+a2(x,y,z)+a3(x,y,z))/sqdeltah & val(icoeff)=(2*done)*(a1(x,y,z)+a2(x,y,z)+a3(x,y,z))/sqdeltah &
& + c(x,y,z) & + c(x,y,z)
icol(icoeff) = (ix-1)*idim*idim+(iy-1)*idim+(iz) icol(icoeff) = (ix-1)*idim*idim+(iy-1)*idim+(iz)
irow(icoeff) = glob_row irow(icoeff) = glob_row
@ -420,7 +420,7 @@ contains
if(info /= psb_success_) exit if(info /= psb_success_) exit
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
zt(:)=0.d0 zt(:)=dzero
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
end do end do
@ -507,7 +507,7 @@ program psb_d_pde3d
integer(psb_ipk_) :: idim integer(psb_ipk_) :: idim
! miscellaneous ! miscellaneous
real(psb_dpk_), parameter :: one = 1.d0 real(psb_dpk_), parameter :: one = done
real(psb_dpk_) :: t1, t2, tprec real(psb_dpk_) :: t1, t2, tprec
! sparse matrix and preconditioner ! sparse matrix and preconditioner
@ -780,43 +780,43 @@ contains
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: b1 real(psb_dpk_) :: b1
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
b1=1.d0/sqrt(3.d0) b1=done/sqrt((3*done))
end function b1 end function b1
function b2(x,y,z) function b2(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: b2 real(psb_dpk_) :: b2
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
b2=1.d0/sqrt(3.d0) b2=done/sqrt((3*done))
end function b2 end function b2
function b3(x,y,z) function b3(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: b3 real(psb_dpk_) :: b3
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
b3=1.d0/sqrt(3.d0) b3=done/sqrt((3*done))
end function b3 end function b3
function c(x,y,z) function c(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: c real(psb_dpk_) :: c
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
c=0.d0 c=dzero
end function c end function c
function a1(x,y,z) function a1(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: a1 real(psb_dpk_) :: a1
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
a1=1.d0/80 a1=done/80
end function a1 end function a1
function a2(x,y,z) function a2(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: a2 real(psb_dpk_) :: a2
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
a2=1.d0/80 a2=done/80
end function a2 end function a2
function a3(x,y,z) function a3(x,y,z)
use psb_base_mod, only : psb_dpk_ use psb_base_mod, only : psb_dpk_
real(psb_dpk_) :: a3 real(psb_dpk_) :: a3
real(psb_dpk_), intent(in) :: x,y,z real(psb_dpk_), intent(in) :: x,y,z
a3=1.d0/80 a3=done/80
end function a3 end function a3
function g(x,y,z) function g(x,y,z)
use psb_base_mod, only : psb_dpk_, done, dzero use psb_base_mod, only : psb_dpk_, done, dzero

@ -63,7 +63,6 @@ module psb_s_pde2d_mod
& psb_sspmat_type, psb_s_vect_type, szero,& & psb_sspmat_type, psb_s_vect_type, szero,&
& psb_s_base_sparse_mat, psb_s_base_vect_type, psb_i_base_vect_type & psb_s_base_sparse_mat, psb_s_base_vect_type, psb_i_base_vect_type
interface interface
function s_func_2d(x,y) result(val) function s_func_2d(x,y) result(val)
import :: psb_spk_ import :: psb_spk_
@ -88,6 +87,7 @@ contains
end function s_null_func_2d end function s_null_func_2d
! !
! subroutine to allocate and fill in the coefficient matrix and ! subroutine to allocate and fill in the coefficient matrix and
! the rhs. ! the rhs.
@ -145,7 +145,7 @@ contains
! deltah dimension of each grid cell ! deltah dimension of each grid cell
! deltat discretization time ! deltat discretization time
real(psb_spk_) :: deltah, sqdeltah, deltah2 real(psb_spk_) :: deltah, sqdeltah, deltah2
real(psb_spk_), parameter :: rhs=0.e0,one=1.e0,zero=0.e0 real(psb_spk_), parameter :: rhs=szero,one=sone,zero=szero
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb
integer(psb_ipk_) :: err_act integer(psb_ipk_) :: err_act
procedure(s_func_2d), pointer :: f_ procedure(s_func_2d), pointer :: f_
@ -164,9 +164,9 @@ contains
f_ => s_null_func_2d f_ => s_null_func_2d
end if end if
deltah = 1.e0/(idim+2) deltah = sone/(idim+2)
sqdeltah = deltah*deltah sqdeltah = deltah*deltah
deltah2 = 2.e0* deltah deltah2 = (2*sone)* deltah
if (present(partition)) then if (present(partition)) then
if ((1<= partition).and.(partition <= 3)) then if ((1<= partition).and.(partition <= 3)) then
@ -269,7 +269,7 @@ contains
! Now, let's generate the list of indices I own ! Now, let's generate the list of indices I own
nr = 0 nr = 0
do i=bndx(iamx),bndx(iamx+1)-1 do i=bndx(iamx),bndx(iamx+1)-1
do j=bndy(iamy),bndx(iamy+1)-1 do j=bndy(iamy),bndy(iamy+1)-1
nr = nr + 1 nr = nr + 1
call ijk2idx(myidx(nr),i,j,idim,idim) call ijk2idx(myidx(nr),i,j,idim,idim)
end do end do
@ -367,7 +367,7 @@ contains
endif endif
! term depending on (x,y) ! term depending on (x,y)
val(icoeff)=2.e0*(a1(x,y) + a2(x,y))/sqdeltah + c(x,y) val(icoeff)=(2*sone)*(a1(x,y) + a2(x,y))/sqdeltah + c(x,y)
icol(icoeff) = (ix-1)*idim+iy icol(icoeff) = (ix-1)*idim+iy
irow(icoeff) = glob_row irow(icoeff) = glob_row
icoeff = icoeff+1 icoeff = icoeff+1
@ -395,7 +395,7 @@ contains
if(info /= psb_success_) exit if(info /= psb_success_) exit
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
zt(:)=0.e0 zt(:)=0.d0
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
end do end do
@ -481,7 +481,7 @@ program psb_s_pde2d
integer(psb_ipk_) :: idim integer(psb_ipk_) :: idim
! miscellaneous ! miscellaneous
real(psb_spk_), parameter :: one = 1.e0 real(psb_spk_), parameter :: one = sone
real(psb_dpk_) :: t1, t2, tprec real(psb_dpk_) :: t1, t2, tprec
! sparse matrix and preconditioner ! sparse matrix and preconditioner
@ -741,6 +741,7 @@ contains
write(iout,*)' >= 1 do tracing every itrace' write(iout,*)' >= 1 do tracing every itrace'
write(iout,*)' iterations ' write(iout,*)' iterations '
end subroutine pr_usage end subroutine pr_usage
! !
! functions parametrizing the differential equation ! functions parametrizing the differential equation
! !
@ -748,31 +749,31 @@ contains
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: b1 real(psb_spk_) :: b1
real(psb_spk_), intent(in) :: x,y real(psb_spk_), intent(in) :: x,y
b1=1.e0/sqrt(2.e0) b1=sone/sqrt((2*sone))
end function b1 end function b1
function b2(x,y) function b2(x,y)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: b2 real(psb_spk_) :: b2
real(psb_spk_), intent(in) :: x,y real(psb_spk_), intent(in) :: x,y
b2=1.e0/sqrt(2.e0) b2=sone/sqrt((2*sone))
end function b2 end function b2
function c(x,y) function c(x,y)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: c real(psb_spk_) :: c
real(psb_spk_), intent(in) :: x,y real(psb_spk_), intent(in) :: x,y
c=0.e0 c=0.d0
end function c end function c
function a1(x,y) function a1(x,y)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: a1 real(psb_spk_) :: a1
real(psb_spk_), intent(in) :: x,y real(psb_spk_), intent(in) :: x,y
a1=1.e0/80 a1=sone/80
end function a1 end function a1
function a2(x,y) function a2(x,y)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: a2 real(psb_spk_) :: a2
real(psb_spk_), intent(in) :: x,y real(psb_spk_), intent(in) :: x,y
a2=1.e0/80 a2=sone/80
end function a2 end function a2
function g(x,y) function g(x,y)
use psb_base_mod, only : psb_spk_, sone, szero use psb_base_mod, only : psb_spk_, sone, szero
@ -785,7 +786,6 @@ contains
g = exp(-y**2) g = exp(-y**2)
end if end if
end function g end function g
end program psb_s_pde2d end program psb_s_pde2d

@ -59,6 +59,8 @@
! !
! !
module psb_s_pde3d_mod module psb_s_pde3d_mod
use psb_base_mod, only : psb_spk_, psb_ipk_, psb_desc_type,& use psb_base_mod, only : psb_spk_, psb_ipk_, psb_desc_type,&
& psb_sspmat_type, psb_s_vect_type, szero,& & psb_sspmat_type, psb_s_vect_type, szero,&
& psb_s_base_sparse_mat, psb_s_base_vect_type, psb_i_base_vect_type & psb_s_base_sparse_mat, psb_s_base_vect_type, psb_i_base_vect_type
@ -75,7 +77,6 @@ module psb_s_pde3d_mod
module procedure psb_s_gen_pde3d module procedure psb_s_gen_pde3d
end interface psb_gen_pde3d end interface psb_gen_pde3d
contains contains
function s_null_func_3d(x,y,z) result(val) function s_null_func_3d(x,y,z) result(val)
@ -145,7 +146,7 @@ contains
! deltah dimension of each grid cell ! deltah dimension of each grid cell
! deltat discretization time ! deltat discretization time
real(psb_spk_) :: deltah, sqdeltah, deltah2 real(psb_spk_) :: deltah, sqdeltah, deltah2
real(psb_spk_), parameter :: rhs=0.e0,one=1.e0,zero=0.e0 real(psb_spk_), parameter :: rhs=szero,one=sone,zero=szero
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen, tcdasb
integer(psb_ipk_) :: err_act integer(psb_ipk_) :: err_act
procedure(s_func_3d), pointer :: f_ procedure(s_func_3d), pointer :: f_
@ -164,9 +165,9 @@ contains
f_ => s_null_func_3d f_ => s_null_func_3d
end if end if
deltah = 1.e0/(idim+2) deltah = sone/(idim+2)
sqdeltah = deltah*deltah sqdeltah = deltah*deltah
deltah2 = 2.e0* deltah deltah2 = (2*sone)* deltah
if (present(partition)) then if (present(partition)) then
if ((1<= partition).and.(partition <= 3)) then if ((1<= partition).and.(partition <= 3)) then
@ -272,7 +273,7 @@ contains
! Now, let's generate the list of indices I own ! Now, let's generate the list of indices I own
nr = 0 nr = 0
do i=bndx(iamx),bndx(iamx+1)-1 do i=bndx(iamx),bndx(iamx+1)-1
do j=bndy(iamy),bndx(iamy+1)-1 do j=bndy(iamy),bndy(iamy+1)-1
do k=bndz(iamz),bndz(iamz+1)-1 do k=bndz(iamz),bndz(iamz+1)-1
nr = nr + 1 nr = nr + 1
call ijk2idx(myidx(nr),i,j,k,idim,idim,idim) call ijk2idx(myidx(nr),i,j,k,idim,idim,idim)
@ -381,7 +382,7 @@ contains
endif endif
! term depending on (x,y,z) ! term depending on (x,y,z)
val(icoeff)=2.e0*(a1(x,y,z)+a2(x,y,z)+a3(x,y,z))/sqdeltah & val(icoeff)=(2*sone)*(a1(x,y,z)+a2(x,y,z)+a3(x,y,z))/sqdeltah &
& + c(x,y,z) & + c(x,y,z)
icol(icoeff) = (ix-1)*idim*idim+(iy-1)*idim+(iz) icol(icoeff) = (ix-1)*idim*idim+(iy-1)*idim+(iz)
irow(icoeff) = glob_row irow(icoeff) = glob_row
@ -419,7 +420,7 @@ contains
if(info /= psb_success_) exit if(info /= psb_success_) exit
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),bv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
zt(:)=0.e0 zt(:)=szero
call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info) call psb_geins(ib,myidx(ii:ii+ib-1),zt(1:ib),xv,desc_a,info)
if(info /= psb_success_) exit if(info /= psb_success_) exit
end do end do
@ -506,7 +507,7 @@ program psb_s_pde3d
integer(psb_ipk_) :: idim integer(psb_ipk_) :: idim
! miscellaneous ! miscellaneous
real(psb_spk_), parameter :: one = 1.e0 real(psb_spk_), parameter :: one = sone
real(psb_dpk_) :: t1, t2, tprec real(psb_dpk_) :: t1, t2, tprec
! sparse matrix and preconditioner ! sparse matrix and preconditioner
@ -543,6 +544,7 @@ program psb_s_pde3d
if(psb_get_errstatus() /= 0) goto 9999 if(psb_get_errstatus() /= 0) goto 9999
name='pde3d90' name='pde3d90'
call psb_set_errverbosity(itwo) call psb_set_errverbosity(itwo)
call psb_cd_set_large_threshold(itwo)
! !
! Hello world ! Hello world
! !
@ -778,43 +780,43 @@ contains
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: b1 real(psb_spk_) :: b1
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
b1=1.e0/sqrt(3.e0) b1=sone/sqrt((3*sone))
end function b1 end function b1
function b2(x,y,z) function b2(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: b2 real(psb_spk_) :: b2
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
b2=1.e0/sqrt(3.e0) b2=sone/sqrt((3*sone))
end function b2 end function b2
function b3(x,y,z) function b3(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: b3 real(psb_spk_) :: b3
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
b3=1.e0/sqrt(3.e0) b3=sone/sqrt((3*sone))
end function b3 end function b3
function c(x,y,z) function c(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: c real(psb_spk_) :: c
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
c=0.e0 c=szero
end function c end function c
function a1(x,y,z) function a1(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: a1 real(psb_spk_) :: a1
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
a1=1.e0/80 a1=sone/80
end function a1 end function a1
function a2(x,y,z) function a2(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: a2 real(psb_spk_) :: a2
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
a2=1.e0/80 a2=sone/80
end function a2 end function a2
function a3(x,y,z) function a3(x,y,z)
use psb_base_mod, only : psb_spk_ use psb_base_mod, only : psb_spk_
real(psb_spk_) :: a3 real(psb_spk_) :: a3
real(psb_spk_), intent(in) :: x,y,z real(psb_spk_), intent(in) :: x,y,z
a3=1.e0/80 a3=sone/80
end function a3 end function a3
function g(x,y,z) function g(x,y,z)
use psb_base_mod, only : psb_spk_, sone, szero use psb_base_mod, only : psb_spk_, sone, szero

@ -31,7 +31,7 @@
! !
! !
! Purpose: ! Purpose:
! Proide functions to handle a distribution of a general ! Provide functions to handle a distribution of a general
! rectangular 2/3/n-dimensional domain onto ! rectangular 2/3/n-dimensional domain onto
! a rectangular 2/3/n-dimensional grid of processes ! a rectangular 2/3/n-dimensional grid of processes
! !

Loading…
Cancel
Save