Infrastructure for remote builds

remotebuild
Salvatore Filippone 3 years ago
parent 1337009f91
commit 0e676d2903

@ -117,7 +117,7 @@ subroutine psb_cspasb(a,desc_a, info, afmt, upd, dupl, mold)
case (psb_matbld_noremote_) case (psb_matbld_noremote_)
! nothing needed ! nothing needed
case (psb_matbld_remote_) case (psb_matbld_remote_)
write(0,*) 'Need to implement data movement! ' write(0,*) me,' Size of rmta:',a%rmta%get_nzeros()
end select end select
call a%cscnv(info,type=afmt,dupl=dupl, mold=mold) call a%cscnv(info,type=afmt,dupl=dupl, mold=mold)

@ -157,6 +157,8 @@ subroutine psb_cspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
! Do nothing ! Do nothing
case (psb_matbld_remote_) case (psb_matbld_remote_)
nnl = count(ila(1:nz)<0) nnl = count(ila(1:nz)<0)
if (nnl > 0) then
write(0,*) 'Check on insert ',nnl
allocate(lila(nnl),ljla(nnl),lval(nnl)) allocate(lila(nnl),ljla(nnl),lval(nnl))
k = 0 k = 0
do i=1,nz do i=1,nz
@ -170,7 +172,7 @@ subroutine psb_cspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl
call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),& call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),&
& 1_psb_lpk_,desc_a%get_global_rows(),info) & 1_psb_lpk_,desc_a%get_global_rows(),info)
end if
case default case default
write(0,*) name,' Ignoring wrong value for %remote_build' write(0,*) name,' Ignoring wrong value for %remote_build'
end select end select

@ -117,7 +117,7 @@ subroutine psb_dspasb(a,desc_a, info, afmt, upd, dupl, mold)
case (psb_matbld_noremote_) case (psb_matbld_noremote_)
! nothing needed ! nothing needed
case (psb_matbld_remote_) case (psb_matbld_remote_)
write(0,*) 'Need to implement data movement! ' write(0,*) me,' Size of rmta:',a%rmta%get_nzeros()
end select end select
call a%cscnv(info,type=afmt,dupl=dupl, mold=mold) call a%cscnv(info,type=afmt,dupl=dupl, mold=mold)

@ -156,7 +156,10 @@ subroutine psb_dspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
case (psb_matbld_noremote_) case (psb_matbld_noremote_)
! Do nothing ! Do nothing
case (psb_matbld_remote_) case (psb_matbld_remote_)
nnl = count(ila(1:nz)<0) nnl = count(ila(1:nz)<0)
if (nnl > 0) then
write(0,*) 'Check on insert ',nnl
allocate(lila(nnl),ljla(nnl),lval(nnl)) allocate(lila(nnl),ljla(nnl),lval(nnl))
k = 0 k = 0
do i=1,nz do i=1,nz
@ -170,7 +173,7 @@ subroutine psb_dspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl
call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),& call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),&
& 1_psb_lpk_,desc_a%get_global_rows(),info) & 1_psb_lpk_,desc_a%get_global_rows(),info)
end if
case default case default
write(0,*) name,' Ignoring wrong value for %remote_build' write(0,*) name,' Ignoring wrong value for %remote_build'
end select end select

@ -117,7 +117,7 @@ subroutine psb_sspasb(a,desc_a, info, afmt, upd, dupl, mold)
case (psb_matbld_noremote_) case (psb_matbld_noremote_)
! nothing needed ! nothing needed
case (psb_matbld_remote_) case (psb_matbld_remote_)
write(0,*) 'Need to implement data movement! ' write(0,*) me,' Size of rmta:',a%rmta%get_nzeros()
end select end select
call a%cscnv(info,type=afmt,dupl=dupl, mold=mold) call a%cscnv(info,type=afmt,dupl=dupl, mold=mold)

@ -157,6 +157,8 @@ subroutine psb_sspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
! Do nothing ! Do nothing
case (psb_matbld_remote_) case (psb_matbld_remote_)
nnl = count(ila(1:nz)<0) nnl = count(ila(1:nz)<0)
if (nnl > 0) then
write(0,*) 'Check on insert ',nnl
allocate(lila(nnl),ljla(nnl),lval(nnl)) allocate(lila(nnl),ljla(nnl),lval(nnl))
k = 0 k = 0
do i=1,nz do i=1,nz
@ -170,7 +172,7 @@ subroutine psb_sspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl
call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),& call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),&
& 1_psb_lpk_,desc_a%get_global_rows(),info) & 1_psb_lpk_,desc_a%get_global_rows(),info)
end if
case default case default
write(0,*) name,' Ignoring wrong value for %remote_build' write(0,*) name,' Ignoring wrong value for %remote_build'
end select end select

