|
|
@ -59,7 +59,7 @@
|
|
|
|
! jx - integer(optional). The column offset for ( X ). Default: 1
|
|
|
|
! jx - integer(optional). The column offset for ( X ). Default: 1
|
|
|
|
! jy - integer(optional). The column offset for ( Y ). Default: 1
|
|
|
|
! jy - integer(optional). The column offset for ( Y ). Default: 1
|
|
|
|
! work(:) - complex,(optional). Working area.
|
|
|
|
! work(:) - complex,(optional). Working area.
|
|
|
|
! doswap - integer(optional). Whether to performe halo updates.
|
|
|
|
! doswap - logical(optional). Whether to performe halo updates.
|
|
|
|
!
|
|
|
|
!
|
|
|
|
subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
& trans, k, jx, jy, work, doswap)
|
|
|
|
& trans, k, jx, jy, work, doswap)
|
|
|
@ -83,18 +83,19 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
integer, intent(out) :: info
|
|
|
|
integer, intent(out) :: info
|
|
|
|
complex(kind(1.d0)), optional, target :: work(:)
|
|
|
|
complex(kind(1.d0)), optional, target :: work(:)
|
|
|
|
character, intent(in), optional :: trans
|
|
|
|
character, intent(in), optional :: trans
|
|
|
|
integer, intent(in), optional :: k, jx, jy,doswap
|
|
|
|
integer, intent(in), optional :: k, jx, jy
|
|
|
|
|
|
|
|
logical, intent(in), optional :: doswap
|
|
|
|
|
|
|
|
|
|
|
|
! locals
|
|
|
|
! locals
|
|
|
|
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,&
|
|
|
|
& idoswap, m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,&
|
|
|
|
& m, nrow, ncol, lldx, lldy, liwork, iiy, jjy,&
|
|
|
|
& i, ib, ib1
|
|
|
|
& i, ib, ib1
|
|
|
|
integer, parameter :: nb=4
|
|
|
|
integer, parameter :: nb=4
|
|
|
|
complex(kind(1.d0)),pointer :: xp(:,:), yp(:,:), iwork(:)
|
|
|
|
complex(kind(1.d0)),pointer :: xp(:,:), yp(:,:), iwork(:)
|
|
|
|
character :: itrans
|
|
|
|
character :: trans_
|
|
|
|
character(len=20) :: name, ch_err
|
|
|
|
character(len=20) :: name, ch_err
|
|
|
|
logical :: aliw
|
|
|
|
logical :: aliw, doswap_
|
|
|
|
|
|
|
|
|
|
|
|
name='psb_zspmm'
|
|
|
|
name='psb_zspmm'
|
|
|
|
if(psb_get_errstatus() /= 0) return
|
|
|
|
if(psb_get_errstatus() /= 0) return
|
|
|
@ -102,6 +103,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
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 == -1) then
|
|
|
|
if (np == -1) then
|
|
|
|
info = 2010
|
|
|
|
info = 2010
|
|
|
@ -127,9 +129,9 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if (present(doswap)) then
|
|
|
|
if (present(doswap)) then
|
|
|
|
idoswap = doswap
|
|
|
|
doswap_ = doswap
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idoswap = 1
|
|
|
|
doswap_ = .true.
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if (present(k)) then
|
|
|
|
if (present(k)) then
|
|
|
@ -140,17 +142,17 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if (present(trans)) then
|
|
|
|
if (present(trans)) then
|
|
|
|
if ( (toupper(trans) == 'N').or.(toupper(trans) == 'T').or.&
|
|
|
|
trans_ = toupper(trans)
|
|
|
|
& (toupper(trans) == 'C')) then
|
|
|
|
|
|
|
|
itrans = toupper(trans)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
info = 70
|
|
|
|
|
|
|
|
call psb_errpush(info,name)
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
itrans = 'N'
|
|
|
|
trans_ = 'N'
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ( (trans_ == 'N').or.(trans_ == 'T')&
|
|
|
|
|
|
|
|
& .or.(trans_ == 'C')) then
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
info = 70
|
|
|
|
|
|
|
|
call psb_errpush(info,name)
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
m = psb_cd_get_global_rows(desc_a)
|
|
|
|
m = psb_cd_get_global_rows(desc_a)
|
|
|
|
n = psb_cd_get_global_cols(desc_a)
|
|
|
|
n = psb_cd_get_global_cols(desc_a)
|
|
|
@ -197,7 +199,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (itrans == 'N') then
|
|
|
|
if (trans_ == 'N') then
|
|
|
|
! Matrix is not transposed
|
|
|
|
! Matrix is not transposed
|
|
|
|
if((ja /= ix).or.(ia /= iy)) then
|
|
|
|
if((ja /= ix).or.(ia /= iy)) then
|
|
|
|
! this case is not yet implemented
|
|
|
|
! this case is not yet implemented
|
|
|
@ -208,7 +210,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
|
|
|
|
|
|
|
|
! checking for vectors correctness
|
|
|
|
! checking for vectors correctness
|
|
|
|
call psb_chkvect(n,ik,size(x,1),ix,ijx,desc_a,info,iix,jjx)
|
|
|
|
call psb_chkvect(n,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 /= 0) then
|
|
|
|
if(info /= 0) then
|
|
|
|
info=4010
|
|
|
|
info=4010
|
|
|
@ -227,7 +229,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
|
|
|
|
|
|
|
|
ib1=min(nb,ik)
|
|
|
|
ib1=min(nb,ik)
|
|
|
|
xp => x(iix:lldx,jjx:jjx+ib1-1)
|
|
|
|
xp => x(iix:lldx,jjx:jjx+ib1-1)
|
|
|
|
if(idoswap > 0)&
|
|
|
|
if (doswap_)&
|
|
|
|
& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
& call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
& ib1,zzero,xp,desc_a,iwork,info)
|
|
|
|
& ib1,zzero,xp,desc_a,iwork,info)
|
|
|
|
|
|
|
|
|
|
|
@ -236,7 +238,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
ib=ib1
|
|
|
|
ib=ib1
|
|
|
|
ib1 = max(0,min(nb,(ik)-(i-1+ib)))
|
|
|
|
ib1 = max(0,min(nb,(ik)-(i-1+ib)))
|
|
|
|
xp => x(iix:lldx,jjx+i+ib-1:jjx+i+ib+ib1-2)
|
|
|
|
xp => x(iix:lldx,jjx+i+ib-1:jjx+i+ib+ib1-2)
|
|
|
|
if((ib1 > 0).and.(idoswap > 0))&
|
|
|
|
if ((ib1 > 0).and.(doswap_)) &
|
|
|
|
& call psi_swapdata(psb_swap_send_,ib1,&
|
|
|
|
& call psi_swapdata(psb_swap_send_,ib1,&
|
|
|
|
& zzero,xp,desc_a,iwork,info)
|
|
|
|
& zzero,xp,desc_a,iwork,info)
|
|
|
|
|
|
|
|
|
|
|
@ -244,11 +246,11 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
|
|
|
|
|
|
|
|
! local Matrix-vector product
|
|
|
|
! local Matrix-vector product
|
|
|
|
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ib-1),&
|
|
|
|
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ib-1),&
|
|
|
|
& beta,y(iiy:lldy,jjy:jjy+ib-1),info,trans=itrans)
|
|
|
|
& beta,y(iiy:lldy,jjy:jjy+ib-1),info,trans=trans_)
|
|
|
|
|
|
|
|
|
|
|
|
if(info /= 0) exit blk
|
|
|
|
if(info /= 0) exit blk
|
|
|
|
|
|
|
|
|
|
|
|
if((ib1 > 0).and.(idoswap > 0))&
|
|
|
|
if((ib1 > 0).and.(doswap_))&
|
|
|
|
& call psi_swapdata(psb_swap_send_,ib1,&
|
|
|
|
& call psi_swapdata(psb_swap_send_,ib1,&
|
|
|
|
& zzero,xp,desc_a,iwork,info)
|
|
|
|
& zzero,xp,desc_a,iwork,info)
|
|
|
|
|
|
|
|
|
|
|
@ -299,7 +301,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
! local Matrix-vector product
|
|
|
|
! local Matrix-vector product
|
|
|
|
|
|
|
|
|
|
|
|
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ik-1),&
|
|
|
|
call psb_csmm(alpha,a,x(iix:lldx,jjx:jjx+ik-1),&
|
|
|
|
& beta,y(iiy:lldy,jjy:jjy+ik-1),info,trans=itrans)
|
|
|
|
& beta,y(iiy:lldy,jjy:jjy+ik-1),info,trans=trans_)
|
|
|
|
|
|
|
|
|
|
|
|
if(info /= 0) then
|
|
|
|
if(info /= 0) then
|
|
|
|
info = 4010
|
|
|
|
info = 4010
|
|
|
@ -309,7 +311,7 @@ subroutine psb_zspmm(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
yp => y(iiy:lldy,jjy:jjy+ik-1)
|
|
|
|
yp => y(iiy:lldy,jjy:jjy+ik-1)
|
|
|
|
if (idoswap/=0)&
|
|
|
|
if (doswap_) &
|
|
|
|
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
& call psi_swaptran(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
& ik,zone,yp,desc_a,iwork,info)
|
|
|
|
& ik,zone,yp,desc_a,iwork,info)
|
|
|
|
|
|
|
|
|
|
|
@ -392,7 +394,7 @@ end subroutine psb_zspmm
|
|
|
|
! info - integer. Return code
|
|
|
|
! info - integer. Return code
|
|
|
|
! trans - character(optional). Whether A or A'. Default: 'N'
|
|
|
|
! trans - character(optional). Whether A or A'. Default: 'N'
|
|
|
|
! work(:) - complex,(optional). Working area.
|
|
|
|
! work(:) - complex,(optional). Working area.
|
|
|
|
! doswap - integer(optional). Whether to performe halo updates.
|
|
|
|
! doswap - logical(optional). Whether to performe halo updates.
|
|
|
|
!
|
|
|
|
!
|
|
|
|
subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
& trans, work, doswap)
|
|
|
|
& trans, work, doswap)
|
|
|
@ -417,18 +419,18 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
integer, intent(out) :: info
|
|
|
|
integer, intent(out) :: info
|
|
|
|
complex(kind(1.d0)), optional, target :: work(:)
|
|
|
|
complex(kind(1.d0)), optional, target :: work(:)
|
|
|
|
character, intent(in), optional :: trans
|
|
|
|
character, intent(in), optional :: trans
|
|
|
|
integer, intent(in), optional :: doswap
|
|
|
|
logical, intent(in), optional :: doswap
|
|
|
|
|
|
|
|
|
|
|
|
! locals
|
|
|
|
! locals
|
|
|
|
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, &
|
|
|
|
& idoswap, m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,&
|
|
|
|
& m, nrow, ncol, lldx, lldy, liwork, jx, jy, iiy, jjy,&
|
|
|
|
& ib
|
|
|
|
& ib
|
|
|
|
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 :: itrans
|
|
|
|
character :: trans_
|
|
|
|
character(len=20) :: name, ch_err
|
|
|
|
character(len=20) :: name, ch_err
|
|
|
|
logical :: aliw
|
|
|
|
logical :: aliw, doswap_
|
|
|
|
integer :: debug_level, debug_unit
|
|
|
|
integer :: debug_level, debug_unit
|
|
|
|
|
|
|
|
|
|
|
|
name='psb_zspmv'
|
|
|
|
name='psb_zspmv'
|
|
|
@ -456,23 +458,23 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
ib = 1
|
|
|
|
ib = 1
|
|
|
|
|
|
|
|
|
|
|
|
if (present(doswap)) then
|
|
|
|
if (present(doswap)) then
|
|
|
|
idoswap = doswap
|
|
|
|
doswap_ = doswap
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idoswap = 1
|
|
|
|
doswap_ = 1
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
if (present(trans)) then
|
|
|
|
if (present(trans)) then
|
|
|
|
if ( (toupper(trans) == 'N').or.(toupper(trans) == 'T') .or.&
|
|
|
|
trans_ = toupper(trans)
|
|
|
|
& (toupper(trans) == 'C')) then
|
|
|
|
|
|
|
|
itrans = toupper(trans)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
info = 70
|
|
|
|
|
|
|
|
call psb_errpush(info,name)
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
itrans = 'N'
|
|
|
|
trans_ = 'N'
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
if ( (trans_ == 'N').or.(trans_ == 'T')&
|
|
|
|
|
|
|
|
& .or.(trans_ == 'C')) then
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
info = 70
|
|
|
|
|
|
|
|
call psb_errpush(info,name)
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
m = psb_cd_get_global_rows(desc_a)
|
|
|
|
m = psb_cd_get_global_rows(desc_a)
|
|
|
|
n = psb_cd_get_global_cols(desc_a)
|
|
|
|
n = psb_cd_get_global_cols(desc_a)
|
|
|
@ -522,7 +524,7 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
|
|
|
|
|
|
|
|
if (debug_level >= psb_debug_comp_) &
|
|
|
|
if (debug_level >= psb_debug_comp_) &
|
|
|
|
& write(debug_unit,*) me,' ',trim(name),' Checkmat ', info
|
|
|
|
& write(debug_unit,*) me,' ',trim(name),' Checkmat ', info
|
|
|
|
if (itrans == 'N') then
|
|
|
|
if (trans_ == 'N') then
|
|
|
|
! Matrix is not transposed
|
|
|
|
! Matrix is not transposed
|
|
|
|
if((ja /= ix).or.(ia /= iy)) then
|
|
|
|
if((ja /= ix).or.(ia /= iy)) then
|
|
|
|
! this case is not yet implemented
|
|
|
|
! this case is not yet implemented
|
|
|
@ -549,9 +551,7 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
if (idoswap == 0) then
|
|
|
|
if (doswap_) then
|
|
|
|
x(nrow+1:ncol)=zzero
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
call psi_swapdata(ior(psb_swap_send_,psb_swap_recv_),&
|
|
|
|
& zzero,x,desc_a,iwork,info,data=psb_comm_halo_)
|
|
|
|
& zzero,x,desc_a,iwork,info,data=psb_comm_halo_)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
@ -605,8 +605,9 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
if (debug_level >= psb_debug_comp_) &
|
|
|
|
if (debug_level >= psb_debug_comp_) &
|
|
|
|
& write(debug_unit,*) me,' ',trim(name),' checkvect ', info
|
|
|
|
& 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=itrans)
|
|
|
|
call psb_csmm(alpha,a,xp,beta,yp,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='zcsmm'
|
|
|
|
ch_err='zcsmm'
|
|
|
@ -614,7 +615,7 @@ subroutine psb_zspmv(alpha,a,x,beta,y,desc_a,info,&
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
if(idoswap /= 0)&
|
|
|
|
if (doswap_)&
|
|
|
|
& 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 (debug_level >= psb_debug_comp_) &
|
|
|
|
if (debug_level >= psb_debug_comp_) &
|
|
|
|