18 integer(4),
parameter :: krealp = 8
20 integer(kind=kint) :: NPFIU, NPFIL
21 integer(kind=kint) :: N
22 integer(kind=kint),
pointer :: inumFI1L(:) => null()
23 integer(kind=kint),
pointer :: inumFI1U(:) => null()
24 integer(kind=kint),
pointer :: FI1L(:) => null()
25 integer(kind=kint),
pointer :: FI1U(:) => null()
27 integer(kind=kint),
pointer :: indexL(:) => null()
28 integer(kind=kint),
pointer :: indexU(:) => null()
29 integer(kind=kint),
pointer :: itemL(:) => null()
30 integer(kind=kint),
pointer :: itemU(:) => null()
31 real(kind=
kreal),
pointer :: d(:) => null()
32 real(kind=
kreal),
pointer :: al(:) => null()
33 real(kind=
kreal),
pointer :: au(:) => null()
35 real(kind=krealp),
pointer :: sainvu(:) => null()
36 real(kind=krealp),
pointer :: sainvl(:) => null()
37 real(kind=krealp),
pointer :: sainvd(:) => null()
38 real(kind=
kreal),
pointer :: t(:) => null()
49 integer(kind=kint ) :: precond
51 real(kind=krealp) :: filter
59 indexl => hecmat%indexL
60 indexu => hecmat%indexU
64 if (precond.eq.20)
call form_ilu1_sainv_33(hecmat)
66 allocate (sainvd(9*hecmat%NP))
67 allocate (sainvl(9*npfiu))
68 allocate (t(3*hecmat%NP))
73 filter= hecmat%Rarray(5)
75 write(*,
"(a,F15.8)")
"### SAINV FILTER :",filter
77 call hecmw_sainv_33(hecmat)
79 allocate (sainvu(9*npfiu))
82 call hecmw_sainv_make_u_33(hecmat)
86 subroutine hecmw_sainv_lu_33()
88 integer(kind=kint) :: i,j,js,je,in
89 real(kind=
kreal) :: x1, x2, x3
92 sainvd(9*i-5) = sainvd(9*i-5)*sainvd(9*i-4)
93 sainvd(9*i-2) = sainvd(9*i-2)*sainvd(9*i )
94 sainvd(9*i-1) = sainvd(9*i-1)*sainvd(9*i )
105 sainvl(9*j-8) = sainvl(9*j-8)*x1
106 sainvl(9*j-7) = sainvl(9*j-7)*x1
107 sainvl(9*j-6) = sainvl(9*j-6)*x1
108 sainvl(9*j-5) = sainvl(9*j-5)*x2
109 sainvl(9*j-4) = sainvl(9*j-4)*x2
110 sainvl(9*j-3) = sainvl(9*j-3)*x2
111 sainvl(9*j-2) = sainvl(9*j-2)*x3
112 sainvl(9*j-1) = sainvl(9*j-1)*x3
113 sainvl(9*j ) = sainvl(9*j )*x3
117 end subroutine hecmw_sainv_lu_33
121 real(kind=
kreal),
intent(inout) :: zp(:)
122 real(kind=
kreal),
intent(in) :: r(:)
123 integer(kind=kint) :: in, i, j, isl, iel, isu, ieu
124 real(kind=
kreal) :: sw1, sw2, sw3, x1, x2, x3
143 sw1= sw1 + sainvl(9*j-8)*x1 + sainvl(9*j-7)*x2 + sainvl(9*j-6)*x3
144 sw2= sw2 + sainvl(9*j-5)*x1 + sainvl(9*j-4)*x2 + sainvl(9*j-3)*x3
145 sw3= sw3 + sainvl(9*j-2)*x1 + sainvl(9*j-1)*x2 + sainvl(9*j )*x3
152 t(3*i-2)= (x1 + sw1)*sainvd(9*i-8)
153 t(3*i-1)= (x2 + sainvd(9*i-7)*x1 + sw2)*sainvd(9*i-4)
154 t(3*i )= (x3 + sainvd(9*i-6)*x1 + sainvd(9*i-3)*x2 + sw3)*sainvd(9*i )
164 isu= inumfi1u(i-1) + 1
171 sw1= sw1 + sainvu(9*j-8)*x1 + sainvu(9*j-7)*x2 + sainvu(9*j-6)*x3
172 sw2= sw2 + sainvu(9*j-5)*x1 + sainvu(9*j-4)*x2 + sainvu(9*j-3)*x3
173 sw3= sw3 + sainvu(9*j-2)*x1 + sainvu(9*j-1)*x2 + sainvu(9*j )*x3
180 zp(3*i-2)= x1 + sw1 + sainvd(9*i-7)*x2 + sainvd(9*i-6)*x3
181 zp(3*i-1)= x2 + sw2 + sainvd(9*i-3)*x3
193 subroutine hecmw_sainv_33(hecMAT)
197 integer(kind=kint) :: i, j, js, je, in, itr
198 real(kind=krealp) :: x1, x2, x3, dd, dd1, dd2, dd3, dtemp(3)
199 real(kind=krealp) :: filter
200 real(kind=krealp),
allocatable :: zz(:), vv(:)
202 filter= hecmat%Rarray(5)
204 allocate (vv(3*hecmat%NP))
205 allocate (zz(3*hecmat%NP))
215 zz(3*itr-2)= sainvd(9*itr-8)
216 zz(3*itr-1)= sainvd(9*itr-5)
217 zz(3*itr )= sainvd(9*itr-2)
221 js= inumfi1l(itr-1) + 1
225 zz(3*in-2)= sainvl(9*j-8)
226 zz(3*in-1)= sainvl(9*j-7)
227 zz(3*in )= sainvl(9*j-6)
234 vv(3*i-2) = vv(3*i-2) + d(9*i-8)*x1 + d(9*i-7)*x2 + d(9*i-6)*x3
235 vv(3*i-1) = vv(3*i-1) + d(9*i-5)*x1 + d(9*i-4)*x2 + d(9*i-3)*x3
236 vv(3*i ) = vv(3*i ) + d(9*i-2)*x1 + d(9*i-1)*x2 + d(9*i )*x3
242 vv(3*in-2)= vv(3*in-2) + al(9*j-8)*x1 + al(9*j-5)*x2 + al(9*j-2)*x3
243 vv(3*in-1)= vv(3*in-1) + al(9*j-7)*x1 + al(9*j-4)*x2 + al(9*j-1)*x3
244 vv(3*in )= vv(3*in ) + al(9*j-6)*x1 + al(9*j-3)*x2 + al(9*j )*x3
251 vv(3*in-2)= vv(3*in-2) + au(9*j-8)*x1 + au(9*j-5)*x2 + au(9*j-2)*x3
252 vv(3*in-1)= vv(3*in-1) + au(9*j-7)*x1 + au(9*j-4)*x2 + au(9*j-1)*x3
253 vv(3*in )= vv(3*in ) + au(9*j-6)*x1 + au(9*j-3)*x2 + au(9*j )*x3
268 sainvd(9*i-8) = vv(3*i-2)
269 sainvd(9*i-4) = vv(3*i-2)*sainvd(9*i-7) + vv(3*i-1)
270 sainvd(9*i ) = vv(3*i-2)*sainvd(9*i-6) + vv(3*i-1)*sainvd(9*i-3) + vv(3*i)
271 js= inumfi1l(i-1) + 1
278 sainvd(9*i-8)= sainvd(9*i-8) + x1*sainvl(9*j-8) + x2*sainvl(9*j-7) + x3*sainvl(9*j-6)
279 sainvd(9*i-4)= sainvd(9*i-4) + x1*sainvl(9*j-5) + x2*sainvl(9*j-4) + x3*sainvl(9*j-3)
280 sainvd(9*i )= sainvd(9*i ) + x1*sainvl(9*j-2) + x2*sainvl(9*j-1) + x3*sainvl(9*j )
287 dd = 1.0d0/sainvd(9*itr-8)
289 sainvd(9*itr-4) =sainvd(9*itr-4)*dd
290 sainvd(9*itr ) =sainvd(9*itr )*dd
293 sainvd(9*i-8) = sainvd(9*i-8)*dd
294 sainvd(9*i-4) = sainvd(9*i-4)*dd
295 sainvd(9*i ) = sainvd(9*i )*dd
301 if(dabs(dd2) > filter)
then
302 sainvd(9*itr-7)= sainvd(9*itr-7) - dd2*zz(3*itr-2)
303 js= inumfi1l(itr-1) + 1
307 sainvl(9*j-5) = sainvl(9*j-5)-dd2*zz(3*in-2)
308 sainvl(9*j-4) = sainvl(9*j-4)-dd2*zz(3*in-1)
309 sainvl(9*j-3) = sainvl(9*j-3)-dd2*zz(3*in )
314 if(dabs(dd3) > filter)
then
315 sainvd(9*itr-6)= sainvd(9*itr-6) - dd3*zz(3*itr-2)
316 js= inumfi1l(itr-1) + 1
320 sainvl(9*j-2) = sainvl(9*j-2)-dd3*zz(3*in-2)
321 sainvl(9*j-1) = sainvl(9*j-1)-dd3*zz(3*in-1)
322 sainvl(9*j ) = sainvl(9*j )-dd3*zz(3*in )
327 js= inumfi1l(i-1) + 1
330 if(dabs(dd1) > filter)
then
334 sainvl(9*j-8) = sainvl(9*j-8)-dd1*zz(3*in-2)
335 sainvl(9*j-7) = sainvl(9*j-7)-dd1*zz(3*in-1)
336 sainvl(9*j-6) = sainvl(9*j-6)-dd1*zz(3*in )
340 if(dabs(dd2) > filter)
then
344 sainvl(9*j-5) = sainvl(9*j-5)-dd2*zz(3*in-2)
345 sainvl(9*j-4) = sainvl(9*j-4)-dd2*zz(3*in-1)
346 sainvl(9*j-3) = sainvl(9*j-3)-dd2*zz(3*in )
350 if(dabs(dd3) > filter)
then
354 sainvl(9*j-2) = sainvl(9*j-2)-dd3*zz(3*in-2)
355 sainvl(9*j-1) = sainvl(9*j-1)-dd3*zz(3*in-1)
356 sainvl(9*j ) = sainvl(9*j )-dd3*zz(3*in )
368 zz(3*itr-2)= sainvd(9*itr-7)
369 zz(3*itr-1)= sainvd(9*itr-4)
370 zz(3*itr )= sainvd(9*itr-1)
374 js= inumfi1l(itr-1) + 1
378 zz(3*in-2)= sainvl(9*j-5)
379 zz(3*in-1)= sainvl(9*j-4)
380 zz(3*in )= sainvl(9*j-3)
387 vv(3*i-2) = vv(3*i-2) + d(9*i-8)*x1 + d(9*i-7)*x2 + d(9*i-6)*x3
388 vv(3*i-1) = vv(3*i-1) + d(9*i-5)*x1 + d(9*i-4)*x2 + d(9*i-3)*x3
389 vv(3*i ) = vv(3*i ) + d(9*i-2)*x1 + d(9*i-1)*x2 + d(9*i )*x3
395 vv(3*in-2)= vv(3*in-2) + al(9*j-8)*x1 + al(9*j-5)*x2 + al(9*j-2)*x3
396 vv(3*in-1)= vv(3*in-1) + al(9*j-7)*x1 + al(9*j-4)*x2 + al(9*j-1)*x3
397 vv(3*in )= vv(3*in ) + al(9*j-6)*x1 + al(9*j-3)*x2 + al(9*j )*x3
404 vv(3*in-2)= vv(3*in-2) + au(9*j-8)*x1 + au(9*j-5)*x2 + au(9*j-2)*x3
405 vv(3*in-1)= vv(3*in-1) + au(9*j-7)*x1 + au(9*j-4)*x2 + au(9*j-1)*x3
406 vv(3*in )= vv(3*in ) + au(9*j-6)*x1 + au(9*j-3)*x2 + au(9*j )*x3
411 dtemp(1) = sainvd(9*itr-8)
419 sainvd(9*i-8) = vv(3*i-2)
420 sainvd(9*i-4) = vv(3*i-2)*sainvd(9*i-7) + vv(3*i-1)
421 sainvd(9*i ) = vv(3*i-2)*sainvd(9*i-6) + vv(3*i-1)*sainvd(9*i-3) + vv(3*i)
422 js= inumfi1l(i-1) + 1
429 sainvd(9*i-8)= sainvd(9*i-8) + x1*sainvl(9*j-8) + x2*sainvl(9*j-7) + x3*sainvl(9*j-6)
430 sainvd(9*i-4)= sainvd(9*i-4) + x1*sainvl(9*j-5) + x2*sainvl(9*j-4) + x3*sainvl(9*j-3)
431 sainvd(9*i )= sainvd(9*i ) + x1*sainvl(9*j-2) + x2*sainvl(9*j-1) + x3*sainvl(9*j )
438 dd = 1.0d0/sainvd(9*itr-4)
440 sainvd(9*itr-8) = dtemp(1)
441 sainvd(9*itr ) =sainvd(9*itr )*dd
444 sainvd(9*i-8) = sainvd(9*i-8)*dd
445 sainvd(9*i-4) = sainvd(9*i-4)*dd
446 sainvd(9*i ) = sainvd(9*i )*dd
451 if(dabs(dd3) > filter)
then
452 sainvd(9*itr-6)= sainvd(9*itr-6) - dd3*zz(3*itr-2)
453 sainvd(9*itr-3)= sainvd(9*itr-3) - dd3*zz(3*itr-1)
455 js= inumfi1l(itr-1) + 1
459 sainvl(9*j-2) = sainvl(9*j-2)-dd3*zz(3*in-2)
460 sainvl(9*j-1) = sainvl(9*j-1)-dd3*zz(3*in-1)
461 sainvl(9*j ) = sainvl(9*j )-dd3*zz(3*in )
466 js= inumfi1l(i-1) + 1
469 if(dabs(dd1) > filter)
then
473 sainvl(9*j-8) = sainvl(9*j-8)-dd1*zz(3*in-2)
474 sainvl(9*j-7) = sainvl(9*j-7)-dd1*zz(3*in-1)
475 sainvl(9*j-6) = sainvl(9*j-6)-dd1*zz(3*in )
479 if(dabs(dd2) > filter)
then
483 sainvl(9*j-5) = sainvl(9*j-5)-dd2*zz(3*in-2)
484 sainvl(9*j-4) = sainvl(9*j-4)-dd2*zz(3*in-1)
485 sainvl(9*j-3) = sainvl(9*j-3)-dd2*zz(3*in )
489 if(dabs(dd3) > filter)
then
493 sainvl(9*j-2) = sainvl(9*j-2)-dd3*zz(3*in-2)
494 sainvl(9*j-1) = sainvl(9*j-1)-dd3*zz(3*in-1)
495 sainvl(9*j ) = sainvl(9*j )-dd3*zz(3*in )
508 zz(3*itr-2)= sainvd(9*itr-6)
509 zz(3*itr-1)= sainvd(9*itr-3)
510 zz(3*itr )= sainvd(9*itr )
514 js= inumfi1l(itr-1) + 1
518 zz(3*in-2)= sainvl(9*j-2)
519 zz(3*in-1)= sainvl(9*j-1)
520 zz(3*in )= sainvl(9*j )
527 vv(3*i-2) = vv(3*i-2) + d(9*i-8)*x1 + d(9*i-7)*x2 + d(9*i-6)*x3
528 vv(3*i-1) = vv(3*i-1) + d(9*i-5)*x1 + d(9*i-4)*x2 + d(9*i-3)*x3
529 vv(3*i ) = vv(3*i ) + d(9*i-2)*x1 + d(9*i-1)*x2 + d(9*i )*x3
535 vv(3*in-2)= vv(3*in-2) + al(9*j-8)*x1 + al(9*j-5)*x2 + al(9*j-2)*x3
536 vv(3*in-1)= vv(3*in-1) + al(9*j-7)*x1 + al(9*j-4)*x2 + al(9*j-1)*x3
537 vv(3*in )= vv(3*in ) + al(9*j-6)*x1 + al(9*j-3)*x2 + al(9*j )*x3
544 vv(3*in-2)= vv(3*in-2) + au(9*j-8)*x1 + au(9*j-5)*x2 + au(9*j-2)*x3
545 vv(3*in-1)= vv(3*in-1) + au(9*j-7)*x1 + au(9*j-4)*x2 + au(9*j-1)*x3
546 vv(3*in )= vv(3*in ) + au(9*j-6)*x1 + au(9*j-3)*x2 + au(9*j )*x3
551 dtemp(1) = sainvd(9*itr-8)
552 dtemp(2) = sainvd(9*itr-4)
560 sainvd(9*i-8) = vv(3*i-2)
561 sainvd(9*i-4) = vv(3*i-2)*sainvd(9*i-7) + vv(3*i-1)
562 sainvd(9*i ) = vv(3*i-2)*sainvd(9*i-6) + vv(3*i-1)*sainvd(9*i-3) + vv(3*i)
563 js= inumfi1l(i-1) + 1
570 sainvd(9*i-8)= sainvd(9*i-8) + x1*sainvl(9*j-8) + x2*sainvl(9*j-7) + x3*sainvl(9*j-6)
571 sainvd(9*i-4)= sainvd(9*i-4) + x1*sainvl(9*j-5) + x2*sainvl(9*j-4) + x3*sainvl(9*j-3)
572 sainvd(9*i )= sainvd(9*i ) + x1*sainvl(9*j-2) + x2*sainvl(9*j-1) + x3*sainvl(9*j )
579 dd = 1.0d0/sainvd(9*itr )
581 sainvd(9*itr-8) = dtemp(1)
582 sainvd(9*itr-4) = dtemp(2)
585 sainvd(9*i-8) = sainvd(9*i-8)*dd
586 sainvd(9*i-4) = sainvd(9*i-4)*dd
587 sainvd(9*i ) = sainvd(9*i )*dd
592 js= inumfi1l(i-1) + 1
595 if(dabs(dd1) > filter)
then
599 sainvl(9*j-8) = sainvl(9*j-8)-dd1*zz(3*in-2)
600 sainvl(9*j-7) = sainvl(9*j-7)-dd1*zz(3*in-1)
601 sainvl(9*j-6) = sainvl(9*j-6)-dd1*zz(3*in )
605 if(dabs(dd2) > filter)
then
609 sainvl(9*j-5) = sainvl(9*j-5)-dd2*zz(3*in-2)
610 sainvl(9*j-4) = sainvl(9*j-4)-dd2*zz(3*in-1)
611 sainvl(9*j-3) = sainvl(9*j-3)-dd2*zz(3*in )
615 if(dabs(dd3) > filter)
then
619 sainvl(9*j-2) = sainvl(9*j-2)-dd3*zz(3*in-2)
620 sainvl(9*j-1) = sainvl(9*j-1)-dd3*zz(3*in-1)
621 sainvl(9*j ) = sainvl(9*j )-dd3*zz(3*in )
630 sainvd(9*i-8) = 1.0d0/sainvd(9*i-8)
631 sainvd(9*i-4) = 1.0d0/sainvd(9*i-4)
632 sainvd(9*i ) = 1.0d0/sainvd(9*i )
633 sainvd(9*i-5) = sainvd(9*i-7)
634 sainvd(9*i-2) = sainvd(9*i-6)
635 sainvd(9*i-1) = sainvd(9*i-3)
638 end subroutine hecmw_sainv_33
640 subroutine hecmw_sainv_make_u_33(hecMAT)
643 integer(kind=kint) i,j,k,n,m,o
644 integer(kind=kint) is,ie,js,je
657 sainvu(9*n-8)=sainvl(9*j-8)
658 sainvu(9*n-7)=sainvl(9*j-5)
659 sainvu(9*n-6)=sainvl(9*j-2)
660 sainvu(9*n-5)=sainvl(9*j-7)
661 sainvu(9*n-4)=sainvl(9*j-4)
662 sainvu(9*n-3)=sainvl(9*j-1)
663 sainvu(9*n-2)=sainvl(9*j-6)
664 sainvu(9*n-1)=sainvl(9*j-3)
665 sainvu(9*n )=sainvl(9*j )
672 end subroutine hecmw_sainv_make_u_33
677 subroutine form_ilu0_sainv_33(hecMAT)
681 allocate (inumfi1l(0:hecmat%NP), inumfi1u(0:hecmat%NP))
682 allocate (fi1l(hecmat%NPL), fi1u(hecmat%NPU))
689 inumfi1l = hecmat%indexL
690 inumfi1u = hecmat%indexU
697 end subroutine form_ilu0_sainv_33
702 subroutine form_ilu1_sainv_33(hecMAT)
706 integer(kind=kint),
allocatable :: iwsl(:), iwsu(:), iw1(:), iw2(:)
707 integer(kind=kint) :: nplf1,npuf1
708 integer(kind=kint) :: i,jj,kk,l,isk,iek,isj,iej
709 integer(kind=kint) :: icou,icou0,icouu,icouu1,icouu2,icouu3,icoul,icoul1,icoul2,icoul3
710 integer(kind=kint) :: j,k,isl,isu
719 allocate (iw1(hecmat%NP) , iw2(hecmat%NP))
720 allocate (inumfi1l(0:hecmat%NP), inumfi1u(0:hecmat%NP))
731 do l= indexl(i-1)+1, indexl(i)
734 do l= indexu(i-1)+1, indexu(i)
742 isj= indexu(kk-1) + 1
746 if (iw1(jj).eq.0 .and. jj.lt.i)
then
747 inumfi1l(i)= inumfi1l(i)+1
750 if (iw1(jj).eq.0 .and. jj.gt.i)
then
751 inumfi1u(i)= inumfi1u(i)+1
756 nplf1= nplf1 + inumfi1l(i)
757 npuf1= npuf1 + inumfi1u(i)
762 allocate (iwsl(0:hecmat%NP), iwsu(0:hecmat%NP))
763 allocate (fi1l(hecmat%NPL+nplf1), fi1u(hecmat%NPU+npuf1))
765 npfiu = hecmat%NPU+npuf1
766 npfil = hecmat%NPL+nplf1
774 iwsl(i)= indexl(i)-indexl(i-1) + inumfi1l(i) + iwsl(i-1)
775 iwsu(i)= indexu(i)-indexu(i-1) + inumfi1u(i) + iwsu(i-1)
781 inumfi1l(i)= inumfi1l(i-1) + inumfi1l(i)
782 inumfi1u(i)= inumfi1u(i-1) + inumfi1u(i)
786 do l= indexl(i-1)+1, indexl(i)
789 do l= indexu(i-1)+1, indexu(i)
797 isj= indexu(kk-1) + 1
801 if (iw1(jj).eq.0 .and. jj.lt.i)
then
803 fi1l(icoul+iwsl(i-1)+indexl(i)-indexl(i-1))= jj
806 if (iw1(jj).eq.0 .and. jj.gt.i)
then
808 fi1u(icouu+iwsu(i-1)+indexu(i)-indexu(i-1))= jj
818 icoul1= indexl(i) - indexl(i-1)
819 icoul2= inumfi1l(i) - inumfi1l(i-1)
820 icoul3= icoul1 + icoul2
821 icouu1= indexu(i) - indexu(i-1)
822 icouu2= inumfi1u(i) - inumfi1u(i-1)
823 icouu3= icouu1 + icouu2
827 do k= indexl(i-1)+1, indexl(i)
832 do k= inumfi1l(i-1)+1, inumfi1l(i)
834 iw1(icou0)= fi1l(icou0+iwsl(i-1))
840 call sainv_sort_33 (iw1, iw2, icoul3, hecmat%NP)
848 do k= indexu(i-1)+1, indexu(i)
853 do k= inumfi1u(i-1)+1, inumfi1u(i)
855 iw1(icou0)= fi1u(icou0+iwsu(i-1))
861 call sainv_sort_33 (iw1, iw2, icouu3, hecmat%NP)
877 deallocate (iw1, iw2)
878 deallocate (iwsl, iwsu)
880 end subroutine form_ilu1_sainv_33
887 subroutine sainv_sort_33(STEM, INUM, N, NP)
890 integer(kind=kint) :: n, np
891 integer(kind=kint),
dimension(NP) :: stem
892 integer(kind=kint),
dimension(NP) :: inum
893 integer(kind=kint),
dimension(:),
allocatable :: istack
894 integer(kind=kint) :: m,nstack,jstack,l,ir,ip,i,j,k,ss,ii,temp,it
896 allocate (istack(-np:+np))
915 if (stem(i).le.ss)
goto 2
926 if (jstack.eq.0)
then
945 if (stem(l+1).gt.stem(ir))
then
954 if (stem(l).gt.stem(ir))
then
963 if (stem(l+1).gt.stem(l))
then
980 if (stem(i).lt.ss)
goto 3
984 if (stem(j).gt.ss)
goto 4
1007 if (jstack.gt.nstack)
then
1008 write (*,*)
'NSTACK overflow'
1012 if (ir-i+1.ge.j-1)
then
1017 istack(jstack )= j-1
1026 end subroutine sainv_sort_33
1031 if (
associated(sainvd))
deallocate(sainvd)
1032 if (
associated(sainvl))
deallocate(sainvl)
1033 if (
associated(sainvu))
deallocate(sainvu)
1034 if (
associated(inumfi1l))
deallocate(inumfi1l)
1035 if (
associated(inumfi1u))
deallocate(inumfi1u)
1036 if (
associated(fi1l))
deallocate(fi1l)
1037 if (
associated(fi1u))
deallocate(fi1u)