247 subroutine fluid_pnpn_init(this, msh, lx, params, user, chkp)
248 class(fluid_pnpn_t),
target,
intent(inout) :: this
249 type(
mesh_t),
target,
intent(inout) :: msh
250 integer,
intent(in) :: lx
251 type(json_file),
target,
intent(inout) :: params
252 type(
user_t),
target,
intent(in) :: user
253 type(
chkp_t),
target,
intent(inout) :: chkp
254 character(len=15),
parameter :: scheme =
'Modular (Pn/Pn)'
256 class(
bc_t),
pointer :: bc_i, vel_bc
257 real(kind=
rp) :: abs_tol
258 character(len=LOG_SIZE) :: log_buf
259 integer :: ierr, integer_val, solver_maxiter
260 character(len=:),
allocatable :: solver_type, precon_type
261 logical :: monitor, found
263 type(json_file) :: numerics_params, precon_params
268 call this%init_base(msh, lx, params, scheme,
user, .true.)
280 allocate(this%ext_bdf)
281 call this%ext_bdf%init(integer_val)
284 this%full_stress_formulation, .false.)
289 if (this%full_stress_formulation)
then
291 call ax_helm_factory(this%Ax_vel, full_formulation = .true.)
294 call pnpn_prs_res_stress_factory(this%prs_res)
297 call pnpn_vel_res_stress_factory(this%vel_res)
300 call ax_helm_factory(this%Ax_vel, full_formulation = .false.)
303 call pnpn_prs_res_factory(this%prs_res)
306 call pnpn_vel_res_factory(this%vel_res)
311 if (params%valid_path(
'case.fluid.nut_field'))
then
312 if (.not. this%full_stress_formulation)
then
313 call neko_error(
"You need to set full_stress_formulation to " // &
314 "true for the fluid to have a spatially varying " // &
317 call json_get(params,
'case.fluid.nut_field', this%nut_field_name)
319 this%nut_field_name =
""
323 call ax_helm_factory(this%Ax_prs, full_formulation = .false.)
327 call rhs_maker_sumab_fctry(this%sumab)
330 call rhs_maker_ext_fctry(this%makeabf)
333 call rhs_maker_bdf_fctry(this%makebdf)
336 call rhs_maker_oifs_fctry(this%makeoifs)
339 associate(xh_lx => this%Xh%lx, xh_ly => this%Xh%ly, xh_lz => this%Xh%lz, &
340 dm_xh => this%dm_Xh, nelv => this%msh%nelv)
342 call this%p_res%init(dm_xh,
"p_res")
343 call this%u_res%init(dm_xh,
"u_res")
344 call this%v_res%init(dm_xh,
"v_res")
345 call this%w_res%init(dm_xh,
"w_res")
346 call this%abx1%init(dm_xh,
"abx1")
347 call this%aby1%init(dm_xh,
"aby1")
348 call this%abz1%init(dm_xh,
"abz1")
349 call this%abx2%init(dm_xh,
"abx2")
350 call this%aby2%init(dm_xh,
"aby2")
351 call this%abz2%init(dm_xh,
"abz2")
352 call this%advx%init(dm_xh,
"advx")
353 call this%advy%init(dm_xh,
"advy")
354 call this%advz%init(dm_xh,
"advz")
357 call this%du%init(this%dm_Xh,
'du')
358 call this%dv%init(this%dm_Xh,
'dv')
359 call this%dw%init(this%dm_Xh,
'dw')
360 call this%dp%init(this%dm_Xh,
'dp')
363 call this%setup_bcs(
user, params)
367 if (found)
call this%write_boundary_conditions()
369 call this%proj_prs%init(this%dm_Xh%size(), this%pr_projection_dim, &
370 this%pr_projection_activ_step)
372 call this%proj_vel%init(this%dm_Xh%size(), this%vel_projection_dim, &
373 this%vel_projection_activ_step)
379 if (params%valid_path(
'case.fluid.flow_rate_force'))
then
380 call this%vol_flow%init(this%dm_Xh, params)
384 call neko_log%section(
"Pressure solver")
387 'case.fluid.pressure_solver.max_iterations', &
389 call json_get(params,
'case.fluid.pressure_solver.type', solver_type)
390 call json_get(params,
'case.fluid.pressure_solver.preconditioner.type', &
393 'case.fluid.pressure_solver.preconditioner', precon_params)
395 'case.fluid.pressure_solver.absolute_tolerance', &
399 call neko_log%message(
'Type : ('// trim(solver_type) // &
400 ', ' // trim(precon_type) //
')')
401 write(log_buf,
'(A,ES13.6)')
'Abs tol :', abs_tol
404 call this%solver_factory(this%ksp_prs, this%dm_Xh%size(), &
405 solver_type, solver_maxiter, abs_tol, monitor)
406 call this%precon_factory_(this%pc_prs, this%ksp_prs, &
407 this%c_Xh, this%dm_Xh, this%gs_Xh, this%bcs_prs, &
408 precon_type, precon_params)
413 call json_get(params,
'case.numerics', numerics_params)
414 call advection_factory(this%adv, numerics_params, this%c_Xh, &
415 this%ulag, this%vlag, this%wlag, &
416 chkp%dtlag, chkp%tlag, this%ext_bdf, &
421 call this%chkp%add_fluid(this%u, this%v, this%w, this%p)
423 this%chkp%abx1 => this%abx1
424 this%chkp%abx2 => this%abx2
425 this%chkp%aby1 => this%aby1
426 this%chkp%aby2 => this%aby2
427 this%chkp%abz1 => this%abz1
428 this%chkp%abz2 => this%abz2
429 call this%chkp%add_lag(this%ulag, this%vlag, this%wlag)
437 subroutine fluid_pnpn_restart(this, chkp)
438 class(fluid_pnpn_t),
target,
intent(inout) :: this
439 type(chkp_t),
intent(inout) :: chkp
440 real(kind=rp) :: dtlag(10), tlag(10)
441 type(field_t) :: u_temp, v_temp, w_temp
447 n = this%u%dof%size()
448 if (
allocated(chkp%previous_mesh%elements) .or. &
449 chkp%previous_Xh%lx .ne. this%Xh%lx)
then
450 associate(u => this%u, v => this%v, w => this%w, p => this%p, &
451 c_xh => this%c_Xh, ulag => this%ulag, vlag => this%vlag, &
453 do concurrent(j = 1:n)
454 u%x(j,1,1,1) = u%x(j,1,1,1) * c_xh%mult(j,1,1,1)
455 v%x(j,1,1,1) = v%x(j,1,1,1) * c_xh%mult(j,1,1,1)
456 w%x(j,1,1,1) = w%x(j,1,1,1) * c_xh%mult(j,1,1,1)
457 p%x(j,1,1,1) = p%x(j,1,1,1) * c_xh%mult(j,1,1,1)
459 do i = 1, this%ulag%size()
460 do concurrent(j = 1:n)
461 ulag%lf(i)%x(j,1,1,1) = ulag%lf(i)%x(j,1,1,1) &
463 vlag%lf(i)%x(j,1,1,1) = vlag%lf(i)%x(j,1,1,1) &
465 wlag%lf(i)%x(j,1,1,1) = wlag%lf(i)%x(j,1,1,1) &
472 if (neko_bcknd_device .eq. 1)
then
473 associate(u => this%u, v => this%v, w => this%w, &
474 ulag => this%ulag, vlag => this%vlag, wlag => this%wlag,&
476 call device_memcpy(u%x, u%x_d, u%dof%size(), &
477 host_to_device, sync = .false.)
478 call device_memcpy(v%x, v%x_d, v%dof%size(), &
479 host_to_device, sync = .false.)
480 call device_memcpy(w%x, w%x_d, w%dof%size(), &
481 host_to_device, sync = .false.)
482 call device_memcpy(p%x, p%x_d, p%dof%size(), &
483 host_to_device, sync = .false.)
484 call device_memcpy(ulag%lf(1)%x, ulag%lf(1)%x_d, &
485 u%dof%size(), host_to_device, sync = .false.)
486 call device_memcpy(ulag%lf(2)%x, ulag%lf(2)%x_d, &
487 u%dof%size(), host_to_device, sync = .false.)
489 call device_memcpy(vlag%lf(1)%x, vlag%lf(1)%x_d, &
490 v%dof%size(), host_to_device, sync = .false.)
491 call device_memcpy(vlag%lf(2)%x, vlag%lf(2)%x_d, &
492 v%dof%size(), host_to_device, sync = .false.)
494 call device_memcpy(wlag%lf(1)%x, wlag%lf(1)%x_d, &
495 w%dof%size(), host_to_device, sync = .false.)
496 call device_memcpy(wlag%lf(2)%x, wlag%lf(2)%x_d, &
497 w%dof%size(), host_to_device, sync = .false.)
498 call device_memcpy(this%abx1%x, this%abx1%x_d, &
499 w%dof%size(), host_to_device, sync = .false.)
500 call device_memcpy(this%abx2%x, this%abx2%x_d, &
501 w%dof%size(), host_to_device, sync = .false.)
502 call device_memcpy(this%aby1%x, this%aby1%x_d, &
503 w%dof%size(), host_to_device, sync = .false.)
504 call device_memcpy(this%aby2%x, this%aby2%x_d, &
505 w%dof%size(), host_to_device, sync = .false.)
506 call device_memcpy(this%abz1%x, this%abz1%x_d, &
507 w%dof%size(), host_to_device, sync = .false.)
508 call device_memcpy(this%abz2%x, this%abz2%x_d, &
509 w%dof%size(), host_to_device, sync = .false.)
510 call device_memcpy(this%advx%x, this%advx%x_d, &
511 w%dof%size(), host_to_device, sync = .false.)
512 call device_memcpy(this%advy%x, this%advy%x_d, &
513 w%dof%size(), host_to_device, sync = .false.)
514 call device_memcpy(this%advz%x, this%advz%x_d, &
515 w%dof%size(), host_to_device, sync = .false.)
522 if (
allocated(chkp%previous_mesh%elements) &
523 .or. chkp%previous_Xh%lx .ne. this%Xh%lx)
then
525 call rotate_cyc(this%u%x, this%v%x, this%w%x, 1, this%c_Xh)
526 call this%gs_Xh%op(this%u, gs_op_add)
527 call this%gs_Xh%op(this%v, gs_op_add)
528 call this%gs_Xh%op(this%w, gs_op_add)
529 call this%gs_Xh%op(this%p, gs_op_add)
530 call rotate_cyc(this%u%x, this%v%x, this%w%x, 0, this%c_Xh)
532 do i = 1, this%ulag%size()
533 call rotate_cyc(this%ulag%lf(i)%x, this%vlag%lf(i)%x, &
534 this%wlag%lf(i)%x, 1, this%c_Xh)
535 call this%gs_Xh%op(this%ulag%lf(i), gs_op_add)
536 call this%gs_Xh%op(this%vlag%lf(i), gs_op_add)
537 call this%gs_Xh%op(this%wlag%lf(i), gs_op_add)
538 call rotate_cyc(this%ulag%lf(i)%x, this%vlag%lf(i)%x, &
539 this%wlag%lf(i)%x, 0, this%c_Xh)
642 subroutine fluid_pnpn_step(this, time, dt_controller)
643 class(fluid_pnpn_t),
target,
intent(inout) :: this
644 type(time_state_t),
intent(in) :: time
645 type(time_step_controller_t),
intent(in) :: dt_controller
649 type(ksp_monitor_t) :: ksp_results(4)
651 type(file_t) :: dump_file
652 class(bc_t),
pointer :: bc_i
653 type(non_normal_t),
pointer :: bc_j
655 if (this%freeze)
return
657 n = this%dm_Xh%size()
659 call profiler_start_region(
'Fluid', 1)
660 associate(u => this%u, v => this%v, w => this%w, p => this%p, &
661 u_e => this%u_e, v_e => this%v_e, w_e => this%w_e, &
662 du => this%du, dv => this%dv, dw => this%dw, dp => this%dp, &
663 u_res => this%u_res, v_res => this%v_res, w_res => this%w_res, &
664 p_res => this%p_res, ax_vel => this%Ax_vel, ax_prs => this%Ax_prs, &
666 c_xh => this%c_Xh, dm_xh => this%dm_Xh, gs_xh => this%gs_Xh, &
667 ulag => this%ulag, vlag => this%vlag, wlag => this%wlag, &
668 msh => this%msh, prs_res => this%prs_res, &
669 source_term => this%source_term, vel_res => this%vel_res, &
670 sumab => this%sumab, makeoifs => this%makeoifs, &
671 makeabf => this%makeabf, makebdf => this%makebdf, &
672 vel_projection_dim => this%vel_projection_dim, &
673 pr_projection_dim => this%pr_projection_dim, &
675 rho => this%rho, mu_tot => this%mu_tot, &
676 f_x => this%f_x, f_y => this%f_y, f_z => this%f_z, &
677 t => time%t, tstep => time%tstep, dt => time%dt, &
678 ext_bdf => this%ext_bdf, event => glb_cmd_event)
681 call sumab%compute_fluid(u_e, v_e, w_e, u, v, w, &
682 ulag, vlag, wlag, ext_bdf%advection_coeffs, ext_bdf%nadv)
685 call this%source_term%compute(time)
688 call this%bcs_vel%apply_vector(f_x%x, f_y%x, f_z%x, &
689 this%dm_Xh%size(), time, strong = .false.)
693 call this%adv%compute(u, v, w, &
694 this%advx, this%advy, this%advz, &
695 xh, this%c_Xh, dm_xh%size(), dt)
702 call makeabf%compute_fluid(this%abx1, this%aby1, this%abz1,&
703 this%abx2, this%aby2, this%abz2, &
704 f_x%x, f_y%x, f_z%x, &
705 rho%x(1,1,1,1), ext_bdf%advection_coeffs, n)
708 call makeoifs%compute_fluid(this%advx%x, this%advy%x, this%advz%x, &
709 f_x%x, f_y%x, f_z%x, &
710 rho%x(1,1,1,1), dt, n)
713 call this%adv%compute(u, v, w, &
715 xh, this%c_Xh, dm_xh%size())
721 call makeabf%compute_fluid(this%abx1, this%aby1, this%abz1,&
722 this%abx2, this%aby2, this%abz2, &
723 f_x%x, f_y%x, f_z%x, &
724 rho%x(1,1,1,1), ext_bdf%advection_coeffs, n)
727 call makebdf%compute_fluid(ulag, vlag, wlag, f_x%x, f_y%x, f_z%x, &
728 u, v, w, c_xh%B, rho%x(1,1,1,1), dt, &
729 ext_bdf%diffusion_coeffs, ext_bdf%ndiff, n)
736 call this%bc_apply_vel(time, strong = .true.)
737 call this%bc_apply_prs(time)
740 call this%update_material_properties(time)
743 call profiler_start_region(
'Pressure_residual', 18)
745 call prs_res%compute(p, p_res,&
750 this%bc_prs_surface, this%bc_sym_surface,&
751 ax_prs, ext_bdf%diffusion_coeffs(1), dt, &
755 if (.not. this%prs_dirichlet .and. neko_bcknd_device .eq. 1)
then
756 call device_ortho(p_res%x_d, this%glb_n_points, n)
757 else if (.not. this%prs_dirichlet)
then
758 call ortho(p_res%x, this%glb_n_points, n)
761 call gs_xh%op(p_res, gs_op_add, event)
762 call device_event_sync(event)
765 call this%bclst_dp%apply_scalar(p_res%x, p%dof%size(), time)
768 call profiler_end_region(
'Pressure_residual', 18)
771 call this%proj_prs%pre_solving(p_res%x, tstep, c_xh, n, dt_controller, &
774 call this%pc_prs%update()
776 call profiler_start_region(
'Pressure_solve', 3)
780 this%ksp_prs%solve(ax_prs, dp, p_res%x, n, c_xh, &
781 this%bclst_dp, gs_xh)
782 ksp_results(1)%name =
'Pressure'
785 call profiler_end_region(
'Pressure_solve', 3)
787 call this%proj_prs%post_solving(dp%x, ax_prs, c_xh, &
788 this%bclst_dp, gs_xh, n, tstep, dt_controller)
791 call field_add2(p, dp, n)
792 if (.not. this%prs_dirichlet .and. neko_bcknd_device .eq. 1)
then
793 call device_ortho(p%x_d, this%glb_n_points, n)
794 else if (.not. this%prs_dirichlet)
then
795 call ortho(p%x, this%glb_n_points, n)
799 call profiler_start_region(
'Velocity_residual', 19)
800 call vel_res%compute(ax_vel, u, v, w, &
801 u_res, v_res, w_res, &
805 mu_tot, rho, ext_bdf%diffusion_coeffs(1), &
808 call rotate_cyc(u_res%x, v_res%x, w_res%x, 1, c_xh)
809 call gs_xh%op(u_res, gs_op_add, event)
810 call device_event_sync(event)
811 call gs_xh%op(v_res, gs_op_add, event)
812 call device_event_sync(event)
813 call gs_xh%op(w_res, gs_op_add, event)
814 call device_event_sync(event)
815 call rotate_cyc(u_res%x, v_res%x, w_res%x, 0, c_xh)
818 call this%bclst_vel_res%apply(u_res, v_res, w_res, time)
821 call profiler_end_region(
'Velocity_residual', 19)
823 call this%proj_vel%pre_solving(u_res%x, v_res%x, w_res%x, &
824 tstep, c_xh, n, dt_controller,
'Velocity')
826 call this%pc_vel%update()
828 call profiler_start_region(
"Velocity_solve", 4)
829 ksp_results(2:4) = this%ksp_vel%solve_coupled(ax_vel, du, dv, dw, &
830 u_res%x, v_res%x, w_res%x, n, c_xh, &
831 this%bclst_du, this%bclst_dv, this%bclst_dw, gs_xh, &
832 this%ksp_vel%max_iter)
833 call profiler_end_region(
"Velocity_solve", 4)
834 if (this%full_stress_formulation)
then
835 ksp_results(2)%name =
'Momentum'
837 ksp_results(2)%name =
'X-Velocity'
838 ksp_results(3)%name =
'Y-Velocity'
839 ksp_results(4)%name =
'Z-Velocity'
842 call this%proj_vel%post_solving(du%x, dv%x, dw%x, ax_vel, c_xh, &
843 this%bclst_du, this%bclst_dv, this%bclst_dw, gs_xh, n, tstep, &
846 if (neko_bcknd_device .eq. 1)
then
847 call device_opadd2cm(u%x_d, v%x_d, w%x_d, &
848 du%x_d, dv%x_d, dw%x_d, 1.0_rp, n, msh%gdim)
850 call opadd2cm(u%x, v%x, w%x, du%x, dv%x, dw%x, 1.0_rp, n, msh%gdim)
853 if (this%forced_flow_rate)
then
855 call this%vol_flow%adjust( u, v, w, p, u_res, v_res, w_res, p_res, &
856 c_xh, gs_xh, ext_bdf, rho%x(1,1,1,1), mu_tot, &
857 dt, this%bclst_dp, this%bclst_du, this%bclst_dv, &
858 this%bclst_dw, this%bclst_vel_res, ax_vel, ax_prs, this%ksp_prs, &
859 this%ksp_vel, this%pc_prs, this%pc_vel, this%ksp_prs%max_iter, &
860 this%ksp_vel%max_iter)
863 call fluid_step_info(time, ksp_results, &
864 this%full_stress_formulation, this%strict_convergence, &
865 this%allow_stabilization)
868 call profiler_end_region(
'Fluid', 1)
873 subroutine fluid_pnpn_setup_bcs(this, user, params)
874 class(fluid_pnpn_t),
target,
intent(inout) :: this
875 type(user_t),
target,
intent(in) :: user
876 type(json_file),
intent(inout) :: params
877 integer :: i, n_bcs, zone_index, j, zone_size, global_zone_size, ierr
878 class(bc_t),
pointer :: bc_i
879 type(json_core) :: core
880 type(json_value),
pointer :: bc_object
881 type(json_file) :: bc_subdict
884 logical,
allocatable :: marked_zones(:)
885 integer,
allocatable :: zone_indices(:)
888 call this%bclst_vel_res%init()
889 call this%bclst_du%init()
890 call this%bclst_dv%init()
891 call this%bclst_dw%init()
892 call this%bclst_dp%init()
894 call this%bc_vel_res%init_from_components(this%c_Xh)
895 call this%bc_du%init_from_components(this%c_Xh)
896 call this%bc_dv%init_from_components(this%c_Xh)
897 call this%bc_dw%init_from_components(this%c_Xh)
898 call this%bc_dp%init_from_components(this%c_Xh)
901 call this%bc_prs_surface%init_from_components(this%c_Xh)
902 call this%bc_sym_surface%init_from_components(this%c_Xh)
905 if (params%valid_path(
'case.fluid.boundary_conditions'))
then
906 call params%info(
'case.fluid.boundary_conditions', n_children = n_bcs)
907 call params%get_core(core)
908 call params%get(
'case.fluid.boundary_conditions', bc_object, found)
913 call this%bcs_vel%init(n_bcs)
915 allocate(marked_zones(
size(this%msh%labeled_zones)))
916 marked_zones = .false.
920 call json_extract_item(core, bc_object, i, bc_subdict)
922 call json_get_or_lookup(bc_subdict,
"zone_indices", zone_indices)
927 do j = 1,
size(zone_indices)
928 zone_size = this%msh%labeled_zones(zone_indices(j))%size
929 call mpi_allreduce(zone_size, global_zone_size, 1, &
930 mpi_integer, mpi_max, neko_comm, ierr)
932 if (global_zone_size .eq. 0)
then
933 write(error_unit,
'(A, A, I0, A, A, I0, A)')
"*** ERROR ***: ",&
934 "Zone index ", zone_indices(j), &
935 " is invalid as this zone has 0 size, meaning it ", &
936 "is not in the mesh. Check fluid boundary condition ", &
941 if (marked_zones(zone_indices(j)))
then
942 write(error_unit,
'(A, A, I0, A, A, A, A)')
"*** ERROR ***: ", &
943 "Zone with index ", zone_indices(j), &
944 " has already been assigned a boundary condition. ", &
945 "Please check your boundary_conditions entry for the ", &
946 "fluid and make sure that each zone index appears only ", &
947 "in a single boundary condition."
950 marked_zones(zone_indices(j)) = .true.
955 call velocity_bc_factory(bc_i, this, bc_subdict, this%c_Xh,
user)
959 if (
associated(bc_i))
then
973 call this%bclst_vel_res%append(bc_i)
974 call this%bc_du%mark_facets(bc_i%bc_x%marked_facet)
975 call this%bc_dv%mark_facets(bc_i%bc_y%marked_facet)
976 call this%bc_dw%mark_facets(bc_i%bc_z%marked_facet)
978 call this%bcs_vel%append(bc_i)
980 call this%bc_sym_surface%mark_facets(bc_i%marked_facet)
981 type is (non_normal_t)
984 call this%bclst_vel_res%append(bc_i)
985 call this%bc_du%mark_facets(bc_i%bc_x%marked_facet)
986 call this%bc_dv%mark_facets(bc_i%bc_y%marked_facet)
987 call this%bc_dw%mark_facets(bc_i%bc_z%marked_facet)
988 type is (shear_stress_t)
990 call this%bclst_vel_res%append(bc_i%symmetry)
991 call this%bclst_du%append(bc_i%symmetry%bc_x)
992 call this%bclst_dv%append(bc_i%symmetry%bc_y)
993 call this%bclst_dw%append(bc_i%symmetry%bc_z)
995 call this%bcs_vel%append(bc_i)
996 type is (wall_model_bc_t)
998 call this%bclst_vel_res%append(bc_i%symmetry)
999 call this%bclst_du%append(bc_i%symmetry%bc_x)
1000 call this%bclst_dv%append(bc_i%symmetry%bc_y)
1001 call this%bclst_dw%append(bc_i%symmetry%bc_z)
1003 call this%bcs_vel%append(bc_i)
1010 if (bc_i%strong)
then
1011 call this%bc_vel_res%mark_facets(bc_i%marked_facet)
1012 call this%bc_du%mark_facets(bc_i%marked_facet)
1013 call this%bc_dv%mark_facets(bc_i%marked_facet)
1014 call this%bc_dw%mark_facets(bc_i%marked_facet)
1016 call this%bc_prs_surface%mark_facets(bc_i%marked_facet)
1019 call this%bcs_vel%append(bc_i)
1025 do i = 1,
size(this%msh%labeled_zones)
1026 if ((this%msh%labeled_zones(i)%size .gt. 0) .and. &
1027 (.not. marked_zones(i)))
then
1028 write(error_unit,
'(A, A, I0)')
"*** ERROR ***: ", &
1029 "No fluid boundary condition assigned to zone ", i
1037 call this%bcs_prs%init(n_bcs)
1041 call json_extract_item(core, bc_object, i, bc_subdict)
1043 call pressure_bc_factory(bc_i, this, bc_subdict, this%c_Xh,
user)
1047 if (
associated(bc_i))
then
1048 call this%bcs_prs%append(bc_i)
1051 if (bc_i%strong)
then
1052 call this%bc_dp%mark_facets(bc_i%marked_facet)
1060 do i = 1,
size(this%msh%labeled_zones)
1061 if (this%msh%labeled_zones(i)%size .gt. 0)
then
1062 call neko_error(
"No boundary_conditions entry in the case file!")
1068 call this%bcs_vel%init()
1069 call this%bcs_prs%init()
1073 call this%bc_prs_surface%finalize()
1074 call this%bc_sym_surface%finalize()
1076 call this%bc_vel_res%finalize()
1077 call this%bc_du%finalize()
1078 call this%bc_dv%finalize()
1079 call this%bc_dw%finalize()
1080 call this%bc_dp%finalize()
1082 call this%bclst_vel_res%append(this%bc_vel_res)
1083 call this%bclst_du%append(this%bc_du)
1084 call this%bclst_dv%append(this%bc_dv)
1085 call this%bclst_dw%append(this%bc_dw)
1086 call this%bclst_dp%append(this%bc_dp)
1089 this%prs_dirichlet = .not. this%bclst_dp%is_empty()
1090 call mpi_allreduce(mpi_in_place, this%prs_dirichlet, 1, &
1091 mpi_logical, mpi_lor, neko_comm)
1094 if (
allocated(marked_zones))
then
1095 deallocate(marked_zones)
1098 if (
allocated(zone_indices))
then
1099 deallocate(zone_indices)
1105 subroutine fluid_pnpn_write_boundary_conditions(this)
1111 class(fluid_pnpn_t),
target,
intent(inout) :: this
1112 type(dirichlet_t) :: bdry_mask
1113 type(field_t),
pointer :: bdry_field
1114 type(file_t) :: bdry_file
1115 integer :: temp_index, i
1116 class(bc_t),
pointer :: bci
1117 character(len=LOG_SIZE) :: log_buf
1119 call neko_log%section(
"Fluid boundary conditions")
1120 write(log_buf,
'(A)')
'Marking using integer keys in bdry0.f00000'
1121 call neko_log%message(log_buf)
1122 write(log_buf,
'(A)')
'Condition-value pairs: '
1123 call neko_log%message(log_buf)
1124 write(log_buf,
'(A)')
' no_slip = 1'
1125 call neko_log%message(log_buf)
1126 write(log_buf,
'(A)')
' velocity_value = 2'
1127 call neko_log%message(log_buf)
1128 write(log_buf,
'(A)')
' outflow, normal_outflow (+dong) = 3'
1129 call neko_log%message(log_buf)
1130 write(log_buf,
'(A)')
' symmetry = 4'
1131 call neko_log%message(log_buf)
1132 write(log_buf,
'(A)')
' periodic = 6'
1133 call neko_log%message(log_buf)
1134 write(log_buf,
'(A)')
' user_velocity = 7'
1135 call neko_log%message(log_buf)
1136 write(log_buf,
'(A)')
' user_pressure = 8'
1137 call neko_log%message(log_buf)
1138 write(log_buf,
'(A)')
' shear_stress = 9'
1139 call neko_log%message(log_buf)
1140 write(log_buf,
'(A)')
' wall_modelling = 10'
1141 call neko_log%message(log_buf)
1142 write(log_buf,
'(A)')
' blasius_profile = 11'
1143 call neko_log%message(log_buf)
1144 call neko_log%end_section()
1146 call neko_scratch_registry%request_field(bdry_field, temp_index, .true.)
1150 call bdry_mask%init_from_components(this%c_Xh, 6.0_rp)
1151 call bdry_mask%mark_zone(this%msh%periodic)
1152 call bdry_mask%finalize()
1153 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1154 call bdry_mask%free()
1156 do i = 1, this%bcs_prs%size()
1157 bci => this%bcs_prs%get(i)
1158 select type (
bc => bci)
1159 type is (zero_dirichlet_t)
1160 call bdry_mask%init_from_components(this%c_Xh, 3.0_rp)
1161 call bdry_mask%mark_facets(bci%marked_facet)
1162 call bdry_mask%finalize()
1163 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1164 call bdry_mask%free()
1166 call bdry_mask%init_from_components(this%c_Xh, 3.0_rp)
1167 call bdry_mask%mark_facets(bci%marked_facet)
1168 call bdry_mask%finalize()
1169 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1170 call bdry_mask%free()
1172 call bdry_mask%init_from_components(this%c_Xh, 8.0_rp)
1173 call bdry_mask%mark_facets(bci%marked_facet)
1174 call bdry_mask%finalize()
1175 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1176 call bdry_mask%free()
1180 do i = 1, this%bcs_vel%size()
1181 bci => this%bcs_vel%get(i)
1182 select type (
bc => bci)
1183 type is (zero_dirichlet_t)
1184 call bdry_mask%init_from_components(this%c_Xh, 1.0_rp)
1185 call bdry_mask%mark_facets(bci%marked_facet)
1186 call bdry_mask%finalize()
1187 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1188 call bdry_mask%free()
1190 call bdry_mask%init_from_components(this%c_Xh, 2.0_rp)
1191 call bdry_mask%mark_facets(bci%marked_facet)
1192 call bdry_mask%finalize()
1193 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1194 call bdry_mask%free()
1195 type is (symmetry_t)
1196 call bdry_mask%init_from_components(this%c_Xh, 4.0_rp)
1197 call bdry_mask%mark_facets(bci%marked_facet)
1198 call bdry_mask%finalize()
1199 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1200 call bdry_mask%free()
1202 call bdry_mask%init_from_components(this%c_Xh, 7.0_rp)
1203 call bdry_mask%mark_facets(bci%marked_facet)
1204 call bdry_mask%finalize()
1205 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1206 call bdry_mask%free()
1207 type is (shear_stress_t)
1208 call bdry_mask%init_from_components(this%c_Xh, 9.0_rp)
1209 call bdry_mask%mark_facets(bci%marked_facet)
1210 call bdry_mask%finalize()
1211 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1212 call bdry_mask%free()
1213 type is (wall_model_bc_t)
1214 call bdry_mask%init_from_components(this%c_Xh, 10.0_rp)
1215 call bdry_mask%mark_facets(bci%marked_facet)
1216 call bdry_mask%finalize()
1217 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1218 call bdry_mask%free()
1220 call bdry_mask%init_from_components(this%c_Xh, 11.0_rp)
1221 call bdry_mask%mark_facets(bci%marked_facet)
1222 call bdry_mask%finalize()
1223 call bdry_mask%apply_scalar(bdry_field%x, this%dm_Xh%size())
1224 call bdry_mask%free()
1229 call bdry_file%init(
'bdry.fld')
1230 call bdry_file%write(bdry_field)
1232 call neko_scratch_registry%relinquish_field(temp_index)