Merged changes at r2702 from branch psblas-ovtrans.

psblas3-type-indexed
Salvatore Filippone 17 years ago
parent 7f758de51c
commit c8c211c0e9

@ -1,7 +1,8 @@
include ../../Make.inc include ../../Make.inc
OBJS = psb_dgather.o psb_dhalo.o psb_dovrl.o \ OBJS = psb_dgather.o psb_dhalo.o psb_dovrl.o \
psb_igather.o psb_ihalo.o psb_zgather.o psb_zhalo.o psb_zovrl.o psb_igather.o psb_ihalo.o psb_iovrl.o \
psb_zgather.o psb_zhalo.o psb_zovrl.o
MPFOBJS=psb_dscatter.o psb_zscatter.o psb_iscatter.o MPFOBJS=psb_dscatter.o psb_zscatter.o psb_iscatter.o
LIBDIR=.. LIBDIR=..

@ -66,7 +66,7 @@ subroutine psb_dgatherm(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dgatherm' name='psb_dgatherm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -82,7 +82,7 @@ subroutine psb_dgatherm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -119,14 +119,14 @@ subroutine psb_dgatherm(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info)
call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx) call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -139,14 +139,15 @@ subroutine psb_dgatherm(globx, locx, desc_a, info, iroot)
idx = desc_a%loc_to_glob(i) idx = desc_a%loc_to_glob(i)
globx(idx,jglobx+j-1) = locx(i,jlx+j-1) globx(idx,jglobx+j-1) = locx(i,jlx+j-1)
end do end do
end do
do j=1,k
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx,jglobx+j-1) = & globx(idx,jglobx+j-1) = dzero
& globx(idx,jglobx+j-1)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) end if
i=i+2
end do end do
end do end do
@ -158,7 +159,7 @@ subroutine psb_dgatherm(globx, locx, desc_a, info, iroot)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -237,7 +238,7 @@ subroutine psb_dgatherv(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dgatherv' name='psb_dgatherv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -253,7 +254,7 @@ subroutine psb_dgatherv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -281,14 +282,14 @@ subroutine psb_dgatherv(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info)
call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx) call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -300,15 +301,15 @@ subroutine psb_dgatherv(globx, locx, desc_a, info, iroot)
idx = desc_a%loc_to_glob(i) idx = desc_a%loc_to_glob(i)
globx(idx) = locx(i) globx(idx) = locx(i)
end do end do
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx) = globx(idx)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) globx(idx) = dzero
i=i+2 end if
end do end do
call psb_sum(ictxt,globx(1:m),root=root) call psb_sum(ictxt,globx(1:m),root=root)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
@ -317,7 +318,7 @@ subroutine psb_dgatherv(globx, locx, desc_a, info, iroot)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -80,7 +80,7 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_dhalom' name='psb_dhalom'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -108,7 +108,7 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
maxk=size(x,2)-ijx+1 maxk=size(x,2)-ijx+1
if(present(ik)) then if(present(ik)) then
if(ik.gt.maxk) then if(ik > maxk) then
k=maxk k=maxk
else else
k=ik k=ik
@ -138,23 +138,23 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
if(present(alpha)) then if(present(alpha)) then
if(alpha.ne.1.d0) then if(alpha /= 1.d0) then
do i=0, k-1 do i=0, k-1
call dscal(nrow,alpha,x(1,jjx+i),1) call dscal(nrow,alpha,x(1,jjx+i),1)
end do end do
@ -163,13 +163,13 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -180,7 +180,7 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
aliw=.true. aliw=.true.
!!$ write(0,*) 'halom ',liwork !!$ write(0,*) 'halom ',liwork
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -202,7 +202,7 @@ subroutine psb_dhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
ch_err='PSI_dSwapdata' ch_err='PSI_dSwapdata'
call psb_errpush(4010,name,a_err=ch_err) call psb_errpush(4010,name,a_err=ch_err)
goto 9999 goto 9999
@ -305,7 +305,7 @@ subroutine psb_dhalov(x,desc_a,info,alpha,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_dhalov' name='psb_dhalov'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -344,36 +344,36 @@ subroutine psb_dhalov(x,desc_a,info,alpha,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
if(present(alpha)) then if(present(alpha)) then
if(alpha.ne.1.d0) then if(alpha /= 1.d0) then
call dscal(nrow,alpha,x,ione) call dscal(nrow,alpha,x,ione)
end if end if
end if end if
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -383,7 +383,7 @@ subroutine psb_dhalov(x,desc_a,info,alpha,work,tran,mode,data)
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -404,7 +404,7 @@ subroutine psb_dhalov(x,desc_a,info,alpha,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
ch_err='PSI_swapdata' ch_err='PSI_swapdata'
call psb_errpush(4010,name,a_err=ch_err) call psb_errpush(4010,name,a_err=ch_err)
goto 9999 goto 9999

@ -79,16 +79,16 @@ subroutine psb_dovrlm(x,desc_a,info,jx,ik,work,update,mode)
integer, intent(in), optional :: update,jx,ik,mode integer, intent(in), optional :: update,jx,ik,mode
! locals ! locals
integer :: int_err(5), ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, maxk, update_,& & err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, maxk, update_,&
& mode_, err, liwork, i & mode_, err, liwork
real(kind(1.d0)),pointer :: iwork(:), xp(:,:) real(kind(1.d0)),pointer :: iwork(:), xp(:,:)
logical :: do_swap logical :: do_swap
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw logical :: aliw
name='psb_dovrlm' name='psb_dovrlm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -117,7 +117,7 @@ subroutine psb_dovrlm(x,desc_a,info,jx,ik,work,update,mode)
maxk=size(x,2)-ijx+1 maxk=size(x,2)-ijx+1
if(present(ik)) then if(present(ik)) then
if(ik.gt.maxk) then if(ik > maxk) then
k=maxk k=maxk
else else
k=ik k=ik
@ -141,87 +141,55 @@ subroutine psb_dovrlm(x,desc_a,info,jx,ik,work,update,mode)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
! check for presence/size of a work area ! check for presence/size of a work area
liwork=ncol liwork=ncol
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info)
if(info.ne.0) then
info=4010
ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
end if end if
else else
aliw=.true. aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' call psb_errpush(info,name,a_err='Allocate')
call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
else
iwork => work
end if end if
! exchange overlap elements ! exchange overlap elements
if(do_swap) then if(do_swap) then
xp => x(iix:size(x,1),jjx:jjx+k-1) xp => x(iix:size(x,1),jjx:jjx+k-1)
call psi_swapdata(mode_,k,done,xp,& call psi_swapdata(mode_,k,done,xp,&
& desc_a,iwork,info,data=psb_comm_ovr_) & desc_a,iwork,info,data=psb_comm_ovr_)
end if end if
if (info == 0) call psi_ovrl_upd(xp,desc_a,update_,info)
if(info.ne.0) then if (info /= 0) then
call psb_errpush(4010,name,a_err='psi_swapdata') call psb_errpush(4010,name,a_err='Inner updates')
goto 9999 goto 9999
end if end if
i=1
! switch on update type
select case (update_)
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,update_,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999
end select
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)
@ -317,16 +285,16 @@ subroutine psb_dovrlv(x,desc_a,info,work,update,mode)
integer, intent(in), optional :: update,mode integer, intent(in), optional :: update,mode
! locals ! locals
integer :: int_err(5), ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, update_,& & err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, update_,&
& mode_, err, liwork, i & mode_, err, liwork
real(kind(1.d0)),pointer :: iwork(:) real(kind(1.d0)),pointer :: iwork(:)
logical :: do_swap logical :: do_swap
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw logical :: aliw
name='psb_dovrlv' name='psb_dovrlv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -365,86 +333,54 @@ subroutine psb_dovrlv(x,desc_a,info,work,update,mode)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
! check for presence/size of a work area ! check for presence/size of a work area
liwork=ncol liwork=ncol
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info)
if(info.ne.0) then
info=4010
ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
end if end if
else else
aliw=.true. aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' call psb_errpush(info,name,a_err='Allocate')
call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
else
iwork => work
end if end if
! exchange overlap elements ! exchange overlap elements
if(do_swap) then if (do_swap) then
call psi_swapdata(mode_,done,x(iix:size(x)),& call psi_swapdata(mode_,done,x(:),&
& desc_a,iwork,info,data=psb_comm_ovr_) & desc_a,iwork,info,data=psb_comm_ovr_)
end if end if
if (info == 0) call psi_ovrl_upd(x,desc_a,update_,info)
if(info.ne.0) then if (info /= 0) then
call psb_errpush(4010,name,a_err='PSI_SwapData') call psb_errpush(4010,name,a_err='Inner updates')
goto 9999 goto 9999
end if end if
i=1
! switch on update type
select case (update_)
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,update_,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999
end select
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)

@ -89,7 +89,7 @@ subroutine psb_dscatterm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -317,7 +317,7 @@ subroutine psb_dscatterv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)

@ -66,7 +66,7 @@ subroutine psb_igatherm(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_igatherm' name='psb_igatherm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -82,7 +82,7 @@ subroutine psb_igatherm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -119,14 +119,14 @@ subroutine psb_igatherm(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info)
call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx) call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -139,14 +139,15 @@ subroutine psb_igatherm(globx, locx, desc_a, info, iroot)
idx = desc_a%loc_to_glob(i) idx = desc_a%loc_to_glob(i)
globx(idx,jglobx+j-1) = locx(i,jlx+j-1) globx(idx,jglobx+j-1) = locx(i,jlx+j-1)
end do end do
end do
do j=1,k
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx,jglobx+j-1) = & globx(idx,jglobx+j-1) = izero
& globx(idx,jglobx+j-1)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) end if
i=i+2
end do end do
end do end do
@ -158,7 +159,7 @@ subroutine psb_igatherm(globx, locx, desc_a, info, iroot)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -237,7 +238,7 @@ subroutine psb_igatherv(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_igatherv' name='psb_igatherv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -253,7 +254,7 @@ subroutine psb_igatherv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -281,14 +282,14 @@ subroutine psb_igatherv(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info)
call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx) call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -301,14 +302,13 @@ subroutine psb_igatherv(globx, locx, desc_a, info, iroot)
globx(idx) = locx(i) globx(idx) = locx(i)
end do end do
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx) = globx(idx)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) globx(idx) = dzero
i=i+2 end if
end do end do
call psb_sum(ictxt,globx(1:m),root=root) call psb_sum(ictxt,globx(1:m),root=root)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
@ -317,7 +317,7 @@ subroutine psb_igatherv(globx, locx, desc_a, info, iroot)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -81,7 +81,7 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_ihalom' name='psb_ihalom'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -109,7 +109,7 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
maxk=size(x,2)-ijx+1 maxk=size(x,2)-ijx+1
if(present(ik)) then if(present(ik)) then
if(ik.gt.maxk) then if(ik > maxk) then
k=maxk k=maxk
else else
k=ik k=ik
@ -139,25 +139,25 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
! we should write an "iscal" ! we should write an "iscal"
!!$ if(present(alpha)) then !!$ if(present(alpha)) then
!!$ if(alpha.ne.1.d0) then !!$ if(alpha /= 1.d0) then
!!$ do i=0, k-1 !!$ do i=0, k-1
!!$ call iscal(nrow,alpha,x(1,jjx+i),1) !!$ call iscal(nrow,alpha,x(1,jjx+i),1)
!!$ end do !!$ end do
@ -166,13 +166,13 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
aliw=.false. aliw=.false.
iwork => work iwork => work
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -182,7 +182,7 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -204,7 +204,7 @@ subroutine psb_ihalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='PSI_iSwap...') call psb_errpush(4010,name,a_err='PSI_iSwap...')
goto 9999 goto 9999
end if end if
@ -309,7 +309,7 @@ subroutine psb_ihalov(x,desc_a,info,alpha,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_ihalov' name='psb_ihalov'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -350,36 +350,36 @@ subroutine psb_ihalov(x,desc_a,info,alpha,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
!!$ if(present(alpha)) then !!$ if(present(alpha)) then
!!$ if(alpha.ne.1.d0) then !!$ if(alpha /= 1.d0) then
!!$ call dscal(nrow,alpha,x,1) !!$ call dscal(nrow,alpha,x,1)
!!$ end if !!$ end if
!!$ end if !!$ end if
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
aliw=.false. aliw=.false.
iwork => work iwork => work
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -389,7 +389,7 @@ subroutine psb_ihalov(x,desc_a,info,alpha,work,tran,mode,data)
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -410,7 +410,7 @@ subroutine psb_ihalov(x,desc_a,info,alpha,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='PSI_iswapdata') call psb_errpush(4010,name,a_err='PSI_iswapdata')
goto 9999 goto 9999
end if end if

@ -0,0 +1,397 @@
!!$
!!$ Parallel Sparse BLAS v2.0
!!$ (C) Copyright 2006 Salvatore Filippone University of Rome Tor Vergata
!!$ Alfredo Buttari University of Rome Tor Vergata
!!$
!!$ Redistribution and use in source and binary forms, with or without
!!$ modification, are permitted provided that the following conditions
!!$ are met:
!!$ 1. Redistributions of source code must retain the above copyright
!!$ notice, this list of conditions and the following disclaimer.
!!$ 2. Redistributions in binary form must reproduce the above copyright
!!$ notice, this list of conditions, and the following disclaimer in the
!!$ documentation and/or other materials provided with the distribution.
!!$ 3. The name of the PSBLAS group or the names of its contributors may
!!$ not be used to endorse or promote products derived from this
!!$ software without specific written permission.
!!$
!!$ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
!!$ ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
!!$ TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
!!$ PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE PSBLAS GROUP OR ITS CONTRIBUTORS
!!$ BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
!!$ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
!!$ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
!!$ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
!!$ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
!!$ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
!!$ POSSIBILITY OF SUCH DAMAGE.
!!$
!!$
! File: psb_iovrl.f90
!
! Subroutine: psb_iovrlm
! This subroutine performs the exchange of the overlap elements in a
! distributed dense matrix between all the processes.
!
! Arguments:
! x(:,:) - integer The local part of the dense matrix.
! desc_a - type(psb_desc_type). The communication descriptor.
! info - integer. Return code.
! jx - integer(optional). The starting column of the global matrix
! ik - integer(optional). The number of columns to gather.
! work - real(optional). A work area.
! update - integer(optional). Type of update:
! psb_none_ do nothing
! psb_sum_ sum of overlaps
! psb_avg_ average of overlaps
! mode - integer(optional). Choose the algorithm for data exchange:
! this is chosen through bit fields.
! - swap_mpi = iand(flag,psb_swap_mpi_) /= 0
! - swap_sync = iand(flag,psb_swap_sync_) /= 0
! - swap_send = iand(flag,psb_swap_send_) /= 0
! - swap_recv = iand(flag,psb_swap_recv_) /= 0
! - if (swap_mpi): use underlying MPI_ALLTOALLV.
! - if (swap_sync): use PSB_SND and PSB_RCV in
! synchronized pairs
! - if (swap_send .and. swap_recv): use mpi_irecv
! and mpi_send
! - if (swap_send): use psb_snd (but need another
! call with swap_recv to complete)
! - if (swap_recv): use psb_rcv (completing a
! previous call with swap_send)
!
!
subroutine psb_iovrlm(x,desc_a,info,jx,ik,work,update,mode)
use psb_descriptor_type
use psb_const_mod
use psi_mod
use psb_realloc_mod
use psb_check_mod
use psb_error_mod
use psb_penv_mod
implicit none
integer, intent(inout), target :: x(:,:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(out) :: info
integer, optional, target :: work(:)
integer, intent(in), optional :: update,jx,ik,mode
! locals
integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, maxk, update_,&
& mode_, err, liwork
integer, pointer :: iwork(:), xp(:,:)
logical :: do_swap
character(len=20) :: name, ch_err
logical :: aliw
name='psb_iovrlm'
if(psb_get_errstatus() /= 0) return
info=0
call psb_erractionsave(err_act)
ictxt=psb_cd_get_context(desc_a)
! check on blacs grid
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
ix = 1
if (present(jx)) then
ijx = jx
else
ijx = 1
endif
m = psb_cd_get_global_rows(desc_a)
n = psb_cd_get_global_cols(desc_a)
nrow = psb_cd_get_local_rows(desc_a)
ncol = psb_cd_get_local_cols(desc_a)
maxk=size(x,2)-ijx+1
if(present(ik)) then
if(ik > maxk) then
k=maxk
else
k=ik
end if
else
k = maxk
end if
if (present(update)) then
update_ = update
else
update_ = psb_avg_
endif
if (present(mode)) then
mode_ = mode
else
mode_ = IOR(psb_swap_send_,psb_swap_recv_)
endif
do_swap = (mode_ /= 0)
! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info /= 0) then
info=4010
ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err)
end if
if (iix /= 1) then
info=3040
call psb_errpush(info,name)
end if
err=info
call psb_errcomm(ictxt,err)
if(err /= 0) goto 9999
! check for presence/size of a work area
liwork=ncol
if (present(work)) then
if(size(work) >= liwork) then
aliw=.false.
else
aliw=.true.
end if
else
aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info)
if(info /= 0) then
info=4010
call psb_errpush(info,name,a_err='Allocate')
goto 9999
end if
else
iwork => work
end if
! exchange overlap elements
if(do_swap) then
xp => x(iix:size(x,1),jjx:jjx+k-1)
call psi_swapdata(mode_,k,ione,xp,&
& desc_a,iwork,info,data=psb_comm_ovr_)
end if
if (info == 0) call psi_ovrl_upd(xp,desc_a,update_,info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Inner updates')
goto 9999
end if
if (aliw) deallocate(iwork)
nullify(iwork)
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psb_iovrlm
!!$
!!$ Parallel Sparse BLAS v2.0
!!$ (C) Copyright 2006 Salvatore Filippone University of Rome Tor Vergata
!!$ Alfredo Buttari University of Rome Tor Vergata
!!$
!!$ Redistribution and use in source and binary forms, with or without
!!$ modification, are permitted provided that the following conditions
!!$ are met:
!!$ 1. Redistributions of source code must retain the above copyright
!!$ notice, this list of conditions and the following disclaimer.
!!$ 2. Redistributions in binary form must reproduce the above copyright
!!$ notice, this list of conditions, and the following disclaimer in the
!!$ documentation and/or other materials provided with the distribution.
!!$ 3. The name of the PSBLAS group or the names of its contributors may
!!$ not be used to endorse or promote products derived from this
!!$ software without specific written permission.
!!$
!!$ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
!!$ ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
!!$ TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
!!$ PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE PSBLAS GROUP OR ITS CONTRIBUTORS
!!$ BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
!!$ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
!!$ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
!!$ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
!!$ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
!!$ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
!!$ POSSIBILITY OF SUCH DAMAGE.
!!$
!!$
!
! Subroutine: psb_iovrlv
! This subroutine performs the exchange of the overlap elements in a
! distributed dense vector between all the processes.
!
! Arguments:
! x(:) - integer The local part of the dense vector.
! desc_a - type(psb_desc_type). The communication descriptor.
! info - integer. Return code.
! work - real(optional). A work area.
! update - integer(optional). Type of update:
! psb_none_ do nothing
! psb_sum_ sum of overlaps
! psb_avg_ average of overlaps
! mode - integer(optional). Choose the algorithm for data exchange:
! this is chosen through bit fields.
! - swap_mpi = iand(flag,psb_swap_mpi_) /= 0
! - swap_sync = iand(flag,psb_swap_sync_) /= 0
! - swap_send = iand(flag,psb_swap_send_) /= 0
! - swap_recv = iand(flag,psb_swap_recv_) /= 0
! - if (swap_mpi): use underlying MPI_ALLTOALLV.
! - if (swap_sync): use PSB_SND and PSB_RCV in
! synchronized pairs
! - if (swap_send .and. swap_recv): use mpi_irecv
! and mpi_send
! - if (swap_send): use psb_snd (but need another
! call with swap_recv to complete)
! - if (swap_recv): use psb_rcv (completing a
! previous call with swap_send)
!
!
!
subroutine psb_iovrlv(x,desc_a,info,work,update,mode)
use psb_descriptor_type
use psi_mod
use psb_const_mod
use psb_realloc_mod
use psb_check_mod
use psb_error_mod
use psb_penv_mod
implicit none
integer, intent(inout), target :: x(:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(out) :: info
integer, optional, target :: work(:)
integer, intent(in), optional :: update,mode
! locals
integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, update_,&
& mode_, err, liwork
integer,pointer :: iwork(:)
logical :: do_swap
character(len=20) :: name, ch_err
logical :: aliw
name='psb_iovrlv'
if(psb_get_errstatus() /= 0) return
info=0
call psb_erractionsave(err_act)
ictxt=psb_cd_get_context(desc_a)
! check on blacs grid
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
ix = 1
ijx = 1
m = psb_cd_get_global_rows(desc_a)
n = psb_cd_get_global_cols(desc_a)
nrow = psb_cd_get_local_rows(desc_a)
ncol = psb_cd_get_local_cols(desc_a)
k = 1
if (present(update)) then
update_ = update
else
update_ = psb_avg_
endif
if (present(mode)) then
mode_ = mode
else
mode_ = IOR(psb_swap_send_,psb_swap_recv_)
endif
do_swap = (mode_ /= 0)
! check vector correctness
call psb_chkvect(m,1,size(x),ix,ijx,desc_a,info,iix,jjx)
if(info /= 0) then
info=4010
ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err)
end if
if (iix /= 1) then
info=3040
call psb_errpush(info,name)
end if
err=info
call psb_errcomm(ictxt,err)
if(err /= 0) goto 9999
! check for presence/size of a work area
liwork=ncol
if (present(work)) then
if(size(work) >= liwork) then
aliw=.false.
else
aliw=.true.
end if
else
aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info)
if(info /= 0) then
info=4010
call psb_errpush(info,name,a_err='Allocate')
goto 9999
end if
else
iwork => work
end if
! exchange overlap elements
if (do_swap) then
call psi_swapdata(mode_,ione,x(:),&
& desc_a,iwork,info,data=psb_comm_ovr_)
end if
if (info == 0) call psi_ovrl_upd(x,desc_a,update_,info)
if (info /= 0) then
call psb_errpush(4010,name,a_err='Inner updates')
goto 9999
end if
if (aliw) deallocate(iwork)
nullify(iwork)
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psb_iovrlv

@ -88,7 +88,7 @@ subroutine psb_iscatterm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -315,7 +315,7 @@ subroutine psb_iscatterv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)

