*** empty log message ***

psblas3-type-indexed
Alfredo Buttari 20 years ago
parent aedef1ef01
commit 9ad5ffe8a6

@ -375,7 +375,7 @@ Subroutine psb_dcgstab(a,prec,b,x,eps,desc_a,info,&
9999 continue 9999 continue
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
if (err_act.eq.act_abort) then if (err_act.eq.act_abort) then
call psb_error() call psb_error(icontxt)
return return
end if end if
return return

@ -169,6 +169,7 @@ function psb_dnrm2v(x, desc_a, info)
m = desc_a%matrix_data(psb_m_) m = desc_a%matrix_data(psb_m_)
call psb_chkvect(m,1,size(x),ix,jx,desc_a%matrix_data,info,iix,jjx) call psb_chkvect(m,1,size(x),ix,jx,desc_a%matrix_data,info,iix,jjx)
if(info.ne.0) then if(info.ne.0) then
info=4010 info=4010

@ -4,10 +4,10 @@ NONE
BICGSTAB BICGSTAB
ILU !!!! Actually, it's IPREC below. Should take this line out. ILU !!!! Actually, it's IPREC below. Should take this line out.
CSR CSR
0 IPART: Partition method 2 IPART: Partition method
2 ISTOPC 1 ISTOPC
00800 ITMAX 00800 ITMAX
6 ITRACE -1 ITRACE
2 IPREC 0:NONE 1:DIAGSC 2:ILU 3: AS 4: RAS 5,6: variants 7 IPREC 0:NONE 1:DIAGSC 2:ILU 3: AS 4: RAS 5,6: variants
1 ML 1 ML
1.d-6 EPS 1.d-6 EPS

@ -59,7 +59,7 @@ program df_sample
! solver paramters ! solver paramters
integer :: iter, itmax, ierr, itrace, ircode, ipart,& integer :: iter, itmax, ierr, itrace, ircode, ipart,&
& methd, istopc, ml, iprec, novr & methd, istopc, ml, iprec, novr, igsmth, matop
character(len=5) :: afmt character(len=5) :: afmt
character(len=20) :: name character(len=20) :: name
@ -85,6 +85,8 @@ program df_sample
name='df_sample' name='df_sample'
info=0 info=0
call psb_set_errverbosity(2)
call psb_set_erraction(0)
! !
! get parameters ! get parameters
! !
@ -114,7 +116,8 @@ program df_sample
write(0,'("Ok, got an rhs ")') write(0,'("Ok, got an rhs ")')
b_col_glob =>aux_b(:,1) b_col_glob =>aux_b(:,1)
else else
write(0,'("Generating an rhs ")') write(*,'("Generating an rhs...")')
write(*,'(" ")')
allocate(aux_b(m_problem,1), stat=ircode) allocate(aux_b(m_problem,1), stat=ircode)
if (ircode /= 0) then if (ircode /= 0) then
call psb_errpush(4000,name) call psb_errpush(4000,name)
@ -141,7 +144,7 @@ program df_sample
! switch over different partition types ! switch over different partition types
if (ipart.eq.0) then if (ipart.eq.0) then
call blacs_barrier(ictxt,'a') call blacs_barrier(ictxt,'a')
write(6,'("Partition type: block")') if (amroot) write(*,'("Partition type: block")')
allocate(ivg(m_problem),ipv(np)) allocate(ivg(m_problem),ipv(np))
do i=1,m_problem do i=1,m_problem
call part_block(i,m_problem,np,ipv,nv) call part_block(i,m_problem,np,ipv,nv)
@ -151,7 +154,7 @@ program df_sample
& desc_a,b_col_glob,b_col,info,fmt=afmt) & desc_a,b_col_glob,b_col,info,fmt=afmt)
else if (ipart.eq.1) then else if (ipart.eq.1) then
call blacs_barrier(ictxt,'a') call blacs_barrier(ictxt,'a')
write(6,'("Partition type: blk2")') if (amroot) write(*,'("Partition type: blk2")')
allocate(ivg(m_problem),ipv(np)) allocate(ivg(m_problem),ipv(np))
do i=1,m_problem do i=1,m_problem
call part_blk2(i,m_problem,np,ipv,nv) call part_blk2(i,m_problem,np,ipv,nv)
@ -160,9 +163,10 @@ program df_sample
call matdist(aux_a, a, ivg, ictxt, & call matdist(aux_a, a, ivg, ictxt, &
& desc_a,b_col_glob,b_col,info,fmt=afmt) & desc_a,b_col_glob,b_col,info,fmt=afmt)
else if (ipart.eq.2) then else if (ipart.eq.2) then
write(6,'("Partition type: graph")')
if (amroot) then if (amroot) then
write(0,'("Build type: graph")') write(*,'("Partition type: graph")')
write(*,'(" ")')
! write(0,'("Build type: graph")')
call build_grppart(aux_a%m,aux_a%fida,aux_a%ia1,aux_a%ia2,np) call build_grppart(aux_a%m,aux_a%fida,aux_a%ia1,aux_a%ia2,np)
endif endif
call blacs_barrier(ictxt,'a') call blacs_barrier(ictxt,'a')
@ -171,7 +175,7 @@ program df_sample
call matdist(aux_a, a, ivg, ictxt, & call matdist(aux_a, a, ivg, ictxt, &
& desc_a,b_col_glob,b_col,info,fmt=afmt) & desc_a,b_col_glob,b_col,info,fmt=afmt)
else else
write(6,'("Partition type: block")') if (amroot) write(*,'("Partition type: block")')
call matdist(aux_a, a, part_block, ictxt, & call matdist(aux_a, a, part_block, ictxt, &
& desc_a,b_col_glob,b_col,info,fmt=afmt) & desc_a,b_col_glob,b_col,info,fmt=afmt)
end if end if
@ -189,7 +193,9 @@ program df_sample
& t1, t1, -1, -1, -1) & t1, t1, -1, -1, -1)
if (amroot) then if (amroot) then
write(6,'("Time to read and partition matrix : ",es10.4)')t2 write(*,'(" ")')
write(*,'("Time to read and partition matrix : ",es10.4)')t2
write(*,'(" ")')
end if end if
! !
@ -197,9 +203,11 @@ program df_sample
! of optional parameters ! of optional parameters
! !
if (amroot) write(6,'("Preconditioner : ",a)')prec(1:6) if (amroot) write(*,'("Preconditioner : ",a)')prec(1:6)
! zero initial guess. ! zero initial guess.
matop=1
igsmth=-1
select case(iprec) select case(iprec)
case(noprec_) case(noprec_)
call psb_precset(pre,'noprec') call psb_precset(pre,'noprec')
@ -215,21 +223,34 @@ program df_sample
call psb_precset(pre,'asm',iv=(/novr,halo_,none_/)) call psb_precset(pre,'asm',iv=(/novr,halo_,none_/))
case(rash_) case(rash_)
call psb_precset(pre,'asm',iv=(/novr,nohalo_,none_/)) call psb_precset(pre,'asm',iv=(/novr,nohalo_,none_/))
case(ras2lv_)
call psb_precset(pre,'asm',iv=(/novr,halo_,none_/))
call psb_precset(pre,'ml',&
&iv=(/add_ml_prec_,loc_aggr_,no_smth_,mat_repl_,&
& pre_smooth_,igsmth/),rs=0.d0)
!!$ call psb_precset(pre,'ml',&
!!$ &iv=(/add_ml_prec_,glb_aggr_,pre_smooth_,igsmth,matop/),rs=0.d0)
case(ras2lvm_)
call psb_precset(pre,'asm',iv=(/novr,halo_,none_/))
call psb_precset(pre,'ml',&
& iv=(/mult_ml_prec_,glb_aggr_,pre_smooth_,igsmth,matop/),rs=0.d0)
end select end select
! building the preconditioner ! building the preconditioner
t1 = mpi_wtime() t1 = mpi_wtime()
call psb_precbld(a,pre,desc_a,info) call psb_precbld(a,pre,desc_a,info)
tprec = mpi_wtime()-t1 tprec = mpi_wtime()-t1
if (info /= 0) then
call psb_errpush(4010,name,a_err='psb_precbld')
goto 9999
end if
call dgamx2d(ictxt,'a',' ',ione, ione,tprec,ione,t1,t1,-1,-1,-1) call dgamx2d(ictxt,'a',' ',ione, ione,tprec,ione,t1,t1,-1,-1,-1)
write(6,'("Preconditioner time: ",es10.4)')tprec if(amroot) then
if (info /= 0) then write(*,'("Preconditioner time: ",es10.4)')tprec
write(0,*) 'error in preconditioner :',info write(*,'(" ")')
call blacs_abort(ictxt,-1)
stop
end if end if
iparm = 0 iparm = 0
@ -250,31 +271,26 @@ program df_sample
endif endif
call blacs_barrier(ictxt,'all') call blacs_barrier(ictxt,'all')
t2 = mpi_wtime() - t1 t2 = mpi_wtime() - t1
write(0,*)'Calling gamx2d'
call dgamx2d(ictxt,'a',' ',ione, ione,t2,ione,t1,t1,-1,-1,-1) call dgamx2d(ictxt,'a',' ',ione, ione,t2,ione,t1,t1,-1,-1,-1)
write(0,*)'Calling axpby'
call psb_axpby(1.d0,b_col,0.d0,r_col,desc_a,info) call psb_axpby(1.d0,b_col,0.d0,r_col,desc_a,info)
write(0,*)'Calling spmm'
call psb_spmm(-1.d0,a,x_col,1.d0,r_col,desc_a,info) call psb_spmm(-1.d0,a,x_col,1.d0,r_col,desc_a,info)
write(0,*)'Calling nrm2'
call psb_nrm2(resmx,r_col,desc_a,info) call psb_nrm2(resmx,r_col,desc_a,info)
write(0,*)'Calling amax'
call psb_amax(resmxp,r_col,desc_a,info) call psb_amax(resmxp,r_col,desc_a,info)
!!$ iter=iparm(5) !!$ iter=iparm(5)
!!$ err = rparm(2) !!$ err = rparm(2)
if (amroot) then if (amroot) then
! call psb_prec_descr(6,pre) ! call psb_prec_descr(6,pre)
write(6,'("Matrix: ",a)')mtrx_file write(*,'("Matrix: ",a)')mtrx_file
write(6,'("Computed solution on ",i4," processors")')nprow write(*,'("Computed solution on ",i4," processors")')nprow
write(6,'("Iterations to convergence: ",i)')iter write(*,'("Iterations to convergence: ",i)')iter
write(6,'("Error indicator on exit: ",f7.2)')err write(*,'("Error indicator on exit: ",f7.2)')err
write(6,'("Time to buil prec. : ",es10.4)')tprec write(*,'("Time to buil prec. : ",es10.4)')tprec
write(6,'("Time to solve matrix : ",es10.4)')t2 write(*,'("Time to solve matrix : ",es10.4)')t2
write(6,'("Time per iteration : ",es10.4)')t2/(iter) write(*,'("Time per iteration : ",es10.4)')t2/(iter)
write(6,'("Total time : ",es10.4)')t2+tprec write(*,'("Total time : ",es10.4)')t2+tprec
write(6,'("Residual norm 2 = ",f7.2)')resmx write(*,'("Residual norm 2 = ",es10.4)')resmx
write(6,'("Residual norm inf = ",f7.2)')resmxp write(*,'("Residual norm inf = ",es10.4)')resmxp
end if end if
allocate(x_col_glob(m_problem),r_col_glob(m_problem),stat=ierr) allocate(x_col_glob(m_problem),r_col_glob(m_problem),stat=ierr)
@ -284,7 +300,8 @@ program df_sample
call psb_gather(x_col_glob,x_col,desc_a,info,iroot=0) call psb_gather(x_col_glob,x_col,desc_a,info,iroot=0)
call psb_gather(r_col_glob,r_col,desc_a,info,iroot=0) call psb_gather(r_col_glob,r_col,desc_a,info,iroot=0)
if (amroot) then if (amroot) then
write(0,*) 'Saving x on file' write(0,'(" ")')
write(0,'("Saving x on file")')
write(20,*) 'matrix: ',mtrx_file write(20,*) 'matrix: ',mtrx_file
write(20,*) 'computed solution on ',nprow,' processors.' write(20,*) 'computed solution on ',nprow,' processors.'
write(20,*) 'iterations to convergence: ',iter write(20,*) 'iterations to convergence: ',iter

