@ -327,9 +327,9 @@ subroutine psb_d_base_mv_from_fmt(a,b,info)
end subroutine psb_d_base_mv_from_fmt
end subroutine psb_d_base_mv_from_fmt
subroutine psb_d_base_csput ( nz , ia , ja , val , a , imin , imax , jmin , jmax , info , gtl )
subroutine psb_d_base_csput _a ( nz , ia , ja , val , a , imin , imax , jmin , jmax , info , gtl )
use psb_error_mod
use psb_error_mod
use psb_d_base_mat_mod , psb_protect_name = > psb_d_base_csput
use psb_d_base_mat_mod , psb_protect_name = > psb_d_base_csput _a
implicit none
implicit none
class ( psb_d_base_sparse_mat ) , intent ( inout ) :: a
class ( psb_d_base_sparse_mat ) , intent ( inout ) :: a
real ( psb_dpk_ ) , intent ( in ) :: val ( : )
real ( psb_dpk_ ) , intent ( in ) :: val ( : )
@ -354,7 +354,56 @@ subroutine psb_d_base_csput(nz,ia,ja,val,a,imin,imax,jmin,jmax,info,gtl)
end if
end if
return
return
end subroutine psb_d_base_csput
end subroutine psb_d_base_csput_a
subroutine psb_d_base_csput_v ( nz , ia , ja , val , a , imin , imax , jmin , jmax , info , gtl )
use psb_error_mod
use psb_d_base_mat_mod , psb_protect_name = > psb_d_base_csput_v
use psb_d_base_vect_mod
implicit none
class ( psb_d_base_sparse_mat ) , intent ( inout ) :: a
class ( psb_d_base_vect_type ) , intent ( inout ) :: val
class ( psb_i_base_vect_type ) , intent ( inout ) :: ia , ja
integer ( psb_ipk_ ) , intent ( in ) :: nz , imin , imax , jmin , jmax
integer ( psb_ipk_ ) , intent ( out ) :: info
integer ( psb_ipk_ ) , intent ( in ) , optional :: gtl ( : )
integer ( psb_ipk_ ) :: err_act , nzin , nzout
integer ( psb_ipk_ ) :: ierr ( 5 )
character ( len = 20 ) :: name = 'csput_v'
integer :: jmin_ , jmax_
logical :: append_ , rscale_ , cscale_
logical , parameter :: debug = . false .
call psb_erractionsave ( err_act )
info = psb_success_
if ( allocated ( val % v ) . and . allocated ( ia % v ) . and . allocated ( ja % v ) ) then
call a % csput ( nz , ia % v , ja % v , val % v , imin , imax , jmin , jmax , info , gtl )
else
info = psb_err_invalid_mat_state_
endif
if ( info / = 0 ) then
call psb_errpush ( info , name )
go to 9999
end if
call psb_erractionrestore ( err_act )
return
9999 continue
call psb_erractionrestore ( err_act )
if ( err_act == psb_act_abort_ ) then
call psb_error ( )
return
end if
return
end subroutine psb_d_base_csput_v
subroutine psb_d_base_csgetrow ( imin , imax , a , nz , ia , ja , val , info , &
subroutine psb_d_base_csgetrow ( imin , imax , a , nz , ia , ja , val , info , &
& jmin , jmax , iren , append , nzin , rscale , cscale )
& jmin , jmax , iren , append , nzin , rscale , cscale )
@ -920,11 +969,11 @@ subroutine psb_d_base_transp_2mat(a,b)
info = psb_success_
info = psb_success_
select type ( b )
select type ( b )
class is ( psb_d_base_sparse_mat )
class is ( psb_d_base_sparse_mat )
call a % cp_to_coo ( tmp , info )
call a % cp_to_coo ( tmp , info )
if ( info == psb_success_ ) call tmp % transp ( )
if ( info == psb_success_ ) call tmp % transp ( )
if ( info == psb_success_ ) call b % mv_from_coo ( tmp , info )
if ( info == psb_success_ ) call b % mv_from_coo ( tmp , info )
class default
class default
info = psb_err_invalid_dynamic_type_
info = psb_err_invalid_dynamic_type_
end select
end select
if ( info / = psb_success_ ) then
if ( info / = psb_success_ ) then
@ -960,11 +1009,11 @@ subroutine psb_d_base_transc_2mat(a,b)
info = psb_success_
info = psb_success_
select type ( b )
select type ( b )
class is ( psb_d_base_sparse_mat )
class is ( psb_d_base_sparse_mat )
call a % cp_to_coo ( tmp , info )
call a % cp_to_coo ( tmp , info )
if ( info == psb_success_ ) call tmp % transc ( )
if ( info == psb_success_ ) call tmp % transc ( )
if ( info == psb_success_ ) call b % mv_from_coo ( tmp , info )
if ( info == psb_success_ ) call b % mv_from_coo ( tmp , info )
class default
class default
info = psb_err_invalid_dynamic_type_
info = psb_err_invalid_dynamic_type_
end select
end select
if ( info / = psb_success_ ) then
if ( info / = psb_success_ ) then
@ -1271,7 +1320,7 @@ subroutine psb_d_base_cssm(alpha,a,x,beta,y,info,trans,scale,d)
if ( size ( d , 1 ) < nar ) then
if ( size ( d , 1 ) < nar ) then
info = psb_err_input_asize_small_i_
info = psb_err_input_asize_small_i_
ierr ( 1 ) = 9 ; ierr ( 2 ) = nar ;
ierr ( 1 ) = 9 ; ierr ( 2 ) = nar ;
call psb_errpush ( info , name , i_err = ierr )
call psb_errpush ( info , name , i_err = ierr )
go to 9999
go to 9999
end if
end if
@ -1407,7 +1456,7 @@ subroutine psb_d_base_cssv(alpha,a,x,beta,y,info,trans,scale,d)
else if ( psb_toupper ( scale_ ) == 'L' ) then
else if ( psb_toupper ( scale_ ) == 'L' ) then
if ( size ( d , 1 ) < nar ) then
if ( size ( d , 1 ) < nar ) then
info = psb_err_input_asize_small_i_
info = psb_err_input_asize_small_i_
ierr ( 1 ) = 9 ; ierr ( 2 ) = nar ;
ierr ( 1 ) = 9 ; ierr ( 2 ) = nar ;
call psb_errpush ( info , name , i_err = ierr )
call psb_errpush ( info , name , i_err = ierr )
go to 9999
go to 9999
end if
end if