Reworked CSR, take 3. But still waiting for the second NAG bugfix.
psblas3-type-indexed
Salvatore Filippone 16 years ago
parent ef68641888
commit 7d8a6bd486

@ -937,7 +937,7 @@ subroutine d_csr_csins_impl(nz,val,ia,ja,a,imin,imax,jmin,jmax,info,gtl)
use psb_realloc_mod use psb_realloc_mod
use psbn_d_csr_mat_mod, psb_protect_name => d_csr_csins_impl use psbn_d_csr_mat_mod, psb_protect_name => d_csr_csins_impl
class(psbn_d_coo_sparse_mat), intent(inout) :: a class(psbn_d_csr_sparse_mat), intent(inout) :: a
real(psb_dpk_), intent(in) :: val(:) real(psb_dpk_), intent(in) :: val(:)
integer, intent(in) :: nz, ia(:), ja(:), imin,imax,jmin,jmax integer, intent(in) :: nz, ia(:), ja(:), imin,imax,jmin,jmax
integer, intent(out) :: info integer, intent(out) :: info

@ -30,6 +30,7 @@ module psbn_d_csr_mat_mod
interface interface
subroutine d_csr_to_coo_impl(a,b,info) subroutine d_csr_to_coo_impl(a,b,info)
use psb_const_mod use psb_const_mod
use psbn_d_base_mat_mod
import psbn_d_csr_sparse_mat import psbn_d_csr_sparse_mat
class(psbn_d_csr_sparse_mat), intent(in) :: a class(psbn_d_csr_sparse_mat), intent(in) :: a
class(psbn_d_coo_sparse_mat), intent(out) :: b class(psbn_d_coo_sparse_mat), intent(out) :: b
@ -40,6 +41,7 @@ module psbn_d_csr_mat_mod
interface interface
subroutine d_csr_from_coo_impl(a,b,info) subroutine d_csr_from_coo_impl(a,b,info)
use psb_const_mod use psb_const_mod
use psbn_d_base_mat_mod
import psbn_d_csr_sparse_mat import psbn_d_csr_sparse_mat
class(psbn_d_csr_sparse_mat), intent(inout) :: a class(psbn_d_csr_sparse_mat), intent(inout) :: a
class(psbn_d_coo_sparse_mat), intent(in) :: b class(psbn_d_coo_sparse_mat), intent(in) :: b
@ -503,9 +505,9 @@ contains
if (info == 0) call psb_realloc(nz,a%ja,info) if (info == 0) call psb_realloc(nz,a%ja,info)
if (info == 0) call psb_realloc(nz,a%val,info) if (info == 0) call psb_realloc(nz,a%val,info)
if (info == 0) then if (info == 0) then
a%irp=0
call a%set_nrows(m) call a%set_nrows(m)
call a%set_ncols(n) call a%set_ncols(n)
call a%set_nzeros(0)
call a%set_bld() call a%set_bld()
call a%set_triangle(.false.) call a%set_triangle(.false.)
end if end if

Loading…
Cancel
Save