@ -66,7 +66,7 @@ subroutine psb_zgatherm(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zgatherm' name='psb_zgatherm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -82,7 +82,7 @@ subroutine psb_zgatherm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -121,14 +121,14 @@ subroutine psb_zgatherm(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx,1),iglobx,jglobx,desc_a,info)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx) & call psb_chkvect(m,n,size(locx,1),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -141,17 +141,18 @@ subroutine psb_zgatherm(globx, locx, desc_a, info, iroot)
idx = desc_a%loc_to_glob(i) idx = desc_a%loc_to_glob(i)
globx(idx,jglobx+j-1) = locx(i,jlx+j-1) globx(idx,jglobx+j-1) = locx(i,jlx+j-1)
end do end do
end do
do j=1,k
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx,jglobx+j-1) = & globx(idx,jglobx+j-1) = zzero
& globx(idx,jglobx+j-1)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) end if
i=i+2
end do end do
end do end do
call psb_sum(ictxt,globx(1:m,jglobx:jglobx+k-1),root=root) call psb_sum(ictxt,globx(1:m,jglobx:jglobx+k-1),root=root)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
@ -160,7 +161,7 @@ subroutine psb_zgatherm(globx, locx, desc_a, info, iroot)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -240,7 +241,7 @@ subroutine psb_zgatherv(globx, locx, desc_a, info, iroot)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zgatherv' name='psb_zgatherv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -256,7 +257,7 @@ subroutine psb_zgatherv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -285,14 +286,14 @@ subroutine psb_zgatherv(globx, locx, desc_a, info, iroot)
call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info) call psb_chkglobvect(m,n,size(globx),iglobx,jglobx,desc_a,info)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx) & call psb_chkvect(m,n,size(locx),ilocx,jlocx,desc_a,info,ilx,jlx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chk(glob)vect' ch_err='psb_chk(glob)vect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ilx.ne.1).or.(iglobx.ne.1)) then if ((ilx /= 1).or.(iglobx /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -305,23 +306,23 @@ subroutine psb_zgatherv(globx, locx, desc_a, info, iroot)
globx(idx) = locx(i) globx(idx) = locx(i)
end do end do
! adjust overlapped elements ! adjust overlapped elements
i=1 do i=1, size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-1) if (me /= desc_a%ovrlap_elem(i,3)) then
idx=desc_a%ovrlap_elem(i+psb_ovrlp_elem_) idx = desc_a%ovrlap_elem(i,1)
idx=desc_a%loc_to_glob(idx) idx = desc_a%loc_to_glob(idx)
globx(idx) = globx(idx)/desc_a%ovrlap_elem(i+psb_n_dom_ovr_) globx(idx) = dzero
i=i+2 end if
end do end do
call psb_sum(ictxt,globx(1:m),root=root) call psb_sum(ictxt,globx(1:m),root=root)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -80,7 +80,7 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_zhalom' name='psb_zhalom'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -108,7 +108,7 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
maxk=size(x,2)-ijx+1 maxk=size(x,2)-ijx+1
if(present(ik)) then if(present(ik)) then
if(ik.gt.maxk) then if(ik > maxk) then
k=maxk k=maxk
else else
k=ik k=ik
@ -136,23 +136,23 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
if(present(alpha)) then if(present(alpha)) then
if(alpha.ne.1.d0) then if(alpha /= 1.d0) then
do i=0, k-1 do i=0, k-1
call zscal(nrow,alpha,x(1,jjx+i),1) call zscal(nrow,alpha,x(1,jjx+i),1)
end do end do
@ -161,13 +161,13 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
aliw=.false. aliw=.false.
iwork => work iwork => work
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -178,7 +178,7 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -200,7 +200,7 @@ subroutine psb_zhalom(x,desc_a,info,alpha,jx,ik,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
ch_err='PSI_zswapdata' ch_err='PSI_zswapdata'
call psb_errpush(4010,name,a_err=ch_err) call psb_errpush(4010,name,a_err=ch_err)
goto 9999 goto 9999
@ -305,7 +305,7 @@ subroutine psb_zhalov(x,desc_a,info,alpha,work,tran,mode,data)
logical :: aliw logical :: aliw
name='psb_zhalov' name='psb_zhalov'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -345,36 +345,36 @@ subroutine psb_zhalov(x,desc_a,info,alpha,work,tran,mode,data)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
if(present(alpha)) then if(present(alpha)) then
if(alpha.ne.1.d0) then if(alpha /= 1.d0) then
call zscal(nrow,alpha,x,ione) call zscal(nrow,alpha,x,ione)
end if end if
end if end if
liwork=nrow liwork=nrow
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
aliw=.false. aliw=.false.
iwork => work iwork => work
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -384,7 +384,7 @@ subroutine psb_zhalov(x,desc_a,info,alpha,work,tran,mode,data)
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -405,7 +405,7 @@ subroutine psb_zhalov(x,desc_a,info,alpha,work,tran,mode,data)
goto 9999 goto 9999
end if end if
if(info.ne.0) then if(info /= 0) then
ch_err='PSI_dSwap...' ch_err='PSI_dSwap...'
call psb_errpush(4010,name,a_err=ch_err) call psb_errpush(4010,name,a_err=ch_err)
goto 9999 goto 9999

@ -80,16 +80,16 @@ subroutine psb_zovrlm(x,desc_a,info,jx,ik,work,update,mode)
integer, intent(in), optional :: update,jx,ik,mode integer, intent(in), optional :: update,jx,ik,mode
! locals ! locals
integer :: int_err(5), ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, maxk, update_,& & err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, maxk, update_,&
& mode_, err, liwork, i & mode_, err, liwork
complex(kind(1.d0)),pointer :: iwork(:), xp(:,:) complex(kind(1.d0)),pointer :: iwork(:), xp(:,:)
logical :: do_swap logical :: do_swap
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw logical :: aliw
name='psb_zovrlm' name='psb_zovrlm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -118,7 +118,7 @@ subroutine psb_zovrlm(x,desc_a,info,jx,ik,work,update,mode)
maxk=size(x,2)-ijx+1 maxk=size(x,2)-ijx+1
if(present(ik)) then if(present(ik)) then
if(ik.gt.maxk) then if(ik > maxk) then
k=maxk k=maxk
else else
k=ik k=ik
@ -142,87 +142,54 @@ subroutine psb_zovrlm(x,desc_a,info,jx,ik,work,update,mode)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
! check for presence/size of a work area ! check for presence/size of a work area
liwork=ncol liwork=ncol
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info)
if(info.ne.0) then
info=4010
ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
end if end if
else else
aliw=.true. aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' call psb_errpush(info,name,a_err='Allocate')
call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
else
iwork => work
end if end if
! exchange overlap elements ! exchange overlap elements
if(do_swap) then if(do_swap) then
xp => x(iix:size(x,1),jjx:jjx+k-1) xp => x(iix:size(x,1),jjx:jjx+k-1)
call psi_swapdata(mode_,k,zone,xp,& call psi_swapdata(mode_,k,zone,xp,&
& desc_a,iwork,info,data=psb_comm_ovr_) & desc_a,iwork,info,data=psb_comm_ovr_)
end if end if
if (info == 0) call psi_ovrl_upd(xp,desc_a,update_,info)
if(info.ne.0) then if (info /= 0) then
call psb_errpush(4010,name,a_err='psi_swapdata') call psb_errpush(4010,name,a_err='Inner updates')
goto 9999 goto 9999
end if end if
i=1
! switch on update type
select case (update_)
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,update_,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999
end select
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)
@ -316,16 +283,16 @@ subroutine psb_zovrlv(x,desc_a,info,work,update,mode)
integer, intent(in), optional :: update,mode integer, intent(in), optional :: update,mode
! locals ! locals
integer :: int_err(5), ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, update_,& & err_act, m, n, iix, jjx, ix, ijx, nrow, ncol, k, update_,&
& mode_, err, liwork, i & mode_, err, liwork
complex(kind(1.d0)),pointer :: iwork(:) complex(kind(1.d0)),pointer :: iwork(:)
logical :: do_swap logical :: do_swap
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw logical :: aliw
name='psb_zovrlv' name='psb_zovrlv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -364,86 +331,54 @@ subroutine psb_zovrlv(x,desc_a,info,work,update,mode)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
err=info err=info
call psb_errcomm(ictxt,err) call psb_errcomm(ictxt,err)
if(err.ne.0) goto 9999 if(err /= 0) goto 9999
! check for presence/size of a work area ! check for presence/size of a work area
liwork=ncol liwork=ncol
if (present(work)) then if (present(work)) then
if(size(work).ge.liwork) then if(size(work) >= liwork) then
iwork => work
aliw=.false. aliw=.false.
else else
aliw=.true. aliw=.true.
allocate(iwork(liwork),stat=info)
if(info.ne.0) then
info=4010
ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
end if end if
else else
aliw=.true. aliw=.true.
end if
if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' call psb_errpush(info,name,a_err='Allocate')
call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
else
iwork => work
end if end if
! exchange overlap elements ! exchange overlap elements
if(do_swap) then if (do_swap) then
call psi_swapdata(mode_,zone,x(iix:size(x)),& call psi_swapdata(mode_,zone,x(:),&
& desc_a,iwork,info,data=psb_comm_ovr_) & desc_a,iwork,info,data=psb_comm_ovr_)
end if end if
if (info == 0) call psi_ovrl_upd(x,desc_a,update_,info)
if(info.ne.0) then if (info /= 0) then
call psb_errpush(4010,name,a_err='PSI_SwapData') call psb_errpush(4010,name,a_err='Inner updates')
goto 9999 goto 9999
end if end if
i=1
! switch on update type
select case (update_)
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,update_,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999
end select
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)

@ -89,7 +89,7 @@ subroutine psb_zscatterm(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
@ -320,7 +320,7 @@ subroutine psb_zscatterv(globx, locx, desc_a, info, iroot)
if (present(iroot)) then if (present(iroot)) then
root = iroot root = iroot
if((root.lt.-1).or.(root.gt.np)) then if((root < -1).or.(root > np)) then
info=30 info=30
int_err(1:2)=(/5,root/) int_err(1:2)=(/5,root/)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)

@ -1,8 +1,7 @@
include ../../Make.inc include ../../Make.inc
FOBJS = psi_compute_size.o psi_crea_bnd_elem.o psi_crea_index.o \ FOBJS = psi_compute_size.o psi_crea_bnd_elem.o psi_crea_index.o \
psi_crea_ovr_elem.o psi_dl_check.o \ psi_crea_ovr_elem.o psi_bld_tmpovrl.o psi_dl_check.o \
psi_gthsct_mod.o \
psi_sort_dl.o \ psi_sort_dl.o \
psi_ldsc_pre_halo.o psi_bld_tmphalo.o psi_bld_hash.o\ psi_ldsc_pre_halo.o psi_bld_tmphalo.o psi_bld_hash.o\
psi_sort_dl.o psi_idx_cnv.o psi_idx_ins_cnv.o psi_fnd_owner.o psi_sort_dl.o psi_idx_cnv.o psi_idx_ins_cnv.o psi_fnd_owner.o
@ -23,7 +22,7 @@ lib: mpfobjs $(FOBJS) $(FOBJS2) $(COBJS) $(MPFOBJS2)
$(RANLIB) $(LIBDIR)/$(LIBNAME) $(RANLIB) $(LIBDIR)/$(LIBNAME)
mpfobjs: psi_gthsct_mod.o mpfobjs:
(make $(MPFOBJS) F90="$(MPF90)" FC="$(MPF90)" FCOPT="$(F90COPT)") (make $(MPFOBJS) F90="$(MPF90)" FC="$(MPF90)" FCOPT="$(F90COPT)")
(make $(FOBJS2) F90="$(MPF77)" FC="$(MPF77)" FCOPT="$(FCOPT)") (make $(FOBJS2) F90="$(MPF77)" FC="$(MPF77)" FCOPT="$(FCOPT)")
clean: clean:

@ -133,7 +133,7 @@ subroutine psi_bld_hash(desc,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -137,7 +137,7 @@ subroutine psi_bld_tmphalo(desc,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -0,0 +1,156 @@
!!$
!!$ Parallel Sparse BLAS v2.0
!!$ (C) Copyright 2006 Salvatore Filippone University of Rome Tor Vergata
!!$ Alfredo Buttari University of Rome Tor Vergata
!!$
!!$ Redistribution and use in source and binary forms, with or without
!!$ modification, are permitted provided that the following conditions
!!$ are met:
!!$ 1. Redistributions of source code must retain the above copyright
!!$ notice, this list of conditions and the following disclaimer.
!!$ 2. Redistributions in binary form must reproduce the above copyright
!!$ notice, this list of conditions, and the following disclaimer in the
!!$ documentation and/or other materials provided with the distribution.
!!$ 3. The name of the PSBLAS group or the names of its contributors may
!!$ not be used to endorse or promote products derived from this
!!$ software without specific written permission.
!!$
!!$ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
!!$ ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
!!$ TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
!!$ PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE PSBLAS GROUP OR ITS CONTRIBUTORS
!!$ BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
!!$ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
!!$ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
!!$ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
!!$ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
!!$ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
!!$ POSSIBILITY OF SUCH DAMAGE.
!!$
!!$
!
! File: psi_bld_tmpovrl.f90
!
! Subroutine: psi_bld_tmpovrl
! Build initial versions of overlap exchange lists.
! When the descriptor is for a large index space, we cannot build
! the data exchange lists "on-the-fly", but we also want to keep using the
! same format conversion routines we use in the small index space case,
! hence this adapter routine.
!
!
! Arguments:
! iv(:) - integer Initial list.
! index
! nprocs (sharing it)
! procs(1:nprocs)
! End marked with -1
!
! desc - type(psb_desc_type). The communication descriptor.
! info - integer. return code.
!
subroutine psi_bld_tmpovrl(iv,desc,info)
use psb_descriptor_type
use psb_serial_mod
use psb_const_mod
use psb_error_mod
use psb_penv_mod
use psb_realloc_mod
use psi_mod, psb_protect_name => psi_bld_tmpovrl
implicit none
integer, intent(in) :: iv(:)
type(psb_desc_type), intent(inout) :: desc
integer, intent(out) :: info
!locals
Integer :: counter,i,j,np,me,loc_row,err,loc_col,nprocs,&
& l_ov_ix,l_ov_el,idx, err_act, itmpov, k, glx, icomm
integer, allocatable :: ov_idx(:),ov_el(:,:)
integer :: ictxt,n_row, debug_unit, debug_level
character(len=20) :: name,ch_err
info = 0
name = 'psi_bld_tmpovrl'
call psb_erractionsave(err_act)
debug_unit = psb_get_debug_unit()
debug_level = psb_get_debug_level()
ictxt = psb_cd_get_context(desc)
icomm = psb_cd_get_mpic(desc)
! check on blacs grid
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
l_ov_ix=0
l_ov_el=0
i = 1
do while (iv(i) /= -1)
idx = iv(i)
i = i + 1
nprocs = iv(i)
i = i + 1
l_ov_ix = l_ov_ix+3*(nprocs-1)
l_ov_el = l_ov_el + 1
i = i + nprocs
enddo
l_ov_ix = l_ov_ix+3
if (debug_level >= psb_debug_inner_) &
& write(debug_unit,*) me,' ',trim(name),': Ov len',l_ov_ix,l_ov_el
allocate(ov_idx(l_ov_ix),ov_el(l_ov_el,3), stat=info)
if (info /= psb_no_err_) then
info=4010
err=info
call psb_errpush(err,name,a_err='psb_realloc')
goto 9999
end if
l_ov_ix=0
l_ov_el=0
i = 1
do while (iv(i) /= -1)
idx = iv(i)
i = i+1
nprocs = iv(i)
l_ov_el = l_ov_el+1
ov_el(l_ov_el,1) = idx ! Index
ov_el(l_ov_el,2) = nprocs ! How many procs
ov_el(l_ov_el,3) = minval(iv(i+1:i+nprocs)) ! master proc
do j=1, nprocs
if (iv(i+j) /= me) then
ov_idx(l_ov_ix+1) = iv(i+j)
ov_idx(l_ov_ix+2) = 1
ov_idx(l_ov_ix+3) = idx
l_ov_ix = l_ov_ix+3
endif
enddo
i = i + nprocs + 1
enddo
l_ov_ix = l_ov_ix + 1
ov_idx(l_ov_ix) = -1
call psb_transfer(ov_idx,desc%ovrlap_index,info)
if (info == 0) call psb_transfer(ov_el,desc%ovrlap_elem,info)
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_ret_) then
return
else
call psb_error(ictxt)
end if
return
end subroutine psi_bld_tmpovrl

@ -84,9 +84,9 @@ subroutine psi_compute_size(desc_data, index_in, dl_lda, info)
! ....verify local correctness of halo_in.... ! ....verify local correctness of halo_in....
i=1 i=1
do while (index_in(i).ne.-1) do while (index_in(i) /= -1)
proc=index_in(i) proc=index_in(i)
if ((proc.gt.np-1).or.(proc.lt.0)) then if ((proc > np-1).or.(proc < 0)) then
info = 115 info = 115
int_err(1) = 11 int_err(1) = 11
int_err(2) = proc int_err(2) = proc
@ -108,8 +108,8 @@ subroutine psi_compute_size(desc_data, index_in, dl_lda, info)
dl_lda=0 dl_lda=0
do i=0,np-1 do i=0,np-1
if (counter_recv(i).gt.max_index) max_index = counter_recv(i) if (counter_recv(i) > max_index) max_index = counter_recv(i)
if (counter_dl(i).eq.1) dl_lda = dl_lda+1 if (counter_dl(i) == 1) dl_lda = dl_lda+1
enddo enddo
! computing max global value of dl_lda ! computing max global value of dl_lda

@ -113,7 +113,7 @@ subroutine psi_crea_bnd_elem(bndel,desc_a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -41,7 +41,7 @@
! desc_a - type(psb_desc_type). The communication descriptor. ! desc_a - type(psb_desc_type). The communication descriptor.
! info - integer. return code. ! info - integer. return code.
! !
subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info) subroutine psi_crea_ovr_elem(me,desc_overlap,ovr_elem,info)
use psi_mod, psb_protect_name => psi_crea_ovr_elem use psi_mod, psb_protect_name => psi_crea_ovr_elem
use psb_realloc_mod use psb_realloc_mod
@ -51,8 +51,8 @@ subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info)
implicit none implicit none
! ...parameter arrays.... ! ...parameter arrays....
integer :: desc_overlap(:) integer, intent(in) :: me, desc_overlap(:)
integer, allocatable, intent(inout) :: ovr_elem(:) integer, allocatable, intent(out) :: ovr_elem(:,:)
integer, intent(out) :: info integer, intent(out) :: info
! ...local scalars... ! ...local scalars...
@ -64,10 +64,9 @@ subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info)
integer :: psi_exist_ovr_elem integer :: psi_exist_ovr_elem
external :: psi_exist_ovr_elem external :: psi_exist_ovr_elem
integer :: nel, ip, ix, iel, insize, err_act integer :: nel, ip, ix, iel, insize, err_act, iproc
integer, allocatable :: telem(:,:) integer, allocatable :: telem(:,:)
logical, parameter :: usetree=.false.
character(len=20) :: name character(len=20) :: name
@ -76,84 +75,15 @@ subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info)
if (allocated(ovr_elem)) then if (allocated(ovr_elem)) then
dim_ovr_elem = size(ovr_elem) dim_ovr_elem = size(ovr_elem,1)
else else
dim_ovr_elem = 0 dim_ovr_elem = 0
endif endif
if (usetree) then
!
! This is now here just for historical reasons.
!
! While running through the column indices exchanged with other procs
! we have to record them in overlap_elem. We do this by maintaining
! an AVL balanced search tree: at each point counter_e is the next
! free index element. The search routine for gidx will return
! glx if gidx was already assigned a local index (glx<counter_e)
! but if gidx was a new index for this process, then it creates
! a new pair (gidx,counter_e), and glx==counter_e. In this case we
! need to record this for the overlap exchange. Otherwise it was
! already there, so we need to record one more parnter in the exchange
!
i=1
pnt_new_elem=1
call initpairsearchtree(pairtree,info)
do while (desc_overlap(i).ne.-1)
! ...loop over all procs of desc_overlap list....
i=i+1
do j=1,desc_overlap(i)
! ....loop over all overlap indices referred to act proc.....
call searchinskeyval(pairtree,desc_overlap(i+j),pnt_new_elem,&
& ret,info)
if (ret == pnt_new_elem) ret=-1
if (ret.eq.-1) then
! ...this point not exist in ovr_elem list:
! add to it.............................
! ...check if overflow element_d array......
if ((pnt_new_elem +2) > dim_ovr_elem) then
dim_ovr_elem=max(((3*dim_ovr_elem)/2+2),pnt_new_elem+100)
call psb_realloc(dim_ovr_elem,ovr_elem,info)
if (info /= 0) then
info = 4000
call psb_errpush(info,name)
goto 9999
end if
endif
ovr_elem(pnt_new_elem)=desc_overlap(i+j)
ovr_elem(pnt_new_elem+1)=2
pnt_new_elem=pnt_new_elem+2
else
! ....this point already exist in ovr_elem list
! its position is ret............................
ovr_elem(ret+1)=ovr_elem(ret+1)+1
endif
enddo
i=i+2*desc_overlap(i)+2
enddo
! Add -1 at the end of output list.
! And fix the size to the minimum necessary.
dim_ovr_elem=pnt_new_elem
call psb_realloc(dim_ovr_elem,ovr_elem,info)
if (info /= 0) then
info = 4000
call psb_errpush(info,name)
goto 9999
end if
ovr_elem(pnt_new_elem)=-1
call freepairsearchtree(pairtree)
else if (.not.usetree) then
! Simple alternative.
insize = size(desc_overlap) insize = size(desc_overlap)
insize = max(1,(insize+1)/2) insize = max(1,(insize+1)/2)
allocate(telem(insize,2),stat=info) allocate(telem(insize,3),stat=info)
if (info /= 0) then if (info /= 0) then
info = 4000 info = 4000
call psb_errpush(info,name) call psb_errpush(info,name)
@ -161,48 +91,50 @@ subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info)
endif endif
i = 1 i = 1
nel = 0 nel = 0
do while (desc_overlap(i).ne.-1) do while (desc_overlap(i) /= -1)
! ...loop over all procs of desc_overlap list.... ! ...loop over all procs of desc_overlap list....
iproc = desc_overlap(i)
i=i+1 i = i+1
do j=1,desc_overlap(i) do j=1,desc_overlap(i)
nel = nel + 1 nel = nel + 1
telem(nel,1) = desc_overlap(i+j) telem(nel,1) = desc_overlap(i+j)
telem(nel,2) = 1
telem(nel,3) = iproc
enddo enddo
i=i+2*desc_overlap(i)+2 i=i+2*desc_overlap(i)+2
enddo enddo
if (nel > 0) then if (nel > 0) then
call psb_msort(telem(1:nel,1)) call psb_msort(telem(1:nel,1),ix=telem(1:nel,3),flag=psb_sort_keep_idx_)
iel = telem(1,1) iel = telem(1,1)
telem(1,2) = 2 telem(1,2) = 2
telem(1,3) = min(me,telem(1,3))
ix = 1 ix = 1
ip = 2 ip = 2
do do
if (ip > nel) exit if (ip > nel) exit
if (telem(ip,1) == iel) then if (telem(ip,1) == iel) then
telem(ix,2) = telem(ix,2) + 1 telem(ix,2) = telem(ix,2) + 1
telem(ix,3) = min(telem(ix,3),telem(ip,3))
else else
ix = ix + 1 ix = ix + 1
telem(ix,1) = telem(ip,1) telem(ix,1) = telem(ip,1)
iel = telem(ip,1) iel = telem(ip,1)
telem(ix,2) = 2 telem(ix,2) = 2
telem(ix,3) = min(me,telem(ip,3))
end if end if
ip = ip + 1 ip = ip + 1
end do end do
else else
ix = 0 ix = 0
end if end if
dim_ovr_elem=2*ix+1
call psb_realloc(dim_ovr_elem,ovr_elem,info) nel = ix
iel = 1
do i=1, ix call psb_realloc(nel,3,telem,info)
ovr_elem(iel) = telem(i,1) call psb_transfer(telem,ovr_elem,info)
ovr_elem(iel+1) = telem(i,2)
iel = iel + 2
end do
ovr_elem(iel) = -1
deallocate(telem)
endif
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -330,7 +330,7 @@ subroutine psi_desc_index(desc,index_in,dep_list,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -65,7 +65,7 @@ subroutine psi_dl_check(dep_list,dl_lda,np,length_dl)
outer: do outer: do
if (i >length_dl(proc)) exit outer if (i >length_dl(proc)) exit outer
proc2=dep_list(i,proc) proc2=dep_list(i,proc)
if (proc2.ne.-1) then if (proc2 /= -1) then
! ...search proc in proc2's dep_list.... ! ...search proc in proc2's dep_list....
j=1 j=1
p2loop:do p2loop:do

@ -86,7 +86,7 @@ subroutine psi_dswapdatam(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -559,7 +559,7 @@ subroutine psi_dswapdatav(flag,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -89,7 +89,7 @@ subroutine psi_dswaptranm(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -557,7 +557,7 @@ subroutine psi_dswaptranv(flag,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -52,7 +52,7 @@ C ELEM_SEARCHED.....:point's Local index identifier to be searched.
IMPLICIT NONE IMPLICIT NONE
C ...Array Parameters.... C ...Array Parameters....
INTEGER OVR_ELEM(*) INTEGER OVR_ELEM(dim_list,*)
C ....Scalars parameters.... C ....Scalars parameters....
INTEGER DIM_LIST,ELEM_SEARCHED INTEGER DIM_LIST,ELEM_SEARCHED
@ -61,10 +61,10 @@ C ...Local Scalars....
INTEGER I INTEGER I
I=1 I=1
DO WHILE ((I.LE.DIM_LIST).AND.(OVR_ELEM(I).NE.ELEM_SEARCHED)) DO WHILE ((I.LE.DIM_LIST).AND.(OVR_ELEM(I,1).NE.ELEM_SEARCHED))
I=I+2 I=I+1
ENDDO ENDDO
IF ((I.LE.DIM_LIST).AND.(OVR_ELEM(I).EQ.ELEM_SEARCHED)) THEN IF ((I.LE.DIM_LIST).AND.(OVR_ELEM(I,1).EQ.ELEM_SEARCHED)) THEN
PSI_EXIST_OVR_ELEM=I PSI_EXIST_OVR_ELEM=I
ELSE ELSE
PSI_EXIST_OVR_ELEM=-1 PSI_EXIST_OVR_ELEM=-1

@ -172,7 +172,7 @@ subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,&
if ((desc_str(i+1) /= 0).or.(desc_str(i+2) /= 0)) then if ((desc_str(i+1) /= 0).or.(desc_str(i+2) /= 0)) then
! ..if number of element to be exchanged !=0 ! ..if number of element to be exchanged !=0
proc=desc_str(i) proc=desc_str(i)
if ((proc < 0).or.(proc.ge.nprow)) then if ((proc < 0).or.(proc >= nprow)) then
if (debug_level >= psb_debug_inner_)& if (debug_level >= psb_debug_inner_)&
& write(debug_unit,*) me,' ',trim(name),': error ',i,desc_str(i) & write(debug_unit,*) me,' ',trim(name),': error ',i,desc_str(i)
info = 9999 info = 9999
@ -196,7 +196,7 @@ subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,&
pointer_dep_list=pointer_dep_list+1 pointer_dep_list=pointer_dep_list+1
endif endif
else if (mode == 0) then else if (mode == 0) then
if (pointer_dep_list.gt.dl_lda) then if (pointer_dep_list > dl_lda) then
info = 4000 info = 4000
goto 998 goto 998
endif endif
@ -227,7 +227,7 @@ subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,&
enddo enddo
if (j == pointer_dep_list) then if (j == pointer_dep_list) then
! ...if not found..... ! ...if not found.....
if (pointer_dep_list.gt.dl_lda) then if (pointer_dep_list > dl_lda) then
info = 4000 info = 4000
goto 998 goto 998
endif endif
@ -235,7 +235,7 @@ subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,&
pointer_dep_list=pointer_dep_list+1 pointer_dep_list=pointer_dep_list+1
endif endif
else if (mode == 0) then else if (mode == 0) then
if (pointer_dep_list.gt.dl_lda) then if (pointer_dep_list > dl_lda) then
info = 4000 info = 4000
goto 998 goto 998
endif endif

@ -158,7 +158,7 @@ subroutine psi_fnd_owner(nv,idx,iprc,desc,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -1,369 +0,0 @@
!!$
!!$ Parallel Sparse BLAS v2.0
!!$ (C) Copyright 2006 Salvatore Filippone University of Rome Tor Vergata
!!$ Alfredo Buttari University of Rome Tor Vergata
!!$
!!$ Redistribution and use in source and binary forms, with or without
!!$ modification, are permitted provided that the following conditions
!!$ are met:
!!$ 1. Redistributions of source code must retain the above copyright
!!$ notice, this list of conditions and the following disclaimer.
!!$ 2. Redistributions in binary form must reproduce the above copyright
!!$ notice, this list of conditions, and the following disclaimer in the
!!$ documentation and/or other materials provided with the distribution.
!!$ 3. The name of the PSBLAS group or the names of its contributors may
!!$ not be used to endorse or promote products derived from this
!!$ software without specific written permission.
!!$
!!$ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
!!$ ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
!!$ TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
!!$ PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE PSBLAS GROUP OR ITS CONTRIBUTORS
!!$ BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
!!$ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
!!$ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
!!$ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
!!$ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
!!$ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
!!$ POSSIBILITY OF SUCH DAMAGE.
!!$
!!$
! File: psi_gthsct_mod.f90
!
! Module: psi_gth_scr_mod
! Provides pack/unpack routines for usage in the data exchange.
! The unpack routines take a BETA argument to have a unified treatment of
! simple receives with overwriting, and receives with sum (for overlap)
!
!
module psi_gthsct_mod
interface psi_gth
module procedure psi_igthm, psi_igthv,&
& psi_dgthm, psi_dgthv,&
& psi_zgthm, psi_zgthv
end interface
interface psi_sct
module procedure psi_isctm, psi_isctv,&
& psi_dsctm, psi_dsctv,&
& psi_zsctm, psi_zsctv
end interface
contains
subroutine psi_dgthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
real(kind(1.d0)) :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_dgthm
subroutine psi_dgthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
real(kind(1.d0)) :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_dgthv
subroutine psi_dsctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
real(kind(1.d0)) :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == dzero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == done) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_dsctm
subroutine psi_dsctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
real(kind(1.d0)) :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == dzero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == done) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_dsctv
subroutine psi_igthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
integer :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_igthm
subroutine psi_igthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
integer :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_igthv
subroutine psi_isctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
integer :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == izero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == ione) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_isctm
subroutine psi_isctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
integer :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == izero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == ione) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_isctv
subroutine psi_zgthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
complex(kind(1.d0)) :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_zgthm
subroutine psi_zgthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
complex(kind(1.d0)) :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_zgthv
subroutine psi_zsctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
complex(kind(1.d0)) :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == zzero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == zone) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_zsctm
subroutine psi_zsctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
complex(kind(1.d0)) :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == zzero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == zone) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_zsctv
end module psi_gthsct_mod

