@ -54,7 +54,7 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
! Local variables
! Local variables
integer ( psb_ipk_ ) , allocatable :: ils ( : ) , neigh ( : ) , irow ( : ) , icol ( : ) , &
integer ( psb_ipk_ ) , allocatable :: ils ( : ) , neigh ( : ) , irow ( : ) , icol ( : ) , &
& ideg ( : ) , idxs ( : )
& ideg ( : ) , idxs ( : ) , tmpaggr ( : )
complex ( psb_spk_ ) , allocatable :: val ( : ) , diag ( : )
complex ( psb_spk_ ) , allocatable :: val ( : ) , diag ( : )
integer ( psb_ipk_ ) :: icnt , nlp , k , n , ia , isz , nr , naggr , i , j , m , nz , ilg , ii , ip
integer ( psb_ipk_ ) :: icnt , nlp , k , n , ia , isz , nr , naggr , i , j , m , nz , ilg , ii , ip
type ( psb_c_csr_sparse_mat ) :: acsr
type ( psb_c_csr_sparse_mat ) :: acsr
@ -158,6 +158,7 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
end if
end if
endif
endif
enddo step1
enddo step1
if ( debug_level > = psb_debug_outer_ ) then
if ( debug_level > = psb_debug_outer_ ) then
write ( debug_unit , * ) me , ' ' , trim ( name ) , &
write ( debug_unit , * ) me , ' ' , trim ( name ) , &
& ' Check 1:' , count ( ilaggr == - ( nr + 1 ) )
& ' Check 1:' , count ( ilaggr == - ( nr + 1 ) )
@ -166,6 +167,7 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
!
!
! Phase two : join the neighbours
! Phase two : join the neighbours
!
!
tmpaggr = ilaggr
step2 : do ii = 1 , nr
step2 : do ii = 1 , nr
i = idxs ( ii )
i = idxs ( ii )
@ -186,7 +188,7 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
j = icol ( k )
j = icol ( k )
if ( ( 1 < = j ) . and . ( j < = nr ) ) then
if ( ( 1 < = j ) . and . ( j < = nr ) ) then
if ( ( abs ( val ( k ) ) > theta * sqrt ( abs ( diag ( i ) * diag ( j ) ) ) ) &
if ( ( abs ( val ( k ) ) > theta * sqrt ( abs ( diag ( i ) * diag ( j ) ) ) ) &
& . and . ( il aggr( j ) > 0 ) . and . ( abs ( val ( k ) ) > cpling ) ) then
& . and . ( tmp aggr( j ) > 0 ) . and . ( abs ( val ( k ) ) > cpling ) ) then
ip = k
ip = k
cpling = abs ( val ( k ) )
cpling = abs ( val ( k ) )
end if
end if
@ -205,7 +207,7 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
step3 : do ii = 1 , nr
step3 : do ii = 1 , nr
i = idxs ( ii )
i = idxs ( ii )
if ( ilaggr ( i ) == - ( nr + 1 ) ) then
if ( ilaggr ( i ) < 0 ) then
call a % csget ( i , i , nz , irow , icol , val , info )
call a % csget ( i , i , nz , irow , icol , val , info )
if ( info / = psb_success_ ) then
if ( info / = psb_success_ ) then
info = psb_err_from_subroutine_
info = psb_err_from_subroutine_
@ -213,8 +215,8 @@ subroutine mld_c_dec_map_bld(iorder,theta,a,desc_a,nlaggr,ilaggr,info)
go to 9999
go to 9999
end if
end if
!
!
! Find the most strongly connected neighbour that is
! Find its strongly connected neighbourhood not
! already aggregated , if any , and join its aggregate
! already aggregated , and make it into a new aggregate .
!
!
cpling = szero
cpling = szero
ip = 0
ip = 0