From a936d041851207c5e9f217dd277e5b3a0bd7e05a Mon Sep 17 00:00:00 2001 From: "M. Kanamaru" Date: Sat, 14 Oct 2023 16:26:33 +0900 Subject: [PATCH] Add a function to calculate mutual heating between the primary and secondary bodies (#76) * Add `mutual_heating!` * Update energy_flux.jl Add mutual heating by scattered light * Update TPM_Didymos.jl Update the version of the SPICE kernels. --- src/TPM.jl | 16 ++++------- src/energy_flux.jl | 69 ++++++++++++++++++++++++++++++++++++++++++++- test/TPM_Didymos.jl | 2 +- 3 files changed, 75 insertions(+), 12 deletions(-) diff --git a/src/TPM.jl b/src/TPM.jl index bb560569..e5d2f3f6 100644 --- a/src/TPM.jl +++ b/src/TPM.jl @@ -257,22 +257,18 @@ function run_TPM!(btpm::BinaryTPM, ephem, savepath) ProgressMeter.ijulia_behavior(:clear) for nₜ in eachindex(ephem.time) - r☉₁ = ephem.sun1[nₜ] - r☉₂ = ephem.sun2[nₜ] - sec_from_pri = ephem.sec[nₜ] - R₂₁ = ephem.S2P[nₜ] + r☉₁ = ephem.sun1[nₜ] # Sun's position in the primary's frame + r☉₂ = ephem.sun2[nₜ] # Sun's position in the secondary's frame + rₛ = ephem.sec[nₜ] # Secondary's position in the primary's frame + R₂₁ = ephem.S2P[nₜ] # Rotation matrix from secondary to primary frames ## Update enegey flux update_flux_sun!(btpm, r☉₁, r☉₂) update_flux_scat_single!(btpm) update_flux_rad_single!(btpm, nₜ) - ## Mutual-shadowing (eclipse) - mutual_shadowing!(btpm, r☉₁, sec_from_pri, R₂₁) - - ## Mutual-heating - # - # + mutual_shadowing!(btpm, r☉₁, rₛ, R₂₁) # Mutual-shadowing (eclipse) + mutual_heating!(btpm, nₜ, rₛ, R₂₁) # Mutual-heating update_thermal_force!(btpm, nₜ) diff --git a/src/energy_flux.jl b/src/energy_flux.jl index f1312600..7e1e90a4 100644 --- a/src/energy_flux.jl +++ b/src/energy_flux.jl @@ -267,7 +267,7 @@ end # **************************************************************** -# Eclipse of binary asteroid +# Mutual shadowing of binary asteroid # **************************************************************** @@ -408,3 +408,70 @@ function mutual_shadowing!(btpm::BinaryTPM, r☉, rₛ, R₂₁) end end + +# **************************************************************** +# Mutual heating of binary asteroid +# **************************************************************** + + +""" + mutual_heating!(btpm::BinaryTPM, nₜ::Integer, rₛ, R₂₁) + +Calculate the mutual heating between the primary and secondary asteroids. + +# Arguments +- `btpm` : Thermophysical model for a binary asteroid +- `nₜ` : Index of time step +- `rₛ` : Position of the secondary relative to the primary (NOT normalized) +- `R₂₁` : Rotation matrix from secondary to primary + +# TO DO +- Need to consider local horizon? +""" +function mutual_heating!(btpm::BinaryTPM, nₜ::Integer, rₛ, R₂₁) + + shape1 = btpm.pri.shape + shape2 = btpm.sec.shape + thermo_params1 = btpm.pri.thermo_params + thermo_params2 = btpm.sec.thermo_params + + for i in eachindex(shape1.faces) # △A₁B₁C₁ in primary + c₁ = shape1.face_centers[i] # Center of △A₁B₁C₁ + n̂₁ = shape1.face_normals[i] # Normal vector of △A₁B₁C₁ + a₁ = shape1.face_areas[i] # Area of △A₁B₁C₁ + + for j in eachindex(shape2.faces) # △A₂B₂C₂ in secondary + c₂ = shape2.face_centers[j] # Center of △A₂B₂C₂ + n̂₂ = shape2.face_normals[j] # Normal vector of △A₂B₂C₂ + a₂ = shape2.face_areas[j] # Area of △A₂B₂C₂ + + ## Transformation from secondary to primary frame + c₂ = R₂₁ * c₂ + rₛ + n̂₂ = R₂₁ * n̂₂ + + f₁₂, d₁₂, d̂₁₂ = view_factor(c₁, c₂, n̂₁, n̂₂, a₂) # View factor from △A₁B₁C₁ to △A₂B₂C₂ + f₂₁, d₂₁, d̂₂₁ = view_factor(c₂, c₁, n̂₂, n̂₁, a₁) # View factor from △A₂B₂C₂ to △A₁B₁C₁ + + ## if △A₁B₁C₁ and △A₂B₂C₂ are facing each other + if d̂₁₂ ⋅ n̂₁ > 0 && d̂₁₂ ⋅ n̂₂ < 0 + T₁ = btpm.pri.temperature[begin, i, nₜ] + T₂ = btpm.sec.temperature[begin, j, nₜ] + + ε₁ = (thermo_params1.ε isa Real ? thermo_params1.ε : thermo_params1.ε[i]) + ε₂ = (thermo_params2.ε isa Real ? thermo_params2.ε : thermo_params2.ε[j]) + A_B₁ = (thermo_params1.A_B isa Real ? thermo_params1.A_B : thermo_params1.A_B[i]) + A_B₂ = (thermo_params2.A_B isa Real ? thermo_params2.A_B : thermo_params2.A_B[j]) + A_TH₁ = (thermo_params1.A_TH isa Real ? thermo_params1.A_TH : thermo_params1.A_TH[i]) + A_TH₂ = (thermo_params2.A_TH isa Real ? thermo_params2.A_TH : thermo_params2.A_TH[j]) + + ## Mutual heating by scattered light + btpm.pri.flux[i, 2] += f₁₂ * A_B₂ * btpm.sec.flux[j, 1] + btpm.sec.flux[j, 2] += f₂₁ * A_B₁ * btpm.pri.flux[i, 1] + + ## Mutual heating by thermal radiation + btpm.pri.flux[i, 3] += ε₂ * σ_SB * (1 - A_TH₂) * f₁₂ * T₂^4 + btpm.sec.flux[j, 3] += ε₁ * σ_SB * (1 - A_TH₁) * f₂₁ * T₁^4 + end + end + end +end \ No newline at end of file diff --git a/test/TPM_Didymos.jl b/test/TPM_Didymos.jl index 0d833f73..8b4c68ab 100644 --- a/test/TPM_Didymos.jl +++ b/test/TPM_Didymos.jl @@ -9,7 +9,7 @@ ##= Download Files =## paths_kernel = [ - "fk/hera_v09.tf", + "fk/hera_v10.tf", "lsk/naif0012.tls", "pck/hera_didymos_v06.tpc", "spk/de432s.bsp",