@ -117,7 +117,7 @@ subroutine psb_zspasb(a,desc_a, info, afmt, upd, dupl, mold)
case (psb_matbld_noremote_) case (psb_matbld_noremote_)
! nothing needed ! nothing needed
case (psb_matbld_remote_) case (psb_matbld_remote_)
write(0,*) 'Need to implement data movement! ' write(0,*) me,' Size of rmta:',a%rmta%get_nzeros()
end select end select
call a%cscnv(info,type=afmt,dupl=dupl, mold=mold) call a%cscnv(info,type=afmt,dupl=dupl, mold=mold)

@ -157,6 +157,8 @@ subroutine psb_zspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
! Do nothing ! Do nothing
case (psb_matbld_remote_) case (psb_matbld_remote_)
nnl = count(ila(1:nz)<0) nnl = count(ila(1:nz)<0)
if (nnl > 0) then
write(0,*) 'Check on insert ',nnl
allocate(lila(nnl),ljla(nnl),lval(nnl)) allocate(lila(nnl),ljla(nnl),lval(nnl))
k = 0 k = 0
do i=1,nz do i=1,nz
@ -170,7 +172,7 @@ subroutine psb_zspins(nz,ia,ja,val,a,desc_a,info,rebuild,local)
if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl if (k /= nnl) write(0,*) name,' Wrong conversion?',k,nnl
call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),& call a%rmta%csput(nnl,lila,ljla,lval,1_psb_lpk_,desc_a%get_global_rows(),&
& 1_psb_lpk_,desc_a%get_global_rows(),info) & 1_psb_lpk_,desc_a%get_global_rows(),info)
end if
case default case default
write(0,*) name,' Ignoring wrong value for %remote_build' write(0,*) name,' Ignoring wrong value for %remote_build'
end select end select

@ -208,7 +208,7 @@ contains
type(psb_d_coo_sparse_mat) :: acoo type(psb_d_coo_sparse_mat) :: acoo
type(psb_d_csr_sparse_mat) :: acsr type(psb_d_csr_sparse_mat) :: acsr
real(psb_dpk_) :: zt(nb),x,y,z real(psb_dpk_) :: zt(nb),x,y,z
integer(psb_ipk_) :: nnz,nr,nlr,i,j,ii,ib,k, partition_ integer(psb_ipk_) :: nnz,nr,nlr,i,j,ii,ib,k, partition_, mysz
integer(psb_lpk_) :: m,n,glob_row,nt integer(psb_lpk_) :: m,n,glob_row,nt
integer(psb_ipk_) :: ix,iy,iz,ia,indx_owner integer(psb_ipk_) :: ix,iy,iz,ia,indx_owner
! For 3D partition ! For 3D partition
@ -377,6 +377,30 @@ contains
! !
call psb_cdall(ctxt,desc_a,info,vl=myidx) call psb_cdall(ctxt,desc_a,info,vl=myidx)
!
! Add extra rows
!
block
integer(psb_ipk_) :: ks
mysz = nlr
if (m>nlr) mysz = mysz + m/nlr
call psb_realloc(mysz,myidx,info)
ks = nlr
outer: do i=1,idim
do j=1,idim
do k=1,idim
if (outside(i,j,k,bndx,bndy,bndz,iamx,iamy,iamz)) then
ks = ks + 1
if (ks > mysz) exit outer
call ijk2idx(myidx(ks),i,j,k,idim,idim,idim)
end if
end do
end do
end do outer
write(0,*) iam,' Check on extra nodes ',nlr,mysz,':',myidx(nlr+1:mysz)
end block
! !
! Specify process topology ! Specify process topology
! !
@ -463,8 +487,9 @@ contains
call psb_barrier(ctxt) call psb_barrier(ctxt)
t1 = psb_wtime() t1 = psb_wtime()
do ii=1, nlr,nb do ii=1, mysz, nb
ib = min(nb,nlr-ii+1) !ib = min(nb,nlr-ii+1)
ib = min(nb,mysz-ii+1)
icoeff = 1 icoeff = 1
do k=1,ib do k=1,ib
i=ii+k-1 i=ii+k-1
@ -616,8 +641,15 @@ contains
return return
end subroutine psb_d_gen_pde3d end subroutine psb_d_gen_pde3d
function outside(i,j,k,bndx,bndy,bndz,iamx,iamy,iamz) result(res)
logical :: res
integer(psb_ipk_), intent(in) :: i,j,k,iamx,iamy,iamz
integer(psb_ipk_), intent(in) :: bndx(0:),bndy(0:),bndz(0:)
res = (i<bndx(iamx)).or.(i>=bndx(iamx+1)) &
& .or.(j<bndy(iamy)).or.(j>=bndy(iamy+1)) &
& .or.(k<bndz(iamz)).or.(k>=bndz(iamz+1))
end function outside
end module psb_d_pde3d_mod end module psb_d_pde3d_mod
program psb_d_pde3d program psb_d_pde3d

Loading…
Cancel
Save