@ -8,10 +8,10 @@ CONTAINS
! Get iteration parameters from the command line ! Get iteration parameters from the command line
! !
SUBROUTINE GET_PARMS(ICONTXT,MTRX_FILE,RHS_FILE,CMETHD,PREC,IPART,& SUBROUTINE GET_PARMS(ICONTXT,MTRX_FILE,RHS_FILE,CMETHD,PREC,IPART,&
& AFMT,ISTOPC,ITMAX,ITRACE,ML,IPREC,EPS) & AFMT,ISTOPC,ITMAX,ITRACE,NOVR,IPREC,EPS)
integer :: icontxt integer :: icontxt
Character*20 :: CMETHD, PREC, MTRX_FILE, RHS_FILE Character*20 :: CMETHD, PREC, MTRX_FILE, RHS_FILE
Integer :: IRET, ISTOPC,ITMAX,ITRACE,IPART,IPREC,ML Integer :: IRET, ISTOPC,ITMAX,ITRACE,IPART,IPREC,NOVR
Character*40 :: CHARBUF Character*40 :: CHARBUF
real(kind(1.d0)) :: eps real(kind(1.d0)) :: eps
character :: afmt*5 character :: afmt*5
@ -78,9 +78,9 @@ CONTAINS
IPREC=0 IPREC=0
ENDIF ENDIF
IF (IP.GE.10) THEN IF (IP.GE.10) THEN
READ(*,*) ML READ(*,*) NOVR
ELSE ELSE
ML = 1 NOVR = 1
ENDIF ENDIF
IF (IP.GE.11) THEN IF (IP.GE.11) THEN
READ(*,*) EPS READ(*,*) EPS
@ -94,13 +94,17 @@ CONTAINS
INPARMS(3) = ITMAX INPARMS(3) = ITMAX
INPARMS(4) = ITRACE INPARMS(4) = ITRACE
INPARMS(5) = IPREC INPARMS(5) = IPREC
INPARMS(6) = ML INPARMS(6) = NOVR
CALL IGEBS2D(ICONTXT,'ALL',' ',6,1,INPARMS,6) CALL IGEBS2D(ICONTXT,'ALL',' ',6,1,INPARMS,6)
CALL DGEBS2D(ICONTXT,'ALL',' ',1,1,EPS,1) CALL DGEBS2D(ICONTXT,'ALL',' ',1,1,EPS,1)
WRITE(6,*)'Solving matrix: ',mtrx_file write(*,'("Solving matrix : ",a)')mtrx_file
WRITE(6,*)' with BLOCK data distribution, NP=',NPROW,& write(*,'("Number of processors : ",i)')nprow
& ' Preconditioner=',PREC write(*,'("Data distribution : ",i2)')ipart
write(*,'("Preconditioner : ",i)')iprec
if(iprec.gt.2) write(*,'("Overlapping levels : ",i)')novr
write(*,'("Iterative method : ",a)')cmethd
write(*,'(" ")')
else else
CALL PR_USAGE(0) CALL PR_USAGE(0)
CALL BLACS_ABORT(ICONTXT,-1) CALL BLACS_ABORT(ICONTXT,-1)
@ -134,7 +138,7 @@ CONTAINS
ITMAX = INPARMS(3) ITMAX = INPARMS(3)
ITRACE = INPARMS(4) ITRACE = INPARMS(4)
IPREC = INPARMS(5) IPREC = INPARMS(5)
ML = INPARMS(6) NOVR = INPARMS(6)
CALL DGEBR2D(ICONTXT,'A',' ',1,1,EPS,1,0,0) CALL DGEBR2D(ICONTXT,'A',' ',1,1,EPS,1,0,0)
END IF END IF

