|
|
@ -223,6 +223,7 @@ program spde
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
tprec = psb_wtime()-t1
|
|
|
|
tprec = psb_wtime()-t1
|
|
|
|
|
|
|
|
!!$ call prec%dump(info,prefix='test-ml',ac=.true.,solver=.true.,smoother=.true.)
|
|
|
|
|
|
|
|
|
|
|
|
call psb_amx(ictxt,tprec)
|
|
|
|
call psb_amx(ictxt,tprec)
|
|
|
|
|
|
|
|
|
|
|
@ -449,8 +450,8 @@ contains
|
|
|
|
real(psb_spk_), allocatable :: val(:)
|
|
|
|
real(psb_spk_), allocatable :: val(:)
|
|
|
|
! deltah dimension of each grid cell
|
|
|
|
! deltah dimension of each grid cell
|
|
|
|
! deltat discretization time
|
|
|
|
! deltat discretization time
|
|
|
|
real(psb_spk_) :: deltah
|
|
|
|
real(psb_spk_) :: deltah, deltah2
|
|
|
|
real(psb_spk_),parameter :: rhs=0.0,one=1.0,zero=0.0
|
|
|
|
real(psb_spk_),parameter :: rhs=0.0,one=1.0,zero=0.0
|
|
|
|
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen
|
|
|
|
real(psb_dpk_) :: t0, t1, t2, t3, tasb, talc, ttot, tgen
|
|
|
|
real(psb_spk_) :: a1, a2, a3, a4, b1, b2, b3
|
|
|
|
real(psb_spk_) :: a1, a2, a3, a4, b1, b2, b3
|
|
|
|
external :: a1, a2, a3, a4, b1, b2, b3
|
|
|
|
external :: a1, a2, a3, a4, b1, b2, b3
|
|
|
@ -464,7 +465,8 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
call psb_info(ictxt, iam, np)
|
|
|
|
call psb_info(ictxt, iam, np)
|
|
|
|
|
|
|
|
|
|
|
|
deltah = 1.0/(idim-1)
|
|
|
|
deltah = 1.d0/(idim-1)
|
|
|
|
|
|
|
|
deltah2 = deltah*deltah
|
|
|
|
|
|
|
|
|
|
|
|
! initialize array descriptor and sparse matrix storage. provide an
|
|
|
|
! initialize array descriptor and sparse matrix storage. provide an
|
|
|
|
! estimate of the number of non zeroes
|
|
|
|
! estimate of the number of non zeroes
|
|
|
@ -472,7 +474,7 @@ contains
|
|
|
|
m = idim*idim*idim
|
|
|
|
m = idim*idim*idim
|
|
|
|
n = m
|
|
|
|
n = m
|
|
|
|
nnz = ((n*9)/(np))
|
|
|
|
nnz = ((n*9)/(np))
|
|
|
|
if(iam == psb_root_) write(0,'("Generating Matrix (size=",i0,")...")')n
|
|
|
|
if(iam == psb_root_) write(psb_out_unit,'("Generating Matrix (size=",i0,")...")')n
|
|
|
|
|
|
|
|
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! Using a simple BLOCK distribution.
|
|
|
|
! Using a simple BLOCK distribution.
|
|
|
@ -482,7 +484,7 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
nt = nr
|
|
|
|
nt = nr
|
|
|
|
call psb_sum(ictxt,nt)
|
|
|
|
call psb_sum(ictxt,nt)
|
|
|
|
if (nt /= m) write(0,*) iam, 'Initialization error ',nr,nt,m
|
|
|
|
if (nt /= m) write(psb_err_unit,*) iam, 'Initialization error ',nr,nt,m
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
call psb_barrier(ictxt)
|
|
|
|
t0 = psb_wtime()
|
|
|
|
t0 = psb_wtime()
|
|
|
|
call psb_cdall(ictxt,desc_a,info,nl=nr)
|
|
|
|
call psb_cdall(ictxt,desc_a,info,nl=nr)
|
|
|
@ -556,79 +558,63 @@ contains
|
|
|
|
! term depending on (x-1,y,z)
|
|
|
|
! term depending on (x-1,y,z)
|
|
|
|
!
|
|
|
|
!
|
|
|
|
if (ix == 1) then
|
|
|
|
if (ix == 1) then
|
|
|
|
val(element)=-b1(x,y,z)-a1(x,y,z)
|
|
|
|
val(element) = -b1(x,y,z)/deltah2-a1(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*&
|
|
|
|
zt(k) = exp(-x**2-y**2-z**2)*(-val(element))
|
|
|
|
& deltah)
|
|
|
|
|
|
|
|
zt(k) = exp(-y**2-z**2)*(-val(element))
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
val(element)=-b1(x,y,z)-a1(x,y,z)
|
|
|
|
val(element) = -b1(x,y,z)/deltah2-a1(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*&
|
|
|
|
|
|
|
|
& deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-2)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
icol(element) = (ix-2)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
! term depending on (x,y-1,z)
|
|
|
|
! term depending on (x,y-1,z)
|
|
|
|
if (iy == 1) then
|
|
|
|
if (iy == 1) then
|
|
|
|
val(element)=-b2(x,y,z)-a2(x,y,z)
|
|
|
|
val(element) = -b2(x,y,z)/deltah2-a2(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*&
|
|
|
|
zt(k) = exp(-x**2-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
& deltah)
|
|
|
|
|
|
|
|
zt(k) = exp(-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
val(element)=-b2(x,y,z)-a2(x,y,z)
|
|
|
|
val(element) = -b2(x,y,z)/deltah2-a2(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-2)*idim+(iz)
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-2)*idim+(iz)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
! term depending on (x,y,z-1)
|
|
|
|
! term depending on (x,y,z-1)
|
|
|
|
if (iz == 1) then
|
|
|
|
if (iz == 1) then
|
|
|
|
val(element)=-b3(x,y,z)-a3(x,y,z)
|
|
|
|
val(element)=-b3(x,y,z)/deltah2-a3(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
zt(k) = exp(-x**2-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
zt(k) = exp(-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
val(element)=-b3(x,y,z)-a3(x,y,z)
|
|
|
|
val(element)=-b3(x,y,z)/deltah2-a3(x,y,z)/deltah
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz-1)
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz-1)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
! term depending on (x,y,z)
|
|
|
|
! term depending on (x,y,z)
|
|
|
|
val(element)=2*b1(x,y,z) + 2*b2(x,y,z)&
|
|
|
|
val(element)=(2*b1(x,y,z) + 2*b2(x,y,z) + 2*b3(x,y,z))/deltah2&
|
|
|
|
& + 2*b3(x,y,z) + a1(x,y,z)&
|
|
|
|
& + (a1(x,y,z) + a2(x,y,z) + a3(x,y,z)+ a4(x,y,z))/deltah
|
|
|
|
& + a2(x,y,z) + a3(x,y,z)
|
|
|
|
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
! term depending on (x,y,z+1)
|
|
|
|
! term depending on (x,y,z+1)
|
|
|
|
if (iz == idim) then
|
|
|
|
if (iz == idim) then
|
|
|
|
val(element)=-b1(x,y,z)
|
|
|
|
val(element)=-b1(x,y,z)/deltah2
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
zt(k) = exp(-x**2-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
zt(k) = exp(-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
val(element)=-b1(x,y,z)
|
|
|
|
val(element)=-b1(x,y,z)/deltah2
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz+1)
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy-1)*idim+(iz+1)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
! term depending on (x,y+1,z)
|
|
|
|
! term depending on (x,y+1,z)
|
|
|
|
if (iy == idim) then
|
|
|
|
if (iy == idim) then
|
|
|
|
val(element)=-b2(x,y,z)
|
|
|
|
val(element)=-b2(x,y,z)/deltah2
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
zt(k) = exp(-x**2-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
zt(k) = exp(-y**2-z**2)*exp(-x)*(-val(element))
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
val(element)=-b2(x,y,z)
|
|
|
|
val(element)=-b2(x,y,z)/deltah2
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy)*idim+(iz)
|
|
|
|
icol(element) = (ix-1)*idim*idim+(iy)*idim+(iz)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
! term depending on (x+1,y,z)
|
|
|
|
! term depending on (x+1,y,z)
|
|
|
|
if (ix<idim) then
|
|
|
|
if (ix<idim) then
|
|
|
|
val(element)=-b3(x,y,z)
|
|
|
|
val(element)=-b3(x,y,z)/deltah2
|
|
|
|
val(element) = val(element)/(deltah*deltah)
|
|
|
|
|
|
|
|
icol(element) = (ix)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
icol(element) = (ix)*idim*idim+(iy-1)*idim+(iz)
|
|
|
|
irow(element) = glob_row
|
|
|
|
irow(element) = glob_row
|
|
|
|
element = element+1
|
|
|
|
element = element+1
|
|
|
|