Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add 2D covariant form using P4estMesh #31

Closed
wants to merge 89 commits into from
Closed
Show file tree
Hide file tree
Changes from 82 commits
Commits
Show all changes
89 commits
Select commit Hold shift + click to select a range
7ff4a57
linear advection on the sphere
tristanmontoya Jul 13, 2024
8236b78
formatter
tristanmontoya Jul 13, 2024
fcf6c75
very preliminary implementation of covariant form with p4est
tristanmontoya Jul 16, 2024
2fc2f67
removed untracked
tristanmontoya Jul 16, 2024
2e1c54c
removed allocations, now 100x faster
tristanmontoya Jul 16, 2024
c64a293
add DS_Store to gitignore
tristanmontoya Jul 16, 2024
5374da9
add DS_Store to gitignore
tristanmontoya Jul 16, 2024
f9a4163
made equations actually 2D
tristanmontoya Jul 17, 2024
3abdaa6
integrated upstream changes
tristanmontoya Jul 17, 2024
e6e08aa
analysis callback for covariant form
tristanmontoya Jul 18, 2024
e153f11
cleanup
tristanmontoya Jul 19, 2024
f45378e
separate Andres's spherical shell containers from main Trixi
tristanmontoya Jul 25, 2024
24a3793
Added containers and 2D p4est mesh from my spherical shell implementa…
amrueda Jul 26, 2024
eb768d9
Added element container with PtrArray for performance and modified th…
amrueda Jul 26, 2024
ca44965
format
amrueda Jul 26, 2024
8ec3e9c
Fixed bug in the definition of init_elements and added nelements(). e…
amrueda Jul 26, 2024
7caca96
Merge remote-tracking branch 'origin/arr/spherical_shell' into tm/p4e…
tristanmontoya Jul 29, 2024
f32afdf
integrated Andres's new container type with covariant solver
tristanmontoya Jul 29, 2024
b5df5c1
Merge remote-tracking branch 'origin/main' into tm/p4est_new_container
tristanmontoya Aug 6, 2024
c5483f3
added flux-differencing kernel for covariant form
tristanmontoya Aug 8, 2024
bab3363
Merge remote-tracking branch 'origin/main' into tm/covariant_flux_dif…
tristanmontoya Aug 15, 2024
bc1da0a
integrated Andrés' PR with covariant solver
tristanmontoya Aug 15, 2024
3d4f809
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Aug 17, 2024
ae53831
add tests for spherical advection in Cartesian coords
tristanmontoya Aug 17, 2024
eb81ca5
revert change to moist bubble case
tristanmontoya Aug 17, 2024
e9ec616
revert change to moist bubble case
tristanmontoya Aug 17, 2024
e0c6303
Merge branch 'tm/test_spherical_advection' into tm/covariant_form
tristanmontoya Aug 17, 2024
98b0f0e
covariant weak form with tests
tristanmontoya Aug 17, 2024
9799f81
removed shallow water from this branch
tristanmontoya Aug 17, 2024
73dda27
reorganize a bit
tristanmontoya Aug 18, 2024
7de998a
hard-code dimension of node coordinates to avoid type instability
tristanmontoya Aug 20, 2024
317033a
metric terms for shell of radius != 1
tristanmontoya Aug 20, 2024
2fd7610
Merge remote-tracking branch 'origin/tm/test_spherical_advection' int…
tristanmontoya Aug 20, 2024
351eb7a
test for covariant form is now on earth scale
tristanmontoya Aug 21, 2024
add6cc7
fix name of cartesian test
tristanmontoya Aug 22, 2024
e1eb237
moved i,j,element,cache into flux signatures for covariant form
tristanmontoya Sep 1, 2024
c4211d3
added test for flux differencing covariant form
tristanmontoya Sep 1, 2024
2fa4e01
Merge branch 'main' into tm/covariant_form
tristanmontoya Sep 1, 2024
44ac576
transformation between local coordinate systems now uses latitude-lon…
tristanmontoya Sep 4, 2024
73e858a
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Sep 4, 2024
fc52dfe
format
tristanmontoya Sep 4, 2024
2067837
make compatible with my PR trixi-framework/Trixi.jl#2068
tristanmontoya Sep 7, 2024
808e74c
Merge remote-tracking branch 'origin/tm/p4est_mesh_compat' into tm/co…
tristanmontoya Sep 7, 2024
2d5e6c5
separate containers to store geometric information specific to covari…
tristanmontoya Sep 9, 2024
6d4ae0d
add element-local mapping from Guba et al.
tristanmontoya Sep 10, 2024
bcb9fda
add reference to Guba et al. to docstring
tristanmontoya Sep 10, 2024
f4f94fb
Merge branch 'tm/element_local_mapping' into tm/covariant_form
tristanmontoya Sep 10, 2024
a69b558
new mapping works with cartesian solver solver in covariant_form branch
tristanmontoya Sep 10, 2024
d2cd693
exact metrics for element-local mapping
tristanmontoya Sep 10, 2024
4324e62
streamline tests and improve readability
tristanmontoya Sep 10, 2024
c46d20b
rename default DGSEM mapping
tristanmontoya Sep 10, 2024
937c069
Merge branch 'tm/element_local_mapping' into tm/covariant_form
tristanmontoya Sep 10, 2024
7ff3331
didn't need new analysis cache
tristanmontoya Sep 11, 2024
1248f88
improve comments
tristanmontoya Sep 11, 2024
9504e9c
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Sep 12, 2024
936dc49
refactor
tristanmontoya Sep 13, 2024
c4adf7c
remove DiffEqCallbacks for now
tristanmontoya Sep 13, 2024
ad0a60e
add better comments
tristanmontoya Sep 14, 2024
4b3642c
improve comments
tristanmontoya Sep 14, 2024
d3bc8f7
better documentation
tristanmontoya Sep 14, 2024
7d7ec99
add NDIMS_AMBIENT parameter to equations
tristanmontoya Sep 15, 2024
e5b3602
Merge remote-tracking branch 'origin/main' into tm/element_local_mapping
tristanmontoya Oct 5, 2024
4de0ca3
fix docstring format
tristanmontoya Oct 5, 2024
4412add
Merge branch 'tm/element_local_mapping' into tm/covariant_form
tristanmontoya Oct 5, 2024
731fa69
make link in docs work
tristanmontoya Oct 5, 2024
ca7118c
fix link in docs
tristanmontoya Oct 5, 2024
7db2950
Merge branch 'tm/element_local_mapping' into tm/covariant_form
tristanmontoya Oct 5, 2024
13fe226
documentation for the covariant solver
tristanmontoya Oct 5, 2024
f8b76ee
added surface central flux and test
tristanmontoya Oct 12, 2024
be033ab
fix trixi_compat
tristanmontoya Oct 12, 2024
87143be
specialize compute_coefficients! to dimension 2
tristanmontoya Oct 12, 2024
b8dc13a
format
tristanmontoya Oct 12, 2024
2b475d5
fix spelling
tristanmontoya Oct 12, 2024
eab59ff
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Oct 12, 2024
4cc1ec9
remove initial_condition parameter from rhs
tristanmontoya Oct 17, 2024
58ed6a9
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Nov 4, 2024
fb379e0
no need to use Float32 for physical constant defaults
tristanmontoya Nov 4, 2024
a4d7e4f
incorporate downstream changes
tristanmontoya Nov 4, 2024
9137903
format
tristanmontoya Nov 4, 2024
9333aa6
Merge remote-tracking branch 'origin/main' into tm/covariant_form
tristanmontoya Nov 6, 2024
9e9b3d7
merge changes from PR #36 (work in progress)
tristanmontoya Nov 10, 2024
78f8593
standardize test cases
tristanmontoya Nov 11, 2024
5d71c5a
move covariant form max_dt method to callbacks_step
tristanmontoya Nov 11, 2024
4f1b3dc
Fix comments
tristanmontoya Nov 11, 2024
0f0a8e7
generalize interface between equations and cache
tristanmontoya Nov 11, 2024
6d11443
relax relative tolerance on cartesian advection test)
tristanmontoya Nov 11, 2024
d515349
improve docs
tristanmontoya Nov 12, 2024
90fa2a6
streamline initial condition definition and improve docs
tristanmontoya Nov 13, 2024
b7a7f5a
tests for cartesian form now use standard and element-local mapping a…
tristanmontoya Nov 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,5 +25,5 @@ Static = "0.8, 1"
StaticArrayInterface = "1.5.1"
StaticArrays = "1"
StrideArrays = "0.1.28"
Trixi = "0.7, 0.8, 0.9"
Trixi = "0.9"
julia = "1.9"
Original file line number Diff line number Diff line change
Expand Up @@ -6,58 +6,21 @@ using TrixiAtmo
###############################################################################
# semidiscretization of the linear advection equation