@ -603,11 +603,6 @@ contains
goto 9999 goto 9999
endif endif
if (myprow == root) then
write (*, fmt = *) 'start matdist v',root, size(iwork),&
&nrow, ncol, nnzero,nrhs
endif
call psb_dscall(nrow,v,icontxt,desc_a,info) call psb_dscall(nrow,v,icontxt,desc_a,info)
if(info/=0) then if(info/=0) then
info=4010 info=4010
@ -785,9 +780,11 @@ contains
goto 9999 goto 9999
end if end if
call psb_asb(b,desc_a,info)
if (myprow == root) then if (myprow == root) then
write(*,*) 'descriptor assembly: ',t1-t0 write(*,'("Descriptor assembly : ",es10.4)')t1-t0
write(*,*) 'sparse matrix assembly: ',t3-t2 write(*,'("Sparse matrix assembly: ",es10.4)')t3-t2
end if end if
if(info/=0)then if(info/=0)then
@ -805,7 +802,6 @@ contains
end if end if
deallocate(iwork) deallocate(iwork)
if (myprow == root) write (*, fmt = *) 'end matdist v'
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return

@ -139,7 +139,7 @@ CONTAINS
wgflag = 0 wgflag = 0
call METIS_PartGraphRecursive(n,ia2,ia1,idummy,jdummy,& call METIS_PartGraphRecursive(n,ia2,ia1,idummy,jdummy,&
& wgflag,numflag,nparts,iopt,nedc,graph_vect) & wgflag,numflag,nparts,iopt,nedc,graph_vect)
write(0,*)'Edge cut from Metis ',nedc ! write(0,*)'Edge cut from Metis ',nedc
DO I=1, N DO I=1, N
GRAPH_VECT(I) = GRAPH_VECT(I) - 1 GRAPH_VECT(I) = GRAPH_VECT(I) - 1
ENDDO ENDDO