@ -143,7 +143,7 @@ subroutine psi_idx_cnv1(nv,idxin,desc,info,mask,owned)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)
@ -362,7 +362,7 @@ subroutine psi_idx_cnv2(nv,idxin,idxout,desc,info,mask,owned)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -139,7 +139,7 @@ subroutine psi_idx_ins_cnv1(nv,idxin,desc,info,mask)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)
@ -332,7 +332,7 @@ subroutine psi_idx_ins_cnv2(nv,idxin,idxout,desc,info,mask)
cycle cycle
endif endif
k = desc%glob_to_loc(ip) k = desc%glob_to_loc(ip)
if (k.lt.-np) then if (k < -np) then
k = k + np k = k + np
k = - k - 1 k = - k - 1
ncol = ncol + 1 ncol = ncol + 1
@ -352,7 +352,7 @@ subroutine psi_idx_ins_cnv2(nv,idxin,idxout,desc,info,mask)
endif endif
desc%loc_to_glob(ncol) = ip desc%loc_to_glob(ncol) = ip
isize = size(desc%halo_index) isize = size(desc%halo_index)
if ((pnt_halo+3).gt.isize) then if ((pnt_halo+3) > isize) then
nh = isize + max(nv,relocsz) nh = isize + max(nv,relocsz)
call psb_realloc(nh,desc%halo_index,info,pad=-1) call psb_realloc(nh,desc%halo_index,info,pad=-1)
if (info /= 0) then if (info /= 0) then
@ -390,7 +390,7 @@ subroutine psi_idx_ins_cnv2(nv,idxin,idxout,desc,info,mask)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -85,7 +85,7 @@ subroutine psi_iswapdatam(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -558,7 +558,7 @@ subroutine psi_iswapdatav(flag,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -89,7 +89,7 @@ subroutine psi_iswaptranm(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -556,7 +556,7 @@ subroutine psi_iswaptranv(flag,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -107,7 +107,7 @@ subroutine psi_ldsc_pre_halo(desc,ext_hv,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error(ictxt) call psb_error(ictxt)

@ -85,7 +85,7 @@ subroutine psi_zswapdatam(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -558,7 +558,7 @@ subroutine psi_zswapdatav(flag,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -89,7 +89,7 @@ subroutine psi_zswaptranm(flag,n,beta,y,desc_a,work,info,data)
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif
@ -553,10 +553,11 @@ end subroutine psi_zswaptranm
! !
subroutine psi_zswaptranv(flag,beta,y,desc_a,work,info,data) subroutine psi_zswaptranv(flag,beta,y,desc_a,work,info,data)
use psi_mod, psb_protect_name => psi_zswaptranv
use psb_error_mod use psb_error_mod
use psb_descriptor_type use psb_descriptor_type
use psb_penv_mod use psb_penv_mod
use psi_gthsct_mod !!$ use psi_gthsct_mod
#ifdef MPI_MOD #ifdef MPI_MOD
use mpi use mpi
#endif #endif

@ -47,6 +47,22 @@ module psb_comm_mod
real(kind(1.d0)), intent(inout), optional :: work(:) real(kind(1.d0)), intent(inout), optional :: work(:)
integer, intent(in), optional :: update,mode integer, intent(in), optional :: update,mode
end subroutine psb_dovrlv end subroutine psb_dovrlv
subroutine psb_iovrlm(x,desc_a,info,jx,ik,work,update,mode)
use psb_descriptor_type
integer, intent(inout) :: x(:,:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(out) :: info
real(kind(1.d0)), intent(inout), optional :: work(:)
integer, intent(in), optional :: update,jx,ik,mode
end subroutine psb_iovrlm
subroutine psb_iovrlv(x,desc_a,info,work,update,mode)
use psb_descriptor_type
integer, intent(inout) :: x(:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(out) :: info
real(kind(1.d0)), intent(inout), optional :: work(:)
integer, intent(in), optional :: update,mode
end subroutine psb_iovrlv
subroutine psb_zovrlm(x,desc_a,info,jx,ik,work,update,mode) subroutine psb_zovrlm(x,desc_a,info,jx,ik,work,update,mode)
use psb_descriptor_type use psb_descriptor_type
complex(kind(1.d0)), intent(inout) :: x(:,:) complex(kind(1.d0)), intent(inout) :: x(:,:)

@ -266,7 +266,7 @@ module psb_descriptor_type
integer, allocatable :: halo_index(:), ext_index(:) integer, allocatable :: halo_index(:), ext_index(:)
integer, allocatable :: bnd_elem(:) integer, allocatable :: bnd_elem(:)
integer, allocatable :: ovrlap_index(:) integer, allocatable :: ovrlap_index(:)
integer, allocatable :: ovrlap_elem(:) integer, allocatable :: ovrlap_elem(:,:)
integer, allocatable :: loc_to_glob(:) integer, allocatable :: loc_to_glob(:)
integer, allocatable :: glob_to_loc (:) integer, allocatable :: glob_to_loc (:)
integer, allocatable :: hashv(:), glb_lc(:,:), ptree(:) integer, allocatable :: hashv(:), glb_lc(:,:), ptree(:)

@ -222,7 +222,7 @@ contains
new_node%next => error_stack%top new_node%next => error_stack%top
error_stack%top => new_node error_stack%top => new_node
error_stack%n_elems = error_stack%n_elems+1 error_stack%n_elems = error_stack%n_elems+1
if(error_status.eq.0) error_status=1 if(error_status == 0) error_status=1
nullify(new_node) nullify(new_node)
end subroutine psb_errpush end subroutine psb_errpush
@ -246,7 +246,7 @@ contains
old_node => error_stack%top old_node => error_stack%top
error_stack%top => old_node%next error_stack%top => old_node%next
error_stack%n_elems = error_stack%n_elems - 1 error_stack%n_elems = error_stack%n_elems - 1
if(error_stack%n_elems.eq.0) error_status=0 if(error_stack%n_elems == 0) error_status=0
deallocate(old_node) deallocate(old_node)
@ -266,10 +266,10 @@ contains
integer, parameter :: ione=1, izero=0 integer, parameter :: ione=1, izero=0
if(error_status.gt.0) then if(error_status > 0) then
if(verbosity_level.gt.1) then if(verbosity_level > 1) then
do while (error_stack%n_elems.gt.izero) do while (error_stack%n_elems > izero)
write(0,'(50("="))') write(0,'(50("="))')
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
call psb_errmsg(err_c, r_name, i_e_d, a_e_d,me) call psb_errmsg(err_c, r_name, i_e_d, a_e_d,me)
@ -284,7 +284,7 @@ contains
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
call psb_errmsg(err_c, r_name, i_e_d, a_e_d,me) call psb_errmsg(err_c, r_name, i_e_d, a_e_d,me)
do while (error_stack%n_elems.gt.0) do while (error_stack%n_elems > 0)
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
end do end do
#if defined(SERIAL_MPI) #if defined(SERIAL_MPI)
@ -295,7 +295,7 @@ contains
end if end if
end if end if
if(error_status.gt.izero) then if(error_status > izero) then
#if defined(SERIAL_MPI) #if defined(SERIAL_MPI)
stop stop
#else #else
@ -316,10 +316,10 @@ contains
integer :: i_e_d(5) integer :: i_e_d(5)
integer, parameter :: ione=1, izero=0 integer, parameter :: ione=1, izero=0
if(error_status.gt.0) then if(error_status > 0) then
if(verbosity_level.gt.1) then if(verbosity_level > 1) then
do while (error_stack%n_elems.gt.izero) do while (error_stack%n_elems > izero)
write(0,'(50("="))') write(0,'(50("="))')
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
call psb_errmsg(err_c, r_name, i_e_d, a_e_d) call psb_errmsg(err_c, r_name, i_e_d, a_e_d)
@ -330,7 +330,7 @@ contains
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
call psb_errmsg(err_c, r_name, i_e_d, a_e_d) call psb_errmsg(err_c, r_name, i_e_d, a_e_d)
do while (error_stack%n_elems.gt.0) do while (error_stack%n_elems > 0)
call psb_errpop(err_c, r_name, i_e_d, a_e_d) call psb_errpop(err_c, r_name, i_e_d, a_e_d)
end do end do
end if end if

@ -62,11 +62,11 @@ CONTAINS
! INDICES OF THE NONZERO ELEMENTS OF THE MATRIX, A. THE ALGO- ! INDICES OF THE NONZERO ELEMENTS OF THE MATRIX, A. THE ALGO-
! RITHM IS DESCRIBED IN TERMS OF THE ADJACENCY GRAPH WHICH ! RITHM IS DESCRIBED IN TERMS OF THE ADJACENCY GRAPH WHICH
! HAS THE CHARACTERISTIC THAT THERE IS AN EDGE (CONNECTION) ! HAS THE CHARACTERISTIC THAT THERE IS AN EDGE (CONNECTION)
! BETWEEN NODES I AND J IF A(I,J) .NE. 0 AND I .NE. J. ! BETWEEN NODES I AND J IF A(I,J) /= 0 AND I /= J.
! DIMENSIONING INFORMATION--THE FOLLOWING INTEGER ARRAYS MUST BE ! DIMENSIONING INFORMATION--THE FOLLOWING INTEGER ARRAYS MUST BE
! DIMENSIONED IN THE CALLING ROUTINE. ! DIMENSIONED IN THE CALLING ROUTINE.
! NDSTK(NR,D1) D1 IS .GE. MAXIMUM DEGREE OF ALL NODES. ! NDSTK(NR,D1) D1 IS >= MAXIMUM DEGREE OF ALL NODES.
! IOLD(D2) D2 AND NR ARE .GE. THE TOTAL NUMBER OF ! IOLD(D2) D2 AND NR ARE >= THE TOTAL NUMBER OF
! RENUM(D2+1) NODES IN THE GRAPH. ! RENUM(D2+1) NODES IN THE GRAPH.
! NDEG(D2) STORAGE REQUIREMENTS CAN BE SIGNIFICANTLY ! NDEG(D2) STORAGE REQUIREMENTS CAN BE SIGNIFICANTLY
! LVL(D2) DECREASED FOR IBM 360 AND 370 COMPUTERS ! LVL(D2) DECREASED FOR IBM 360 AND 370 COMPUTERS
@ -146,7 +146,7 @@ CONTAINS
STNUM = N STNUM = N
! NUMBER THE NODES OF DEGREE ZERO ! NUMBER THE NODES OF DEGREE ZERO
DO I=1,N DO I=1,N
IF (NDEG(I).GT.0) CYCLE IF (NDEG(I) > 0) CYCLE
RENUM(I) = STNUM RENUM(I) = STNUM
STNUM = STNUM - 1 STNUM = STNUM - 1
END DO END DO
@ -156,8 +156,8 @@ CONTAINS
NFLG = 1 NFLG = 1
ISDIR = 1 ISDIR = 1
DO I=1,N DO I=1,N
IF (NDEG(I).GE.LOWDG) CYCLE IF (NDEG(I) >= LOWDG) CYCLE
IF (RENUM(I).GT.0) CYCLE IF (RENUM(I) > 0) CYCLE
LOWDG = NDEG(I) LOWDG = NDEG(I)
STNODE = I STNODE = I
END DO END DO
@ -165,7 +165,7 @@ CONTAINS
! STNODE AND RVNODE ARE THE ENDS OF THE DIAM AND LVLS1 AND LVLS2 ! STNODE AND RVNODE ARE THE ENDS OF THE DIAM AND LVLS1 AND LVLS2
! ARE THE RESPECTIVE LEVEL STRUCTURES. ! ARE THE RESPECTIVE LEVEL STRUCTURES.
CALL FNDIAM(STNODE, RVNODE, NDSTK, NR, NDEG, LVL, LVLS1,LVLS2, CCSTOR, IDFLT) CALL FNDIAM(STNODE, RVNODE, NDSTK, NR, NDEG, LVL, LVLS1,LVLS2, CCSTOR, IDFLT)
IF (.not.(ndeg(stnode).le.ndeg(rvnode))) then IF (.not.(ndeg(stnode) <= ndeg(rvnode))) then
! NFLG INDICATES THE END TO BEGIN NUMBERING ON ! NFLG INDICATES THE END TO BEGIN NUMBERING ON
NFLG = -1 NFLG = -1
STNODE = RVNODE STNODE = RVNODE
@ -176,7 +176,7 @@ CONTAINS
LROOT = 1 LROOT = 1
LVLN = 1 LVLN = 1
DO I=1,N DO I=1,N
IF (LVL(I).NE.0) CYCLE IF (LVL(I) /= 0) CYCLE
XCC = XCC + 1 XCC = XCC + 1
STPT(XCC) = LROOT STPT(XCC) = LROOT
CALL TREE(I, NDSTK, NR, LVL, CCSTOR, NDEG, LVLWTH, LVLBOT,LVLN, MAXLW, N) CALL TREE(I, NDSTK, NR, LVL, CCSTOR, NDEG, LVLWTH, LVLBOT,LVLN, MAXLW, N)
@ -192,13 +192,13 @@ CONTAINS
! DIRECTION. NUM IS SET TO THE PROPER VALUE FOR THIS DIRECTION. ! DIRECTION. NUM IS SET TO THE PROPER VALUE FOR THIS DIRECTION.
ISDIR = ISDIR*NFLG ISDIR = ISDIR*NFLG
NUM = SBNUM NUM = SBNUM
IF (ISDIR.LT.0) NUM = STNUM IF (ISDIR < 0) NUM = STNUM
CALL NUMBER(STNODE, NUM, NDSTK, LVLS2, NDEG, RENUM, LVLS1,LVL,& CALL NUMBER(STNODE, NUM, NDSTK, LVLS2, NDEG, RENUM, LVLS1,LVL,&
& NR, NFLG, IBW2, IPF2, CCSTOR, ISDIR) & NR, NFLG, IBW2, IPF2, CCSTOR, ISDIR)
! UPDATE STNUM OR SBNUM AFTER NUMBERING ! UPDATE STNUM OR SBNUM AFTER NUMBERING
IF (ISDIR.LT.0) STNUM = NUM IF (ISDIR < 0) STNUM = NUM
IF (ISDIR.GT.0) SBNUM = NUM IF (ISDIR > 0) SBNUM = NUM
IF (.not.(sbnum.le.stnum)) exit IF (.not.(sbnum <= stnum)) exit
end do end do
IF (IBW2 > IBW1) then IF (IBW2 > IBW1) then
! IF ORIGINAL NUMBERING IS BETTER THAN NEW ONE, SET UP TO RETURN IT ! IF ORIGINAL NUMBERING IS BETTER THAN NEW ONE, SET UP TO RETURN IT
@ -233,10 +233,10 @@ CONTAINS
IF(ITST <= 0) EXIT IF(ITST <= 0) EXIT
NDEG(I) = NDEG(I) + 1 NDEG(I) = NDEG(I) + 1
IDIF = IOLD(I) - IOLD(ITST) IDIF = IOLD(I) - IOLD(ITST)
IF (IRW.LT.IDIF) IRW = IDIF IF (IRW < IDIF) IRW = IDIF
END DO END DO
IPF1 = IPF1 + IRW IPF1 = IPF1 + IRW
IF (IRW.GT.IBW1) IBW1 = IRW IF (IRW > IBW1) IBW1 = IRW
END DO END DO
RETURN RETURN
END SUBROUTINE DGREE END SUBROUTINE DGREE
@ -251,7 +251,7 @@ CONTAINS
! LVLS1- ARRAY CONTAINING LEVEL STRUCTURE WITH SND1 AS ROOT ! LVLS1- ARRAY CONTAINING LEVEL STRUCTURE WITH SND1 AS ROOT
! LVLS2- ARRAY CONTAINING LEVEL STRUCTURE WITH SND2 AS ROOT ! LVLS2- ARRAY CONTAINING LEVEL STRUCTURE WITH SND2 AS ROOT
! IDFLT- FLAG USED IN PICKING FINAL LEVEL STRUCTURE, SET ! IDFLT- FLAG USED IN PICKING FINAL LEVEL STRUCTURE, SET
! =1 IF WIDTH OF LVLS1 .LE. WIDTH OF LVLS2, OTHERWISE =2 ! =1 IF WIDTH OF LVLS1 <= WIDTH OF LVLS2, OTHERWISE =2
! LVL,IWK- WORKING STORAGE ! LVL,IWK- WORKING STORAGE
! USE INTEGER*2 NDSTK WITH AN IBM 360 OR 370. ! USE INTEGER*2 NDSTK WITH AN IBM 360 OR 370.
INTEGER NDSTK INTEGER NDSTK
@ -274,7 +274,7 @@ CONTAINS
LVLN = 1 LVLN = 1
! DROP A TREE FROM SND ! DROP A TREE FROM SND
CALL TREE(SND, NDSTK, NR, LVL, IWK, NDEG, LVLWTH, LVLBOT,LVLN, MAXLW, MTW2) CALL TREE(SND, NDSTK, NR, LVL, IWK, NDEG, LVLWTH, LVLBOT,LVLN, MAXLW, MTW2)
IF (FLAG.GE.1) GO TO 50 IF (FLAG >= 1) GO TO 50
FLAG = 1 FLAG = 1
30 IDPTH = LVLN - 1 30 IDPTH = LVLN - 1
MTW1 = MAXLW MTW1 = MAXLW
@ -289,24 +289,24 @@ CONTAINS
CALL SORTDG(NDLST, IWK(LVLBOT), NDXL, LVLWTH, NDEG) CALL SORTDG(NDLST, IWK(LVLBOT), NDXL, LVLWTH, NDEG)
SND = NDLST(1) SND = NDLST(1)
GO TO 10 GO TO 10
50 IF (IDPTH.GE.LVLN-1) GO TO 60 50 IF (IDPTH >= LVLN-1) GO TO 60
! START AGAIN WITH NEW STARTING NODE ! START AGAIN WITH NEW STARTING NODE
SND1 = SND SND1 = SND
GO TO 30 GO TO 30
60 IF (MAXLW.GE.MTW2) GO TO 80 60 IF (MAXLW >= MTW2) GO TO 80
MTW2 = MAXLW MTW2 = MAXLW
SND2 = SND SND2 = SND
! STORE NARROWEST REVERSE LEVEL STRUCTURE IN LVLS2 ! STORE NARROWEST REVERSE LEVEL STRUCTURE IN LVLS2
DO 70 I=1,N DO 70 I=1,N
LVLS2(I) = LVL(I) LVLS2(I) = LVL(I)
70 END DO 70 END DO
80 IF (NDXN.EQ.NDXL) GO TO 90 80 IF (NDXN == NDXL) GO TO 90
! TRY NEXT NODE IN NDLST ! TRY NEXT NODE IN NDLST
NDXN = NDXN + 1 NDXN = NDXN + 1
SND = NDLST(NDXN) SND = NDLST(NDXN)
GO TO 10 GO TO 10
90 IDFLT = 1 90 IDFLT = 1
IF (MTW2.LE.MTW1) IDFLT = 2 IF (MTW2 <= MTW1) IDFLT = 2
NULLIFY(NDLST) NULLIFY(NDLST)
RETURN RETURN
END SUBROUTINE FNDIAM END SUBROUTINE FNDIAM
@ -328,7 +328,7 @@ CONTAINS
! CONNECTED COMPONENTS, LVLN IS NEXT AVAILABLE LOCATION. ! CONNECTED COMPONENTS, LVLN IS NEXT AVAILABLE LOCATION.
! ON OUTPUT THE TOTAL NUMBER OF LEVELS + 1 ! ON OUTPUT THE TOTAL NUMBER OF LEVELS + 1
! IBORT- INPUT PARAM WHICH TRIGGERS EARLY RETURN IF ! IBORT- INPUT PARAM WHICH TRIGGERS EARLY RETURN IF
! MAXLW BECOMES .GE. IBORT ! MAXLW BECOMES >= IBORT
! USE INTEGER*2 NDSTK WITH AN IBM 360 OR 370. ! USE INTEGER*2 NDSTK WITH AN IBM 360 OR 370.
INTEGER NDSTK INTEGER NDSTK
DIMENSION NDSTK(NR,IDEG), LVL(N), IWK(N), NDEG(N) DIMENSION NDSTK(NR,IDEG), LVL(N), IWK(N), NDEG(N)
@ -345,17 +345,17 @@ CONTAINS
NDROW = NDEG(IWKNOW) NDROW = NDEG(IWKNOW)
DO 30 J=1,NDROW DO 30 J=1,NDROW
ITEST = NDSTK(IWKNOW,J) ITEST = NDSTK(IWKNOW,J)
IF (LVL(ITEST).NE.0) CYCLE IF (LVL(ITEST) /= 0) CYCLE
LVL(ITEST) = LVLN LVL(ITEST) = LVLN
ITOP = ITOP + 1 ITOP = ITOP + 1
IWK(ITOP) = ITEST IWK(ITOP) = ITEST
30 END DO 30 END DO
INOW = INOW + 1 INOW = INOW + 1
IF (INOW.LT.LVLTOP) GO TO 20 IF (INOW < LVLTOP) GO TO 20
LVLWTH = LVLTOP - LVLBOT LVLWTH = LVLTOP - LVLBOT
IF (MAXLW.LT.LVLWTH) MAXLW = LVLWTH IF (MAXLW < LVLWTH) MAXLW = LVLWTH
IF (MAXLW.GE.IBORT) RETURN IF (MAXLW >= IBORT) RETURN
IF (ITOP.LT.LVLTOP) RETURN IF (ITOP < LVLTOP) RETURN
LVLBOT = INOW LVLBOT = INOW
LVLTOP = ITOP + 1 LVLTOP = ITOP + 1
GO TO 10 GO TO 10
@ -371,18 +371,18 @@ CONTAINS
IND = X2 IND = X2
10 ITEST = 0 10 ITEST = 0
IND = IND - 1 IND = IND - 1
IF (IND.LT.1) GO TO 30 IF (IND < 1) GO TO 30
DO 20 I=1,IND DO 20 I=1,IND
J = I + 1 J = I + 1
ISTK2 = STK2(I) ISTK2 = STK2(I)
JSTK2 = STK2(J) JSTK2 = STK2(J)
IF (NDEG(ISTK2).LE.NDEG(JSTK2)) CYCLE IF (NDEG(ISTK2) <= NDEG(JSTK2)) CYCLE
ITEST = 1 ITEST = 1
TEMP = STK2(I) TEMP = STK2(I)
STK2(I) = STK2(J) STK2(I) = STK2(J)
STK2(J) = TEMP STK2(J) = TEMP
20 END DO 20 END DO
IF (ITEST.EQ.1) GO TO 10 IF (ITEST == 1) GO TO 10
30 DO 40 I=1,X2 30 DO 40 I=1,X2
X1 = X1 + 1 X1 = X1 + 1
STK1(X1) = STK2(I) STK1(X1) = STK2(I)
@ -403,7 +403,7 @@ CONTAINS
INTEGER :: SZ INTEGER :: SZ
!----------------------------------------------------- !-----------------------------------------------------
SZ=SIZE(NACUM) SZ=SIZE(NACUM)
IF(SZ .LT. IDPTH) THEN IF(SZ < IDPTH) THEN
WRITE(*,*) 'GPS_SETUP: on fly reallocation of NACUM' WRITE(*,*) 'GPS_SETUP: on fly reallocation of NACUM'
CALL REALLOC(NACUM,SZ,IDPTH) CALL REALLOC(NACUM,SZ,IDPTH)
END IF END IF
@ -415,8 +415,8 @@ CONTAINS
LVL(I) = 1 LVL(I) = 1
LVLS2(I) = IDPTH + 1 - LVLS2(I) LVLS2(I) = IDPTH + 1 - LVLS2(I)
ITEMP = LVLS2(I) ITEMP = LVLS2(I)
IF (ITEMP.GT.IDPTH) CYCLE IF (ITEMP > IDPTH) CYCLE
IF (ITEMP.NE.LVLS1(I)) GO TO 20 IF (ITEMP /= LVLS1(I)) GO TO 20
NACUM(ITEMP) = NACUM(ITEMP) + 1 NACUM(ITEMP) = NACUM(ITEMP) + 1
CYCLE CYCLE
20 LVL(I) = 0 20 LVL(I) = 0
@ -432,15 +432,15 @@ CONTAINS
!COMMON /CC/ XCC, SIZEG(50), STPT(50) !COMMON /CC/ XCC, SIZEG(50), STPT(50)
SORT2 = 0 SORT2 = 0
IF (XCC.EQ.0) RETURN IF (XCC == 0) RETURN
SORT2 = 1 SORT2 = 1
IND = XCC IND = XCC
10 ITEST = 0 10 ITEST = 0
IND = IND - 1 IND = IND - 1
IF (IND.LT.1) RETURN IF (IND < 1) RETURN
DO 20 I=1,IND DO 20 I=1,IND
J = I + 1 J = I + 1
IF (SIZEG(I).GE.SIZEG(J)) CYCLE IF (SIZEG(I) >= SIZEG(J)) CYCLE
ITEST = 1 ITEST = 1
TEMP = SIZEG(I) TEMP = SIZEG(I)
SIZEG(I) = SIZEG(J) SIZEG(I) = SIZEG(J)
@ -449,7 +449,7 @@ CONTAINS
STPT(I) = STPT(J) STPT(I) = STPT(J)
STPT(J) = TEMP STPT(J) = TEMP
20 END DO 20 END DO
IF (ITEST.EQ.1) GO TO 10 IF (ITEST == 1) GO TO 10
RETURN RETURN
END FUNCTION SORT2 END FUNCTION SORT2
! !
@ -459,7 +459,7 @@ CONTAINS
! LVLS2- ON INPUT CONTAINS REVERSE LEVELING INFO ! LVLS2- ON INPUT CONTAINS REVERSE LEVELING INFO
! ON OUTPUT THE FINAL LEVEL STRUCTURE CHOSEN ! ON OUTPUT THE FINAL LEVEL STRUCTURE CHOSEN
! CCSTOR- ON INPUT CONTAINS CONNECTED COMPONENT INFO ! CCSTOR- ON INPUT CONTAINS CONNECTED COMPONENT INFO
! IDFLT- ON INPUT =1 IF WDTH LVLS1.LE.WDTH LVLS2, =2 OTHERWISE ! IDFLT- ON INPUT =1 IF WDTH LVLS1 <= WDTH LVLS2, =2 OTHERWISE
! NHIGH KEEPS TRACK OF LEVEL WIDTHS FOR HIGH NUMBERING ! NHIGH KEEPS TRACK OF LEVEL WIDTHS FOR HIGH NUMBERING
! NLOW- KEEPS TRACK OF LEVEL WIDTHS FOR LOW NUMBERING ! NLOW- KEEPS TRACK OF LEVEL WIDTHS FOR LOW NUMBERING
! NACUM- KEEPS TRACK OF LEVEL WIDTHS FOR CHOSEN LEVEL STRUCTURE ! NACUM- KEEPS TRACK OF LEVEL WIDTHS FOR CHOSEN LEVEL STRUCTURE
@ -483,12 +483,12 @@ CONTAINS
! SET NHIGH AND NLOW EQUAL TO NACUM ! SET NHIGH AND NLOW EQUAL TO NACUM
!----------------------------------------------------- !-----------------------------------------------------
SZ=SIZE(NHIGH) SZ=SIZE(NHIGH)
IF(SZ .LT. IDPTH) THEN IF(SZ < IDPTH) THEN
WRITE(*,*) 'GPS_PIKLVL: on fly reallocation of NHIGH' WRITE(*,*) 'GPS_PIKLVL: on fly reallocation of NHIGH'
CALL REALLOC(NHIGH,SZ,IDPTH) CALL REALLOC(NHIGH,SZ,IDPTH)
END IF END IF
SZ=SIZE(NLOW) SZ=SIZE(NLOW)
IF(SZ .LT. IDPTH) THEN IF(SZ < IDPTH) THEN
WRITE(*,*) 'GPS_PIKLVL: on fly reallocation of NLOW' WRITE(*,*) 'GPS_PIKLVL: on fly reallocation of NLOW'
CALL REALLOC(NLOW,SZ,IDPTH) CALL REALLOC(NLOW,SZ,IDPTH)
END IF END IF
@ -510,16 +510,16 @@ CONTAINS
! SET MAX1=LARGEST NEW NUMBER IN NHIGH ! SET MAX1=LARGEST NEW NUMBER IN NHIGH
! SET MAX2=LARGEST NEW NUMBER IN NLOW ! SET MAX2=LARGEST NEW NUMBER IN NLOW
DO 30 K=1,IDPTH DO 30 K=1,IDPTH
IF (2*NACUM(K).EQ.NLOW(K)+NHIGH(K)) CYCLE IF (2*NACUM(K) == NLOW(K)+NHIGH(K)) CYCLE
IF (NHIGH(K).GT.MAX1) MAX1 = NHIGH(K) IF (NHIGH(K) > MAX1) MAX1 = NHIGH(K)
IF (NLOW(K).GT.MAX2) MAX2 = NLOW(K) IF (NLOW(K) > MAX2) MAX2 = NLOW(K)
30 END DO 30 END DO
! SET IT= NUMBER OF LEVEL STRUCTURE TO BE USED ! SET IT= NUMBER OF LEVEL STRUCTURE TO BE USED
IT = 1 IT = 1
IF (MAX1.GT.MAX2) IT = 2 IF (MAX1 > MAX2) IT = 2
IF (MAX1.EQ.MAX2) IT = IDFLT IF (MAX1 == MAX2) IT = IDFLT
IF (IT.EQ.2) GO TO 60 IF (IT == 2) GO TO 60
IF (I.EQ.1) ISDIR = -1 IF (I == 1) ISDIR = -1
! COPY LVLS1 INTO LVLS2 FOR EACH NODE IN CONNECTED COMPONENT ! COPY LVLS1 INTO LVLS2 FOR EACH NODE IN CONNECTED COMPONENT
DO 40 K=J,ENDC DO 40 K=J,ENDC
INODE = CCSTOR(K) INODE = CCSTOR(K)
@ -580,7 +580,7 @@ CONTAINS
DO 30 I=1,IDPTH DO 30 I=1,IDPTH
LSTPT(I) = NSTPT LSTPT(I) = NSTPT
DO 20 J=1,N DO 20 J=1,N
IF (LVLS2(J).NE.I) CYCLE IF (LVLS2(J) /= I) CYCLE
LVLST(NSTPT) = J LVLST(NSTPT) = J
NSTPT = NSTPT + 1 NSTPT = NSTPT + 1
20 END DO 20 END DO
@ -592,7 +592,7 @@ CONTAINS
! LVLN KEEPS TRACK OF THE LEVEL WE ARE WORKING AT. ! LVLN KEEPS TRACK OF THE LEVEL WE ARE WORKING AT.
! INITIALLY STKC CONTAINS ONLY THE INITIAL NODE, SND. ! INITIALLY STKC CONTAINS ONLY THE INITIAL NODE, SND.
LVLN = 0 LVLN = 0
IF (NFLG.LT.0) LVLN = IDPTH + 1 IF (NFLG < 0) LVLN = IDPTH + 1
XC = 1 XC = 1
STKC(XC) = SND STKC(XC) = SND
40 CX = 1 40 CX = 1
@ -612,16 +612,16 @@ CONTAINS
TEST = NDSTK(IPRO,I) TEST = NDSTK(IPRO,I)
INX = RENUM(TEST) INX = RENUM(TEST)
! ONLY NODES NOT NUMBERED OR ALREADY ON A STACK ARE ADDED ! ONLY NODES NOT NUMBERED OR ALREADY ON A STACK ARE ADDED
IF (INX.EQ.0) GO TO 60 IF (INX == 0) GO TO 60
IF (INX.LT.0) CYCLE IF (INX < 0) CYCLE
! DO PRELIMINARY BANDWIDTH AND PROFILE CALCULATIONS ! DO PRELIMINARY BANDWIDTH AND PROFILE CALCULATIONS
NBW = (RENUM(IPRO)-INX)*ISDIR NBW = (RENUM(IPRO)-INX)*ISDIR
IF (ISDIR.GT.0) INX = RENUM(IPRO) IF (ISDIR > 0) INX = RENUM(IPRO)
IF (IPFA(INX).LT.NBW) IPFA(INX) = NBW IF (IPFA(INX) < NBW) IPFA(INX) = NBW
CYCLE CYCLE
60 RENUM(TEST) = -1 60 RENUM(TEST) = -1
! PUT NODES ON SAME LEVEL ON STKA, ALL OTHERS ON STKB ! PUT NODES ON SAME LEVEL ON STKA, ALL OTHERS ON STKB
IF (LVLS2(TEST).EQ.LVLS2(IPRO)) GO TO 70 IF (LVLS2(TEST) == LVLS2(IPRO)) GO TO 70
XB = XB + 1 XB = XB + 1
STKB(XB) = TEST STKB(XB) = TEST
CYCLE CYCLE
@ -630,8 +630,8 @@ CONTAINS
80 END DO 80 END DO
! SORT STKA AND STKB INTO INCREASING DEGREE AND ADD STKA TO STKC ! SORT STKA AND STKB INTO INCREASING DEGREE AND ADD STKA TO STKC
! AND STKB TO STKD ! AND STKB TO STKD
IF (XA.EQ.0) GO TO 100 IF (XA == 0) GO TO 100
IF (XA.EQ.1) GO TO 90 IF (XA == 1) GO TO 90
!----------------------------------------------------------------- !-----------------------------------------------------------------
SZ1=SIZE(STKC) SZ1=SIZE(STKC)
SZ2=XC+XA SZ2=XC+XA
@ -655,8 +655,8 @@ CONTAINS
END IF END IF
!----------------------------------------------------------------- !-----------------------------------------------------------------
STKC(XC) = STKA(XA) STKC(XC) = STKA(XA)
100 IF (XB.EQ.0) GO TO 120 100 IF (XB == 0) GO TO 120
IF (XB.EQ.1) GO TO 110 IF (XB == 1) GO TO 110
!----------------------------------------------------------------- !-----------------------------------------------------------------
SZ1=SIZE(STKD) SZ1=SIZE(STKD)
SZ2=XD+XB SZ2=XD+XB
@ -682,21 +682,21 @@ CONTAINS
STKD(XD) = STKB(XB) STKD(XD) = STKB(XB)
! BE SURE TO PROCESS ALL NODES IN STKC ! BE SURE TO PROCESS ALL NODES IN STKC
120 CX = CX + 1 120 CX = CX + 1
IF (XC.GE.CX) GO TO 50 IF (XC >= CX) GO TO 50
! WHEN STKC IS EXHAUSTED LOOK FOR MIN DEGREE NODE IN SAME LEVEL ! WHEN STKC IS EXHAUSTED LOOK FOR MIN DEGREE NODE IN SAME LEVEL
! WHICH HAS NOT BEEN PROCESSED ! WHICH HAS NOT BEEN PROCESSED
MAX = IDEG + 1 MAX = IDEG + 1
SND = N + 1 SND = N + 1
DO 130 I=LST,LND DO 130 I=LST,LND
TEST = LVLST(I) TEST = LVLST(I)
IF (RENUM(TEST).NE.0) CYCLE IF (RENUM(TEST) /= 0) CYCLE
IF (NDEG(TEST).GE.MAX) CYCLE IF (NDEG(TEST) >= MAX) CYCLE
RENUM(SND) = 0 RENUM(SND) = 0
RENUM(TEST) = -1 RENUM(TEST) = -1
MAX = NDEG(TEST) MAX = NDEG(TEST)
SND = TEST SND = TEST
130 END DO 130 END DO
IF (SND.EQ.N+1) GO TO 140 IF (SND == N+1) GO TO 140
XC = XC + 1 XC = XC + 1
!----------------------------------------------------------------- !-----------------------------------------------------------------
SZ1=SIZE(STKC) SZ1=SIZE(STKC)
@ -712,7 +712,7 @@ CONTAINS
GO TO 50 GO TO 50
! IF STKD IS EMPTY WE ARE DONE, OTHERWISE COPY STKD ONTO STKC ! IF STKD IS EMPTY WE ARE DONE, OTHERWISE COPY STKD ONTO STKC
! AND BEGIN PROCESSING NEW STKC ! AND BEGIN PROCESSING NEW STKC
140 IF (XD.EQ.0) GO TO 160 140 IF (XD == 0) GO TO 160
!----------------------------------------------------------------- !-----------------------------------------------------------------
SZ1=SIZE(STKC) SZ1=SIZE(STKC)
SZ2=XD SZ2=XD
@ -730,7 +730,7 @@ CONTAINS
GO TO 40 GO TO 40
! DO FINAL BANDWIDTH AND PROFILE CALCULATIONS ! DO FINAL BANDWIDTH AND PROFILE CALCULATIONS
160 DO 170 I=1,N 160 DO 170 I=1,N
IF (IPFA(I).GT.IBW2) IBW2 = IPFA(I) IF (IPFA(I) > IBW2) IBW2 = IPFA(I)
IPF2 = IPF2 + IPFA(I) IPF2 = IPF2 + IPFA(I)
170 END DO 170 END DO
! !

@ -96,7 +96,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz = size(vin) isz = size(vin)
@ -118,7 +118,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -143,7 +143,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz1 = size(vin,1) isz1 = size(vin,1)
@ -167,7 +167,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -192,7 +192,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz = size(vin) isz = size(vin)
@ -214,7 +214,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -239,7 +239,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz1 = size(vin,1) isz1 = size(vin,1)
@ -263,7 +263,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -288,7 +288,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz = size(vin) isz = size(vin)
@ -310,7 +310,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -335,7 +335,7 @@ Contains
name='psb_cpy1d' name='psb_cpy1d'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info = 0 info = 0
if (allocated(vin)) then if (allocated(vin)) then
isz1 = size(vin,1) isz1 = size(vin,1)
@ -359,7 +359,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -473,7 +473,7 @@ Contains
name='psb_ensure_size' name='psb_ensure_size'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
If (len > psb_size(v)) Then If (len > psb_size(v)) Then
@ -501,7 +501,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -529,7 +529,7 @@ Contains
name='psb_ensure_size' name='psb_ensure_size'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
If (len > psb_size(v)) Then If (len > psb_size(v)) Then
@ -557,7 +557,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -585,7 +585,7 @@ Contains
name='psb_ensure_size' name='psb_ensure_size'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
If (len > psb_size(v)) Then If (len > psb_size(v)) Then
@ -612,7 +612,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -642,7 +642,7 @@ Contains
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if (debug) write(0,*) 'reallocate I',len if (debug) write(0,*) 'reallocate I',len
if (psb_get_errstatus().ne.0) return if (psb_get_errstatus() /= 0) return
info=0 info=0
if (present(lb)) then if (present(lb)) then
lb_ = lb lb_ = lb
@ -689,7 +689,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -765,7 +765,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -839,7 +839,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -932,7 +932,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -1026,7 +1026,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -1117,7 +1117,7 @@ Contains
info = err info = err
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -1140,7 +1140,7 @@ Contains
name='psb_dreallocate2i' name='psb_dreallocate2i'
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_dreallocate1i(len,rrax,info,pad=pad) call psb_dreallocate1i(len,rrax,info,pad=pad)
if (info /= 0) then if (info /= 0) then
@ -1160,7 +1160,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -1211,7 +1211,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()
@ -1260,7 +1260,7 @@ Contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_ret_) then if (err_act == psb_act_ret_) then
return return
else else
call psb_error() call psb_error()

@ -171,7 +171,7 @@ contains
end if end if
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -231,7 +231,7 @@ contains
end if end if
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -290,7 +290,7 @@ contains
end if end if
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -330,7 +330,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -406,7 +406,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -482,7 +482,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -571,7 +571,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -681,7 +681,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -789,7 +789,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -897,7 +897,7 @@ contains
9999 continue 9999 continue
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -365,7 +365,7 @@ contains
if (clear_) a%aspk(:) = dzero if (clear_) a%aspk(:) = dzero
if (psb_sp_getifld(psb_upd_,a,info)==psb_upd_perm_) then if (psb_sp_getifld(psb_upd_,a,info)==psb_upd_perm_) then
if(a%fida(1:3).eq.'JAD') then if(a%fida(1:3) == 'JAD') then
a%ia1(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0 a%ia1(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0
else else
a%ia2(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0 a%ia2(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0
@ -397,7 +397,7 @@ contains
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
Endif Endif
@ -463,7 +463,7 @@ contains
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
endif endif
@ -534,7 +534,7 @@ contains
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
endif endif
@ -910,7 +910,7 @@ contains
if (clear_) a%aspk(:) = zzero if (clear_) a%aspk(:) = zzero
if (psb_sp_getifld(psb_upd_,a,info)==psb_upd_perm_) then if (psb_sp_getifld(psb_upd_,a,info)==psb_upd_perm_) then
if(a%fida(1:3).eq.'JAD') then if(a%fida(1:3) == 'JAD') then
a%ia1(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0 a%ia1(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0
else else
a%ia2(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0 a%ia2(a%infoa(psb_upd_pnt_)+psb_nnz_) = 0
@ -942,7 +942,7 @@ contains
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
Endif Endif
@ -1008,7 +1008,7 @@ contains
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
endif endif
@ -1101,7 +1101,7 @@ contains
integer :: ifc_ integer :: ifc_
info = 0 info = 0
if (nnz.lt.0) then if (nnz < 0) then
info=45 info=45
return return
endif endif
@ -1450,14 +1450,14 @@ contains
nz=0 nz=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.idx) then if(ia1(j) == idx) then
nz=nz+ia3(j)-ia2(j) nz=nz+ia3(j)-ia2(j)
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = idx-ipx ! the row offset within the block rb = idx-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
nz = nz+ja(row+1)-ja(row) nz = nz+ja(row+1)-ja(row)
exit blkfnd exit blkfnd
else if(ia1(j).gt.idx) then else if(ia1(j) > idx) then
nz=nz+ia3(j-1)-ia2(j-1) nz=nz+ia3(j-1)-ia2(j-1)
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = idx-ipx ! the row offset within the block rb = idx-ipx ! the row offset within the block
@ -1500,7 +1500,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -1605,14 +1605,14 @@ contains
nz=0 nz=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.idx) then if(ia1(j) == idx) then
nz=nz+ia3(j)-ia2(j) nz=nz+ia3(j)-ia2(j)
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = idx-ipx ! the row offset within the block rb = idx-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
nz = nz+ja(row+1)-ja(row) nz = nz+ja(row+1)-ja(row)
exit blkfnd exit blkfnd
else if(ia1(j).gt.idx) then else if(ia1(j) > idx) then
nz=nz+ia3(j-1)-ia2(j-1) nz=nz+ia3(j-1)-ia2(j-1)
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = idx-ipx ! the row offset within the block rb = idx-ipx ! the row offset within the block
@ -1655,7 +1655,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -674,6 +674,7 @@ contains
subroutine psb_cdasb(desc_a,info) subroutine psb_cdasb(desc_a,info)
use psb_descriptor_type use psb_descriptor_type
interface interface
subroutine psb_icdasb(desc_a,info,ext_hv) subroutine psb_icdasb(desc_a,info,ext_hv)
use psb_descriptor_type use psb_descriptor_type

@ -60,9 +60,9 @@ module psi_mod
end interface end interface
interface interface
subroutine psi_crea_ovr_elem(desc_overlap,ovr_elem,info) subroutine psi_crea_ovr_elem(me,desc_overlap,ovr_elem,info)
integer :: desc_overlap(:) integer, intent(in) :: me, desc_overlap(:)
integer, allocatable, intent(inout) :: ovr_elem(:) integer, allocatable, intent(out) :: ovr_elem(:,:)
integer, intent(out) :: info integer, intent(out) :: info
end subroutine psi_crea_ovr_elem end subroutine psi_crea_ovr_elem
end interface end interface
@ -201,14 +201,6 @@ module psi_mod
end subroutine psi_zswaptranv end subroutine psi_zswaptranv
end interface end interface
interface psi_cnv_dsc
module procedure psi_cnv_dsc
end interface
interface psi_inner_cnv
module procedure psi_inner_cnv1, psi_inner_cnv2
end interface
interface interface
subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,& subroutine psi_extract_dep_list(desc_data,desc_str,dep_list,&
& length_dl,np,dl_lda,mode,info) & length_dl,np,dl_lda,mode,info)
@ -252,6 +244,17 @@ module psi_mod
end subroutine psi_bld_tmphalo end subroutine psi_bld_tmphalo
end interface end interface
interface psi_bld_tmpovrl
subroutine psi_bld_tmpovrl(iv,desc,info)
use psb_descriptor_type
integer, intent(in) :: iv(:)
type(psb_desc_type), intent(inout) :: desc
integer, intent(out) :: info
end subroutine psi_bld_tmpovrl
end interface
interface psi_idx_cnv interface psi_idx_cnv
subroutine psi_idx_cnv1(nv,idxin,desc,info,mask,owned) subroutine psi_idx_cnv1(nv,idxin,desc,info,mask,owned)
use psb_descriptor_type use psb_descriptor_type
@ -309,6 +312,33 @@ module psi_mod
end subroutine psi_idx_ins_cnvs end subroutine psi_idx_ins_cnvs
end interface end interface
interface psi_cnv_dsc
module procedure psi_cnv_dsc
end interface
interface psi_inner_cnv
module procedure psi_inner_cnv1, psi_inner_cnv2
end interface
interface psi_ovrl_upd
module procedure psi_iovrl_updr1, psi_iovrl_updr2,&
& psi_dovrl_updr1, psi_dovrl_updr2, &
& psi_zovrl_updr1, psi_zovrl_updr2
end interface
interface psi_gth
module procedure psi_igthm, psi_igthv,&
& psi_dgthm, psi_dgthv,&
& psi_zgthm, psi_zgthv
end interface
interface psi_sct
module procedure psi_isctm, psi_isctv,&
& psi_dsctm, psi_dsctv,&
& psi_zsctm, psi_zsctv
end interface
contains contains
subroutine psi_cnv_dsc(halo_in,ovrlap_in,ext_in,cdesc, info) subroutine psi_cnv_dsc(halo_in,ovrlap_in,ext_in,cdesc, info)
@ -327,7 +357,7 @@ contains
! ....local scalars.... ! ....local scalars....
integer :: np,me integer :: np,me
integer :: ictxt, err_act,nxch,nsnd,nrcv integer :: ictxt, err_act,nxch,nsnd,nrcv,j,k
! ...local array... ! ...local array...
integer, allocatable :: idx_out(:) integer, allocatable :: idx_out(:)
@ -384,7 +414,6 @@ contains
if (debug_level>0) write(debug_unit,*) me,'Calling crea_index on ovrlap' if (debug_level>0) write(debug_unit,*) me,'Calling crea_index on ovrlap'
! then the overlap index ! then the overlap index
call psi_crea_index(cdesc,ovrlap_in, idx_out,.true.,nxch,nsnd,nrcv,info) call psi_crea_index(cdesc,ovrlap_in, idx_out,.true.,nxch,nsnd,nrcv,info)
if(info /= 0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='psi_crea_index') call psb_errpush(4010,name,a_err='psi_crea_index')
@ -402,7 +431,7 @@ contains
if (debug_level>0) write(debug_unit,*) me,'Calling crea_ovr_elem' if (debug_level>0) write(debug_unit,*) me,'Calling crea_ovr_elem'
! next ovrlap_elem ! next ovrlap_elem
call psi_crea_ovr_elem(cdesc%ovrlap_index,cdesc%ovrlap_elem,info) call psi_crea_ovr_elem(me,cdesc%ovrlap_index,cdesc%ovrlap_elem,info)
if (debug_level>0) write(debug_unit,*) me,'Done crea_ovr_elem' if (debug_level>0) write(debug_unit,*) me,'Done crea_ovr_elem'
if(info /= 0) then if(info /= 0) then
call psb_errpush(4010,name,a_err='psi_crea_ovr_elem') call psb_errpush(4010,name,a_err='psi_crea_ovr_elem')
@ -529,4 +558,715 @@ contains
end do end do
end subroutine psi_inner_cnv2 end subroutine psi_inner_cnv2
subroutine psi_dovrl_updr1(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
real(kind(1.d0)), intent(inout), target :: x(:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_dovrl_updr1'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
case(psb_square_root_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx) = x(idx)/sqrt(real(ndm))
end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx) = x(idx)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_dovrl_updr1
subroutine psi_dovrl_updr2(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
real(kind(1.d0)), intent(inout), target :: x(:,:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_dovrl_updr2'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
case(psb_square_root_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx,:) = x(idx,:)/sqrt(real(ndm))
end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx,:) = x(idx,:)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_dovrl_updr2
subroutine psi_zovrl_updr1(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
complex(kind(1.d0)), intent(inout), target :: x(:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_zovrl_updr1'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
case(psb_square_root_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx) = x(idx)/sqrt(real(ndm))
end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx) = x(idx)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_zovrl_updr1
subroutine psi_zovrl_updr2(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
complex(kind(1.d0)), intent(inout), target :: x(:,:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_zovrl_updr2'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
case(psb_square_root_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx,:) = x(idx,:)/sqrt(real(ndm))
end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx,:) = x(idx,:)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_zovrl_updr2
subroutine psi_iovrl_updr1(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
integer, intent(inout), target :: x(:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_iovrl_updr1'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
! Square root does not make sense here
!!$ case(psb_square_root_)
!!$ do i=1,size(desc_a%ovrlap_elem,1)
!!$ idx = desc_a%ovrlap_elem(i,1)
!!$ ndm = desc_a%ovrlap_elem(i,2)
!!$ x(idx) = x(idx)/sqrt(real(ndm))
!!$ end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx) = x(idx)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_iovrl_updr1
subroutine psi_iovrl_updr2(x,desc_a,update,info)
use psb_descriptor_type
use psb_const_mod
use psb_error_mod
use psb_penv_mod
implicit none
integer, intent(inout), target :: x(:,:)
type(psb_desc_type), intent(in) :: desc_a
integer, intent(in) :: update
integer, intent(out) :: info
! locals
integer :: ictxt, np, me, err_act, i, idx, ndm
character(len=20) :: name, ch_err
name='psi_iovrl_updr2'
if (psb_get_errstatus() /= 0) return
info = 0
call psb_erractionsave(err_act)
ictxt = psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np)
if (np == -1) then
info = 2010
call psb_errpush(info,name)
goto 9999
endif
! switch on update type
select case (update)
! Square root does not make sense here
!!$ case(psb_square_root_)
!!$ do i=1,size(desc_a%ovrlap_elem,1)
!!$ idx = desc_a%ovrlap_elem(i,1)
!!$ ndm = desc_a%ovrlap_elem(i,2)
!!$ x(idx,:) = x(idx,:)/sqrt(real(ndm))
!!$ end do
case(psb_avg_)
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
x(idx,:) = x(idx,:)/real(ndm)
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
call psb_errpush(info,name,i_err=(/3,update,0,0,0/))
goto 9999
end select
call psb_erractionrestore(err_act)
return
9999 continue
call psb_erractionrestore(err_act)
if (err_act == psb_act_abort_) then
call psb_error(ictxt)
return
end if
return
end subroutine psi_iovrl_updr2
subroutine psi_dgthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
real(kind(1.d0)) :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_dgthm
subroutine psi_dgthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
real(kind(1.d0)) :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_dgthv
subroutine psi_dsctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
real(kind(1.d0)) :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == dzero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == done) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_dsctm
subroutine psi_dsctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
real(kind(1.d0)) :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == dzero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == done) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_dsctv
subroutine psi_igthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
integer :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_igthm
subroutine psi_igthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
integer :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_igthv
subroutine psi_isctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
integer :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == izero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == ione) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_isctm
subroutine psi_isctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
integer :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == izero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == ione) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_isctv
subroutine psi_zgthm(n,k,idx,x,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
complex(kind(1.d0)) :: x(:,:), y(:)
! Locals
integer :: i, j, pt
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(pt)=x(idx(i),j)
end do
end do
end subroutine psi_zgthm
subroutine psi_zgthv(n,idx,x,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
complex(kind(1.d0)) :: x(:), y(:)
! Locals
integer :: i
do i=1,n
y(i)=x(idx(i))
end do
end subroutine psi_zgthv
subroutine psi_zsctm(n,k,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, k, idx(:)
complex(kind(1.d0)) :: beta, x(:), y(:,:)
! Locals
integer :: i, j, pt
if (beta == zzero) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = x(pt)
end do
end do
else if (beta == zone) then
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = y(idx(i),j)+x(pt)
end do
end do
else
pt=0
do j=1,k
do i=1,n
pt=pt+1
y(idx(i),j) = beta*y(idx(i),j)+x(pt)
end do
end do
end if
end subroutine psi_zsctm
subroutine psi_zsctv(n,idx,x,beta,y)
use psb_const_mod
implicit none
integer :: n, idx(:)
complex(kind(1.d0)) :: beta, x(:), y(:)
! Locals
integer :: i
if (beta == zzero) then
do i=1,n
y(idx(i)) = x(i)
end do
else if (beta == zone) then
do i=1,n
y(idx(i)) = y(idx(i))+x(i)
end do
else
do i=1,n
y(idx(i)) = beta*y(idx(i))+x(i)
end do
end if
end subroutine psi_zsctv
end module psi_mod end module psi_mod

@ -64,7 +64,7 @@ function psb_damax (x,desc_a, info, jx)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_damax' name='psb_damax'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -89,21 +89,21 @@ function psb_damax (x,desc_a, info, jx)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),1) imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),1)
amax=abs(x(iix+imax-1,jjx)) amax=abs(x(iix+imax-1,jjx))
end if end if
@ -119,7 +119,7 @@ function psb_damax (x,desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -190,7 +190,7 @@ function psb_damaxv (x,desc_a, info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_damaxv' name='psb_damaxv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -211,21 +211,21 @@ function psb_damaxv (x,desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1) imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1)
amax=abs(x(iix+imax-1)) amax=abs(x(iix+imax-1))
end if end if
@ -241,7 +241,7 @@ function psb_damaxv (x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -313,7 +313,7 @@ subroutine psb_damaxvs (res,x,desc_a, info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_damaxvs' name='psb_damaxvs'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -334,21 +334,21 @@ subroutine psb_damaxvs (res,x,desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1) imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1)
amax=abs(x(iix+imax-1)) amax=abs(x(iix+imax-1))
end if end if
@ -364,7 +364,7 @@ subroutine psb_damaxvs (res,x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -435,7 +435,7 @@ subroutine psb_dmamaxs (res,x,desc_a, info,jx)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dmamaxs' name='psb_dmamaxs'
if (psb_get_errstatus().ne.0) return if (psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -461,21 +461,21 @@ subroutine psb_dmamaxs (res,x,desc_a, info,jx)
k = min(size(x,2),size(res,1)) k = min(size(x,2),size(res,1))
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
do i=1,k do i=1,k
imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx+i-1),1) imax=idamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx+i-1),1)
res(i)=abs(x(iix+imax-1,jjx+i-1)) res(i)=abs(x(iix+imax-1,jjx+i-1))
@ -491,7 +491,7 @@ subroutine psb_dmamaxs (res,x,desc_a, info,jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -60,12 +60,12 @@ function psb_dasum (x,desc_a, info, jx)
! locals ! locals
integer :: ictxt, np, me, err_act, & integer :: ictxt, np, me, err_act, &
& iix, jjx, ix, ijx, m, i & iix, jjx, ix, ijx, m, i, idx, ndm
real(kind(1.d0)) :: asum, dasum real(kind(1.d0)) :: asum, dasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dasum' name='psb_dasum'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -91,31 +91,29 @@ function psb_dasum (x,desc_a, info, jx)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dasum(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),ione) asum=dasum(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
asum = asum -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& asum = asum - (real(ndm-1)/real(ndm))*abs(x(idx,jjx))
& abs(x(desc_a%ovrlap_elem(i)-iix+1,jjx))
i = i+2
end do end do
! compute global sum ! compute global sum
@ -139,7 +137,7 @@ function psb_dasum (x,desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -203,12 +201,12 @@ function psb_dasumv (x,desc_a, info)
real(kind(1.d0)) :: psb_dasumv real(kind(1.d0)) :: psb_dasumv
! locals ! locals
integer :: ictxt, np, me, err_act, iix, jjx, jx, ix, m, i integer :: ictxt, np, me, err_act, iix, jjx, jx, ix, m, i, idx, ndm
real(kind(1.d0)) :: asum, dasum real(kind(1.d0)) :: asum, dasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dasumv' name='psb_dasumv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -230,31 +228,28 @@ function psb_dasumv (x,desc_a, info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dasum(psb_cd_get_local_rows(desc_a),x,ione) asum=dasum(psb_cd_get_local_rows(desc_a),x,ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
asum = asum -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& asum = asum - (real(ndm-1)/real(ndm))*abs(x(idx))
& abs(x(desc_a%ovrlap_elem(i)))
i = i+2
end do end do
! compute global sum ! compute global sum
@ -277,7 +272,7 @@ function psb_dasumv (x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -342,12 +337,12 @@ subroutine psb_dasumvs(res,x,desc_a, info)
integer, intent(out) :: info integer, intent(out) :: info
! locals ! locals
integer :: ictxt, np, me, err_act, iix, jjx, ix, jx, m, i integer :: ictxt, np, me, err_act, iix, jjx, ix, jx, m, i, idx, ndm
real(kind(1.d0)) :: asum, dasum real(kind(1.d0)) :: asum, dasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dasumvs' name='psb_dasumvs'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -369,31 +364,29 @@ subroutine psb_dasumvs(res,x,desc_a, info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dasum(psb_cd_get_local_rows(desc_a),x,ione) asum=dasum(psb_cd_get_local_rows(desc_a),x,ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
asum = asum -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& asum = asum - (real(ndm-1)/real(ndm))*abs(x(idx))
& abs(x(desc_a%ovrlap_elem(i)))
i = i+2
end do end do
! compute global sum ! compute global sum
@ -417,12 +410,9 @@ subroutine psb_dasumvs(res,x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
return return
end subroutine psb_dasumvs end subroutine psb_dasumvs

@ -70,7 +70,7 @@ subroutine psb_daxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dgeaxpby' name='psb_dgeaxpby'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -98,8 +98,8 @@ subroutine psb_daxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
endif endif
if (present(n)) then if (present(n)) then
if(((ijx+n).le.size(x,2)).and.& if(((ijx+n) <= size(x,2)).and.&
& ((ijy+n).le.size(y,2))) then & ((ijy+n) <= size(y,2))) then
in = n in = n
else else
in = min(size(x,2),size(y,2)) in = min(size(x,2),size(y,2))
@ -108,7 +108,7 @@ subroutine psb_daxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
in = min(size(x,2),size(y,2)) in = min(size(x,2),size(y,2))
endif endif
if(ijx.ne.ijy) then if(ijx /= ijy) then
info=3050 info=3050
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -120,21 +120,21 @@ subroutine psb_daxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if ((in.ne.0)) then if ((in /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
call daxpby(psb_cd_get_local_rows(desc_a),in,& call daxpby(psb_cd_get_local_rows(desc_a),in,&
& alpha,x(iix,jjx),size(x,1),beta,& & alpha,x(iix,jjx),size(x,1),beta,&
& y(iiy,jjy),size(y,1),info) & y(iiy,jjy),size(y,1),info)
@ -147,7 +147,7 @@ subroutine psb_daxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -223,7 +223,7 @@ subroutine psb_daxpbyv(alpha, x, beta,y,desc_a,info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dgeaxpby' name='psb_dgeaxpby'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -243,26 +243,26 @@ subroutine psb_daxpbyv(alpha, x, beta,y,desc_a,info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,ione,size(x),ix,ione,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x),ix,ione,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect 1' ch_err='psb_chkvect 1'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
call psb_chkvect(m,ione,size(y),iy,ione,desc_a,info,iiy,jjy) call psb_chkvect(m,ione,size(y),iy,ione,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect 2' ch_err='psb_chkvect 2'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
call daxpby(psb_cd_get_local_rows(desc_a),ione,& call daxpby(psb_cd_get_local_rows(desc_a),ione,&
& alpha,x,size(x),beta,& & alpha,x,size(x),beta,&
& y,size(y),info) & y,size(y),info)
@ -274,7 +274,7 @@ subroutine psb_daxpbyv(alpha, x, beta,y,desc_a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -61,19 +61,18 @@ function psb_ddot(x, y,desc_a, info, jx, jy)
real(kind(1.D0)) :: psb_ddot real(kind(1.D0)) :: psb_ddot
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, ijx, iy, ijy, iiy, jjy, i, m & err_act, iix, jjx, ix, ijx, iy, ijy, iiy, jjy, i, m
real(kind(1.D0)) :: dot_local real(kind(1.D0)) :: dot_local
real(kind(1.d0)) :: ddot real(kind(1.d0)) :: ddot
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_ddot' name='psb_ddot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
ictxt=psb_cd_get_context(desc_a) ictxt=psb_cd_get_context(desc_a)
call psb_info(ictxt, me, np) call psb_info(ictxt, me, np)
if (np == -ione) then if (np == -ione) then
info = 2010 info = 2010
@ -95,7 +94,7 @@ function psb_ddot(x, y,desc_a, info, jx, jy)
ijy = ione ijy = ione
endif endif
if(ijx.ne.ijy) then if(ijx /= ijy) then
info=3050 info=3050
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -107,31 +106,28 @@ function psb_ddot(x, y,desc_a, info, jx, jy)
call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = ddot(psb_cd_get_local_rows(desc_a),& dot_local = ddot(psb_cd_get_local_rows(desc_a),&
& x(iix,jjx),ione,y(iiy,jjy),ione) & x(iix,jjx),ione,y(iiy,jjy),ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(x(idx,jjx)*y(idx,jjy))
& x(iix+desc_a%ovrlap_elem(i)-1,jjx)*&
& y(iiy+desc_a%ovrlap_elem(i)-1,jjy)
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -151,7 +147,7 @@ function psb_ddot(x, y,desc_a, info, jx, jy)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -216,14 +212,14 @@ function psb_ddotv(x, y,desc_a, info)
real(kind(1.D0)) :: psb_ddotv real(kind(1.D0)) :: psb_ddotv
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, jx, iy, jy, iiy, jjy, i, m & err_act, iix, jjx, ix, jx, iy, jy, iiy, jjy, i, m
real(kind(1.D0)) :: dot_local real(kind(1.D0)) :: dot_local
real(kind(1.d0)) :: ddot real(kind(1.d0)) :: ddot
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_ddot' name='psb_ddot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -246,31 +242,28 @@ function psb_ddotv(x, y,desc_a, info)
call psb_chkvect(m,ione,size(x,1),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,jx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,jy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,jy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = ddot(psb_cd_get_local_rows(desc_a),& dot_local = ddot(psb_cd_get_local_rows(desc_a),&
& x,ione,y,ione) & x,ione,y,ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(x(idx)*y(idx))
& x(desc_a%ovrlap_elem(i))*&
& y(desc_a%ovrlap_elem(i))
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -290,7 +283,7 @@ function psb_ddotv(x, y,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -355,14 +348,14 @@ subroutine psb_ddotvs(res, x, y,desc_a, info)
integer, intent(out) :: info integer, intent(out) :: info
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, iy, iiy, jjy, i, m & err_act, iix, jjx, ix, iy, iiy, jjy, i, m
real(kind(1.D0)) :: dot_local real(kind(1.D0)) :: dot_local
real(kind(1.d0)) :: ddot real(kind(1.d0)) :: ddot
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_ddot' name='psb_ddot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -378,36 +371,32 @@ subroutine psb_ddotvs(res, x, y,desc_a, info)
ix = ione ix = ione
iy = ione iy = ione
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
! check vector correctness ! check vector correctness
call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = ddot(psb_cd_get_local_rows(desc_a),& dot_local = ddot(psb_cd_get_local_rows(desc_a),&
& x,ione,y,ione) & x,ione,y,ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(x(idx)*y(idx))
& x(desc_a%ovrlap_elem(i))*&
& y(desc_a%ovrlap_elem(i))
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -427,7 +416,7 @@ subroutine psb_ddotvs(res, x, y,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -493,14 +482,14 @@ subroutine psb_dmdots(res, x, y, desc_a, info)
integer, intent(out) :: info integer, intent(out) :: info
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, iy, iiy, jjy, i, m, j, k & err_act, iix, jjx, ix, iy, iiy, jjy, i, m, j, k
real(kind(1.d0)),allocatable :: dot_local(:) real(kind(1.d0)),allocatable :: dot_local(:)
real(kind(1.d0)) :: ddot real(kind(1.d0)) :: ddot
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dmdots' name='psb_dmdots'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -520,21 +509,21 @@ subroutine psb_dmdots(res, x, y, desc_a, info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy) call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ix.ne.ione).or.(iy.ne.ione)) then if ((ix /= ione).or.(iy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -543,20 +532,17 @@ subroutine psb_dmdots(res, x, y, desc_a, info)
k = min(size(x,2),size(y,2)) k = min(size(x,2),size(y,2))
allocate(dot_local(k)) allocate(dot_local(k))
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
do j=1,k do j=1,k
dot_local(j) = ddot(psb_cd_get_local_rows(desc_a),& dot_local(j) = ddot(psb_cd_get_local_rows(desc_a),&
& x(1,j),ione,y(1,j),ione) & x(1,j),ione,y(1,j),ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1
do while (desc_a%ovrlap_elem(i).ne.-ione)
dot_local(j) = dot_local(j) -&
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*&
& x(desc_a%ovrlap_elem(i)-1,j)*&
& y(desc_a%ovrlap_elem(i)-1,j)
i = i+2
end do end do
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
dot_local(1:k) = dot_local(1:k) - (real(ndm-1)/real(ndm))*(x(idx,1:k)*y(idx,1:k))
end do end do
else else
dot_local(:)=0.d0 dot_local(:)=0.d0
@ -576,10 +562,9 @@ subroutine psb_dmdots(res, x, y, desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
return return
end subroutine psb_dmdots end subroutine psb_dmdots

@ -58,13 +58,13 @@ function psb_dnrm2(x, desc_a, info, jx)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, ijx, i, m, id & err_act, iix, jjx, ndim, ix, ijx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dnrm2, dd real(kind(1.d0)) :: nrm2, dnrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dnrm2' name='psb_dnrm2'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -85,35 +85,30 @@ function psb_dnrm2(x, desc_a, info, jx)
endif endif
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dnrm2( ndim, x(iix,jjx), ione ) nrm2 = dnrm2( ndim, x(iix,jjx), ione )
i=1
do while (desc_a%ovrlap_elem(i) .ne. -1) ! adjust because overlapped elements are computed more than once
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) do i=1,size(desc_a%ovrlap_elem,1)
dd = dble(id-1)/dble(id) idx = desc_a%ovrlap_elem(i,1)
nrm2 = nrm2 * sqrt(& ndm = desc_a%ovrlap_elem(i,2)
& done - dd * ( & dd = dble(ndm-1)/dble(ndm)
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_), jjx) & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx,jjx))/nrm2)**2)
& / nrm2 &
& ) ** 2 &
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -132,7 +127,7 @@ function psb_dnrm2(x, desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -196,13 +191,13 @@ function psb_dnrm2v(x, desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, jx, i, m, id & err_act, iix, jjx, ndim, ix, jx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dnrm2, dd real(kind(1.d0)) :: nrm2, dnrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dnrm2v' name='psb_dnrm2v'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -217,37 +212,31 @@ function psb_dnrm2v(x, desc_a, info)
ix = 1 ix = 1
jx=1 jx=1
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dnrm2( ndim, x, ione ) nrm2 = dnrm2( ndim, x, ione )
i=1 ! adjust because overlapped elements are computed more than once
do while (desc_a%ovrlap_elem(i) .ne. -1) do i=1,size(desc_a%ovrlap_elem,1)
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) idx = desc_a%ovrlap_elem(i,1)
dd = dble(id-1)/dble(id) ndm = desc_a%ovrlap_elem(i,2)
nrm2 = nrm2 * sqrt(& dd = dble(ndm-1)/dble(ndm)
& done - dd * ( & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx))/nrm2)**2)
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) &
& / nrm2 &
& ) ** 2 &
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -266,7 +255,7 @@ function psb_dnrm2v(x, desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -332,13 +321,13 @@ subroutine psb_dnrm2vs(res, x, desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, jx, i, m, id & err_act, iix, jjx, ndim, ix, jx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dnrm2, dd real(kind(1.d0)) :: nrm2, dnrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dnrm2' name='psb_dnrm2'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -356,33 +345,28 @@ subroutine psb_dnrm2vs(res, x, desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dnrm2( ndim, x, ione ) nrm2 = dnrm2( ndim, x, ione )
i=1 ! adjust because overlapped elements are computed more than once
do while (desc_a%ovrlap_elem(i) .ne. -1) do i=1,size(desc_a%ovrlap_elem,1)
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) idx = desc_a%ovrlap_elem(i,1)
dd = dble(id-1)/dble(id) ndm = desc_a%ovrlap_elem(i,2)
nrm2 = nrm2 * sqrt(& dd = dble(ndm-1)/dble(ndm)
& done - dd * ( & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx))/nrm2)**2)
& x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) &
& / nrm2 &
& ) ** 2 &
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -401,7 +385,7 @@ subroutine psb_dnrm2vs(res, x, desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -60,7 +60,7 @@ function psb_dnrmi(a,desc_a,info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dnrmi' name='psb_dnrmi'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -79,27 +79,27 @@ function psb_dnrmi(a,desc_a,info)
n = psb_cd_get_global_cols(desc_a) n = psb_cd_get_global_cols(desc_a)
call psb_chkmat(m,n,ia,ja,desc_a,info,iia,jja) call psb_chkmat(m,n,ia,ja,desc_a,info,iia,jja)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkmat' ch_err='psb_chkmat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iia.ne.1).or.(jja.ne.1)) then if ((iia /= 1).or.(jja /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if ((m.ne.0).and.(n.ne.0)) then if ((m /= 0).and.(n /= 0)) then
mdim = psb_cd_get_local_rows(desc_a) mdim = psb_cd_get_local_rows(desc_a)
ndim = psb_cd_get_local_cols(desc_a) ndim = psb_cd_get_local_cols(desc_a)
nrmi = dcsnmi('N',mdim,ndim,a%fida,& nrmi = dcsnmi('N',mdim,ndim,a%fida,&
& a%descra,a%aspk,a%ia1,a%ia2,& & a%descra,a%aspk,a%ia1,a%ia2,&
& a%infoa,info) & a%infoa,info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='dcsnmi' ch_err='dcsnmi'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -120,7 +120,7 @@ function psb_dnrmi(a,desc_a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -90,17 +90,21 @@ subroutine psb_dspmm(alpha,a,x,beta,y,desc_a,info,&
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, ijx, ijy,& & err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, ijx, ijy,&
& m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,& & m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,&
& i, ib, ib1 & i, ib, ib1, ip, idx
integer, parameter :: nb=4 integer, parameter :: nb=4
real(kind(1.d0)),pointer :: xp(:,:), yp(:,:), iwork(:) real(kind(1.d0)), pointer :: xp(:,:), yp(:,:), iwork(:)
real(kind(1.d0)), allocatable :: wrkt(:,:)
character :: trans_ character :: trans_
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw, doswap_ logical :: aliw, doswap_
integer :: debug_level, debug_unit
name='psb_dspmm' name='psb_dspmm'
if(psb_get_errstatus() /= 0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
debug_unit = psb_get_debug_unit()
debug_level = psb_get_debug_level()
ictxt=psb_cd_get_context(desc_a) ictxt=psb_cd_get_context(desc_a)
@ -163,8 +167,7 @@ subroutine psb_dspmm(alpha,a,x,beta,y,desc_a,info,&
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) liwork = liwork + n * ik
if (a%pl(1) /= 0) liwork = liwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
aliw =.false. aliw =.false.
@ -264,6 +267,7 @@ subroutine psb_dspmm(alpha,a,x,beta,y,desc_a,info,&
end if end if
else else
! Matrix is transposed ! Matrix is transposed
if((ja /= iy).or.(ia /= ix)) then if((ja /= iy).or.(ia /= ix)) then
! this case is not yet implemented ! this case is not yet implemented
@ -272,11 +276,6 @@ subroutine psb_dspmm(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
if(desc_a%ovrlap_elem(1) /= -1) then
info = 3070
call psb_errpush(info,name)
goto 9999
end if
! checking for vectors correctness ! checking for vectors correctness
call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx)
@ -296,35 +295,54 @@ subroutine psb_dspmm(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
y(iiy+nrow+1-1:iiy+ncol,1:ik)=dzero !
! Non-empty overlap, need a buffer to hold
! the entries updated with average operator.
!
allocate(wrkt(ncol,ik),stat=info)
if (info /= 0) then
info=4010
ch_err='Allocate'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
! local Matrix-vector product
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ik-1),& !
& beta,y(iiy:lldy,jjy:jjy+ik-1),info,trans=trans_) wrkt(1:nrow,1:ik) = x(1:nrow,1:ik)
wrkt(nrow+1:ncol,1:ik) = dzero
y(nrow+1:ncol,1:ik) = dzero
call psi_ovrl_upd(wrkt,desc_a,psb_avg_,info)
call psb_csmm(alpha,a,wrkt(:,1:ik),beta,y(:,1:ik),info,trans=trans_)
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' csmm ', info
if(info /= 0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='csmm' ch_err='psb_csmm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
yp => y(iiy:lldy,jjy:jjy+ik-1) if (doswap_)then
if (doswap_) & call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),& & ik,done,y(:,1:ik),desc_a,iwork,info)
& ik,done,yp,desc_a,iwork,info) if (info == 0) call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& ik,done,y(:,1:ik),desc_a,iwork,info,data=psb_comm_ovr_)
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' swaptran ', info
if(info /= 0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='PSI_dSwapTran' ch_err='PSI_dSwapTran'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
end if
end if end if
if(aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
@ -425,7 +443,7 @@ subroutine psb_dspmv(alpha,a,x,beta,y,desc_a,info,&
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, & & err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, &
& m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,& & m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,&
& ib & ib, ip, idx
integer, parameter :: nb=4 integer, parameter :: nb=4
real(kind(1.d0)),pointer :: iwork(:), xp(:), yp(:) real(kind(1.d0)),pointer :: iwork(:), xp(:), yp(:)
character :: trans_ character :: trans_
@ -486,8 +504,6 @@ subroutine psb_dspmv(alpha,a,x,beta,y,desc_a,info,&
iwork => null() iwork => null()
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) liwork = liwork + n * ik
if (a%pl(1) /= 0) liwork = liwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
@ -574,12 +590,6 @@ subroutine psb_dspmv(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
if(desc_a%ovrlap_elem(1) /= -1) then
info = 3070
call psb_errpush(info,name)
goto 9999
end if
! checking for vectors correctness ! checking for vectors correctness
call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx)
if (info == 0)& if (info == 0)&
@ -598,26 +608,37 @@ subroutine psb_dspmv(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
xp => x(iix:lldx) xp => x(1:lldx)
yp => y(iiy:lldy) yp => y(1:lldy)
!
! Non-empty overlap, need a buffer to hold
! the entries updated with average operator.
!
iwork(1:nrow) = x(1:nrow)
iwork(nrow+1:ncol) = dzero
yp(nrow+1:ncol) = dzero
call psi_ovrl_upd(iwork,desc_a,psb_avg_,info)
yp(nrow+1:ncol)=dzero
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' checkvect ', info
! local Matrix-vector product ! local Matrix-vector product
call psb_csmm(alpha,a,xp,beta,yp,info,trans=trans_) call psb_csmm(alpha,a,iwork,beta,yp,info,trans=trans_)
if (debug_level >= psb_debug_comp_) & if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' csmm ', info & write(debug_unit,*) me,' ',trim(name),' csmm ', info
if(info /= 0) then
if (info /= 0) then
info = 4010 info = 4010
ch_err='dcsmm' ch_err='psb_csmm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (doswap_)& if (doswap_) then
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
& done,yp,desc_a,iwork,info) & done,yp,desc_a,iwork,info)
if (info == 0) call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& done,yp,desc_a,iwork,info,data=psb_comm_ovr_)
if (debug_level >= psb_debug_comp_) & if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' swaptran ', info & write(debug_unit,*) me,' ',trim(name),' swaptran ', info
if(info /= 0) then if(info /= 0) then
@ -626,6 +647,7 @@ subroutine psb_dspmv(alpha,a,x,beta,y,desc_a,info,&
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
end if
end if end if

@ -100,10 +100,10 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
integer, intent(in), optional :: k, jx, jy integer, intent(in), optional :: k, jx, jy
! locals ! locals
integer :: int_err(5), ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, lchoice,& & err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, choice_,&
& ix, iy, ik, ijx, ijy, i, lld,& & ix, iy, ik, ijx, ijy, i, lld,&
& m, nrow, ncol, liwork, llwork, iiy, jjy & m, nrow, ncol, liwork, llwork, iiy, jjy, idx, ndm
character :: lunitd character :: lunitd
integer, parameter :: nb=4 integer, parameter :: nb=4
@ -113,7 +113,7 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
logical :: aliw logical :: aliw
name='psb_dspsm' name='psb_dspsm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -152,9 +152,9 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
endif endif
if (present(choice)) then if (present(choice)) then
lchoice = choice choice_ = choice
else else
lchoice = psb_avg_ choice_ = psb_avg_
endif endif
if (present(unitd)) then if (present(unitd)) then
@ -165,7 +165,7 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
if (present(trans)) then if (present(trans)) then
itrans = toupper(trans) itrans = toupper(trans)
if((itrans.eq.'N').or.(itrans.eq.'T').or. (itrans.eq.'C')) then if((itrans == 'N').or.(itrans == 'T').or. (itrans == 'C')) then
! OK ! OK
else else
info = 70 info = 70
@ -179,11 +179,10 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
nrow = psb_cd_get_local_rows(desc_a) nrow = psb_cd_get_local_rows(desc_a)
ncol = psb_cd_get_local_cols(desc_a) ncol = psb_cd_get_local_cols(desc_a)
lldx = size(x,1) lldx = size(x,1)
lldy = size(y,1) lldy = size(y,1)
if((lldx.lt.ncol).or.(lldy.lt.ncol)) then if((lldx < ncol).or.(lldy < ncol)) then
info=3010 info=3010
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -206,7 +205,7 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
if (aliw) then if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -234,24 +233,24 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
& call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx) & call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ik,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ik,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect/mat' ch_err='psb_chkvect/mat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if(ja.ne.ix) then if(ja /= ix) then
! this case is not yet implemented ! this case is not yet implemented
info = 3030 info = 3030
end if end if
if((iix.ne.1).or.(iiy.ne.1)) then if((iix /= 1).or.(iiy /= 1)) then
! this case is not yet implemented ! this case is not yet implemented
info = 3040 info = 3040
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
@ -261,7 +260,7 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
yp => y(iiy:lldy,jjy:jjy+ik-1) yp => y(iiy:lldy,jjy:jjy+ik-1)
call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans) call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans)
if(info.ne.0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='dcssm' ch_err='dcssm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -269,37 +268,16 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
end if end if
! update overlap elements ! update overlap elements
if(lchoice.gt.0) then if (choice_ > 0) then
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),ik,& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),ik,&
& done,yp,desc_a,iwork,info) & done,yp,desc_a,iwork,info,data=psb_comm_ovr_)
i=0 if (info == 0) call psi_ovrl_upd(yp,desc_a,choice_,info)
! switch on update type if (info /= 0) then
select case (lchoice) call psb_errpush(4010,name,a_err='Inner updates')
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,lchoice,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999 goto 9999
end select end if
end if end if
if(aliw) deallocate(iwork) if(aliw) deallocate(iwork)
@ -311,7 +289,7 @@ subroutine psb_dspsm(alpha,a,x,beta,y,desc_a,info,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -408,10 +386,10 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
integer, intent(in), optional :: choice integer, intent(in), optional :: choice
! locals ! locals
integer :: int_err(5), ictxt, np, me,& integer :: ictxt, np, me, &
& err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, lchoice,& & err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, choice_,&
& ix, iy, ik, jx, jy, i, lld,& & ix, iy, ik, jx, jy, i, lld,&
& m, nrow, ncol, liwork, llwork, iiy, jjy & m, nrow, ncol, liwork, llwork, iiy, jjy, idx, ndm
character :: lunitd character :: lunitd
integer, parameter :: nb=4 integer, parameter :: nb=4
@ -421,7 +399,7 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
logical :: aliw logical :: aliw
name='psb_dspsv' name='psb_dspsv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -444,9 +422,9 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
jy= 1 jy= 1
if (present(choice)) then if (present(choice)) then
lchoice = choice choice_ = choice
else else
lchoice = psb_avg_ choice_ = psb_avg_
endif endif
if (present(unitd)) then if (present(unitd)) then
@ -457,12 +435,8 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
if (present(trans)) then if (present(trans)) then
itrans = toupper(trans) itrans = toupper(trans)
if((itrans.eq.'N').or.(itrans.eq.'T')) then if((itrans == 'N').or.(itrans == 'T').or.(itrans == 'C')) then
! Ok ! Ok
else if (itrans.eq.'C') then
info = 3020
call psb_errpush(info,name)
goto 9999
else else
info = 70 info = 70
call psb_errpush(info,name) call psb_errpush(info,name)
@ -475,11 +449,10 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
nrow = psb_cd_get_local_rows(desc_a) nrow = psb_cd_get_local_rows(desc_a)
ncol = psb_cd_get_local_cols(desc_a) ncol = psb_cd_get_local_cols(desc_a)
lldx = size(x) lldx = size(x)
lldy = size(y) lldy = size(y)
if((lldx.lt.ncol).or.(lldy.lt.ncol)) then if((lldx < ncol).or.(lldy < ncol)) then
info=3010 info=3010
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -488,8 +461,6 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
iwork => null() iwork => null()
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) llwork = liwork + m * ik
if (a%pl(1) /= 0) llwork = llwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
@ -503,7 +474,7 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
if (aliw) then if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -531,24 +502,24 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
& call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx) & call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx)
if (info == 0)& if (info == 0)&
& call psb_chkvect(m,ik,size(y),iy,jy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ik,size(y),iy,jy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect/mat' ch_err='psb_chkvect/mat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if(ja.ne.ix) then if(ja /= ix) then
! this case is not yet implemented ! this case is not yet implemented
info = 3030 info = 3030
end if end if
if((iix.ne.1).or.(iiy.ne.1)) then if((iix /= 1).or.(iiy /= 1)) then
! this case is not yet implemented ! this case is not yet implemented
info = 3040 info = 3040
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
@ -558,7 +529,7 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
yp => y(iiy:lldy) yp => y(iiy:lldy)
call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans) call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans)
if(info.ne.0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='dcssm' ch_err='dcssm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -566,36 +537,16 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
end if end if
! update overlap elements ! update overlap elements
if(lchoice.gt.0) then if (choice_ > 0) then
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& done,yp,desc_a,iwork,info) & done,yp,desc_a,iwork,info,data=psb_comm_ovr_)
i=0
! switch on update type if (info == 0) call psi_ovrl_upd(yp,desc_a,choice_,info)
select case (lchoice) if (info /= 0) then
case(psb_square_root_) call psb_errpush(4010,name,a_err='Inner updates')
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,lchoice,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999 goto 9999
end select end if
end if end if
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
@ -607,7 +558,7 @@ subroutine psb_dspsv(alpha,a,x,beta,y,desc_a,info,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -67,7 +67,7 @@ function psb_zamax (x,desc_a, info, jx)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zamax' name='psb_zamax'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -92,21 +92,21 @@ function psb_zamax (x,desc_a, info, jx)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),1) imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),1)
amax=cabs1(x(iix+imax-1,jjx)) amax=cabs1(x(iix+imax-1,jjx))
end if end if
@ -122,7 +122,7 @@ function psb_zamax (x,desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -197,7 +197,7 @@ function psb_zamaxv (x,desc_a, info)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zamaxv' name='psb_zamaxv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -218,21 +218,21 @@ function psb_zamaxv (x,desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1) imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1)
cmax=(x(iix+imax-1)) cmax=(x(iix+imax-1))
amax=cabs1(cmax) amax=cabs1(cmax)
@ -249,7 +249,7 @@ function psb_zamaxv (x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -325,7 +325,7 @@ subroutine psb_zamaxvs(res,x,desc_a, info)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zamaxvs' name='psb_zamaxvs'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -345,21 +345,21 @@ subroutine psb_zamaxvs(res,x,desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1) imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix),1)
cmax=(x(iix+imax-1)) cmax=(x(iix+imax-1))
amax=cabs1(cmax) amax=cabs1(cmax)
@ -376,7 +376,7 @@ subroutine psb_zamaxvs(res,x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -451,7 +451,7 @@ subroutine psb_zmamaxs(res,x,desc_a, info,jx)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zmamaxs' name='psb_zmamaxs'
if (psb_get_errstatus().ne.0) return if (psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -477,21 +477,21 @@ subroutine psb_zmamaxs(res,x,desc_a, info,jx)
k = min(size(x,2),size(res,1)) k = min(size(x,2),size(res,1))
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((psb_cd_get_local_rows(desc_a).gt.0).and.(m.ne.0)) then if ((psb_cd_get_local_rows(desc_a) > 0).and.(m /= 0)) then
do i=1,k do i=1,k
imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx+i-1),1) imax=izamax(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx+i-1),1)
cmax=(x(iix+imax-1,jjx+i-1)) cmax=(x(iix+imax-1,jjx+i-1))
@ -508,7 +508,7 @@ subroutine psb_zmamaxs(res,x,desc_a, info,jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -60,7 +60,7 @@ function psb_zasum (x,desc_a, info, jx)
! locals ! locals
integer :: ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, iix, jjx, ix, ijx, m, i & err_act, iix, jjx, ix, ijx, m, i, idx, ndm
real(kind(1.d0)) :: asum, dzasum real(kind(1.d0)) :: asum, dzasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
complex(kind(1.d0)) :: cmax complex(kind(1.d0)) :: cmax
@ -69,7 +69,7 @@ function psb_zasum (x,desc_a, info, jx)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zasum' name='psb_zasum'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -95,32 +95,29 @@ function psb_zasum (x,desc_a, info, jx)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dzasum(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),ione) asum=dzasum(psb_cd_get_local_rows(desc_a)-iix+1,x(iix,jjx),ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
cmax = x(desc_a%ovrlap_elem(i)-iix+1,jjx) ndm = desc_a%ovrlap_elem(i,2)
asum = asum -& asum = asum - (real(ndm-1)/real(ndm))*cabs1(x(idx,jjx))
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*&
& cabs1(cmax)
i = i+2
end do end do
! compute global sum ! compute global sum
@ -144,7 +141,7 @@ function psb_zasum (x,desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -209,7 +206,7 @@ function psb_zasumv(x,desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, jx, ix, m, i & err_act, iix, jjx, jx, ix, m, i, idx, ndm
real(kind(1.d0)) :: asum, dzasum real(kind(1.d0)) :: asum, dzasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
complex(kind(1.d0)) :: cmax complex(kind(1.d0)) :: cmax
@ -218,7 +215,7 @@ function psb_zasumv(x,desc_a, info)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zasumv' name='psb_zasumv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -240,32 +237,29 @@ function psb_zasumv(x,desc_a, info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dzasum(psb_cd_get_local_rows(desc_a),x,ione) asum=dzasum(psb_cd_get_local_rows(desc_a),x,ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
cmax = x(desc_a%ovrlap_elem(i)) ndm = desc_a%ovrlap_elem(i,2)
asum = asum -& asum = asum - (real(ndm-1)/real(ndm))*cabs1(x(idx))
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*&
& cabs1(cmax)
i = i+2
end do end do
! compute global sum ! compute global sum
@ -288,7 +282,7 @@ function psb_zasumv(x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -354,7 +348,7 @@ subroutine psb_zasumvs(res,x,desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ix, jx, m, i & err_act, iix, jjx, ix, jx, m, i, idx, ndm
real(kind(1.d0)) :: asum, dzasum real(kind(1.d0)) :: asum, dzasum
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
complex(kind(1.d0)) :: cmax complex(kind(1.d0)) :: cmax
@ -363,7 +357,7 @@ subroutine psb_zasumvs(res,x,desc_a, info)
cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) ) cabs1( zdum ) = abs( dble( zdum ) ) + abs( dimag( zdum ) )
name='psb_zasumvs' name='psb_zasumvs'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -382,34 +376,32 @@ subroutine psb_zasumvs(res,x,desc_a, info)
jx = 1 jx = 1
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
! check vector correctness ! check vector correctness
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
! compute local max ! compute local max
if ((m.ne.0)) then if ((m /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
asum=dzasum(psb_cd_get_local_rows(desc_a),x,ione) asum=dzasum(psb_cd_get_local_rows(desc_a),x,ione)
! adjust asum because overlapped elements are computed more than once ! adjust asum because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
cmax = x(desc_a%ovrlap_elem(i)) ndm = desc_a%ovrlap_elem(i,2)
asum = asum -& asum = asum - (real(ndm-1)/real(ndm))*cabs1(x(idx))
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*&
& cabs1(cmax)
i = i+2
end do end do
! compute global sum ! compute global sum
@ -433,7 +425,7 @@ subroutine psb_zasumvs(res,x,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -70,7 +70,7 @@ subroutine psb_zaxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_dgeaxpby' name='psb_dgeaxpby'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -97,8 +97,8 @@ subroutine psb_zaxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
endif endif
if (present(n)) then if (present(n)) then
if(((ijx+n).le.size(x,2)).and.& if(((ijx+n) <= size(x,2)).and.&
& ((ijy+n).le.size(y,2))) then & ((ijy+n) <= size(y,2))) then
in = n in = n
else else
in = min(size(x,2),size(y,2)) in = min(size(x,2),size(y,2))
@ -107,7 +107,7 @@ subroutine psb_zaxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
in = min(size(x,2),size(y,2)) in = min(size(x,2),size(y,2))
endif endif
if(ijx.ne.ijy) then if(ijx /= ijy) then
info=3050 info=3050
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -119,21 +119,21 @@ subroutine psb_zaxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if ((in.ne.0)) then if ((in /= 0)) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
call zaxpby(psb_cd_get_local_cols(desc_a),in,& call zaxpby(psb_cd_get_local_cols(desc_a),in,&
& alpha,x(iix,jjx),size(x,1),beta,& & alpha,x(iix,jjx),size(x,1),beta,&
& y(iiy,jjy),size(y,1),info) & y(iiy,jjy),size(y,1),info)
@ -146,7 +146,7 @@ subroutine psb_zaxpby(alpha, x, beta,y,desc_a,info, n, jx, jy)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -223,7 +223,7 @@ subroutine psb_zaxpbyv(alpha, x, beta,y,desc_a,info)
logical, parameter :: debug=.false. logical, parameter :: debug=.false.
name='psb_dgeaxpby' name='psb_dgeaxpby'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -243,26 +243,26 @@ subroutine psb_zaxpbyv(alpha, x, beta,y,desc_a,info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,ione,size(x),ix,ione,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x),ix,ione,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect 1' ch_err='psb_chkvect 1'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
call psb_chkvect(m,ione,size(y),iy,ione,desc_a,info,iiy,jjy) call psb_chkvect(m,ione,size(y),iy,ione,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect 2' ch_err='psb_chkvect 2'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
end if end if
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
call zaxpby(psb_cd_get_local_cols(desc_a),ione,& call zaxpby(psb_cd_get_local_cols(desc_a),ione,&
& alpha,x,size(x),beta,& & alpha,x,size(x),beta,&
& y,size(y),info) & y,size(y),info)
@ -274,7 +274,7 @@ subroutine psb_zaxpbyv(alpha, x, beta,y,desc_a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -61,14 +61,14 @@ function psb_zdot(x, y,desc_a, info, jx, jy)
complex(kind(1.D0)) :: psb_zdot complex(kind(1.D0)) :: psb_zdot
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, ijx, iy, ijy, iiy, jjy, i, m & err_act, iix, jjx, ix, ijx, iy, ijy, iiy, jjy, i, m
complex(kind(1.D0)) :: dot_local complex(kind(1.D0)) :: dot_local
complex(kind(1.d0)) :: zdotc complex(kind(1.d0)) :: zdotc
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zdot' name='psb_zdot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -94,7 +94,7 @@ function psb_zdot(x, y,desc_a, info, jx, jy)
ijy = ione ijy = ione
endif endif
if(ijx.ne.ijy) then if(ijx /= ijy) then
info=3050 info=3050
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -106,31 +106,28 @@ function psb_zdot(x, y,desc_a, info, jx, jy)
call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = zdotc(psb_cd_get_local_rows(desc_a),& dot_local = zdotc(psb_cd_get_local_rows(desc_a),&
& x(iix,jjx),ione,y(iiy,jjy),ione) & x(iix,jjx),ione,y(iiy,jjy),ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(conjg(x(idx,jjx))*y(idx,jjy))
& conjg(x(iix+desc_a%ovrlap_elem(i)-1,jjx))*&
& y(iiy+desc_a%ovrlap_elem(i)-1,jjy)
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -150,7 +147,7 @@ function psb_zdot(x, y,desc_a, info, jx, jy)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -215,14 +212,14 @@ function psb_zdotv(x, y,desc_a, info)
complex(kind(1.D0)) :: psb_zdotv complex(kind(1.D0)) :: psb_zdotv
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, jx, iy, jy, iiy, jjy, i, m & err_act, iix, jjx, ix, jx, iy, jy, iiy, jjy, i, m
complex(kind(1.D0)) :: dot_local complex(kind(1.D0)) :: dot_local
complex(kind(1.d0)) :: zdotc complex(kind(1.d0)) :: zdotc
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zdot' name='psb_zdot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -245,31 +242,28 @@ function psb_zdotv(x, y,desc_a, info)
call psb_chkvect(m,ione,size(x,1),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,jx,desc_a,info,iix,jjx)
if (info == 0)& if (info == 0)&
& call psb_chkvect(m,ione,size(y,1),iy,jy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,jy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = zdotc(psb_cd_get_local_rows(desc_a),& dot_local = zdotc(psb_cd_get_local_rows(desc_a),&
& x,ione,y,ione) & x,ione,y,ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(conjg(x(idx))*y(idx))
& conjg(x(desc_a%ovrlap_elem(i)))*&
& y(desc_a%ovrlap_elem(i))
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -289,7 +283,7 @@ function psb_zdotv(x, y,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -354,14 +348,14 @@ subroutine psb_zdotvs(res, x, y,desc_a, info)
integer, intent(out) :: info integer, intent(out) :: info
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, iy, iiy, jjy, i, m & err_act, iix, jjx, ix, iy, iiy, jjy, i, m
complex(kind(1.D0)) :: dot_local complex(kind(1.D0)) :: dot_local
complex(kind(1.d0)) :: zdotc complex(kind(1.d0)) :: zdotc
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zdot' name='psb_zdot'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -381,31 +375,28 @@ subroutine psb_zdotvs(res, x, y,desc_a, info)
call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iix.ne.ione).or.(iiy.ne.ione)) then if ((iix /= ione).or.(iiy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
dot_local = zdotc(psb_cd_get_local_rows(desc_a),& dot_local = zdotc(psb_cd_get_local_rows(desc_a),&
& x,ione,y,ione) & x,ione,y,ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1 do i=1,size(desc_a%ovrlap_elem,1)
do while (desc_a%ovrlap_elem(i).ne.-ione) idx = desc_a%ovrlap_elem(i,1)
dot_local = dot_local -& ndm = desc_a%ovrlap_elem(i,2)
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*& dot_local = dot_local - (real(ndm-1)/real(ndm))*(conjg(x(idx))*y(idx))
& conjg(x(desc_a%ovrlap_elem(i)))*&
& y(desc_a%ovrlap_elem(i))
i = i+2
end do end do
else else
dot_local=0.d0 dot_local=0.d0
@ -425,7 +416,7 @@ subroutine psb_zdotvs(res, x, y,desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -491,14 +482,14 @@ subroutine psb_zmdots(res, x, y, desc_a, info)
integer, intent(out) :: info integer, intent(out) :: info
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me, idx, ndm,&
& err_act, iix, jjx, ix, iy, iiy, jjy, i, m, j, k & err_act, iix, jjx, ix, iy, iiy, jjy, i, m, j, k
complex(kind(1.d0)),allocatable :: dot_local(:) complex(kind(1.d0)),allocatable :: dot_local(:)
complex(kind(1.d0)) :: zdotc complex(kind(1.d0)) :: zdotc
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_zmdots' name='psb_zmdots'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -518,21 +509,21 @@ subroutine psb_zmdots(res, x, y, desc_a, info)
! check vector correctness ! check vector correctness
call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx) call psb_chkvect(m,ione,size(x,1),ix,ix,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy) call psb_chkvect(m,ione,size(y,1),iy,iy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((ix.ne.ione).or.(iy.ne.ione)) then if ((ix /= ione).or.(iy /= ione)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -541,20 +532,17 @@ subroutine psb_zmdots(res, x, y, desc_a, info)
k = min(size(x,2),size(y,2)) k = min(size(x,2),size(y,2))
allocate(dot_local(k)) allocate(dot_local(k))
if(m.ne.0) then if(m /= 0) then
if(psb_cd_get_local_rows(desc_a).gt.0) then if(psb_cd_get_local_rows(desc_a) > 0) then
do j=1,k do j=1,k
dot_local(j) = zdotc(psb_cd_get_local_rows(desc_a),& dot_local(j) = zdotc(psb_cd_get_local_rows(desc_a),&
& x(1,j),ione,y(1,j),ione) & x(1,j),ione,y(1,j),ione)
! adjust dot_local because overlapped elements are computed more than once ! adjust dot_local because overlapped elements are computed more than once
i=1
do while (desc_a%ovrlap_elem(i).ne.-ione)
dot_local(j) = dot_local(j) -&
& (desc_a%ovrlap_elem(i+1)-1)/desc_a%ovrlap_elem(i+1)*&
& conjg(x(desc_a%ovrlap_elem(i)-1,j))*&
& y(desc_a%ovrlap_elem(i)-1,j)
i = i+2
end do end do
do i=1,size(desc_a%ovrlap_elem,1)
idx = desc_a%ovrlap_elem(i,1)
ndm = desc_a%ovrlap_elem(i,2)
dot_local(1:k) = dot_local(1:k) - (real(ndm-1)/real(ndm))*(conjg(x(idx,1:k))*y(idx,1:k))
end do end do
else else
dot_local(:)=0.d0 dot_local(:)=0.d0
@ -568,14 +556,13 @@ subroutine psb_zmdots(res, x, y, desc_a, info)
res(1:k) = dot_local(1:k) res(1:k) = dot_local(1:k)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -58,14 +58,14 @@ function psb_znrm2(x, desc_a, info, jx)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, ijx, i, m, id & err_act, iix, jjx, ndim, ix, ijx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dznrm2, dd real(kind(1.d0)) :: nrm2, dznrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_znrm2' name='psb_znrm2'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -87,32 +87,29 @@ function psb_znrm2(x, desc_a, info, jx)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dznrm2( ndim, x(iix,jjx), ione ) nrm2 = dznrm2( ndim, x(iix,jjx), ione )
i=1
do while (desc_a%ovrlap_elem(i) .ne. -1) ! adjust because overlapped elements are computed more than once
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) do i=1,size(desc_a%ovrlap_elem,1)
dd = dble(id-1)/dble(id) idx = desc_a%ovrlap_elem(i,1)
nrm2 = nrm2 * sqrt(& ndm = desc_a%ovrlap_elem(i,2)
& done - dd * (abs(x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_), jjx)) & dd = dble(ndm-1)/dble(ndm)
& / nrm2 & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx,jjx))/nrm2)**2)
& ) ** 2 &
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -131,7 +128,7 @@ function psb_znrm2(x, desc_a, info, jx)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -195,14 +192,14 @@ function psb_znrm2v(x, desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, jx, i, m, id & err_act, iix, jjx, ndim, ix, jx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dznrm2, dd real(kind(1.d0)) :: nrm2, dznrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_znrm2v' name='psb_znrm2v'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -219,34 +216,29 @@ function psb_znrm2v(x, desc_a, info)
jx=1 jx=1
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dznrm2( ndim, x, ione ) nrm2 = dznrm2( ndim, x, ione )
i=1 ! adjust because overlapped elements are computed more than once
do while (desc_a%ovrlap_elem(i) .ne. -1) do i=1,size(desc_a%ovrlap_elem,1)
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) idx = desc_a%ovrlap_elem(i,1)
dd = dble(id-1)/dble(id) ndm = desc_a%ovrlap_elem(i,2)
nrm2 = nrm2 * sqrt(& dd = dble(ndm-1)/dble(ndm)
& done - dd * (abs(x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))) & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx))/nrm2)**2)
& / nrm2 &
& ) ** 2 &
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -265,7 +257,7 @@ function psb_znrm2v(x, desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -331,14 +323,14 @@ subroutine psb_znrm2vs(res, x, desc_a, info)
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ndim, ix, jx, i, m, id & err_act, iix, jjx, ndim, ix, jx, i, m, id, idx, ndm
real(kind(1.d0)) :: nrm2, dznrm2, dd real(kind(1.d0)) :: nrm2, dznrm2, dd
external dcombnrm2 external dcombnrm2
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_znrm2' name='psb_znrm2'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -356,30 +348,28 @@ subroutine psb_znrm2vs(res, x, desc_a, info)
m = psb_cd_get_global_rows(desc_a) m = psb_cd_get_global_rows(desc_a)
call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a,info,iix,jjx)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect' ch_err='psb_chkvect'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
end if end if
if (iix.ne.1) then if (iix /= 1) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if(m.ne.0) then if(m /= 0) then
if (psb_cd_get_local_rows(desc_a) .gt. 0) then if (psb_cd_get_local_rows(desc_a) > 0) then
ndim = psb_cd_get_local_rows(desc_a) ndim = psb_cd_get_local_rows(desc_a)
nrm2 = dznrm2( ndim, x, ione ) nrm2 = dznrm2( ndim, x, ione )
i=1 ! adjust because overlapped elements are computed more than once
do while (desc_a%ovrlap_elem(i) .ne. -1) do i=1,size(desc_a%ovrlap_elem,1)
id = desc_a%ovrlap_elem(i+psb_n_dom_ovr_) idx = desc_a%ovrlap_elem(i,1)
dd = dble(id-1)/dble(id) ndm = desc_a%ovrlap_elem(i,2)
nrm2 = nrm2 * sqrt(& dd = dble(ndm-1)/dble(ndm)
& done-dd*(abs(x(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)))/nrm2)**2 & nrm2 = nrm2 * sqrt(done - dd*(abs(x(idx))/nrm2)**2)
& )
i = i+2
end do end do
else else
nrm2 = dzero nrm2 = dzero
@ -398,7 +388,7 @@ subroutine psb_znrm2vs(res, x, desc_a, info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -60,7 +60,7 @@ function psb_znrmi(a,desc_a,info)
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
name='psb_znrmi' name='psb_znrmi'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -79,27 +79,27 @@ function psb_znrmi(a,desc_a,info)
n = psb_cd_get_global_cols(desc_a) n = psb_cd_get_global_cols(desc_a)
call psb_chkmat(m,n,ia,ja,desc_a,info,iia,jja) call psb_chkmat(m,n,ia,ja,desc_a,info,iia,jja)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkmat' ch_err='psb_chkmat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if ((iia.ne.1).or.(jja.ne.1)) then if ((iia /= 1).or.(jja /= 1)) then
info=3040 info=3040
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
if ((m.ne.0).and.(n.ne.0)) then if ((m /= 0).and.(n /= 0)) then
mdim = psb_cd_get_local_rows(desc_a) mdim = psb_cd_get_local_rows(desc_a)
ndim = psb_cd_get_local_cols(desc_a) ndim = psb_cd_get_local_cols(desc_a)
nrmi = zcsnmi('N',mdim,ndim,a%fida,& nrmi = zcsnmi('N',mdim,ndim,a%fida,&
& a%descra,a%aspk,a%ia1,a%ia2,& & a%descra,a%aspk,a%ia1,a%ia2,&
& a%infoa,info) & a%infoa,info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='dcsnmi' ch_err='dcsnmi'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -120,7 +120,7 @@ function psb_znrmi(a,desc_a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -37,7 +37,7 @@
! !
! sub( Y ) := alpha * Pr * A' * Pr * sub( X ) + beta * sub( Y ), ! sub( Y ) := alpha * Pr * A' * Pr * sub( X ) + beta * sub( Y ),
! !
! ! where:
! !
! sub( X ) denotes: X(1:N,JX:JX+K-1), ! sub( X ) denotes: X(1:N,JX:JX+K-1),
! !
@ -90,17 +90,21 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, ijx, ijy,& & err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, ijx, ijy,&
& m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,& & m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,&
& i, ib, ib1 & i, ib, ib1, ip, idx
integer, parameter :: nb=4 integer, parameter :: nb=4
complex(kind(1.d0)),pointer :: xp(:,:), yp(:,:), iwork(:) complex(kind(1.d0)), pointer :: xp(:,:), yp(:,:), iwork(:)
complex(kind(1.d0)), allocatable :: wrkt(:,:)
character :: trans_ character :: trans_
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw, doswap_ logical :: aliw, doswap_
integer :: debug_level, debug_unit
name='psb_zspmm' name='psb_zspmm'
if(psb_get_errstatus() /= 0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
debug_unit = psb_get_debug_unit()
debug_level = psb_get_debug_level()
ictxt=psb_cd_get_context(desc_a) ictxt=psb_cd_get_context(desc_a)
@ -163,8 +167,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) liwork = liwork + n * ik
if (a%pl(1) /= 0) liwork = liwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
aliw =.false. aliw =.false.
@ -264,6 +267,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
end if end if
else else
! Matrix is transposed ! Matrix is transposed
if((ja /= iy).or.(ia /= ix)) then if((ja /= iy).or.(ia /= ix)) then
! this case is not yet implemented ! this case is not yet implemented
@ -272,11 +276,6 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
if(desc_a%ovrlap_elem(1) /= -1) then
info = 3070
call psb_errpush(info,name)
goto 9999
end if
! checking for vectors correctness ! checking for vectors correctness
call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx) call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx)
@ -296,35 +295,54 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
y(iiy+nrow+1-1:iiy+ncol,1:ik)=zzero !
! Non-empty overlap, need a buffer to hold
! the entries updated with average operator.
!
allocate(wrkt(ncol,ik),stat=info)
if (info /= 0) then
info=4010
ch_err='Allocate'
call psb_errpush(info,name,a_err=ch_err)
goto 9999
end if
! local Matrix-vector product
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ik-1),& !
& beta,y(iiy:lldy,jjy:jjy+ik-1),info,trans=trans_) wrkt(1:nrow,1:ik) = x(1:nrow,1:ik)
wrkt(nrow+1:ncol,1:ik) = zzero
y(nrow+1:ncol,1:ik) = zzero
call psi_ovrl_upd(wrkt,desc_a,psb_avg_,info)
call psb_csmm(alpha,a,wrkt(:,1:ik),beta,y(:,1:ik),info,trans=trans_)
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' csmm ', info
if(info /= 0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='csmm' ch_err='psb_csmm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
yp => y(iiy:lldy,jjy:jjy+ik-1) if (doswap_)then
if (doswap_) & call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),& & ik,zone,y(:,1:ik),desc_a,iwork,info)
& ik,zone,yp,desc_a,iwork,info) if (info == 0) call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& ik,zone,y(:,1:ik),desc_a,iwork,info,data=psb_comm_ovr_)
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' swaptran ', info
if(info /= 0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='PSI_dSwapTran' ch_err='PSI_dSwapTran'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
end if
end if end if
if(aliw) deallocate(iwork) if (aliw) deallocate(iwork)
nullify(iwork) nullify(iwork)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
@ -425,9 +443,9 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, & & err_act, n, iix, jjx, ia, ja, iia, jja, ix, iy, ik, &
& m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,& & m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,&
& ib & ib, ip, idx
integer, parameter :: nb=4 integer, parameter :: nb=4
complex(kind(1.d0)),pointer :: iwork(:), xp(:), yp(:) complex(kind(1.d0)), pointer :: iwork(:), xp(:), yp(:)
character :: trans_ character :: trans_
character(len=20) :: name, ch_err character(len=20) :: name, ch_err
logical :: aliw, doswap_ logical :: aliw, doswap_
@ -486,8 +504,6 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
iwork => null() iwork => null()
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) liwork = liwork + n * ik
if (a%pl(1) /= 0) liwork = liwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
@ -574,12 +590,6 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
if(desc_a%ovrlap_elem(1) /= -1) then
info = 3070
call psb_errpush(info,name)
goto 9999
end if
! checking for vectors correctness ! checking for vectors correctness
call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx) call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx)
if (info == 0)& if (info == 0)&
@ -598,26 +608,36 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
goto 9999 goto 9999
end if end if
xp => x(iix:lldx) xp => x(1:lldx)
yp => y(iiy:lldy) yp => y(1:lldy)
!
! Non-empty overlap, need a buffer to hold
! the entries updated with average operator.
!
iwork(1:nrow) = x(1:nrow)
iwork(nrow+1:ncol) = zzero
yp(nrow+1:ncol) = zzero
call psi_ovrl_upd(iwork,desc_a,psb_avg_,info)
yp(nrow+1:ncol)=zzero
if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' checkvect ', info
! local Matrix-vector product ! local Matrix-vector product
call psb_csmm(alpha,a,xp,beta,yp,info,trans=trans_) call psb_csmm(alpha,a,iwork,beta,yp,info,trans=trans_)
if (debug_level >= psb_debug_comp_) & if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' csmm ', info & write(debug_unit,*) me,' ',trim(name),' csmm ', info
if(info /= 0) then
if (info /= 0) then
info = 4010 info = 4010
ch_err='zcsmm' ch_err='psb_csmm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if (doswap_)& if (doswap_) then
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
& zone,yp,desc_a,iwork,info) & zone,yp,desc_a,iwork,info)
if (info == 0) call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& zone,yp,desc_a,iwork,info,data=psb_comm_ovr_)
if (debug_level >= psb_debug_comp_) & if (debug_level >= psb_debug_comp_) &
& write(debug_unit,*) me,' ',trim(name),' swaptran ', info & write(debug_unit,*) me,' ',trim(name),' swaptran ', info
if(info /= 0) then if(info /= 0) then
@ -626,6 +646,7 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
end if
end if end if

@ -100,9 +100,9 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
! locals ! locals
integer :: ictxt, np, me,& integer :: ictxt, np, me,&
& err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, lchoice,& & err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, choice_,&
& ix, iy, ik, ijx, ijy, i, lld, int_err(5),& & ix, iy, ik, ijx, ijy, i, lld,&
& m, nrow, ncol, liwork, llwork, iiy, jjy & m, nrow, ncol, liwork, llwork, iiy, jjy, idx, ndm
character :: lunitd character :: lunitd
integer, parameter :: nb=4 integer, parameter :: nb=4
@ -112,7 +112,7 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
logical :: aliw logical :: aliw
name='psb_zspsm' name='psb_zspsm'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -151,9 +151,9 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
endif endif
if (present(choice)) then if (present(choice)) then
lchoice = choice choice_ = choice
else else
lchoice = psb_avg_ choice_ = psb_avg_
endif endif
if (present(unitd)) then if (present(unitd)) then
@ -164,12 +164,8 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
if (present(trans)) then if (present(trans)) then
itrans = toupper(trans) itrans = toupper(trans)
if((itrans.eq.'N').or.(itrans.eq.'T')) then if((itrans == 'N').or.(itrans == 'T').or. (itrans == 'C')) then
! Ok ! OK
else if (itrans.eq.'C') then
info = 3020
call psb_errpush(info,name)
goto 9999
else else
info = 70 info = 70
call psb_errpush(info,name) call psb_errpush(info,name)
@ -185,7 +181,7 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
lldx = size(x,1) lldx = size(x,1)
lldy = size(y,1) lldy = size(y,1)
if((lldx.lt.ncol).or.(lldy.lt.ncol)) then if((lldx < ncol).or.(lldy < ncol)) then
info=3010 info=3010
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -208,7 +204,7 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
if (aliw) then if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -236,24 +232,24 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
& call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx) & call psb_chkvect(m,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ik,size(y,1),iy,ijy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ik,size(y,1),iy,ijy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect/mat' ch_err='psb_chkvect/mat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if(ja.ne.ix) then if(ja /= ix) then
! this case is not yet implemented ! this case is not yet implemented
info = 3030 info = 3030
end if end if
if((iix.ne.1).or.(iiy.ne.1)) then if((iix /= 1).or.(iiy /= 1)) then
! this case is not yet implemented ! this case is not yet implemented
info = 3040 info = 3040
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
@ -263,7 +259,7 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
yp => y(iiy:lldy,jjy:jjy+ik-1) yp => y(iiy:lldy,jjy:jjy+ik-1)
call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans) call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans)
if(info.ne.0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='zcssm' ch_err='zcssm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -271,37 +267,16 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
end if end if
! update overlap elements ! update overlap elements
if(lchoice.gt.0) then if (choice_ > 0) then
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),ik,& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),ik,&
& zone,yp,desc_a,iwork,info) & zone,yp,desc_a,iwork,info,data=psb_comm_ovr_)
i=0 if (info == 0) call psi_ovrl_upd(yp,desc_a,choice_,info)
! switch on update type if (info /= 0) then
select case (lchoice) call psb_errpush(4010,name,a_err='Inner updates')
case(psb_square_root_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_),:)/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,lchoice,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999 goto 9999
end select end if
end if end if
if(aliw) deallocate(iwork) if(aliw) deallocate(iwork)
@ -313,7 +288,7 @@ subroutine psb_zspsm(alpha,a,x,beta,y,desc_a,info,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if
@ -411,9 +386,9 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
! locals ! locals
integer :: ictxt, np, me, & integer :: ictxt, np, me, &
& err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, lchoice,& & err_act, iix, jjx, ia, ja, iia, jja, lldx,lldy, choice_,&
& ix, iy, ik, jx, jy, i, lld, int_err(5),& & ix, iy, ik, jx, jy, i, lld,&
& m, nrow, ncol, liwork, llwork, iiy, jjy & m, nrow, ncol, liwork, llwork, iiy, jjy, idx, ndm
character :: lunitd character :: lunitd
integer, parameter :: nb=4 integer, parameter :: nb=4
@ -423,7 +398,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
logical :: aliw logical :: aliw
name='psb_zspsv' name='psb_zspsv'
if(psb_get_errstatus().ne.0) return if(psb_get_errstatus() /= 0) return
info=0 info=0
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
@ -446,9 +421,9 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
jy= 1 jy= 1
if (present(choice)) then if (present(choice)) then
lchoice = choice choice_ = choice
else else
lchoice = psb_avg_ choice_ = psb_avg_
endif endif
if (present(unitd)) then if (present(unitd)) then
@ -459,7 +434,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
if (present(trans)) then if (present(trans)) then
itrans = toupper(trans) itrans = toupper(trans)
if((itrans.eq.'N').or.(itrans.eq.'T').or.(itrans.eq.'C')) then if((itrans == 'N').or.(itrans == 'T').or.(itrans == 'C')) then
! Ok ! Ok
else else
info = 70 info = 70
@ -476,7 +451,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
lldx = size(x) lldx = size(x)
lldy = size(y) lldy = size(y)
if((lldx.lt.ncol).or.(lldy.lt.ncol)) then if((lldx < ncol).or.(lldy < ncol)) then
info=3010 info=3010
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
@ -485,8 +460,6 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
iwork => null() iwork => null()
! check for presence/size of a work area ! check for presence/size of a work area
liwork= 2*ncol liwork= 2*ncol
if (a%pr(1) /= 0) llwork = liwork + m * ik
if (a%pl(1) /= 0) llwork = llwork + m * ik
if (present(work)) then if (present(work)) then
if (size(work) >= liwork) then if (size(work) >= liwork) then
@ -500,7 +473,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
if (aliw) then if (aliw) then
allocate(iwork(liwork),stat=info) allocate(iwork(liwork),stat=info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_realloc' ch_err='psb_realloc'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -528,24 +501,24 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
& call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx) & call psb_chkvect(m,ik,size(x),ix,jx,desc_a,info,iix,jjx)
if (info == 0) & if (info == 0) &
& call psb_chkvect(m,ik,size(y),iy,jy,desc_a,info,iiy,jjy) & call psb_chkvect(m,ik,size(y),iy,jy,desc_a,info,iiy,jjy)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_chkvect/mat' ch_err='psb_chkvect/mat'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
goto 9999 goto 9999
end if end if
if(ja.ne.ix) then if(ja /= ix) then
! this case is not yet implemented ! this case is not yet implemented
info = 3030 info = 3030
end if end if
if((iix.ne.1).or.(iiy.ne.1)) then if((iix /= 1).or.(iiy /= 1)) then
! this case is not yet implemented ! this case is not yet implemented
info = 3040 info = 3040
end if end if
if(info.ne.0) then if(info /= 0) then
call psb_errpush(info,name) call psb_errpush(info,name)
goto 9999 goto 9999
end if end if
@ -555,7 +528,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
yp => y(iiy:lldy) yp => y(iiy:lldy)
call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans) call psb_cssm(alpha,a,xp,beta,yp,info,unitd=lunitd,d=id,trans=itrans)
if(info.ne.0) then if(info /= 0) then
info = 4010 info = 4010
ch_err='dcssm' ch_err='dcssm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -563,36 +536,16 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
end if end if
! update overlap elements ! update overlap elements
if(lchoice.gt.0) then if(choice_ > 0) then
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
& zone,yp,desc_a,iwork,info) & zone,yp,desc_a,iwork,info,data=psb_comm_ovr_)
i=0
! switch on update type if (info == 0) call psi_ovrl_upd(yp,desc_a,choice_,info)
select case (lchoice) if (info /= 0) then
case(psb_square_root_) call psb_errpush(4010,name,a_err='Inner updates')
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& sqrt(real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_)))
i = i+2
end do
case(psb_avg_)
do while(desc_a%ovrlap_elem(i).ne.-ione)
y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_)) =&
& y(desc_a%ovrlap_elem(i+psb_ovrlp_elem_))/&
& real(desc_a%ovrlap_elem(i+psb_n_dom_ovr_))
i = i+2
end do
case(psb_sum_)
! do nothing
case default
! wrong value for choice argument
info = 70
int_err=(/10,lchoice,0,0,0/)
call psb_errpush(info,name,i_err=int_err)
goto 9999 goto 9999
end select end if
end if end if
if (aliw) deallocate(iwork) if (aliw) deallocate(iwork)
@ -604,7 +557,7 @@ subroutine psb_zspsv(alpha,a,x,beta,y,desc_a,info,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error(ictxt) call psb_error(ictxt)
return return
end if end if

@ -108,7 +108,7 @@ subroutine psb_cest(afmt,m,n,nnz, lia1, lia2, lar, iup,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if ( err_act .ne. 0 ) then if ( err_act /= 0 ) then
call psb_error() call psb_error()
return return
endif endif

@ -473,7 +473,7 @@ subroutine psb_dcoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -80,7 +80,7 @@ subroutine psb_dcsmm(alpha,a,b,beta,c,info,trans)
& b,lb,beta,c,lc,work,iwsz,info) & b,lb,beta,c,lc,work,iwsz,info)
if (info.ne.0) then if (info /= 0) then
info = 4010 info = 4010
ch_err='Serial csmm' ch_err='Serial csmm'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -90,7 +90,7 @@ subroutine psb_dcsmm(alpha,a,b,beta,c,info,trans)
end if end if
deallocate(work,stat=info) deallocate(work,stat=info)
if (info.ne.0) then if (info /= 0) then
info = 4010 info = 4010
ch_err='Deallocate' ch_err='Deallocate'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)

@ -76,8 +76,8 @@ subroutine psb_dcsmv(alpha,a,b,beta,c,info,trans)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -81,7 +81,7 @@ real(kind(1.d0)) function psb_dcsnmi(a,info,trans)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -94,7 +94,7 @@ subroutine psb_dcsrws(rw,a,info,trans)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -87,8 +87,8 @@ subroutine psb_dcssm(alpha,t,b,beta,c,info,trans,unitd,d)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -87,8 +87,8 @@ subroutine psb_dcssv(alpha,t,b,beta,c,info,trans,unitd,d)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -84,17 +84,17 @@ subroutine psb_dfixcoo(a,info,idir)
case(0) ! Row major order case(0) ! Row major order
call msort_up(nza,a%ia1(1),iaux(1),iret) call msort_up(nza,a%ia1(1),iaux(1),iret)
if (iret.eq.0) call reordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1)) if (iret == 0) call reordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1))
i = 1 i = 1
j = i j = i
do while (i.le.nza) do while (i <= nza)
do while ((a%ia1(j).eq.a%ia1(i))) do while ((a%ia1(j) == a%ia1(i)))
j = j+1 j = j+1
if (j > nza) exit if (j > nza) exit
enddo enddo
nzl = j - i nzl = j - i
call msort_up(nzl,a%ia2(i),iaux(1),iret) call msort_up(nzl,a%ia2(i),iaux(1),iret)
if (iret.eq.0) & if (iret == 0) &
& call reordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1)) & call reordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1))
i = j i = j
enddo enddo
@ -165,17 +165,17 @@ subroutine psb_dfixcoo(a,info,idir)
case(1) ! Col major order case(1) ! Col major order
call msort_up(nza,a%ia2(1),iaux(1),iret) call msort_up(nza,a%ia2(1),iaux(1),iret)
if (iret.eq.0) call reordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1)) if (iret == 0) call reordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1))
i = 1 i = 1
j = i j = i
do while (i.le.nza) do while (i <= nza)
do while ((a%ia2(j).eq.a%ia2(i))) do while ((a%ia2(j) == a%ia2(i)))
j = j+1 j = j+1
if (j > nza) exit if (j > nza) exit
enddo enddo
nzl = j - i nzl = j - i
call msort_up(nzl,a%ia1(i),iaux(1),iret) call msort_up(nzl,a%ia1(i),iaux(1),iret)
if (iret.eq.0) & if (iret == 0) &
& call reordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1)) & call reordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1))
i = j i = j
enddo enddo
@ -254,7 +254,7 @@ subroutine psb_dfixcoo(a,info,idir)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -204,7 +204,7 @@ subroutine psb_dipcoo2csc(a,info,clshr)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -203,7 +203,7 @@ subroutine psb_dipcoo2csr(a,info,rwshr)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -92,7 +92,7 @@ Subroutine psb_dipcsr2coo(a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -86,7 +86,7 @@ subroutine psb_dneigh(a,idx,neigh,n,info,lev)
ntl = 0 ntl = 0
do i=ifl,ill do i=ifl,ill
nidx=neigh(i) nidx=neigh(i)
if ((nidx.ne.idx).and.(nidx.gt.0).and.(nidx.le.a%m)) then if ((nidx /= idx).and.(nidx > 0).and.(nidx <= a%m)) then
call psb_sp_getrow(nidx,a,nn,ia,ja,val,info) call psb_sp_getrow(nidx,a,nn,ia,ja,val,info)
if (info==0) call psb_ensure_size(ill+ntl+nn,neigh,info) if (info==0) call psb_ensure_size(ill+ntl+nn,neigh,info)
if (info /= 0) then if (info /= 0) then
@ -109,7 +109,7 @@ subroutine psb_dneigh(a,idx,neigh,n,info,lev)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -165,7 +165,7 @@ subroutine psb_drwextd(nr,a,info,b,rowscale)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -146,7 +146,7 @@ subroutine psb_dspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -360,7 +360,7 @@ subroutine psb_dspcnv2(a, b,info,afmt,upd,dupl)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -550,7 +550,7 @@ subroutine psb_dspcnv1(a, info, afmt, upd, dupl)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -118,7 +118,7 @@ subroutine psb_dspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
9999 continue 9999 continue
!!$ call psb_erractionrestore(err_act) !!$ call psb_erractionrestore(err_act)
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -89,7 +89,7 @@ subroutine psb_dspgtdiag(a,d,info)
do i=1, rng, nrb do i=1, rng, nrb
irb=min(i+nrb-1,rng) irb=min(i+nrb-1,rng)
call psb_sp_getblk(i,a,tmpa,info,lrw=irb) call psb_sp_getblk(i,a,tmpa,info,lrw=irb)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='psb_sp_getblk' ch_err='psb_sp_getblk'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -112,7 +112,7 @@ subroutine psb_dspgtdiag(a,d,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -88,7 +88,7 @@ subroutine psb_dspscal(a,d,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -100,7 +100,7 @@ subroutine psb_dsymbmm(a,b,c,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -160,7 +160,7 @@ contains
info=2 info=2
return return
else else
if(index(ibcl(k)).eq.0) then if(index(ibcl(k)) == 0) then
index(ibcl(k))=istart index(ibcl(k))=istart
istart=ibcl(k) istart=ibcl(k)
length=length+1 length=length+1

@ -351,7 +351,7 @@ contains
j=0 j=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
nz=nz+ia3(j)-ia2(j) nz=nz+ia3(j)-ia2(j)
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
@ -359,7 +359,7 @@ contains
row = ia3(j)+rb row = ia3(j)+rb
nz = nz+ja_(row+1)-ja_(row) nz = nz+ja_(row+1)-ja_(row)
exit blkfnd exit blkfnd
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
nz=nz+ia3(j-1)-ia2(j-1) nz=nz+ia3(j-1)-ia2(j-1)
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
@ -775,7 +775,7 @@ contains
j=0 j=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
nz=nz+ia3(j)-ia2(j) nz=nz+ia3(j)-ia2(j)
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
@ -783,7 +783,7 @@ contains
row = ia3(j)+rb row = ia3(j)+rb
nz = nz+ja_(row+1)-ja_(row) nz = nz+ja_(row+1)-ja_(row)
exit blkfnd exit blkfnd
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
nz=nz+ia3(j-1)-ia2(j-1) nz=nz+ia3(j-1)-ia2(j-1)
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block

@ -110,7 +110,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -216,7 +216,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -321,7 +321,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -428,7 +428,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -532,7 +532,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -637,7 +637,7 @@ contains
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -708,13 +708,13 @@ contains
j=0 j=0
blkfnd_gtl: do blkfnd_gtl: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
exit blkfnd_gtl exit blkfnd_gtl
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
@ -800,13 +800,13 @@ contains
j=0 j=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
exit blkfnd exit blkfnd
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
@ -1424,13 +1424,13 @@ contains
j=0 j=0
blkfnd_gtl: do blkfnd_gtl: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
exit blkfnd_gtl exit blkfnd_gtl
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
@ -1516,13 +1516,13 @@ contains
j=0 j=0
blkfnd: do blkfnd: do
j=j+1 j=j+1
if(ia1(j).eq.indices(i)) then if(ia1(j) == indices(i)) then
blks(i)=j blks(i)=j
ipx = ia1(j) ! the first row index of the block ipx = ia1(j) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block
row = ia3(j)+rb row = ia3(j)+rb
exit blkfnd exit blkfnd
else if(ia1(j).gt.indices(i)) then else if(ia1(j) > indices(i)) then
blks(i)=j-1 blks(i)=j-1
ipx = ia1(j-1) ! the first row index of the block ipx = ia1(j-1) ! the first row index of the block
rb = indices(i)-ipx ! the row offset within the block rb = indices(i)-ipx ! the row offset within the block

@ -442,7 +442,7 @@ subroutine psb_zcoins(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl,rebuild)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -76,8 +76,8 @@ subroutine psb_zcsmm(alpha,a,b,beta,c,info,trans)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -76,8 +76,8 @@ subroutine psb_zcsmv(alpha,a,b,beta,c,info,trans)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -81,7 +81,7 @@ real(kind(1.d0)) function psb_zcsnmi(a,info,trans)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -94,7 +94,7 @@ subroutine psb_zcsrws(rw,a,info,trans)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -87,8 +87,8 @@ subroutine psb_zcssm(alpha,t,b,beta,c,info,trans,unitd,d)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -87,8 +87,8 @@ subroutine psb_zcssv(alpha,t,b,beta,c,info,trans,unitd,d)
deallocate(work) deallocate(work)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if(info.ne.0) then if(info /= 0) then
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -84,17 +84,17 @@ Subroutine psb_zfixcoo(a,info,idir)
case(0) ! Row major order case(0) ! Row major order
call msort_up(nza,a%ia1(1),iaux(1),iret) call msort_up(nza,a%ia1(1),iaux(1),iret)
if (iret.eq.0) call zreordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1)) if (iret == 0) call zreordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1))
i = 1 i = 1
j = i j = i
do while (i.le.nza) do while (i <= nza)
do while ((a%ia1(j).eq.a%ia1(i))) do while ((a%ia1(j) == a%ia1(i)))
j = j+1 j = j+1
if (j > nza) exit if (j > nza) exit
enddo enddo
nzl = j - i nzl = j - i
call msort_up(nzl,a%ia2(i),iaux(1),iret) call msort_up(nzl,a%ia2(i),iaux(1),iret)
if (iret.eq.0) & if (iret == 0) &
& call zreordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1)) & call zreordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1))
i = j i = j
enddo enddo
@ -165,17 +165,17 @@ Subroutine psb_zfixcoo(a,info,idir)
case(1) ! Col major order case(1) ! Col major order
call msort_up(nza,a%ia2(1),iaux(1),iret) call msort_up(nza,a%ia2(1),iaux(1),iret)
if (iret.eq.0) call zreordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1)) if (iret == 0) call zreordvn(nza,a%aspk(1),a%ia1(1),a%ia2(1),iaux(1))
i = 1 i = 1
j = i j = i
do while (i.le.nza) do while (i <= nza)
do while ((a%ia2(j).eq.a%ia2(i))) do while ((a%ia2(j) == a%ia2(i)))
j = j+1 j = j+1
if (j > nza) exit if (j > nza) exit
enddo enddo
nzl = j - i nzl = j - i
call msort_up(nzl,a%ia1(i),iaux(1),iret) call msort_up(nzl,a%ia1(i),iaux(1),iret)
if (iret.eq.0) & if (iret == 0) &
& call zreordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1)) & call zreordvn(nzl,a%aspk(i),a%ia1(i),a%ia2(i),iaux(1))
i = j i = j
enddo enddo
@ -254,7 +254,7 @@ Subroutine psb_zfixcoo(a,info,idir)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -104,7 +104,7 @@ subroutine psb_zgelp(trans,iperm,x,info)
call zgelp(trans,i1sz,i2sz,itemp,x,i1sz,dtemp,i1sz,info) call zgelp(trans,i1sz,i2sz,itemp,x,i1sz,dtemp,i1sz,info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='zgelp' ch_err='zgelp'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)
@ -237,7 +237,7 @@ subroutine psb_zgelpv(trans,iperm,x,info)
call zgelp(trans,i1sz,1,itemp,x,i1sz,dtemp,i1sz,info) call zgelp(trans,i1sz,1,itemp,x,i1sz,dtemp,i1sz,info)
if(info.ne.0) then if(info /= 0) then
info=4010 info=4010
ch_err='zgelp' ch_err='zgelp'
call psb_errpush(info,name,a_err=ch_err) call psb_errpush(info,name,a_err=ch_err)

