38 type(
field_t),
intent(inout) :: u,v, w
39 type(
field_t),
intent(inout) :: uu, vv, ww
41 real(kind=
rp),
dimension(3),
intent(in) :: ab
42 integer,
intent(in) :: nab
53 u%x(i,1,1,1) = ab(1) * uu%x(i,1,1,1) + &
54 ab(2) * uulag%lf(1)%x(i,1,1,1) + ab(3) * uulag%lf(2)%x(i,1,1,1)
55 v%x(i,1,1,1) = ab(1) * vv%x(i,1,1,1) + &
56 ab(2) * vvlag%lf(1)%x(i,1,1,1) + ab(3) * vvlag%lf(2)%x(i,1,1,1)
57 w%x(i,1,1,1) = ab(1) * ww%x(i,1,1,1) + &
58 ab(2) * wwlag%lf(1)%x(i,1,1,1) + ab(3) * wwlag%lf(2)%x(i,1,1,1)
67 u%x(i,1,1,1) = ab(1) * uu%x(i,1,1,1) + ab(2) * uulag%lf(1)%x(i,1,1,1)
68 v%x(i,1,1,1) = ab(1) * vv%x(i,1,1,1) + ab(2) * vvlag%lf(1)%x(i,1,1,1)
69 w%x(i,1,1,1) = ab(1) * ww%x(i,1,1,1) + ab(2) * wwlag%lf(1)%x(i,1,1,1)
78 fx_laglag, fy_laglag, fz_laglag, fx, fy, fz, &
80 type(
field_t),
intent(inout) :: fx_lag, fy_lag, fz_lag
81 type(
field_t),
intent(inout) :: fx_laglag, fy_laglag, fz_laglag
82 real(kind=
rp),
intent(in) :: rho, ext_coeffs(4)
83 integer,
intent(in) :: n
84 real(kind=
rp),
intent(inout) :: fx(n), fy(n), fz(n)
86 type(
field_t),
pointer :: temp1, temp2, temp3
87 integer :: temp_indices(3)
99 temp1%x(i,1,1,1) = ext_coeffs(2) * fx_lag%x(i,1,1,1) + &
100 ext_coeffs(3) * fx_laglag%x(i,1,1,1)
101 temp2%x(i,1,1,1) = ext_coeffs(2) * fy_lag%x(i,1,1,1) + &
102 ext_coeffs(3) * fy_laglag%x(i,1,1,1)
103 temp3%x(i,1,1,1) = ext_coeffs(2) * fz_lag%x(i,1,1,1) + &
104 ext_coeffs(3) * fz_laglag%x(i,1,1,1)
113 fx_laglag%x(i,1,1,1) = fx_lag%x(i,1,1,1)
114 fy_laglag%x(i,1,1,1) = fy_lag%x(i,1,1,1)
115 fz_laglag%x(i,1,1,1) = fz_lag%x(i,1,1,1)
116 fx_lag%x(i,1,1,1) = fx(i)
117 fy_lag%x(i,1,1,1) = fy(i)
118 fz_lag%x(i,1,1,1) = fz(i)
127 fx(i) = (ext_coeffs(1) * fx(i) + temp1%x(i,1,1,1)) * rho
128 fy(i) = (ext_coeffs(1) * fy(i) + temp2%x(i,1,1,1)) * rho
129 fz(i) = (ext_coeffs(1) * fz(i) + temp3%x(i,1,1,1)) * rho
139 type(
field_t),
intent(inout) :: fs_lag
140 type(
field_t),
intent(inout) :: fs_laglag
141 real(kind=
rp),
intent(in) :: rho, ext_coeffs(4)
142 integer,
intent(in) :: n
143 real(kind=
rp),
intent(inout) :: fs(n)
145 type(
field_t),
pointer :: temp1
146 integer :: temp_index
156 temp1%x(i,1,1,1) = ext_coeffs(2) * fs_lag%x(i,1,1,1) + &
157 ext_coeffs(3) * fs_laglag%x(i,1,1,1)
166 fs_laglag%x(i,1,1,1) = fs_lag%x(i,1,1,1)
167 fs_lag%x(i,1,1,1) = fs(i)
176 fs(i) = (ext_coeffs(1) * fs(i) + temp1%x(i,1,1,1)) * rho
185 u, v, w, B, rho, dt, bd, nbd, n, Blag, Blaglag)
186 integer,
intent(in) :: n, nbd
187 type(
field_t),
intent(in) :: u, v, w
189 real(kind=
rp),
intent(in) :: blag(n), blaglag(n)
190 real(kind=
rp),
intent(inout) :: bfx(n), bfy(n), bfz(n)
191 real(kind=
rp),
intent(in) :: b(n)
192 real(kind=
rp),
intent(in) :: dt, rho, bd(4)
193 type(
field_t),
pointer :: tb1, tb2, tb3
194 integer :: temp_indices(3)
207 tb1%x(i,1,1,1) = u%x(i,1,1,1) * b(i) * bd(2)
208 tb2%x(i,1,1,1) = v%x(i,1,1,1) * b(i) * bd(2)
209 tb3%x(i,1,1,1) = w%x(i,1,1,1) * b(i) * bd(2)
214 if (ilag .eq. 2)
then
220 tb1%x(i,1,1,1) = tb1%x(i,1,1,1) + &
221 (ulag%lf(ilag-1)%x(i,1,1,1) * blag(i) * bd(ilag+1))
222 tb2%x(i,1,1,1) = tb2%x(i,1,1,1) + &
223 (vlag%lf(ilag-1)%x(i,1,1,1) * blag(i) * bd(ilag+1))
224 tb3%x(i,1,1,1) = tb3%x(i,1,1,1) + &
225 (wlag%lf(ilag-1)%x(i,1,1,1) * blag(i) * bd(ilag+1))
228 else if (ilag .eq. 3)
then
234 tb1%x(i,1,1,1) = tb1%x(i,1,1,1) + &
235 (ulag%lf(ilag-1)%x(i,1,1,1) * blaglag(i) * bd(ilag+1))
236 tb2%x(i,1,1,1) = tb2%x(i,1,1,1) + &
237 (vlag%lf(ilag-1)%x(i,1,1,1) * blaglag(i) * bd(ilag+1))
238 tb3%x(i,1,1,1) = tb3%x(i,1,1,1) + &
239 (wlag%lf(ilag-1)%x(i,1,1,1) * blaglag(i) * bd(ilag+1))
250 bfx(i) = bfx(i) + tb1%x(i,1,1,1) * (rho / dt)
251 bfy(i) = bfy(i) + tb2%x(i,1,1,1) * (rho / dt)
252 bfz(i) = bfz(i) + tb3%x(i,1,1,1) * (rho / dt)
262 integer,
intent(in) :: n, nbd
265 real(kind=
rp),
intent(inout) :: fs(n)
266 real(kind=
rp),
intent(in) :: b(n)
267 real(kind=
rp),
intent(in) :: dt, rho, bd(4)
269 type(
field_t),
pointer :: temp1
270 integer :: temp_indices
280 temp1%x(i,1,1,1) = s%x(i,1,1,1) * b(i) * bd(2)
290 temp1%x(i,1,1,1) = temp1%x(i,1,1,1) + &
291 (s_lag%lf(ilag-1)%x(i,1,1,1) * b(i) * bd(ilag+1))
301 fs(i) = fs(i) + temp1%x(i,1,1,1) * (rho / dt)
subroutine rhs_maker_bdf_cpu(ulag, vlag, wlag, bfx, bfy, bfz, u, v, w, b, rho, dt, bd, nbd, n, blag, blaglag)