@ -60,9 +60,8 @@ contains
end if end if
call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol) call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol)
if (myprow == root) then if (myprow == root) then
write(*, *) 'start read_matrix' ! open input file write(*, '("Reading matrix...")') ! open input file
call mm_mat_read(a,info,infile,filename) call mm_mat_read(a,info,infile,filename)
write(*, *) 'end read_matrix'
if (info /= 0) then if (info /= 0) then
write(0,*) 'Error return from MM_MAT_READ ',info write(0,*) 'Error return from MM_MAT_READ ',info
call blacs_abort(ictxt, 1) ! Unexpected End of File call blacs_abort(ictxt, 1) ! Unexpected End of File
@ -93,7 +92,7 @@ contains
end if end if
call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol) call blacs_gridinfo(ictxt, nprow, npcol, myprow, mypcol)
if (myprow == root) then if (myprow == root) then
write(*, *) 'start read_rhs' ! open input file write(*, '("Reading rhs...")') ! open input file
open(infile,file=filename, status='old', err=901, action="read") open(infile,file=filename, status='old', err=901, action="read")
read(infile,fmt=*, end=902) mmheader, object, fmt, type, sym read(infile,fmt=*, end=902) mmheader, object, fmt, type, sym
write(0,*)'obj fmt',object, fmt write(0,*)'obj fmt',object, fmt

Loading…
Cancel
Save