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

WIP: Add FV method for T8codeMesh #1844

Draft
wants to merge 97 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 87 commits
Commits
Show all changes
97 commits
Select commit Hold shift + click to select a range
38ebc81
Add first working first order FV method on T8codeMesh (periodic bound…
bennibolm Feb 13, 2024
3c75fb9
Add simple routine to create `cmesh`s by hand
bennibolm Feb 13, 2024
2a7f417
fmt
bennibolm Feb 13, 2024
f59dc75
Fix bug in visualization
bennibolm Feb 13, 2024
398ed0d
Relocate function to adapt to "normal" structure
bennibolm Feb 13, 2024
1c5a941
Add tests
bennibolm Feb 13, 2024
67a25da
Rename Interface Container
bennibolm Feb 13, 2024
2d51511
Activate tests; clean up
bennibolm Feb 14, 2024
173e4b9
Merge branch 'main' into t8codemesh-fv
bennibolm Feb 20, 2024
3f09f80
Remove comments in elixirs [skip ci]
bennibolm Feb 20, 2024
3abe300
Change dispatch from T8codeMesh to FV
bennibolm Feb 20, 2024
f4511e7
Remove not-needed lines of code
bennibolm Feb 20, 2024
22527bd
Add comment; correct dispatch
bennibolm Feb 20, 2024
f0d939d
Outsource interface flux
bennibolm Feb 27, 2024
9f9a917
Add prolong2boundaries
bennibolm Feb 27, 2024
beeb833
Add non periodic elixir and flux calculation
bennibolm Feb 27, 2024
dbc5dc8
fmt
bennibolm Feb 27, 2024
76b0945
Clean up RealT and uEltype
bennibolm Feb 27, 2024
fde260d
Fix bug for simulations with mpi by using simple version of `fill_mes…
bennibolm Feb 29, 2024
765b828
remove show routine
bennibolm Feb 29, 2024
3b74f39
Move other boundary calculations to new function
bennibolm Feb 29, 2024
4710d38
Add MPI tests
bennibolm Feb 29, 2024
62b47bb
Move calculation of interface data to `fill_mesh_info_fv!`
bennibolm Feb 29, 2024
bb2138a
Update comment
bennibolm Feb 29, 2024
721b7f8
Remove elements from init routines for interfaces and boundaries
bennibolm Feb 29, 2024
dde4453
Remove not-needed code
bennibolm Mar 4, 2024
cc84c73
fmt
bennibolm Mar 4, 2024
72573f8
Change structure of element container to structure-of-arrays style
bennibolm Mar 4, 2024
4b0bc4f
Reduce unnecessary allocations
bennibolm Mar 4, 2024
78750e6
Rename routines
bennibolm Mar 4, 2024
0f7dde7
Merge branch 'main' into t8codemesh-fv
bennibolm Apr 8, 2024
2cc5e9d
Add RealT to solver
bennibolm Apr 8, 2024
75eba41
Fix dual faces
bennibolm Apr 16, 2024
d7d042d
Add first working version with linear reconstruction
bennibolm Apr 17, 2024
7cdd83e
fmt
bennibolm Apr 17, 2024
bc91a50
Fix bug
bennibolm Apr 18, 2024
6c585ce
Some changes
bennibolm Apr 22, 2024
c332a01
Add usage of gradient to `prolong2boundaries` [skip ci]
bennibolm Apr 24, 2024
5460e31
Clean up cmesh routines
bennibolm Apr 24, 2024
fa85580
Add simple reconstruction stencil
bennibolm Apr 24, 2024
aa48583
fmt [skip ci]
bennibolm Apr 24, 2024
641d8cf
Simpify code
bennibolm Apr 24, 2024
08f2418
Calc reconstruction distance in init_stencil; adapt distance for pori…
bennibolm Apr 24, 2024
874dc47
Adapt mpi test; fmt
bennibolm Apr 24, 2024
faf9709
Add source terms; Euler source term elixir; tests
bennibolm Apr 24, 2024
e92b875
fmt
bennibolm Apr 24, 2024
94ad70f
Change order of tests
bennibolm Apr 25, 2024
f72d20f
Merge branch 'main' into t8codemesh-fv
bennibolm Apr 30, 2024
b5c463c
Adapt structure of communication data to allow parallel 2order fv
bennibolm May 6, 2024
357ac9d
Remove 2order extended stencil from parallel tests
bennibolm May 6, 2024
c643295
Merge branch 'main' into t8codemesh-fv
bennibolm May 7, 2024
0b233f6
Fix bug; Change default in one elixir
bennibolm Jun 21, 2024
9eb9643
Update elixirs
bennibolm Jun 26, 2024
6829a0c
format
bennibolm Jun 26, 2024
c66c46e
Add solution variables to solution_callback
bennibolm Jul 2, 2024
43227da
Adapt elixir
bennibolm Jul 3, 2024
1f31f90
Adapt test after 9eb9643
bennibolm Jul 3, 2024
1bf61c5
Merge branch 'main' into t8codemesh-fv
bennibolm Jul 3, 2024
d956ee9
Simplify code
bennibolm Jul 3, 2024
69231ac
Add first version of reconstruction/limiting
bennibolm Jul 19, 2024
c4a4813
fmt
bennibolm Jul 19, 2024
933064b
Adapting MPI tests
bennibolm Jul 22, 2024
cf23329
fmt
bennibolm Jul 22, 2024
5d6a0bf
Adapt tests
bennibolm Jul 23, 2024
c1a15a9
Add reconstruction support for extended stencil
bennibolm Jul 25, 2024
4fddfd9
Adapt cfl number
bennibolm Aug 1, 2024
0b4ef50
Merge branch 'main' into t8codemesh-fv
bennibolm Aug 26, 2024
0994aab
Add finalizing of t8codemesh to fv elixirs
bennibolm Aug 26, 2024
a46520f
Remove finalizing from fv elixirs due to seg fault during mpi runs
bennibolm Aug 26, 2024
0139519
Add tests using triangles and second hybrid mesh
bennibolm Sep 3, 2024
dce751b
Add comment on domain size; Allow different T8code version
bennibolm Sep 17, 2024
95d5b64
New quad and tri cmesh routines; New FV T8codeMesh interface
bennibolm Sep 18, 2024
4d063b6
Merge branch 'main' into t8codemesh-fv
bennibolm Sep 18, 2024
2ea1bff
fmt
bennibolm Sep 18, 2024
def2547
Remove `@t8_load_tree_data` from code; pass C_NULL for now
bennibolm Sep 18, 2024
8243750
Add comment in nonperiodic tri mesh simulations
bennibolm Sep 19, 2024
8d7c2e1
Use just `@cfunction` instead of `@t8_analytic_callback`
bennibolm Sep 24, 2024
9c10471
Update mapping routines
bennibolm Oct 14, 2024
a8f35ef
Merge branch 'main' into t8codemesh-fv
bennibolm Oct 15, 2024
de7b527
fmt
bennibolm Oct 15, 2024
92e1d3b
Remove initial_condition; Disable advection_basic tests
bennibolm Oct 15, 2024
05d61eb
Add 3d support for FV using T8codeMesh (#130)
bennibolm Oct 15, 2024
03e4736
Support hybrid mesh of flexibel domain size
bennibolm Oct 15, 2024
c58e2f5
Merge branch 'main' into t8codemesh-fv
bennibolm Nov 8, 2024
67c9381
Add finalization to elixirs
bennibolm Nov 14, 2024
acfd0d1
Merge branch 'main' into t8codemesh-fv
bennibolm Nov 14, 2024
1a503d8
Add T8code to test environment for now
bennibolm Nov 15, 2024
4ea4d3d
Disabled gc in elixir; clean up
bennibolm Nov 22, 2024
155887b
Move allocation tests to elixirs
bennibolm Nov 26, 2024
d7770ef
Move t8 eclasses to constructor
bennibolm Nov 29, 2024
819014f
Remove T8code from test environment
bennibolm Nov 29, 2024
69df398
Add using Test to elixir
bennibolm Dec 4, 2024
832e706
Merge branch 'main' into t8codemesh-fv
bennibolm Dec 4, 2024
dfbcb70
Reactivate allocation tests in test file
bennibolm Dec 4, 2024
1c7413d
Remove alloc tests from elixir
bennibolm Dec 4, 2024
a80cfcb
Add free stream test
bennibolm Dec 5, 2024
d95def6
Update T8code.jl to newest version
bennibolm Dec 6, 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
1 change: 1 addition & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ jobs:
- p4est_part2
- t8code_part1
- t8code_part2
- t8code_fv
- unstructured_dgmulti
- parabolic
- paper_self_gravitating_gas_dynamics
Expand Down
129 changes: 129 additions & 0 deletions examples/t8code_2d_fv/elixir_advection_basic.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
using OrdinaryDiffEq
using Trixi
using T8code

advection_velocity = (0.2, -0.7)
equations = LinearScalarAdvectionEquation2D(advection_velocity)

initial_condition = initial_condition_convergence_test

solver = FV(order = 2, extended_reconstruction_stencil = false,
surface_flux = flux_lax_friedrichs)

# Option 1: coordinates
coordinates_min = (0.0, 0.0) # minimum coordinates (min(x), min(y))
coordinates_max = (8.0, 8.0) # maximum coordinates (max(x), max(y))
# Note and TODO: The plan is to move the auxiliary routine trixi_t8_mapping and the macro to a
# different place.
# Then, somehow, I get SegFaults when using this `mapping_coordinates` or (equally) when
# using `coordinates_min/max` and then use the `coordinates2mapping` within the constructor.
# With both other mappings I don't get that.
mapping_coordinates = Trixi.coordinates2mapping(coordinates_min, coordinates_max)

# Option 2: faces
# waving flag
# f1(s) = SVector(-1.0, s - 1.0)
# f2(s) = SVector(1.0, s + 1.0)
# f3(s) = SVector(s, -1.0 + sin(0.5 * pi * s))
# f4(s) = SVector(s, 1.0 + sin(0.5 * pi * s))

# [0,8]^2
f1(s) = SVector(0.0, 4 * (s + 1))
f2(s) = SVector(8.0, 4 * (s + 1))
f3(s) = SVector(4 * (s + 1), 0.0)
f4(s) = SVector(4 * (s + 1), 8.0)
faces = (f1, f2, f3, f4)
Trixi.validate_faces(faces)
mapping_faces = Trixi.transfinite_mapping(faces)

# Option 3: classic mapping
function mapping(xi, eta)
x = 4 * (xi + 1)
y = 4 * (eta + 1)

return SVector(x, y)
end

# Note and TODO:
# Normally, this should be put somewhere else. For now, that doesn't work properly.
# For instance, in `src/auxiliary/t8code.jl`
# Problem: Even when define this routine somewhere else (then by using a closure) and called
# directly within this elixir (e.g. mapping = trixi_t8_mapping_c(mapping)), we get the SegFault error.
# - Is the function called with the correct parameters? Memory location correct? It seems so, yes.
# - Life time issue for the GC tracked Julia object used in C? **Yes, see gc deactivation in elixir.**
function trixi_t8_mapping(cmesh, gtreeid, ref_coords, num_coords, out_coords,
tree_data, user_data)
ltreeid = t8_cmesh_get_local_id(cmesh, gtreeid)
eclass = t8_cmesh_get_tree_class(cmesh, ltreeid)
T8code.t8_geom_compute_linear_geometry(eclass, tree_data,
ref_coords, num_coords, out_coords)

for i in 1:num_coords
offset_3d = 3 * (i - 1) + 1

xi = unsafe_load(out_coords, offset_3d)
eta = unsafe_load(out_coords, offset_3d + 1)
# xy = mapping_coordinates(xi, eta)
# xy = mapping_faces(xi, eta)
xy = mapping(xi, eta)

unsafe_store!(out_coords, xy[1], offset_3d)
unsafe_store!(out_coords, xy[2], offset_3d + 1)
end

return nothing
end

function trixi_t8_mapping_c()
@cfunction($trixi_t8_mapping, Cvoid,
(t8_cmesh_t, t8_gloidx_t, Ptr{Cdouble}, Csize_t,
Ptr{Cdouble}, Ptr{Cvoid}, Ptr{Cvoid}))
end

trees_per_dimension = (2, 2)

# Disabling the gc for almost the entire elixir seems to work in order to fix the SegFault errors with trixi_t8_mapping_c and mapping_coordinates
# GC.enable(false)

eclass = T8_ECLASS_QUAD
mesh = T8codeMesh(trees_per_dimension, eclass,
mapping = trixi_t8_mapping_c(),
# Plan is to use either
# coordinates_max = coordinates_max, coordinates_min = coordinates_min,
# or at least
# mapping = mapping,
initial_refinement_level = 6)

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)

tspan = (0.0, 1.0)
ode = semidiscretize(semi, tspan);

summary_callback = SummaryCallback()

analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)

alive_callback = AliveCallback(analysis_interval = analysis_interval)

save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2prim)

stepsize_callback = StepsizeCallback(cfl = 0.9)

callbacks = CallbackSet(summary_callback, analysis_callback, alive_callback,
stepsize_callback, save_solution)

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

sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),
dt = 1.0, # solve needs some value here but it will be overwritten by the stepsize_callback
save_everystep = false, callback = callbacks);
summary_callback()

# GC.enable(true)

# Finalize `T8codeMesh` to make sure MPI related objects in t8code are
# released before `MPI` finalizes.
!isinteractive() && finalize(mesh)
47 changes: 47 additions & 0 deletions examples/t8code_2d_fv/elixir_advection_basic_hybrid.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
using OrdinaryDiffEq
using Trixi

advection_velocity = (0.2, -0.7)
equations = LinearScalarAdvectionEquation2D(advection_velocity)

initial_condition = initial_condition_convergence_test

solver = FV(order = 2, extended_reconstruction_stencil = false,
surface_flux = flux_lax_friedrichs)

cmesh = Trixi.cmesh_new_hybrid()
# cmesh = Trixi.cmesh_new_quad(periodicity = (true, true))
# cmesh = Trixi.cmesh_new_tri(periodicity = (true, true))
mesh = T8codeMesh(cmesh, solver,
initial_refinement_level = 3)

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)

ode = semidiscretize(semi, (0.0, 1.0));

summary_callback = SummaryCallback()

analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)

alive_callback = AliveCallback(analysis_interval = analysis_interval)

save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2prim)

stepsize_callback = StepsizeCallback(cfl = 0.9)

callbacks = CallbackSet(summary_callback, analysis_callback, alive_callback,
stepsize_callback, save_solution)

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

sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),
dt = 1.0, # solve needs some value here but it will be overwritten by the stepsize_callback
save_everystep = false, callback = callbacks);
summary_callback()

# Finalize `T8codeMesh` to make sure MPI related objects in t8code are
# released before `MPI` finalizes.
!isinteractive() && finalize(mesh)
49 changes: 49 additions & 0 deletions examples/t8code_2d_fv/elixir_advection_gauss.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
using OrdinaryDiffEq
using Trixi

####################################################

advection_velocity = (0.2, -0.7)
equations = LinearScalarAdvectionEquation2D(advection_velocity)

initial_condition = initial_condition_gauss

solver = FV(order = 2, surface_flux = flux_lax_friedrichs)

initial_refinement_level = 4
# Note: The initial_condition is set up for a domain [-5,5]^2.
# This becomes important when using a non-periodic mesh.
cmesh = Trixi.cmesh_new_hybrid()

mesh = T8codeMesh(cmesh, solver, initial_refinement_level = initial_refinement_level)

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)

ode = semidiscretize(semi, (0.0, 20.0));

summary_callback = SummaryCallback()

analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)

alive_callback = AliveCallback(analysis_interval = analysis_interval)

save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2prim)

stepsize_callback = StepsizeCallback(cfl = 0.5)

callbacks = CallbackSet(summary_callback, save_solution, analysis_callback, alive_callback,
stepsize_callback)

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

sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),#Euler(),
dt = 5.0e-2, # solve needs some value here but it will be overwritten by the stepsize_callback
save_everystep = false, callback = callbacks);
summary_callback()

# Finalize `T8codeMesh` to make sure MPI related objects in t8code are
# released before `MPI` finalizes.
!isinteractive() && finalize(mesh)
69 changes: 69 additions & 0 deletions examples/t8code_2d_fv/elixir_advection_nonperiodic.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
using OrdinaryDiffEq
using Trixi

###############################################################################
# Semidiscretization of the linear advection equation.

advection_velocity = (0.2, -0.7)
equations = LinearScalarAdvectionEquation2D(advection_velocity)

initial_condition = initial_condition_convergence_test

boundary_condition = BoundaryConditionDirichlet(initial_condition)
boundary_conditions = Dict(:all => boundary_condition)
# Problem: T8codeMesh interface with parameter cmesh cannot distinguish between boundaries
# boundary_conditions = Dict(:x_neg => boundary_condition,
# :x_pos => boundary_condition,
# :y_neg => boundary_condition_periodic,
# :y_pos => boundary_condition_periodic)

solver = FV(order = 2, surface_flux = flux_lax_friedrichs)

# TODO: When using mesh construction as in elixir_advection_basic.jl boundary Symbol :all is not defined
initial_refinement_level = 5
cmesh = Trixi.cmesh_new_quad(periodicity = (false, false))

# **Note**: A non-periodic run with the tri mesh is unstable.
# - This only happens with **2nd order**
# - When increasing refinement_level to 6 and lower CFL to 0.4, it seems like the simulation is stable again (except of some smaller noises at the corners)
# - With a lower resolution (5) I cannot get the simulation stable. Even with a cfl of 0.01 etc.
# -> That can't be expected.
# -> Maybe, the reconstruction is just not fitted for this example/mesh/resolution?!
# cmesh = Trixi.cmesh_new_tri(periodicity = (false, false))

mesh = T8codeMesh(cmesh, solver, initial_refinement_level = initial_refinement_level)

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
boundary_conditions = boundary_conditions)

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

tspan = (0.0, 1.0)
ode = semidiscretize(semi, tspan)

summary_callback = SummaryCallback()

analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)
alive_callback = AliveCallback(analysis_interval = analysis_interval)

save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2prim)

stepsize_callback = StepsizeCallback(cfl = 0.8)

callbacks = CallbackSet(summary_callback, analysis_callback, alive_callback,
save_solution, stepsize_callback)

###############################################################################
# Run the simulation.

sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),
dt = 1.0, # Solve needs some value here but it will be overwritten by the stepsize_callback.
save_everystep = false, callback = callbacks);
summary_callback()

# Finalize `T8codeMesh` to make sure MPI related objects in t8code are
# released before `MPI` finalizes.
!isinteractive() && finalize(mesh)
65 changes: 65 additions & 0 deletions examples/t8code_2d_fv/elixir_euler_blast_wave.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
using OrdinaryDiffEq
using Trixi

####################################################

equations = CompressibleEulerEquations2D(1.4)

function initial_condition_blast_wave(x, t, equations::CompressibleEulerEquations2D)
# Modified From Hennemann & Gassner JCP paper 2020 (Sec. 6.3) -> "medium blast wave"
# Set up polar coordinates
inicenter = SVector(0.0, 0.0)
x_norm = x[1] - inicenter[1]
y_norm = x[2] - inicenter[2]
r = sqrt(x_norm^2 + y_norm^2)
phi = atan(y_norm, x_norm)
sin_phi, cos_phi = sincos(phi)

# Calculate primitive variables
rho = r > 0.5 ? 1.0 : 1.1691
v1 = r > 0.5 ? 0.0 : 0.1882 * cos_phi
v2 = r > 0.5 ? 0.0 : 0.1882 * sin_phi
p = r > 0.5 ? 1.0E-3 : 1.245

return prim2cons(SVector(rho, v1, v2, p), equations)
end
initial_condition = initial_condition_blast_wave

solver = FV(order = 2, extended_reconstruction_stencil = true,
surface_flux = flux_lax_friedrichs)

initial_refinement_level = 4
# cmesh = Trixi.cmesh_new_periodic_hybrid2()
cmesh = Trixi.cmesh_new_quad(periodicity = (true, true))
mesh = T8codeMesh(cmesh, solver, initial_refinement_level = initial_refinement_level)

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)

ode = semidiscretize(semi, (0.0, 2.0));

summary_callback = SummaryCallback()

analysis_interval = 100
analysis_callback = AnalysisCallback(semi, interval = analysis_interval)

alive_callback = AliveCallback(analysis_interval = analysis_interval)

save_solution = SaveSolutionCallback(interval = 10,
solution_variables = cons2prim)

stepsize_callback = StepsizeCallback(cfl = 0.9)

callbacks = CallbackSet(summary_callback, save_solution, analysis_callback, alive_callback,
stepsize_callback)

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

sol = solve(ode, CarpenterKennedy2N54(williamson_condition = false),
dt = 5.0e-2, # solve needs some value here but it will be overwritten by the stepsize_callback
save_everystep = false, callback = callbacks);
summary_callback()

# Finalize `T8codeMesh` to make sure MPI related objects in t8code are
# released before `MPI` finalizes.
!isinteractive() && finalize(mesh)
Loading
Loading