# We use the Euler equations structure but modify the rhs! function to convert it to a
# variable-coefficient advection equation
equations = CompressibleEulerEquations3D(1.4)
polydeg = 3
cells_per_dimension = 5
initial_condition = initial_condition_gaussian
element_local_mapping = false

# We use the ShallowWaterEquations3D equations structure but modify the rhs! function to
# convert it to a variable-coefficient advection equation
equations = ShallowWaterEquations3D(gravity_constant = 0.0)

# Create DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux
polydeg = 3
solver = DGSEM(polydeg = polydeg, surface_flux = flux_lax_friedrichs)

# Initial condition for a Gaussian density profile with constant pressure
# and the velocity of a rotating solid body
function initial_condition_advection_sphere(x, t, equations::CompressibleEulerEquations3D)
# Gaussian density
rho = 1.0 + exp(-20 * (x[1]^2 + x[3]^2))
# Constant pressure
p = 1.0

# Spherical coordinates for the point x
if sign(x[2]) == 0.0
signy = 1.0
else
signy = sign(x[2])
end
# Co-latitude
colat = acos(x[3] / sqrt(x[1]^2 + x[2]^2 + x[3]^2))
# Latitude (auxiliary variable)
lat = -colat + 0.5 * pi
# Longitude
r_xy = sqrt(x[1]^2 + x[2]^2)
if r_xy == 0.0
phi = pi / 2
else
phi = signy * acos(x[1] / r_xy)
end

