|
|
@ -200,34 +200,20 @@ subroutine psb_c_bjac_apply_vect(alpha,prec,x,beta,y,desc_data,info,trans,work)
|
|
|
|
select case(trans_)
|
|
|
|
select case(trans_)
|
|
|
|
case('N')
|
|
|
|
case('N')
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,wv,desc_data,info,&
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,wv,desc_data,info,&
|
|
|
|
& trans=trans_, work=aux)
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
call wv1%mlt(cone,prec%dv,wv,czero,info)
|
|
|
|
if (info == psb_success_) call wv1%mlt(cone,prec%dv,wv,czero,info)
|
|
|
|
|
|
|
|
if(info == psb_success_) &
|
|
|
|
|
|
|
|
& call psb_spmm(alpha,prec%av(psb_u_pr_),wv1,&
|
|
|
|
|
|
|
|
& beta,y,desc_data,info, trans=trans_, work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
if(info == psb_success_) call psb_spsm(alpha,prec%av(psb_u_pr_),wv,&
|
|
|
|
case('T','C')
|
|
|
|
& beta,y,desc_data,info,&
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,wv,desc_data,info,&
|
|
|
|
& trans=trans_, work=aux)
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
if (info == psb_success_) call wv1%mlt(cone,prec%dv,wv,czero,info)
|
|
|
|
case('T')
|
|
|
|
if (info == psb_success_) &
|
|
|
|
call psb_spmm(cone,prec%av(psb_u_pr_),x,czero,wv,desc_data,info,&
|
|
|
|
& call psb_spmm(alpha,prec%av(psb_u_pr_),wv1, &
|
|
|
|
& trans=trans_, work=aux)
|
|
|
|
& beta,y,desc_data,info,trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
call wv1%mlt(cone,prec%dv,wv,czero,info)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(info == psb_success_) call psb_spsm(alpha,prec%av(psb_l_pr_),wv1,&
|
|
|
|
|
|
|
|
& beta,y,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case('C')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
call psb_spmm(cone,prec%av(psb_u_pr_),x,czero,wv,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
call wv1%mlt(cone,prec%dv,wv,czero,info,conjgx=trans_)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(info == psb_success_) call psb_spsm(alpha,prec%av(psb_l_pr_),wv1,&
|
|
|
|
|
|
|
|
& beta,y,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end select
|
|
|
|
end select
|
|
|
|
if (info /= psb_success_) then
|
|
|
|
if (info /= psb_success_) then
|
|
|
@ -394,19 +380,30 @@ subroutine psb_c_bjac_apply(alpha,prec,x,beta,y,desc_data,info,trans,work)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
select case(trans_)
|
|
|
|
select case(trans_)
|
|
|
|
case('N','T')
|
|
|
|
|
|
|
|
|
|
|
|
case('N')
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,ww,desc_data,info,&
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,ww,desc_data,info,&
|
|
|
|
& trans=trans_, work=aux)
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
ww(1:n_row) = ww(1:n_row) * prec%dv%v%v(1:n_row)
|
|
|
|
ww(1:n_row) = ww(1:n_row) * prec%dv%v%v(1:n_row)
|
|
|
|
if(info == psb_success_) call psb_spsm(alpha,prec%av(psb_u_pr_),ww,&
|
|
|
|
if (info == psb_success_) &
|
|
|
|
& beta,y,desc_data,info, trans=trans_, work=aux)
|
|
|
|
& call psb_spmm(alpha,prec%av(psb_u_pr_),ww,beta,y,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case('T')
|
|
|
|
|
|
|
|
call psb_spmm(cone,prec%av(psb_u_pr_),x,czero,ww,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
ww(1:n_row) = ww(1:n_row) * prec%dv%v%v(1:n_row)
|
|
|
|
|
|
|
|
if (info == psb_success_) &
|
|
|
|
|
|
|
|
& call psb_spmm(alpha,prec%av(psb_l_pr_),ww,beta,y,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
case('C')
|
|
|
|
case('C')
|
|
|
|
call psb_spmm(cone,prec%av(psb_l_pr_),x,czero,ww,desc_data,info,&
|
|
|
|
call psb_spmm(cone,prec%av(psb_u_pr_),x,czero,ww,desc_data,info,&
|
|
|
|
& trans=trans_, work=aux)
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
ww(1:n_row) = ww(1:n_row) * conjg(prec%dv%v%v(1:n_row))
|
|
|
|
ww(1:n_row) = ww(1:n_row) * conjg(prec%dv%v%v(1:n_row))
|
|
|
|
if(info == psb_success_) call psb_spsm(alpha,prec%av(psb_u_pr_),ww,&
|
|
|
|
if (info == psb_success_) &
|
|
|
|
& beta,y,desc_data,info, trans=trans_, work=aux)
|
|
|
|
& call psb_spmm(alpha,prec%av(psb_l_pr_),ww,beta,y,desc_data,info,&
|
|
|
|
|
|
|
|
& trans=trans_,work=aux,doswap=.false.)
|
|
|
|
|
|
|
|
|
|
|
|
end select
|
|
|
|
end select
|
|
|
|
|
|
|
|
|
|
|
@ -592,6 +589,8 @@ subroutine psb_c_bjac_precbld(a,desc_a,prec,info,amold,vmold,imold)
|
|
|
|
prec%iprcparm(psb_f_type_) = psb_f_ilu_n_
|
|
|
|
prec%iprcparm(psb_f_type_) = psb_f_ilu_n_
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
inv_fill = prec%iprcparm(psb_inv_fillin_)
|
|
|
|
|
|
|
|
if (inv_fill <= 0) inv_fill = m ! If no limit on the fill_in is required we allow everything
|
|
|
|
! Select on the type of factorization to be used
|
|
|
|
! Select on the type of factorization to be used
|
|
|
|
select case(prec%iprcparm(psb_f_type_))
|
|
|
|
select case(prec%iprcparm(psb_f_type_))
|
|
|
|
|
|
|
|
|
|
|
|