|
|
@ -54,7 +54,6 @@ subroutine mld_c_bwgs_solver_apply_vect(alpha,sv,x,beta,y,desc_data,&
|
|
|
|
type(psb_c_vect_type),intent(inout), optional :: initu
|
|
|
|
type(psb_c_vect_type),intent(inout), optional :: initu
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: n_row,n_col, itx
|
|
|
|
integer(psb_ipk_) :: n_row,n_col, itx
|
|
|
|
type(psb_c_vect_type) :: tw, xit
|
|
|
|
|
|
|
|
complex(psb_spk_), pointer :: ww(:), aux(:), tx(:),ty(:)
|
|
|
|
complex(psb_spk_), pointer :: ww(:), aux(:), tx(:),ty(:)
|
|
|
|
complex(psb_spk_), allocatable :: temp(:)
|
|
|
|
complex(psb_spk_), allocatable :: temp(:)
|
|
|
|
integer(psb_ipk_) :: ictxt,np,me,i, err_act
|
|
|
|
integer(psb_ipk_) :: ictxt,np,me,i, err_act
|
|
|
@ -121,8 +120,15 @@ subroutine mld_c_bwgs_solver_apply_vect(alpha,sv,x,beta,y,desc_data,&
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_geasb(tw,desc_data,info,mold=x%v,scratch=.true.)
|
|
|
|
if (size(wv) < 2) then
|
|
|
|
call psb_geasb(xit,desc_data,info,mold=x%v,scratch=.true.)
|
|
|
|
info = psb_err_internal_error_
|
|
|
|
|
|
|
|
call psb_errpush(info,name,&
|
|
|
|
|
|
|
|
& a_err='invalid wv size')
|
|
|
|
|
|
|
|
goto 9999
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
associate(tw => wv(1), xit => wv(2))
|
|
|
|
|
|
|
|
|
|
|
|
select case (init_)
|
|
|
|
select case (init_)
|
|
|
|
case('Z')
|
|
|
|
case('Z')
|
|
|
|
call xit%zero()
|
|
|
|
call xit%zero()
|
|
|
@ -182,8 +188,8 @@ subroutine mld_c_bwgs_solver_apply_vect(alpha,sv,x,beta,y,desc_data,&
|
|
|
|
& a_err='Error in subsolve')
|
|
|
|
& a_err='Error in subsolve')
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
call tw%free(info)
|
|
|
|
end associate
|
|
|
|
call xit%free(info)
|
|
|
|
|
|
|
|
if (n_col <= size(work)) then
|
|
|
|
if (n_col <= size(work)) then
|
|
|
|
if ((4*n_col+n_col) <= size(work)) then
|
|
|
|
if ((4*n_col+n_col) <= size(work)) then
|
|
|
|
else
|
|
|
|
else
|
|
|
|