# Compute the velocity of a rotating solid body
# (alpha is the angle between the rotation axis and the polar axis of the spherical coordinate system)
v0 = 1.0 # Velocity at the "equator"
alpha = 0.0 #pi / 4
v_long = v0 * (cos(lat) * cos(alpha) + sin(lat) * cos(phi) * sin(alpha))
v_lat = -v0 * sin(phi) * sin(alpha)

# Transform to Cartesian coordinate system
v1 = -cos(colat) * cos(phi) * v_lat - sin(phi) * v_long
v2 = -cos(colat) * sin(phi) * v_lat + cos(phi) * v_long
v3 = sin(colat) * v_lat

return prim2cons(SVector(rho, v1, v2, v3, p), equations)
end

# Source term function to transform the Euler equations into the linear advection equations with variable advection velocity
function source_terms_convert_to_linear_advection(u, du, x, t,
equations::CompressibleEulerEquations3D,
equations::ShallowWaterEquations3D,
normal_direction)
v1 = u[2] / u[1]
v2 = u[3] / u[1]
Expand All @@ -66,18 +29,13 @@ function source_terms_convert_to_linear_advection(u, du, x, t,
s2 = du[1] * v1 - du[2]
s3 = du[1] * v2 - du[3]
s4 = du[1] * v3 - du[4]
s5 = 0.5 * (s2 * v1 + s3 * v2 + s4 * v3) - du[5]

return SVector(0.0, s2, s3, s4, s5)
return SVector(0.0, s2, s3, s4, 0.0)
end

initial_condition = initial_condition_advection_sphere

element_local_mapping = false

mesh = P4estMeshCubedSphere2D(5, 1.0, polydeg = polydeg,
mesh = P4estMeshCubedSphere2D(cells_per_dimension, EARTH_RADIUS, polydeg = polydeg,
initial_refinement_level = 0,
element_local_mapping = element_local_mapping)
element_local_mapping = true)

# A semidiscretization collects data structures and functions for the spatial discretization
semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
Expand All @@ -86,9 +44,7 @@ semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
###############################################################################
# ODE solvers, callbacks etc.

# Create ODE problem with time span from 0.0 to π
tspan = (0.0, pi)
ode = semidiscretize(semi, tspan)
ode = semidiscretize(semi, (0.0, 12 * SECONDS_PER_DAY))

# At the beginning of the main loop, the SummaryCallback prints a summary of the simulation setup
# and resets the timers
Expand All @@ -97,8 +53,7 @@ summary_callback = SummaryCallback()
# The AnalysisCallback allows to analyse the solution in regular intervals and prints the results
analysis_callback = AnalysisCallback(semi, interval = 10,
save_analysis = true,
extra_analysis_errors = (:conservation_error,),
extra_analysis_integrals = (Trixi.density,))
extra_analysis_errors = (:conservation_error,))

