550# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
552# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
554# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
556# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
558# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
560# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
562# 210 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
565 integer,
intent(in) :: patch_id
566 integer,
intent(in) ::
j,
k,
l
567 real(wp),
intent(in) :: eta
568#ifdef MFC_MIXED_PRECISION
569 integer(kind=1),
dimension(0:m,0:n,0:p),
intent(inout) :: patch_id_fp
571 integer,
dimension(0:m,0:n,0:p),
intent(inout) :: patch_id_fp
573 type(scalar_field),
dimension(1:sys_size),
intent(inout) :: q_prim_vf
578 real(wp) :: lit_gamma
582 real(wp) :: orig_gamma
583 real(wp) :: orig_pi_inf
587 real(wp) :: rcoord, theta, phi, xi_sph
588 real(wp),
dimension(3) :: xi_cart
589 real(wp) :: ys(1:num_species)
590 real(stp),
dimension(sys_size) :: orig_prim_vf
592 integer :: smooth_patch_id
594 smooth_patch_id = patch_icpp(patch_id)%smooth_patch_id
597 orig_prim_vf(i) = q_prim_vf(i)%sf(
j,
k,
l)
600 if (mpp_lim .and. bubbles_euler)
then
603 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
607 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
608 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
612 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, orig_rho, orig_gamma, orig_pi_inf, orig_qv)
614 if (.not. igr .or. num_fluids > 1)
then
615 do i = eqn_idx%adv%beg, eqn_idx%adv%end
616 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(patch_id)%alpha(i - eqn_idx%E)
620 if (mpp_lim .and. bubbles_euler)
then
623 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
627 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
628 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
632 if (model_eqns /= model_eqns_4eq)
then
633 do i = 1, eqn_idx%cont%end
634 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(patch_id)%alpha_rho(i)
638 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, patch_icpp(patch_id)%rho, patch_icpp(patch_id)%gamma, &
639 & patch_icpp(patch_id)%pi_inf, patch_icpp(patch_id)%qv)
641 if (model_eqns /= model_eqns_4eq)
then
642 do i = 1, eqn_idx%cont%end
643 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(smooth_patch_id)%alpha_rho(i)
647 if (.not. igr .or. num_fluids > 1)
then
648 do i = eqn_idx%adv%beg, eqn_idx%adv%end
649 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(smooth_patch_id)%alpha(i - eqn_idx%E)
653 if (mpp_lim .and. bubbles_euler)
then
656 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
660 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
661 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
665 if (bubbles_euler)
then
667 mur = r0(i)*patch_icpp(smooth_patch_id)%r0/r0ref
668 muv = patch_icpp(smooth_patch_id)%v0
671 if (dist_type == 1)
then
672 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
673 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = mur
674 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
675 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = mur**2 + (sigr*r0ref)**2
676 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = mur*muv + rhorv*(sigr*r0ref)*(sigv*sqrt(p0ref/rho0ref))
677 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
678 else if (dist_type == 2)
then
679 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
680 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur
681 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
682 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = exp((sigr**2)*2._wp)*(mur**2)
683 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur*muv
684 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
687 q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l) = mur
688 q_prim_vf(qbmm_idx%vs(i))%sf(
j,
k,
l) = muv
689 if (.not. polytropic)
then
690 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%p0
691 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%m0
700 r3bar = r3bar + weight(i)*(q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l))**3._wp
702 q_prim_vf(eqn_idx%n)%sf(
j,
k,
l) = 3*q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l)/(4*pi*r3bar)
706 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, patch_icpp(smooth_patch_id)%rho, &
707 & patch_icpp(smooth_patch_id)%gamma, patch_icpp(smooth_patch_id)%pi_inf, &
708 & patch_icpp(smooth_patch_id)%qv)
710 q_prim_vf(eqn_idx%E)%sf(
j,
k,
l) = (eta*patch_icpp(patch_id)%pres + (1._wp - eta)*orig_prim_vf(eqn_idx%E))
712 if (.not. igr .or. num_fluids > 1)
then
713 do i = eqn_idx%adv%beg, eqn_idx%adv%end
714 q_prim_vf(i)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%alpha(i - eqn_idx%E) + (1._wp - eta)*orig_prim_vf(i)
720 q_prim_vf(eqn_idx%B%beg)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%By + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg)
721 q_prim_vf(eqn_idx%B%beg + 1)%sf(
j,
k, &
722 &
l) = eta*patch_icpp(patch_id)%Bz + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 1)
724 q_prim_vf(eqn_idx%B%beg)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%Bx + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg)
725 q_prim_vf(eqn_idx%B%beg + 1)%sf(
j,
k, &
726 &
l) = eta*patch_icpp(patch_id)%By + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 1)
727 q_prim_vf(eqn_idx%B%beg + 2)%sf(
j,
k, &
728 &
l) = eta*patch_icpp(patch_id)%Bz + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 2)
733 do i = 1, (eqn_idx%stress%end - eqn_idx%stress%beg) + 1
734 q_prim_vf(i + eqn_idx%stress%beg - 1)%sf(
j,
k, &
735 &
l) = (eta*patch_icpp(patch_id)%tau_e(i) + (1._wp - eta)*orig_prim_vf(i + eqn_idx%stress%beg - 1))
739 if (hyperelasticity)
then
741 rcoord = sqrt((x_cc(
j)**2 + y_cc(
k)**2 + z_cc(
l)**2))
742 theta = atan2(y_cc(
k), x_cc(
j))
743 phi = atan2(sqrt(x_cc(
j)**2 + y_cc(
k)**2), z_cc(
l))
745 xi_sph = (rcoord**3 - r0ref**3 + 1._wp)**(1._wp/3._wp)
746 xi_cart(1) = xi_sph*sin(phi)*cos(theta)
747 xi_cart(2) = xi_sph*sin(phi)*sin(theta)
748 xi_cart(3) = xi_sph*cos(phi)
757 q_prim_vf(i + eqn_idx%xi%beg - 1)%sf(
j,
k,
l) = eta*xi_cart(i) + (1._wp - eta)*orig_prim_vf(i + eqn_idx%xi%beg - 1)
761 if (mpp_lim .and. bubbles_euler)
then
764 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
768 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
769 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
773 if (model_eqns /= model_eqns_4eq)
then
775 do i = 1, eqn_idx%cont%end
776 q_prim_vf(i)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%alpha_rho(i) + (1._wp - eta)*orig_prim_vf(i)
782 lit_gamma = gs_min(1)
785 q_prim_vf(1)%sf(
j,
k,
l) = (((q_prim_vf(eqn_idx%E)%sf(
j,
k, &
786 &
l) + pi_inf)/(pref + pi_inf))**(1/lit_gamma))*rhoref*(1 - q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l))
789 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, rho, gamma, pi_inf, qv)
791 do i = 1, eqn_idx%E - eqn_idx%mom%beg
792 q_prim_vf(i + eqn_idx%cont%end)%sf(
j,
k, &
793 &
l) = (eta*patch_icpp(patch_id)%vel(i) + (1._wp - eta)*orig_prim_vf(i + eqn_idx%cont%end))
798 real(wp) :: sum, term
801 do i = 1, num_species
802 term = eta*patch_icpp(patch_id)%Y(i) + (1._wp - eta)*patch_icpp(smooth_patch_id)%Y(i)
803 q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l) = term
807 if (sum < verysmall)
then
811 do i = 1, num_species
812 q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l) = q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l)/sum
813 ys(i) = q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l)
819 if (mixlayer_vel_profile)
then
820 q_prim_vf(1 + eqn_idx%cont%end)%sf(
j,
k, &
821 &
l) = (eta*patch_icpp(patch_id)%vel(1)*tanh(y_cc(
k)*mixlayer_vel_coef) + (1._wp - eta)*orig_prim_vf(1 &
822 & + eqn_idx%cont%end))
826 if (model_eqns == model_eqns_6eq)
then
827 do i = eqn_idx%int_en%beg, eqn_idx%int_en%end
828 q_prim_vf(i)%sf(
j,
k,
l) = q_prim_vf(eqn_idx%E)%sf(
j,
k,
l)
832 if (bubbles_euler)
then
834 mur = r0(i)*patch_icpp(patch_id)%r0/r0ref
835 muv = patch_icpp(patch_id)%v0
838 if (dist_type == 1)
then
839 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
840 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = mur
841 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
842 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = mur**2 + (sigr*r0ref)**2
843 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = mur*muv + rhorv*(sigr*r0ref)*(sigv*sqrt(p0ref/rho0ref))
844 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
845 else if (dist_type == 2)
then
846 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
847 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur
848 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
849 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = exp((sigr**2)*2._wp)*(mur**2)
850 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur*muv
851 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
854 q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l) = mur
855 q_prim_vf(qbmm_idx%vs(i))%sf(
j,
k,
l) = muv
857 if (.not. polytropic)
then
858 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%p0
859 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%m0
868 r3bar = r3bar + weight(i)*(q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l))**3._wp
870 q_prim_vf(eqn_idx%n)%sf(
j,
k,
l) = 3*q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l)/(4*pi*r3bar)
874 if (mpp_lim .and. bubbles_euler)
then
877 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
881 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
882 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
886 if (bubbles_euler .and. (.not. polytropic) .and. (.not. qbmm))
then
888 if (f_is_default(real(q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l), kind=wp)))
then
889 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = pb0(i)
891 if (f_is_default(real(q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l), kind=wp)))
then
892 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = mass_v0(i)
897 if (surface_tension)
then
898 q_prim_vf(eqn_idx%c)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%cf_val + (1._wp - eta)*orig_prim_vf(eqn_idx%c)
901 if (1._wp - eta < 1.e-16_wp) patch_id_fp(
j,
k,
l) = patch_id