|
|
@ -270,7 +270,7 @@ subroutine zmm_mat_read(a, info, iunit, filename)
|
|
|
|
if ((psb_tolower(type) == 'complex').and.(psb_tolower(sym) == 'general')) then
|
|
|
|
if ((psb_tolower(type) == 'complex').and.(psb_tolower(sym) == 'general')) then
|
|
|
|
call acoo%allocate(nrow,ncol,nnzero)
|
|
|
|
call acoo%allocate(nrow,ncol,nnzero)
|
|
|
|
do i=1,nnzero
|
|
|
|
do i=1,nnzero
|
|
|
|
read(infile,fmt=*,end=902) acoo%ia(i),acoo%ja(i),are,aim
|
|
|
|
read(infile,fmt=*,end=902,err=905) acoo%ia(i),acoo%ja(i),are,aim
|
|
|
|
acoo%val(i) = cmplx(are,aim,kind=psb_dpk_)
|
|
|
|
acoo%val(i) = cmplx(are,aim,kind=psb_dpk_)
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
call acoo%set_nzeros(nnzero)
|
|
|
|
call acoo%set_nzeros(nnzero)
|
|
|
@ -284,7 +284,7 @@ subroutine zmm_mat_read(a, info, iunit, filename)
|
|
|
|
! we de-symmetrize what we are about to read
|
|
|
|
! we de-symmetrize what we are about to read
|
|
|
|
call acoo%allocate(nrow,ncol,2*nnzero)
|
|
|
|
call acoo%allocate(nrow,ncol,2*nnzero)
|
|
|
|
do i=1,nnzero
|
|
|
|
do i=1,nnzero
|
|
|
|
read(infile,fmt=*,end=902) acoo%ia(i),acoo%ja(i),are,aim
|
|
|
|
read(infile,fmt=*,end=902,err=905) acoo%ia(i),acoo%ja(i),are,aim
|
|
|
|
acoo%val(i) = cmplx(are,aim,kind=psb_dpk_)
|
|
|
|
acoo%val(i) = cmplx(are,aim,kind=psb_dpk_)
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
nzr = nnzero
|
|
|
|
nzr = nnzero
|
|
|
@ -339,6 +339,9 @@ subroutine zmm_mat_read(a, info, iunit, filename)
|
|
|
|
902 info=902
|
|
|
|
902 info=902
|
|
|
|
write(psb_err_unit,*) 'READ_MATRIX: Unexpected end of file '
|
|
|
|
write(psb_err_unit,*) 'READ_MATRIX: Unexpected end of file '
|
|
|
|
return
|
|
|
|
return
|
|
|
|
|
|
|
|
905 info=905
|
|
|
|
|
|
|
|
write(psb_err_unit,*) 'READ_MATRIX: Error at line',i
|
|
|
|
|
|
|
|
return
|
|
|
|
993 info=993
|
|
|
|
993 info=993
|
|
|
|
write(psb_err_unit,*) 'READ_MATRIX: Memory allocation failure'
|
|
|
|
write(psb_err_unit,*) 'READ_MATRIX: Memory allocation failure'
|
|
|
|
return
|
|
|
|
return
|
|
|
|