# The SaveSolutionCallback allows to save the solution to a file in regular intervals
save_solution = SaveSolutionCallback(interval = 10,
Expand Down
68 changes: 68 additions & 0 deletions examples/elixir_spherical_advection_covariant.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
###############################################################################
# DGSEM for the linear advection equation on the cubed sphere
###############################################################################
tristanmontoya marked this conversation as resolved.
Show resolved Hide resolved

using OrdinaryDiffEq, Trixi, TrixiAtmo

###############################################################################
# Spatial discretization

polydeg = 3
cells_per_dimension = 5
element_local_mapping = true
initial_condition = initial_condition_gaussian

mesh = P4estMeshCubedSphere2D(cells_per_dimension, EARTH_RADIUS, polydeg = polydeg,
initial_refinement_level = 0,
element_local_mapping = element_local_mapping)

equations = CovariantLinearAdvectionEquation2D()

# Local Lax-Friedrichs surface flux
surface_flux = flux_lax_friedrichs

# Standard weak-form volume integral
volume_integral = VolumeIntegralWeakForm()

# Create DG solver with polynomial degree = p and a local Lax-Friedrichs flux
solver = DGSEM(polydeg = polydeg, surface_flux = surface_flux,
volume_integral = volume_integral)

# A semidiscretization collects data structures and functions for the spatial discretization
semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)

###############################################################################
# ODE solvers, callbacks etc.

# Create ODE problem with time span from 0 to T
ode = semidiscretize(semi, (0.0, 12 * SECONDS_PER_DAY))

# At the beginning of the main loop, the SummaryCallback prints a summary of the simulation setup
# and resets the timers
summary_callback = SummaryCallback()

# The AnalysisCallback allows to analyse the solution in regular intervals and prints the results
analysis_callback = AnalysisCallback(semi, interval = 10,
save_analysis = true,
extra_analysis_errors = (:conservation_error,))

# The SaveSolutionCallback allows to save the solution to a file in regular intervals
save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2cons)

# The StepsizeCallback handles the re-calculation of the maximum Δt after each time step
stepsize_callback = StepsizeCallback(cfl = 0.7)

# Create a CallbackSet to collect all callbacks such that they can be passed to the ODE solver
callbacks = CallbackSet(summary_callback, analysis_callback, save_solution,
stepsize_callback)

###############################################################################
# run the simulation

# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks
sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),
dt = 1.0, save_everystep = false, callback = callbacks);

