|
|
@ -48,7 +48,7 @@ subroutine psb_iqsort(x,ix,dir,flag)
|
|
|
|
integer(psb_ipk_), optional, intent(in) :: dir, flag
|
|
|
|
integer(psb_ipk_), optional, intent(in) :: dir, flag
|
|
|
|
integer(psb_ipk_), optional, intent(inout) :: ix(:)
|
|
|
|
integer(psb_ipk_), optional, intent(inout) :: ix(:)
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: dir_, flag_, n, err_act
|
|
|
|
integer(psb_ipk_) :: dir_, flag_, n, err_act, i
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: ierr(5)
|
|
|
|
integer(psb_ipk_) :: ierr(5)
|
|
|
|
character(len=20) :: name
|
|
|
|
character(len=20) :: name
|
|
|
@ -129,15 +129,13 @@ subroutine psb_iqsort(x,ix,dir,flag)
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end subroutine psb_iqsort
|
|
|
|
end subroutine psb_iqsort
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
subroutine psi_iqsrx_up(n,x,idx)
|
|
|
|
|
|
|
|
|
|
|
|
subroutine psi_iqsrx_up(n,x,ix)
|
|
|
|
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iqsrx_up
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iqsrx_up
|
|
|
|
use psb_error_mod
|
|
|
|
use psb_error_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: ix(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: idx(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
@ -170,40 +168,40 @@ subroutine psi_iqsrx_up(n,x,ix)
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
if (piv < x(i)) then
|
|
|
|
if (piv < x(i)) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv > x(j)) then
|
|
|
|
if (piv > x(j)) then
|
|
|
|
xt = x(j)
|
|
|
|
xt = x(j)
|
|
|
|
ixt = indx(j)
|
|
|
|
ixt = idx(j)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
indx(j) = indx(lpiv)
|
|
|
|
idx(j) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv < x(i)) then
|
|
|
|
if (piv < x(i)) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
|
|
|
|
|
|
|
|
i = ilx - 1
|
|
|
|
i = ilx - 1
|
|
|
|
j = iux + 1
|
|
|
|
j = iux + 1
|
|
|
@ -228,11 +226,11 @@ subroutine psi_iqsrx_up(n,x,ix)
|
|
|
|
|
|
|
|
|
|
|
|
if (j > i) then
|
|
|
|
if (j > i) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(j)
|
|
|
|
x(i) = x(j)
|
|
|
|
indx(i) = indx(j)
|
|
|
|
idx(i) = idx(j)
|
|
|
|
x(j) = xt
|
|
|
|
x(j) = xt
|
|
|
|
indx(j) = ixt
|
|
|
|
idx(j) = ixt
|
|
|
|
else
|
|
|
|
else
|
|
|
|
exit outer_up
|
|
|
|
exit outer_up
|
|
|
|
end if
|
|
|
|
end if
|
|
|
@ -254,14 +252,14 @@ subroutine psi_iqsrx_up(n,x,ix)
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_up(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iisrx_up(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_up(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iisrx_up(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
@ -269,29 +267,29 @@ subroutine psi_iqsrx_up(n,x,ix)
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_up(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iisrx_up(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_up(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iisrx_up(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_up(n,x,indx)
|
|
|
|
call psi_iisrx_up(n,x,idx)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
end subroutine psi_iqsrx_up
|
|
|
|
end subroutine psi_iqsrx_up
|
|
|
|
|
|
|
|
|
|
|
|
subroutine psi_iqsrx_dw(n,x,ix)
|
|
|
|
subroutine psi_iqsrx_dw(n,x,idx)
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iqsrx_dw
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iqsrx_dw
|
|
|
|
use psb_error_mod
|
|
|
|
use psb_error_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: ix(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: idx(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
@ -324,40 +322,40 @@ subroutine psi_iqsrx_dw(n,x,ix)
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
if (piv > x(i)) then
|
|
|
|
if (piv > x(i)) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv < x(j)) then
|
|
|
|
if (piv < x(j)) then
|
|
|
|
xt = x(j)
|
|
|
|
xt = x(j)
|
|
|
|
ixt = indx(j)
|
|
|
|
ixt = idx(j)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
indx(j) = indx(lpiv)
|
|
|
|
idx(j) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv > x(i)) then
|
|
|
|
if (piv > x(i)) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = x(lpiv)
|
|
|
|
piv = x(lpiv)
|
|
|
|
|
|
|
|
|
|
|
|
i = ilx - 1
|
|
|
|
i = ilx - 1
|
|
|
|
j = iux + 1
|
|
|
|
j = iux + 1
|
|
|
@ -382,11 +380,11 @@ subroutine psi_iqsrx_dw(n,x,ix)
|
|
|
|
|
|
|
|
|
|
|
|
if (j > i) then
|
|
|
|
if (j > i) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(j)
|
|
|
|
x(i) = x(j)
|
|
|
|
indx(i) = indx(j)
|
|
|
|
idx(i) = idx(j)
|
|
|
|
x(j) = xt
|
|
|
|
x(j) = xt
|
|
|
|
indx(j) = ixt
|
|
|
|
idx(j) = ixt
|
|
|
|
else
|
|
|
|
else
|
|
|
|
exit outer_dw
|
|
|
|
exit outer_dw
|
|
|
|
end if
|
|
|
|
end if
|
|
|
@ -408,14 +406,14 @@ subroutine psi_iqsrx_dw(n,x,ix)
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_dw(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iisrx_dw(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_dw(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iisrx_dw(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
@ -423,19 +421,19 @@ subroutine psi_iqsrx_dw(n,x,ix)
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_dw(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iisrx_dw(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_dw(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iisrx_dw(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iisrx_dw(n,x,indx)
|
|
|
|
call psi_iisrx_dw(n,x,idx)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine psi_iqsrx_dw
|
|
|
|
end subroutine psi_iqsrx_dw
|
|
|
@ -590,7 +588,7 @@ subroutine psi_iqsr_dw(n,x)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! ..
|
|
|
|
! ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(@FKIND) :: piv, xt, xk
|
|
|
|
integer(psb_ipk_) :: piv, xt, xk
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: n1, n2
|
|
|
|
integer(psb_ipk_) :: n1, n2
|
|
|
|
|
|
|
|
|
|
|
@ -722,16 +720,17 @@ subroutine psi_iqsr_dw(n,x)
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine psi_iqsr_dw
|
|
|
|
end subroutine psi_iqsr_dw
|
|
|
|
|
|
|
|
|
|
|
|
subroutine psi_iaqsrx_up(n,x,ix)
|
|
|
|
subroutine psi_iaqsrx_up(n,x,idx)
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iaqsrx_up
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iaqsrx_up
|
|
|
|
use psb_error_mod
|
|
|
|
use psb_error_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: ix(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: idx(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: xt
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
|
|
|
|
|
|
|
@ -761,39 +760,39 @@ subroutine psi_iaqsrx_up(n,x,ix)
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
if (piv < abs(x(i))) then
|
|
|
|
if (piv < abs(x(i))) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv > abs(x(j))) then
|
|
|
|
if (piv > abs(x(j))) then
|
|
|
|
xt = x(j)
|
|
|
|
xt = x(j)
|
|
|
|
ixt = indx(j)
|
|
|
|
ixt = idx(j)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
indx(j) = indx(lpiv)
|
|
|
|
idx(j) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv < abs(x(i))) then
|
|
|
|
if (piv < abs(x(i))) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
|
|
|
|
|
|
|
|
i = ilx - 1
|
|
|
|
i = ilx - 1
|
|
|
|
j = iux + 1
|
|
|
|
j = iux + 1
|
|
|
@ -818,11 +817,11 @@ subroutine psi_iaqsrx_up(n,x,ix)
|
|
|
|
|
|
|
|
|
|
|
|
if (j > i) then
|
|
|
|
if (j > i) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(j)
|
|
|
|
x(i) = x(j)
|
|
|
|
indx(i) = indx(j)
|
|
|
|
idx(i) = idx(j)
|
|
|
|
x(j) = xt
|
|
|
|
x(j) = xt
|
|
|
|
indx(j) = ixt
|
|
|
|
idx(j) = ixt
|
|
|
|
else
|
|
|
|
else
|
|
|
|
exit outer_up
|
|
|
|
exit outer_up
|
|
|
|
end if
|
|
|
|
end if
|
|
|
@ -844,14 +843,14 @@ subroutine psi_iaqsrx_up(n,x,ix)
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_up(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iaisrx_up(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_up(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iaisrx_up(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
@ -859,34 +858,35 @@ subroutine psi_iaqsrx_up(n,x,ix)
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_up(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iaisrx_up(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_up(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iaisrx_up(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_up(n,x,indx)
|
|
|
|
call psi_iaisrx_up(n,x,idx)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine psi_iaqsrx_up
|
|
|
|
end subroutine psi_iaqsrx_up
|
|
|
|
|
|
|
|
|
|
|
|
subroutine psi_iaqsrx_dw(n,x,ix)
|
|
|
|
subroutine psi_iaqsrx_dw(n,x,idx)
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iaqsrx_dw
|
|
|
|
use psb_i_sort_mod, psb_protect_name => psi_iaqsrx_dw
|
|
|
|
use psb_error_mod
|
|
|
|
use psb_error_mod
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: ix(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: idx(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: xt
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
|
|
|
|
|
|
|
@ -915,39 +915,39 @@ subroutine psi_iaqsrx_dw(n,x,ix)
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
if (piv > abs(x(i))) then
|
|
|
|
if (piv > abs(x(i))) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv < abs(x(j))) then
|
|
|
|
if (piv < abs(x(j))) then
|
|
|
|
xt = x(j)
|
|
|
|
xt = x(j)
|
|
|
|
ixt = indx(j)
|
|
|
|
ixt = idx(j)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
x(j) = x(lpiv)
|
|
|
|
indx(j) = indx(lpiv)
|
|
|
|
idx(j) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (piv > abs(x(i))) then
|
|
|
|
if (piv > abs(x(i))) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
piv = abs(x(lpiv))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
!
|
|
|
|
!
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
! now piv is correct; place it into first location
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
x(i) = x(lpiv)
|
|
|
|
indx(i) = indx(lpiv)
|
|
|
|
idx(i) = idx(lpiv)
|
|
|
|
x(lpiv) = xt
|
|
|
|
x(lpiv) = xt
|
|
|
|
indx(lpiv) = ixt
|
|
|
|
idx(lpiv) = ixt
|
|
|
|
|
|
|
|
|
|
|
|
i = ilx - 1
|
|
|
|
i = ilx - 1
|
|
|
|
j = iux + 1
|
|
|
|
j = iux + 1
|
|
|
@ -972,11 +972,11 @@ subroutine psi_iaqsrx_dw(n,x,ix)
|
|
|
|
|
|
|
|
|
|
|
|
if (j > i) then
|
|
|
|
if (j > i) then
|
|
|
|
xt = x(i)
|
|
|
|
xt = x(i)
|
|
|
|
ixt = indx(i)
|
|
|
|
ixt = idx(i)
|
|
|
|
x(i) = x(j)
|
|
|
|
x(i) = x(j)
|
|
|
|
indx(i) = indx(j)
|
|
|
|
idx(i) = idx(j)
|
|
|
|
x(j) = xt
|
|
|
|
x(j) = xt
|
|
|
|
indx(j) = ixt
|
|
|
|
idx(j) = ixt
|
|
|
|
else
|
|
|
|
else
|
|
|
|
exit outer_dw
|
|
|
|
exit outer_dw
|
|
|
|
end if
|
|
|
|
end if
|
|
|
@ -998,14 +998,14 @@ subroutine psi_iaqsrx_dw(n,x,ix)
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_dw(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iaisrx_dw(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_dw(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iaisrx_dw(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
else
|
|
|
|
else
|
|
|
|
if (n2 > ithrs) then
|
|
|
|
if (n2 > ithrs) then
|
|
|
@ -1013,19 +1013,19 @@ subroutine psi_iaqsrx_dw(n,x,ix)
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(1,istp) = i
|
|
|
|
istack(2,istp) = iux
|
|
|
|
istack(2,istp) = iux
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_dw(n2,x(i:iux),indx(i:iux))
|
|
|
|
call psi_iaisrx_dw(n2,x(i:iux),idx(i:iux))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
if (n1 > ithrs) then
|
|
|
|
istp = istp + 1
|
|
|
|
istp = istp + 1
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(1,istp) = ilx
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
istack(2,istp) = i-1
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_dw(n1,x(ilx:i-1),indx(ilx:i-1))
|
|
|
|
call psi_iaisrx_dw(n1,x(ilx:i-1),idx(ilx:i-1))
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psi_iaisrx_dw(n,x,indx)
|
|
|
|
call psi_iaisrx_dw(n,x,idx)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine psi_iaqsrx_dw
|
|
|
|
end subroutine psi_iaqsrx_dw
|
|
|
@ -1038,7 +1038,8 @@ subroutine psi_iaqsr_up(n,x)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: xt
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
|
|
|
|
|
|
|
@ -1177,7 +1178,8 @@ subroutine psi_iaqsr_dw(n,x)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(inout) :: x(:)
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
integer(psb_ipk_), intent(in) :: n
|
|
|
|
! .. Local Scalars ..
|
|
|
|
! .. Local Scalars ..
|
|
|
|
integer(psb_ipk_) :: piv, xk, xt
|
|
|
|
integer(psb_ipk_) :: piv, xk
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: xt
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: i, j, ilx, iux, istp, lpiv
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
integer(psb_ipk_) :: ixt, n1, n2
|
|
|
|
|
|
|
|
|
|
|
|