66 c_dyn, test_filter, mij, lij, num, den)
67 logical,
intent(in) :: if_ext
68 real(kind=
rp),
intent(in) :: t
69 integer,
intent(in) :: tstep
70 type(
coef_t),
intent(in) :: coef
71 type(
field_t),
intent(inout) :: nut
72 type(
field_t),
intent(in) :: delta
73 type(
field_t),
intent(inout) :: c_dyn
75 type(
field_t),
intent(inout) :: mij(6), lij(6)
76 type(
field_t),
intent(inout) :: num, den
78 type(
field_t),
pointer :: u, v, w
81 type(
field_t),
pointer :: s11, s22, s33, s12, s13, s23, s_abs
82 real(kind=
rp) :: alpha
83 integer :: temp_indices(7)
86 if (tstep .eq. 1)
then
92 if (if_ext .eqv. .true.)
then
112 call strain_rate(s11%x, s22%x, s33%x, s12%x, s13%x, s23%x, &
115 call coef%gs_h%op(s11%x, s11%dof%size(),
gs_op_add)
116 call coef%gs_h%op(s22%x, s11%dof%size(),
gs_op_add)
117 call coef%gs_h%op(s33%x, s11%dof%size(),
gs_op_add)
118 call coef%gs_h%op(s12%x, s11%dof%size(),
gs_op_add)
119 call coef%gs_h%op(s13%x, s11%dof%size(),
gs_op_add)
120 call coef%gs_h%op(s23%x, s11%dof%size(),
gs_op_add)
126 do i = 1, u%dof%size()
127 s11%x(i,1,1,1) = s11%x(i,1,1,1) * coef%mult(i,1,1,1)
128 s22%x(i,1,1,1) = s22%x(i,1,1,1) * coef%mult(i,1,1,1)
129 s33%x(i,1,1,1) = s33%x(i,1,1,1) * coef%mult(i,1,1,1)
130 s12%x(i,1,1,1) = s12%x(i,1,1,1) * coef%mult(i,1,1,1)
131 s13%x(i,1,1,1) = s13%x(i,1,1,1) * coef%mult(i,1,1,1)
132 s23%x(i,1,1,1) = s23%x(i,1,1,1) * coef%mult(i,1,1,1)
140 do i = 1, u%dof%size()
141 s_abs%x(i,1,1,1) = sqrt(2.0_rp * (s11%x(i,1,1,1)*s11%x(i,1,1,1) + &
142 s22%x(i,1,1,1)*s22%x(i,1,1,1) + &
143 s33%x(i,1,1,1)*s33%x(i,1,1,1)) + &
144 4.0_rp * (s12%x(i,1,1,1)*s12%x(i,1,1,1) + &
145 s13%x(i,1,1,1)*s13%x(i,1,1,1) + &
146 s23%x(i,1,1,1)*s23%x(i,1,1,1)))
152 s_abs, test_filter, delta, u%dof%size())
159 do i = 1, u%dof%size()
160 if (den%x(i,1,1,1) .gt. 0.0_rp)
then
161 c_dyn%x(i,1,1,1) = 0.5_rp * (num%x(i,1,1,1)/den%x(i,1,1,1))
163 c_dyn%x(i,1,1,1) = 0.0_rp
165 c_dyn%x(i,1,1,1) =
max(c_dyn%x(i,1,1,1),0.0_rp)
166 nut%x(i,1,1,1) = c_dyn%x(i,1,1,1) * delta%x(i,1,1,1)**2 &
172 call col2(nut%x, coef%mult, nut%dof%size())
187 type(
field_t),
intent(inout) :: lij(6)
188 type(
field_t),
pointer,
intent(in) :: u, v, w
190 integer,
intent(in) :: n
193 integer :: temp_indices(3)
194 type(
field_t),
pointer :: fu, fv, fw
200 call test_filter%apply(fu, u)
201 call test_filter%apply(fv, v)
202 call test_filter%apply(fw, w)
210 lij(1)%x(i,1,1,1) = fu%x(i,1,1,1) * fu%x(i,1,1,1)
211 lij(2)%x(i,1,1,1) = fv%x(i,1,1,1) * fv%x(i,1,1,1)
212 lij(3)%x(i,1,1,1) = fw%x(i,1,1,1) * fw%x(i,1,1,1)
213 lij(4)%x(i,1,1,1) = fu%x(i,1,1,1) * fv%x(i,1,1,1)
214 lij(5)%x(i,1,1,1) = fu%x(i,1,1,1) * fw%x(i,1,1,1)
215 lij(6)%x(i,1,1,1) = fv%x(i,1,1,1) * fw%x(i,1,1,1)
222 call col3(fu%x, u%x, u%x, n)
223 call test_filter%apply(fv, fu)
224 call sub2(lij(1)%x, fv%x, n)
226 call col3(fu%x, v%x, v%x, n)
227 call test_filter%apply(fv, fu)
228 call sub2(lij(2)%x, fv%x, n)
230 call col3(fu%x, w%x, w%x, n)
231 call test_filter%apply(fv, fu)
232 call sub2(lij(3)%x, fv%x, n)
234 call col3(fu%x, u%x, v%x, n)
235 call test_filter%apply(fv, fu)
236 call sub2(lij(4)%x, fv%x, n)
238 call col3(fu%x, u%x, w%x, n)
239 call test_filter%apply(fv, fu)
240 call sub2(lij(5)%x, fv%x, n)
242 call col3(fu%x, v%x, w%x, n)
243 call test_filter%apply(fv, fu)
244 call sub2(lij(6)%x, fv%x, n)
262 s_abs, test_filter, delta, n)
263 type(
field_t),
intent(inout) :: mij(6)
264 type(
field_t),
intent(inout) :: s11, s22, s33, s12, s13, s23, s_abs
266 type(
field_t),
intent(in) :: delta
267 integer,
intent(in) :: n
269 integer :: temp_indices(7)
270 type(
field_t),
pointer :: fs11, fs22, fs33, fs12, fs13, fs23, fs_abs
271 real(kind=
rp) :: delta_ratio2
273 real(kind=
rp) :: delta2
275 delta_ratio2 = ((test_filter%nx-1.0_rp)/(test_filter%nt-1.0_rp))**2
287 call test_filter%apply(fs_abs, s_abs)
289 call test_filter%apply(fs11, s11)
290 call col3(mij(1)%x, fs_abs%x, fs11%x, n)
291 call cmult(mij(1)%x, delta_ratio2, n)
293 call test_filter%apply(fs22, s22)
294 call col3(mij(2)%x, fs_abs%x, fs22%x, n)
295 call cmult(mij(2)%x, delta_ratio2, n)
297 call test_filter%apply(fs33, s33)
298 call col3(mij(3)%x, fs_abs%x, fs33%x, n)
299 call cmult(mij(3)%x, delta_ratio2, n)
301 call test_filter%apply(fs12, s12)
302 call col3(mij(4)%x, fs_abs%x, fs12%x, n)
303 call cmult(mij(4)%x, delta_ratio2, n)
305 call test_filter%apply(fs13, s13)
306 call col3(mij(5)%x, fs_abs%x, fs13%x, n)
307 call cmult(mij(5)%x, delta_ratio2, n)
309 call test_filter%apply(fs23, s23)
310 call col3(mij(6)%x, fs_abs%x, fs23%x, n)
311 call cmult(mij(6)%x, delta_ratio2, n)
317 call col3(fs11%x, s_abs%x, s11%x, n)
318 call test_filter%apply(fs22, fs11)
319 call sub2(mij(1)%x, fs22%x, n)
321 call col3(fs11%x, s_abs%x, s22%x, n)
322 call test_filter%apply(fs22, fs11)
323 call sub2(mij(2)%x, fs22%x, n)
325 call col3(fs11%x, s_abs%x, s33%x, n)
326 call test_filter%apply(fs22, fs11)
327 call sub2(mij(3)%x, fs22%x, n)
329 call col3(fs11%x, s_abs%x, s12%x, n)
330 call test_filter%apply(fs22, fs11)
331 call sub2(mij(4)%x, fs22%x, n)
333 call col3(fs11%x, s_abs%x, s13%x, n)
334 call test_filter%apply(fs22, fs11)
335 call sub2(mij(5)%x, fs22%x, n)
337 call col3(fs11%x, s_abs%x, s23%x, n)
338 call test_filter%apply(fs22, fs11)
339 call sub2(mij(6)%x, fs22%x, n)
347 delta2 = delta%x(i,1,1,1)**2
348 mij(1)%x(i,1,1,1) = mij(1)%x(i,1,1,1) * delta2
349 mij(2)%x(i,1,1,1) = mij(2)%x(i,1,1,1) * delta2
350 mij(3)%x(i,1,1,1) = mij(3)%x(i,1,1,1) * delta2
351 mij(4)%x(i,1,1,1) = mij(4)%x(i,1,1,1) * delta2
352 mij(5)%x(i,1,1,1) = mij(5)%x(i,1,1,1) * delta2
353 mij(6)%x(i,1,1,1) = mij(6)%x(i,1,1,1) * delta2
367 type(
field_t),
intent(inout) :: num, den
368 type(
field_t),
intent(in) :: lij(6), mij(6)
369 real(kind=
rp),
intent(in) :: alpha
370 integer,
intent(in) :: n
372 real(kind=
rp),
dimension(n) :: num_curr, den_curr
380 num_curr(i) = mij(1)%x(i,1,1,1)*lij(1)%x(i,1,1,1) + &
381 mij(2)%x(i,1,1,1)*lij(2)%x(i,1,1,1) + &
382 mij(3)%x(i,1,1,1)*lij(3)%x(i,1,1,1) + &
383 2.0_rp*(mij(4)%x(i,1,1,1)*lij(4)%x(i,1,1,1) + &
384 mij(5)%x(i,1,1,1)*lij(5)%x(i,1,1,1) + &
385 mij(6)%x(i,1,1,1)*lij(6)%x(i,1,1,1))
386 den_curr(i) = mij(1)%x(i,1,1,1)*mij(1)%x(i,1,1,1) + &
387 mij(2)%x(i,1,1,1)*mij(2)%x(i,1,1,1) + &
388 mij(3)%x(i,1,1,1)*mij(3)%x(i,1,1,1) + &
389 2.0_rp*(mij(4)%x(i,1,1,1)*mij(4)%x(i,1,1,1) + &
390 mij(5)%x(i,1,1,1)*mij(5)%x(i,1,1,1) + &
391 mij(6)%x(i,1,1,1)*mij(6)%x(i,1,1,1))
401 num%x(i,1,1,1) = alpha * num%x(i,1,1,1) + (1.0_rp - alpha) * num_curr(i)
402 den%x(i,1,1,1) = alpha * den%x(i,1,1,1) + (1.0_rp - alpha) * den_curr(i)