@ -204,7 +204,7 @@ subroutine psb_zipcoo2csc(a,info,clshr)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -203,7 +203,7 @@ subroutine psb_zipcoo2csr(a,info,rwshr)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -92,7 +92,7 @@ Subroutine psb_zipcsr2coo(a,info)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -86,7 +86,7 @@ subroutine psb_zneigh(a,idx,neigh,n,info,lev)
ntl = 0 ntl = 0
do i=ifl,ill do i=ifl,ill
nidx=neigh(i) nidx=neigh(i)
if ((nidx.ne.idx).and.(nidx.gt.0).and.(nidx.le.a%m)) then if ((nidx /= idx).and.(nidx > 0).and.(nidx <= a%m)) then
call psb_sp_getrow(nidx,a,nn,ia,ja,val,info) call psb_sp_getrow(nidx,a,nn,ia,ja,val,info)
if (info==0) call psb_ensure_size(ill+ntl+nn,neigh,info) if (info==0) call psb_ensure_size(ill+ntl+nn,neigh,info)
if (info /= 0) then if (info /= 0) then
@ -109,7 +109,7 @@ subroutine psb_zneigh(a,idx,neigh,n,info,lev)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -164,7 +164,7 @@ subroutine psb_zrwextd(nr,a,info,b,rowscale)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -146,7 +146,7 @@ subroutine psb_zspclip(a,b,info,imin,imax,jmin,jmax,rscale,cscale)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -360,7 +360,7 @@ subroutine psb_zspcnv2(a, b,info,afmt,upd,dupl)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if
@ -550,7 +550,7 @@ subroutine psb_zspcnv1(a, info, afmt, upd, dupl)
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

@ -118,7 +118,7 @@ subroutine psb_zspgetrow(irw,a,nz,ia,ja,val,info,iren,lrw,append,nzin)
9999 continue 9999 continue
!!$ call psb_erractionrestore(err_act) !!$ call psb_erractionrestore(err_act)
call psb_erractionsave(err_act) call psb_erractionsave(err_act)
if (err_act.eq.psb_act_abort_) then if (err_act == psb_act_abort_) then
call psb_error() call psb_error()
return return
end if end if

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save