543# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
545# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
547# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
549# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
551# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
553# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
555# 209 "/home/runner/work/MFC/MFC/src/pre_process/m_assign_variables.fpp"
558 integer,
intent(in) :: patch_id
559 integer,
intent(in) ::
j,
k,
l
560 real(wp),
intent(in) :: eta
561#ifdef MFC_MIXED_PRECISION
562 integer(kind=1),
dimension(0:m,0:n,0:p),
intent(inout) :: patch_id_fp
564 integer,
dimension(0:m,0:n,0:p),
intent(inout) :: patch_id_fp
566 type(scalar_field),
dimension(1:sys_size),
intent(inout) :: q_prim_vf
571 real(wp) :: lit_gamma
575 real(wp) :: orig_gamma
576 real(wp) :: orig_pi_inf
580 real(wp) :: rcoord, theta, phi, xi_sph
581 real(wp),
dimension(3) :: xi_cart
582 real(wp) :: ys(1:num_species)
583 real(stp),
dimension(sys_size) :: orig_prim_vf
585 integer :: smooth_patch_id
587 smooth_patch_id = patch_icpp(patch_id)%smooth_patch_id
590 orig_prim_vf(i) = q_prim_vf(i)%sf(
j,
k,
l)
593 if (mpp_lim .and. bubbles_euler)
then
596 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
600 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
601 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
605 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, orig_rho, orig_gamma, orig_pi_inf, orig_qv)
607 if (.not. igr .or. num_fluids > 1)
then
608 do i = eqn_idx%adv%beg, eqn_idx%adv%end
609 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(patch_id)%alpha(i - eqn_idx%E)
613 if (mpp_lim .and. bubbles_euler)
then
616 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
620 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
621 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
625 if (model_eqns /= 4)
then
626 do i = 1, eqn_idx%cont%end
627 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(patch_id)%alpha_rho(i)
631 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, patch_icpp(patch_id)%rho, patch_icpp(patch_id)%gamma, &
632 & patch_icpp(patch_id)%pi_inf, patch_icpp(patch_id)%qv)
634 if (model_eqns /= 4)
then
635 do i = 1, eqn_idx%cont%end
636 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(smooth_patch_id)%alpha_rho(i)
640 if (.not. igr .or. num_fluids > 1)
then
641 do i = eqn_idx%adv%beg, eqn_idx%adv%end
642 q_prim_vf(i)%sf(
j,
k,
l) = patch_icpp(smooth_patch_id)%alpha(i - eqn_idx%E)
646 if (mpp_lim .and. bubbles_euler)
then
649 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
653 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
654 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
658 if (bubbles_euler)
then
660 mur = r0(i)*patch_icpp(smooth_patch_id)%r0/r0ref
661 muv = patch_icpp(smooth_patch_id)%v0
664 if (dist_type == 1)
then
665 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
666 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = mur
667 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
668 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = mur**2 + (sigr*r0ref)**2
669 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = mur*muv + rhorv*(sigr*r0ref)*(sigv*sqrt(p0ref/rho0ref))
670 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
671 else if (dist_type == 2)
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) = exp((sigr**2)/2._wp)*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) = exp((sigr**2)*2._wp)*(mur**2)
676 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur*muv
677 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
680 q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l) = mur
681 q_prim_vf(qbmm_idx%vs(i))%sf(
j,
k,
l) = muv
682 if (.not. polytropic)
then
683 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%p0
684 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%m0
693 r3bar = r3bar + weight(i)*(q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l))**3._wp
695 q_prim_vf(eqn_idx%n)%sf(
j,
k,
l) = 3*q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l)/(4*pi*r3bar)
699 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, patch_icpp(smooth_patch_id)%rho, &
700 & patch_icpp(smooth_patch_id)%gamma, patch_icpp(smooth_patch_id)%pi_inf, &
701 & patch_icpp(smooth_patch_id)%qv)
703 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))
705 if (.not. igr .or. num_fluids > 1)
then
706 do i = eqn_idx%adv%beg, eqn_idx%adv%end
707 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)
713 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)
714 q_prim_vf(eqn_idx%B%beg + 1)%sf(
j,
k, &
715 &
l) = eta*patch_icpp(patch_id)%Bz + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 1)
717 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)
718 q_prim_vf(eqn_idx%B%beg + 1)%sf(
j,
k, &
719 &
l) = eta*patch_icpp(patch_id)%By + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 1)
720 q_prim_vf(eqn_idx%B%beg + 2)%sf(
j,
k, &
721 &
l) = eta*patch_icpp(patch_id)%Bz + (1._wp - eta)*orig_prim_vf(eqn_idx%B%beg + 2)
726 do i = 1, (eqn_idx%stress%end - eqn_idx%stress%beg) + 1
727 q_prim_vf(i + eqn_idx%stress%beg - 1)%sf(
j,
k, &
728 &
l) = (eta*patch_icpp(patch_id)%tau_e(i) + (1._wp - eta)*orig_prim_vf(i + eqn_idx%stress%beg - 1))
732 if (hyperelasticity)
then
734 rcoord = sqrt((x_cc(
j)**2 + y_cc(
k)**2 + z_cc(
l)**2))
735 theta = atan2(y_cc(
k), x_cc(
j))
736 phi = atan2(sqrt(x_cc(
j)**2 + y_cc(
k)**2), z_cc(
l))
738 xi_sph = (rcoord**3 - r0ref**3 + 1._wp)**(1._wp/3._wp)
739 xi_cart(1) = xi_sph*sin(phi)*cos(theta)
740 xi_cart(2) = xi_sph*sin(phi)*sin(theta)
741 xi_cart(3) = xi_sph*cos(phi)
750 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)
754 if (mpp_lim .and. bubbles_euler)
then
757 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
761 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
762 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
766 if (model_eqns /= 4)
then
768 do i = 1, eqn_idx%cont%end
769 q_prim_vf(i)%sf(
j,
k,
l) = eta*patch_icpp(patch_id)%alpha_rho(i) + (1._wp - eta)*orig_prim_vf(i)
775 lit_gamma = gs_min(1)
778 q_prim_vf(1)%sf(
j,
k,
l) = (((q_prim_vf(eqn_idx%E)%sf(
j,
k, &
779 &
l) + pi_inf)/(pref + pi_inf))**(1/lit_gamma))*rhoref*(1 - q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l))
782 call s_convert_to_mixture_variables(q_prim_vf,
j,
k,
l, rho, gamma, pi_inf, qv)
784 do i = 1, eqn_idx%E - eqn_idx%mom%beg
785 q_prim_vf(i + eqn_idx%cont%end)%sf(
j,
k, &
786 &
l) = (eta*patch_icpp(patch_id)%vel(i) + (1._wp - eta)*orig_prim_vf(i + eqn_idx%cont%end))
791 real(wp) :: sum, term
794 do i = 1, num_species
795 term = eta*patch_icpp(patch_id)%Y(i) + (1._wp - eta)*patch_icpp(smooth_patch_id)%Y(i)
796 q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l) = term
800 if (sum < verysmall)
then
804 do i = 1, num_species
805 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
806 ys(i) = q_prim_vf(eqn_idx%species%beg + i - 1)%sf(
j,
k,
l)
812 if (mixlayer_vel_profile)
then
813 q_prim_vf(1 + eqn_idx%cont%end)%sf(
j,
k, &
814 &
l) = (eta*patch_icpp(patch_id)%vel(1)*tanh(y_cc(
k)*mixlayer_vel_coef) + (1._wp - eta)*orig_prim_vf(1 &
815 & + eqn_idx%cont%end))
819 if (model_eqns == 3)
then
820 do i = eqn_idx%int_en%beg, eqn_idx%int_en%end
821 q_prim_vf(i)%sf(
j,
k,
l) = q_prim_vf(eqn_idx%E)%sf(
j,
k,
l)
825 if (bubbles_euler)
then
827 mur = r0(i)*patch_icpp(patch_id)%r0/r0ref
828 muv = patch_icpp(patch_id)%v0
831 if (dist_type == 1)
then
832 q_prim_vf(qbmm_idx%fullmom(i, 0, 0))%sf(
j,
k,
l) = 1._wp
833 q_prim_vf(qbmm_idx%fullmom(i, 1, 0))%sf(
j,
k,
l) = mur
834 q_prim_vf(qbmm_idx%fullmom(i, 0, 1))%sf(
j,
k,
l) = muv
835 q_prim_vf(qbmm_idx%fullmom(i, 2, 0))%sf(
j,
k,
l) = mur**2 + (sigr*r0ref)**2
836 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = mur*muv + rhorv*(sigr*r0ref)*(sigv*sqrt(p0ref/rho0ref))
837 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
838 else if (dist_type == 2)
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) = exp((sigr**2)/2._wp)*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) = exp((sigr**2)*2._wp)*(mur**2)
843 q_prim_vf(qbmm_idx%fullmom(i, 1, 1))%sf(
j,
k,
l) = exp((sigr**2)/2._wp)*mur*muv
844 q_prim_vf(qbmm_idx%fullmom(i, 0, 2))%sf(
j,
k,
l) = muv**2 + (sigv*sqrt(p0ref/rho0ref))**2
847 q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l) = mur
848 q_prim_vf(qbmm_idx%vs(i))%sf(
j,
k,
l) = muv
850 if (.not. polytropic)
then
851 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%p0
852 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = patch_icpp(patch_id)%m0
861 r3bar = r3bar + weight(i)*(q_prim_vf(qbmm_idx%rs(i))%sf(
j,
k,
l))**3._wp
863 q_prim_vf(eqn_idx%n)%sf(
j,
k,
l) = 3*q_prim_vf(eqn_idx%alf)%sf(
j,
k,
l)/(4*pi*r3bar)
867 if (mpp_lim .and. bubbles_euler)
then
870 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
874 do i = eqn_idx%adv%beg, eqn_idx%adv%end - 1
875 q_prim_vf(i)%sf = q_prim_vf(i)%sf*(1._wp - q_prim_vf(eqn_idx%alf)%sf)/
alf_sum%sf
879 if (bubbles_euler .and. (.not. polytropic) .and. (.not. qbmm))
then
881 if (f_is_default(real(q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l), kind=wp)))
then
882 q_prim_vf(qbmm_idx%ps(i))%sf(
j,
k,
l) = pb0(i)
884 if (f_is_default(real(q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l), kind=wp)))
then
885 q_prim_vf(qbmm_idx%ms(i))%sf(
j,
k,
l) = mass_v0(i)
890 if (surface_tension)
then
891 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)
894 if (1._wp - eta < 1.e-16_wp) patch_id_fp(
j,
k,
l) = patch_id