21 real(kind=
kreal),
allocatable :: ajad(:)
22 integer(kind=kint),
allocatable :: JAJAD(:)
23 integer(kind=kint),
allocatable :: JADORD(:)
24 integer(kind=kint),
allocatable :: IAJAD(:)
25 integer(kind=kint) :: MJAD
26 real(kind=
kreal),
allocatable :: wp(:,:)
27 integer(kind=kint) :: INITIALIZED = 0
33 allocate(wp(hecmat%NDOF,hecmat%NP))
34 allocate(ajad((hecmat%NPL+hecmat%NPU)*hecmat%NDOF*hecmat%NDOF))
35 allocate(jajad(hecmat%NPL+hecmat%NPU))
36 allocate(jadord(hecmat%NP))
37 allocate(iajad(hecmat%NP+1))
38 call repack(hecmat%N, hecmat, mjad, ajad, jajad, iajad, jadord)
59 real(kind=
kreal),
intent(in) :: x(:)
60 real(kind=
kreal),
intent(out) :: y(:)
61 real(kind=
kreal),
intent(inout) :: commtime
62 real(kind=
kreal) :: start_time, end_time
63 real(kind=
kreal),
pointer :: d(:)
64 integer(kind=kint) :: i,idof,jdof,ndof,ndof2
69 commtime = commtime + end_time - start_time
81 y(ndof*(i-1)+idof) = y(ndof*(i-1)+idof) + d(ndof2*(i-1)+ndof*(idof-1)+jdof)*x(ndof*(i-1)+jdof)
87 call matjad(hecmat%N,hecmat%NDOF, mjad, iajad, jajad, ajad, jadord, x, y, wp)
90 subroutine repack(N, hecMAT, MJAD, AJAD, JAJAD, IAJAD, JADORD)
95 integer(kind = kint) :: n, mjad
96 real(kind =
kreal),
dimension(*) :: ajad
97 integer(kind = kint),
dimension(*) :: jajad
98 integer(kind = kint),
dimension(*) :: iajad
99 integer(kind = kint),
dimension(*) :: jadord
101 integer(kind = kint) :: ijad, maxnz, minnz,ndof,ndof2
102 integer(kind = kint) :: i, j, js, je, in, jc
103 integer(kind = kint),
allocatable :: len(:), lenz(:), jadreord(:)
104 ndof = hecmat%NDOF;ndof2=ndof*ndof
106 allocate(jadreord(n))
108 len(i)= hecmat%indexL(i) - hecmat%indexL(i-1) &
109 & + hecmat%indexU(i) - hecmat%indexU(i-1)
111 maxnz=maxval(len(1:n))
112 minnz=minval(len(1:n))
114 allocate(lenz(0:mjad))
117 lenz(len(i))=lenz(len(i))+1
119 do i=maxnz-1,minnz,-1
120 lenz(i)=lenz(i)+lenz(i+1)
123 jadord(i)=lenz(len(i))
124 lenz(len(i))=lenz(len(i))-1
127 jadreord(jadord(i))=i
130 lenz(len(jadreord(i)))=i
133 lenz(i)=max(lenz(i+1),lenz(i))
137 iajad(i+1)=iajad(i)+lenz(i)
142 js= hecmat%indexL(i-1) + 1
143 je= hecmat%indexL(i )
146 len(ijad)=len(ijad)+1
147 jc=iajad(len(ijad))+ijad-1
148 ajad(ndof2*(jc-1)+1:ndof2*(jc)) = hecmat%AL(ndof2*(j-1)+1:ndof2*(j))
154 js= hecmat%indexU(i-1) + 1
155 je= hecmat%indexU(i )
158 len(ijad)=len(ijad)+1
159 jc=iajad(len(ijad))+ijad-1
160 ajad(ndof2*(jc-1)+1:ndof2*(jc)) = hecmat%AU(ndof2*(j-1)+1:ndof2*(j))
167 end subroutine repack
169 subroutine matjad(N, NDOF, MJAD, IAJAD, JAJAD, AJAD, JADORD, X, Y, W)
171 integer(kind=kint) :: N,NDOF, MJAD,NDOF2
172 integer(kind=kint) :: IAJAD(*), JAJAD(*), JADORD(*)
173 real(kind=
kreal) :: ajad(*), x(*), y(*), w(ndof,n)
174 integer(kind=kint) :: I, K, NZ, IXX, idof,jdof
182 do k=iajad(nz),iajad(nz+1)-1
186 w(idof,ixx)=w(idof,ixx)+ajad(ndof2*(k-1)+ndof*(idof-1)+jdof)*x(ndof*(jajad(k)-1)+jdof)
198 y(ndof*(i-1)+idof)=y(ndof*(i-1)+idof)+w(idof,jadord(i))