c--------------------------------------------------------------------- c--------------------------------------------------------------------- subroutine txinvr c--------------------------------------------------------------------- c--------------------------------------------------------------------- c--------------------------------------------------------------------- c block-diagonal matrix-vector multiplication c--------------------------------------------------------------------- include 'header.h' integer i, j, k double precision t1, t2, t3, ac, ru1, uu, vv, ww, r1, r2, r3, > r4, r5, ac2inv do k = 1, nz2 do j = 1, ny2 do i = 1, nx2 ru1 = rho_i(i,j,k) uu = us(i,j,k) vv = vs(i,j,k) ww = ws(i,j,k) ac = speed(i,j,k) c ac2inv = ainv(i,j,k)*ainv(i,j,k) ac2inv = 1.0d0 / ( ac*ac ) r1 = rhs(1,i,j,k) r2 = rhs(2,i,j,k) r3 = rhs(3,i,j,k) r4 = rhs(4,i,j,k) r5 = rhs(5,i,j,k) t1 = c2 * ac2inv * ( qs(i,j,k)*r1 - uu*r2 - > vv*r3 - ww*r4 + r5 ) t2 = bt * ru1 * ( uu * r1 - r2 ) t3 = ( bt * ru1 * ac ) * t1 rhs(1,i,j,k) = r1 - t1 rhs(2,i,j,k) = - ru1 * ( ww*r1 - r4 ) rhs(3,i,j,k) = ru1 * ( vv*r1 - r3 ) rhs(4,i,j,k) = - t2 + t3 rhs(5,i,j,k) = t2 + t3 end do end do end do return end