Changed default allocation for halo_index, to reduce chances of

reallocation during insertion.
psblas3-type-indexed
Salvatore Filippone 19 years ago
parent 793e4ba81e
commit 6dab2c3ab0

@ -266,7 +266,8 @@ subroutine psb_cdall(m, n, parts, ictxt, desc_a, info)
Goto 9999 Goto 9999
endif endif
! estimate local cols number ! estimate local cols number
loc_col=int((psb_colrow_+1.d0)*loc_row)+1 !!$ loc_col=int((psb_colrow_+1.d0)*loc_row)+1
loc_col=min(2*loc_row,m)
allocate(desc_a%loc_to_glob(loc_col),& allocate(desc_a%loc_to_glob(loc_col),&
&desc_a%lprm(1),stat=info) &desc_a%lprm(1),stat=info)
if (info /= 0) then if (info /= 0) then

@ -235,7 +235,8 @@ subroutine psb_cdalv(m, v, ictxt, desc_a, info, flag)
endif endif
! estimate local cols number ! estimate local cols number
loc_col=int((psb_colrow_+1.d0)*loc_row)+1 !!$ loc_col = int((psb_colrow_+1.d0)*loc_row)+1
loc_col = min(2*loc_row,m)
allocate(desc_a%loc_to_glob(loc_col),& allocate(desc_a%loc_to_glob(loc_col),&
&desc_a%lprm(1),stat=info) &desc_a%lprm(1),stat=info)
if (info /= 0) then if (info /= 0) then

@ -52,7 +52,7 @@ subroutine psb_cdasb(desc_a,info)
!....Locals.... !....Locals....
integer :: int_err(5), itemp(2) integer :: int_err(5), itemp(2)
integer,pointer :: ovrlap_index(:),halo_index(:) integer,pointer :: ovrlap_index(:),halo_index(:),ovrlap_out(:),halo_out(:)
integer :: i,err,np,me,& integer :: i,err,np,me,&
& lovrlap,lhalo,nhalo,novrlap,max_size,max_halo,n_col,ldesc_halo,& & lovrlap,lhalo,nhalo,novrlap,max_size,max_halo,n_col,ldesc_halo,&
& ldesc_ovrlap, dectype, err_act & ldesc_ovrlap, dectype, err_act
@ -102,15 +102,16 @@ subroutine psb_cdasb(desc_a,info)
call psb_errpush(info,name,i_err=int_err) call psb_errpush(info,name,i_err=int_err)
goto 9999 goto 9999
endif endif
call psb_realloc(desc_a%matrix_data(psb_n_col_),desc_a%loc_to_glob,info)
! comm desc_size is size requested for temporary comm descriptors ! comm desc_size is size requested for temporary comm descriptors
! (expressed in No of dble element) ! (expressed in No of dble element)
ldesc_halo = (((3*(n_col-n_row)+1)+1)) ldesc_halo = (((3*(n_col-n_row)+1)+1))
ovrlap_index => desc_a%ovrlap_index ovrlap_index => desc_a%ovrlap_index
nullify(desc_a%ovrlap_index) nullify(desc_a%ovrlap_index,ovrlap_out)
halo_index => desc_a%halo_index halo_index => desc_a%halo_index
nullify(desc_a%halo_index) nullify(desc_a%halo_index,halo_out)
lhalo = 1 lhalo = 1
do while (halo_index(lhalo) /= -1) do while (halo_index(lhalo) /= -1)
@ -137,7 +138,7 @@ subroutine psb_cdasb(desc_a,info)
ldesc_halo = 3*max_halo+3*nhalo+1 ldesc_halo = 3*max_halo+3*nhalo+1
! allocate HALO_INDEX field ! allocate HALO_INDEX field
call psb_realloc(ldesc_halo, desc_a%halo_index, info) call psb_realloc(ldesc_halo, halo_out, info)
! check on allocate ! check on allocate
if (info /= no_err) then if (info /= no_err) then
info=4010 info=4010
@ -150,7 +151,7 @@ subroutine psb_cdasb(desc_a,info)
ldesc_ovrlap = 2*lovrlap+1 ldesc_ovrlap = 2*lovrlap+1
! allocate OVRLAP_INDEX field ! allocate OVRLAP_INDEX field
call psb_realloc(ldesc_ovrlap, desc_a%ovrlap_index, info) call psb_realloc(ldesc_ovrlap, ovrlap_out, info)
! check on allocate ! check on allocate
if (info /= no_err) then if (info /= no_err) then
info=4010 info=4010
@ -167,19 +168,21 @@ subroutine psb_cdasb(desc_a,info)
! first the halo index ! first the halo index
call psi_crea_index(desc_a,halo_index,& call psi_crea_index(desc_a,halo_index,&
& desc_a%halo_index,.false.,info) & halo_out,.false.,info)
if(info.ne.0) then if(info.ne.0) then
call psb_errpush(4010,name,a_err='psi_crea_index') call psb_errpush(4010,name,a_err='psi_crea_index')
goto 9999 goto 9999
end if end if
desc_a%halo_index => halo_out
! then the overlap index ! then the overlap index
call psi_crea_index(desc_a,ovrlap_index,& call psi_crea_index(desc_a,ovrlap_index,&
& desc_a%ovrlap_index,.true.,info) & ovrlap_out,.true.,info)
if(info.ne.0) then if(info.ne.0) then
call psb_errpush(4010,name,a_err='psi_crea_index') call psb_errpush(4010,name,a_err='psi_crea_index')
goto 9999 goto 9999
end if end if
desc_a%ovrlap_index => ovrlap_out
! next is the ovrlap_elem index ! next is the ovrlap_elem index
call psi_crea_ovr_elem(desc_a%ovrlap_index,desc_a%ovrlap_elem) call psi_crea_ovr_elem(desc_a%ovrlap_index,desc_a%ovrlap_elem)

Loading…
Cancel
Save