# Print the timer summary
summary_callback()
15 changes: 10 additions & 5 deletions src/TrixiAtmo.jl
Original file line number Diff line number Diff line change
Expand Up @@ -8,32 +8,37 @@ See also: [trixi-framework/TrixiAtmo.jl](https://github.com/trixi-framework/Trix
"""
module TrixiAtmo

using Reexport: @reexport
using Trixi
using MuladdMacro: @muladd
using Static: True, False
using StrideArrays: PtrArray
using StaticArrayInterface: static_size
using LinearAlgebra: norm
using LinearAlgebra: norm, dot
using Reexport: @reexport
using LoopVectorization: @turbo
@reexport using StaticArrays: SVector
@reexport using StaticArrays: SVector, SMatrix

include("auxiliary/auxiliary.jl")
include("equations/equations.jl")
include("meshes/meshes.jl")
include("semidiscretization/semidiscretization.jl")
include("solvers/solvers.jl")
include("semidiscretization/semidiscretization_hyperbolic_2d_manifold_in_3d.jl")
include("callbacks_step/stepsize_dg2d.jl")
include("callbacks_step/callbacks_step.jl")

export CompressibleMoistEulerEquations2D, ShallowWaterEquations3D
export CompressibleMoistEulerEquations2D, ShallowWaterEquations3D,
CovariantLinearAdvectionEquation2D

export flux_chandrashekar, flux_LMARS

export velocity, waterheight, pressure, energy_total, energy_kinetic, energy_internal,
lake_at_rest_error, source_terms_lagrange_multiplier,
clean_solution_lagrange_multiplier!
export P4estCubedSphere2D, MetricTermsCrossProduct, MetricTermsInvariantCurl
export examples_dir
export EARTH_RADIUS, EARTH_GRAVITATIONAL_ACCELERATION,
EARTH_ROTATION_RATE, SECONDS_PER_DAY, spherical2cartesian
export initial_condition_gaussian

export examples_dir
end # module TrixiAtmo
1 change: 1 addition & 0 deletions src/auxiliary/auxiliary.jl
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ read-only and should *not* be modified.
To find out which files are available, use, e.g., `readdir`:

# Examples

```@example
readdir(examples_dir())
```
Expand Down
54 changes: 54 additions & 0 deletions src/callbacks_step/analysis_covariant.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
@muladd begin
#! format: noindent

function Trixi.analyze(::typeof(Trixi.entropy_timederivative), du, u, t,
mesh::P4estMesh{2},
equations::AbstractCovariantEquations{2}, dg::DG, cache)
# Calculate ∫(∂S/∂u ⋅ ∂u/∂t)dΩ
Trixi.integrate_via_indices(u, mesh, equations, dg, cache,
du) do u, i, j, element, equations, dg, du
u_node = Trixi.get_node_vars(u, equations, dg, i, j, element)
du_node = Trixi.get_node_vars(du, equations, dg, i, j, element)
dot(cons2entropy(u_node, equations, cache.elements, i, j, element), du_node)
end
end

function Trixi.calc_error_norms(func, u, t, analyzer, mesh::P4estMesh{2},
equations::AbstractCovariantEquations{2},
initial_condition, dg::DGSEM, cache, cache_analysis)
(; weights) = dg.basis
(; node_coordinates) = cache.elements

# Set up data structures
l2_error = zero(func(Trixi.get_node_vars(u, equations, dg, 1, 1, 1), equations))
linf_error = copy(l2_error)
total_volume = zero(real(mesh))

# Iterate over all elements for error calculations
for element in eachelement(dg, cache)

# Calculate errors at each volume quadrature node
for j in eachnode(dg), i in eachnode(dg)
x = Trixi.get_node_coords(node_coordinates, equations, dg, i, j, element)

u_exact = spherical2contravariant(initial_condition(x, t, equations),
equations, cache.elements, i, j, element)

u_numerical = Trixi.get_node_vars(u, equations, dg, i, j, element)

diff = func(u_exact, equations) - func(u_numerical, equations)

J = volume_element(cache.elements, i, j, element)

l2_error += diff .^ 2 * (weights[i] * weights[j] * J)
linf_error = @. max(linf_error, abs(diff))
total_volume += weights[i] * weights[j] * J
end
end

# For L2 error, divide by total volume
l2_error = @. sqrt(l2_error / total_volume)

return l2_error, linf_error
end
end # muladd
2 changes: 2 additions & 0 deletions src/callbacks_step/callbacks_step.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
include("analysis_covariant.jl")
include("stepsize_dg2d.jl")
13 changes: 10 additions & 3 deletions src/callbacks_step/stepsize_dg2d.jl
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
@muladd begin
#! format: noindent

# Specialization of max_dt function for 3D equations in 2D manifolds
function Trixi.max_dt(u, t,
mesh::Union{StructuredMesh{2}, UnstructuredMesh2D, P4estMesh{2},
T8codeMesh{2}},
constant_speed::False, equations::AbstractEquations{3}, dg::DG, cache)
constant_speed::False, equations::AbstractEquations{3}, dg::DG,
cache)
# to avoid a division by zero if the speed vanishes everywhere,
# e.g. for steady-state linear advection
max_scaled_speed = nextfloat(zero(t))
Expand All @@ -16,11 +20,13 @@ function Trixi.max_dt(u, t,
lambda1, lambda2, lambda3 = max_abs_speeds(u_node, equations)

# Local speeds transformed to the reference element
Ja11, Ja12, Ja13 = Trixi.get_contravariant_vector(1, contravariant_vectors, i,
Ja11, Ja12, Ja13 = Trixi.get_contravariant_vector(1, contravariant_vectors,
i,
j,
element)
lambda1_transformed = abs(Ja11 * lambda1 + Ja12 * lambda2 + Ja13 * lambda3)
Ja21, Ja22, Ja23 = Trixi.get_contravariant_vector(2, contravariant_vectors, i,
Ja21, Ja22, Ja23 = Trixi.get_contravariant_vector(2, contravariant_vectors,
i,
j,
element)
lambda2_transformed = abs(Ja21 * lambda1 + Ja22 * lambda2 + Ja23 * lambda3)
Expand All @@ -36,3 +42,4 @@ function Trixi.max_dt(u, t,

return 2 / (nnodes(dg) * max_scaled_speed)
end
end # muladd
Loading
Loading