util/psb_d_renum_impl.F90
 util/psb_renum_mod.f90

Added identity option to renumbering
psblas3-type-indexed
Salvatore Filippone 13 years ago
parent 844a942947
commit caaced3ad1

@ -1,7 +1,7 @@
include Make.inc include Make.inc
all: libd based precd kryld utild all: libd based precd kryld utild
(cd opt; $(MAKE) lib) # (cd opt; $(MAKE) lib)
@echo "=====================================" @echo "====================================="
@echo "PSBLAS libraries Compilation Successful." @echo "PSBLAS libraries Compilation Successful."

@ -20,6 +20,8 @@ subroutine psb_d_mat_renums(alg,mat,info,perm)
ialg = psb_mat_renum_gps_ ialg = psb_mat_renum_gps_
case ('AMD') case ('AMD')
ialg = psb_mat_renum_amd_ ialg = psb_mat_renum_amd_
case ('NONE', 'ID')
ialg = psb_mat_renum_identity_
case default case default
write(0,*) 'Unknown algorithm "',psb_toupper(alg),'"' write(0,*) 'Unknown algorithm "',psb_toupper(alg),'"'
ialg = -1 ialg = -1
@ -54,7 +56,7 @@ subroutine psb_d_mat_renum(alg,mat,info,perm)
integer, intent(out) :: info integer, intent(out) :: info
integer, allocatable, optional, intent(out) :: perm(:) integer, allocatable, optional, intent(out) :: perm(:)
integer :: err_act, nr, nc integer :: err_act, nr, nc, i
character(len=20) :: name character(len=20) :: name
info = psb_success_ info = psb_success_
@ -80,6 +82,18 @@ subroutine psb_d_mat_renum(alg,mat,info,perm)
call psb_mat_renum_amd(mat,info,perm) call psb_mat_renum_amd(mat,info,perm)
case(psb_mat_renum_identity_)
nr = mat%get_nrows()
allocate(perm(nr),stat=info)
if (info == 0) then
do i=1,nr
perm(i) = i
end do
else
info = psb_err_alloc_dealloc_
call psb_errpush(info,name)
goto 9999
endif
case default case default
info = psb_err_input_value_invalid_i_ info = psb_err_input_value_invalid_i_
call psb_errpush(info,name,i_err=(/1,alg,0,0,0/)) call psb_errpush(info,name,i_err=(/1,alg,0,0,0/))

@ -1,9 +1,10 @@
module psb_renum_mod module psb_renum_mod
use psb_base_mod use psb_base_mod
integer, parameter :: psb_mat_renum_identity_ = 0
integer, parameter :: psb_mat_renum_gps_ = 456 integer, parameter :: psb_mat_renum_gps_ = 456
integer, parameter :: psb_mat_renum_amd_ = psb_mat_renum_gps_ + 1 integer, parameter :: psb_mat_renum_amd_ = psb_mat_renum_gps_ + 1
interface psb_mat_renum interface psb_mat_renum
subroutine psb_d_mat_renums(alg,mat,info,perm) subroutine psb_d_mat_renums(alg,mat,info,perm)

Loading…
Cancel
Save