You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
5020 lines
121 KiB
Fortran
5020 lines
121 KiB
Fortran
!!$
|
|
!!$ Parallel Sparse BLAS version 2.2
|
|
!!$ (C) Copyright 2006/2007/2008
|
|
!!$ 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.
|
|
!!$
|
|
!!$
|
|
#if defined(SERIAL_MPI)
|
|
! Provide a fake mpi module just to keep the compiler(s) happy.
|
|
module mpi
|
|
integer, parameter :: mpi_success=0
|
|
integer, parameter :: mpi_request_null=0
|
|
integer, parameter :: mpi_status_size=1
|
|
integer, parameter :: mpi_integer=1, mpi_double_precision=3
|
|
integer, parameter :: mpi_double_complex=5
|
|
real(kind(1.d0)), external :: mpi_wtime
|
|
end module mpi
|
|
#endif
|
|
|
|
module psb_penv_mod
|
|
|
|
use psb_const_mod
|
|
|
|
interface psb_init
|
|
module procedure psb_init
|
|
end interface
|
|
|
|
interface psb_exit
|
|
module procedure psb_exit
|
|
end interface
|
|
|
|
interface psb_abort
|
|
module procedure psb_abort
|
|
end interface
|
|
|
|
interface psb_info
|
|
module procedure psb_info
|
|
end interface
|
|
|
|
interface psb_barrier
|
|
module procedure psb_barrier
|
|
end interface
|
|
|
|
interface psb_wtime
|
|
module procedure psb_wtime
|
|
end interface
|
|
|
|
interface psb_bcast
|
|
module procedure psb_ibcasts, psb_ibcastv, psb_ibcastm,&
|
|
& psb_dbcasts, psb_dbcastv, psb_dbcastm,&
|
|
& psb_zbcasts, psb_zbcastv, psb_zbcastm,&
|
|
& psb_hbcasts, psb_hbcastv, psb_lbcasts, psb_lbcastv
|
|
end interface
|
|
|
|
|
|
interface psb_snd
|
|
module procedure psb_isnds, psb_isndv, psb_isndm,&
|
|
& psb_dsnds, psb_dsndv, psb_dsndm,&
|
|
& psb_zsnds, psb_zsndv, psb_zsndm,&
|
|
& psb_hsnds, psb_lsnds
|
|
end interface
|
|
|
|
interface psb_rcv
|
|
module procedure psb_ircvs, psb_ircvv, psb_ircvm,&
|
|
& psb_drcvs, psb_drcvv, psb_drcvm,&
|
|
& psb_zrcvs, psb_zrcvv, psb_zrcvm,&
|
|
& psb_hrcvs, psb_lrcvs
|
|
end interface
|
|
|
|
interface psb_max
|
|
module procedure psb_imaxs, psb_imaxv, psb_imaxm,&
|
|
& psb_dmaxs, psb_dmaxv, psb_dmaxm
|
|
end interface
|
|
|
|
|
|
interface psb_min
|
|
module procedure psb_imins, psb_iminv, psb_iminm,&
|
|
& psb_dmins, psb_dminv, psb_dminm
|
|
end interface
|
|
|
|
|
|
interface psb_amx
|
|
module procedure psb_iamxs, psb_iamxv, psb_iamxm,&
|
|
& psb_damxs, psb_damxv, psb_damxm,&
|
|
& psb_zamxs, psb_zamxv, psb_zamxm
|
|
end interface
|
|
|
|
interface psb_amn
|
|
module procedure psb_iamns, psb_iamnv, psb_iamnm,&
|
|
& psb_damns, psb_damnv, psb_damnm,&
|
|
& psb_zamns, psb_zamnv, psb_zamnm
|
|
end interface
|
|
|
|
interface psb_sum
|
|
module procedure psb_isums, psb_isumv, psb_isumm,&
|
|
& psb_dsums, psb_dsumv, psb_dsumm,&
|
|
& psb_zsums, psb_zsumv, psb_zsumm
|
|
end interface
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
interface gebs2d
|
|
module procedure igebs2ds, igebs2dv, igebs2dm,&
|
|
& dgebs2ds, dgebs2dv, dgebs2dm,&
|
|
& zgebs2ds, zgebs2dv, zgebs2dm
|
|
end interface
|
|
|
|
interface gebr2d
|
|
module procedure igebr2ds, igebr2dv, igebr2dm,&
|
|
& dgebr2ds, dgebr2dv, dgebr2dm,&
|
|
& zgebr2ds, zgebr2dv, zgebr2dm
|
|
end interface
|
|
|
|
interface gesd2d
|
|
module procedure igesd2ds, igesd2dv, igesd2dm,&
|
|
& dgesd2ds, dgesd2dv, dgesd2dm,&
|
|
& zgesd2ds, zgesd2dv, zgesd2dm
|
|
end interface
|
|
|
|
interface gerv2d
|
|
module procedure igerv2ds, igerv2dv, igerv2dm,&
|
|
& dgerv2ds, dgerv2dv, dgerv2dm,&
|
|
& zgerv2ds, zgerv2dv, zgerv2dm
|
|
end interface
|
|
|
|
interface gsum2d
|
|
module procedure igsum2ds, igsum2dv, igsum2dm,&
|
|
& dgsum2ds, dgsum2dv, dgsum2dm,&
|
|
& zgsum2ds, zgsum2dv, zgsum2dm
|
|
end interface
|
|
|
|
interface gamx2d
|
|
module procedure igamx2ds, igamx2dv, igamx2dm,&
|
|
& dgamx2ds, dgamx2dv, dgamx2dm,&
|
|
& zgamx2ds, zgamx2dv, zgamx2dm
|
|
end interface
|
|
|
|
|
|
interface gamn2d
|
|
module procedure igamn2ds, igamn2dv, igamn2dm,&
|
|
& dgamn2ds, dgamn2dv, dgamn2dm,&
|
|
& zgamn2ds, zgamn2dv, zgamn2dm
|
|
end interface
|
|
#endif
|
|
|
|
#if defined(SERIAL_MPI)
|
|
integer, private, save :: nctxt=0
|
|
#endif
|
|
|
|
|
|
#if defined(HAVE_KSENDID)
|
|
interface
|
|
integer function krecvid(contxt,proc_to_comm,myrow)
|
|
integer contxt,proc_to_comm,myrow
|
|
end function krecvid
|
|
end interface
|
|
interface
|
|
integer function ksendid(contxt,proc_to_comm,myrow)
|
|
integer contxt,proc_to_comm,myrow
|
|
end function ksendid
|
|
end interface
|
|
#endif
|
|
|
|
contains
|
|
|
|
subroutine psb_init(ictxt,np)
|
|
use psb_const_mod
|
|
use psb_error_mod
|
|
integer, intent(out) :: ictxt
|
|
integer, intent(in), optional :: np
|
|
|
|
integer :: np_, npavail, iam, info
|
|
character(len=20), parameter :: name='psb_init'
|
|
#if defined(SERIAL_MPI)
|
|
ictxt = nctxt
|
|
nctxt = nctxt + 1
|
|
np_ = 1
|
|
#else
|
|
call blacs_pinfo(iam, npavail)
|
|
call blacs_get(izero, izero, ictxt)
|
|
|
|
if (present(np)) then
|
|
np_ = max(1,min(np,npavail))
|
|
else
|
|
np_ = npavail
|
|
endif
|
|
|
|
call blacs_gridinit(ictxt, 'R', np_, ione)
|
|
#endif
|
|
if (present(np)) then
|
|
if (np_ < np) then
|
|
info = 2011
|
|
call psb_errpush(info,name)
|
|
call psb_error(ictxt)
|
|
endif
|
|
endif
|
|
|
|
end subroutine psb_init
|
|
|
|
subroutine psb_exit(ictxt,close)
|
|
integer, intent(in) :: ictxt
|
|
logical, intent(in), optional :: close
|
|
logical :: close_
|
|
integer :: nprow, npcol, myprow, mypcol
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(close)) then
|
|
close_ = close
|
|
else
|
|
close_ = .true.
|
|
end if
|
|
call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol)
|
|
if ((myprow >=0).and.(mypcol>=0)) then
|
|
call blacs_gridexit(ictxt)
|
|
end if
|
|
if (close_) call blacs_exit(0)
|
|
#endif
|
|
end subroutine psb_exit
|
|
|
|
|
|
subroutine psb_barrier(ictxt)
|
|
integer, intent(in) :: ictxt
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call blacs_barrier(ictxt,'All')
|
|
#endif
|
|
|
|
end subroutine psb_barrier
|
|
|
|
function psb_wtime()
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
real(kind(1.d0)) :: psb_wtime
|
|
|
|
psb_wtime = mpi_wtime()
|
|
end function psb_wtime
|
|
|
|
subroutine psb_abort(ictxt)
|
|
integer, intent(in) :: ictxt
|
|
|
|
#if defined(SERIAL_MPI)
|
|
stop
|
|
#else
|
|
call blacs_abort(ictxt,-1)
|
|
#endif
|
|
|
|
end subroutine psb_abort
|
|
|
|
|
|
subroutine psb_info(ictxt,iam,np)
|
|
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(out) :: iam, np
|
|
integer :: nprow, npcol, myprow, mypcol
|
|
|
|
#if defined(SERIAL_MPI)
|
|
iam = 0
|
|
np = 1
|
|
#else
|
|
call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol)
|
|
|
|
iam = myprow
|
|
np = nprow
|
|
#endif
|
|
|
|
end subroutine psb_info
|
|
|
|
|
|
subroutine psb_ibcasts(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_ibcasts
|
|
|
|
subroutine psb_ibcastv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_ibcastv
|
|
|
|
subroutine psb_ibcastm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_ibcastm
|
|
|
|
|
|
subroutine psb_dbcasts(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_dbcasts
|
|
|
|
|
|
subroutine psb_dbcastv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_dbcastv
|
|
|
|
subroutine psb_dbcastm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_dbcastm
|
|
|
|
|
|
subroutine psb_zbcasts(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zbcasts
|
|
|
|
subroutine psb_zbcastv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zbcastv
|
|
|
|
subroutine psb_zbcastm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
|
|
if (iam==root_) then
|
|
call gebs2d(ictxt,'A',dat)
|
|
else
|
|
call gebr2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zbcastm
|
|
|
|
|
|
subroutine psb_hbcasts(ictxt,dat,root,length)
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
character(len=*), intent(inout) :: dat
|
|
integer, intent(in), optional :: root,length
|
|
|
|
integer :: iam, np, root_,icomm,length_,info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
if (present(length)) then
|
|
length_ = length
|
|
else
|
|
length_ = len(dat)
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
call mpi_bcast(dat,length_,MPI_CHARACTER,root_,icomm,info)
|
|
#endif
|
|
|
|
end subroutine psb_hbcasts
|
|
|
|
subroutine psb_hbcastv(ictxt,dat,root)
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
character(len=*), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_,icomm,length_,info, size_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
length_ = len(dat)
|
|
size_ = size(dat)
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
call mpi_bcast(dat,length_*size_,MPI_CHARACTER,root_,icomm,info)
|
|
#endif
|
|
|
|
end subroutine psb_hbcastv
|
|
|
|
subroutine psb_lbcasts(ictxt,dat,root)
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
logical, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_,icomm,info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
call mpi_bcast(dat,1,MPI_LOGICAL,root_,icomm,info)
|
|
#endif
|
|
|
|
end subroutine psb_lbcasts
|
|
|
|
|
|
subroutine psb_lbcastv(ictxt,dat,root)
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
logical, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: iam, np, root_,icomm,info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = psb_root_
|
|
endif
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
call mpi_bcast(dat,size(dat),MPI_LOGICAL,root_,icomm,info)
|
|
#endif
|
|
|
|
end subroutine psb_lbcastv
|
|
|
|
|
|
|
|
subroutine psb_imaxs(ictxt,dat,root)
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer :: root_, dat_
|
|
integer :: iam, np, icomm,info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call mpi_allreduce(dat,dat_,1,mpi_integer,mpi_max,icomm,info)
|
|
dat = dat_
|
|
else
|
|
call mpi_reduce(dat,dat_,1,mpi_integer,mpi_max,root_,icomm,info)
|
|
dat = dat_
|
|
endif
|
|
#endif
|
|
end subroutine psb_imaxs
|
|
subroutine psb_imaxv(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
integer, allocatable :: dat_(:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_=dat
|
|
if (info ==0) call mpi_allreduce(dat_,dat,size(dat),mpi_integer,mpi_max,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_=dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_integer,mpi_max,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_integer,mpi_max,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_imaxv
|
|
subroutine psb_imaxm(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
integer, allocatable :: dat_(:,:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_=dat
|
|
if (info ==0) call mpi_allreduce(dat_,dat,size(dat),mpi_integer,mpi_max,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_=dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_integer,mpi_max,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_integer,mpi_max,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_imaxm
|
|
|
|
subroutine psb_dmaxs(ictxt,dat,root)
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)) :: dat_
|
|
integer :: iam, np, icomm,info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call mpi_allreduce(dat,dat_,1,mpi_double_precision,mpi_max,icomm,info)
|
|
dat = dat_
|
|
else
|
|
call mpi_reduce(dat,dat_,1,mpi_double_precision,mpi_max,root_,icomm,info)
|
|
dat = dat_
|
|
endif
|
|
#endif
|
|
end subroutine psb_dmaxs
|
|
subroutine psb_dmaxv(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)), allocatable :: dat_(:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_ = dat
|
|
if (info ==0) &
|
|
& call mpi_allreduce(dat_,dat,size(dat),mpi_double_precision,mpi_max,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_ = dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_double_precision,mpi_max,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_double_precision,mpi_max,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_dmaxv
|
|
subroutine psb_dmaxm(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)), allocatable :: dat_(:,:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_ = dat
|
|
if (info ==0)&
|
|
& call mpi_allreduce(dat_,dat,size(dat),mpi_double_precision,mpi_max,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_ = dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_double_precision,mpi_max,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_double_precision,mpi_max,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_dmaxm
|
|
|
|
|
|
subroutine psb_imins(ictxt,dat,root)
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer :: root_, dat_
|
|
integer :: iam, np, icomm,info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call mpi_allreduce(dat,dat_,1,mpi_integer,mpi_min,icomm,info)
|
|
dat = dat_
|
|
else
|
|
call mpi_reduce(dat,dat_,1,mpi_integer,mpi_min,root_,icomm,info)
|
|
dat = dat_
|
|
endif
|
|
#endif
|
|
end subroutine psb_imins
|
|
subroutine psb_iminv(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
integer, allocatable :: dat_(:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_=dat
|
|
if (info ==0) call mpi_allreduce(dat_,dat,size(dat),mpi_integer,mpi_min,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_=dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_integer,mpi_min,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_integer,mpi_min,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_iminv
|
|
subroutine psb_iminm(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
integer, allocatable :: dat_(:,:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_=dat
|
|
if (info ==0) call mpi_allreduce(dat_,dat,size(dat),mpi_integer,mpi_min,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_=dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_integer,mpi_min,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_integer,mpi_min,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_iminm
|
|
|
|
subroutine psb_dmins(ictxt,dat,root)
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)) :: dat_
|
|
integer :: iam, np, icomm,info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call mpi_allreduce(dat,dat_,1,mpi_double_precision,mpi_min,icomm,info)
|
|
dat = dat_
|
|
else
|
|
call mpi_reduce(dat,dat_,1,mpi_double_precision,mpi_min,root_,icomm,info)
|
|
dat = dat_
|
|
endif
|
|
#endif
|
|
end subroutine psb_dmins
|
|
subroutine psb_dminv(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)), allocatable :: dat_(:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_ = dat
|
|
if (info ==0) &
|
|
& call mpi_allreduce(dat_,dat,size(dat),mpi_double_precision,mpi_min,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat),dat_,info)
|
|
dat_ = dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_double_precision,mpi_min,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_double_precision,mpi_min,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
end subroutine psb_dminv
|
|
subroutine psb_dminm(ictxt,dat,root)
|
|
use psb_realloc_mod
|
|
#ifdef MPI_MOD
|
|
use mpi
|
|
#endif
|
|
#ifdef MPI_H
|
|
include 'mpif.h'
|
|
#endif
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer :: root_
|
|
real(kind(1.d0)), allocatable :: dat_(:,:)
|
|
integer :: iam, np, icomm, info
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
call psb_info(ictxt,iam,np)
|
|
call psb_get_mpicomm(ictxt,icomm)
|
|
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (root_ == -1) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_ = dat
|
|
if (info ==0) &
|
|
& call mpi_allreduce(dat_,dat,size(dat),mpi_double_precision,mpi_min,icomm,info)
|
|
else
|
|
if (iam==root_) then
|
|
call psb_realloc(size(dat,1),size(dat,2),dat_,info)
|
|
dat_ = dat
|
|
call mpi_reduce(dat_,dat,size(dat),mpi_double_precision,mpi_min,root_,icomm,info)
|
|
else
|
|
call mpi_reduce(dat,dat_,size(dat),mpi_double_precision,mpi_min,root_,icomm,info)
|
|
end if
|
|
endif
|
|
#endif
|
|
|
|
end subroutine psb_dminm
|
|
|
|
|
|
subroutine psb_iamxs(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamx2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamxs
|
|
|
|
subroutine psb_iamxv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamxv
|
|
|
|
subroutine psb_iamxm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamxm
|
|
|
|
|
|
subroutine psb_damxs(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamx2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damxs
|
|
|
|
subroutine psb_damxv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damxv
|
|
|
|
subroutine psb_damxm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damxm
|
|
|
|
|
|
subroutine psb_zamxs(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamx2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamxs
|
|
|
|
subroutine psb_zamxv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamxv
|
|
|
|
subroutine psb_zamxm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamx2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamx2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamxm
|
|
|
|
|
|
|
|
subroutine psb_iamns(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamn2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamns
|
|
|
|
subroutine psb_iamnv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamnv
|
|
|
|
subroutine psb_iamnm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_iamnm
|
|
|
|
|
|
subroutine psb_damns(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamn2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damns
|
|
|
|
subroutine psb_damnv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damnv
|
|
|
|
subroutine psb_damnm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_damnm
|
|
|
|
|
|
subroutine psb_zamns(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia
|
|
|
|
integer :: root_
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
call gamn2d(ictxt,'A',dat,ria=ia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamns
|
|
|
|
subroutine psb_zamnv(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamnv
|
|
|
|
subroutine psb_zamnm(ictxt,dat,root,ia)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
integer, intent(inout), optional :: ia(:,:)
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:,:)
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (present(ia)) then
|
|
ia = 0
|
|
end if
|
|
#else
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
if (present(ia)) then
|
|
allocate(cia(size(ia,1),size(ia,2)))
|
|
call gamn2d(ictxt,'A',dat,ria=ia,cia=cia,rrt=root_)
|
|
else
|
|
call gamn2d(ictxt,'A',dat,rrt=root_)
|
|
endif
|
|
#endif
|
|
end subroutine psb_zamnm
|
|
|
|
|
|
|
|
subroutine psb_isums(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_isums
|
|
|
|
subroutine psb_isumv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
end subroutine psb_isumv
|
|
|
|
subroutine psb_isumm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_isumm
|
|
|
|
|
|
subroutine psb_dsums(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_dsums
|
|
|
|
subroutine psb_dsumv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_dsumv
|
|
|
|
subroutine psb_dsumm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
|
|
#endif
|
|
end subroutine psb_dsumm
|
|
|
|
|
|
subroutine psb_zsums(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_zsums
|
|
|
|
subroutine psb_zsumv(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
integer, allocatable :: cia(:)
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
#endif
|
|
|
|
end subroutine psb_zsumv
|
|
|
|
subroutine psb_zsumm(ictxt,dat,root)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in), optional :: root
|
|
|
|
integer :: root_
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
if (present(root)) then
|
|
root_ = root
|
|
else
|
|
root_ = -1
|
|
endif
|
|
|
|
call gsum2d(ictxt,'A',dat,rrt=root_)
|
|
|
|
#endif
|
|
end subroutine psb_zsumm
|
|
|
|
|
|
|
|
subroutine psb_hsnds(ictxt,dat,dst,length)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
character(len=*), intent(in) :: dat
|
|
integer, intent(in) :: dst
|
|
integer, intent(in), optional :: length
|
|
integer, allocatable :: buffer(:)
|
|
integer :: length_, i
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
if (present(length)) then
|
|
length_ = length
|
|
else
|
|
length_ = len(dat)
|
|
endif
|
|
allocate(buffer(length_))
|
|
do i=1,length_
|
|
buffer(i) = iachar(dat(i:i))
|
|
end do
|
|
|
|
call gesd2d(ictxt,buffer,dst,0)
|
|
#endif
|
|
end subroutine psb_hsnds
|
|
|
|
subroutine psb_hrcvs(ictxt,dat,src,length)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
character(len=*), intent(out) :: dat
|
|
integer, intent(in) :: src
|
|
integer, intent(in), optional :: length
|
|
integer, allocatable :: buffer(:)
|
|
integer :: length_, i
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = ''
|
|
#else
|
|
if (present(length)) then
|
|
length_ = length
|
|
else
|
|
length_ = len(dat)
|
|
endif
|
|
allocate(buffer(length_))
|
|
|
|
call gerv2d(ictxt,buffer,src,0)
|
|
do i=1,length_
|
|
dat(i:i) = achar(buffer(i))
|
|
end do
|
|
#endif
|
|
|
|
end subroutine psb_hrcvs
|
|
|
|
subroutine psb_lsnds(ictxt,dat,dst,length)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
logical, intent(in) :: dat
|
|
integer, intent(in) :: dst
|
|
integer :: i
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
if (dat) then
|
|
i = 1
|
|
else
|
|
i = 0
|
|
endif
|
|
call gesd2d(ictxt,i,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_lsnds
|
|
|
|
subroutine psb_lrcvs(ictxt,dat,src,length)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
logical, intent(out) :: dat
|
|
integer, intent(in) :: src
|
|
integer :: i
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = .false.
|
|
#else
|
|
call gerv2d(ictxt,i,src,0)
|
|
|
|
dat = (i == 1)
|
|
#endif
|
|
|
|
end subroutine psb_lrcvs
|
|
|
|
|
|
subroutine psb_isnds(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_isnds
|
|
|
|
subroutine psb_isndv(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat(:)
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_isndv
|
|
|
|
subroutine psb_isndm(ictxt,dat,dst,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat(:,:)
|
|
integer, intent(in) :: dst
|
|
integer, intent(in), optional :: m
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_isndm
|
|
|
|
|
|
subroutine psb_dsnds(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_dsnds
|
|
|
|
subroutine psb_dsndv(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:)
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_dsndv
|
|
|
|
subroutine psb_dsndm(ictxt,dat,dst,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:,:)
|
|
integer, intent(in) :: dst
|
|
integer, intent(in), optional :: m
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_dsndm
|
|
|
|
|
|
subroutine psb_zsnds(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_zsnds
|
|
|
|
subroutine psb_zsndv(ictxt,dat,dst)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:)
|
|
integer, intent(in) :: dst
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
call gesd2d(ictxt,dat,dst,0)
|
|
#endif
|
|
|
|
end subroutine psb_zsndv
|
|
|
|
subroutine psb_zsndm(ictxt,dat,dst,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:,:)
|
|
integer, intent(in) :: dst
|
|
integer, intent(in), optional :: m
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >1) then
|
|
write(0,*) "Warning: process sending a message in serial mode (to itself)"
|
|
endif
|
|
#else
|
|
|
|
call gesd2d(ictxt,dat,dst,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_zsndm
|
|
|
|
|
|
|
|
subroutine psb_ircvs(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in) :: src
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_ircvs
|
|
|
|
subroutine psb_ircvv(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in) :: src
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_ircvv
|
|
|
|
subroutine psb_ircvm(ictxt,dat,src,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: src
|
|
integer, intent(in), optional :: m
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
|
|
call gerv2d(ictxt,dat,src,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_ircvm
|
|
|
|
|
|
subroutine psb_drcvs(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in) :: src
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_drcvs
|
|
|
|
subroutine psb_drcvv(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in) :: src
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_drcvv
|
|
|
|
subroutine psb_drcvm(ictxt,dat,src,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: src
|
|
integer, intent(in), optional :: m
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_drcvm
|
|
|
|
|
|
subroutine psb_zrcvs(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in) :: src
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_zrcvs
|
|
|
|
subroutine psb_zrcvv(ictxt,dat,src)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in) :: src
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0)
|
|
#endif
|
|
|
|
end subroutine psb_zrcvv
|
|
|
|
subroutine psb_zrcvm(ictxt,dat,src,m)
|
|
use psb_error_mod
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: src
|
|
integer, intent(in), optional :: m
|
|
|
|
|
|
#if defined(SERIAL_MPI)
|
|
if (psb_get_errverbosity() >0) then
|
|
write(0,*) "Warning: process receiving a message in serial mode (to itself)"
|
|
endif
|
|
dat = 0
|
|
#else
|
|
call gerv2d(ictxt,dat,src,0,m)
|
|
#endif
|
|
|
|
end subroutine psb_zrcvm
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if !defined(SERIAL_MPI)
|
|
|
|
subroutine igebs2ds(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt,dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
character :: top_
|
|
|
|
interface
|
|
subroutine igebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v
|
|
character, intent(in) :: scope, top
|
|
end subroutine igebs2d
|
|
end interface
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call igebs2d(ictxt,scope,top_,1,1,dat,1)
|
|
|
|
end subroutine igebs2ds
|
|
|
|
subroutine igebs2dv(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt,dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
|
|
interface
|
|
subroutine igebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine igebs2d
|
|
end interface
|
|
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call igebs2d(ictxt,scope,top_,size(dat,1),1,dat,size(dat,1))
|
|
|
|
end subroutine igebs2dv
|
|
|
|
subroutine igebs2dm(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt,dat(:,:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine igebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine igebs2d
|
|
end interface
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call igebs2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1))
|
|
|
|
end subroutine igebs2dm
|
|
|
|
|
|
|
|
subroutine dgebs2ds(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine dgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v
|
|
character, intent(in) :: scope, top
|
|
end subroutine dgebs2d
|
|
end interface
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call dgebs2d(ictxt,scope,top_,1,1,dat,1)
|
|
|
|
end subroutine dgebs2ds
|
|
|
|
subroutine dgebs2dv(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine dgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine dgebs2d
|
|
end interface
|
|
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call dgebs2d(ictxt,scope,top_,size(dat),1,dat,size(dat))
|
|
|
|
end subroutine dgebs2dv
|
|
|
|
subroutine dgebs2dm(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine dgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine dgebs2d
|
|
end interface
|
|
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call dgebs2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1))
|
|
|
|
end subroutine dgebs2dm
|
|
|
|
|
|
|
|
subroutine zgebs2ds(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine zgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v
|
|
character, intent(in) :: scope, top
|
|
end subroutine zgebs2d
|
|
end interface
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call zgebs2d(ictxt,scope,top_,1,1,dat,1)
|
|
|
|
end subroutine zgebs2ds
|
|
|
|
subroutine zgebs2dv(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine zgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine zgebs2d
|
|
end interface
|
|
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call zgebs2d(ictxt,scope,top_,size(dat),1,dat,size(dat))
|
|
|
|
end subroutine zgebs2dv
|
|
|
|
subroutine zgebs2dm(ictxt,scope,dat,top)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
|
|
interface
|
|
subroutine zgebs2d(ictxt,scope,top,m,n,v,ld)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
end subroutine zgebs2d
|
|
end interface
|
|
|
|
character :: top_
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
|
|
call zgebs2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1))
|
|
|
|
end subroutine zgebs2dm
|
|
|
|
|
|
|
|
|
|
|
|
subroutine dgebr2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgebr2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgebr2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine dgebr2ds
|
|
|
|
subroutine dgebr2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgebr2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine dgebr2dv
|
|
|
|
subroutine dgebr2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgebr2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine dgebr2dm
|
|
|
|
|
|
|
|
|
|
subroutine zgebr2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgebr2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgebr2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine zgebr2ds
|
|
|
|
subroutine zgebr2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgebr2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine zgebr2dv
|
|
|
|
subroutine zgebr2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgebr2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine zgebr2dm
|
|
|
|
|
|
|
|
subroutine igebr2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igebr2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igebr2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine igebr2ds
|
|
|
|
subroutine igebr2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igebr2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine igebr2dv
|
|
|
|
subroutine igebr2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igebr2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igebr2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
integer :: rrt_, crt_
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = 0
|
|
case('C','c')
|
|
rrt_ = 0
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
case default
|
|
rrt_ = 0
|
|
crt_ = 0
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igebr2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine igebr2dm
|
|
|
|
|
|
|
|
subroutine dgesd2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine dgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgesd2d
|
|
end interface
|
|
|
|
call dgesd2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine dgesd2ds
|
|
|
|
|
|
subroutine dgesd2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine dgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgesd2d
|
|
end interface
|
|
|
|
call dgesd2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine dgesd2dv
|
|
|
|
subroutine dgesd2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(in) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
interface
|
|
subroutine dgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(in) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgesd2d
|
|
end interface
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call dgesd2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine dgesd2dm
|
|
|
|
|
|
subroutine igesd2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine igesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igesd2d
|
|
end interface
|
|
|
|
call igesd2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine igesd2ds
|
|
|
|
|
|
subroutine igesd2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine igesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igesd2d
|
|
end interface
|
|
|
|
call igesd2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine igesd2dv
|
|
|
|
subroutine igesd2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(in) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
|
|
interface
|
|
subroutine igesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(in) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igesd2d
|
|
end interface
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call igesd2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine igesd2dm
|
|
|
|
|
|
|
|
subroutine zgesd2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine zgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgesd2d
|
|
end interface
|
|
|
|
call zgesd2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine zgesd2ds
|
|
|
|
|
|
subroutine zgesd2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine zgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgesd2d
|
|
end interface
|
|
|
|
call zgesd2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine zgesd2dv
|
|
|
|
subroutine zgesd2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(in) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
|
|
interface
|
|
subroutine zgesd2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(in) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgesd2d
|
|
end interface
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call zgesd2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine zgesd2dm
|
|
|
|
|
|
|
|
subroutine dgerv2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine dgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgerv2d
|
|
end interface
|
|
|
|
call dgerv2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine dgerv2ds
|
|
|
|
|
|
subroutine dgerv2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine dgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgerv2d
|
|
end interface
|
|
|
|
call dgerv2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine dgerv2dv
|
|
|
|
subroutine dgerv2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
|
|
interface
|
|
subroutine dgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine dgerv2d
|
|
end interface
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call dgerv2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine dgerv2dm
|
|
|
|
|
|
subroutine igerv2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine igerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igerv2d
|
|
end interface
|
|
|
|
call igerv2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine igerv2ds
|
|
|
|
|
|
subroutine igerv2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine igerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igerv2d
|
|
end interface
|
|
|
|
call igerv2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine igerv2dv
|
|
|
|
subroutine igerv2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
|
|
interface
|
|
subroutine igerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine igerv2d
|
|
end interface
|
|
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call igerv2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine igerv2dm
|
|
|
|
|
|
|
|
subroutine zgerv2ds(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine zgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgerv2d
|
|
end interface
|
|
|
|
call zgerv2d(ictxt,1,1,dat,1,rdst,cdst)
|
|
|
|
end subroutine zgerv2ds
|
|
|
|
|
|
subroutine zgerv2dv(ictxt,dat,rdst,cdst)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
integer, intent(in) :: rdst,cdst
|
|
|
|
interface
|
|
subroutine zgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgerv2d
|
|
end interface
|
|
|
|
call zgerv2d(ictxt,size(dat),1,dat,size(dat),rdst,cdst)
|
|
|
|
end subroutine zgerv2dv
|
|
|
|
subroutine zgerv2dm(ictxt,dat,rdst,cdst,m)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
integer, intent(in) :: rdst,cdst
|
|
integer, intent(in), optional :: m
|
|
|
|
integer :: m_
|
|
|
|
interface
|
|
subroutine zgerv2d(ictxt,m,n,v,ld,rd,cd)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(in) :: rd,cd
|
|
end subroutine zgerv2d
|
|
end interface
|
|
|
|
|
|
if (present(m)) then
|
|
m_ = m
|
|
else
|
|
m_ = size(dat,1)
|
|
endif
|
|
|
|
call zgerv2d(ictxt,m_,size(dat,2),dat,size(dat,1),rdst,cdst)
|
|
|
|
end subroutine zgerv2dm
|
|
|
|
|
|
|
|
subroutine dgsum2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgsum2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgsum2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine dgsum2ds
|
|
|
|
subroutine dgsum2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgsum2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine dgsum2dv
|
|
|
|
subroutine dgsum2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call dgsum2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine dgsum2dm
|
|
|
|
|
|
|
|
subroutine igsum2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igsum2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igsum2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine igsum2ds
|
|
|
|
subroutine igsum2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igsum2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine igsum2dv
|
|
|
|
subroutine igsum2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call igsum2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine igsum2dm
|
|
|
|
|
|
|
|
subroutine zgsum2ds(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgsum2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgsum2d(ictxt,scope,top_,1,1,dat,1,rrt_,crt_)
|
|
|
|
end subroutine zgsum2ds
|
|
|
|
subroutine zgsum2dv(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgsum2d(ictxt,scope,top_,size(dat),1,dat,size(dat),rrt_,crt_)
|
|
|
|
end subroutine zgsum2dv
|
|
|
|
subroutine zgsum2dm(ictxt,scope,dat,top,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgsum2d(ictxt,scope,top,m,n,v,ld,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgsum2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
call zgsum2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),rrt_,crt_)
|
|
|
|
end subroutine zgsum2dm
|
|
|
|
|
|
|
|
|
|
subroutine dgamx2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine dgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine dgamx2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call dgamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call dgamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine dgamx2ds
|
|
|
|
|
|
subroutine dgamx2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine dgamx2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call dgamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call dgamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine dgamx2dv
|
|
|
|
subroutine dgamx2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
real(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgamx2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call dgamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call dgamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine dgamx2dm
|
|
|
|
|
|
|
|
subroutine igamx2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine igamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine igamx2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call igamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call igamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine igamx2ds
|
|
|
|
|
|
subroutine igamx2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine igamx2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call igamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call igamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine igamx2dv
|
|
|
|
subroutine igamx2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
integer, intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igamx2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call igamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call igamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine igamx2dm
|
|
|
|
|
|
|
|
subroutine zgamx2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine zgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine zgamx2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call zgamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call zgamx2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine zgamx2ds
|
|
|
|
|
|
subroutine zgamx2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine zgamx2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call zgamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call zgamx2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine zgamx2dv
|
|
|
|
subroutine zgamx2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgamx2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
complex(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgamx2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call zgamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call zgamx2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine zgamx2dm
|
|
|
|
|
|
subroutine dgamn2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine dgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine dgamn2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call dgamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call dgamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine dgamn2ds
|
|
|
|
|
|
subroutine dgamn2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
real(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine dgamn2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call dgamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call dgamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine dgamn2dv
|
|
|
|
subroutine dgamn2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
real(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine dgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
real(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine dgamn2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call dgamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call dgamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine dgamn2dm
|
|
|
|
|
|
|
|
subroutine igamn2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine igamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine igamn2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call igamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call igamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine igamn2ds
|
|
|
|
|
|
subroutine igamn2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
integer, intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine igamn2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call igamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call igamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine igamn2dv
|
|
|
|
subroutine igamn2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
integer, intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine igamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
integer, intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine igamn2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call igamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call igamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine igamn2dm
|
|
|
|
|
|
|
|
subroutine zgamn2ds(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
integer, intent(inout), optional :: ria,cia
|
|
|
|
interface
|
|
subroutine zgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine zgamn2d
|
|
end interface
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).or.present(cia)) then
|
|
call zgamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,1,rrt_,crt_)
|
|
if (present(ria)) ria=ria_(1)
|
|
if (present(cia)) cia=cia_(1)
|
|
else
|
|
call zgamn2d(ictxt,scope,top_,1,1,dat,1,ria_,cia_,-1,rrt_,crt_)
|
|
endif
|
|
end subroutine zgamn2ds
|
|
|
|
|
|
subroutine zgamn2dv(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:)
|
|
character, intent(in) :: scope
|
|
character, intent(in), optional :: top
|
|
integer, intent(inout), optional :: ria(:),cia(:)
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld
|
|
complex(kind(1.d0)), intent(inout) :: v(*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(inout) :: ria(*),cia(*)
|
|
integer, intent(in) :: rrt,crt,ldia
|
|
end subroutine zgamn2d
|
|
end interface
|
|
|
|
integer :: ldia_,ria_(1),cia_(1)
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call zgamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria,cia,min(size(ria),size(cia)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call zgamn2d(ictxt,scope,top_,size(dat),1,dat,size(dat),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine zgamn2dv
|
|
|
|
subroutine zgamn2dm(ictxt,scope,dat,top,ria,cia,rrt,crt)
|
|
integer, intent(in) :: ictxt
|
|
complex(kind(1.d0)), intent(inout) :: dat(:,:)
|
|
character, intent(in) :: scope
|
|
integer, intent(inout), optional :: ria(:,:),cia(:,:)
|
|
character, intent(in), optional :: top
|
|
integer, intent(in), optional :: rrt,crt
|
|
|
|
interface
|
|
subroutine zgamn2d(ictxt,scope,top,m,n,v,ld,ria,cia,ldia,rrt,crt)
|
|
integer, intent(in) :: ictxt,m,n,ld,ldia
|
|
complex(kind(1.d0)), intent(inout) :: v(ld,*)
|
|
integer, intent(inout) :: ria(ldia,*),cia(ldia,*)
|
|
character, intent(in) :: scope, top
|
|
integer, intent(in) :: rrt,crt
|
|
end subroutine zgamn2d
|
|
end interface
|
|
|
|
character :: top_
|
|
integer :: rrt_, crt_
|
|
integer :: ldia_,ria_(1,1),cia_(1,1)
|
|
integer :: nrows,ncols,myrow,mycol
|
|
|
|
|
|
call blacs_gridinfo(ictxt,nrows,ncols,myrow,mycol)
|
|
select case(scope)
|
|
case('R','r')
|
|
rrt_ = myrow
|
|
crt_ = -1
|
|
case('C','c')
|
|
rrt_ = -1
|
|
crt_ = mycol
|
|
case('A','a')
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
case default
|
|
rrt_ = -1
|
|
crt_ = -1
|
|
end select
|
|
|
|
|
|
if (present(top)) then
|
|
top_ = top
|
|
else
|
|
top_ = ' '
|
|
endif
|
|
if (present(rrt)) then
|
|
rrt_ = rrt
|
|
endif
|
|
if (present(crt)) then
|
|
crt_ = crt
|
|
endif
|
|
|
|
if (present(ria).and.present(cia)) then
|
|
call zgamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria,cia,min(size(ria,1),size(cia,1)),rrt_,crt_)
|
|
else
|
|
ldia_ = -1
|
|
call zgamn2d(ictxt,scope,top_,size(dat,1),size(dat,2),dat,size(dat,1),&
|
|
& ria_,cia_,ldia_,rrt_,crt_)
|
|
end if
|
|
|
|
end subroutine zgamn2dm
|
|
#endif
|
|
|
|
|
|
subroutine psb_set_coher(ictxt,isvch)
|
|
integer :: ictxt, isvch
|
|
! Ensure global repeatability for convergence checks.
|
|
#if !defined(HAVE_ESSL_BLACS)
|
|
Call blacs_get(ictxt,15,isvch)
|
|
Call blacs_set(ictxt,15,1)
|
|
#else
|
|
! Do nothing: ESSL does coherence by default,
|
|
! and does not handle req=16
|
|
#endif
|
|
end subroutine psb_set_coher
|
|
subroutine psb_restore_coher(ictxt,isvch)
|
|
integer :: ictxt, isvch
|
|
! Ensure global coherence for convergence checks.
|
|
#if !defined(HAVE_ESSL_BLACS)
|
|
Call blacs_set(ictxt,15,isvch)
|
|
#else
|
|
! Do nothing: ESSL does coherence by default,
|
|
! and does not handle req=15
|
|
#endif
|
|
end subroutine psb_restore_coher
|
|
subroutine psb_get_mpicomm(ictxt,comm)
|
|
integer :: ictxt, comm
|
|
#if !defined(SERIAL_MPI)
|
|
call blacs_get(ictxt,10,comm)
|
|
#else
|
|
comm = ictxt
|
|
#endif
|
|
end subroutine psb_get_mpicomm
|
|
subroutine psb_get_rank(rank,ictxt,id)
|
|
integer :: rank,ictxt, id
|
|
integer :: blacs_pnum
|
|
#if defined(SERIAL_MPI)
|
|
rank = 0
|
|
#else
|
|
rank = blacs_pnum(ictxt,id,0)
|
|
#endif
|
|
end subroutine psb_get_rank
|
|
|
|
#if (!defined(HAVE_KSENDID)) || defined(SERIAL_MPI)
|
|
!
|
|
! Need these, as they are not in the ESSL implementation
|
|
! of the BLACS.
|
|
!
|
|
integer function krecvid(contxt,proc_to_comm,myrow)
|
|
integer contxt,proc_to_comm,myrow
|
|
|
|
krecvid=32766
|
|
|
|
return
|
|
end function krecvid
|
|
integer function ksendid(contxt,proc_to_comm,myrow)
|
|
integer contxt,proc_to_comm,myrow
|
|
|
|
ksendid=32766
|
|
|
|
return
|
|
end function ksendid
|
|
#endif
|
|
|
|
|
|
end module psb_penv_mod
|