|
|
@ -72,7 +72,7 @@ Subroutine psb_dcg(a,prec,b,x,eps,desc_a,info,&
|
|
|
|
real(kind(1.d0)) ::rerr
|
|
|
|
real(kind(1.d0)) ::rerr
|
|
|
|
real(kind(1.d0)) ::alpha, beta, rho, rho_old, rni, xni, bni, ani,bn2,&
|
|
|
|
real(kind(1.d0)) ::alpha, beta, rho, rho_old, rni, xni, bni, ani,bn2,&
|
|
|
|
& sigma
|
|
|
|
& sigma
|
|
|
|
integer :: litmax, liter, listop, naux, m, mglob, it, itrac,&
|
|
|
|
integer :: litmax, liter, listop, naux, m, mglob, it, itx, itrac,&
|
|
|
|
& nprows,npcols,me,mecol, n_col, isvch, ich, icontxt, n_row,err_act, int_err(5)
|
|
|
|
& nprows,npcols,me,mecol, n_col, isvch, ich, icontxt, n_row,err_act, int_err(5)
|
|
|
|
character ::diagl, diagu
|
|
|
|
character ::diagl, diagu
|
|
|
|
logical, parameter :: exchange=.true., noexchange=.false.
|
|
|
|
logical, parameter :: exchange=.true., noexchange=.false.
|
|
|
@ -154,9 +154,12 @@ Subroutine psb_dcg(a,prec,b,x,eps,desc_a,info,&
|
|
|
|
ich = 1
|
|
|
|
ich = 1
|
|
|
|
call blacs_set(icontxt,16,ich)
|
|
|
|
call blacs_set(icontxt,16,ich)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
restart: do
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ r0 = b-Ax0
|
|
|
|
!!$ r0 = b-Ax0
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
|
|
|
|
if (itx>= litmax) exit restart
|
|
|
|
|
|
|
|
it = 0
|
|
|
|
call psb_axpby(one,b,zero,r,desc_a,info)
|
|
|
|
call psb_axpby(one,b,zero,r,desc_a,info)
|
|
|
|
call psb_spmm(-one,a,x,one,r,desc_a,info,work=aux)
|
|
|
|
call psb_spmm(-one,a,x,one,r,desc_a,info,work=aux)
|
|
|
|
if (info.ne.0) then
|
|
|
|
if (info.ne.0) then
|
|
|
@ -179,7 +182,9 @@ Subroutine psb_dcg(a,prec,b,x,eps,desc_a,info,&
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
iteration: do it = 1, itmax
|
|
|
|
iteration: do
|
|
|
|
|
|
|
|
it = it + 1
|
|
|
|
|
|
|
|
itx = itx + 1
|
|
|
|
|
|
|
|
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ solve mz = r
|
|
|
|
!!$ solve mz = r
|
|
|
@ -230,7 +235,7 @@ Subroutine psb_dcg(a,prec,b,x,eps,desc_a,info,&
|
|
|
|
xni = psb_amax(x,desc_a,info)
|
|
|
|
xni = psb_amax(x,desc_a,info)
|
|
|
|
rerr = rni/(ani*xni+bni)
|
|
|
|
rerr = rni/(ani*xni+bni)
|
|
|
|
If (itrac /= -1) Then
|
|
|
|
If (itrac /= -1) Then
|
|
|
|
If (me.Eq.0) Write(itrac,'(a,i4,5(2x,es10.4))') 'cg: ',it,rerr,rni,bni,&
|
|
|
|
If (me.Eq.0) Write(itrac,'(a,i4,5(2x,es10.4))') 'cg: ',itx,rerr,rni,bni,&
|
|
|
|
&xni,ani
|
|
|
|
&xni,ani
|
|
|
|
Endif
|
|
|
|
Endif
|
|
|
|
|
|
|
|
|
|
|
@ -239,21 +244,20 @@ Subroutine psb_dcg(a,prec,b,x,eps,desc_a,info,&
|
|
|
|
rni = psb_nrm2(r,desc_a,info)
|
|
|
|
rni = psb_nrm2(r,desc_a,info)
|
|
|
|
rerr = rni/bn2
|
|
|
|
rerr = rni/bn2
|
|
|
|
If (itrac /= -1) Then
|
|
|
|
If (itrac /= -1) Then
|
|
|
|
If (me.Eq.0) Write(itrac,'(a,i4,3(2x,es10.4)))') 'cg: ',it,rerr,rni,bn2
|
|
|
|
If (me.Eq.0) Write(itrac,'(a,i4,3(2x,es10.4)))') 'cg: ',itx,rerr,rni,bn2
|
|
|
|
Endif
|
|
|
|
Endif
|
|
|
|
Endif
|
|
|
|
Endif
|
|
|
|
|
|
|
|
if (rerr<=eps) exit restart
|
|
|
|
if (rerr<=eps) then
|
|
|
|
if (itx>= litmax) exit restart
|
|
|
|
exit iteration
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
end do iteration
|
|
|
|
end do iteration
|
|
|
|
|
|
|
|
end do restart
|
|
|
|
|
|
|
|
|
|
|
|
if (present(err)) err=rerr
|
|
|
|
if (present(err)) err=rerr
|
|
|
|
if (present(iter)) iter = it
|
|
|
|
if (present(iter)) iter = itx
|
|
|
|
if (rerr>eps) then
|
|
|
|
if (rerr>eps) then
|
|
|
|
write(0,*) 'CG Failed to converge to ',eps,&
|
|
|
|
write(0,*) 'CG Failed to converge to ',eps,&
|
|
|
|
& ' in ',litmax,' iterations '
|
|
|
|
& ' in ',litmax,' iterations '
|
|
|
|
info=it
|
|
|
|
info=itx
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
deallocate(aux)
|
|
|
|
deallocate(aux)
|
|
|
|