From 982c2fa5a5eb15d902e7bd131069b932ed86e6a6 Mon Sep 17 00:00:00 2001 From: "Documenter.jl" Date: Mon, 30 Oct 2023 19:28:31 +0000 Subject: [PATCH] build based on aea7b1d --- previews/PR1697/.documenter-siteinfo.json | 1 + previews/PR1697/assets/documenter.js | 889 ++ previews/PR1697/assets/favicon.ico | Bin 0 -> 15406 bytes .../assets/solution_000040_scalar_resized.png | Bin 0 -> 94699 bytes .../PR1697/assets/themes/documenter-dark.css | 7 + .../PR1697/assets/themes/documenter-light.css | 9 + previews/PR1697/assets/themeswap.js | 84 + previews/PR1697/assets/trixi.drawio | 1 + previews/PR1697/assets/warner.js | 52 + previews/PR1697/authors/index.html | 2 + previews/PR1697/callbacks/index.html | 15 + previews/PR1697/code_of_conduct/index.html | 2 + previews/PR1697/contributing/index.html | 38 + previews/PR1697/conventions/index.html | 2 + previews/PR1697/development/index.html | 42 + previews/PR1697/github-git/index.html | 44 + previews/PR1697/index.html | 104 + previews/PR1697/license/index.html | 2 + .../PR1697/meshes/dgmulti_mesh/index.html | 8 + previews/PR1697/meshes/p4est_mesh/index.html | 136 + .../PR1697/meshes/structured_mesh/index.html | 2 + previews/PR1697/meshes/tree_mesh/index.html | 2 + .../meshes/unstructured_quad_mesh/index.html | 79 + previews/PR1697/overview/index.html | 2 + previews/PR1697/parallelization/index.html | 36 + previews/PR1697/performance/index.html | 55 + previews/PR1697/reference-trixi/index.html | 573 + .../PR1697/reference-trixi2vtk/index.html | 6 + previews/PR1697/restart/index.html | 6 + previews/PR1697/search_index.js | 3 + previews/PR1697/siteinfo.js | 1 + previews/PR1697/styleguide/index.html | 2 + previews/PR1697/testing/index.html | 6 + previews/PR1697/time_integration/index.html | 2 + previews/PR1697/troubleshooting/index.html | 47 + .../PR1697/tutorials/DGMulti_1/12ccb79d.svg | 8384 +++++++++++++++ .../PR1697/tutorials/DGMulti_1/57a0c12e.svg | 6315 +++++++++++ .../PR1697/tutorials/DGMulti_1/ce428824.svg | 4921 +++++++++ .../PR1697/tutorials/DGMulti_1/d6194a32.svg | 5566 ++++++++++ .../PR1697/tutorials/DGMulti_1/dc354ad7.svg | 4816 +++++++++ .../PR1697/tutorials/DGMulti_1/eca33cfe.svg | 6306 +++++++++++ .../PR1697/tutorials/DGMulti_1/index.html | 308 + .../PR1697/tutorials/DGMulti_2/index.html | 36 + .../tutorials/DGSEM_FluxDiff/606795d1.svg | 4089 +++++++ .../tutorials/DGSEM_FluxDiff/869d34b2.svg | 2845 +++++ .../tutorials/DGSEM_FluxDiff/index.html | 166 + .../adaptive_mesh_refinement/3e0d31e8.svg | 1518 +++ .../adaptive_mesh_refinement/index.html | 91 + .../adding_new_parabolic_terms/35a5f0a8.svg | 756 ++ .../adding_new_parabolic_terms/index.html | 94 + .../adding_new_scalar_equations/00857e32.svg | 44 + .../adding_new_scalar_equations/49ba4521.svg | 43 + .../adding_new_scalar_equations/a4331a9e.svg | 43 + .../adding_new_scalar_equations/dfd5e74f.svg | 47 + .../adding_new_scalar_equations/f7da1af1.svg | 43 + .../adding_new_scalar_equations/index.html | 205 + .../53f78937.svg | 80 + .../index.html | 243 + .../custom_semidiscretization/686132e6.svg | 50 + .../custom_semidiscretization/bd8c446b.svg | 50 + .../custom_semidiscretization/dfd5cf6d.svg | 50 + .../custom_semidiscretization/eb8e84c6.svg | 46 + .../custom_semidiscretization/f31b1a9a.svg | 48 + .../custom_semidiscretization/index.html | 597 ++ .../differentiable_programming/6726dae8.svg | 46 + .../differentiable_programming/69a549ba.svg | 809 ++ .../differentiable_programming/71e1538b.svg | 2100 ++++ .../differentiable_programming/73fec259.svg | 815 ++ .../differentiable_programming/896ef882.svg | 1077 ++ .../differentiable_programming/c6ac5c01.svg | 307 + .../differentiable_programming/cc8281b6.svg | 46 + .../differentiable_programming/dac2545d.svg | 1582 +++ .../differentiable_programming/index.html | 209 + .../tutorials/hohqmesh_tutorial/index.html | 305 + .../PR1697/tutorials/introduction/index.html | 2 + .../non_periodic_boundaries/c37303c4.gif | Bin 0 -> 1128612 bytes .../non_periodic_boundaries/dc45730b.svg | 50 + .../non_periodic_boundaries/index.html | 89 + .../tutorials/notebooks/DGMulti_1.ipynb | 478 + .../tutorials/notebooks/DGMulti_2.ipynb | 157 + .../tutorials/notebooks/DGSEM_FluxDiff.ipynb | 525 + .../notebooks/adaptive_mesh_refinement.ipynb | 410 + .../adding_new_parabolic_terms.ipynb | 309 + .../adding_new_scalar_equations.ipynb | 451 + .../adding_nonconservative_equation.ipynb | 455 + .../notebooks/custom_semidiscretization.ipynb | 673 ++ .../differentiable_programming.ipynb | 956 ++ .../notebooks/hohqmesh_tutorial.ipynb | 1034 ++ .../notebooks/non_periodic_boundaries.ipynb | 346 + .../tutorials/notebooks/parabolic_terms.ipynb | 264 + .../scalar_linear_advection_1d.ipynb | 976 ++ .../tutorials/notebooks/shock_capturing.ipynb | 503 + .../notebooks/structured_mesh_mapping.ipynb | 451 + .../tutorials/notebooks/time_stepping.ipynb | 195 + .../tutorials/notebooks/upwind_fdsbp.ipynb | 219 + .../out/ice_cream_curved_sides.control | 65 + .../tutorials/out/ice_cream_curved_sides.mesh | 1778 ++++ .../tutorials/out/ice_cream_curved_sides.tec | 474 + .../tutorials/out/ice_cream_curved_sides.txt | 222 + .../out/ice_cream_straight_sides.control | 57 + .../out/ice_cream_straight_sides.mesh | 1722 +++ .../out/ice_cream_straight_sides.tec | 550 + .../out/ice_cream_straight_sides.txt | 258 + previews/PR1697/tutorials/out/mesh.h5 | Bin 0 -> 1136 bytes .../PR1697/tutorials/out/restart_000050.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/restart_000100.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/restart_000150.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/restart_000180.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000.pvd | 24 + .../PR1697/tutorials/out/solution_000000.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000000.vtu | Bin 0 -> 12687 bytes .../out/solution_000000_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000010.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000010.vtu | Bin 0 -> 18966 bytes .../out/solution_000010_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000020.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000020.vtu | Bin 0 -> 19000 bytes .../out/solution_000020_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000030.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000030.vtu | Bin 0 -> 19045 bytes .../out/solution_000030_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000040.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000040.vtu | Bin 0 -> 19091 bytes .../out/solution_000040_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000050.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000050.vtu | Bin 0 -> 19110 bytes .../out/solution_000050_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000060.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000060.vtu | Bin 0 -> 19131 bytes .../out/solution_000060_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000065.h5 | Bin 0 -> 205696 bytes .../PR1697/tutorials/out/solution_000070.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000070.vtu | Bin 0 -> 19148 bytes .../out/solution_000070_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000080.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000080.vtu | Bin 0 -> 19171 bytes .../out/solution_000080_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000090.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000090.vtu | Bin 0 -> 19175 bytes .../out/solution_000090_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000100.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000100.vtu | Bin 0 -> 19213 bytes .../out/solution_000100_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000110.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000110.vtu | Bin 0 -> 19188 bytes .../out/solution_000110_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000120.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000120.vtu | Bin 0 -> 19147 bytes .../out/solution_000120_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000130.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000130.vtu | Bin 0 -> 19172 bytes .../out/solution_000130_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000140.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000140.vtu | Bin 0 -> 19171 bytes .../out/solution_000140_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000150.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000150.vtu | Bin 0 -> 19176 bytes .../out/solution_000150_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000160.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000160.vtu | Bin 0 -> 19165 bytes .../out/solution_000160_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000170.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000170.vtu | Bin 0 -> 19202 bytes .../out/solution_000170_celldata.vtu | Bin 0 -> 6739 bytes .../PR1697/tutorials/out/solution_000180.h5 | Bin 0 -> 11976 bytes .../PR1697/tutorials/out/solution_000180.vtu | Bin 0 -> 19180 bytes .../out/solution_000180_celldata.vtu | Bin 0 -> 6739 bytes .../tutorials/out/solution_000_celldata.pvd | 24 + .../tutorials/parabolic_terms/287083f9.svg | 731 ++ .../tutorials/parabolic_terms/index.html | 130 + .../scalar_linear_advection_1d/17dd5be8.svg | 54 + .../scalar_linear_advection_1d/22fe8c96.svg | 46 + .../scalar_linear_advection_1d/5ea0a2e7.svg | 48 + .../scalar_linear_advection_1d/8f31c7f1.svg | 46 + .../scalar_linear_advection_1d/ba041784.svg | 48 + .../scalar_linear_advection_1d/d998e897.svg | 46 + .../scalar_linear_advection_1d/index.html | 294 + .../tutorials/shock_capturing/ca991843.svg | 4419 ++++++++ .../tutorials/shock_capturing/index.html | 113 + .../structured_mesh_mapping/52c207b4.svg | 5575 ++++++++++ .../structured_mesh_mapping/63b0ba38.svg | 9475 +++++++++++++++++ .../structured_mesh_mapping/bfa9c649.svg | 3800 +++++++ .../structured_mesh_mapping/index.html | 198 + .../PR1697/tutorials/time_stepping/index.html | 26 + .../PR1697/tutorials/upwind_fdsbp/index.html | 65 + previews/PR1697/visualization/index.html | 91 + 186 files changed, 96278 insertions(+) create mode 100644 previews/PR1697/.documenter-siteinfo.json create mode 100644 previews/PR1697/assets/documenter.js create mode 100644 previews/PR1697/assets/favicon.ico create mode 100644 previews/PR1697/assets/solution_000040_scalar_resized.png create mode 100644 previews/PR1697/assets/themes/documenter-dark.css create mode 100644 previews/PR1697/assets/themes/documenter-light.css create mode 100644 previews/PR1697/assets/themeswap.js create mode 100644 previews/PR1697/assets/trixi.drawio create mode 100644 previews/PR1697/assets/warner.js create mode 100644 previews/PR1697/authors/index.html create mode 100644 previews/PR1697/callbacks/index.html create mode 100644 previews/PR1697/code_of_conduct/index.html create mode 100644 previews/PR1697/contributing/index.html create mode 100644 previews/PR1697/conventions/index.html create mode 100644 previews/PR1697/development/index.html create mode 100644 previews/PR1697/github-git/index.html create mode 100644 previews/PR1697/index.html create mode 100644 previews/PR1697/license/index.html create mode 100644 previews/PR1697/meshes/dgmulti_mesh/index.html create mode 100644 previews/PR1697/meshes/p4est_mesh/index.html create mode 100644 previews/PR1697/meshes/structured_mesh/index.html create mode 100644 previews/PR1697/meshes/tree_mesh/index.html create mode 100644 previews/PR1697/meshes/unstructured_quad_mesh/index.html create mode 100644 previews/PR1697/overview/index.html create mode 100644 previews/PR1697/parallelization/index.html create mode 100644 previews/PR1697/performance/index.html create mode 100644 previews/PR1697/reference-trixi/index.html create mode 100644 previews/PR1697/reference-trixi2vtk/index.html create mode 100644 previews/PR1697/restart/index.html create mode 100644 previews/PR1697/search_index.js create mode 100644 previews/PR1697/siteinfo.js create mode 100644 previews/PR1697/styleguide/index.html create mode 100644 previews/PR1697/testing/index.html create mode 100644 previews/PR1697/time_integration/index.html create mode 100644 previews/PR1697/troubleshooting/index.html create mode 100644 previews/PR1697/tutorials/DGMulti_1/12ccb79d.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/57a0c12e.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/ce428824.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/d6194a32.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/dc354ad7.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/eca33cfe.svg create mode 100644 previews/PR1697/tutorials/DGMulti_1/index.html create mode 100644 previews/PR1697/tutorials/DGMulti_2/index.html create mode 100644 previews/PR1697/tutorials/DGSEM_FluxDiff/606795d1.svg create mode 100644 previews/PR1697/tutorials/DGSEM_FluxDiff/869d34b2.svg create mode 100644 previews/PR1697/tutorials/DGSEM_FluxDiff/index.html create mode 100644 previews/PR1697/tutorials/adaptive_mesh_refinement/3e0d31e8.svg create mode 100644 previews/PR1697/tutorials/adaptive_mesh_refinement/index.html create mode 100644 previews/PR1697/tutorials/adding_new_parabolic_terms/35a5f0a8.svg create mode 100644 previews/PR1697/tutorials/adding_new_parabolic_terms/index.html create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/00857e32.svg create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/49ba4521.svg create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/a4331a9e.svg create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/dfd5e74f.svg create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/f7da1af1.svg create mode 100644 previews/PR1697/tutorials/adding_new_scalar_equations/index.html create mode 100644 previews/PR1697/tutorials/adding_nonconservative_equation/53f78937.svg create mode 100644 previews/PR1697/tutorials/adding_nonconservative_equation/index.html create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/686132e6.svg create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/bd8c446b.svg create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/dfd5cf6d.svg create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/eb8e84c6.svg create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/f31b1a9a.svg create mode 100644 previews/PR1697/tutorials/custom_semidiscretization/index.html create mode 100644 previews/PR1697/tutorials/differentiable_programming/6726dae8.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/69a549ba.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/71e1538b.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/73fec259.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/896ef882.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/c6ac5c01.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/cc8281b6.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/dac2545d.svg create mode 100644 previews/PR1697/tutorials/differentiable_programming/index.html create mode 100644 previews/PR1697/tutorials/hohqmesh_tutorial/index.html create mode 100644 previews/PR1697/tutorials/introduction/index.html create mode 100644 previews/PR1697/tutorials/non_periodic_boundaries/c37303c4.gif create mode 100644 previews/PR1697/tutorials/non_periodic_boundaries/dc45730b.svg create mode 100644 previews/PR1697/tutorials/non_periodic_boundaries/index.html create mode 100644 previews/PR1697/tutorials/notebooks/DGMulti_1.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/DGMulti_2.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/DGSEM_FluxDiff.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/adaptive_mesh_refinement.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/adding_new_parabolic_terms.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/adding_new_scalar_equations.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/adding_nonconservative_equation.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/custom_semidiscretization.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/differentiable_programming.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/hohqmesh_tutorial.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/non_periodic_boundaries.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/parabolic_terms.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/scalar_linear_advection_1d.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/shock_capturing.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/structured_mesh_mapping.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/time_stepping.ipynb create mode 100644 previews/PR1697/tutorials/notebooks/upwind_fdsbp.ipynb create mode 100644 previews/PR1697/tutorials/out/ice_cream_curved_sides.control create mode 100644 previews/PR1697/tutorials/out/ice_cream_curved_sides.mesh create mode 100644 previews/PR1697/tutorials/out/ice_cream_curved_sides.tec create mode 100644 previews/PR1697/tutorials/out/ice_cream_curved_sides.txt create mode 100644 previews/PR1697/tutorials/out/ice_cream_straight_sides.control create mode 100644 previews/PR1697/tutorials/out/ice_cream_straight_sides.mesh create mode 100644 previews/PR1697/tutorials/out/ice_cream_straight_sides.tec create mode 100644 previews/PR1697/tutorials/out/ice_cream_straight_sides.txt create mode 100644 previews/PR1697/tutorials/out/mesh.h5 create mode 100644 previews/PR1697/tutorials/out/restart_000050.h5 create mode 100644 previews/PR1697/tutorials/out/restart_000100.h5 create mode 100644 previews/PR1697/tutorials/out/restart_000150.h5 create mode 100644 previews/PR1697/tutorials/out/restart_000180.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000.pvd create mode 100644 previews/PR1697/tutorials/out/solution_000000.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000000.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000000_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000010.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000010.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000010_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000020.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000020.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000020_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000030.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000030.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000030_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000040.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000040.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000040_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000050.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000050.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000050_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000060.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000060.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000060_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000065.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000070.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000070.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000070_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000080.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000080.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000080_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000090.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000090.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000090_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000100.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000100.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000100_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000110.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000110.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000110_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000120.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000120.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000120_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000130.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000130.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000130_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000140.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000140.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000140_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000150.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000150.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000150_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000160.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000160.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000160_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000170.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000170.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000170_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000180.h5 create mode 100644 previews/PR1697/tutorials/out/solution_000180.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000180_celldata.vtu create mode 100644 previews/PR1697/tutorials/out/solution_000_celldata.pvd create mode 100644 previews/PR1697/tutorials/parabolic_terms/287083f9.svg create mode 100644 previews/PR1697/tutorials/parabolic_terms/index.html create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/17dd5be8.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/22fe8c96.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/5ea0a2e7.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/8f31c7f1.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/ba041784.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/d998e897.svg create mode 100644 previews/PR1697/tutorials/scalar_linear_advection_1d/index.html create mode 100644 previews/PR1697/tutorials/shock_capturing/ca991843.svg create mode 100644 previews/PR1697/tutorials/shock_capturing/index.html create mode 100644 previews/PR1697/tutorials/structured_mesh_mapping/52c207b4.svg create mode 100644 previews/PR1697/tutorials/structured_mesh_mapping/63b0ba38.svg create mode 100644 previews/PR1697/tutorials/structured_mesh_mapping/bfa9c649.svg create mode 100644 previews/PR1697/tutorials/structured_mesh_mapping/index.html create mode 100644 previews/PR1697/tutorials/time_stepping/index.html create mode 100644 previews/PR1697/tutorials/upwind_fdsbp/index.html create mode 100644 previews/PR1697/visualization/index.html diff --git a/previews/PR1697/.documenter-siteinfo.json b/previews/PR1697/.documenter-siteinfo.json new file mode 100644 index 00000000000..7a00a411a7c --- /dev/null +++ b/previews/PR1697/.documenter-siteinfo.json @@ -0,0 +1 @@ +{"documenter":{"julia_version":"1.9.3","generation_timestamp":"2023-10-30T19:27:47","documenter_version":"1.1.2"}} \ No newline at end of file diff --git a/previews/PR1697/assets/documenter.js b/previews/PR1697/assets/documenter.js new file mode 100644 index 00000000000..f5311607bf5 --- /dev/null +++ b/previews/PR1697/assets/documenter.js @@ -0,0 +1,889 @@ +// Generated by Documenter.jl +requirejs.config({ + paths: { + 'highlight-julia': 'https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.8.0/languages/julia.min', + 'headroom': 'https://cdnjs.cloudflare.com/ajax/libs/headroom/0.12.0/headroom.min', + 'jqueryui': 'https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.13.2/jquery-ui.min', + 'minisearch': 'https://cdn.jsdelivr.net/npm/minisearch@6.1.0/dist/umd/index.min', + 'katex-auto-render': 'https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.8/contrib/auto-render.min', + 'jquery': 'https://cdnjs.cloudflare.com/ajax/libs/jquery/3.7.0/jquery.min', + 'headroom-jquery': 'https://cdnjs.cloudflare.com/ajax/libs/headroom/0.12.0/jQuery.headroom.min', + 'katex': 'https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.8/katex.min', + 'highlight': 'https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.8.0/highlight.min', + 'highlight-julia-repl': 'https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.8.0/languages/julia-repl.min', + }, + shim: { + "highlight-julia": { + "deps": [ + "highlight" + ] + }, + "katex-auto-render": { + "deps": [ + "katex" + ] + }, + "headroom-jquery": { + "deps": [ + "jquery", + "headroom" + ] + }, + "highlight-julia-repl": { + "deps": [ + "highlight" + ] + } +} +}); +//////////////////////////////////////////////////////////////////////////////// +require(['jquery', 'katex', 'katex-auto-render'], function($, katex, renderMathInElement) { +$(document).ready(function() { + renderMathInElement( + document.body, + { + "delimiters": [ + { + "left": "$", + "right": "$", + "display": false + }, + { + "left": "$$", + "right": "$$", + "display": true + }, + { + "left": "\\[", + "right": "\\]", + "display": true + } + ] +} + + ); +}) + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery', 'highlight', 'highlight-julia', 'highlight-julia-repl'], function($) { +$(document).ready(function() { + hljs.highlightAll(); +}) + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +let timer = 0; +var isExpanded = true; + +$(document).on("click", ".docstring header", function () { + let articleToggleTitle = "Expand docstring"; + + debounce(() => { + if ($(this).siblings("section").is(":visible")) { + $(this) + .find(".docstring-article-toggle-button") + .removeClass("fa-chevron-down") + .addClass("fa-chevron-right"); + } else { + $(this) + .find(".docstring-article-toggle-button") + .removeClass("fa-chevron-right") + .addClass("fa-chevron-down"); + + articleToggleTitle = "Collapse docstring"; + } + + $(this) + .find(".docstring-article-toggle-button") + .prop("title", articleToggleTitle); + $(this).siblings("section").slideToggle(); + }); +}); + +$(document).on("click", ".docs-article-toggle-button", function () { + let articleToggleTitle = "Expand docstring"; + let navArticleToggleTitle = "Expand all docstrings"; + + debounce(() => { + if (isExpanded) { + $(this).removeClass("fa-chevron-up").addClass("fa-chevron-down"); + $(".docstring-article-toggle-button") + .removeClass("fa-chevron-down") + .addClass("fa-chevron-right"); + + isExpanded = false; + + $(".docstring section").slideUp(); + } else { + $(this).removeClass("fa-chevron-down").addClass("fa-chevron-up"); + $(".docstring-article-toggle-button") + .removeClass("fa-chevron-right") + .addClass("fa-chevron-down"); + + isExpanded = true; + articleToggleTitle = "Collapse docstring"; + navArticleToggleTitle = "Collapse all docstrings"; + + $(".docstring section").slideDown(); + } + + $(this).prop("title", navArticleToggleTitle); + $(".docstring-article-toggle-button").prop("title", articleToggleTitle); + }); +}); + +function debounce(callback, timeout = 300) { + if (Date.now() - timer > timeout) { + callback(); + } + + clearTimeout(timer); + + timer = Date.now(); +} + +}) +//////////////////////////////////////////////////////////////////////////////// +require([], function() { +function addCopyButtonCallbacks() { + for (const el of document.getElementsByTagName("pre")) { + const button = document.createElement("button"); + button.classList.add("copy-button", "fa-solid", "fa-copy"); + button.setAttribute("aria-label", "Copy this code block"); + button.setAttribute("title", "Copy"); + + el.appendChild(button); + + const success = function () { + button.classList.add("success", "fa-check"); + button.classList.remove("fa-copy"); + }; + + const failure = function () { + button.classList.add("error", "fa-xmark"); + button.classList.remove("fa-copy"); + }; + + button.addEventListener("click", function () { + copyToClipboard(el.innerText).then(success, failure); + + setTimeout(function () { + button.classList.add("fa-copy"); + button.classList.remove("success", "fa-check", "fa-xmark"); + }, 5000); + }); + } +} + +function copyToClipboard(text) { + // clipboard API is only available in secure contexts + if (window.navigator && window.navigator.clipboard) { + return window.navigator.clipboard.writeText(text); + } else { + return new Promise(function (resolve, reject) { + try { + const el = document.createElement("textarea"); + el.textContent = text; + el.style.position = "fixed"; + el.style.opacity = 0; + document.body.appendChild(el); + el.select(); + document.execCommand("copy"); + + resolve(); + } catch (err) { + reject(err); + } finally { + document.body.removeChild(el); + } + }); + } +} + +if (document.readyState === "loading") { + document.addEventListener("DOMContentLoaded", addCopyButtonCallbacks); +} else { + addCopyButtonCallbacks(); +} + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery', 'headroom', 'headroom-jquery'], function($, Headroom) { + +// Manages the top navigation bar (hides it when the user starts scrolling down on the +// mobile). +window.Headroom = Headroom; // work around buggy module loading? +$(document).ready(function () { + $("#documenter .docs-navbar").headroom({ + tolerance: { up: 10, down: 10 }, + }); +}); + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery', 'minisearch'], function($, minisearch) { + +// In general, most search related things will have "search" as a prefix. +// To get an in-depth about the thought process you can refer: https://hetarth02.hashnode.dev/series/gsoc + +let results = []; +let timer = undefined; + +let data = documenterSearchIndex["docs"].map((x, key) => { + x["id"] = key; // minisearch requires a unique for each object + return x; +}); + +// list below is the lunr 2.1.3 list minus the intersect with names(Base) +// (all, any, get, in, is, only, which) and (do, else, for, let, where, while, with) +// ideally we'd just filter the original list but it's not available as a variable +const stopWords = new Set([ + "a", + "able", + "about", + "across", + "after", + "almost", + "also", + "am", + "among", + "an", + "and", + "are", + "as", + "at", + "be", + "because", + "been", + "but", + "by", + "can", + "cannot", + "could", + "dear", + "did", + "does", + "either", + "ever", + "every", + "from", + "got", + "had", + "has", + "have", + "he", + "her", + "hers", + "him", + "his", + "how", + "however", + "i", + "if", + "into", + "it", + "its", + "just", + "least", + "like", + "likely", + "may", + "me", + "might", + "most", + "must", + "my", + "neither", + "no", + "nor", + "not", + "of", + "off", + "often", + "on", + "or", + "other", + "our", + "own", + "rather", + "said", + "say", + "says", + "she", + "should", + "since", + "so", + "some", + "than", + "that", + "the", + "their", + "them", + "then", + "there", + "these", + "they", + "this", + "tis", + "to", + "too", + "twas", + "us", + "wants", + "was", + "we", + "were", + "what", + "when", + "who", + "whom", + "why", + "will", + "would", + "yet", + "you", + "your", +]); + +let index = new minisearch({ + fields: ["title", "text"], // fields to index for full-text search + storeFields: ["location", "title", "text", "category", "page"], // fields to return with search results + processTerm: (term) => { + let word = stopWords.has(term) ? null : term; + if (word) { + // custom trimmer that doesn't strip @ and !, which are used in julia macro and function names + word = word + .replace(/^[^a-zA-Z0-9@!]+/, "") + .replace(/[^a-zA-Z0-9@!]+$/, ""); + } + + return word ?? null; + }, + // add . as a separator, because otherwise "title": "Documenter.Anchors.add!", would not find anything if searching for "add!", only for the entire qualification + tokenize: (string) => string.split(/[\s\-\.]+/), + // options which will be applied during the search + searchOptions: { + boost: { title: 100 }, + fuzzy: 2, + processTerm: (term) => { + let word = stopWords.has(term) ? null : term; + if (word) { + word = word + .replace(/^[^a-zA-Z0-9@!]+/, "") + .replace(/[^a-zA-Z0-9@!]+$/, ""); + } + + return word ?? null; + }, + tokenize: (string) => string.split(/[\s\-\.]+/), + }, +}); + +index.addAll(data); + +let filters = [...new Set(data.map((x) => x.category))]; +var modal_filters = make_modal_body_filters(filters); +var filter_results = []; + +$(document).on("keyup", ".documenter-search-input", function (event) { + // Adding a debounce to prevent disruptions from super-speed typing! + debounce(() => update_search(filter_results), 300); +}); + +$(document).on("click", ".search-filter", function () { + if ($(this).hasClass("search-filter-selected")) { + $(this).removeClass("search-filter-selected"); + } else { + $(this).addClass("search-filter-selected"); + } + + // Adding a debounce to prevent disruptions from crazy clicking! + debounce(() => get_filters(), 300); +}); + +/** + * A debounce function, takes a function and an optional timeout in milliseconds + * + * @function callback + * @param {number} timeout + */ +function debounce(callback, timeout = 300) { + clearTimeout(timer); + timer = setTimeout(callback, timeout); +} + +/** + * Make/Update the search component + * + * @param {string[]} selected_filters + */ +function update_search(selected_filters = []) { + let initial_search_body = ` +
Type something to get started!
+ `; + + let querystring = $(".documenter-search-input").val(); + + if (querystring.trim()) { + results = index.search(querystring, { + filter: (result) => { + // Filtering results + if (selected_filters.length === 0) { + return result.score >= 1; + } else { + return ( + result.score >= 1 && selected_filters.includes(result.category) + ); + } + }, + }); + + let search_result_container = ``; + let search_divider = `
`; + + if (results.length) { + let links = []; + let count = 0; + let search_results = ""; + + results.forEach(function (result) { + if (result.location) { + // Checking for duplication of results for the same page + if (!links.includes(result.location)) { + search_results += make_search_result(result, querystring); + count++; + } + + links.push(result.location); + } + }); + + let result_count = `
${count} result(s)
`; + + search_result_container = ` +
+ ${modal_filters} + ${search_divider} + ${result_count} +
+ ${search_results} +
+
+ `; + } else { + search_result_container = ` +
+ ${modal_filters} + ${search_divider} +
0 result(s)
+
+
No result found!
+ `; + } + + if ($(".search-modal-card-body").hasClass("is-justify-content-center")) { + $(".search-modal-card-body").removeClass("is-justify-content-center"); + } + + $(".search-modal-card-body").html(search_result_container); + } else { + filter_results = []; + modal_filters = make_modal_body_filters(filters, filter_results); + + if (!$(".search-modal-card-body").hasClass("is-justify-content-center")) { + $(".search-modal-card-body").addClass("is-justify-content-center"); + } + + $(".search-modal-card-body").html(initial_search_body); + } +} + +/** + * Make the modal filter html + * + * @param {string[]} filters + * @param {string[]} selected_filters + * @returns string + */ +function make_modal_body_filters(filters, selected_filters = []) { + let str = ``; + + filters.forEach((val) => { + if (selected_filters.includes(val)) { + str += `${val}`; + } else { + str += `${val}`; + } + }); + + let filter_html = ` +
+ Filters: + ${str} +
+ `; + + return filter_html; +} + +/** + * Make the result component given a minisearch result data object and the value of the search input as queryString. + * To view the result object structure, refer: https://lucaong.github.io/minisearch/modules/_minisearch_.html#searchresult + * + * @param {object} result + * @param {string} querystring + * @returns string + */ +function make_search_result(result, querystring) { + let search_divider = `
`; + let display_link = + result.location.slice(Math.max(0), Math.min(50, result.location.length)) + + (result.location.length > 30 ? "..." : ""); // To cut-off the link because it messes with the overflow of the whole div + + if (result.page !== "") { + display_link += ` (${result.page})`; + } + + let textindex = new RegExp(`\\b${querystring}\\b`, "i").exec(result.text); + let text = + textindex !== null + ? result.text.slice( + Math.max(textindex.index - 100, 0), + Math.min( + textindex.index + querystring.length + 100, + result.text.length + ) + ) + : ""; // cut-off text before and after from the match + + let display_result = text.length + ? "..." + + text.replace( + new RegExp(`\\b${querystring}\\b`, "i"), // For first occurrence + '$&' + ) + + "..." + : ""; // highlights the match + + let in_code = false; + if (!["page", "section"].includes(result.category.toLowerCase())) { + in_code = true; + } + + // We encode the full url to escape some special characters which can lead to broken links + let result_div = ` + +
+
${result.title}
+
${result.category}
+
+

+ ${display_result} +

+
+ ${display_link} +
+
+ ${search_divider} + `; + + return result_div; +} + +/** + * Get selected filters, remake the filter html and lastly update the search modal + */ +function get_filters() { + let ele = $(".search-filters .search-filter-selected").get(); + filter_results = ele.map((x) => $(x).text().toLowerCase()); + modal_filters = make_modal_body_filters(filters, filter_results); + update_search(filter_results); +} + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +// Modal settings dialog +$(document).ready(function () { + var settings = $("#documenter-settings"); + $("#documenter-settings-button").click(function () { + settings.toggleClass("is-active"); + }); + // Close the dialog if X is clicked + $("#documenter-settings button.delete").click(function () { + settings.removeClass("is-active"); + }); + // Close dialog if ESC is pressed + $(document).keyup(function (e) { + if (e.keyCode == 27) settings.removeClass("is-active"); + }); +}); + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +let search_modal_header = ` + +`; + +let initial_search_body = ` +
Type something to get started!
+`; + +let search_modal_footer = ` + +`; + +$(document.body).append( + ` + + ` +); + +document.querySelector(".docs-search-query").addEventListener("click", () => { + openModal(); +}); + +document.querySelector(".close-search-modal").addEventListener("click", () => { + closeModal(); +}); + +$(document).on("click", ".search-result-link", function () { + closeModal(); +}); + +document.addEventListener("keydown", (event) => { + if ((event.ctrlKey || event.metaKey) && event.key === "/") { + openModal(); + } else if (event.key === "Escape") { + closeModal(); + } + + return false; +}); + +// Functions to open and close a modal +function openModal() { + let searchModal = document.querySelector("#search-modal"); + + searchModal.classList.add("is-active"); + document.querySelector(".documenter-search-input").focus(); +} + +function closeModal() { + let searchModal = document.querySelector("#search-modal"); + let initial_search_body = ` +
Type something to get started!
+ `; + + searchModal.classList.remove("is-active"); + document.querySelector(".documenter-search-input").blur(); + + if (!$(".search-modal-card-body").hasClass("is-justify-content-center")) { + $(".search-modal-card-body").addClass("is-justify-content-center"); + } + + $(".documenter-search-input").val(""); + $(".search-modal-card-body").html(initial_search_body); +} + +document + .querySelector("#search-modal .modal-background") + .addEventListener("click", () => { + closeModal(); + }); + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +// Manages the showing and hiding of the sidebar. +$(document).ready(function () { + var sidebar = $("#documenter > .docs-sidebar"); + var sidebar_button = $("#documenter-sidebar-button"); + sidebar_button.click(function (ev) { + ev.preventDefault(); + sidebar.toggleClass("visible"); + if (sidebar.hasClass("visible")) { + // Makes sure that the current menu item is visible in the sidebar. + $("#documenter .docs-menu a.is-active").focus(); + } + }); + $("#documenter > .docs-main").bind("click", function (ev) { + if ($(ev.target).is(sidebar_button)) { + return; + } + if (sidebar.hasClass("visible")) { + sidebar.removeClass("visible"); + } + }); +}); + +// Resizes the package name / sitename in the sidebar if it is too wide. +// Inspired by: https://github.com/davatron5000/FitText.js +$(document).ready(function () { + e = $("#documenter .docs-autofit"); + function resize() { + var L = parseInt(e.css("max-width"), 10); + var L0 = e.width(); + if (L0 > L) { + var h0 = parseInt(e.css("font-size"), 10); + e.css("font-size", (L * h0) / L0); + // TODO: make sure it survives resizes? + } + } + // call once and then register events + resize(); + $(window).resize(resize); + $(window).on("orientationchange", resize); +}); + +// Scroll the navigation bar to the currently selected menu item +$(document).ready(function () { + var sidebar = $("#documenter .docs-menu").get(0); + var active = $("#documenter .docs-menu .is-active").get(0); + if (typeof active !== "undefined") { + sidebar.scrollTop = active.offsetTop - sidebar.offsetTop - 15; + } +}); + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +// Theme picker setup +$(document).ready(function () { + // onchange callback + $("#documenter-themepicker").change(function themepick_callback(ev) { + var themename = $("#documenter-themepicker option:selected").attr("value"); + if (themename === "auto") { + // set_theme(window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'); + window.localStorage.removeItem("documenter-theme"); + } else { + // set_theme(themename); + window.localStorage.setItem("documenter-theme", themename); + } + // We re-use the global function from themeswap.js to actually do the swapping. + set_theme_from_local_storage(); + }); + + // Make sure that the themepicker displays the correct theme when the theme is retrieved + // from localStorage + if (typeof window.localStorage !== "undefined") { + var theme = window.localStorage.getItem("documenter-theme"); + if (theme !== null) { + $("#documenter-themepicker option").each(function (i, e) { + e.selected = e.value === theme; + }); + } + } +}); + +}) +//////////////////////////////////////////////////////////////////////////////// +require(['jquery'], function($) { + +// update the version selector with info from the siteinfo.js and ../versions.js files +$(document).ready(function () { + // If the version selector is disabled with DOCUMENTER_VERSION_SELECTOR_DISABLED in the + // siteinfo.js file, we just return immediately and not display the version selector. + if ( + typeof DOCUMENTER_VERSION_SELECTOR_DISABLED === "boolean" && + DOCUMENTER_VERSION_SELECTOR_DISABLED + ) { + return; + } + + var version_selector = $("#documenter .docs-version-selector"); + var version_selector_select = $("#documenter .docs-version-selector select"); + + version_selector_select.change(function (x) { + target_href = version_selector_select + .children("option:selected") + .get(0).value; + window.location.href = target_href; + }); + + // add the current version to the selector based on siteinfo.js, but only if the selector is empty + if ( + typeof DOCUMENTER_CURRENT_VERSION !== "undefined" && + $("#version-selector > option").length == 0 + ) { + var option = $( + "" + ); + version_selector_select.append(option); + } + + if (typeof DOC_VERSIONS !== "undefined") { + var existing_versions = version_selector_select.children("option"); + var existing_versions_texts = existing_versions.map(function (i, x) { + return x.text; + }); + DOC_VERSIONS.forEach(function (each) { + var version_url = documenterBaseURL + "/../" + each + "/"; + var existing_id = $.inArray(each, existing_versions_texts); + // if not already in the version selector, add it as a new option, + // otherwise update the old option with the URL and enable it + if (existing_id == -1) { + var option = $( + "" + ); + version_selector_select.append(option); + } else { + var option = existing_versions[existing_id]; + option.value = version_url; + option.disabled = false; + } + }); + } + + // only show the version selector if the selector has been populated + if (version_selector_select.children("option").length > 0) { + version_selector.toggleClass("visible"); + } +}); + +}) diff --git a/previews/PR1697/assets/favicon.ico b/previews/PR1697/assets/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..be7e49a9c80a73367beb61669233f572ce97c2a2 GIT binary patch literal 15406 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 UeY0mdNKupipZ>3bf2@K30B`TKH2?qr literal 0 HcmV?d00001 diff --git a/previews/PR1697/assets/solution_000040_scalar_resized.png b/previews/PR1697/assets/solution_000040_scalar_resized.png new file mode 100644 index 0000000000000000000000000000000000000000..e002208c46a98255909e1c7f2a46d6cc4d23c690 GIT binary patch literal 94699 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 X*Z*EY6QBbNtpFn@r7T$sJ-z)8BBdcc literal 0 HcmV?d00001 diff --git a/previews/PR1697/assets/themes/documenter-dark.css b/previews/PR1697/assets/themes/documenter-dark.css new file mode 100644 index 00000000000..ec054ecc189 --- /dev/null +++ b/previews/PR1697/assets/themes/documenter-dark.css @@ -0,0 +1,7 @@ +html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-ellipsis,html.theme--documenter-dark .file-cta,html.theme--documenter-dark .file-name,html.theme--documenter-dark .select select,html.theme--documenter-dark .textarea,html.theme--documenter-dark .input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark .button{-moz-appearance:none;-webkit-appearance:none;align-items:center;border:1px solid transparent;border-radius:.4em;box-shadow:none;display:inline-flex;font-size:1rem;height:2.5em;justify-content:flex-start;line-height:1.5;padding-bottom:calc(0.5em - 1px);padding-left:calc(0.75em - 1px);padding-right:calc(0.75em - 1px);padding-top:calc(0.5em - 1px);position:relative;vertical-align:top}html.theme--documenter-dark .pagination-previous:focus,html.theme--documenter-dark .pagination-next:focus,html.theme--documenter-dark .pagination-link:focus,html.theme--documenter-dark .pagination-ellipsis:focus,html.theme--documenter-dark .file-cta:focus,html.theme--documenter-dark .file-name:focus,html.theme--documenter-dark .select select:focus,html.theme--documenter-dark .textarea:focus,html.theme--documenter-dark .input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:focus,html.theme--documenter-dark .button:focus,html.theme--documenter-dark .is-focused.pagination-previous,html.theme--documenter-dark .is-focused.pagination-next,html.theme--documenter-dark .is-focused.pagination-link,html.theme--documenter-dark .is-focused.pagination-ellipsis,html.theme--documenter-dark .is-focused.file-cta,html.theme--documenter-dark .is-focused.file-name,html.theme--documenter-dark .select select.is-focused,html.theme--documenter-dark .is-focused.textarea,html.theme--documenter-dark .is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-focused.button,html.theme--documenter-dark .pagination-previous:active,html.theme--documenter-dark .pagination-next:active,html.theme--documenter-dark .pagination-link:active,html.theme--documenter-dark .pagination-ellipsis:active,html.theme--documenter-dark .file-cta:active,html.theme--documenter-dark .file-name:active,html.theme--documenter-dark .select select:active,html.theme--documenter-dark .textarea:active,html.theme--documenter-dark .input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:active,html.theme--documenter-dark .button:active,html.theme--documenter-dark .is-active.pagination-previous,html.theme--documenter-dark .is-active.pagination-next,html.theme--documenter-dark .is-active.pagination-link,html.theme--documenter-dark .is-active.pagination-ellipsis,html.theme--documenter-dark .is-active.file-cta,html.theme--documenter-dark .is-active.file-name,html.theme--documenter-dark .select select.is-active,html.theme--documenter-dark .is-active.textarea,html.theme--documenter-dark .is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active,html.theme--documenter-dark .is-active.button{outline:none}html.theme--documenter-dark .pagination-previous[disabled],html.theme--documenter-dark .pagination-next[disabled],html.theme--documenter-dark .pagination-link[disabled],html.theme--documenter-dark .pagination-ellipsis[disabled],html.theme--documenter-dark .file-cta[disabled],html.theme--documenter-dark .file-name[disabled],html.theme--documenter-dark .select select[disabled],html.theme--documenter-dark .textarea[disabled],html.theme--documenter-dark .input[disabled],html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled],html.theme--documenter-dark .button[disabled],fieldset[disabled] html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark fieldset[disabled] .pagination-previous,fieldset[disabled] html.theme--documenter-dark .pagination-next,html.theme--documenter-dark fieldset[disabled] .pagination-next,fieldset[disabled] html.theme--documenter-dark .pagination-link,html.theme--documenter-dark fieldset[disabled] .pagination-link,fieldset[disabled] html.theme--documenter-dark .pagination-ellipsis,html.theme--documenter-dark fieldset[disabled] .pagination-ellipsis,fieldset[disabled] html.theme--documenter-dark .file-cta,html.theme--documenter-dark fieldset[disabled] .file-cta,fieldset[disabled] html.theme--documenter-dark .file-name,html.theme--documenter-dark fieldset[disabled] .file-name,fieldset[disabled] html.theme--documenter-dark .select select,fieldset[disabled] html.theme--documenter-dark .textarea,fieldset[disabled] html.theme--documenter-dark .input,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark fieldset[disabled] .select select,html.theme--documenter-dark .select fieldset[disabled] select,html.theme--documenter-dark fieldset[disabled] .textarea,html.theme--documenter-dark fieldset[disabled] .input,html.theme--documenter-dark fieldset[disabled] #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar fieldset[disabled] form.docs-search>input,fieldset[disabled] html.theme--documenter-dark .button,html.theme--documenter-dark fieldset[disabled] .button{cursor:not-allowed}html.theme--documenter-dark .tabs,html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-ellipsis,html.theme--documenter-dark .breadcrumb,html.theme--documenter-dark .file,html.theme--documenter-dark .button,.is-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}html.theme--documenter-dark .navbar-link:not(.is-arrowless)::after,html.theme--documenter-dark .select:not(.is-multiple):not(.is-loading)::after{border:3px solid rgba(0,0,0,0);border-radius:2px;border-right:0;border-top:0;content:" ";display:block;height:0.625em;margin-top:-0.4375em;pointer-events:none;position:absolute;top:50%;transform:rotate(-45deg);transform-origin:center;width:0.625em}html.theme--documenter-dark .admonition:not(:last-child),html.theme--documenter-dark .tabs:not(:last-child),html.theme--documenter-dark .pagination:not(:last-child),html.theme--documenter-dark .message:not(:last-child),html.theme--documenter-dark .level:not(:last-child),html.theme--documenter-dark .breadcrumb:not(:last-child),html.theme--documenter-dark .block:not(:last-child),html.theme--documenter-dark .title:not(:last-child),html.theme--documenter-dark .subtitle:not(:last-child),html.theme--documenter-dark .table-container:not(:last-child),html.theme--documenter-dark .table:not(:last-child),html.theme--documenter-dark .progress:not(:last-child),html.theme--documenter-dark .notification:not(:last-child),html.theme--documenter-dark .content:not(:last-child),html.theme--documenter-dark .box:not(:last-child){margin-bottom:1.5rem}html.theme--documenter-dark .modal-close,html.theme--documenter-dark .delete{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-moz-appearance:none;-webkit-appearance:none;background-color:rgba(10,10,10,0.2);border:none;border-radius:9999px;cursor:pointer;pointer-events:auto;display:inline-block;flex-grow:0;flex-shrink:0;font-size:0;height:20px;max-height:20px;max-width:20px;min-height:20px;min-width:20px;outline:none;position:relative;vertical-align:top;width:20px}html.theme--documenter-dark .modal-close::before,html.theme--documenter-dark .delete::before,html.theme--documenter-dark .modal-close::after,html.theme--documenter-dark .delete::after{background-color:#fff;content:"";display:block;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%) rotate(45deg);transform-origin:center center}html.theme--documenter-dark .modal-close::before,html.theme--documenter-dark .delete::before{height:2px;width:50%}html.theme--documenter-dark .modal-close::after,html.theme--documenter-dark .delete::after{height:50%;width:2px}html.theme--documenter-dark .modal-close:hover,html.theme--documenter-dark .delete:hover,html.theme--documenter-dark .modal-close:focus,html.theme--documenter-dark .delete:focus{background-color:rgba(10,10,10,0.3)}html.theme--documenter-dark .modal-close:active,html.theme--documenter-dark .delete:active{background-color:rgba(10,10,10,0.4)}html.theme--documenter-dark .is-small.modal-close,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.modal-close,html.theme--documenter-dark .is-small.delete,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.delete{height:16px;max-height:16px;max-width:16px;min-height:16px;min-width:16px;width:16px}html.theme--documenter-dark .is-medium.modal-close,html.theme--documenter-dark .is-medium.delete{height:24px;max-height:24px;max-width:24px;min-height:24px;min-width:24px;width:24px}html.theme--documenter-dark .is-large.modal-close,html.theme--documenter-dark .is-large.delete{height:32px;max-height:32px;max-width:32px;min-height:32px;min-width:32px;width:32px}html.theme--documenter-dark .control.is-loading::after,html.theme--documenter-dark .select.is-loading::after,html.theme--documenter-dark .loader,html.theme--documenter-dark .button.is-loading::after{animation:spinAround 500ms infinite linear;border:2px solid #dbdee0;border-radius:9999px;border-right-color:transparent;border-top-color:transparent;content:"";display:block;height:1em;position:relative;width:1em}html.theme--documenter-dark .hero-video,html.theme--documenter-dark .modal-background,html.theme--documenter-dark .modal,html.theme--documenter-dark .image.is-square img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-square img,html.theme--documenter-dark .image.is-square .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-square .has-ratio,html.theme--documenter-dark .image.is-1by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by1 img,html.theme--documenter-dark .image.is-1by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by1 .has-ratio,html.theme--documenter-dark .image.is-5by4 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by4 img,html.theme--documenter-dark .image.is-5by4 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by4 .has-ratio,html.theme--documenter-dark .image.is-4by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by3 img,html.theme--documenter-dark .image.is-4by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by3 .has-ratio,html.theme--documenter-dark .image.is-3by2 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by2 img,html.theme--documenter-dark .image.is-3by2 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by2 .has-ratio,html.theme--documenter-dark .image.is-5by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by3 img,html.theme--documenter-dark .image.is-5by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by3 .has-ratio,html.theme--documenter-dark .image.is-16by9 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16by9 img,html.theme--documenter-dark .image.is-16by9 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16by9 .has-ratio,html.theme--documenter-dark .image.is-2by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by1 img,html.theme--documenter-dark .image.is-2by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by1 .has-ratio,html.theme--documenter-dark .image.is-3by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by1 img,html.theme--documenter-dark .image.is-3by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by1 .has-ratio,html.theme--documenter-dark .image.is-4by5 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by5 img,html.theme--documenter-dark .image.is-4by5 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by5 .has-ratio,html.theme--documenter-dark .image.is-3by4 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by4 img,html.theme--documenter-dark .image.is-3by4 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by4 .has-ratio,html.theme--documenter-dark .image.is-2by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by3 img,html.theme--documenter-dark .image.is-2by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by3 .has-ratio,html.theme--documenter-dark .image.is-3by5 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by5 img,html.theme--documenter-dark .image.is-3by5 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by5 .has-ratio,html.theme--documenter-dark .image.is-9by16 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-9by16 img,html.theme--documenter-dark .image.is-9by16 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-9by16 .has-ratio,html.theme--documenter-dark .image.is-1by2 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by2 img,html.theme--documenter-dark .image.is-1by2 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by2 .has-ratio,html.theme--documenter-dark .image.is-1by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by3 img,html.theme--documenter-dark .image.is-1by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by3 .has-ratio,.is-overlay{bottom:0;left:0;position:absolute;right:0;top:0}html.theme--documenter-dark .navbar-burger{-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;color:currentColor;font-family:inherit;font-size:1em;margin:0;padding:0}/*! minireset.css v0.0.6 | MIT License | github.com/jgthms/minireset.css */html,body,p,ol,ul,li,dl,dt,dd,blockquote,figure,fieldset,legend,textarea,pre,iframe,hr,h1,h2,h3,h4,h5,h6{margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}ul{list-style:none}button,input,select,textarea{margin:0}html{box-sizing:border-box}*,*::before,*::after{box-sizing:inherit}img,video{height:auto;max-width:100%}iframe{border:0}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}td:not([align]),th:not([align]){text-align:inherit}.has-text-white{color:#fff !important}a.has-text-white:hover,a.has-text-white:focus{color:#e6e6e6 !important}.has-background-white{background-color:#fff !important}.has-text-black{color:#0a0a0a !important}a.has-text-black:hover,a.has-text-black:focus{color:#000 !important}.has-background-black{background-color:#0a0a0a !important}.has-text-light{color:#ecf0f1 !important}a.has-text-light:hover,a.has-text-light:focus{color:#cfd9db !important}.has-background-light{background-color:#ecf0f1 !important}.has-text-dark{color:#282f2f !important}a.has-text-dark:hover,a.has-text-dark:focus{color:#111414 !important}.has-background-dark{background-color:#282f2f !important}.has-text-primary{color:#375a7f !important}a.has-text-primary:hover,a.has-text-primary:focus{color:#28415b !important}.has-background-primary{background-color:#375a7f !important}.has-text-primary-light{color:#f1f5f9 !important}a.has-text-primary-light:hover,a.has-text-primary-light:focus{color:#cddbe9 !important}.has-background-primary-light{background-color:#f1f5f9 !important}.has-text-primary-dark{color:#4d7eb2 !important}a.has-text-primary-dark:hover,a.has-text-primary-dark:focus{color:#7198c1 !important}.has-background-primary-dark{background-color:#4d7eb2 !important}.has-text-link{color:#1abc9c !important}a.has-text-link:hover,a.has-text-link:focus{color:#148f77 !important}.has-background-link{background-color:#1abc9c !important}.has-text-link-light{color:#edfdf9 !important}a.has-text-link-light:hover,a.has-text-link-light:focus{color:#c0f6ec !important}.has-background-link-light{background-color:#edfdf9 !important}.has-text-link-dark{color:#15987e !important}a.has-text-link-dark:hover,a.has-text-link-dark:focus{color:#1bc5a4 !important}.has-background-link-dark{background-color:#15987e !important}.has-text-info{color:#024c7d !important}a.has-text-info:hover,a.has-text-info:focus{color:#012d4b !important}.has-background-info{background-color:#024c7d !important}.has-text-info-light{color:#ebf7ff !important}a.has-text-info-light:hover,a.has-text-info-light:focus{color:#b9e2fe !important}.has-background-info-light{background-color:#ebf7ff !important}.has-text-info-dark{color:#0e9dfb !important}a.has-text-info-dark:hover,a.has-text-info-dark:focus{color:#40b1fc !important}.has-background-info-dark{background-color:#0e9dfb !important}.has-text-success{color:#008438 !important}a.has-text-success:hover,a.has-text-success:focus{color:#005122 !important}.has-background-success{background-color:#008438 !important}.has-text-success-light{color:#ebfff3 !important}a.has-text-success-light:hover,a.has-text-success-light:focus{color:#b8ffd6 !important}.has-background-success-light{background-color:#ebfff3 !important}.has-text-success-dark{color:#00eb64 !important}a.has-text-success-dark:hover,a.has-text-success-dark:focus{color:#1fff7e !important}.has-background-success-dark{background-color:#00eb64 !important}.has-text-warning{color:#ad8100 !important}a.has-text-warning:hover,a.has-text-warning:focus{color:#7a5b00 !important}.has-background-warning{background-color:#ad8100 !important}.has-text-warning-light{color:#fffaeb !important}a.has-text-warning-light:hover,a.has-text-warning-light:focus{color:#ffedb8 !important}.has-background-warning-light{background-color:#fffaeb !important}.has-text-warning-dark{color:#d19c00 !important}a.has-text-warning-dark:hover,a.has-text-warning-dark:focus{color:#ffbf05 !important}.has-background-warning-dark{background-color:#d19c00 !important}.has-text-danger{color:#9e1b0d !important}a.has-text-danger:hover,a.has-text-danger:focus{color:#6f1309 !important}.has-background-danger{background-color:#9e1b0d !important}.has-text-danger-light{color:#fdeeec !important}a.has-text-danger-light:hover,a.has-text-danger-light:focus{color:#fac3bd !important}.has-background-danger-light{background-color:#fdeeec !important}.has-text-danger-dark{color:#ec311d !important}a.has-text-danger-dark:hover,a.has-text-danger-dark:focus{color:#f05c4c !important}.has-background-danger-dark{background-color:#ec311d !important}.has-text-black-bis{color:#121212 !important}.has-background-black-bis{background-color:#121212 !important}.has-text-black-ter{color:#242424 !important}.has-background-black-ter{background-color:#242424 !important}.has-text-grey-darker{color:#282f2f !important}.has-background-grey-darker{background-color:#282f2f !important}.has-text-grey-dark{color:#343c3d !important}.has-background-grey-dark{background-color:#343c3d !important}.has-text-grey{color:#5e6d6f !important}.has-background-grey{background-color:#5e6d6f !important}.has-text-grey-light{color:#8c9b9d !important}.has-background-grey-light{background-color:#8c9b9d !important}.has-text-grey-lighter{color:#dbdee0 !important}.has-background-grey-lighter{background-color:#dbdee0 !important}.has-text-white-ter{color:#ecf0f1 !important}.has-background-white-ter{background-color:#ecf0f1 !important}.has-text-white-bis{color:#fafafa !important}.has-background-white-bis{background-color:#fafafa !important}.is-flex-direction-row{flex-direction:row !important}.is-flex-direction-row-reverse{flex-direction:row-reverse !important}.is-flex-direction-column{flex-direction:column !important}.is-flex-direction-column-reverse{flex-direction:column-reverse !important}.is-flex-wrap-nowrap{flex-wrap:nowrap !important}.is-flex-wrap-wrap{flex-wrap:wrap !important}.is-flex-wrap-wrap-reverse{flex-wrap:wrap-reverse !important}.is-justify-content-flex-start{justify-content:flex-start !important}.is-justify-content-flex-end{justify-content:flex-end !important}.is-justify-content-center{justify-content:center !important}.is-justify-content-space-between{justify-content:space-between !important}.is-justify-content-space-around{justify-content:space-around !important}.is-justify-content-space-evenly{justify-content:space-evenly !important}.is-justify-content-start{justify-content:start !important}.is-justify-content-end{justify-content:end !important}.is-justify-content-left{justify-content:left !important}.is-justify-content-right{justify-content:right !important}.is-align-content-flex-start{align-content:flex-start !important}.is-align-content-flex-end{align-content:flex-end !important}.is-align-content-center{align-content:center !important}.is-align-content-space-between{align-content:space-between !important}.is-align-content-space-around{align-content:space-around !important}.is-align-content-space-evenly{align-content:space-evenly !important}.is-align-content-stretch{align-content:stretch !important}.is-align-content-start{align-content:start !important}.is-align-content-end{align-content:end !important}.is-align-content-baseline{align-content:baseline !important}.is-align-items-stretch{align-items:stretch !important}.is-align-items-flex-start{align-items:flex-start !important}.is-align-items-flex-end{align-items:flex-end !important}.is-align-items-center{align-items:center !important}.is-align-items-baseline{align-items:baseline !important}.is-align-items-start{align-items:start !important}.is-align-items-end{align-items:end !important}.is-align-items-self-start{align-items:self-start !important}.is-align-items-self-end{align-items:self-end !important}.is-align-self-auto{align-self:auto !important}.is-align-self-flex-start{align-self:flex-start !important}.is-align-self-flex-end{align-self:flex-end !important}.is-align-self-center{align-self:center !important}.is-align-self-baseline{align-self:baseline !important}.is-align-self-stretch{align-self:stretch !important}.is-flex-grow-0{flex-grow:0 !important}.is-flex-grow-1{flex-grow:1 !important}.is-flex-grow-2{flex-grow:2 !important}.is-flex-grow-3{flex-grow:3 !important}.is-flex-grow-4{flex-grow:4 !important}.is-flex-grow-5{flex-grow:5 !important}.is-flex-shrink-0{flex-shrink:0 !important}.is-flex-shrink-1{flex-shrink:1 !important}.is-flex-shrink-2{flex-shrink:2 !important}.is-flex-shrink-3{flex-shrink:3 !important}.is-flex-shrink-4{flex-shrink:4 !important}.is-flex-shrink-5{flex-shrink:5 !important}.is-clearfix::after{clear:both;content:" ";display:table}.is-pulled-left{float:left !important}.is-pulled-right{float:right !important}.is-radiusless{border-radius:0 !important}.is-shadowless{box-shadow:none !important}.is-clickable{cursor:pointer !important;pointer-events:all !important}.is-clipped{overflow:hidden !important}.is-relative{position:relative !important}.is-marginless{margin:0 !important}.is-paddingless{padding:0 !important}.m-0{margin:0 !important}.mt-0{margin-top:0 !important}.mr-0{margin-right:0 !important}.mb-0{margin-bottom:0 !important}.ml-0{margin-left:0 !important}.mx-0{margin-left:0 !important;margin-right:0 !important}.my-0{margin-top:0 !important;margin-bottom:0 !important}.m-1{margin:.25rem !important}.mt-1{margin-top:.25rem !important}.mr-1{margin-right:.25rem !important}.mb-1{margin-bottom:.25rem !important}.ml-1{margin-left:.25rem !important}.mx-1{margin-left:.25rem !important;margin-right:.25rem !important}.my-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.m-2{margin:.5rem !important}.mt-2{margin-top:.5rem !important}.mr-2{margin-right:.5rem !important}.mb-2{margin-bottom:.5rem !important}.ml-2{margin-left:.5rem !important}.mx-2{margin-left:.5rem !important;margin-right:.5rem !important}.my-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.m-3{margin:.75rem !important}.mt-3{margin-top:.75rem !important}.mr-3{margin-right:.75rem !important}.mb-3{margin-bottom:.75rem !important}.ml-3{margin-left:.75rem !important}.mx-3{margin-left:.75rem !important;margin-right:.75rem !important}.my-3{margin-top:.75rem !important;margin-bottom:.75rem !important}.m-4{margin:1rem !important}.mt-4{margin-top:1rem !important}.mr-4{margin-right:1rem !important}.mb-4{margin-bottom:1rem !important}.ml-4{margin-left:1rem !important}.mx-4{margin-left:1rem !important;margin-right:1rem !important}.my-4{margin-top:1rem !important;margin-bottom:1rem !important}.m-5{margin:1.5rem !important}.mt-5{margin-top:1.5rem !important}.mr-5{margin-right:1.5rem !important}.mb-5{margin-bottom:1.5rem !important}.ml-5{margin-left:1.5rem !important}.mx-5{margin-left:1.5rem !important;margin-right:1.5rem !important}.my-5{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.m-6{margin:3rem !important}.mt-6{margin-top:3rem !important}.mr-6{margin-right:3rem !important}.mb-6{margin-bottom:3rem !important}.ml-6{margin-left:3rem !important}.mx-6{margin-left:3rem !important;margin-right:3rem !important}.my-6{margin-top:3rem !important;margin-bottom:3rem !important}.m-auto{margin:auto !important}.mt-auto{margin-top:auto !important}.mr-auto{margin-right:auto !important}.mb-auto{margin-bottom:auto !important}.ml-auto{margin-left:auto !important}.mx-auto{margin-left:auto !important;margin-right:auto !important}.my-auto{margin-top:auto !important;margin-bottom:auto !important}.p-0{padding:0 !important}.pt-0{padding-top:0 !important}.pr-0{padding-right:0 !important}.pb-0{padding-bottom:0 !important}.pl-0{padding-left:0 !important}.px-0{padding-left:0 !important;padding-right:0 !important}.py-0{padding-top:0 !important;padding-bottom:0 !important}.p-1{padding:.25rem !important}.pt-1{padding-top:.25rem !important}.pr-1{padding-right:.25rem !important}.pb-1{padding-bottom:.25rem !important}.pl-1{padding-left:.25rem !important}.px-1{padding-left:.25rem !important;padding-right:.25rem !important}.py-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.p-2{padding:.5rem !important}.pt-2{padding-top:.5rem !important}.pr-2{padding-right:.5rem !important}.pb-2{padding-bottom:.5rem !important}.pl-2{padding-left:.5rem !important}.px-2{padding-left:.5rem !important;padding-right:.5rem !important}.py-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.p-3{padding:.75rem !important}.pt-3{padding-top:.75rem !important}.pr-3{padding-right:.75rem !important}.pb-3{padding-bottom:.75rem !important}.pl-3{padding-left:.75rem !important}.px-3{padding-left:.75rem !important;padding-right:.75rem !important}.py-3{padding-top:.75rem !important;padding-bottom:.75rem !important}.p-4{padding:1rem !important}.pt-4{padding-top:1rem !important}.pr-4{padding-right:1rem !important}.pb-4{padding-bottom:1rem !important}.pl-4{padding-left:1rem !important}.px-4{padding-left:1rem !important;padding-right:1rem !important}.py-4{padding-top:1rem !important;padding-bottom:1rem !important}.p-5{padding:1.5rem !important}.pt-5{padding-top:1.5rem !important}.pr-5{padding-right:1.5rem !important}.pb-5{padding-bottom:1.5rem !important}.pl-5{padding-left:1.5rem !important}.px-5{padding-left:1.5rem !important;padding-right:1.5rem !important}.py-5{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.p-6{padding:3rem !important}.pt-6{padding-top:3rem !important}.pr-6{padding-right:3rem !important}.pb-6{padding-bottom:3rem !important}.pl-6{padding-left:3rem !important}.px-6{padding-left:3rem !important;padding-right:3rem !important}.py-6{padding-top:3rem !important;padding-bottom:3rem !important}.p-auto{padding:auto !important}.pt-auto{padding-top:auto !important}.pr-auto{padding-right:auto !important}.pb-auto{padding-bottom:auto !important}.pl-auto{padding-left:auto !important}.px-auto{padding-left:auto !important;padding-right:auto !important}.py-auto{padding-top:auto !important;padding-bottom:auto !important}.is-size-1{font-size:3rem !important}.is-size-2{font-size:2.5rem !important}.is-size-3{font-size:2rem !important}.is-size-4{font-size:1.5rem !important}.is-size-5{font-size:1.25rem !important}.is-size-6{font-size:1rem !important}.is-size-7,html.theme--documenter-dark .docstring>section>a.docs-sourcelink{font-size:.75rem !important}@media screen and (max-width: 768px){.is-size-1-mobile{font-size:3rem !important}.is-size-2-mobile{font-size:2.5rem !important}.is-size-3-mobile{font-size:2rem !important}.is-size-4-mobile{font-size:1.5rem !important}.is-size-5-mobile{font-size:1.25rem !important}.is-size-6-mobile{font-size:1rem !important}.is-size-7-mobile{font-size:.75rem !important}}@media screen and (min-width: 769px),print{.is-size-1-tablet{font-size:3rem !important}.is-size-2-tablet{font-size:2.5rem !important}.is-size-3-tablet{font-size:2rem !important}.is-size-4-tablet{font-size:1.5rem !important}.is-size-5-tablet{font-size:1.25rem !important}.is-size-6-tablet{font-size:1rem !important}.is-size-7-tablet{font-size:.75rem !important}}@media screen and (max-width: 1055px){.is-size-1-touch{font-size:3rem !important}.is-size-2-touch{font-size:2.5rem !important}.is-size-3-touch{font-size:2rem !important}.is-size-4-touch{font-size:1.5rem !important}.is-size-5-touch{font-size:1.25rem !important}.is-size-6-touch{font-size:1rem !important}.is-size-7-touch{font-size:.75rem !important}}@media screen and (min-width: 1056px){.is-size-1-desktop{font-size:3rem !important}.is-size-2-desktop{font-size:2.5rem !important}.is-size-3-desktop{font-size:2rem !important}.is-size-4-desktop{font-size:1.5rem !important}.is-size-5-desktop{font-size:1.25rem !important}.is-size-6-desktop{font-size:1rem !important}.is-size-7-desktop{font-size:.75rem !important}}@media screen and (min-width: 1216px){.is-size-1-widescreen{font-size:3rem !important}.is-size-2-widescreen{font-size:2.5rem !important}.is-size-3-widescreen{font-size:2rem !important}.is-size-4-widescreen{font-size:1.5rem !important}.is-size-5-widescreen{font-size:1.25rem !important}.is-size-6-widescreen{font-size:1rem !important}.is-size-7-widescreen{font-size:.75rem !important}}@media screen and (min-width: 1408px){.is-size-1-fullhd{font-size:3rem !important}.is-size-2-fullhd{font-size:2.5rem !important}.is-size-3-fullhd{font-size:2rem !important}.is-size-4-fullhd{font-size:1.5rem !important}.is-size-5-fullhd{font-size:1.25rem !important}.is-size-6-fullhd{font-size:1rem !important}.is-size-7-fullhd{font-size:.75rem !important}}.has-text-centered{text-align:center !important}.has-text-justified{text-align:justify !important}.has-text-left{text-align:left !important}.has-text-right{text-align:right !important}@media screen and (max-width: 768px){.has-text-centered-mobile{text-align:center !important}}@media screen and (min-width: 769px),print{.has-text-centered-tablet{text-align:center !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-centered-tablet-only{text-align:center !important}}@media screen and (max-width: 1055px){.has-text-centered-touch{text-align:center !important}}@media screen and (min-width: 1056px){.has-text-centered-desktop{text-align:center !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-centered-desktop-only{text-align:center !important}}@media screen and (min-width: 1216px){.has-text-centered-widescreen{text-align:center !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-centered-widescreen-only{text-align:center !important}}@media screen and (min-width: 1408px){.has-text-centered-fullhd{text-align:center !important}}@media screen and (max-width: 768px){.has-text-justified-mobile{text-align:justify !important}}@media screen and (min-width: 769px),print{.has-text-justified-tablet{text-align:justify !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-justified-tablet-only{text-align:justify !important}}@media screen and (max-width: 1055px){.has-text-justified-touch{text-align:justify !important}}@media screen and (min-width: 1056px){.has-text-justified-desktop{text-align:justify !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-justified-desktop-only{text-align:justify !important}}@media screen and (min-width: 1216px){.has-text-justified-widescreen{text-align:justify !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-justified-widescreen-only{text-align:justify !important}}@media screen and (min-width: 1408px){.has-text-justified-fullhd{text-align:justify !important}}@media screen and (max-width: 768px){.has-text-left-mobile{text-align:left !important}}@media screen and (min-width: 769px),print{.has-text-left-tablet{text-align:left !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-left-tablet-only{text-align:left !important}}@media screen and (max-width: 1055px){.has-text-left-touch{text-align:left !important}}@media screen and (min-width: 1056px){.has-text-left-desktop{text-align:left !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-left-desktop-only{text-align:left !important}}@media screen and (min-width: 1216px){.has-text-left-widescreen{text-align:left !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-left-widescreen-only{text-align:left !important}}@media screen and (min-width: 1408px){.has-text-left-fullhd{text-align:left !important}}@media screen and (max-width: 768px){.has-text-right-mobile{text-align:right !important}}@media screen and (min-width: 769px),print{.has-text-right-tablet{text-align:right !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-right-tablet-only{text-align:right !important}}@media screen and (max-width: 1055px){.has-text-right-touch{text-align:right !important}}@media screen and (min-width: 1056px){.has-text-right-desktop{text-align:right !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-right-desktop-only{text-align:right !important}}@media screen and (min-width: 1216px){.has-text-right-widescreen{text-align:right !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-right-widescreen-only{text-align:right !important}}@media screen and (min-width: 1408px){.has-text-right-fullhd{text-align:right !important}}.is-capitalized{text-transform:capitalize !important}.is-lowercase{text-transform:lowercase !important}.is-uppercase{text-transform:uppercase !important}.is-italic{font-style:italic !important}.is-underlined{text-decoration:underline !important}.has-text-weight-light{font-weight:300 !important}.has-text-weight-normal{font-weight:400 !important}.has-text-weight-medium{font-weight:500 !important}.has-text-weight-semibold{font-weight:600 !important}.has-text-weight-bold{font-weight:700 !important}.is-family-primary{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-secondary{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-sans-serif{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-monospace{font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace !important}.is-family-code{font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace !important}.is-block{display:block !important}@media screen and (max-width: 768px){.is-block-mobile{display:block !important}}@media screen and (min-width: 769px),print{.is-block-tablet{display:block !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-block-tablet-only{display:block !important}}@media screen and (max-width: 1055px){.is-block-touch{display:block !important}}@media screen and (min-width: 1056px){.is-block-desktop{display:block !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-block-desktop-only{display:block !important}}@media screen and (min-width: 1216px){.is-block-widescreen{display:block !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-block-widescreen-only{display:block !important}}@media screen and (min-width: 1408px){.is-block-fullhd{display:block !important}}.is-flex{display:flex !important}@media screen and (max-width: 768px){.is-flex-mobile{display:flex !important}}@media screen and (min-width: 769px),print{.is-flex-tablet{display:flex !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-flex-tablet-only{display:flex !important}}@media screen and (max-width: 1055px){.is-flex-touch{display:flex !important}}@media screen and (min-width: 1056px){.is-flex-desktop{display:flex !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-flex-desktop-only{display:flex !important}}@media screen and (min-width: 1216px){.is-flex-widescreen{display:flex !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-flex-widescreen-only{display:flex !important}}@media screen and (min-width: 1408px){.is-flex-fullhd{display:flex !important}}.is-inline{display:inline !important}@media screen and (max-width: 768px){.is-inline-mobile{display:inline !important}}@media screen and (min-width: 769px),print{.is-inline-tablet{display:inline !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-tablet-only{display:inline !important}}@media screen and (max-width: 1055px){.is-inline-touch{display:inline !important}}@media screen and (min-width: 1056px){.is-inline-desktop{display:inline !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-desktop-only{display:inline !important}}@media screen and (min-width: 1216px){.is-inline-widescreen{display:inline !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-widescreen-only{display:inline !important}}@media screen and (min-width: 1408px){.is-inline-fullhd{display:inline !important}}.is-inline-block{display:inline-block !important}@media screen and (max-width: 768px){.is-inline-block-mobile{display:inline-block !important}}@media screen and (min-width: 769px),print{.is-inline-block-tablet{display:inline-block !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-block-tablet-only{display:inline-block !important}}@media screen and (max-width: 1055px){.is-inline-block-touch{display:inline-block !important}}@media screen and (min-width: 1056px){.is-inline-block-desktop{display:inline-block !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-block-desktop-only{display:inline-block !important}}@media screen and (min-width: 1216px){.is-inline-block-widescreen{display:inline-block !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-block-widescreen-only{display:inline-block !important}}@media screen and (min-width: 1408px){.is-inline-block-fullhd{display:inline-block !important}}.is-inline-flex{display:inline-flex !important}@media screen and (max-width: 768px){.is-inline-flex-mobile{display:inline-flex !important}}@media screen and (min-width: 769px),print{.is-inline-flex-tablet{display:inline-flex !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-flex-tablet-only{display:inline-flex !important}}@media screen and (max-width: 1055px){.is-inline-flex-touch{display:inline-flex !important}}@media screen and (min-width: 1056px){.is-inline-flex-desktop{display:inline-flex !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-flex-desktop-only{display:inline-flex !important}}@media screen and (min-width: 1216px){.is-inline-flex-widescreen{display:inline-flex !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-flex-widescreen-only{display:inline-flex !important}}@media screen and (min-width: 1408px){.is-inline-flex-fullhd{display:inline-flex !important}}.is-hidden{display:none !important}.is-sr-only{border:none !important;clip:rect(0, 0, 0, 0) !important;height:0.01em !important;overflow:hidden !important;padding:0 !important;position:absolute !important;white-space:nowrap !important;width:0.01em !important}@media screen and (max-width: 768px){.is-hidden-mobile{display:none !important}}@media screen and (min-width: 769px),print{.is-hidden-tablet{display:none !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-hidden-tablet-only{display:none !important}}@media screen and (max-width: 1055px){.is-hidden-touch{display:none !important}}@media screen and (min-width: 1056px){.is-hidden-desktop{display:none !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-hidden-desktop-only{display:none !important}}@media screen and (min-width: 1216px){.is-hidden-widescreen{display:none !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-hidden-widescreen-only{display:none !important}}@media screen and (min-width: 1408px){.is-hidden-fullhd{display:none !important}}.is-invisible{visibility:hidden !important}@media screen and (max-width: 768px){.is-invisible-mobile{visibility:hidden !important}}@media screen and (min-width: 769px),print{.is-invisible-tablet{visibility:hidden !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-invisible-tablet-only{visibility:hidden !important}}@media screen and (max-width: 1055px){.is-invisible-touch{visibility:hidden !important}}@media screen and (min-width: 1056px){.is-invisible-desktop{visibility:hidden !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-invisible-desktop-only{visibility:hidden !important}}@media screen and (min-width: 1216px){.is-invisible-widescreen{visibility:hidden !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-invisible-widescreen-only{visibility:hidden !important}}@media screen and (min-width: 1408px){.is-invisible-fullhd{visibility:hidden !important}}html.theme--documenter-dark{/*! + Theme: a11y-dark + Author: @ericwbailey + Maintainer: @ericwbailey + + Based on the Tomorrow Night Eighties theme: https://github.com/isagalaev/highlight.js/blob/master/src/styles/tomorrow-night-eighties.css +*/}html.theme--documenter-dark html{background-color:#1f2424;font-size:16px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;min-width:300px;overflow-x:auto;overflow-y:scroll;text-rendering:optimizeLegibility;text-size-adjust:100%}html.theme--documenter-dark article,html.theme--documenter-dark aside,html.theme--documenter-dark figure,html.theme--documenter-dark footer,html.theme--documenter-dark header,html.theme--documenter-dark hgroup,html.theme--documenter-dark section{display:block}html.theme--documenter-dark body,html.theme--documenter-dark button,html.theme--documenter-dark input,html.theme--documenter-dark optgroup,html.theme--documenter-dark select,html.theme--documenter-dark textarea{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif}html.theme--documenter-dark code,html.theme--documenter-dark pre{-moz-osx-font-smoothing:auto;-webkit-font-smoothing:auto;font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace}html.theme--documenter-dark body{color:#fff;font-size:1em;font-weight:400;line-height:1.5}html.theme--documenter-dark a{color:#1abc9c;cursor:pointer;text-decoration:none}html.theme--documenter-dark a strong{color:currentColor}html.theme--documenter-dark a:hover{color:#1dd2af}html.theme--documenter-dark code{background-color:rgba(255,255,255,0.05);color:#ececec;font-size:.875em;font-weight:normal;padding:.1em}html.theme--documenter-dark hr{background-color:#282f2f;border:none;display:block;height:2px;margin:1.5rem 0}html.theme--documenter-dark img{height:auto;max-width:100%}html.theme--documenter-dark input[type="checkbox"],html.theme--documenter-dark input[type="radio"]{vertical-align:baseline}html.theme--documenter-dark small{font-size:.875em}html.theme--documenter-dark span{font-style:inherit;font-weight:inherit}html.theme--documenter-dark strong{color:#f2f2f2;font-weight:700}html.theme--documenter-dark fieldset{border:none}html.theme--documenter-dark pre{-webkit-overflow-scrolling:touch;background-color:#282f2f;color:#fff;font-size:.875em;overflow-x:auto;padding:1.25rem 1.5rem;white-space:pre;word-wrap:normal}html.theme--documenter-dark pre code{background-color:transparent;color:currentColor;font-size:1em;padding:0}html.theme--documenter-dark table td,html.theme--documenter-dark table th{vertical-align:top}html.theme--documenter-dark table td:not([align]),html.theme--documenter-dark table th:not([align]){text-align:inherit}html.theme--documenter-dark table th{color:#f2f2f2}html.theme--documenter-dark .box{background-color:#343c3d;border-radius:8px;box-shadow:none;color:#fff;display:block;padding:1.25rem}html.theme--documenter-dark a.box:hover,html.theme--documenter-dark a.box:focus{box-shadow:0 0.5em 1em -0.125em rgba(10,10,10,0.1),0 0 0 1px #1abc9c}html.theme--documenter-dark a.box:active{box-shadow:inset 0 1px 2px rgba(10,10,10,0.2),0 0 0 1px #1abc9c}html.theme--documenter-dark .button{background-color:#282f2f;border-color:#4c5759;border-width:1px;color:#375a7f;cursor:pointer;justify-content:center;padding-bottom:calc(0.5em - 1px);padding-left:1em;padding-right:1em;padding-top:calc(0.5em - 1px);text-align:center;white-space:nowrap}html.theme--documenter-dark .button strong{color:inherit}html.theme--documenter-dark .button .icon,html.theme--documenter-dark .button .icon.is-small,html.theme--documenter-dark .button #documenter .docs-sidebar form.docs-search>input.icon,html.theme--documenter-dark #documenter .docs-sidebar .button form.docs-search>input.icon,html.theme--documenter-dark .button .icon.is-medium,html.theme--documenter-dark .button .icon.is-large{height:1.5em;width:1.5em}html.theme--documenter-dark .button .icon:first-child:not(:last-child){margin-left:calc(-0.5em - 1px);margin-right:.25em}html.theme--documenter-dark .button .icon:last-child:not(:first-child){margin-left:.25em;margin-right:calc(-0.5em - 1px)}html.theme--documenter-dark .button .icon:first-child:last-child{margin-left:calc(-0.5em - 1px);margin-right:calc(-0.5em - 1px)}html.theme--documenter-dark .button:hover,html.theme--documenter-dark .button.is-hovered{border-color:#8c9b9d;color:#f2f2f2}html.theme--documenter-dark .button:focus,html.theme--documenter-dark .button.is-focused{border-color:#8c9b9d;color:#17a689}html.theme--documenter-dark .button:focus:not(:active),html.theme--documenter-dark .button.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(26,188,156,0.25)}html.theme--documenter-dark .button:active,html.theme--documenter-dark .button.is-active{border-color:#343c3d;color:#f2f2f2}html.theme--documenter-dark .button.is-text{background-color:transparent;border-color:transparent;color:#fff;text-decoration:underline}html.theme--documenter-dark .button.is-text:hover,html.theme--documenter-dark .button.is-text.is-hovered,html.theme--documenter-dark .button.is-text:focus,html.theme--documenter-dark .button.is-text.is-focused{background-color:#282f2f;color:#f2f2f2}html.theme--documenter-dark .button.is-text:active,html.theme--documenter-dark .button.is-text.is-active{background-color:#1d2122;color:#f2f2f2}html.theme--documenter-dark .button.is-text[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-text{background-color:transparent;border-color:transparent;box-shadow:none}html.theme--documenter-dark .button.is-ghost{background:none;border-color:rgba(0,0,0,0);color:#1abc9c;text-decoration:none}html.theme--documenter-dark .button.is-ghost:hover,html.theme--documenter-dark .button.is-ghost.is-hovered{color:#1abc9c;text-decoration:underline}html.theme--documenter-dark .button.is-white{background-color:#fff;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .button.is-white:hover,html.theme--documenter-dark .button.is-white.is-hovered{background-color:#f9f9f9;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .button.is-white:focus,html.theme--documenter-dark .button.is-white.is-focused{border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .button.is-white:focus:not(:active),html.theme--documenter-dark .button.is-white.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}html.theme--documenter-dark .button.is-white:active,html.theme--documenter-dark .button.is-white.is-active{background-color:#f2f2f2;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .button.is-white[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-white{background-color:#fff;border-color:#fff;box-shadow:none}html.theme--documenter-dark .button.is-white.is-inverted{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .button.is-white.is-inverted:hover,html.theme--documenter-dark .button.is-white.is-inverted.is-hovered{background-color:#000}html.theme--documenter-dark .button.is-white.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-white.is-inverted{background-color:#0a0a0a;border-color:transparent;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-white.is-loading::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}html.theme--documenter-dark .button.is-white.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-white.is-outlined:hover,html.theme--documenter-dark .button.is-white.is-outlined.is-hovered,html.theme--documenter-dark .button.is-white.is-outlined:focus,html.theme--documenter-dark .button.is-white.is-outlined.is-focused{background-color:#fff;border-color:#fff;color:#0a0a0a}html.theme--documenter-dark .button.is-white.is-outlined.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-white.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-white.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-white.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-white.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}html.theme--documenter-dark .button.is-white.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-white.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-white.is-inverted.is-outlined{background-color:transparent;border-color:#0a0a0a;color:#0a0a0a}html.theme--documenter-dark .button.is-white.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-focused{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-white.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-white.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-white.is-inverted.is-outlined{background-color:transparent;border-color:#0a0a0a;box-shadow:none;color:#0a0a0a}html.theme--documenter-dark .button.is-black{background-color:#0a0a0a;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-black:hover,html.theme--documenter-dark .button.is-black.is-hovered{background-color:#040404;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-black:focus,html.theme--documenter-dark .button.is-black.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-black:focus:not(:active),html.theme--documenter-dark .button.is-black.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}html.theme--documenter-dark .button.is-black:active,html.theme--documenter-dark .button.is-black.is-active{background-color:#000;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-black[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-black{background-color:#0a0a0a;border-color:#0a0a0a;box-shadow:none}html.theme--documenter-dark .button.is-black.is-inverted{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .button.is-black.is-inverted:hover,html.theme--documenter-dark .button.is-black.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-black.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-black.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#0a0a0a}html.theme--documenter-dark .button.is-black.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-black.is-outlined{background-color:transparent;border-color:#0a0a0a;color:#0a0a0a}html.theme--documenter-dark .button.is-black.is-outlined:hover,html.theme--documenter-dark .button.is-black.is-outlined.is-hovered,html.theme--documenter-dark .button.is-black.is-outlined:focus,html.theme--documenter-dark .button.is-black.is-outlined.is-focused{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}html.theme--documenter-dark .button.is-black.is-outlined.is-loading::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}html.theme--documenter-dark .button.is-black.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-black.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-black.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-black.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-black.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-black.is-outlined{background-color:transparent;border-color:#0a0a0a;box-shadow:none;color:#0a0a0a}html.theme--documenter-dark .button.is-black.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-black.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-focused{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-black.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}html.theme--documenter-dark .button.is-black.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-black.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-light{background-color:#ecf0f1;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light:hover,html.theme--documenter-dark .button.is-light.is-hovered{background-color:#e5eaec;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light:focus,html.theme--documenter-dark .button.is-light.is-focused{border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light:focus:not(:active),html.theme--documenter-dark .button.is-light.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(236,240,241,0.25)}html.theme--documenter-dark .button.is-light:active,html.theme--documenter-dark .button.is-light.is-active{background-color:#dde4e6;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-light{background-color:#ecf0f1;border-color:#ecf0f1;box-shadow:none}html.theme--documenter-dark .button.is-light.is-inverted{background-color:rgba(0,0,0,0.7);color:#ecf0f1}html.theme--documenter-dark .button.is-light.is-inverted:hover,html.theme--documenter-dark .button.is-light.is-inverted.is-hovered{background-color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-light.is-inverted{background-color:rgba(0,0,0,0.7);border-color:transparent;box-shadow:none;color:#ecf0f1}html.theme--documenter-dark .button.is-light.is-loading::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}html.theme--documenter-dark .button.is-light.is-outlined{background-color:transparent;border-color:#ecf0f1;color:#ecf0f1}html.theme--documenter-dark .button.is-light.is-outlined:hover,html.theme--documenter-dark .button.is-light.is-outlined.is-hovered,html.theme--documenter-dark .button.is-light.is-outlined:focus,html.theme--documenter-dark .button.is-light.is-outlined.is-focused{background-color:#ecf0f1;border-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light.is-outlined.is-loading::after{border-color:transparent transparent #ecf0f1 #ecf0f1 !important}html.theme--documenter-dark .button.is-light.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-light.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-light.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-light.is-outlined.is-loading.is-focused::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}html.theme--documenter-dark .button.is-light.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-light.is-outlined{background-color:transparent;border-color:#ecf0f1;box-shadow:none;color:#ecf0f1}html.theme--documenter-dark .button.is-light.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-light.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-focused{background-color:rgba(0,0,0,0.7);color:#ecf0f1}html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-light.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #ecf0f1 #ecf0f1 !important}html.theme--documenter-dark .button.is-light.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-light.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);box-shadow:none;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .button.is-dark,html.theme--documenter-dark .content kbd.button{background-color:#282f2f;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-dark:hover,html.theme--documenter-dark .content kbd.button:hover,html.theme--documenter-dark .button.is-dark.is-hovered,html.theme--documenter-dark .content kbd.button.is-hovered{background-color:#232829;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-dark:focus,html.theme--documenter-dark .content kbd.button:focus,html.theme--documenter-dark .button.is-dark.is-focused,html.theme--documenter-dark .content kbd.button.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-dark:focus:not(:active),html.theme--documenter-dark .content kbd.button:focus:not(:active),html.theme--documenter-dark .button.is-dark.is-focused:not(:active),html.theme--documenter-dark .content kbd.button.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(40,47,47,0.25)}html.theme--documenter-dark .button.is-dark:active,html.theme--documenter-dark .content kbd.button:active,html.theme--documenter-dark .button.is-dark.is-active,html.theme--documenter-dark .content kbd.button.is-active{background-color:#1d2122;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-dark[disabled],html.theme--documenter-dark .content kbd.button[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-dark,fieldset[disabled] html.theme--documenter-dark .content kbd.button{background-color:#282f2f;border-color:#282f2f;box-shadow:none}html.theme--documenter-dark .button.is-dark.is-inverted,html.theme--documenter-dark .content kbd.button.is-inverted{background-color:#fff;color:#282f2f}html.theme--documenter-dark .button.is-dark.is-inverted:hover,html.theme--documenter-dark .content kbd.button.is-inverted:hover,html.theme--documenter-dark .button.is-dark.is-inverted.is-hovered,html.theme--documenter-dark .content kbd.button.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-dark.is-inverted[disabled],html.theme--documenter-dark .content kbd.button.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-dark.is-inverted,fieldset[disabled] html.theme--documenter-dark .content kbd.button.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#282f2f}html.theme--documenter-dark .button.is-dark.is-loading::after,html.theme--documenter-dark .content kbd.button.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-dark.is-outlined,html.theme--documenter-dark .content kbd.button.is-outlined{background-color:transparent;border-color:#282f2f;color:#282f2f}html.theme--documenter-dark .button.is-dark.is-outlined:hover,html.theme--documenter-dark .content kbd.button.is-outlined:hover,html.theme--documenter-dark .button.is-dark.is-outlined.is-hovered,html.theme--documenter-dark .content kbd.button.is-outlined.is-hovered,html.theme--documenter-dark .button.is-dark.is-outlined:focus,html.theme--documenter-dark .content kbd.button.is-outlined:focus,html.theme--documenter-dark .button.is-dark.is-outlined.is-focused,html.theme--documenter-dark .content kbd.button.is-outlined.is-focused{background-color:#282f2f;border-color:#282f2f;color:#fff}html.theme--documenter-dark .button.is-dark.is-outlined.is-loading::after,html.theme--documenter-dark .content kbd.button.is-outlined.is-loading::after{border-color:transparent transparent #282f2f #282f2f !important}html.theme--documenter-dark .button.is-dark.is-outlined.is-loading:hover::after,html.theme--documenter-dark .content kbd.button.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-dark.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .content kbd.button.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-dark.is-outlined.is-loading:focus::after,html.theme--documenter-dark .content kbd.button.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-dark.is-outlined.is-loading.is-focused::after,html.theme--documenter-dark .content kbd.button.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-dark.is-outlined[disabled],html.theme--documenter-dark .content kbd.button.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-dark.is-outlined,fieldset[disabled] html.theme--documenter-dark .content kbd.button.is-outlined{background-color:transparent;border-color:#282f2f;box-shadow:none;color:#282f2f}html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined:hover,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined:focus,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-focused,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-focused{background-color:#fff;color:#282f2f}html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined.is-loading.is-focused::after,html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #282f2f #282f2f !important}html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined[disabled],html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-dark.is-inverted.is-outlined,fieldset[disabled] html.theme--documenter-dark .content kbd.button.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-primary,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink{background-color:#375a7f;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-primary:hover,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:hover,html.theme--documenter-dark .button.is-primary.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-hovered.docs-sourcelink{background-color:#335476;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-primary:focus,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:focus,html.theme--documenter-dark .button.is-primary.is-focused,html.theme--documenter-dark .docstring>section>a.button.is-focused.docs-sourcelink{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-primary:focus:not(:active),html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:focus:not(:active),html.theme--documenter-dark .button.is-primary.is-focused:not(:active),html.theme--documenter-dark .docstring>section>a.button.is-focused.docs-sourcelink:not(:active){box-shadow:0 0 0 0.125em rgba(55,90,127,0.25)}html.theme--documenter-dark .button.is-primary:active,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:active,html.theme--documenter-dark .button.is-primary.is-active,html.theme--documenter-dark .docstring>section>a.button.is-active.docs-sourcelink{background-color:#2f4d6d;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-primary[disabled],html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-primary,fieldset[disabled] html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink{background-color:#375a7f;border-color:#375a7f;box-shadow:none}html.theme--documenter-dark .button.is-primary.is-inverted,html.theme--documenter-dark .docstring>section>a.button.is-inverted.docs-sourcelink{background-color:#fff;color:#375a7f}html.theme--documenter-dark .button.is-primary.is-inverted:hover,html.theme--documenter-dark .docstring>section>a.button.is-inverted.docs-sourcelink:hover,html.theme--documenter-dark .button.is-primary.is-inverted.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-hovered.docs-sourcelink{background-color:#f2f2f2}html.theme--documenter-dark .button.is-primary.is-inverted[disabled],html.theme--documenter-dark .docstring>section>a.button.is-inverted.docs-sourcelink[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-primary.is-inverted,fieldset[disabled] html.theme--documenter-dark .docstring>section>a.button.is-inverted.docs-sourcelink{background-color:#fff;border-color:transparent;box-shadow:none;color:#375a7f}html.theme--documenter-dark .button.is-primary.is-loading::after,html.theme--documenter-dark .docstring>section>a.button.is-loading.docs-sourcelink::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-primary.is-outlined,html.theme--documenter-dark .docstring>section>a.button.is-outlined.docs-sourcelink{background-color:transparent;border-color:#375a7f;color:#375a7f}html.theme--documenter-dark .button.is-primary.is-outlined:hover,html.theme--documenter-dark .docstring>section>a.button.is-outlined.docs-sourcelink:hover,html.theme--documenter-dark .button.is-primary.is-outlined.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-hovered.docs-sourcelink,html.theme--documenter-dark .button.is-primary.is-outlined:focus,html.theme--documenter-dark .docstring>section>a.button.is-outlined.docs-sourcelink:focus,html.theme--documenter-dark .button.is-primary.is-outlined.is-focused,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-focused.docs-sourcelink{background-color:#375a7f;border-color:#375a7f;color:#fff}html.theme--documenter-dark .button.is-primary.is-outlined.is-loading::after,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-loading.docs-sourcelink::after{border-color:transparent transparent #375a7f #375a7f !important}html.theme--documenter-dark .button.is-primary.is-outlined.is-loading:hover::after,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-loading.docs-sourcelink:hover::after,html.theme--documenter-dark .button.is-primary.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-loading.is-hovered.docs-sourcelink::after,html.theme--documenter-dark .button.is-primary.is-outlined.is-loading:focus::after,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-loading.docs-sourcelink:focus::after,html.theme--documenter-dark .button.is-primary.is-outlined.is-loading.is-focused::after,html.theme--documenter-dark .docstring>section>a.button.is-outlined.is-loading.is-focused.docs-sourcelink::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-primary.is-outlined[disabled],html.theme--documenter-dark .docstring>section>a.button.is-outlined.docs-sourcelink[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-primary.is-outlined,fieldset[disabled] html.theme--documenter-dark .docstring>section>a.button.is-outlined.docs-sourcelink{background-color:transparent;border-color:#375a7f;box-shadow:none;color:#375a7f}html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined:hover,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink:hover,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-hovered.docs-sourcelink,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined:focus,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink:focus,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-focused,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-focused.docs-sourcelink{background-color:#fff;color:#375a7f}html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-loading.docs-sourcelink:hover::after,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-loading.is-hovered.docs-sourcelink::after,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-loading.docs-sourcelink:focus::after,html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined.is-loading.is-focused::after,html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.is-loading.is-focused.docs-sourcelink::after{border-color:transparent transparent #375a7f #375a7f !important}html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined[disabled],html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-primary.is-inverted.is-outlined,fieldset[disabled] html.theme--documenter-dark .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-primary.is-light,html.theme--documenter-dark .docstring>section>a.button.is-light.docs-sourcelink{background-color:#f1f5f9;color:#4d7eb2}html.theme--documenter-dark .button.is-primary.is-light:hover,html.theme--documenter-dark .docstring>section>a.button.is-light.docs-sourcelink:hover,html.theme--documenter-dark .button.is-primary.is-light.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-light.is-hovered.docs-sourcelink{background-color:#e8eef5;border-color:transparent;color:#4d7eb2}html.theme--documenter-dark .button.is-primary.is-light:active,html.theme--documenter-dark .docstring>section>a.button.is-light.docs-sourcelink:active,html.theme--documenter-dark .button.is-primary.is-light.is-active,html.theme--documenter-dark .docstring>section>a.button.is-light.is-active.docs-sourcelink{background-color:#dfe8f1;border-color:transparent;color:#4d7eb2}html.theme--documenter-dark .button.is-link{background-color:#1abc9c;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-link:hover,html.theme--documenter-dark .button.is-link.is-hovered{background-color:#18b193;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-link:focus,html.theme--documenter-dark .button.is-link.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-link:focus:not(:active),html.theme--documenter-dark .button.is-link.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(26,188,156,0.25)}html.theme--documenter-dark .button.is-link:active,html.theme--documenter-dark .button.is-link.is-active{background-color:#17a689;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-link[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-link{background-color:#1abc9c;border-color:#1abc9c;box-shadow:none}html.theme--documenter-dark .button.is-link.is-inverted{background-color:#fff;color:#1abc9c}html.theme--documenter-dark .button.is-link.is-inverted:hover,html.theme--documenter-dark .button.is-link.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-link.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-link.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#1abc9c}html.theme--documenter-dark .button.is-link.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-link.is-outlined{background-color:transparent;border-color:#1abc9c;color:#1abc9c}html.theme--documenter-dark .button.is-link.is-outlined:hover,html.theme--documenter-dark .button.is-link.is-outlined.is-hovered,html.theme--documenter-dark .button.is-link.is-outlined:focus,html.theme--documenter-dark .button.is-link.is-outlined.is-focused{background-color:#1abc9c;border-color:#1abc9c;color:#fff}html.theme--documenter-dark .button.is-link.is-outlined.is-loading::after{border-color:transparent transparent #1abc9c #1abc9c !important}html.theme--documenter-dark .button.is-link.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-link.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-link.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-link.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-link.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-link.is-outlined{background-color:transparent;border-color:#1abc9c;box-shadow:none;color:#1abc9c}html.theme--documenter-dark .button.is-link.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-link.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-focused{background-color:#fff;color:#1abc9c}html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-link.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #1abc9c #1abc9c !important}html.theme--documenter-dark .button.is-link.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-link.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-link.is-light{background-color:#edfdf9;color:#15987e}html.theme--documenter-dark .button.is-link.is-light:hover,html.theme--documenter-dark .button.is-link.is-light.is-hovered{background-color:#e2fbf6;border-color:transparent;color:#15987e}html.theme--documenter-dark .button.is-link.is-light:active,html.theme--documenter-dark .button.is-link.is-light.is-active{background-color:#d7f9f3;border-color:transparent;color:#15987e}html.theme--documenter-dark .button.is-info{background-color:#024c7d;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-info:hover,html.theme--documenter-dark .button.is-info.is-hovered{background-color:#024470;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-info:focus,html.theme--documenter-dark .button.is-info.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-info:focus:not(:active),html.theme--documenter-dark .button.is-info.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(2,76,125,0.25)}html.theme--documenter-dark .button.is-info:active,html.theme--documenter-dark .button.is-info.is-active{background-color:#023d64;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-info[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-info{background-color:#024c7d;border-color:#024c7d;box-shadow:none}html.theme--documenter-dark .button.is-info.is-inverted{background-color:#fff;color:#024c7d}html.theme--documenter-dark .button.is-info.is-inverted:hover,html.theme--documenter-dark .button.is-info.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-info.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-info.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#024c7d}html.theme--documenter-dark .button.is-info.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-info.is-outlined{background-color:transparent;border-color:#024c7d;color:#024c7d}html.theme--documenter-dark .button.is-info.is-outlined:hover,html.theme--documenter-dark .button.is-info.is-outlined.is-hovered,html.theme--documenter-dark .button.is-info.is-outlined:focus,html.theme--documenter-dark .button.is-info.is-outlined.is-focused{background-color:#024c7d;border-color:#024c7d;color:#fff}html.theme--documenter-dark .button.is-info.is-outlined.is-loading::after{border-color:transparent transparent #024c7d #024c7d !important}html.theme--documenter-dark .button.is-info.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-info.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-info.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-info.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-info.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-info.is-outlined{background-color:transparent;border-color:#024c7d;box-shadow:none;color:#024c7d}html.theme--documenter-dark .button.is-info.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-info.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-focused{background-color:#fff;color:#024c7d}html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-info.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #024c7d #024c7d !important}html.theme--documenter-dark .button.is-info.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-info.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-info.is-light{background-color:#ebf7ff;color:#0e9dfb}html.theme--documenter-dark .button.is-info.is-light:hover,html.theme--documenter-dark .button.is-info.is-light.is-hovered{background-color:#def2fe;border-color:transparent;color:#0e9dfb}html.theme--documenter-dark .button.is-info.is-light:active,html.theme--documenter-dark .button.is-info.is-light.is-active{background-color:#d2edfe;border-color:transparent;color:#0e9dfb}html.theme--documenter-dark .button.is-success{background-color:#008438;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-success:hover,html.theme--documenter-dark .button.is-success.is-hovered{background-color:#073;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-success:focus,html.theme--documenter-dark .button.is-success.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-success:focus:not(:active),html.theme--documenter-dark .button.is-success.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(0,132,56,0.25)}html.theme--documenter-dark .button.is-success:active,html.theme--documenter-dark .button.is-success.is-active{background-color:#006b2d;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-success[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-success{background-color:#008438;border-color:#008438;box-shadow:none}html.theme--documenter-dark .button.is-success.is-inverted{background-color:#fff;color:#008438}html.theme--documenter-dark .button.is-success.is-inverted:hover,html.theme--documenter-dark .button.is-success.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-success.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-success.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#008438}html.theme--documenter-dark .button.is-success.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-success.is-outlined{background-color:transparent;border-color:#008438;color:#008438}html.theme--documenter-dark .button.is-success.is-outlined:hover,html.theme--documenter-dark .button.is-success.is-outlined.is-hovered,html.theme--documenter-dark .button.is-success.is-outlined:focus,html.theme--documenter-dark .button.is-success.is-outlined.is-focused{background-color:#008438;border-color:#008438;color:#fff}html.theme--documenter-dark .button.is-success.is-outlined.is-loading::after{border-color:transparent transparent #008438 #008438 !important}html.theme--documenter-dark .button.is-success.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-success.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-success.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-success.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-success.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-success.is-outlined{background-color:transparent;border-color:#008438;box-shadow:none;color:#008438}html.theme--documenter-dark .button.is-success.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-success.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-focused{background-color:#fff;color:#008438}html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-success.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #008438 #008438 !important}html.theme--documenter-dark .button.is-success.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-success.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-success.is-light{background-color:#ebfff3;color:#00eb64}html.theme--documenter-dark .button.is-success.is-light:hover,html.theme--documenter-dark .button.is-success.is-light.is-hovered{background-color:#deffec;border-color:transparent;color:#00eb64}html.theme--documenter-dark .button.is-success.is-light:active,html.theme--documenter-dark .button.is-success.is-light.is-active{background-color:#d1ffe5;border-color:transparent;color:#00eb64}html.theme--documenter-dark .button.is-warning{background-color:#ad8100;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-warning:hover,html.theme--documenter-dark .button.is-warning.is-hovered{background-color:#a07700;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-warning:focus,html.theme--documenter-dark .button.is-warning.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-warning:focus:not(:active),html.theme--documenter-dark .button.is-warning.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(173,129,0,0.25)}html.theme--documenter-dark .button.is-warning:active,html.theme--documenter-dark .button.is-warning.is-active{background-color:#946e00;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-warning[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-warning{background-color:#ad8100;border-color:#ad8100;box-shadow:none}html.theme--documenter-dark .button.is-warning.is-inverted{background-color:#fff;color:#ad8100}html.theme--documenter-dark .button.is-warning.is-inverted:hover,html.theme--documenter-dark .button.is-warning.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-warning.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-warning.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#ad8100}html.theme--documenter-dark .button.is-warning.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-warning.is-outlined{background-color:transparent;border-color:#ad8100;color:#ad8100}html.theme--documenter-dark .button.is-warning.is-outlined:hover,html.theme--documenter-dark .button.is-warning.is-outlined.is-hovered,html.theme--documenter-dark .button.is-warning.is-outlined:focus,html.theme--documenter-dark .button.is-warning.is-outlined.is-focused{background-color:#ad8100;border-color:#ad8100;color:#fff}html.theme--documenter-dark .button.is-warning.is-outlined.is-loading::after{border-color:transparent transparent #ad8100 #ad8100 !important}html.theme--documenter-dark .button.is-warning.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-warning.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-warning.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-warning.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-warning.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-warning.is-outlined{background-color:transparent;border-color:#ad8100;box-shadow:none;color:#ad8100}html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-focused{background-color:#fff;color:#ad8100}html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #ad8100 #ad8100 !important}html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-warning.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-warning.is-light{background-color:#fffaeb;color:#d19c00}html.theme--documenter-dark .button.is-warning.is-light:hover,html.theme--documenter-dark .button.is-warning.is-light.is-hovered{background-color:#fff7de;border-color:transparent;color:#d19c00}html.theme--documenter-dark .button.is-warning.is-light:active,html.theme--documenter-dark .button.is-warning.is-light.is-active{background-color:#fff3d1;border-color:transparent;color:#d19c00}html.theme--documenter-dark .button.is-danger{background-color:#9e1b0d;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-danger:hover,html.theme--documenter-dark .button.is-danger.is-hovered{background-color:#92190c;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-danger:focus,html.theme--documenter-dark .button.is-danger.is-focused{border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-danger:focus:not(:active),html.theme--documenter-dark .button.is-danger.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(158,27,13,0.25)}html.theme--documenter-dark .button.is-danger:active,html.theme--documenter-dark .button.is-danger.is-active{background-color:#86170b;border-color:transparent;color:#fff}html.theme--documenter-dark .button.is-danger[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-danger{background-color:#9e1b0d;border-color:#9e1b0d;box-shadow:none}html.theme--documenter-dark .button.is-danger.is-inverted{background-color:#fff;color:#9e1b0d}html.theme--documenter-dark .button.is-danger.is-inverted:hover,html.theme--documenter-dark .button.is-danger.is-inverted.is-hovered{background-color:#f2f2f2}html.theme--documenter-dark .button.is-danger.is-inverted[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-danger.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#9e1b0d}html.theme--documenter-dark .button.is-danger.is-loading::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-danger.is-outlined{background-color:transparent;border-color:#9e1b0d;color:#9e1b0d}html.theme--documenter-dark .button.is-danger.is-outlined:hover,html.theme--documenter-dark .button.is-danger.is-outlined.is-hovered,html.theme--documenter-dark .button.is-danger.is-outlined:focus,html.theme--documenter-dark .button.is-danger.is-outlined.is-focused{background-color:#9e1b0d;border-color:#9e1b0d;color:#fff}html.theme--documenter-dark .button.is-danger.is-outlined.is-loading::after{border-color:transparent transparent #9e1b0d #9e1b0d !important}html.theme--documenter-dark .button.is-danger.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-danger.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-danger.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-danger.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}html.theme--documenter-dark .button.is-danger.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-danger.is-outlined{background-color:transparent;border-color:#9e1b0d;box-shadow:none;color:#9e1b0d}html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined:hover,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-hovered,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined:focus,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-focused{background-color:#fff;color:#9e1b0d}html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-loading:hover::after,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-loading.is-hovered::after,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-loading:focus::after,html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #9e1b0d #9e1b0d !important}html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined[disabled],fieldset[disabled] html.theme--documenter-dark .button.is-danger.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}html.theme--documenter-dark .button.is-danger.is-light{background-color:#fdeeec;color:#ec311d}html.theme--documenter-dark .button.is-danger.is-light:hover,html.theme--documenter-dark .button.is-danger.is-light.is-hovered{background-color:#fce3e0;border-color:transparent;color:#ec311d}html.theme--documenter-dark .button.is-danger.is-light:active,html.theme--documenter-dark .button.is-danger.is-light.is-active{background-color:#fcd8d5;border-color:transparent;color:#ec311d}html.theme--documenter-dark .button.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.button{font-size:.75rem}html.theme--documenter-dark .button.is-small:not(.is-rounded),html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.button:not(.is-rounded){border-radius:3px}html.theme--documenter-dark .button.is-normal{font-size:1rem}html.theme--documenter-dark .button.is-medium{font-size:1.25rem}html.theme--documenter-dark .button.is-large{font-size:1.5rem}html.theme--documenter-dark .button[disabled],fieldset[disabled] html.theme--documenter-dark .button{background-color:#8c9b9d;border-color:#5e6d6f;box-shadow:none;opacity:.5}html.theme--documenter-dark .button.is-fullwidth{display:flex;width:100%}html.theme--documenter-dark .button.is-loading{color:transparent !important;pointer-events:none}html.theme--documenter-dark .button.is-loading::after{position:absolute;left:calc(50% - (1em * 0.5));top:calc(50% - (1em * 0.5));position:absolute !important}html.theme--documenter-dark .button.is-static{background-color:#282f2f;border-color:#5e6d6f;color:#dbdee0;box-shadow:none;pointer-events:none}html.theme--documenter-dark .button.is-rounded,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.button{border-radius:9999px;padding-left:calc(1em + 0.25em);padding-right:calc(1em + 0.25em)}html.theme--documenter-dark .buttons{align-items:center;display:flex;flex-wrap:wrap;justify-content:flex-start}html.theme--documenter-dark .buttons .button{margin-bottom:0.5rem}html.theme--documenter-dark .buttons .button:not(:last-child):not(.is-fullwidth){margin-right:.5rem}html.theme--documenter-dark .buttons:last-child{margin-bottom:-0.5rem}html.theme--documenter-dark .buttons:not(:last-child){margin-bottom:1rem}html.theme--documenter-dark .buttons.are-small .button:not(.is-normal):not(.is-medium):not(.is-large){font-size:.75rem}html.theme--documenter-dark .buttons.are-small .button:not(.is-normal):not(.is-medium):not(.is-large):not(.is-rounded){border-radius:3px}html.theme--documenter-dark .buttons.are-medium .button:not(.is-small):not(.is-normal):not(.is-large){font-size:1.25rem}html.theme--documenter-dark .buttons.are-large .button:not(.is-small):not(.is-normal):not(.is-medium){font-size:1.5rem}html.theme--documenter-dark .buttons.has-addons .button:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}html.theme--documenter-dark .buttons.has-addons .button:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0;margin-right:-1px}html.theme--documenter-dark .buttons.has-addons .button:last-child{margin-right:0}html.theme--documenter-dark .buttons.has-addons .button:hover,html.theme--documenter-dark .buttons.has-addons .button.is-hovered{z-index:2}html.theme--documenter-dark .buttons.has-addons .button:focus,html.theme--documenter-dark .buttons.has-addons .button.is-focused,html.theme--documenter-dark .buttons.has-addons .button:active,html.theme--documenter-dark .buttons.has-addons .button.is-active,html.theme--documenter-dark .buttons.has-addons .button.is-selected{z-index:3}html.theme--documenter-dark .buttons.has-addons .button:focus:hover,html.theme--documenter-dark .buttons.has-addons .button.is-focused:hover,html.theme--documenter-dark .buttons.has-addons .button:active:hover,html.theme--documenter-dark .buttons.has-addons .button.is-active:hover,html.theme--documenter-dark .buttons.has-addons .button.is-selected:hover{z-index:4}html.theme--documenter-dark .buttons.has-addons .button.is-expanded{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .buttons.is-centered{justify-content:center}html.theme--documenter-dark .buttons.is-centered:not(.has-addons) .button:not(.is-fullwidth){margin-left:0.25rem;margin-right:0.25rem}html.theme--documenter-dark .buttons.is-right{justify-content:flex-end}html.theme--documenter-dark .buttons.is-right:not(.has-addons) .button:not(.is-fullwidth){margin-left:0.25rem;margin-right:0.25rem}@media screen and (max-width: 768px){html.theme--documenter-dark .button.is-responsive.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-responsive{font-size:.5625rem}html.theme--documenter-dark .button.is-responsive,html.theme--documenter-dark .button.is-responsive.is-normal{font-size:.65625rem}html.theme--documenter-dark .button.is-responsive.is-medium{font-size:.75rem}html.theme--documenter-dark .button.is-responsive.is-large{font-size:1rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .button.is-responsive.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-responsive{font-size:.65625rem}html.theme--documenter-dark .button.is-responsive,html.theme--documenter-dark .button.is-responsive.is-normal{font-size:.75rem}html.theme--documenter-dark .button.is-responsive.is-medium{font-size:1rem}html.theme--documenter-dark .button.is-responsive.is-large{font-size:1.25rem}}html.theme--documenter-dark .container{flex-grow:1;margin:0 auto;position:relative;width:auto}html.theme--documenter-dark .container.is-fluid{max-width:none !important;padding-left:32px;padding-right:32px;width:100%}@media screen and (min-width: 1056px){html.theme--documenter-dark .container{max-width:992px}}@media screen and (max-width: 1215px){html.theme--documenter-dark .container.is-widescreen:not(.is-max-desktop){max-width:1152px}}@media screen and (max-width: 1407px){html.theme--documenter-dark .container.is-fullhd:not(.is-max-desktop):not(.is-max-widescreen){max-width:1344px}}@media screen and (min-width: 1216px){html.theme--documenter-dark .container:not(.is-max-desktop){max-width:1152px}}@media screen and (min-width: 1408px){html.theme--documenter-dark .container:not(.is-max-desktop):not(.is-max-widescreen){max-width:1344px}}html.theme--documenter-dark .content li+li{margin-top:0.25em}html.theme--documenter-dark .content p:not(:last-child),html.theme--documenter-dark .content dl:not(:last-child),html.theme--documenter-dark .content ol:not(:last-child),html.theme--documenter-dark .content ul:not(:last-child),html.theme--documenter-dark .content blockquote:not(:last-child),html.theme--documenter-dark .content pre:not(:last-child),html.theme--documenter-dark .content table:not(:last-child){margin-bottom:1em}html.theme--documenter-dark .content h1,html.theme--documenter-dark .content h2,html.theme--documenter-dark .content h3,html.theme--documenter-dark .content h4,html.theme--documenter-dark .content h5,html.theme--documenter-dark .content h6{color:#f2f2f2;font-weight:600;line-height:1.125}html.theme--documenter-dark .content h1{font-size:2em;margin-bottom:0.5em}html.theme--documenter-dark .content h1:not(:first-child){margin-top:1em}html.theme--documenter-dark .content h2{font-size:1.75em;margin-bottom:0.5714em}html.theme--documenter-dark .content h2:not(:first-child){margin-top:1.1428em}html.theme--documenter-dark .content h3{font-size:1.5em;margin-bottom:0.6666em}html.theme--documenter-dark .content h3:not(:first-child){margin-top:1.3333em}html.theme--documenter-dark .content h4{font-size:1.25em;margin-bottom:0.8em}html.theme--documenter-dark .content h5{font-size:1.125em;margin-bottom:0.8888em}html.theme--documenter-dark .content h6{font-size:1em;margin-bottom:1em}html.theme--documenter-dark .content blockquote{background-color:#282f2f;border-left:5px solid #5e6d6f;padding:1.25em 1.5em}html.theme--documenter-dark .content ol{list-style-position:outside;margin-left:2em;margin-top:1em}html.theme--documenter-dark .content ol:not([type]){list-style-type:decimal}html.theme--documenter-dark .content ol.is-lower-alpha:not([type]){list-style-type:lower-alpha}html.theme--documenter-dark .content ol.is-lower-roman:not([type]){list-style-type:lower-roman}html.theme--documenter-dark .content ol.is-upper-alpha:not([type]){list-style-type:upper-alpha}html.theme--documenter-dark .content ol.is-upper-roman:not([type]){list-style-type:upper-roman}html.theme--documenter-dark .content ul{list-style:disc outside;margin-left:2em;margin-top:1em}html.theme--documenter-dark .content ul ul{list-style-type:circle;margin-top:0.5em}html.theme--documenter-dark .content ul ul ul{list-style-type:square}html.theme--documenter-dark .content dd{margin-left:2em}html.theme--documenter-dark .content figure{margin-left:2em;margin-right:2em;text-align:center}html.theme--documenter-dark .content figure:not(:first-child){margin-top:2em}html.theme--documenter-dark .content figure:not(:last-child){margin-bottom:2em}html.theme--documenter-dark .content figure img{display:inline-block}html.theme--documenter-dark .content figure figcaption{font-style:italic}html.theme--documenter-dark .content pre{-webkit-overflow-scrolling:touch;overflow-x:auto;padding:0;white-space:pre;word-wrap:normal}html.theme--documenter-dark .content sup,html.theme--documenter-dark .content sub{font-size:75%}html.theme--documenter-dark .content table{width:100%}html.theme--documenter-dark .content table td,html.theme--documenter-dark .content table th{border:1px solid #5e6d6f;border-width:0 0 1px;padding:0.5em 0.75em;vertical-align:top}html.theme--documenter-dark .content table th{color:#f2f2f2}html.theme--documenter-dark .content table th:not([align]){text-align:inherit}html.theme--documenter-dark .content table thead td,html.theme--documenter-dark .content table thead th{border-width:0 0 2px;color:#f2f2f2}html.theme--documenter-dark .content table tfoot td,html.theme--documenter-dark .content table tfoot th{border-width:2px 0 0;color:#f2f2f2}html.theme--documenter-dark .content table tbody tr:last-child td,html.theme--documenter-dark .content table tbody tr:last-child th{border-bottom-width:0}html.theme--documenter-dark .content .tabs li+li{margin-top:0}html.theme--documenter-dark .content.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.content{font-size:.75rem}html.theme--documenter-dark .content.is-normal{font-size:1rem}html.theme--documenter-dark .content.is-medium{font-size:1.25rem}html.theme--documenter-dark .content.is-large{font-size:1.5rem}html.theme--documenter-dark .icon{align-items:center;display:inline-flex;justify-content:center;height:1.5rem;width:1.5rem}html.theme--documenter-dark .icon.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.icon{height:1rem;width:1rem}html.theme--documenter-dark .icon.is-medium{height:2rem;width:2rem}html.theme--documenter-dark .icon.is-large{height:3rem;width:3rem}html.theme--documenter-dark .icon-text{align-items:flex-start;color:inherit;display:inline-flex;flex-wrap:wrap;line-height:1.5rem;vertical-align:top}html.theme--documenter-dark .icon-text .icon{flex-grow:0;flex-shrink:0}html.theme--documenter-dark .icon-text .icon:not(:last-child){margin-right:.25em}html.theme--documenter-dark .icon-text .icon:not(:first-child){margin-left:.25em}html.theme--documenter-dark div.icon-text{display:flex}html.theme--documenter-dark .image,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img{display:block;position:relative}html.theme--documenter-dark .image img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img img{display:block;height:auto;width:100%}html.theme--documenter-dark .image img.is-rounded,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img img.is-rounded{border-radius:9999px}html.theme--documenter-dark .image.is-fullwidth,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-fullwidth{width:100%}html.theme--documenter-dark .image.is-square img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-square img,html.theme--documenter-dark .image.is-square .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-square .has-ratio,html.theme--documenter-dark .image.is-1by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by1 img,html.theme--documenter-dark .image.is-1by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by1 .has-ratio,html.theme--documenter-dark .image.is-5by4 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by4 img,html.theme--documenter-dark .image.is-5by4 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by4 .has-ratio,html.theme--documenter-dark .image.is-4by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by3 img,html.theme--documenter-dark .image.is-4by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by3 .has-ratio,html.theme--documenter-dark .image.is-3by2 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by2 img,html.theme--documenter-dark .image.is-3by2 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by2 .has-ratio,html.theme--documenter-dark .image.is-5by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by3 img,html.theme--documenter-dark .image.is-5by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by3 .has-ratio,html.theme--documenter-dark .image.is-16by9 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16by9 img,html.theme--documenter-dark .image.is-16by9 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16by9 .has-ratio,html.theme--documenter-dark .image.is-2by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by1 img,html.theme--documenter-dark .image.is-2by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by1 .has-ratio,html.theme--documenter-dark .image.is-3by1 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by1 img,html.theme--documenter-dark .image.is-3by1 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by1 .has-ratio,html.theme--documenter-dark .image.is-4by5 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by5 img,html.theme--documenter-dark .image.is-4by5 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by5 .has-ratio,html.theme--documenter-dark .image.is-3by4 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by4 img,html.theme--documenter-dark .image.is-3by4 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by4 .has-ratio,html.theme--documenter-dark .image.is-2by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by3 img,html.theme--documenter-dark .image.is-2by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by3 .has-ratio,html.theme--documenter-dark .image.is-3by5 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by5 img,html.theme--documenter-dark .image.is-3by5 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by5 .has-ratio,html.theme--documenter-dark .image.is-9by16 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-9by16 img,html.theme--documenter-dark .image.is-9by16 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-9by16 .has-ratio,html.theme--documenter-dark .image.is-1by2 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by2 img,html.theme--documenter-dark .image.is-1by2 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by2 .has-ratio,html.theme--documenter-dark .image.is-1by3 img,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by3 img,html.theme--documenter-dark .image.is-1by3 .has-ratio,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by3 .has-ratio{height:100%;width:100%}html.theme--documenter-dark .image.is-square,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-square,html.theme--documenter-dark .image.is-1by1,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by1{padding-top:100%}html.theme--documenter-dark .image.is-5by4,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by4{padding-top:80%}html.theme--documenter-dark .image.is-4by3,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by3{padding-top:75%}html.theme--documenter-dark .image.is-3by2,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by2{padding-top:66.6666%}html.theme--documenter-dark .image.is-5by3,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-5by3{padding-top:60%}html.theme--documenter-dark .image.is-16by9,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16by9{padding-top:56.25%}html.theme--documenter-dark .image.is-2by1,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by1{padding-top:50%}html.theme--documenter-dark .image.is-3by1,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by1{padding-top:33.3333%}html.theme--documenter-dark .image.is-4by5,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-4by5{padding-top:125%}html.theme--documenter-dark .image.is-3by4,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by4{padding-top:133.3333%}html.theme--documenter-dark .image.is-2by3,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-2by3{padding-top:150%}html.theme--documenter-dark .image.is-3by5,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-3by5{padding-top:166.6666%}html.theme--documenter-dark .image.is-9by16,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-9by16{padding-top:177.7777%}html.theme--documenter-dark .image.is-1by2,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by2{padding-top:200%}html.theme--documenter-dark .image.is-1by3,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-1by3{padding-top:300%}html.theme--documenter-dark .image.is-16x16,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-16x16{height:16px;width:16px}html.theme--documenter-dark .image.is-24x24,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-24x24{height:24px;width:24px}html.theme--documenter-dark .image.is-32x32,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-32x32{height:32px;width:32px}html.theme--documenter-dark .image.is-48x48,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-48x48{height:48px;width:48px}html.theme--documenter-dark .image.is-64x64,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-64x64{height:64px;width:64px}html.theme--documenter-dark .image.is-96x96,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-96x96{height:96px;width:96px}html.theme--documenter-dark .image.is-128x128,html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img.is-128x128{height:128px;width:128px}html.theme--documenter-dark .notification{background-color:#282f2f;border-radius:.4em;position:relative;padding:1.25rem 2.5rem 1.25rem 1.5rem}html.theme--documenter-dark .notification a:not(.button):not(.dropdown-item){color:currentColor;text-decoration:underline}html.theme--documenter-dark .notification strong{color:currentColor}html.theme--documenter-dark .notification code,html.theme--documenter-dark .notification pre{background:#fff}html.theme--documenter-dark .notification pre code{background:transparent}html.theme--documenter-dark .notification>.delete{right:.5rem;position:absolute;top:0.5rem}html.theme--documenter-dark .notification .title,html.theme--documenter-dark .notification .subtitle,html.theme--documenter-dark .notification .content{color:currentColor}html.theme--documenter-dark .notification.is-white{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .notification.is-black{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .notification.is-light{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .notification.is-dark,html.theme--documenter-dark .content kbd.notification{background-color:#282f2f;color:#fff}html.theme--documenter-dark .notification.is-primary,html.theme--documenter-dark .docstring>section>a.notification.docs-sourcelink{background-color:#375a7f;color:#fff}html.theme--documenter-dark .notification.is-primary.is-light,html.theme--documenter-dark .docstring>section>a.notification.is-light.docs-sourcelink{background-color:#f1f5f9;color:#4d7eb2}html.theme--documenter-dark .notification.is-link{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .notification.is-link.is-light{background-color:#edfdf9;color:#15987e}html.theme--documenter-dark .notification.is-info{background-color:#024c7d;color:#fff}html.theme--documenter-dark .notification.is-info.is-light{background-color:#ebf7ff;color:#0e9dfb}html.theme--documenter-dark .notification.is-success{background-color:#008438;color:#fff}html.theme--documenter-dark .notification.is-success.is-light{background-color:#ebfff3;color:#00eb64}html.theme--documenter-dark .notification.is-warning{background-color:#ad8100;color:#fff}html.theme--documenter-dark .notification.is-warning.is-light{background-color:#fffaeb;color:#d19c00}html.theme--documenter-dark .notification.is-danger{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .notification.is-danger.is-light{background-color:#fdeeec;color:#ec311d}html.theme--documenter-dark .progress{-moz-appearance:none;-webkit-appearance:none;border:none;border-radius:9999px;display:block;height:1rem;overflow:hidden;padding:0;width:100%}html.theme--documenter-dark .progress::-webkit-progress-bar{background-color:#343c3d}html.theme--documenter-dark .progress::-webkit-progress-value{background-color:#dbdee0}html.theme--documenter-dark .progress::-moz-progress-bar{background-color:#dbdee0}html.theme--documenter-dark .progress::-ms-fill{background-color:#dbdee0;border:none}html.theme--documenter-dark .progress.is-white::-webkit-progress-value{background-color:#fff}html.theme--documenter-dark .progress.is-white::-moz-progress-bar{background-color:#fff}html.theme--documenter-dark .progress.is-white::-ms-fill{background-color:#fff}html.theme--documenter-dark .progress.is-white:indeterminate{background-image:linear-gradient(to right, #fff 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-black::-webkit-progress-value{background-color:#0a0a0a}html.theme--documenter-dark .progress.is-black::-moz-progress-bar{background-color:#0a0a0a}html.theme--documenter-dark .progress.is-black::-ms-fill{background-color:#0a0a0a}html.theme--documenter-dark .progress.is-black:indeterminate{background-image:linear-gradient(to right, #0a0a0a 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-light::-webkit-progress-value{background-color:#ecf0f1}html.theme--documenter-dark .progress.is-light::-moz-progress-bar{background-color:#ecf0f1}html.theme--documenter-dark .progress.is-light::-ms-fill{background-color:#ecf0f1}html.theme--documenter-dark .progress.is-light:indeterminate{background-image:linear-gradient(to right, #ecf0f1 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-dark::-webkit-progress-value,html.theme--documenter-dark .content kbd.progress::-webkit-progress-value{background-color:#282f2f}html.theme--documenter-dark .progress.is-dark::-moz-progress-bar,html.theme--documenter-dark .content kbd.progress::-moz-progress-bar{background-color:#282f2f}html.theme--documenter-dark .progress.is-dark::-ms-fill,html.theme--documenter-dark .content kbd.progress::-ms-fill{background-color:#282f2f}html.theme--documenter-dark .progress.is-dark:indeterminate,html.theme--documenter-dark .content kbd.progress:indeterminate{background-image:linear-gradient(to right, #282f2f 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-primary::-webkit-progress-value,html.theme--documenter-dark .docstring>section>a.progress.docs-sourcelink::-webkit-progress-value{background-color:#375a7f}html.theme--documenter-dark .progress.is-primary::-moz-progress-bar,html.theme--documenter-dark .docstring>section>a.progress.docs-sourcelink::-moz-progress-bar{background-color:#375a7f}html.theme--documenter-dark .progress.is-primary::-ms-fill,html.theme--documenter-dark .docstring>section>a.progress.docs-sourcelink::-ms-fill{background-color:#375a7f}html.theme--documenter-dark .progress.is-primary:indeterminate,html.theme--documenter-dark .docstring>section>a.progress.docs-sourcelink:indeterminate{background-image:linear-gradient(to right, #375a7f 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-link::-webkit-progress-value{background-color:#1abc9c}html.theme--documenter-dark .progress.is-link::-moz-progress-bar{background-color:#1abc9c}html.theme--documenter-dark .progress.is-link::-ms-fill{background-color:#1abc9c}html.theme--documenter-dark .progress.is-link:indeterminate{background-image:linear-gradient(to right, #1abc9c 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-info::-webkit-progress-value{background-color:#024c7d}html.theme--documenter-dark .progress.is-info::-moz-progress-bar{background-color:#024c7d}html.theme--documenter-dark .progress.is-info::-ms-fill{background-color:#024c7d}html.theme--documenter-dark .progress.is-info:indeterminate{background-image:linear-gradient(to right, #024c7d 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-success::-webkit-progress-value{background-color:#008438}html.theme--documenter-dark .progress.is-success::-moz-progress-bar{background-color:#008438}html.theme--documenter-dark .progress.is-success::-ms-fill{background-color:#008438}html.theme--documenter-dark .progress.is-success:indeterminate{background-image:linear-gradient(to right, #008438 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-warning::-webkit-progress-value{background-color:#ad8100}html.theme--documenter-dark .progress.is-warning::-moz-progress-bar{background-color:#ad8100}html.theme--documenter-dark .progress.is-warning::-ms-fill{background-color:#ad8100}html.theme--documenter-dark .progress.is-warning:indeterminate{background-image:linear-gradient(to right, #ad8100 30%, #343c3d 30%)}html.theme--documenter-dark .progress.is-danger::-webkit-progress-value{background-color:#9e1b0d}html.theme--documenter-dark .progress.is-danger::-moz-progress-bar{background-color:#9e1b0d}html.theme--documenter-dark .progress.is-danger::-ms-fill{background-color:#9e1b0d}html.theme--documenter-dark .progress.is-danger:indeterminate{background-image:linear-gradient(to right, #9e1b0d 30%, #343c3d 30%)}html.theme--documenter-dark .progress:indeterminate{animation-duration:1.5s;animation-iteration-count:infinite;animation-name:moveIndeterminate;animation-timing-function:linear;background-color:#343c3d;background-image:linear-gradient(to right, #fff 30%, #343c3d 30%);background-position:top left;background-repeat:no-repeat;background-size:150% 150%}html.theme--documenter-dark .progress:indeterminate::-webkit-progress-bar{background-color:transparent}html.theme--documenter-dark .progress:indeterminate::-moz-progress-bar{background-color:transparent}html.theme--documenter-dark .progress:indeterminate::-ms-fill{animation-name:none}html.theme--documenter-dark .progress.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.progress{height:.75rem}html.theme--documenter-dark .progress.is-medium{height:1.25rem}html.theme--documenter-dark .progress.is-large{height:1.5rem}@keyframes moveIndeterminate{from{background-position:200% 0}to{background-position:-200% 0}}html.theme--documenter-dark .table{background-color:#343c3d;color:#fff}html.theme--documenter-dark .table td,html.theme--documenter-dark .table th{border:1px solid #5e6d6f;border-width:0 0 1px;padding:0.5em 0.75em;vertical-align:top}html.theme--documenter-dark .table td.is-white,html.theme--documenter-dark .table th.is-white{background-color:#fff;border-color:#fff;color:#0a0a0a}html.theme--documenter-dark .table td.is-black,html.theme--documenter-dark .table th.is-black{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}html.theme--documenter-dark .table td.is-light,html.theme--documenter-dark .table th.is-light{background-color:#ecf0f1;border-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .table td.is-dark,html.theme--documenter-dark .table th.is-dark{background-color:#282f2f;border-color:#282f2f;color:#fff}html.theme--documenter-dark .table td.is-primary,html.theme--documenter-dark .table th.is-primary{background-color:#375a7f;border-color:#375a7f;color:#fff}html.theme--documenter-dark .table td.is-link,html.theme--documenter-dark .table th.is-link{background-color:#1abc9c;border-color:#1abc9c;color:#fff}html.theme--documenter-dark .table td.is-info,html.theme--documenter-dark .table th.is-info{background-color:#024c7d;border-color:#024c7d;color:#fff}html.theme--documenter-dark .table td.is-success,html.theme--documenter-dark .table th.is-success{background-color:#008438;border-color:#008438;color:#fff}html.theme--documenter-dark .table td.is-warning,html.theme--documenter-dark .table th.is-warning{background-color:#ad8100;border-color:#ad8100;color:#fff}html.theme--documenter-dark .table td.is-danger,html.theme--documenter-dark .table th.is-danger{background-color:#9e1b0d;border-color:#9e1b0d;color:#fff}html.theme--documenter-dark .table td.is-narrow,html.theme--documenter-dark .table th.is-narrow{white-space:nowrap;width:1%}html.theme--documenter-dark .table td.is-selected,html.theme--documenter-dark .table th.is-selected{background-color:#375a7f;color:#fff}html.theme--documenter-dark .table td.is-selected a,html.theme--documenter-dark .table td.is-selected strong,html.theme--documenter-dark .table th.is-selected a,html.theme--documenter-dark .table th.is-selected strong{color:currentColor}html.theme--documenter-dark .table td.is-vcentered,html.theme--documenter-dark .table th.is-vcentered{vertical-align:middle}html.theme--documenter-dark .table th{color:#f2f2f2}html.theme--documenter-dark .table th:not([align]){text-align:left}html.theme--documenter-dark .table tr.is-selected{background-color:#375a7f;color:#fff}html.theme--documenter-dark .table tr.is-selected a,html.theme--documenter-dark .table tr.is-selected strong{color:currentColor}html.theme--documenter-dark .table tr.is-selected td,html.theme--documenter-dark .table tr.is-selected th{border-color:#fff;color:currentColor}html.theme--documenter-dark .table thead{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .table thead td,html.theme--documenter-dark .table thead th{border-width:0 0 2px;color:#f2f2f2}html.theme--documenter-dark .table tfoot{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .table tfoot td,html.theme--documenter-dark .table tfoot th{border-width:2px 0 0;color:#f2f2f2}html.theme--documenter-dark .table tbody{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .table tbody tr:last-child td,html.theme--documenter-dark .table tbody tr:last-child th{border-bottom-width:0}html.theme--documenter-dark .table.is-bordered td,html.theme--documenter-dark .table.is-bordered th{border-width:1px}html.theme--documenter-dark .table.is-bordered tr:last-child td,html.theme--documenter-dark .table.is-bordered tr:last-child th{border-bottom-width:1px}html.theme--documenter-dark .table.is-fullwidth{width:100%}html.theme--documenter-dark .table.is-hoverable tbody tr:not(.is-selected):hover{background-color:#282f2f}html.theme--documenter-dark .table.is-hoverable.is-striped tbody tr:not(.is-selected):hover{background-color:#282f2f}html.theme--documenter-dark .table.is-hoverable.is-striped tbody tr:not(.is-selected):hover:nth-child(even){background-color:#2d3435}html.theme--documenter-dark .table.is-narrow td,html.theme--documenter-dark .table.is-narrow th{padding:0.25em 0.5em}html.theme--documenter-dark .table.is-striped tbody tr:not(.is-selected):nth-child(even){background-color:#282f2f}html.theme--documenter-dark .table-container{-webkit-overflow-scrolling:touch;overflow:auto;overflow-y:hidden;max-width:100%}html.theme--documenter-dark .tags{align-items:center;display:flex;flex-wrap:wrap;justify-content:flex-start}html.theme--documenter-dark .tags .tag,html.theme--documenter-dark .tags .content kbd,html.theme--documenter-dark .content .tags kbd,html.theme--documenter-dark .tags .docstring>section>a.docs-sourcelink{margin-bottom:0.5rem}html.theme--documenter-dark .tags .tag:not(:last-child),html.theme--documenter-dark .tags .content kbd:not(:last-child),html.theme--documenter-dark .content .tags kbd:not(:last-child),html.theme--documenter-dark .tags .docstring>section>a.docs-sourcelink:not(:last-child){margin-right:.5rem}html.theme--documenter-dark .tags:last-child{margin-bottom:-0.5rem}html.theme--documenter-dark .tags:not(:last-child){margin-bottom:1rem}html.theme--documenter-dark .tags.are-medium .tag:not(.is-normal):not(.is-large),html.theme--documenter-dark .tags.are-medium .content kbd:not(.is-normal):not(.is-large),html.theme--documenter-dark .content .tags.are-medium kbd:not(.is-normal):not(.is-large),html.theme--documenter-dark .tags.are-medium .docstring>section>a.docs-sourcelink:not(.is-normal):not(.is-large){font-size:1rem}html.theme--documenter-dark .tags.are-large .tag:not(.is-normal):not(.is-medium),html.theme--documenter-dark .tags.are-large .content kbd:not(.is-normal):not(.is-medium),html.theme--documenter-dark .content .tags.are-large kbd:not(.is-normal):not(.is-medium),html.theme--documenter-dark .tags.are-large .docstring>section>a.docs-sourcelink:not(.is-normal):not(.is-medium){font-size:1.25rem}html.theme--documenter-dark .tags.is-centered{justify-content:center}html.theme--documenter-dark .tags.is-centered .tag,html.theme--documenter-dark .tags.is-centered .content kbd,html.theme--documenter-dark .content .tags.is-centered kbd,html.theme--documenter-dark .tags.is-centered .docstring>section>a.docs-sourcelink{margin-right:0.25rem;margin-left:0.25rem}html.theme--documenter-dark .tags.is-right{justify-content:flex-end}html.theme--documenter-dark .tags.is-right .tag:not(:first-child),html.theme--documenter-dark .tags.is-right .content kbd:not(:first-child),html.theme--documenter-dark .content .tags.is-right kbd:not(:first-child),html.theme--documenter-dark .tags.is-right .docstring>section>a.docs-sourcelink:not(:first-child){margin-left:0.5rem}html.theme--documenter-dark .tags.is-right .tag:not(:last-child),html.theme--documenter-dark .tags.is-right .content kbd:not(:last-child),html.theme--documenter-dark .content .tags.is-right kbd:not(:last-child),html.theme--documenter-dark .tags.is-right .docstring>section>a.docs-sourcelink:not(:last-child){margin-right:0}html.theme--documenter-dark .tags.has-addons .tag,html.theme--documenter-dark .tags.has-addons .content kbd,html.theme--documenter-dark .content .tags.has-addons kbd,html.theme--documenter-dark .tags.has-addons .docstring>section>a.docs-sourcelink{margin-right:0}html.theme--documenter-dark .tags.has-addons .tag:not(:first-child),html.theme--documenter-dark .tags.has-addons .content kbd:not(:first-child),html.theme--documenter-dark .content .tags.has-addons kbd:not(:first-child),html.theme--documenter-dark .tags.has-addons .docstring>section>a.docs-sourcelink:not(:first-child){margin-left:0;border-top-left-radius:0;border-bottom-left-radius:0}html.theme--documenter-dark .tags.has-addons .tag:not(:last-child),html.theme--documenter-dark .tags.has-addons .content kbd:not(:last-child),html.theme--documenter-dark .content .tags.has-addons kbd:not(:last-child),html.theme--documenter-dark .tags.has-addons .docstring>section>a.docs-sourcelink:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}html.theme--documenter-dark .tag:not(body),html.theme--documenter-dark .content kbd:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body){align-items:center;background-color:#282f2f;border-radius:.4em;color:#fff;display:inline-flex;font-size:.75rem;height:2em;justify-content:center;line-height:1.5;padding-left:0.75em;padding-right:0.75em;white-space:nowrap}html.theme--documenter-dark .tag:not(body) .delete,html.theme--documenter-dark .content kbd:not(body) .delete,html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body) .delete{margin-left:.25rem;margin-right:-.375rem}html.theme--documenter-dark .tag.is-white:not(body),html.theme--documenter-dark .content kbd.is-white:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-white:not(body){background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .tag.is-black:not(body),html.theme--documenter-dark .content kbd.is-black:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-black:not(body){background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .tag.is-light:not(body),html.theme--documenter-dark .content kbd.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-light:not(body){background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .tag.is-dark:not(body),html.theme--documenter-dark .content kbd:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-dark:not(body),html.theme--documenter-dark .content .docstring>section>kbd:not(body){background-color:#282f2f;color:#fff}html.theme--documenter-dark .tag.is-primary:not(body),html.theme--documenter-dark .content kbd.is-primary:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body){background-color:#375a7f;color:#fff}html.theme--documenter-dark .tag.is-primary.is-light:not(body),html.theme--documenter-dark .content kbd.is-primary.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-light:not(body){background-color:#f1f5f9;color:#4d7eb2}html.theme--documenter-dark .tag.is-link:not(body),html.theme--documenter-dark .content kbd.is-link:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-link:not(body){background-color:#1abc9c;color:#fff}html.theme--documenter-dark .tag.is-link.is-light:not(body),html.theme--documenter-dark .content kbd.is-link.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-link.is-light:not(body){background-color:#edfdf9;color:#15987e}html.theme--documenter-dark .tag.is-info:not(body),html.theme--documenter-dark .content kbd.is-info:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-info:not(body){background-color:#024c7d;color:#fff}html.theme--documenter-dark .tag.is-info.is-light:not(body),html.theme--documenter-dark .content kbd.is-info.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-info.is-light:not(body){background-color:#ebf7ff;color:#0e9dfb}html.theme--documenter-dark .tag.is-success:not(body),html.theme--documenter-dark .content kbd.is-success:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-success:not(body){background-color:#008438;color:#fff}html.theme--documenter-dark .tag.is-success.is-light:not(body),html.theme--documenter-dark .content kbd.is-success.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-success.is-light:not(body){background-color:#ebfff3;color:#00eb64}html.theme--documenter-dark .tag.is-warning:not(body),html.theme--documenter-dark .content kbd.is-warning:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-warning:not(body){background-color:#ad8100;color:#fff}html.theme--documenter-dark .tag.is-warning.is-light:not(body),html.theme--documenter-dark .content kbd.is-warning.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-warning.is-light:not(body){background-color:#fffaeb;color:#d19c00}html.theme--documenter-dark .tag.is-danger:not(body),html.theme--documenter-dark .content kbd.is-danger:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-danger:not(body){background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .tag.is-danger.is-light:not(body),html.theme--documenter-dark .content kbd.is-danger.is-light:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-danger.is-light:not(body){background-color:#fdeeec;color:#ec311d}html.theme--documenter-dark .tag.is-normal:not(body),html.theme--documenter-dark .content kbd.is-normal:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-normal:not(body){font-size:.75rem}html.theme--documenter-dark .tag.is-medium:not(body),html.theme--documenter-dark .content kbd.is-medium:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-medium:not(body){font-size:1rem}html.theme--documenter-dark .tag.is-large:not(body),html.theme--documenter-dark .content kbd.is-large:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-large:not(body){font-size:1.25rem}html.theme--documenter-dark .tag:not(body) .icon:first-child:not(:last-child),html.theme--documenter-dark .content kbd:not(body) .icon:first-child:not(:last-child),html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body) .icon:first-child:not(:last-child){margin-left:-.375em;margin-right:.1875em}html.theme--documenter-dark .tag:not(body) .icon:last-child:not(:first-child),html.theme--documenter-dark .content kbd:not(body) .icon:last-child:not(:first-child),html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body) .icon:last-child:not(:first-child){margin-left:.1875em;margin-right:-.375em}html.theme--documenter-dark .tag:not(body) .icon:first-child:last-child,html.theme--documenter-dark .content kbd:not(body) .icon:first-child:last-child,html.theme--documenter-dark .docstring>section>a.docs-sourcelink:not(body) .icon:first-child:last-child{margin-left:-.375em;margin-right:-.375em}html.theme--documenter-dark .tag.is-delete:not(body),html.theme--documenter-dark .content kbd.is-delete:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body){margin-left:1px;padding:0;position:relative;width:2em}html.theme--documenter-dark .tag.is-delete:not(body)::before,html.theme--documenter-dark .content kbd.is-delete:not(body)::before,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body)::before,html.theme--documenter-dark .tag.is-delete:not(body)::after,html.theme--documenter-dark .content kbd.is-delete:not(body)::after,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body)::after{background-color:currentColor;content:"";display:block;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%) rotate(45deg);transform-origin:center center}html.theme--documenter-dark .tag.is-delete:not(body)::before,html.theme--documenter-dark .content kbd.is-delete:not(body)::before,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body)::before{height:1px;width:50%}html.theme--documenter-dark .tag.is-delete:not(body)::after,html.theme--documenter-dark .content kbd.is-delete:not(body)::after,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body)::after{height:50%;width:1px}html.theme--documenter-dark .tag.is-delete:not(body):hover,html.theme--documenter-dark .content kbd.is-delete:not(body):hover,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body):hover,html.theme--documenter-dark .tag.is-delete:not(body):focus,html.theme--documenter-dark .content kbd.is-delete:not(body):focus,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body):focus{background-color:#1d2122}html.theme--documenter-dark .tag.is-delete:not(body):active,html.theme--documenter-dark .content kbd.is-delete:not(body):active,html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-delete:not(body):active{background-color:#111414}html.theme--documenter-dark .tag.is-rounded:not(body),html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:not(body),html.theme--documenter-dark .content kbd.is-rounded:not(body),html.theme--documenter-dark #documenter .docs-sidebar .content form.docs-search>input:not(body),html.theme--documenter-dark .docstring>section>a.docs-sourcelink.is-rounded:not(body){border-radius:9999px}html.theme--documenter-dark a.tag:hover,html.theme--documenter-dark .docstring>section>a.docs-sourcelink:hover{text-decoration:underline}html.theme--documenter-dark .title,html.theme--documenter-dark .subtitle{word-break:break-word}html.theme--documenter-dark .title em,html.theme--documenter-dark .title span,html.theme--documenter-dark .subtitle em,html.theme--documenter-dark .subtitle span{font-weight:inherit}html.theme--documenter-dark .title sub,html.theme--documenter-dark .subtitle sub{font-size:.75em}html.theme--documenter-dark .title sup,html.theme--documenter-dark .subtitle sup{font-size:.75em}html.theme--documenter-dark .title .tag,html.theme--documenter-dark .title .content kbd,html.theme--documenter-dark .content .title kbd,html.theme--documenter-dark .title .docstring>section>a.docs-sourcelink,html.theme--documenter-dark .subtitle .tag,html.theme--documenter-dark .subtitle .content kbd,html.theme--documenter-dark .content .subtitle kbd,html.theme--documenter-dark .subtitle .docstring>section>a.docs-sourcelink{vertical-align:middle}html.theme--documenter-dark .title{color:#fff;font-size:2rem;font-weight:500;line-height:1.125}html.theme--documenter-dark .title strong{color:inherit;font-weight:inherit}html.theme--documenter-dark .title:not(.is-spaced)+.subtitle{margin-top:-1.25rem}html.theme--documenter-dark .title.is-1{font-size:3rem}html.theme--documenter-dark .title.is-2{font-size:2.5rem}html.theme--documenter-dark .title.is-3{font-size:2rem}html.theme--documenter-dark .title.is-4{font-size:1.5rem}html.theme--documenter-dark .title.is-5{font-size:1.25rem}html.theme--documenter-dark .title.is-6{font-size:1rem}html.theme--documenter-dark .title.is-7{font-size:.75rem}html.theme--documenter-dark .subtitle{color:#8c9b9d;font-size:1.25rem;font-weight:400;line-height:1.25}html.theme--documenter-dark .subtitle strong{color:#8c9b9d;font-weight:600}html.theme--documenter-dark .subtitle:not(.is-spaced)+.title{margin-top:-1.25rem}html.theme--documenter-dark .subtitle.is-1{font-size:3rem}html.theme--documenter-dark .subtitle.is-2{font-size:2.5rem}html.theme--documenter-dark .subtitle.is-3{font-size:2rem}html.theme--documenter-dark .subtitle.is-4{font-size:1.5rem}html.theme--documenter-dark .subtitle.is-5{font-size:1.25rem}html.theme--documenter-dark .subtitle.is-6{font-size:1rem}html.theme--documenter-dark .subtitle.is-7{font-size:.75rem}html.theme--documenter-dark .heading{display:block;font-size:11px;letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}html.theme--documenter-dark .number{align-items:center;background-color:#282f2f;border-radius:9999px;display:inline-flex;font-size:1.25rem;height:2em;justify-content:center;margin-right:1.5rem;min-width:2.5em;padding:0.25rem 0.5rem;text-align:center;vertical-align:top}html.theme--documenter-dark .select select,html.theme--documenter-dark .textarea,html.theme--documenter-dark .input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{background-color:#1f2424;border-color:#5e6d6f;border-radius:.4em;color:#dbdee0}html.theme--documenter-dark .select select::-moz-placeholder,html.theme--documenter-dark .textarea::-moz-placeholder,html.theme--documenter-dark .input::-moz-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input::-moz-placeholder{color:#868c98}html.theme--documenter-dark .select select::-webkit-input-placeholder,html.theme--documenter-dark .textarea::-webkit-input-placeholder,html.theme--documenter-dark .input::-webkit-input-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input::-webkit-input-placeholder{color:#868c98}html.theme--documenter-dark .select select:-moz-placeholder,html.theme--documenter-dark .textarea:-moz-placeholder,html.theme--documenter-dark .input:-moz-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:-moz-placeholder{color:#868c98}html.theme--documenter-dark .select select:-ms-input-placeholder,html.theme--documenter-dark .textarea:-ms-input-placeholder,html.theme--documenter-dark .input:-ms-input-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:-ms-input-placeholder{color:#868c98}html.theme--documenter-dark .select select:hover,html.theme--documenter-dark .textarea:hover,html.theme--documenter-dark .input:hover,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:hover,html.theme--documenter-dark .select select.is-hovered,html.theme--documenter-dark .is-hovered.textarea,html.theme--documenter-dark .is-hovered.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-hovered{border-color:#8c9b9d}html.theme--documenter-dark .select select:focus,html.theme--documenter-dark .textarea:focus,html.theme--documenter-dark .input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:focus,html.theme--documenter-dark .select select.is-focused,html.theme--documenter-dark .is-focused.textarea,html.theme--documenter-dark .is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .select select:active,html.theme--documenter-dark .textarea:active,html.theme--documenter-dark .input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:active,html.theme--documenter-dark .select select.is-active,html.theme--documenter-dark .is-active.textarea,html.theme--documenter-dark .is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{border-color:#1abc9c;box-shadow:0 0 0 0.125em rgba(26,188,156,0.25)}html.theme--documenter-dark .select select[disabled],html.theme--documenter-dark .textarea[disabled],html.theme--documenter-dark .input[disabled],html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled],fieldset[disabled] html.theme--documenter-dark .select select,fieldset[disabled] html.theme--documenter-dark .textarea,fieldset[disabled] html.theme--documenter-dark .input,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{background-color:#8c9b9d;border-color:#282f2f;box-shadow:none;color:#fff}html.theme--documenter-dark .select select[disabled]::-moz-placeholder,html.theme--documenter-dark .textarea[disabled]::-moz-placeholder,html.theme--documenter-dark .input[disabled]::-moz-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled]::-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .select select::-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .textarea::-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .input::-moz-placeholder,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input::-moz-placeholder{color:rgba(255,255,255,0.3)}html.theme--documenter-dark .select select[disabled]::-webkit-input-placeholder,html.theme--documenter-dark .textarea[disabled]::-webkit-input-placeholder,html.theme--documenter-dark .input[disabled]::-webkit-input-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled]::-webkit-input-placeholder,fieldset[disabled] html.theme--documenter-dark .select select::-webkit-input-placeholder,fieldset[disabled] html.theme--documenter-dark .textarea::-webkit-input-placeholder,fieldset[disabled] html.theme--documenter-dark .input::-webkit-input-placeholder,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input::-webkit-input-placeholder{color:rgba(255,255,255,0.3)}html.theme--documenter-dark .select select[disabled]:-moz-placeholder,html.theme--documenter-dark .textarea[disabled]:-moz-placeholder,html.theme--documenter-dark .input[disabled]:-moz-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled]:-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .select select:-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .textarea:-moz-placeholder,fieldset[disabled] html.theme--documenter-dark .input:-moz-placeholder,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:-moz-placeholder{color:rgba(255,255,255,0.3)}html.theme--documenter-dark .select select[disabled]:-ms-input-placeholder,html.theme--documenter-dark .textarea[disabled]:-ms-input-placeholder,html.theme--documenter-dark .input[disabled]:-ms-input-placeholder,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[disabled]:-ms-input-placeholder,fieldset[disabled] html.theme--documenter-dark .select select:-ms-input-placeholder,fieldset[disabled] html.theme--documenter-dark .textarea:-ms-input-placeholder,fieldset[disabled] html.theme--documenter-dark .input:-ms-input-placeholder,fieldset[disabled] html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input:-ms-input-placeholder{color:rgba(255,255,255,0.3)}html.theme--documenter-dark .textarea,html.theme--documenter-dark .input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{box-shadow:inset 0 0.0625em 0.125em rgba(10,10,10,0.05);max-width:100%;width:100%}html.theme--documenter-dark .textarea[readonly],html.theme--documenter-dark .input[readonly],html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input[readonly]{box-shadow:none}html.theme--documenter-dark .is-white.textarea,html.theme--documenter-dark .is-white.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-white{border-color:#fff}html.theme--documenter-dark .is-white.textarea:focus,html.theme--documenter-dark .is-white.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-white:focus,html.theme--documenter-dark .is-white.is-focused.textarea,html.theme--documenter-dark .is-white.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-white.textarea:active,html.theme--documenter-dark .is-white.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-white:active,html.theme--documenter-dark .is-white.is-active.textarea,html.theme--documenter-dark .is-white.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}html.theme--documenter-dark .is-black.textarea,html.theme--documenter-dark .is-black.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-black{border-color:#0a0a0a}html.theme--documenter-dark .is-black.textarea:focus,html.theme--documenter-dark .is-black.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-black:focus,html.theme--documenter-dark .is-black.is-focused.textarea,html.theme--documenter-dark .is-black.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-black.textarea:active,html.theme--documenter-dark .is-black.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-black:active,html.theme--documenter-dark .is-black.is-active.textarea,html.theme--documenter-dark .is-black.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}html.theme--documenter-dark .is-light.textarea,html.theme--documenter-dark .is-light.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-light{border-color:#ecf0f1}html.theme--documenter-dark .is-light.textarea:focus,html.theme--documenter-dark .is-light.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-light:focus,html.theme--documenter-dark .is-light.is-focused.textarea,html.theme--documenter-dark .is-light.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-light.textarea:active,html.theme--documenter-dark .is-light.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-light:active,html.theme--documenter-dark .is-light.is-active.textarea,html.theme--documenter-dark .is-light.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(236,240,241,0.25)}html.theme--documenter-dark .is-dark.textarea,html.theme--documenter-dark .content kbd.textarea,html.theme--documenter-dark .is-dark.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-dark,html.theme--documenter-dark .content kbd.input{border-color:#282f2f}html.theme--documenter-dark .is-dark.textarea:focus,html.theme--documenter-dark .content kbd.textarea:focus,html.theme--documenter-dark .is-dark.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-dark:focus,html.theme--documenter-dark .content kbd.input:focus,html.theme--documenter-dark .is-dark.is-focused.textarea,html.theme--documenter-dark .content kbd.is-focused.textarea,html.theme--documenter-dark .is-dark.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .content kbd.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar .content form.docs-search>input.is-focused,html.theme--documenter-dark .is-dark.textarea:active,html.theme--documenter-dark .content kbd.textarea:active,html.theme--documenter-dark .is-dark.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-dark:active,html.theme--documenter-dark .content kbd.input:active,html.theme--documenter-dark .is-dark.is-active.textarea,html.theme--documenter-dark .content kbd.is-active.textarea,html.theme--documenter-dark .is-dark.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active,html.theme--documenter-dark .content kbd.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar .content form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(40,47,47,0.25)}html.theme--documenter-dark .is-primary.textarea,html.theme--documenter-dark .docstring>section>a.textarea.docs-sourcelink,html.theme--documenter-dark .is-primary.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-primary,html.theme--documenter-dark .docstring>section>a.input.docs-sourcelink{border-color:#375a7f}html.theme--documenter-dark .is-primary.textarea:focus,html.theme--documenter-dark .docstring>section>a.textarea.docs-sourcelink:focus,html.theme--documenter-dark .is-primary.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-primary:focus,html.theme--documenter-dark .docstring>section>a.input.docs-sourcelink:focus,html.theme--documenter-dark .is-primary.is-focused.textarea,html.theme--documenter-dark .docstring>section>a.is-focused.textarea.docs-sourcelink,html.theme--documenter-dark .is-primary.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .docstring>section>a.is-focused.input.docs-sourcelink,html.theme--documenter-dark .is-primary.textarea:active,html.theme--documenter-dark .docstring>section>a.textarea.docs-sourcelink:active,html.theme--documenter-dark .is-primary.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-primary:active,html.theme--documenter-dark .docstring>section>a.input.docs-sourcelink:active,html.theme--documenter-dark .is-primary.is-active.textarea,html.theme--documenter-dark .docstring>section>a.is-active.textarea.docs-sourcelink,html.theme--documenter-dark .is-primary.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active,html.theme--documenter-dark .docstring>section>a.is-active.input.docs-sourcelink{box-shadow:0 0 0 0.125em rgba(55,90,127,0.25)}html.theme--documenter-dark .is-link.textarea,html.theme--documenter-dark .is-link.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-link{border-color:#1abc9c}html.theme--documenter-dark .is-link.textarea:focus,html.theme--documenter-dark .is-link.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-link:focus,html.theme--documenter-dark .is-link.is-focused.textarea,html.theme--documenter-dark .is-link.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-link.textarea:active,html.theme--documenter-dark .is-link.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-link:active,html.theme--documenter-dark .is-link.is-active.textarea,html.theme--documenter-dark .is-link.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(26,188,156,0.25)}html.theme--documenter-dark .is-info.textarea,html.theme--documenter-dark .is-info.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-info{border-color:#024c7d}html.theme--documenter-dark .is-info.textarea:focus,html.theme--documenter-dark .is-info.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-info:focus,html.theme--documenter-dark .is-info.is-focused.textarea,html.theme--documenter-dark .is-info.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-info.textarea:active,html.theme--documenter-dark .is-info.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-info:active,html.theme--documenter-dark .is-info.is-active.textarea,html.theme--documenter-dark .is-info.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(2,76,125,0.25)}html.theme--documenter-dark .is-success.textarea,html.theme--documenter-dark .is-success.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-success{border-color:#008438}html.theme--documenter-dark .is-success.textarea:focus,html.theme--documenter-dark .is-success.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-success:focus,html.theme--documenter-dark .is-success.is-focused.textarea,html.theme--documenter-dark .is-success.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-success.textarea:active,html.theme--documenter-dark .is-success.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-success:active,html.theme--documenter-dark .is-success.is-active.textarea,html.theme--documenter-dark .is-success.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(0,132,56,0.25)}html.theme--documenter-dark .is-warning.textarea,html.theme--documenter-dark .is-warning.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-warning{border-color:#ad8100}html.theme--documenter-dark .is-warning.textarea:focus,html.theme--documenter-dark .is-warning.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-warning:focus,html.theme--documenter-dark .is-warning.is-focused.textarea,html.theme--documenter-dark .is-warning.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-warning.textarea:active,html.theme--documenter-dark .is-warning.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-warning:active,html.theme--documenter-dark .is-warning.is-active.textarea,html.theme--documenter-dark .is-warning.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(173,129,0,0.25)}html.theme--documenter-dark .is-danger.textarea,html.theme--documenter-dark .is-danger.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-danger{border-color:#9e1b0d}html.theme--documenter-dark .is-danger.textarea:focus,html.theme--documenter-dark .is-danger.input:focus,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-danger:focus,html.theme--documenter-dark .is-danger.is-focused.textarea,html.theme--documenter-dark .is-danger.is-focused.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-focused,html.theme--documenter-dark .is-danger.textarea:active,html.theme--documenter-dark .is-danger.input:active,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-danger:active,html.theme--documenter-dark .is-danger.is-active.textarea,html.theme--documenter-dark .is-danger.is-active.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(158,27,13,0.25)}html.theme--documenter-dark .is-small.textarea,html.theme--documenter-dark .is-small.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{border-radius:3px;font-size:.75rem}html.theme--documenter-dark .is-medium.textarea,html.theme--documenter-dark .is-medium.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-medium{font-size:1.25rem}html.theme--documenter-dark .is-large.textarea,html.theme--documenter-dark .is-large.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-large{font-size:1.5rem}html.theme--documenter-dark .is-fullwidth.textarea,html.theme--documenter-dark .is-fullwidth.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-fullwidth{display:block;width:100%}html.theme--documenter-dark .is-inline.textarea,html.theme--documenter-dark .is-inline.input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-inline{display:inline;width:auto}html.theme--documenter-dark .input.is-rounded,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{border-radius:9999px;padding-left:calc(calc(0.75em - 1px) + 0.375em);padding-right:calc(calc(0.75em - 1px) + 0.375em)}html.theme--documenter-dark .input.is-static,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-static{background-color:transparent;border-color:transparent;box-shadow:none;padding-left:0;padding-right:0}html.theme--documenter-dark .textarea{display:block;max-width:100%;min-width:100%;padding:calc(0.75em - 1px);resize:vertical}html.theme--documenter-dark .textarea:not([rows]){max-height:40em;min-height:8em}html.theme--documenter-dark .textarea[rows]{height:initial}html.theme--documenter-dark .textarea.has-fixed-size{resize:none}html.theme--documenter-dark .radio,html.theme--documenter-dark .checkbox{cursor:pointer;display:inline-block;line-height:1.25;position:relative}html.theme--documenter-dark .radio input,html.theme--documenter-dark .checkbox input{cursor:pointer}html.theme--documenter-dark .radio:hover,html.theme--documenter-dark .checkbox:hover{color:#8c9b9d}html.theme--documenter-dark .radio[disabled],html.theme--documenter-dark .checkbox[disabled],fieldset[disabled] html.theme--documenter-dark .radio,fieldset[disabled] html.theme--documenter-dark .checkbox,html.theme--documenter-dark .radio input[disabled],html.theme--documenter-dark .checkbox input[disabled]{color:#fff;cursor:not-allowed}html.theme--documenter-dark .radio+.radio{margin-left:.5em}html.theme--documenter-dark .select{display:inline-block;max-width:100%;position:relative;vertical-align:top}html.theme--documenter-dark .select:not(.is-multiple){height:2.5em}html.theme--documenter-dark .select:not(.is-multiple):not(.is-loading)::after{border-color:#1abc9c;right:1.125em;z-index:4}html.theme--documenter-dark .select.is-rounded select,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.select select{border-radius:9999px;padding-left:1em}html.theme--documenter-dark .select select{cursor:pointer;display:block;font-size:1em;max-width:100%;outline:none}html.theme--documenter-dark .select select::-ms-expand{display:none}html.theme--documenter-dark .select select[disabled]:hover,fieldset[disabled] html.theme--documenter-dark .select select:hover{border-color:#282f2f}html.theme--documenter-dark .select select:not([multiple]){padding-right:2.5em}html.theme--documenter-dark .select select[multiple]{height:auto;padding:0}html.theme--documenter-dark .select select[multiple] option{padding:0.5em 1em}html.theme--documenter-dark .select:not(.is-multiple):not(.is-loading):hover::after{border-color:#8c9b9d}html.theme--documenter-dark .select.is-white:not(:hover)::after{border-color:#fff}html.theme--documenter-dark .select.is-white select{border-color:#fff}html.theme--documenter-dark .select.is-white select:hover,html.theme--documenter-dark .select.is-white select.is-hovered{border-color:#f2f2f2}html.theme--documenter-dark .select.is-white select:focus,html.theme--documenter-dark .select.is-white select.is-focused,html.theme--documenter-dark .select.is-white select:active,html.theme--documenter-dark .select.is-white select.is-active{box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}html.theme--documenter-dark .select.is-black:not(:hover)::after{border-color:#0a0a0a}html.theme--documenter-dark .select.is-black select{border-color:#0a0a0a}html.theme--documenter-dark .select.is-black select:hover,html.theme--documenter-dark .select.is-black select.is-hovered{border-color:#000}html.theme--documenter-dark .select.is-black select:focus,html.theme--documenter-dark .select.is-black select.is-focused,html.theme--documenter-dark .select.is-black select:active,html.theme--documenter-dark .select.is-black select.is-active{box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}html.theme--documenter-dark .select.is-light:not(:hover)::after{border-color:#ecf0f1}html.theme--documenter-dark .select.is-light select{border-color:#ecf0f1}html.theme--documenter-dark .select.is-light select:hover,html.theme--documenter-dark .select.is-light select.is-hovered{border-color:#dde4e6}html.theme--documenter-dark .select.is-light select:focus,html.theme--documenter-dark .select.is-light select.is-focused,html.theme--documenter-dark .select.is-light select:active,html.theme--documenter-dark .select.is-light select.is-active{box-shadow:0 0 0 0.125em rgba(236,240,241,0.25)}html.theme--documenter-dark .select.is-dark:not(:hover)::after,html.theme--documenter-dark .content kbd.select:not(:hover)::after{border-color:#282f2f}html.theme--documenter-dark .select.is-dark select,html.theme--documenter-dark .content kbd.select select{border-color:#282f2f}html.theme--documenter-dark .select.is-dark select:hover,html.theme--documenter-dark .content kbd.select select:hover,html.theme--documenter-dark .select.is-dark select.is-hovered,html.theme--documenter-dark .content kbd.select select.is-hovered{border-color:#1d2122}html.theme--documenter-dark .select.is-dark select:focus,html.theme--documenter-dark .content kbd.select select:focus,html.theme--documenter-dark .select.is-dark select.is-focused,html.theme--documenter-dark .content kbd.select select.is-focused,html.theme--documenter-dark .select.is-dark select:active,html.theme--documenter-dark .content kbd.select select:active,html.theme--documenter-dark .select.is-dark select.is-active,html.theme--documenter-dark .content kbd.select select.is-active{box-shadow:0 0 0 0.125em rgba(40,47,47,0.25)}html.theme--documenter-dark .select.is-primary:not(:hover)::after,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink:not(:hover)::after{border-color:#375a7f}html.theme--documenter-dark .select.is-primary select,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select{border-color:#375a7f}html.theme--documenter-dark .select.is-primary select:hover,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select:hover,html.theme--documenter-dark .select.is-primary select.is-hovered,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select.is-hovered{border-color:#2f4d6d}html.theme--documenter-dark .select.is-primary select:focus,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select:focus,html.theme--documenter-dark .select.is-primary select.is-focused,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select.is-focused,html.theme--documenter-dark .select.is-primary select:active,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select:active,html.theme--documenter-dark .select.is-primary select.is-active,html.theme--documenter-dark .docstring>section>a.select.docs-sourcelink select.is-active{box-shadow:0 0 0 0.125em rgba(55,90,127,0.25)}html.theme--documenter-dark .select.is-link:not(:hover)::after{border-color:#1abc9c}html.theme--documenter-dark .select.is-link select{border-color:#1abc9c}html.theme--documenter-dark .select.is-link select:hover,html.theme--documenter-dark .select.is-link select.is-hovered{border-color:#17a689}html.theme--documenter-dark .select.is-link select:focus,html.theme--documenter-dark .select.is-link select.is-focused,html.theme--documenter-dark .select.is-link select:active,html.theme--documenter-dark .select.is-link select.is-active{box-shadow:0 0 0 0.125em rgba(26,188,156,0.25)}html.theme--documenter-dark .select.is-info:not(:hover)::after{border-color:#024c7d}html.theme--documenter-dark .select.is-info select{border-color:#024c7d}html.theme--documenter-dark .select.is-info select:hover,html.theme--documenter-dark .select.is-info select.is-hovered{border-color:#023d64}html.theme--documenter-dark .select.is-info select:focus,html.theme--documenter-dark .select.is-info select.is-focused,html.theme--documenter-dark .select.is-info select:active,html.theme--documenter-dark .select.is-info select.is-active{box-shadow:0 0 0 0.125em rgba(2,76,125,0.25)}html.theme--documenter-dark .select.is-success:not(:hover)::after{border-color:#008438}html.theme--documenter-dark .select.is-success select{border-color:#008438}html.theme--documenter-dark .select.is-success select:hover,html.theme--documenter-dark .select.is-success select.is-hovered{border-color:#006b2d}html.theme--documenter-dark .select.is-success select:focus,html.theme--documenter-dark .select.is-success select.is-focused,html.theme--documenter-dark .select.is-success select:active,html.theme--documenter-dark .select.is-success select.is-active{box-shadow:0 0 0 0.125em rgba(0,132,56,0.25)}html.theme--documenter-dark .select.is-warning:not(:hover)::after{border-color:#ad8100}html.theme--documenter-dark .select.is-warning select{border-color:#ad8100}html.theme--documenter-dark .select.is-warning select:hover,html.theme--documenter-dark .select.is-warning select.is-hovered{border-color:#946e00}html.theme--documenter-dark .select.is-warning select:focus,html.theme--documenter-dark .select.is-warning select.is-focused,html.theme--documenter-dark .select.is-warning select:active,html.theme--documenter-dark .select.is-warning select.is-active{box-shadow:0 0 0 0.125em rgba(173,129,0,0.25)}html.theme--documenter-dark .select.is-danger:not(:hover)::after{border-color:#9e1b0d}html.theme--documenter-dark .select.is-danger select{border-color:#9e1b0d}html.theme--documenter-dark .select.is-danger select:hover,html.theme--documenter-dark .select.is-danger select.is-hovered{border-color:#86170b}html.theme--documenter-dark .select.is-danger select:focus,html.theme--documenter-dark .select.is-danger select.is-focused,html.theme--documenter-dark .select.is-danger select:active,html.theme--documenter-dark .select.is-danger select.is-active{box-shadow:0 0 0 0.125em rgba(158,27,13,0.25)}html.theme--documenter-dark .select.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.select{border-radius:3px;font-size:.75rem}html.theme--documenter-dark .select.is-medium{font-size:1.25rem}html.theme--documenter-dark .select.is-large{font-size:1.5rem}html.theme--documenter-dark .select.is-disabled::after{border-color:#fff !important;opacity:0.5}html.theme--documenter-dark .select.is-fullwidth{width:100%}html.theme--documenter-dark .select.is-fullwidth select{width:100%}html.theme--documenter-dark .select.is-loading::after{margin-top:0;position:absolute;right:.625em;top:0.625em;transform:none}html.theme--documenter-dark .select.is-loading.is-small:after,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-loading:after{font-size:.75rem}html.theme--documenter-dark .select.is-loading.is-medium:after{font-size:1.25rem}html.theme--documenter-dark .select.is-loading.is-large:after{font-size:1.5rem}html.theme--documenter-dark .file{align-items:stretch;display:flex;justify-content:flex-start;position:relative}html.theme--documenter-dark .file.is-white .file-cta{background-color:#fff;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .file.is-white:hover .file-cta,html.theme--documenter-dark .file.is-white.is-hovered .file-cta{background-color:#f9f9f9;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .file.is-white:focus .file-cta,html.theme--documenter-dark .file.is-white.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(255,255,255,0.25);color:#0a0a0a}html.theme--documenter-dark .file.is-white:active .file-cta,html.theme--documenter-dark .file.is-white.is-active .file-cta{background-color:#f2f2f2;border-color:transparent;color:#0a0a0a}html.theme--documenter-dark .file.is-black .file-cta{background-color:#0a0a0a;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-black:hover .file-cta,html.theme--documenter-dark .file.is-black.is-hovered .file-cta{background-color:#040404;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-black:focus .file-cta,html.theme--documenter-dark .file.is-black.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(10,10,10,0.25);color:#fff}html.theme--documenter-dark .file.is-black:active .file-cta,html.theme--documenter-dark .file.is-black.is-active .file-cta{background-color:#000;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-light .file-cta{background-color:#ecf0f1;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .file.is-light:hover .file-cta,html.theme--documenter-dark .file.is-light.is-hovered .file-cta{background-color:#e5eaec;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .file.is-light:focus .file-cta,html.theme--documenter-dark .file.is-light.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(236,240,241,0.25);color:rgba(0,0,0,0.7)}html.theme--documenter-dark .file.is-light:active .file-cta,html.theme--documenter-dark .file.is-light.is-active .file-cta{background-color:#dde4e6;border-color:transparent;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .file.is-dark .file-cta,html.theme--documenter-dark .content kbd.file .file-cta{background-color:#282f2f;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-dark:hover .file-cta,html.theme--documenter-dark .content kbd.file:hover .file-cta,html.theme--documenter-dark .file.is-dark.is-hovered .file-cta,html.theme--documenter-dark .content kbd.file.is-hovered .file-cta{background-color:#232829;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-dark:focus .file-cta,html.theme--documenter-dark .content kbd.file:focus .file-cta,html.theme--documenter-dark .file.is-dark.is-focused .file-cta,html.theme--documenter-dark .content kbd.file.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(40,47,47,0.25);color:#fff}html.theme--documenter-dark .file.is-dark:active .file-cta,html.theme--documenter-dark .content kbd.file:active .file-cta,html.theme--documenter-dark .file.is-dark.is-active .file-cta,html.theme--documenter-dark .content kbd.file.is-active .file-cta{background-color:#1d2122;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-primary .file-cta,html.theme--documenter-dark .docstring>section>a.file.docs-sourcelink .file-cta{background-color:#375a7f;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-primary:hover .file-cta,html.theme--documenter-dark .docstring>section>a.file.docs-sourcelink:hover .file-cta,html.theme--documenter-dark .file.is-primary.is-hovered .file-cta,html.theme--documenter-dark .docstring>section>a.file.is-hovered.docs-sourcelink .file-cta{background-color:#335476;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-primary:focus .file-cta,html.theme--documenter-dark .docstring>section>a.file.docs-sourcelink:focus .file-cta,html.theme--documenter-dark .file.is-primary.is-focused .file-cta,html.theme--documenter-dark .docstring>section>a.file.is-focused.docs-sourcelink .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(55,90,127,0.25);color:#fff}html.theme--documenter-dark .file.is-primary:active .file-cta,html.theme--documenter-dark .docstring>section>a.file.docs-sourcelink:active .file-cta,html.theme--documenter-dark .file.is-primary.is-active .file-cta,html.theme--documenter-dark .docstring>section>a.file.is-active.docs-sourcelink .file-cta{background-color:#2f4d6d;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-link .file-cta{background-color:#1abc9c;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-link:hover .file-cta,html.theme--documenter-dark .file.is-link.is-hovered .file-cta{background-color:#18b193;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-link:focus .file-cta,html.theme--documenter-dark .file.is-link.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(26,188,156,0.25);color:#fff}html.theme--documenter-dark .file.is-link:active .file-cta,html.theme--documenter-dark .file.is-link.is-active .file-cta{background-color:#17a689;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-info .file-cta{background-color:#024c7d;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-info:hover .file-cta,html.theme--documenter-dark .file.is-info.is-hovered .file-cta{background-color:#024470;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-info:focus .file-cta,html.theme--documenter-dark .file.is-info.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(2,76,125,0.25);color:#fff}html.theme--documenter-dark .file.is-info:active .file-cta,html.theme--documenter-dark .file.is-info.is-active .file-cta{background-color:#023d64;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-success .file-cta{background-color:#008438;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-success:hover .file-cta,html.theme--documenter-dark .file.is-success.is-hovered .file-cta{background-color:#073;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-success:focus .file-cta,html.theme--documenter-dark .file.is-success.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(0,132,56,0.25);color:#fff}html.theme--documenter-dark .file.is-success:active .file-cta,html.theme--documenter-dark .file.is-success.is-active .file-cta{background-color:#006b2d;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-warning .file-cta{background-color:#ad8100;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-warning:hover .file-cta,html.theme--documenter-dark .file.is-warning.is-hovered .file-cta{background-color:#a07700;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-warning:focus .file-cta,html.theme--documenter-dark .file.is-warning.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(173,129,0,0.25);color:#fff}html.theme--documenter-dark .file.is-warning:active .file-cta,html.theme--documenter-dark .file.is-warning.is-active .file-cta{background-color:#946e00;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-danger .file-cta{background-color:#9e1b0d;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-danger:hover .file-cta,html.theme--documenter-dark .file.is-danger.is-hovered .file-cta{background-color:#92190c;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-danger:focus .file-cta,html.theme--documenter-dark .file.is-danger.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(158,27,13,0.25);color:#fff}html.theme--documenter-dark .file.is-danger:active .file-cta,html.theme--documenter-dark .file.is-danger.is-active .file-cta{background-color:#86170b;border-color:transparent;color:#fff}html.theme--documenter-dark .file.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.file{font-size:.75rem}html.theme--documenter-dark .file.is-normal{font-size:1rem}html.theme--documenter-dark .file.is-medium{font-size:1.25rem}html.theme--documenter-dark .file.is-medium .file-icon .fa{font-size:21px}html.theme--documenter-dark .file.is-large{font-size:1.5rem}html.theme--documenter-dark .file.is-large .file-icon .fa{font-size:28px}html.theme--documenter-dark .file.has-name .file-cta{border-bottom-right-radius:0;border-top-right-radius:0}html.theme--documenter-dark .file.has-name .file-name{border-bottom-left-radius:0;border-top-left-radius:0}html.theme--documenter-dark .file.has-name.is-empty .file-cta{border-radius:.4em}html.theme--documenter-dark .file.has-name.is-empty .file-name{display:none}html.theme--documenter-dark .file.is-boxed .file-label{flex-direction:column}html.theme--documenter-dark .file.is-boxed .file-cta{flex-direction:column;height:auto;padding:1em 3em}html.theme--documenter-dark .file.is-boxed .file-name{border-width:0 1px 1px}html.theme--documenter-dark .file.is-boxed .file-icon{height:1.5em;width:1.5em}html.theme--documenter-dark .file.is-boxed .file-icon .fa{font-size:21px}html.theme--documenter-dark .file.is-boxed.is-small .file-icon .fa,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-boxed .file-icon .fa{font-size:14px}html.theme--documenter-dark .file.is-boxed.is-medium .file-icon .fa{font-size:28px}html.theme--documenter-dark .file.is-boxed.is-large .file-icon .fa{font-size:35px}html.theme--documenter-dark .file.is-boxed.has-name .file-cta{border-radius:.4em .4em 0 0}html.theme--documenter-dark .file.is-boxed.has-name .file-name{border-radius:0 0 .4em .4em;border-width:0 1px 1px}html.theme--documenter-dark .file.is-centered{justify-content:center}html.theme--documenter-dark .file.is-fullwidth .file-label{width:100%}html.theme--documenter-dark .file.is-fullwidth .file-name{flex-grow:1;max-width:none}html.theme--documenter-dark .file.is-right{justify-content:flex-end}html.theme--documenter-dark .file.is-right .file-cta{border-radius:0 .4em .4em 0}html.theme--documenter-dark .file.is-right .file-name{border-radius:.4em 0 0 .4em;border-width:1px 0 1px 1px;order:-1}html.theme--documenter-dark .file-label{align-items:stretch;display:flex;cursor:pointer;justify-content:flex-start;overflow:hidden;position:relative}html.theme--documenter-dark .file-label:hover .file-cta{background-color:#232829;color:#f2f2f2}html.theme--documenter-dark .file-label:hover .file-name{border-color:#596668}html.theme--documenter-dark .file-label:active .file-cta{background-color:#1d2122;color:#f2f2f2}html.theme--documenter-dark .file-label:active .file-name{border-color:#535f61}html.theme--documenter-dark .file-input{height:100%;left:0;opacity:0;outline:none;position:absolute;top:0;width:100%}html.theme--documenter-dark .file-cta,html.theme--documenter-dark .file-name{border-color:#5e6d6f;border-radius:.4em;font-size:1em;padding-left:1em;padding-right:1em;white-space:nowrap}html.theme--documenter-dark .file-cta{background-color:#282f2f;color:#fff}html.theme--documenter-dark .file-name{border-color:#5e6d6f;border-style:solid;border-width:1px 1px 1px 0;display:block;max-width:16em;overflow:hidden;text-align:inherit;text-overflow:ellipsis}html.theme--documenter-dark .file-icon{align-items:center;display:flex;height:1em;justify-content:center;margin-right:.5em;width:1em}html.theme--documenter-dark .file-icon .fa{font-size:14px}html.theme--documenter-dark .label{color:#f2f2f2;display:block;font-size:1rem;font-weight:700}html.theme--documenter-dark .label:not(:last-child){margin-bottom:0.5em}html.theme--documenter-dark .label.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.label{font-size:.75rem}html.theme--documenter-dark .label.is-medium{font-size:1.25rem}html.theme--documenter-dark .label.is-large{font-size:1.5rem}html.theme--documenter-dark .help{display:block;font-size:.75rem;margin-top:0.25rem}html.theme--documenter-dark .help.is-white{color:#fff}html.theme--documenter-dark .help.is-black{color:#0a0a0a}html.theme--documenter-dark .help.is-light{color:#ecf0f1}html.theme--documenter-dark .help.is-dark,html.theme--documenter-dark .content kbd.help{color:#282f2f}html.theme--documenter-dark .help.is-primary,html.theme--documenter-dark .docstring>section>a.help.docs-sourcelink{color:#375a7f}html.theme--documenter-dark .help.is-link{color:#1abc9c}html.theme--documenter-dark .help.is-info{color:#024c7d}html.theme--documenter-dark .help.is-success{color:#008438}html.theme--documenter-dark .help.is-warning{color:#ad8100}html.theme--documenter-dark .help.is-danger{color:#9e1b0d}html.theme--documenter-dark .field:not(:last-child){margin-bottom:0.75rem}html.theme--documenter-dark .field.has-addons{display:flex;justify-content:flex-start}html.theme--documenter-dark .field.has-addons .control:not(:last-child){margin-right:-1px}html.theme--documenter-dark .field.has-addons .control:not(:first-child):not(:last-child) .button,html.theme--documenter-dark .field.has-addons .control:not(:first-child):not(:last-child) .input,html.theme--documenter-dark .field.has-addons .control:not(:first-child):not(:last-child) #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control:not(:first-child):not(:last-child) form.docs-search>input,html.theme--documenter-dark .field.has-addons .control:not(:first-child):not(:last-child) .select select{border-radius:0}html.theme--documenter-dark .field.has-addons .control:first-child:not(:only-child) .button,html.theme--documenter-dark .field.has-addons .control:first-child:not(:only-child) .input,html.theme--documenter-dark .field.has-addons .control:first-child:not(:only-child) #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control:first-child:not(:only-child) form.docs-search>input,html.theme--documenter-dark .field.has-addons .control:first-child:not(:only-child) .select select{border-bottom-right-radius:0;border-top-right-radius:0}html.theme--documenter-dark .field.has-addons .control:last-child:not(:only-child) .button,html.theme--documenter-dark .field.has-addons .control:last-child:not(:only-child) .input,html.theme--documenter-dark .field.has-addons .control:last-child:not(:only-child) #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control:last-child:not(:only-child) form.docs-search>input,html.theme--documenter-dark .field.has-addons .control:last-child:not(:only-child) .select select{border-bottom-left-radius:0;border-top-left-radius:0}html.theme--documenter-dark .field.has-addons .control .button:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .button.is-hovered:not([disabled]),html.theme--documenter-dark .field.has-addons .control .input:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):hover,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .input.is-hovered:not([disabled]),html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-hovered:not([disabled]),html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-hovered:not([disabled]),html.theme--documenter-dark .field.has-addons .control .select select:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .select select.is-hovered:not([disabled]){z-index:2}html.theme--documenter-dark .field.has-addons .control .button:not([disabled]):focus,html.theme--documenter-dark .field.has-addons .control .button.is-focused:not([disabled]),html.theme--documenter-dark .field.has-addons .control .button:not([disabled]):active,html.theme--documenter-dark .field.has-addons .control .button.is-active:not([disabled]),html.theme--documenter-dark .field.has-addons .control .input:not([disabled]):focus,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):focus,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):focus,html.theme--documenter-dark .field.has-addons .control .input.is-focused:not([disabled]),html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-focused:not([disabled]),html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-focused:not([disabled]),html.theme--documenter-dark .field.has-addons .control .input:not([disabled]):active,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):active,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):active,html.theme--documenter-dark .field.has-addons .control .input.is-active:not([disabled]),html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-active:not([disabled]),html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-active:not([disabled]),html.theme--documenter-dark .field.has-addons .control .select select:not([disabled]):focus,html.theme--documenter-dark .field.has-addons .control .select select.is-focused:not([disabled]),html.theme--documenter-dark .field.has-addons .control .select select:not([disabled]):active,html.theme--documenter-dark .field.has-addons .control .select select.is-active:not([disabled]){z-index:3}html.theme--documenter-dark .field.has-addons .control .button:not([disabled]):focus:hover,html.theme--documenter-dark .field.has-addons .control .button.is-focused:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .button:not([disabled]):active:hover,html.theme--documenter-dark .field.has-addons .control .button.is-active:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .input:not([disabled]):focus:hover,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):focus:hover,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):focus:hover,html.theme--documenter-dark .field.has-addons .control .input.is-focused:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-focused:not([disabled]):hover,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-focused:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .input:not([disabled]):active:hover,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):active:hover,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):active:hover,html.theme--documenter-dark .field.has-addons .control .input.is-active:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-active:not([disabled]):hover,html.theme--documenter-dark #documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-active:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .select select:not([disabled]):focus:hover,html.theme--documenter-dark .field.has-addons .control .select select.is-focused:not([disabled]):hover,html.theme--documenter-dark .field.has-addons .control .select select:not([disabled]):active:hover,html.theme--documenter-dark .field.has-addons .control .select select.is-active:not([disabled]):hover{z-index:4}html.theme--documenter-dark .field.has-addons .control.is-expanded{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .field.has-addons.has-addons-centered{justify-content:center}html.theme--documenter-dark .field.has-addons.has-addons-right{justify-content:flex-end}html.theme--documenter-dark .field.has-addons.has-addons-fullwidth .control{flex-grow:1;flex-shrink:0}html.theme--documenter-dark .field.is-grouped{display:flex;justify-content:flex-start}html.theme--documenter-dark .field.is-grouped>.control{flex-shrink:0}html.theme--documenter-dark .field.is-grouped>.control:not(:last-child){margin-bottom:0;margin-right:.75rem}html.theme--documenter-dark .field.is-grouped>.control.is-expanded{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .field.is-grouped.is-grouped-centered{justify-content:center}html.theme--documenter-dark .field.is-grouped.is-grouped-right{justify-content:flex-end}html.theme--documenter-dark .field.is-grouped.is-grouped-multiline{flex-wrap:wrap}html.theme--documenter-dark .field.is-grouped.is-grouped-multiline>.control:last-child,html.theme--documenter-dark .field.is-grouped.is-grouped-multiline>.control:not(:last-child){margin-bottom:0.75rem}html.theme--documenter-dark .field.is-grouped.is-grouped-multiline:last-child{margin-bottom:-0.75rem}html.theme--documenter-dark .field.is-grouped.is-grouped-multiline:not(:last-child){margin-bottom:0}@media screen and (min-width: 769px),print{html.theme--documenter-dark .field.is-horizontal{display:flex}}html.theme--documenter-dark .field-label .label{font-size:inherit}@media screen and (max-width: 768px){html.theme--documenter-dark .field-label{margin-bottom:0.5rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .field-label{flex-basis:0;flex-grow:1;flex-shrink:0;margin-right:1.5rem;text-align:right}html.theme--documenter-dark .field-label.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.field-label{font-size:.75rem;padding-top:0.375em}html.theme--documenter-dark .field-label.is-normal{padding-top:0.375em}html.theme--documenter-dark .field-label.is-medium{font-size:1.25rem;padding-top:0.375em}html.theme--documenter-dark .field-label.is-large{font-size:1.5rem;padding-top:0.375em}}html.theme--documenter-dark .field-body .field .field{margin-bottom:0}@media screen and (min-width: 769px),print{html.theme--documenter-dark .field-body{display:flex;flex-basis:0;flex-grow:5;flex-shrink:1}html.theme--documenter-dark .field-body .field{margin-bottom:0}html.theme--documenter-dark .field-body>.field{flex-shrink:1}html.theme--documenter-dark .field-body>.field:not(.is-narrow){flex-grow:1}html.theme--documenter-dark .field-body>.field:not(:last-child){margin-right:.75rem}}html.theme--documenter-dark .control{box-sizing:border-box;clear:both;font-size:1rem;position:relative;text-align:inherit}html.theme--documenter-dark .control.has-icons-left .input:focus~.icon,html.theme--documenter-dark .control.has-icons-left #documenter .docs-sidebar form.docs-search>input:focus~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-left form.docs-search>input:focus~.icon,html.theme--documenter-dark .control.has-icons-left .select:focus~.icon,html.theme--documenter-dark .control.has-icons-right .input:focus~.icon,html.theme--documenter-dark .control.has-icons-right #documenter .docs-sidebar form.docs-search>input:focus~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-right form.docs-search>input:focus~.icon,html.theme--documenter-dark .control.has-icons-right .select:focus~.icon{color:#282f2f}html.theme--documenter-dark .control.has-icons-left .input.is-small~.icon,html.theme--documenter-dark .control.has-icons-left #documenter .docs-sidebar form.docs-search>input~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-left form.docs-search>input~.icon,html.theme--documenter-dark .control.has-icons-left .select.is-small~.icon,html.theme--documenter-dark .control.has-icons-right .input.is-small~.icon,html.theme--documenter-dark .control.has-icons-right #documenter .docs-sidebar form.docs-search>input~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-right form.docs-search>input~.icon,html.theme--documenter-dark .control.has-icons-right .select.is-small~.icon{font-size:.75rem}html.theme--documenter-dark .control.has-icons-left .input.is-medium~.icon,html.theme--documenter-dark .control.has-icons-left #documenter .docs-sidebar form.docs-search>input.is-medium~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-left form.docs-search>input.is-medium~.icon,html.theme--documenter-dark .control.has-icons-left .select.is-medium~.icon,html.theme--documenter-dark .control.has-icons-right .input.is-medium~.icon,html.theme--documenter-dark .control.has-icons-right #documenter .docs-sidebar form.docs-search>input.is-medium~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-right form.docs-search>input.is-medium~.icon,html.theme--documenter-dark .control.has-icons-right .select.is-medium~.icon{font-size:1.25rem}html.theme--documenter-dark .control.has-icons-left .input.is-large~.icon,html.theme--documenter-dark .control.has-icons-left #documenter .docs-sidebar form.docs-search>input.is-large~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-left form.docs-search>input.is-large~.icon,html.theme--documenter-dark .control.has-icons-left .select.is-large~.icon,html.theme--documenter-dark .control.has-icons-right .input.is-large~.icon,html.theme--documenter-dark .control.has-icons-right #documenter .docs-sidebar form.docs-search>input.is-large~.icon,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-right form.docs-search>input.is-large~.icon,html.theme--documenter-dark .control.has-icons-right .select.is-large~.icon{font-size:1.5rem}html.theme--documenter-dark .control.has-icons-left .icon,html.theme--documenter-dark .control.has-icons-right .icon{color:#5e6d6f;height:2.5em;pointer-events:none;position:absolute;top:0;width:2.5em;z-index:4}html.theme--documenter-dark .control.has-icons-left .input,html.theme--documenter-dark .control.has-icons-left #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-left form.docs-search>input,html.theme--documenter-dark .control.has-icons-left .select select{padding-left:2.5em}html.theme--documenter-dark .control.has-icons-left .icon.is-left{left:0}html.theme--documenter-dark .control.has-icons-right .input,html.theme--documenter-dark .control.has-icons-right #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .control.has-icons-right form.docs-search>input,html.theme--documenter-dark .control.has-icons-right .select select{padding-right:2.5em}html.theme--documenter-dark .control.has-icons-right .icon.is-right{right:0}html.theme--documenter-dark .control.is-loading::after{position:absolute !important;right:.625em;top:0.625em;z-index:4}html.theme--documenter-dark .control.is-loading.is-small:after,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.is-loading:after{font-size:.75rem}html.theme--documenter-dark .control.is-loading.is-medium:after{font-size:1.25rem}html.theme--documenter-dark .control.is-loading.is-large:after{font-size:1.5rem}html.theme--documenter-dark .breadcrumb{font-size:1rem;white-space:nowrap}html.theme--documenter-dark .breadcrumb a{align-items:center;color:#1abc9c;display:flex;justify-content:center;padding:0 .75em}html.theme--documenter-dark .breadcrumb a:hover{color:#1dd2af}html.theme--documenter-dark .breadcrumb li{align-items:center;display:flex}html.theme--documenter-dark .breadcrumb li:first-child a{padding-left:0}html.theme--documenter-dark .breadcrumb li.is-active a{color:#f2f2f2;cursor:default;pointer-events:none}html.theme--documenter-dark .breadcrumb li+li::before{color:#8c9b9d;content:"\0002f"}html.theme--documenter-dark .breadcrumb ul,html.theme--documenter-dark .breadcrumb ol{align-items:flex-start;display:flex;flex-wrap:wrap;justify-content:flex-start}html.theme--documenter-dark .breadcrumb .icon:first-child{margin-right:.5em}html.theme--documenter-dark .breadcrumb .icon:last-child{margin-left:.5em}html.theme--documenter-dark .breadcrumb.is-centered ol,html.theme--documenter-dark .breadcrumb.is-centered ul{justify-content:center}html.theme--documenter-dark .breadcrumb.is-right ol,html.theme--documenter-dark .breadcrumb.is-right ul{justify-content:flex-end}html.theme--documenter-dark .breadcrumb.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.breadcrumb{font-size:.75rem}html.theme--documenter-dark .breadcrumb.is-medium{font-size:1.25rem}html.theme--documenter-dark .breadcrumb.is-large{font-size:1.5rem}html.theme--documenter-dark .breadcrumb.has-arrow-separator li+li::before{content:"\02192"}html.theme--documenter-dark .breadcrumb.has-bullet-separator li+li::before{content:"\02022"}html.theme--documenter-dark .breadcrumb.has-dot-separator li+li::before{content:"\000b7"}html.theme--documenter-dark .breadcrumb.has-succeeds-separator li+li::before{content:"\0227B"}html.theme--documenter-dark .card{background-color:#fff;border-radius:.25rem;box-shadow:#171717;color:#fff;max-width:100%;position:relative}html.theme--documenter-dark .card-footer:first-child,html.theme--documenter-dark .card-content:first-child,html.theme--documenter-dark .card-header:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}html.theme--documenter-dark .card-footer:last-child,html.theme--documenter-dark .card-content:last-child,html.theme--documenter-dark .card-header:last-child{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}html.theme--documenter-dark .card-header{background-color:rgba(0,0,0,0);align-items:stretch;box-shadow:0 0.125em 0.25em rgba(10,10,10,0.1);display:flex}html.theme--documenter-dark .card-header-title{align-items:center;color:#f2f2f2;display:flex;flex-grow:1;font-weight:700;padding:0.75rem 1rem}html.theme--documenter-dark .card-header-title.is-centered{justify-content:center}html.theme--documenter-dark .card-header-icon{-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;color:currentColor;font-family:inherit;font-size:1em;margin:0;padding:0;align-items:center;cursor:pointer;display:flex;justify-content:center;padding:0.75rem 1rem}html.theme--documenter-dark .card-image{display:block;position:relative}html.theme--documenter-dark .card-image:first-child img{border-top-left-radius:.25rem;border-top-right-radius:.25rem}html.theme--documenter-dark .card-image:last-child img{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}html.theme--documenter-dark .card-content{background-color:rgba(0,0,0,0);padding:1.5rem}html.theme--documenter-dark .card-footer{background-color:rgba(0,0,0,0);border-top:1px solid #ededed;align-items:stretch;display:flex}html.theme--documenter-dark .card-footer-item{align-items:center;display:flex;flex-basis:0;flex-grow:1;flex-shrink:0;justify-content:center;padding:.75rem}html.theme--documenter-dark .card-footer-item:not(:last-child){border-right:1px solid #ededed}html.theme--documenter-dark .card .media:not(:last-child){margin-bottom:1.5rem}html.theme--documenter-dark .dropdown{display:inline-flex;position:relative;vertical-align:top}html.theme--documenter-dark .dropdown.is-active .dropdown-menu,html.theme--documenter-dark .dropdown.is-hoverable:hover .dropdown-menu{display:block}html.theme--documenter-dark .dropdown.is-right .dropdown-menu{left:auto;right:0}html.theme--documenter-dark .dropdown.is-up .dropdown-menu{bottom:100%;padding-bottom:4px;padding-top:initial;top:auto}html.theme--documenter-dark .dropdown-menu{display:none;left:0;min-width:12rem;padding-top:4px;position:absolute;top:100%;z-index:20}html.theme--documenter-dark .dropdown-content{background-color:#282f2f;border-radius:.4em;box-shadow:#171717;padding-bottom:.5rem;padding-top:.5rem}html.theme--documenter-dark .dropdown-item{color:#fff;display:block;font-size:0.875rem;line-height:1.5;padding:0.375rem 1rem;position:relative}html.theme--documenter-dark a.dropdown-item,html.theme--documenter-dark button.dropdown-item{padding-right:3rem;text-align:inherit;white-space:nowrap;width:100%}html.theme--documenter-dark a.dropdown-item:hover,html.theme--documenter-dark button.dropdown-item:hover{background-color:#282f2f;color:#0a0a0a}html.theme--documenter-dark a.dropdown-item.is-active,html.theme--documenter-dark button.dropdown-item.is-active{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .dropdown-divider{background-color:#ededed;border:none;display:block;height:1px;margin:0.5rem 0}html.theme--documenter-dark .level{align-items:center;justify-content:space-between}html.theme--documenter-dark .level code{border-radius:.4em}html.theme--documenter-dark .level img{display:inline-block;vertical-align:top}html.theme--documenter-dark .level.is-mobile{display:flex}html.theme--documenter-dark .level.is-mobile .level-left,html.theme--documenter-dark .level.is-mobile .level-right{display:flex}html.theme--documenter-dark .level.is-mobile .level-left+.level-right{margin-top:0}html.theme--documenter-dark .level.is-mobile .level-item:not(:last-child){margin-bottom:0;margin-right:.75rem}html.theme--documenter-dark .level.is-mobile .level-item:not(.is-narrow){flex-grow:1}@media screen and (min-width: 769px),print{html.theme--documenter-dark .level{display:flex}html.theme--documenter-dark .level>.level-item:not(.is-narrow){flex-grow:1}}html.theme--documenter-dark .level-item{align-items:center;display:flex;flex-basis:auto;flex-grow:0;flex-shrink:0;justify-content:center}html.theme--documenter-dark .level-item .title,html.theme--documenter-dark .level-item .subtitle{margin-bottom:0}@media screen and (max-width: 768px){html.theme--documenter-dark .level-item:not(:last-child){margin-bottom:.75rem}}html.theme--documenter-dark .level-left,html.theme--documenter-dark .level-right{flex-basis:auto;flex-grow:0;flex-shrink:0}html.theme--documenter-dark .level-left .level-item.is-flexible,html.theme--documenter-dark .level-right .level-item.is-flexible{flex-grow:1}@media screen and (min-width: 769px),print{html.theme--documenter-dark .level-left .level-item:not(:last-child),html.theme--documenter-dark .level-right .level-item:not(:last-child){margin-right:.75rem}}html.theme--documenter-dark .level-left{align-items:center;justify-content:flex-start}@media screen and (max-width: 768px){html.theme--documenter-dark .level-left+.level-right{margin-top:1.5rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .level-left{display:flex}}html.theme--documenter-dark .level-right{align-items:center;justify-content:flex-end}@media screen and (min-width: 769px),print{html.theme--documenter-dark .level-right{display:flex}}html.theme--documenter-dark .media{align-items:flex-start;display:flex;text-align:inherit}html.theme--documenter-dark .media .content:not(:last-child){margin-bottom:.75rem}html.theme--documenter-dark .media .media{border-top:1px solid rgba(94,109,111,0.5);display:flex;padding-top:.75rem}html.theme--documenter-dark .media .media .content:not(:last-child),html.theme--documenter-dark .media .media .control:not(:last-child){margin-bottom:.5rem}html.theme--documenter-dark .media .media .media{padding-top:.5rem}html.theme--documenter-dark .media .media .media+.media{margin-top:.5rem}html.theme--documenter-dark .media+.media{border-top:1px solid rgba(94,109,111,0.5);margin-top:1rem;padding-top:1rem}html.theme--documenter-dark .media.is-large+.media{margin-top:1.5rem;padding-top:1.5rem}html.theme--documenter-dark .media-left,html.theme--documenter-dark .media-right{flex-basis:auto;flex-grow:0;flex-shrink:0}html.theme--documenter-dark .media-left{margin-right:1rem}html.theme--documenter-dark .media-right{margin-left:1rem}html.theme--documenter-dark .media-content{flex-basis:auto;flex-grow:1;flex-shrink:1;text-align:inherit}@media screen and (max-width: 768px){html.theme--documenter-dark .media-content{overflow-x:auto}}html.theme--documenter-dark .menu{font-size:1rem}html.theme--documenter-dark .menu.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.menu{font-size:.75rem}html.theme--documenter-dark .menu.is-medium{font-size:1.25rem}html.theme--documenter-dark .menu.is-large{font-size:1.5rem}html.theme--documenter-dark .menu-list{line-height:1.25}html.theme--documenter-dark .menu-list a{border-radius:3px;color:#fff;display:block;padding:0.5em 0.75em}html.theme--documenter-dark .menu-list a:hover{background-color:#282f2f;color:#f2f2f2}html.theme--documenter-dark .menu-list a.is-active{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .menu-list li ul{border-left:1px solid #5e6d6f;margin:.75em;padding-left:.75em}html.theme--documenter-dark .menu-label{color:#fff;font-size:.75em;letter-spacing:.1em;text-transform:uppercase}html.theme--documenter-dark .menu-label:not(:first-child){margin-top:1em}html.theme--documenter-dark .menu-label:not(:last-child){margin-bottom:1em}html.theme--documenter-dark .message{background-color:#282f2f;border-radius:.4em;font-size:1rem}html.theme--documenter-dark .message strong{color:currentColor}html.theme--documenter-dark .message a:not(.button):not(.tag):not(.dropdown-item){color:currentColor;text-decoration:underline}html.theme--documenter-dark .message.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.message{font-size:.75rem}html.theme--documenter-dark .message.is-medium{font-size:1.25rem}html.theme--documenter-dark .message.is-large{font-size:1.5rem}html.theme--documenter-dark .message.is-white{background-color:#fff}html.theme--documenter-dark .message.is-white .message-header{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .message.is-white .message-body{border-color:#fff}html.theme--documenter-dark .message.is-black{background-color:#fafafa}html.theme--documenter-dark .message.is-black .message-header{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .message.is-black .message-body{border-color:#0a0a0a}html.theme--documenter-dark .message.is-light{background-color:#f9fafb}html.theme--documenter-dark .message.is-light .message-header{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .message.is-light .message-body{border-color:#ecf0f1}html.theme--documenter-dark .message.is-dark,html.theme--documenter-dark .content kbd.message{background-color:#f9fafa}html.theme--documenter-dark .message.is-dark .message-header,html.theme--documenter-dark .content kbd.message .message-header{background-color:#282f2f;color:#fff}html.theme--documenter-dark .message.is-dark .message-body,html.theme--documenter-dark .content kbd.message .message-body{border-color:#282f2f}html.theme--documenter-dark .message.is-primary,html.theme--documenter-dark .docstring>section>a.message.docs-sourcelink{background-color:#f1f5f9}html.theme--documenter-dark .message.is-primary .message-header,html.theme--documenter-dark .docstring>section>a.message.docs-sourcelink .message-header{background-color:#375a7f;color:#fff}html.theme--documenter-dark .message.is-primary .message-body,html.theme--documenter-dark .docstring>section>a.message.docs-sourcelink .message-body{border-color:#375a7f;color:#4d7eb2}html.theme--documenter-dark .message.is-link{background-color:#edfdf9}html.theme--documenter-dark .message.is-link .message-header{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .message.is-link .message-body{border-color:#1abc9c;color:#15987e}html.theme--documenter-dark .message.is-info{background-color:#ebf7ff}html.theme--documenter-dark .message.is-info .message-header{background-color:#024c7d;color:#fff}html.theme--documenter-dark .message.is-info .message-body{border-color:#024c7d;color:#0e9dfb}html.theme--documenter-dark .message.is-success{background-color:#ebfff3}html.theme--documenter-dark .message.is-success .message-header{background-color:#008438;color:#fff}html.theme--documenter-dark .message.is-success .message-body{border-color:#008438;color:#00eb64}html.theme--documenter-dark .message.is-warning{background-color:#fffaeb}html.theme--documenter-dark .message.is-warning .message-header{background-color:#ad8100;color:#fff}html.theme--documenter-dark .message.is-warning .message-body{border-color:#ad8100;color:#d19c00}html.theme--documenter-dark .message.is-danger{background-color:#fdeeec}html.theme--documenter-dark .message.is-danger .message-header{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .message.is-danger .message-body{border-color:#9e1b0d;color:#ec311d}html.theme--documenter-dark .message-header{align-items:center;background-color:#fff;border-radius:.4em .4em 0 0;color:rgba(0,0,0,0.7);display:flex;font-weight:700;justify-content:space-between;line-height:1.25;padding:0.75em 1em;position:relative}html.theme--documenter-dark .message-header .delete{flex-grow:0;flex-shrink:0;margin-left:.75em}html.theme--documenter-dark .message-header+.message-body{border-width:0;border-top-left-radius:0;border-top-right-radius:0}html.theme--documenter-dark .message-body{border-color:#5e6d6f;border-radius:.4em;border-style:solid;border-width:0 0 0 4px;color:#fff;padding:1.25em 1.5em}html.theme--documenter-dark .message-body code,html.theme--documenter-dark .message-body pre{background-color:#fff}html.theme--documenter-dark .message-body pre code{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .modal{align-items:center;display:none;flex-direction:column;justify-content:center;overflow:hidden;position:fixed;z-index:40}html.theme--documenter-dark .modal.is-active{display:flex}html.theme--documenter-dark .modal-background{background-color:rgba(10,10,10,0.86)}html.theme--documenter-dark .modal-content,html.theme--documenter-dark .modal-card{margin:0 20px;max-height:calc(100vh - 160px);overflow:auto;position:relative;width:100%}@media screen and (min-width: 769px){html.theme--documenter-dark .modal-content,html.theme--documenter-dark .modal-card{margin:0 auto;max-height:calc(100vh - 40px);width:640px}}html.theme--documenter-dark .modal-close{background:none;height:40px;position:fixed;right:20px;top:20px;width:40px}html.theme--documenter-dark .modal-card{display:flex;flex-direction:column;max-height:calc(100vh - 40px);overflow:hidden;-ms-overflow-y:visible}html.theme--documenter-dark .modal-card-head,html.theme--documenter-dark .modal-card-foot{align-items:center;background-color:#282f2f;display:flex;flex-shrink:0;justify-content:flex-start;padding:20px;position:relative}html.theme--documenter-dark .modal-card-head{border-bottom:1px solid #5e6d6f;border-top-left-radius:8px;border-top-right-radius:8px}html.theme--documenter-dark .modal-card-title{color:#f2f2f2;flex-grow:1;flex-shrink:0;font-size:1.5rem;line-height:1}html.theme--documenter-dark .modal-card-foot{border-bottom-left-radius:8px;border-bottom-right-radius:8px;border-top:1px solid #5e6d6f}html.theme--documenter-dark .modal-card-foot .button:not(:last-child){margin-right:.5em}html.theme--documenter-dark .modal-card-body{-webkit-overflow-scrolling:touch;background-color:#fff;flex-grow:1;flex-shrink:1;overflow:auto;padding:20px}html.theme--documenter-dark .navbar{background-color:#375a7f;min-height:4rem;position:relative;z-index:30}html.theme--documenter-dark .navbar.is-white{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-white .navbar-brand .navbar-link{color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-white .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-white .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-white .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-white .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-white .navbar-brand .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-brand .navbar-link::after{border-color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-burger{color:#0a0a0a}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-white .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-white .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-white .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-white .navbar-end .navbar-link{color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-white .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-white .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-white .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-white .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-white .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-white .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-white .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-white .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-white .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-white .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-white .navbar-end .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-white .navbar-end .navbar-link::after{border-color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-white .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-white .navbar-item.has-dropdown.is-active .navbar-link{background-color:#f2f2f2;color:#0a0a0a}html.theme--documenter-dark .navbar.is-white .navbar-dropdown a.navbar-item.is-active{background-color:#fff;color:#0a0a0a}}html.theme--documenter-dark .navbar.is-black{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-black .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-black .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-black .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-black .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-black .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-black .navbar-brand .navbar-link.is-active{background-color:#000;color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-black .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-black .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-black .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-black .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-black .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-black .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-black .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-black .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-black .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-black .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-black .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-black .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-black .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-black .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-black .navbar-end .navbar-link.is-active{background-color:#000;color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-black .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-black .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-black .navbar-item.has-dropdown.is-active .navbar-link{background-color:#000;color:#fff}html.theme--documenter-dark .navbar.is-black .navbar-dropdown a.navbar-item.is-active{background-color:#0a0a0a;color:#fff}}html.theme--documenter-dark .navbar.is-light{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-light .navbar-brand .navbar-link{color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-light .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-light .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-light .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-light .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-light .navbar-brand .navbar-link.is-active{background-color:#dde4e6;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-brand .navbar-link::after{border-color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-burger{color:rgba(0,0,0,0.7)}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-light .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-light .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-light .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-light .navbar-end .navbar-link{color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-light .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-light .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-light .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-light .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-light .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-light .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-light .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-light .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-light .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-light .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-light .navbar-end .navbar-link.is-active{background-color:#dde4e6;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-light .navbar-end .navbar-link::after{border-color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-light .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-light .navbar-item.has-dropdown.is-active .navbar-link{background-color:#dde4e6;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .navbar.is-light .navbar-dropdown a.navbar-item.is-active{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}}html.theme--documenter-dark .navbar.is-dark,html.theme--documenter-dark .content kbd.navbar{background-color:#282f2f;color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-brand>.navbar-item,html.theme--documenter-dark .content kbd.navbar .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-dark .navbar-brand .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .content kbd.navbar .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-dark .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .content kbd.navbar .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-dark .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-dark .navbar-brand .navbar-link:focus,html.theme--documenter-dark .content kbd.navbar .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-dark .navbar-brand .navbar-link:hover,html.theme--documenter-dark .content kbd.navbar .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-dark .navbar-brand .navbar-link.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-brand .navbar-link.is-active{background-color:#1d2122;color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-brand .navbar-link::after,html.theme--documenter-dark .content kbd.navbar .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-burger,html.theme--documenter-dark .content kbd.navbar .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-dark .navbar-start>.navbar-item,html.theme--documenter-dark .content kbd.navbar .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-dark .navbar-start .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-dark .navbar-end>.navbar-item,html.theme--documenter-dark .content kbd.navbar .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-dark .navbar-end .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .content kbd.navbar .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-dark .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .content kbd.navbar .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-dark .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-dark .navbar-start .navbar-link:focus,html.theme--documenter-dark .content kbd.navbar .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-dark .navbar-start .navbar-link:hover,html.theme--documenter-dark .content kbd.navbar .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-dark .navbar-start .navbar-link.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-dark .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .content kbd.navbar .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-dark .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .content kbd.navbar .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-dark .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-dark .navbar-end .navbar-link:focus,html.theme--documenter-dark .content kbd.navbar .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-dark .navbar-end .navbar-link:hover,html.theme--documenter-dark .content kbd.navbar .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-dark .navbar-end .navbar-link.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-end .navbar-link.is-active{background-color:#1d2122;color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-start .navbar-link::after,html.theme--documenter-dark .content kbd.navbar .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-dark .navbar-end .navbar-link::after,html.theme--documenter-dark .content kbd.navbar .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-dark .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-dark .navbar-item.has-dropdown.is-active .navbar-link,html.theme--documenter-dark .content kbd.navbar .navbar-item.has-dropdown.is-active .navbar-link{background-color:#1d2122;color:#fff}html.theme--documenter-dark .navbar.is-dark .navbar-dropdown a.navbar-item.is-active,html.theme--documenter-dark .content kbd.navbar .navbar-dropdown a.navbar-item.is-active{background-color:#282f2f;color:#fff}}html.theme--documenter-dark .navbar.is-primary,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink{background-color:#375a7f;color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-brand>.navbar-item,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-primary .navbar-brand .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-primary .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-primary .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-primary .navbar-brand .navbar-link:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-primary .navbar-brand .navbar-link:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-primary .navbar-brand .navbar-link.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link.is-active{background-color:#2f4d6d;color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-brand .navbar-link::after,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-burger,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-primary .navbar-start>.navbar-item,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-primary .navbar-start .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-primary .navbar-end>.navbar-item,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-primary .navbar-end .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-primary .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-primary .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-primary .navbar-start .navbar-link:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-primary .navbar-start .navbar-link:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-primary .navbar-start .navbar-link.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-primary .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-primary .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-primary .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-primary .navbar-end .navbar-link:focus,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-primary .navbar-end .navbar-link:hover,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-primary .navbar-end .navbar-link.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link.is-active{background-color:#2f4d6d;color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-start .navbar-link::after,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-primary .navbar-end .navbar-link::after,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-primary .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-primary .navbar-item.has-dropdown.is-active .navbar-link,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown.is-active .navbar-link{background-color:#2f4d6d;color:#fff}html.theme--documenter-dark .navbar.is-primary .navbar-dropdown a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-dropdown a.navbar-item.is-active{background-color:#375a7f;color:#fff}}html.theme--documenter-dark .navbar.is-link{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-link .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-link .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-link .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-link .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-link .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-link .navbar-brand .navbar-link.is-active{background-color:#17a689;color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-link .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-link .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-link .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-link .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-link .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-link .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-link .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-link .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-link .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-link .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-link .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-link .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-link .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-link .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-link .navbar-end .navbar-link.is-active{background-color:#17a689;color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-link .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-link .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-link .navbar-item.has-dropdown.is-active .navbar-link{background-color:#17a689;color:#fff}html.theme--documenter-dark .navbar.is-link .navbar-dropdown a.navbar-item.is-active{background-color:#1abc9c;color:#fff}}html.theme--documenter-dark .navbar.is-info{background-color:#024c7d;color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-info .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-info .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-info .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-info .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-info .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-info .navbar-brand .navbar-link.is-active{background-color:#023d64;color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-info .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-info .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-info .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-info .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-info .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-info .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-info .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-info .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-info .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-info .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-info .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-info .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-info .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-info .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-info .navbar-end .navbar-link.is-active{background-color:#023d64;color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-info .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-info .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-info .navbar-item.has-dropdown.is-active .navbar-link{background-color:#023d64;color:#fff}html.theme--documenter-dark .navbar.is-info .navbar-dropdown a.navbar-item.is-active{background-color:#024c7d;color:#fff}}html.theme--documenter-dark .navbar.is-success{background-color:#008438;color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-success .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-success .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-success .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-success .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-success .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-success .navbar-brand .navbar-link.is-active{background-color:#006b2d;color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-success .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-success .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-success .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-success .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-success .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-success .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-success .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-success .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-success .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-success .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-success .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-success .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-success .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-success .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-success .navbar-end .navbar-link.is-active{background-color:#006b2d;color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-success .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-success .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-success .navbar-item.has-dropdown.is-active .navbar-link{background-color:#006b2d;color:#fff}html.theme--documenter-dark .navbar.is-success .navbar-dropdown a.navbar-item.is-active{background-color:#008438;color:#fff}}html.theme--documenter-dark .navbar.is-warning{background-color:#ad8100;color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-warning .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-warning .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-warning .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-warning .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-warning .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-warning .navbar-brand .navbar-link.is-active{background-color:#946e00;color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-warning .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-warning .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-warning .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-warning .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-warning .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-warning .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-warning .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-warning .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-warning .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-warning .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-warning .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-warning .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-warning .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-warning .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-warning .navbar-end .navbar-link.is-active{background-color:#946e00;color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-warning .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-warning .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-warning .navbar-item.has-dropdown.is-active .navbar-link{background-color:#946e00;color:#fff}html.theme--documenter-dark .navbar.is-warning .navbar-dropdown a.navbar-item.is-active{background-color:#ad8100;color:#fff}}html.theme--documenter-dark .navbar.is-danger{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-brand>.navbar-item,html.theme--documenter-dark .navbar.is-danger .navbar-brand .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-brand>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-danger .navbar-brand>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-danger .navbar-brand>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-danger .navbar-brand .navbar-link:focus,html.theme--documenter-dark .navbar.is-danger .navbar-brand .navbar-link:hover,html.theme--documenter-dark .navbar.is-danger .navbar-brand .navbar-link.is-active{background-color:#86170b;color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-brand .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-burger{color:#fff}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar.is-danger .navbar-start>.navbar-item,html.theme--documenter-dark .navbar.is-danger .navbar-start .navbar-link,html.theme--documenter-dark .navbar.is-danger .navbar-end>.navbar-item,html.theme--documenter-dark .navbar.is-danger .navbar-end .navbar-link{color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-start>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-danger .navbar-start>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-danger .navbar-start>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-danger .navbar-start .navbar-link:focus,html.theme--documenter-dark .navbar.is-danger .navbar-start .navbar-link:hover,html.theme--documenter-dark .navbar.is-danger .navbar-start .navbar-link.is-active,html.theme--documenter-dark .navbar.is-danger .navbar-end>a.navbar-item:focus,html.theme--documenter-dark .navbar.is-danger .navbar-end>a.navbar-item:hover,html.theme--documenter-dark .navbar.is-danger .navbar-end>a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-danger .navbar-end .navbar-link:focus,html.theme--documenter-dark .navbar.is-danger .navbar-end .navbar-link:hover,html.theme--documenter-dark .navbar.is-danger .navbar-end .navbar-link.is-active{background-color:#86170b;color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-start .navbar-link::after,html.theme--documenter-dark .navbar.is-danger .navbar-end .navbar-link::after{border-color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar.is-danger .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar.is-danger .navbar-item.has-dropdown.is-active .navbar-link{background-color:#86170b;color:#fff}html.theme--documenter-dark .navbar.is-danger .navbar-dropdown a.navbar-item.is-active{background-color:#9e1b0d;color:#fff}}html.theme--documenter-dark .navbar>.container{align-items:stretch;display:flex;min-height:4rem;width:100%}html.theme--documenter-dark .navbar.has-shadow{box-shadow:0 2px 0 0 #282f2f}html.theme--documenter-dark .navbar.is-fixed-bottom,html.theme--documenter-dark .navbar.is-fixed-top{left:0;position:fixed;right:0;z-index:30}html.theme--documenter-dark .navbar.is-fixed-bottom{bottom:0}html.theme--documenter-dark .navbar.is-fixed-bottom.has-shadow{box-shadow:0 -2px 0 0 #282f2f}html.theme--documenter-dark .navbar.is-fixed-top{top:0}html.theme--documenter-dark html.has-navbar-fixed-top,html.theme--documenter-dark body.has-navbar-fixed-top{padding-top:4rem}html.theme--documenter-dark html.has-navbar-fixed-bottom,html.theme--documenter-dark body.has-navbar-fixed-bottom{padding-bottom:4rem}html.theme--documenter-dark .navbar-brand,html.theme--documenter-dark .navbar-tabs{align-items:stretch;display:flex;flex-shrink:0;min-height:4rem}html.theme--documenter-dark .navbar-brand a.navbar-item:focus,html.theme--documenter-dark .navbar-brand a.navbar-item:hover{background-color:transparent}html.theme--documenter-dark .navbar-tabs{-webkit-overflow-scrolling:touch;max-width:100vw;overflow-x:auto;overflow-y:hidden}html.theme--documenter-dark .navbar-burger{color:#fff;-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;cursor:pointer;display:block;height:4rem;position:relative;width:4rem;margin-left:auto}html.theme--documenter-dark .navbar-burger span{background-color:currentColor;display:block;height:1px;left:calc(50% - 8px);position:absolute;transform-origin:center;transition-duration:86ms;transition-property:background-color, opacity, transform;transition-timing-function:ease-out;width:16px}html.theme--documenter-dark .navbar-burger span:nth-child(1){top:calc(50% - 6px)}html.theme--documenter-dark .navbar-burger span:nth-child(2){top:calc(50% - 1px)}html.theme--documenter-dark .navbar-burger span:nth-child(3){top:calc(50% + 4px)}html.theme--documenter-dark .navbar-burger:hover{background-color:rgba(0,0,0,0.05)}html.theme--documenter-dark .navbar-burger.is-active span:nth-child(1){transform:translateY(5px) rotate(45deg)}html.theme--documenter-dark .navbar-burger.is-active span:nth-child(2){opacity:0}html.theme--documenter-dark .navbar-burger.is-active span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}html.theme--documenter-dark .navbar-menu{display:none}html.theme--documenter-dark .navbar-item,html.theme--documenter-dark .navbar-link{color:#fff;display:block;line-height:1.5;padding:0.5rem 0.75rem;position:relative}html.theme--documenter-dark .navbar-item .icon:only-child,html.theme--documenter-dark .navbar-link .icon:only-child{margin-left:-0.25rem;margin-right:-0.25rem}html.theme--documenter-dark a.navbar-item,html.theme--documenter-dark .navbar-link{cursor:pointer}html.theme--documenter-dark a.navbar-item:focus,html.theme--documenter-dark a.navbar-item:focus-within,html.theme--documenter-dark a.navbar-item:hover,html.theme--documenter-dark a.navbar-item.is-active,html.theme--documenter-dark .navbar-link:focus,html.theme--documenter-dark .navbar-link:focus-within,html.theme--documenter-dark .navbar-link:hover,html.theme--documenter-dark .navbar-link.is-active{background-color:rgba(0,0,0,0);color:#1abc9c}html.theme--documenter-dark .navbar-item{flex-grow:0;flex-shrink:0}html.theme--documenter-dark .navbar-item img{max-height:1.75rem}html.theme--documenter-dark .navbar-item.has-dropdown{padding:0}html.theme--documenter-dark .navbar-item.is-expanded{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .navbar-item.is-tab{border-bottom:1px solid transparent;min-height:4rem;padding-bottom:calc(0.5rem - 1px)}html.theme--documenter-dark .navbar-item.is-tab:focus,html.theme--documenter-dark .navbar-item.is-tab:hover{background-color:rgba(0,0,0,0);border-bottom-color:#1abc9c}html.theme--documenter-dark .navbar-item.is-tab.is-active{background-color:rgba(0,0,0,0);border-bottom-color:#1abc9c;border-bottom-style:solid;border-bottom-width:3px;color:#1abc9c;padding-bottom:calc(0.5rem - 3px)}html.theme--documenter-dark .navbar-content{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .navbar-link:not(.is-arrowless){padding-right:2.5em}html.theme--documenter-dark .navbar-link:not(.is-arrowless)::after{border-color:#fff;margin-top:-0.375em;right:1.125em}html.theme--documenter-dark .navbar-dropdown{font-size:0.875rem;padding-bottom:0.5rem;padding-top:0.5rem}html.theme--documenter-dark .navbar-dropdown .navbar-item{padding-left:1.5rem;padding-right:1.5rem}html.theme--documenter-dark .navbar-divider{background-color:rgba(0,0,0,0.2);border:none;display:none;height:2px;margin:0.5rem 0}@media screen and (max-width: 1055px){html.theme--documenter-dark .navbar>.container{display:block}html.theme--documenter-dark .navbar-brand .navbar-item,html.theme--documenter-dark .navbar-tabs .navbar-item{align-items:center;display:flex}html.theme--documenter-dark .navbar-link::after{display:none}html.theme--documenter-dark .navbar-menu{background-color:#375a7f;box-shadow:0 8px 16px rgba(10,10,10,0.1);padding:0.5rem 0}html.theme--documenter-dark .navbar-menu.is-active{display:block}html.theme--documenter-dark .navbar.is-fixed-bottom-touch,html.theme--documenter-dark .navbar.is-fixed-top-touch{left:0;position:fixed;right:0;z-index:30}html.theme--documenter-dark .navbar.is-fixed-bottom-touch{bottom:0}html.theme--documenter-dark .navbar.is-fixed-bottom-touch.has-shadow{box-shadow:0 -2px 3px rgba(10,10,10,0.1)}html.theme--documenter-dark .navbar.is-fixed-top-touch{top:0}html.theme--documenter-dark .navbar.is-fixed-top .navbar-menu,html.theme--documenter-dark .navbar.is-fixed-top-touch .navbar-menu{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 4rem);overflow:auto}html.theme--documenter-dark html.has-navbar-fixed-top-touch,html.theme--documenter-dark body.has-navbar-fixed-top-touch{padding-top:4rem}html.theme--documenter-dark html.has-navbar-fixed-bottom-touch,html.theme--documenter-dark body.has-navbar-fixed-bottom-touch{padding-bottom:4rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .navbar,html.theme--documenter-dark .navbar-menu,html.theme--documenter-dark .navbar-start,html.theme--documenter-dark .navbar-end{align-items:stretch;display:flex}html.theme--documenter-dark .navbar{min-height:4rem}html.theme--documenter-dark .navbar.is-spaced{padding:1rem 2rem}html.theme--documenter-dark .navbar.is-spaced .navbar-start,html.theme--documenter-dark .navbar.is-spaced .navbar-end{align-items:center}html.theme--documenter-dark .navbar.is-spaced a.navbar-item,html.theme--documenter-dark .navbar.is-spaced .navbar-link{border-radius:.4em}html.theme--documenter-dark .navbar.is-transparent a.navbar-item:focus,html.theme--documenter-dark .navbar.is-transparent a.navbar-item:hover,html.theme--documenter-dark .navbar.is-transparent a.navbar-item.is-active,html.theme--documenter-dark .navbar.is-transparent .navbar-link:focus,html.theme--documenter-dark .navbar.is-transparent .navbar-link:hover,html.theme--documenter-dark .navbar.is-transparent .navbar-link.is-active{background-color:transparent !important}html.theme--documenter-dark .navbar.is-transparent .navbar-item.has-dropdown.is-active .navbar-link,html.theme--documenter-dark .navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:focus .navbar-link,html.theme--documenter-dark .navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:focus-within .navbar-link,html.theme--documenter-dark .navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:hover .navbar-link{background-color:transparent !important}html.theme--documenter-dark .navbar.is-transparent .navbar-dropdown a.navbar-item:focus,html.theme--documenter-dark .navbar.is-transparent .navbar-dropdown a.navbar-item:hover{background-color:rgba(0,0,0,0);color:#dbdee0}html.theme--documenter-dark .navbar.is-transparent .navbar-dropdown a.navbar-item.is-active{background-color:rgba(0,0,0,0);color:#1abc9c}html.theme--documenter-dark .navbar-burger{display:none}html.theme--documenter-dark .navbar-item,html.theme--documenter-dark .navbar-link{align-items:center;display:flex}html.theme--documenter-dark .navbar-item.has-dropdown{align-items:stretch}html.theme--documenter-dark .navbar-item.has-dropdown-up .navbar-link::after{transform:rotate(135deg) translate(0.25em, -0.25em)}html.theme--documenter-dark .navbar-item.has-dropdown-up .navbar-dropdown{border-bottom:1px solid rgba(0,0,0,0.2);border-radius:8px 8px 0 0;border-top:none;bottom:100%;box-shadow:0 -8px 8px rgba(10,10,10,0.1);top:auto}html.theme--documenter-dark .navbar-item.is-active .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:focus .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:focus-within .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:hover .navbar-dropdown{display:block}.navbar.is-spaced html.theme--documenter-dark .navbar-item.is-active .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-active .navbar-dropdown.is-boxed,.navbar.is-spaced html.theme--documenter-dark .navbar-item.is-hoverable:focus .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:focus .navbar-dropdown.is-boxed,.navbar.is-spaced html.theme--documenter-dark .navbar-item.is-hoverable:focus-within .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:focus-within .navbar-dropdown.is-boxed,.navbar.is-spaced html.theme--documenter-dark .navbar-item.is-hoverable:hover .navbar-dropdown,html.theme--documenter-dark .navbar-item.is-hoverable:hover .navbar-dropdown.is-boxed{opacity:1;pointer-events:auto;transform:translateY(0)}html.theme--documenter-dark .navbar-menu{flex-grow:1;flex-shrink:0}html.theme--documenter-dark .navbar-start{justify-content:flex-start;margin-right:auto}html.theme--documenter-dark .navbar-end{justify-content:flex-end;margin-left:auto}html.theme--documenter-dark .navbar-dropdown{background-color:#375a7f;border-bottom-left-radius:8px;border-bottom-right-radius:8px;border-top:1px solid rgba(0,0,0,0.2);box-shadow:0 8px 8px rgba(10,10,10,0.1);display:none;font-size:0.875rem;left:0;min-width:100%;position:absolute;top:100%;z-index:20}html.theme--documenter-dark .navbar-dropdown .navbar-item{padding:0.375rem 1rem;white-space:nowrap}html.theme--documenter-dark .navbar-dropdown a.navbar-item{padding-right:3rem}html.theme--documenter-dark .navbar-dropdown a.navbar-item:focus,html.theme--documenter-dark .navbar-dropdown a.navbar-item:hover{background-color:rgba(0,0,0,0);color:#dbdee0}html.theme--documenter-dark .navbar-dropdown a.navbar-item.is-active{background-color:rgba(0,0,0,0);color:#1abc9c}.navbar.is-spaced html.theme--documenter-dark .navbar-dropdown,html.theme--documenter-dark .navbar-dropdown.is-boxed{border-radius:8px;border-top:none;box-shadow:0 8px 8px rgba(10,10,10,0.1), 0 0 0 1px rgba(10,10,10,0.1);display:block;opacity:0;pointer-events:none;top:calc(100% + (-4px));transform:translateY(-5px);transition-duration:86ms;transition-property:opacity, transform}html.theme--documenter-dark .navbar-dropdown.is-right{left:auto;right:0}html.theme--documenter-dark .navbar-divider{display:block}html.theme--documenter-dark .navbar>.container .navbar-brand,html.theme--documenter-dark .container>.navbar .navbar-brand{margin-left:-.75rem}html.theme--documenter-dark .navbar>.container .navbar-menu,html.theme--documenter-dark .container>.navbar .navbar-menu{margin-right:-.75rem}html.theme--documenter-dark .navbar.is-fixed-bottom-desktop,html.theme--documenter-dark .navbar.is-fixed-top-desktop{left:0;position:fixed;right:0;z-index:30}html.theme--documenter-dark .navbar.is-fixed-bottom-desktop{bottom:0}html.theme--documenter-dark .navbar.is-fixed-bottom-desktop.has-shadow{box-shadow:0 -2px 3px rgba(10,10,10,0.1)}html.theme--documenter-dark .navbar.is-fixed-top-desktop{top:0}html.theme--documenter-dark html.has-navbar-fixed-top-desktop,html.theme--documenter-dark body.has-navbar-fixed-top-desktop{padding-top:4rem}html.theme--documenter-dark html.has-navbar-fixed-bottom-desktop,html.theme--documenter-dark body.has-navbar-fixed-bottom-desktop{padding-bottom:4rem}html.theme--documenter-dark html.has-spaced-navbar-fixed-top,html.theme--documenter-dark body.has-spaced-navbar-fixed-top{padding-top:6rem}html.theme--documenter-dark html.has-spaced-navbar-fixed-bottom,html.theme--documenter-dark body.has-spaced-navbar-fixed-bottom{padding-bottom:6rem}html.theme--documenter-dark a.navbar-item.is-active,html.theme--documenter-dark .navbar-link.is-active{color:#1abc9c}html.theme--documenter-dark a.navbar-item.is-active:not(:focus):not(:hover),html.theme--documenter-dark .navbar-link.is-active:not(:focus):not(:hover){background-color:rgba(0,0,0,0)}html.theme--documenter-dark .navbar-item.has-dropdown:focus .navbar-link,html.theme--documenter-dark .navbar-item.has-dropdown:hover .navbar-link,html.theme--documenter-dark .navbar-item.has-dropdown.is-active .navbar-link{background-color:rgba(0,0,0,0)}}html.theme--documenter-dark .hero.is-fullheight-with-navbar{min-height:calc(100vh - 4rem)}html.theme--documenter-dark .pagination{font-size:1rem;margin:-.25rem}html.theme--documenter-dark .pagination.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.pagination{font-size:.75rem}html.theme--documenter-dark .pagination.is-medium{font-size:1.25rem}html.theme--documenter-dark .pagination.is-large{font-size:1.5rem}html.theme--documenter-dark .pagination.is-rounded .pagination-previous,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.pagination .pagination-previous,html.theme--documenter-dark .pagination.is-rounded .pagination-next,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.pagination .pagination-next{padding-left:1em;padding-right:1em;border-radius:9999px}html.theme--documenter-dark .pagination.is-rounded .pagination-link,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.pagination .pagination-link{border-radius:9999px}html.theme--documenter-dark .pagination,html.theme--documenter-dark .pagination-list{align-items:center;display:flex;justify-content:center;text-align:center}html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-ellipsis{font-size:1em;justify-content:center;margin:.25rem;padding-left:.5em;padding-right:.5em;text-align:center}html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-link{border-color:#5e6d6f;color:#1abc9c;min-width:2.5em}html.theme--documenter-dark .pagination-previous:hover,html.theme--documenter-dark .pagination-next:hover,html.theme--documenter-dark .pagination-link:hover{border-color:#8c9b9d;color:#1dd2af}html.theme--documenter-dark .pagination-previous:focus,html.theme--documenter-dark .pagination-next:focus,html.theme--documenter-dark .pagination-link:focus{border-color:#8c9b9d}html.theme--documenter-dark .pagination-previous:active,html.theme--documenter-dark .pagination-next:active,html.theme--documenter-dark .pagination-link:active{box-shadow:inset 0 1px 2px rgba(10,10,10,0.2)}html.theme--documenter-dark .pagination-previous[disabled],html.theme--documenter-dark .pagination-previous.is-disabled,html.theme--documenter-dark .pagination-next[disabled],html.theme--documenter-dark .pagination-next.is-disabled,html.theme--documenter-dark .pagination-link[disabled],html.theme--documenter-dark .pagination-link.is-disabled{background-color:#5e6d6f;border-color:#5e6d6f;box-shadow:none;color:#fff;opacity:0.5}html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next{padding-left:.75em;padding-right:.75em;white-space:nowrap}html.theme--documenter-dark .pagination-link.is-current{background-color:#1abc9c;border-color:#1abc9c;color:#fff}html.theme--documenter-dark .pagination-ellipsis{color:#8c9b9d;pointer-events:none}html.theme--documenter-dark .pagination-list{flex-wrap:wrap}html.theme--documenter-dark .pagination-list li{list-style:none}@media screen and (max-width: 768px){html.theme--documenter-dark .pagination{flex-wrap:wrap}html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .pagination-list li{flex-grow:1;flex-shrink:1}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .pagination-list{flex-grow:1;flex-shrink:1;justify-content:flex-start;order:1}html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-ellipsis{margin-bottom:0;margin-top:0}html.theme--documenter-dark .pagination-previous{order:2}html.theme--documenter-dark .pagination-next{order:3}html.theme--documenter-dark .pagination{justify-content:space-between;margin-bottom:0;margin-top:0}html.theme--documenter-dark .pagination.is-centered .pagination-previous{order:1}html.theme--documenter-dark .pagination.is-centered .pagination-list{justify-content:center;order:2}html.theme--documenter-dark .pagination.is-centered .pagination-next{order:3}html.theme--documenter-dark .pagination.is-right .pagination-previous{order:1}html.theme--documenter-dark .pagination.is-right .pagination-next{order:2}html.theme--documenter-dark .pagination.is-right .pagination-list{justify-content:flex-end;order:3}}html.theme--documenter-dark .panel{border-radius:8px;box-shadow:#171717;font-size:1rem}html.theme--documenter-dark .panel:not(:last-child){margin-bottom:1.5rem}html.theme--documenter-dark .panel.is-white .panel-heading{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .panel.is-white .panel-tabs a.is-active{border-bottom-color:#fff}html.theme--documenter-dark .panel.is-white .panel-block.is-active .panel-icon{color:#fff}html.theme--documenter-dark .panel.is-black .panel-heading{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .panel.is-black .panel-tabs a.is-active{border-bottom-color:#0a0a0a}html.theme--documenter-dark .panel.is-black .panel-block.is-active .panel-icon{color:#0a0a0a}html.theme--documenter-dark .panel.is-light .panel-heading{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .panel.is-light .panel-tabs a.is-active{border-bottom-color:#ecf0f1}html.theme--documenter-dark .panel.is-light .panel-block.is-active .panel-icon{color:#ecf0f1}html.theme--documenter-dark .panel.is-dark .panel-heading,html.theme--documenter-dark .content kbd.panel .panel-heading{background-color:#282f2f;color:#fff}html.theme--documenter-dark .panel.is-dark .panel-tabs a.is-active,html.theme--documenter-dark .content kbd.panel .panel-tabs a.is-active{border-bottom-color:#282f2f}html.theme--documenter-dark .panel.is-dark .panel-block.is-active .panel-icon,html.theme--documenter-dark .content kbd.panel .panel-block.is-active .panel-icon{color:#282f2f}html.theme--documenter-dark .panel.is-primary .panel-heading,html.theme--documenter-dark .docstring>section>a.panel.docs-sourcelink .panel-heading{background-color:#375a7f;color:#fff}html.theme--documenter-dark .panel.is-primary .panel-tabs a.is-active,html.theme--documenter-dark .docstring>section>a.panel.docs-sourcelink .panel-tabs a.is-active{border-bottom-color:#375a7f}html.theme--documenter-dark .panel.is-primary .panel-block.is-active .panel-icon,html.theme--documenter-dark .docstring>section>a.panel.docs-sourcelink .panel-block.is-active .panel-icon{color:#375a7f}html.theme--documenter-dark .panel.is-link .panel-heading{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .panel.is-link .panel-tabs a.is-active{border-bottom-color:#1abc9c}html.theme--documenter-dark .panel.is-link .panel-block.is-active .panel-icon{color:#1abc9c}html.theme--documenter-dark .panel.is-info .panel-heading{background-color:#024c7d;color:#fff}html.theme--documenter-dark .panel.is-info .panel-tabs a.is-active{border-bottom-color:#024c7d}html.theme--documenter-dark .panel.is-info .panel-block.is-active .panel-icon{color:#024c7d}html.theme--documenter-dark .panel.is-success .panel-heading{background-color:#008438;color:#fff}html.theme--documenter-dark .panel.is-success .panel-tabs a.is-active{border-bottom-color:#008438}html.theme--documenter-dark .panel.is-success .panel-block.is-active .panel-icon{color:#008438}html.theme--documenter-dark .panel.is-warning .panel-heading{background-color:#ad8100;color:#fff}html.theme--documenter-dark .panel.is-warning .panel-tabs a.is-active{border-bottom-color:#ad8100}html.theme--documenter-dark .panel.is-warning .panel-block.is-active .panel-icon{color:#ad8100}html.theme--documenter-dark .panel.is-danger .panel-heading{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .panel.is-danger .panel-tabs a.is-active{border-bottom-color:#9e1b0d}html.theme--documenter-dark .panel.is-danger .panel-block.is-active .panel-icon{color:#9e1b0d}html.theme--documenter-dark .panel-tabs:not(:last-child),html.theme--documenter-dark .panel-block:not(:last-child){border-bottom:1px solid #ededed}html.theme--documenter-dark .panel-heading{background-color:#343c3d;border-radius:8px 8px 0 0;color:#f2f2f2;font-size:1.25em;font-weight:700;line-height:1.25;padding:0.75em 1em}html.theme--documenter-dark .panel-tabs{align-items:flex-end;display:flex;font-size:.875em;justify-content:center}html.theme--documenter-dark .panel-tabs a{border-bottom:1px solid #5e6d6f;margin-bottom:-1px;padding:0.5em}html.theme--documenter-dark .panel-tabs a.is-active{border-bottom-color:#343c3d;color:#17a689}html.theme--documenter-dark .panel-list a{color:#fff}html.theme--documenter-dark .panel-list a:hover{color:#1abc9c}html.theme--documenter-dark .panel-block{align-items:center;color:#f2f2f2;display:flex;justify-content:flex-start;padding:0.5em 0.75em}html.theme--documenter-dark .panel-block input[type="checkbox"]{margin-right:.75em}html.theme--documenter-dark .panel-block>.control{flex-grow:1;flex-shrink:1;width:100%}html.theme--documenter-dark .panel-block.is-wrapped{flex-wrap:wrap}html.theme--documenter-dark .panel-block.is-active{border-left-color:#1abc9c;color:#17a689}html.theme--documenter-dark .panel-block.is-active .panel-icon{color:#1abc9c}html.theme--documenter-dark .panel-block:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}html.theme--documenter-dark a.panel-block,html.theme--documenter-dark label.panel-block{cursor:pointer}html.theme--documenter-dark a.panel-block:hover,html.theme--documenter-dark label.panel-block:hover{background-color:#282f2f}html.theme--documenter-dark .panel-icon{display:inline-block;font-size:14px;height:1em;line-height:1em;text-align:center;vertical-align:top;width:1em;color:#fff;margin-right:.75em}html.theme--documenter-dark .panel-icon .fa{font-size:inherit;line-height:inherit}html.theme--documenter-dark .tabs{-webkit-overflow-scrolling:touch;align-items:stretch;display:flex;font-size:1rem;justify-content:space-between;overflow:hidden;overflow-x:auto;white-space:nowrap}html.theme--documenter-dark .tabs a{align-items:center;border-bottom-color:#5e6d6f;border-bottom-style:solid;border-bottom-width:1px;color:#fff;display:flex;justify-content:center;margin-bottom:-1px;padding:0.5em 1em;vertical-align:top}html.theme--documenter-dark .tabs a:hover{border-bottom-color:#f2f2f2;color:#f2f2f2}html.theme--documenter-dark .tabs li{display:block}html.theme--documenter-dark .tabs li.is-active a{border-bottom-color:#1abc9c;color:#1abc9c}html.theme--documenter-dark .tabs ul{align-items:center;border-bottom-color:#5e6d6f;border-bottom-style:solid;border-bottom-width:1px;display:flex;flex-grow:1;flex-shrink:0;justify-content:flex-start}html.theme--documenter-dark .tabs ul.is-left{padding-right:0.75em}html.theme--documenter-dark .tabs ul.is-center{flex:none;justify-content:center;padding-left:0.75em;padding-right:0.75em}html.theme--documenter-dark .tabs ul.is-right{justify-content:flex-end;padding-left:0.75em}html.theme--documenter-dark .tabs .icon:first-child{margin-right:.5em}html.theme--documenter-dark .tabs .icon:last-child{margin-left:.5em}html.theme--documenter-dark .tabs.is-centered ul{justify-content:center}html.theme--documenter-dark .tabs.is-right ul{justify-content:flex-end}html.theme--documenter-dark .tabs.is-boxed a{border:1px solid transparent;border-radius:.4em .4em 0 0}html.theme--documenter-dark .tabs.is-boxed a:hover{background-color:#282f2f;border-bottom-color:#5e6d6f}html.theme--documenter-dark .tabs.is-boxed li.is-active a{background-color:#fff;border-color:#5e6d6f;border-bottom-color:rgba(0,0,0,0) !important}html.theme--documenter-dark .tabs.is-fullwidth li{flex-grow:1;flex-shrink:0}html.theme--documenter-dark .tabs.is-toggle a{border-color:#5e6d6f;border-style:solid;border-width:1px;margin-bottom:0;position:relative}html.theme--documenter-dark .tabs.is-toggle a:hover{background-color:#282f2f;border-color:#8c9b9d;z-index:2}html.theme--documenter-dark .tabs.is-toggle li+li{margin-left:-1px}html.theme--documenter-dark .tabs.is-toggle li:first-child a{border-top-left-radius:.4em;border-bottom-left-radius:.4em}html.theme--documenter-dark .tabs.is-toggle li:last-child a{border-top-right-radius:.4em;border-bottom-right-radius:.4em}html.theme--documenter-dark .tabs.is-toggle li.is-active a{background-color:#1abc9c;border-color:#1abc9c;color:#fff;z-index:1}html.theme--documenter-dark .tabs.is-toggle ul{border-bottom:none}html.theme--documenter-dark .tabs.is-toggle.is-toggle-rounded li:first-child a{border-bottom-left-radius:9999px;border-top-left-radius:9999px;padding-left:1.25em}html.theme--documenter-dark .tabs.is-toggle.is-toggle-rounded li:last-child a{border-bottom-right-radius:9999px;border-top-right-radius:9999px;padding-right:1.25em}html.theme--documenter-dark .tabs.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.tabs{font-size:.75rem}html.theme--documenter-dark .tabs.is-medium{font-size:1.25rem}html.theme--documenter-dark .tabs.is-large{font-size:1.5rem}html.theme--documenter-dark .column{display:block;flex-basis:0;flex-grow:1;flex-shrink:1;padding:.75rem}.columns.is-mobile>html.theme--documenter-dark .column.is-narrow{flex:none;width:unset}.columns.is-mobile>html.theme--documenter-dark .column.is-full{flex:none;width:100%}.columns.is-mobile>html.theme--documenter-dark .column.is-three-quarters{flex:none;width:75%}.columns.is-mobile>html.theme--documenter-dark .column.is-two-thirds{flex:none;width:66.6666%}.columns.is-mobile>html.theme--documenter-dark .column.is-half{flex:none;width:50%}.columns.is-mobile>html.theme--documenter-dark .column.is-one-third{flex:none;width:33.3333%}.columns.is-mobile>html.theme--documenter-dark .column.is-one-quarter{flex:none;width:25%}.columns.is-mobile>html.theme--documenter-dark .column.is-one-fifth{flex:none;width:20%}.columns.is-mobile>html.theme--documenter-dark .column.is-two-fifths{flex:none;width:40%}.columns.is-mobile>html.theme--documenter-dark .column.is-three-fifths{flex:none;width:60%}.columns.is-mobile>html.theme--documenter-dark .column.is-four-fifths{flex:none;width:80%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-three-quarters{margin-left:75%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-two-thirds{margin-left:66.6666%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-half{margin-left:50%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-one-third{margin-left:33.3333%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-one-quarter{margin-left:25%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-one-fifth{margin-left:20%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-two-fifths{margin-left:40%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-three-fifths{margin-left:60%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-four-fifths{margin-left:80%}.columns.is-mobile>html.theme--documenter-dark .column.is-0{flex:none;width:0%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-0{margin-left:0%}.columns.is-mobile>html.theme--documenter-dark .column.is-1{flex:none;width:8.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-1{margin-left:8.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-2{flex:none;width:16.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-2{margin-left:16.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-3{flex:none;width:25%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-3{margin-left:25%}.columns.is-mobile>html.theme--documenter-dark .column.is-4{flex:none;width:33.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-4{margin-left:33.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-5{flex:none;width:41.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-5{margin-left:41.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-6{flex:none;width:50%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-6{margin-left:50%}.columns.is-mobile>html.theme--documenter-dark .column.is-7{flex:none;width:58.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-7{margin-left:58.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-8{flex:none;width:66.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-8{margin-left:66.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-9{flex:none;width:75%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-9{margin-left:75%}.columns.is-mobile>html.theme--documenter-dark .column.is-10{flex:none;width:83.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-10{margin-left:83.33333337%}.columns.is-mobile>html.theme--documenter-dark .column.is-11{flex:none;width:91.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-11{margin-left:91.66666674%}.columns.is-mobile>html.theme--documenter-dark .column.is-12{flex:none;width:100%}.columns.is-mobile>html.theme--documenter-dark .column.is-offset-12{margin-left:100%}@media screen and (max-width: 768px){html.theme--documenter-dark .column.is-narrow-mobile{flex:none;width:unset}html.theme--documenter-dark .column.is-full-mobile{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters-mobile{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds-mobile{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half-mobile{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third-mobile{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter-mobile{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth-mobile{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths-mobile{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths-mobile{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths-mobile{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters-mobile{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds-mobile{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half-mobile{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third-mobile{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter-mobile{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth-mobile{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths-mobile{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths-mobile{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths-mobile{margin-left:80%}html.theme--documenter-dark .column.is-0-mobile{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0-mobile{margin-left:0%}html.theme--documenter-dark .column.is-1-mobile{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1-mobile{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2-mobile{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2-mobile{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3-mobile{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3-mobile{margin-left:25%}html.theme--documenter-dark .column.is-4-mobile{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4-mobile{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5-mobile{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5-mobile{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6-mobile{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6-mobile{margin-left:50%}html.theme--documenter-dark .column.is-7-mobile{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7-mobile{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8-mobile{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8-mobile{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9-mobile{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9-mobile{margin-left:75%}html.theme--documenter-dark .column.is-10-mobile{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10-mobile{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11-mobile{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11-mobile{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12-mobile{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12-mobile{margin-left:100%}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .column.is-narrow,html.theme--documenter-dark .column.is-narrow-tablet{flex:none;width:unset}html.theme--documenter-dark .column.is-full,html.theme--documenter-dark .column.is-full-tablet{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters,html.theme--documenter-dark .column.is-three-quarters-tablet{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds,html.theme--documenter-dark .column.is-two-thirds-tablet{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half,html.theme--documenter-dark .column.is-half-tablet{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third,html.theme--documenter-dark .column.is-one-third-tablet{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter,html.theme--documenter-dark .column.is-one-quarter-tablet{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth,html.theme--documenter-dark .column.is-one-fifth-tablet{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths,html.theme--documenter-dark .column.is-two-fifths-tablet{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths,html.theme--documenter-dark .column.is-three-fifths-tablet{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths,html.theme--documenter-dark .column.is-four-fifths-tablet{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters,html.theme--documenter-dark .column.is-offset-three-quarters-tablet{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds,html.theme--documenter-dark .column.is-offset-two-thirds-tablet{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half,html.theme--documenter-dark .column.is-offset-half-tablet{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third,html.theme--documenter-dark .column.is-offset-one-third-tablet{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter,html.theme--documenter-dark .column.is-offset-one-quarter-tablet{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth,html.theme--documenter-dark .column.is-offset-one-fifth-tablet{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths,html.theme--documenter-dark .column.is-offset-two-fifths-tablet{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths,html.theme--documenter-dark .column.is-offset-three-fifths-tablet{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths,html.theme--documenter-dark .column.is-offset-four-fifths-tablet{margin-left:80%}html.theme--documenter-dark .column.is-0,html.theme--documenter-dark .column.is-0-tablet{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0,html.theme--documenter-dark .column.is-offset-0-tablet{margin-left:0%}html.theme--documenter-dark .column.is-1,html.theme--documenter-dark .column.is-1-tablet{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1,html.theme--documenter-dark .column.is-offset-1-tablet{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2,html.theme--documenter-dark .column.is-2-tablet{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2,html.theme--documenter-dark .column.is-offset-2-tablet{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3,html.theme--documenter-dark .column.is-3-tablet{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3,html.theme--documenter-dark .column.is-offset-3-tablet{margin-left:25%}html.theme--documenter-dark .column.is-4,html.theme--documenter-dark .column.is-4-tablet{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4,html.theme--documenter-dark .column.is-offset-4-tablet{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5,html.theme--documenter-dark .column.is-5-tablet{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5,html.theme--documenter-dark .column.is-offset-5-tablet{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6,html.theme--documenter-dark .column.is-6-tablet{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6,html.theme--documenter-dark .column.is-offset-6-tablet{margin-left:50%}html.theme--documenter-dark .column.is-7,html.theme--documenter-dark .column.is-7-tablet{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7,html.theme--documenter-dark .column.is-offset-7-tablet{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8,html.theme--documenter-dark .column.is-8-tablet{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8,html.theme--documenter-dark .column.is-offset-8-tablet{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9,html.theme--documenter-dark .column.is-9-tablet{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9,html.theme--documenter-dark .column.is-offset-9-tablet{margin-left:75%}html.theme--documenter-dark .column.is-10,html.theme--documenter-dark .column.is-10-tablet{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10,html.theme--documenter-dark .column.is-offset-10-tablet{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11,html.theme--documenter-dark .column.is-11-tablet{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11,html.theme--documenter-dark .column.is-offset-11-tablet{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12,html.theme--documenter-dark .column.is-12-tablet{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12,html.theme--documenter-dark .column.is-offset-12-tablet{margin-left:100%}}@media screen and (max-width: 1055px){html.theme--documenter-dark .column.is-narrow-touch{flex:none;width:unset}html.theme--documenter-dark .column.is-full-touch{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters-touch{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds-touch{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half-touch{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third-touch{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter-touch{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth-touch{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths-touch{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths-touch{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths-touch{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters-touch{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds-touch{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half-touch{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third-touch{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter-touch{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth-touch{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths-touch{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths-touch{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths-touch{margin-left:80%}html.theme--documenter-dark .column.is-0-touch{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0-touch{margin-left:0%}html.theme--documenter-dark .column.is-1-touch{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1-touch{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2-touch{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2-touch{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3-touch{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3-touch{margin-left:25%}html.theme--documenter-dark .column.is-4-touch{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4-touch{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5-touch{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5-touch{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6-touch{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6-touch{margin-left:50%}html.theme--documenter-dark .column.is-7-touch{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7-touch{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8-touch{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8-touch{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9-touch{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9-touch{margin-left:75%}html.theme--documenter-dark .column.is-10-touch{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10-touch{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11-touch{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11-touch{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12-touch{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12-touch{margin-left:100%}}@media screen and (min-width: 1056px){html.theme--documenter-dark .column.is-narrow-desktop{flex:none;width:unset}html.theme--documenter-dark .column.is-full-desktop{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters-desktop{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds-desktop{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half-desktop{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third-desktop{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter-desktop{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth-desktop{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths-desktop{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths-desktop{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths-desktop{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters-desktop{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds-desktop{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half-desktop{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third-desktop{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter-desktop{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth-desktop{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths-desktop{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths-desktop{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths-desktop{margin-left:80%}html.theme--documenter-dark .column.is-0-desktop{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0-desktop{margin-left:0%}html.theme--documenter-dark .column.is-1-desktop{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1-desktop{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2-desktop{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2-desktop{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3-desktop{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3-desktop{margin-left:25%}html.theme--documenter-dark .column.is-4-desktop{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4-desktop{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5-desktop{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5-desktop{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6-desktop{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6-desktop{margin-left:50%}html.theme--documenter-dark .column.is-7-desktop{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7-desktop{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8-desktop{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8-desktop{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9-desktop{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9-desktop{margin-left:75%}html.theme--documenter-dark .column.is-10-desktop{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10-desktop{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11-desktop{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11-desktop{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12-desktop{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12-desktop{margin-left:100%}}@media screen and (min-width: 1216px){html.theme--documenter-dark .column.is-narrow-widescreen{flex:none;width:unset}html.theme--documenter-dark .column.is-full-widescreen{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters-widescreen{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds-widescreen{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half-widescreen{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third-widescreen{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter-widescreen{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth-widescreen{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths-widescreen{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths-widescreen{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths-widescreen{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters-widescreen{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds-widescreen{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half-widescreen{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third-widescreen{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter-widescreen{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth-widescreen{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths-widescreen{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths-widescreen{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths-widescreen{margin-left:80%}html.theme--documenter-dark .column.is-0-widescreen{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0-widescreen{margin-left:0%}html.theme--documenter-dark .column.is-1-widescreen{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1-widescreen{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2-widescreen{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2-widescreen{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3-widescreen{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3-widescreen{margin-left:25%}html.theme--documenter-dark .column.is-4-widescreen{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4-widescreen{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5-widescreen{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5-widescreen{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6-widescreen{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6-widescreen{margin-left:50%}html.theme--documenter-dark .column.is-7-widescreen{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7-widescreen{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8-widescreen{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8-widescreen{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9-widescreen{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9-widescreen{margin-left:75%}html.theme--documenter-dark .column.is-10-widescreen{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10-widescreen{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11-widescreen{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11-widescreen{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12-widescreen{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12-widescreen{margin-left:100%}}@media screen and (min-width: 1408px){html.theme--documenter-dark .column.is-narrow-fullhd{flex:none;width:unset}html.theme--documenter-dark .column.is-full-fullhd{flex:none;width:100%}html.theme--documenter-dark .column.is-three-quarters-fullhd{flex:none;width:75%}html.theme--documenter-dark .column.is-two-thirds-fullhd{flex:none;width:66.6666%}html.theme--documenter-dark .column.is-half-fullhd{flex:none;width:50%}html.theme--documenter-dark .column.is-one-third-fullhd{flex:none;width:33.3333%}html.theme--documenter-dark .column.is-one-quarter-fullhd{flex:none;width:25%}html.theme--documenter-dark .column.is-one-fifth-fullhd{flex:none;width:20%}html.theme--documenter-dark .column.is-two-fifths-fullhd{flex:none;width:40%}html.theme--documenter-dark .column.is-three-fifths-fullhd{flex:none;width:60%}html.theme--documenter-dark .column.is-four-fifths-fullhd{flex:none;width:80%}html.theme--documenter-dark .column.is-offset-three-quarters-fullhd{margin-left:75%}html.theme--documenter-dark .column.is-offset-two-thirds-fullhd{margin-left:66.6666%}html.theme--documenter-dark .column.is-offset-half-fullhd{margin-left:50%}html.theme--documenter-dark .column.is-offset-one-third-fullhd{margin-left:33.3333%}html.theme--documenter-dark .column.is-offset-one-quarter-fullhd{margin-left:25%}html.theme--documenter-dark .column.is-offset-one-fifth-fullhd{margin-left:20%}html.theme--documenter-dark .column.is-offset-two-fifths-fullhd{margin-left:40%}html.theme--documenter-dark .column.is-offset-three-fifths-fullhd{margin-left:60%}html.theme--documenter-dark .column.is-offset-four-fifths-fullhd{margin-left:80%}html.theme--documenter-dark .column.is-0-fullhd{flex:none;width:0%}html.theme--documenter-dark .column.is-offset-0-fullhd{margin-left:0%}html.theme--documenter-dark .column.is-1-fullhd{flex:none;width:8.33333337%}html.theme--documenter-dark .column.is-offset-1-fullhd{margin-left:8.33333337%}html.theme--documenter-dark .column.is-2-fullhd{flex:none;width:16.66666674%}html.theme--documenter-dark .column.is-offset-2-fullhd{margin-left:16.66666674%}html.theme--documenter-dark .column.is-3-fullhd{flex:none;width:25%}html.theme--documenter-dark .column.is-offset-3-fullhd{margin-left:25%}html.theme--documenter-dark .column.is-4-fullhd{flex:none;width:33.33333337%}html.theme--documenter-dark .column.is-offset-4-fullhd{margin-left:33.33333337%}html.theme--documenter-dark .column.is-5-fullhd{flex:none;width:41.66666674%}html.theme--documenter-dark .column.is-offset-5-fullhd{margin-left:41.66666674%}html.theme--documenter-dark .column.is-6-fullhd{flex:none;width:50%}html.theme--documenter-dark .column.is-offset-6-fullhd{margin-left:50%}html.theme--documenter-dark .column.is-7-fullhd{flex:none;width:58.33333337%}html.theme--documenter-dark .column.is-offset-7-fullhd{margin-left:58.33333337%}html.theme--documenter-dark .column.is-8-fullhd{flex:none;width:66.66666674%}html.theme--documenter-dark .column.is-offset-8-fullhd{margin-left:66.66666674%}html.theme--documenter-dark .column.is-9-fullhd{flex:none;width:75%}html.theme--documenter-dark .column.is-offset-9-fullhd{margin-left:75%}html.theme--documenter-dark .column.is-10-fullhd{flex:none;width:83.33333337%}html.theme--documenter-dark .column.is-offset-10-fullhd{margin-left:83.33333337%}html.theme--documenter-dark .column.is-11-fullhd{flex:none;width:91.66666674%}html.theme--documenter-dark .column.is-offset-11-fullhd{margin-left:91.66666674%}html.theme--documenter-dark .column.is-12-fullhd{flex:none;width:100%}html.theme--documenter-dark .column.is-offset-12-fullhd{margin-left:100%}}html.theme--documenter-dark .columns{margin-left:-.75rem;margin-right:-.75rem;margin-top:-.75rem}html.theme--documenter-dark .columns:last-child{margin-bottom:-.75rem}html.theme--documenter-dark .columns:not(:last-child){margin-bottom:calc(1.5rem - .75rem)}html.theme--documenter-dark .columns.is-centered{justify-content:center}html.theme--documenter-dark .columns.is-gapless{margin-left:0;margin-right:0;margin-top:0}html.theme--documenter-dark .columns.is-gapless>.column{margin:0;padding:0 !important}html.theme--documenter-dark .columns.is-gapless:not(:last-child){margin-bottom:1.5rem}html.theme--documenter-dark .columns.is-gapless:last-child{margin-bottom:0}html.theme--documenter-dark .columns.is-mobile{display:flex}html.theme--documenter-dark .columns.is-multiline{flex-wrap:wrap}html.theme--documenter-dark .columns.is-vcentered{align-items:center}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns:not(.is-desktop){display:flex}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-desktop{display:flex}}html.theme--documenter-dark .columns.is-variable{--columnGap: 0.75rem;margin-left:calc(-1 * var(--columnGap));margin-right:calc(-1 * var(--columnGap))}html.theme--documenter-dark .columns.is-variable>.column{padding-left:var(--columnGap);padding-right:var(--columnGap)}html.theme--documenter-dark .columns.is-variable.is-0{--columnGap: 0rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-0-mobile{--columnGap: 0rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-0-tablet{--columnGap: 0rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-0-tablet-only{--columnGap: 0rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-0-touch{--columnGap: 0rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-0-desktop{--columnGap: 0rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-0-desktop-only{--columnGap: 0rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-0-widescreen{--columnGap: 0rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-0-widescreen-only{--columnGap: 0rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-0-fullhd{--columnGap: 0rem}}html.theme--documenter-dark .columns.is-variable.is-1{--columnGap: .25rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-1-mobile{--columnGap: .25rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-1-tablet{--columnGap: .25rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-1-tablet-only{--columnGap: .25rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-1-touch{--columnGap: .25rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-1-desktop{--columnGap: .25rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-1-desktop-only{--columnGap: .25rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-1-widescreen{--columnGap: .25rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-1-widescreen-only{--columnGap: .25rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-1-fullhd{--columnGap: .25rem}}html.theme--documenter-dark .columns.is-variable.is-2{--columnGap: .5rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-2-mobile{--columnGap: .5rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-2-tablet{--columnGap: .5rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-2-tablet-only{--columnGap: .5rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-2-touch{--columnGap: .5rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-2-desktop{--columnGap: .5rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-2-desktop-only{--columnGap: .5rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-2-widescreen{--columnGap: .5rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-2-widescreen-only{--columnGap: .5rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-2-fullhd{--columnGap: .5rem}}html.theme--documenter-dark .columns.is-variable.is-3{--columnGap: .75rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-3-mobile{--columnGap: .75rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-3-tablet{--columnGap: .75rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-3-tablet-only{--columnGap: .75rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-3-touch{--columnGap: .75rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-3-desktop{--columnGap: .75rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-3-desktop-only{--columnGap: .75rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-3-widescreen{--columnGap: .75rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-3-widescreen-only{--columnGap: .75rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-3-fullhd{--columnGap: .75rem}}html.theme--documenter-dark .columns.is-variable.is-4{--columnGap: 1rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-4-mobile{--columnGap: 1rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-4-tablet{--columnGap: 1rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-4-tablet-only{--columnGap: 1rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-4-touch{--columnGap: 1rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-4-desktop{--columnGap: 1rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-4-desktop-only{--columnGap: 1rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-4-widescreen{--columnGap: 1rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-4-widescreen-only{--columnGap: 1rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-4-fullhd{--columnGap: 1rem}}html.theme--documenter-dark .columns.is-variable.is-5{--columnGap: 1.25rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-5-mobile{--columnGap: 1.25rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-5-tablet{--columnGap: 1.25rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-5-tablet-only{--columnGap: 1.25rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-5-touch{--columnGap: 1.25rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-5-desktop{--columnGap: 1.25rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-5-desktop-only{--columnGap: 1.25rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-5-widescreen{--columnGap: 1.25rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-5-widescreen-only{--columnGap: 1.25rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-5-fullhd{--columnGap: 1.25rem}}html.theme--documenter-dark .columns.is-variable.is-6{--columnGap: 1.5rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-6-mobile{--columnGap: 1.5rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-6-tablet{--columnGap: 1.5rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-6-tablet-only{--columnGap: 1.5rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-6-touch{--columnGap: 1.5rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-6-desktop{--columnGap: 1.5rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-6-desktop-only{--columnGap: 1.5rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-6-widescreen{--columnGap: 1.5rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-6-widescreen-only{--columnGap: 1.5rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-6-fullhd{--columnGap: 1.5rem}}html.theme--documenter-dark .columns.is-variable.is-7{--columnGap: 1.75rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-7-mobile{--columnGap: 1.75rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-7-tablet{--columnGap: 1.75rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-7-tablet-only{--columnGap: 1.75rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-7-touch{--columnGap: 1.75rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-7-desktop{--columnGap: 1.75rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-7-desktop-only{--columnGap: 1.75rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-7-widescreen{--columnGap: 1.75rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-7-widescreen-only{--columnGap: 1.75rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-7-fullhd{--columnGap: 1.75rem}}html.theme--documenter-dark .columns.is-variable.is-8{--columnGap: 2rem}@media screen and (max-width: 768px){html.theme--documenter-dark .columns.is-variable.is-8-mobile{--columnGap: 2rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .columns.is-variable.is-8-tablet{--columnGap: 2rem}}@media screen and (min-width: 769px) and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-8-tablet-only{--columnGap: 2rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark .columns.is-variable.is-8-touch{--columnGap: 2rem}}@media screen and (min-width: 1056px){html.theme--documenter-dark .columns.is-variable.is-8-desktop{--columnGap: 2rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){html.theme--documenter-dark .columns.is-variable.is-8-desktop-only{--columnGap: 2rem}}@media screen and (min-width: 1216px){html.theme--documenter-dark .columns.is-variable.is-8-widescreen{--columnGap: 2rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){html.theme--documenter-dark .columns.is-variable.is-8-widescreen-only{--columnGap: 2rem}}@media screen and (min-width: 1408px){html.theme--documenter-dark .columns.is-variable.is-8-fullhd{--columnGap: 2rem}}html.theme--documenter-dark .tile{align-items:stretch;display:block;flex-basis:0;flex-grow:1;flex-shrink:1;min-height:min-content}html.theme--documenter-dark .tile.is-ancestor{margin-left:-.75rem;margin-right:-.75rem;margin-top:-.75rem}html.theme--documenter-dark .tile.is-ancestor:last-child{margin-bottom:-.75rem}html.theme--documenter-dark .tile.is-ancestor:not(:last-child){margin-bottom:.75rem}html.theme--documenter-dark .tile.is-child{margin:0 !important}html.theme--documenter-dark .tile.is-parent{padding:.75rem}html.theme--documenter-dark .tile.is-vertical{flex-direction:column}html.theme--documenter-dark .tile.is-vertical>.tile.is-child:not(:last-child){margin-bottom:1.5rem !important}@media screen and (min-width: 769px),print{html.theme--documenter-dark .tile:not(.is-child){display:flex}html.theme--documenter-dark .tile.is-1{flex:none;width:8.33333337%}html.theme--documenter-dark .tile.is-2{flex:none;width:16.66666674%}html.theme--documenter-dark .tile.is-3{flex:none;width:25%}html.theme--documenter-dark .tile.is-4{flex:none;width:33.33333337%}html.theme--documenter-dark .tile.is-5{flex:none;width:41.66666674%}html.theme--documenter-dark .tile.is-6{flex:none;width:50%}html.theme--documenter-dark .tile.is-7{flex:none;width:58.33333337%}html.theme--documenter-dark .tile.is-8{flex:none;width:66.66666674%}html.theme--documenter-dark .tile.is-9{flex:none;width:75%}html.theme--documenter-dark .tile.is-10{flex:none;width:83.33333337%}html.theme--documenter-dark .tile.is-11{flex:none;width:91.66666674%}html.theme--documenter-dark .tile.is-12{flex:none;width:100%}}html.theme--documenter-dark .hero{align-items:stretch;display:flex;flex-direction:column;justify-content:space-between}html.theme--documenter-dark .hero .navbar{background:none}html.theme--documenter-dark .hero .tabs ul{border-bottom:none}html.theme--documenter-dark .hero.is-white{background-color:#fff;color:#0a0a0a}html.theme--documenter-dark .hero.is-white a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-white strong{color:inherit}html.theme--documenter-dark .hero.is-white .title{color:#0a0a0a}html.theme--documenter-dark .hero.is-white .subtitle{color:rgba(10,10,10,0.9)}html.theme--documenter-dark .hero.is-white .subtitle a:not(.button),html.theme--documenter-dark .hero.is-white .subtitle strong{color:#0a0a0a}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-white .navbar-menu{background-color:#fff}}html.theme--documenter-dark .hero.is-white .navbar-item,html.theme--documenter-dark .hero.is-white .navbar-link{color:rgba(10,10,10,0.7)}html.theme--documenter-dark .hero.is-white a.navbar-item:hover,html.theme--documenter-dark .hero.is-white a.navbar-item.is-active,html.theme--documenter-dark .hero.is-white .navbar-link:hover,html.theme--documenter-dark .hero.is-white .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}html.theme--documenter-dark .hero.is-white .tabs a{color:#0a0a0a;opacity:0.9}html.theme--documenter-dark .hero.is-white .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-white .tabs li.is-active a{color:#fff !important;opacity:1}html.theme--documenter-dark .hero.is-white .tabs.is-boxed a,html.theme--documenter-dark .hero.is-white .tabs.is-toggle a{color:#0a0a0a}html.theme--documenter-dark .hero.is-white .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-white .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-white .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-white .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-white .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-white .tabs.is-toggle li.is-active a:hover{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}html.theme--documenter-dark .hero.is-white.is-bold{background-image:linear-gradient(141deg, #e8e3e4 0%, #fff 71%, #fff 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-white.is-bold .navbar-menu{background-image:linear-gradient(141deg, #e8e3e4 0%, #fff 71%, #fff 100%)}}html.theme--documenter-dark .hero.is-black{background-color:#0a0a0a;color:#fff}html.theme--documenter-dark .hero.is-black a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-black strong{color:inherit}html.theme--documenter-dark .hero.is-black .title{color:#fff}html.theme--documenter-dark .hero.is-black .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-black .subtitle a:not(.button),html.theme--documenter-dark .hero.is-black .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-black .navbar-menu{background-color:#0a0a0a}}html.theme--documenter-dark .hero.is-black .navbar-item,html.theme--documenter-dark .hero.is-black .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-black a.navbar-item:hover,html.theme--documenter-dark .hero.is-black a.navbar-item.is-active,html.theme--documenter-dark .hero.is-black .navbar-link:hover,html.theme--documenter-dark .hero.is-black .navbar-link.is-active{background-color:#000;color:#fff}html.theme--documenter-dark .hero.is-black .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-black .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-black .tabs li.is-active a{color:#0a0a0a !important;opacity:1}html.theme--documenter-dark .hero.is-black .tabs.is-boxed a,html.theme--documenter-dark .hero.is-black .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-black .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-black .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-black .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-black .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-black .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-black .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#0a0a0a}html.theme--documenter-dark .hero.is-black.is-bold{background-image:linear-gradient(141deg, #000 0%, #0a0a0a 71%, #181616 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-black.is-bold .navbar-menu{background-image:linear-gradient(141deg, #000 0%, #0a0a0a 71%, #181616 100%)}}html.theme--documenter-dark .hero.is-light{background-color:#ecf0f1;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .hero.is-light a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-light strong{color:inherit}html.theme--documenter-dark .hero.is-light .title{color:rgba(0,0,0,0.7)}html.theme--documenter-dark .hero.is-light .subtitle{color:rgba(0,0,0,0.9)}html.theme--documenter-dark .hero.is-light .subtitle a:not(.button),html.theme--documenter-dark .hero.is-light .subtitle strong{color:rgba(0,0,0,0.7)}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-light .navbar-menu{background-color:#ecf0f1}}html.theme--documenter-dark .hero.is-light .navbar-item,html.theme--documenter-dark .hero.is-light .navbar-link{color:rgba(0,0,0,0.7)}html.theme--documenter-dark .hero.is-light a.navbar-item:hover,html.theme--documenter-dark .hero.is-light a.navbar-item.is-active,html.theme--documenter-dark .hero.is-light .navbar-link:hover,html.theme--documenter-dark .hero.is-light .navbar-link.is-active{background-color:#dde4e6;color:rgba(0,0,0,0.7)}html.theme--documenter-dark .hero.is-light .tabs a{color:rgba(0,0,0,0.7);opacity:0.9}html.theme--documenter-dark .hero.is-light .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-light .tabs li.is-active a{color:#ecf0f1 !important;opacity:1}html.theme--documenter-dark .hero.is-light .tabs.is-boxed a,html.theme--documenter-dark .hero.is-light .tabs.is-toggle a{color:rgba(0,0,0,0.7)}html.theme--documenter-dark .hero.is-light .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-light .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-light .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-light .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-light .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-light .tabs.is-toggle li.is-active a:hover{background-color:rgba(0,0,0,0.7);border-color:rgba(0,0,0,0.7);color:#ecf0f1}html.theme--documenter-dark .hero.is-light.is-bold{background-image:linear-gradient(141deg, #cadfe0 0%, #ecf0f1 71%, #fafbfc 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-light.is-bold .navbar-menu{background-image:linear-gradient(141deg, #cadfe0 0%, #ecf0f1 71%, #fafbfc 100%)}}html.theme--documenter-dark .hero.is-dark,html.theme--documenter-dark .content kbd.hero{background-color:#282f2f;color:#fff}html.theme--documenter-dark .hero.is-dark a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .content kbd.hero a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-dark strong,html.theme--documenter-dark .content kbd.hero strong{color:inherit}html.theme--documenter-dark .hero.is-dark .title,html.theme--documenter-dark .content kbd.hero .title{color:#fff}html.theme--documenter-dark .hero.is-dark .subtitle,html.theme--documenter-dark .content kbd.hero .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-dark .subtitle a:not(.button),html.theme--documenter-dark .content kbd.hero .subtitle a:not(.button),html.theme--documenter-dark .hero.is-dark .subtitle strong,html.theme--documenter-dark .content kbd.hero .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-dark .navbar-menu,html.theme--documenter-dark .content kbd.hero .navbar-menu{background-color:#282f2f}}html.theme--documenter-dark .hero.is-dark .navbar-item,html.theme--documenter-dark .content kbd.hero .navbar-item,html.theme--documenter-dark .hero.is-dark .navbar-link,html.theme--documenter-dark .content kbd.hero .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-dark a.navbar-item:hover,html.theme--documenter-dark .content kbd.hero a.navbar-item:hover,html.theme--documenter-dark .hero.is-dark a.navbar-item.is-active,html.theme--documenter-dark .content kbd.hero a.navbar-item.is-active,html.theme--documenter-dark .hero.is-dark .navbar-link:hover,html.theme--documenter-dark .content kbd.hero .navbar-link:hover,html.theme--documenter-dark .hero.is-dark .navbar-link.is-active,html.theme--documenter-dark .content kbd.hero .navbar-link.is-active{background-color:#1d2122;color:#fff}html.theme--documenter-dark .hero.is-dark .tabs a,html.theme--documenter-dark .content kbd.hero .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-dark .tabs a:hover,html.theme--documenter-dark .content kbd.hero .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-dark .tabs li.is-active a,html.theme--documenter-dark .content kbd.hero .tabs li.is-active a{color:#282f2f !important;opacity:1}html.theme--documenter-dark .hero.is-dark .tabs.is-boxed a,html.theme--documenter-dark .content kbd.hero .tabs.is-boxed a,html.theme--documenter-dark .hero.is-dark .tabs.is-toggle a,html.theme--documenter-dark .content kbd.hero .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-dark .tabs.is-boxed a:hover,html.theme--documenter-dark .content kbd.hero .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-dark .tabs.is-toggle a:hover,html.theme--documenter-dark .content kbd.hero .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-dark .tabs.is-boxed li.is-active a,html.theme--documenter-dark .content kbd.hero .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-dark .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-dark .tabs.is-toggle li.is-active a,html.theme--documenter-dark .content kbd.hero .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-dark .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#282f2f}html.theme--documenter-dark .hero.is-dark.is-bold,html.theme--documenter-dark .content kbd.hero.is-bold{background-image:linear-gradient(141deg, #0f1615 0%, #282f2f 71%, #313c40 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-dark.is-bold .navbar-menu,html.theme--documenter-dark .content kbd.hero.is-bold .navbar-menu{background-image:linear-gradient(141deg, #0f1615 0%, #282f2f 71%, #313c40 100%)}}html.theme--documenter-dark .hero.is-primary,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink{background-color:#375a7f;color:#fff}html.theme--documenter-dark .hero.is-primary a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-primary strong,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink strong{color:inherit}html.theme--documenter-dark .hero.is-primary .title,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .title{color:#fff}html.theme--documenter-dark .hero.is-primary .subtitle,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-primary .subtitle a:not(.button),html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .subtitle a:not(.button),html.theme--documenter-dark .hero.is-primary .subtitle strong,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-primary .navbar-menu,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar-menu{background-color:#375a7f}}html.theme--documenter-dark .hero.is-primary .navbar-item,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar-item,html.theme--documenter-dark .hero.is-primary .navbar-link,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-primary a.navbar-item:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink a.navbar-item:hover,html.theme--documenter-dark .hero.is-primary a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink a.navbar-item.is-active,html.theme--documenter-dark .hero.is-primary .navbar-link:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar-link:hover,html.theme--documenter-dark .hero.is-primary .navbar-link.is-active,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar-link.is-active{background-color:#2f4d6d;color:#fff}html.theme--documenter-dark .hero.is-primary .tabs a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-primary .tabs a:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-primary .tabs li.is-active a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs li.is-active a{color:#375a7f !important;opacity:1}html.theme--documenter-dark .hero.is-primary .tabs.is-boxed a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-boxed a,html.theme--documenter-dark .hero.is-primary .tabs.is-toggle a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-primary .tabs.is-boxed a:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-primary .tabs.is-toggle a:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-primary .tabs.is-boxed li.is-active a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-primary .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-primary .tabs.is-toggle li.is-active a,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-primary .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#375a7f}html.theme--documenter-dark .hero.is-primary.is-bold,html.theme--documenter-dark .docstring>section>a.hero.is-bold.docs-sourcelink{background-image:linear-gradient(141deg, #214b62 0%, #375a7f 71%, #3a5796 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-primary.is-bold .navbar-menu,html.theme--documenter-dark .docstring>section>a.hero.is-bold.docs-sourcelink .navbar-menu{background-image:linear-gradient(141deg, #214b62 0%, #375a7f 71%, #3a5796 100%)}}html.theme--documenter-dark .hero.is-link{background-color:#1abc9c;color:#fff}html.theme--documenter-dark .hero.is-link a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-link strong{color:inherit}html.theme--documenter-dark .hero.is-link .title{color:#fff}html.theme--documenter-dark .hero.is-link .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-link .subtitle a:not(.button),html.theme--documenter-dark .hero.is-link .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-link .navbar-menu{background-color:#1abc9c}}html.theme--documenter-dark .hero.is-link .navbar-item,html.theme--documenter-dark .hero.is-link .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-link a.navbar-item:hover,html.theme--documenter-dark .hero.is-link a.navbar-item.is-active,html.theme--documenter-dark .hero.is-link .navbar-link:hover,html.theme--documenter-dark .hero.is-link .navbar-link.is-active{background-color:#17a689;color:#fff}html.theme--documenter-dark .hero.is-link .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-link .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-link .tabs li.is-active a{color:#1abc9c !important;opacity:1}html.theme--documenter-dark .hero.is-link .tabs.is-boxed a,html.theme--documenter-dark .hero.is-link .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-link .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-link .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-link .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-link .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-link .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-link .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#1abc9c}html.theme--documenter-dark .hero.is-link.is-bold{background-image:linear-gradient(141deg, #0c9764 0%, #1abc9c 71%, #17d8d2 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-link.is-bold .navbar-menu{background-image:linear-gradient(141deg, #0c9764 0%, #1abc9c 71%, #17d8d2 100%)}}html.theme--documenter-dark .hero.is-info{background-color:#024c7d;color:#fff}html.theme--documenter-dark .hero.is-info a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-info strong{color:inherit}html.theme--documenter-dark .hero.is-info .title{color:#fff}html.theme--documenter-dark .hero.is-info .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-info .subtitle a:not(.button),html.theme--documenter-dark .hero.is-info .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-info .navbar-menu{background-color:#024c7d}}html.theme--documenter-dark .hero.is-info .navbar-item,html.theme--documenter-dark .hero.is-info .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-info a.navbar-item:hover,html.theme--documenter-dark .hero.is-info a.navbar-item.is-active,html.theme--documenter-dark .hero.is-info .navbar-link:hover,html.theme--documenter-dark .hero.is-info .navbar-link.is-active{background-color:#023d64;color:#fff}html.theme--documenter-dark .hero.is-info .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-info .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-info .tabs li.is-active a{color:#024c7d !important;opacity:1}html.theme--documenter-dark .hero.is-info .tabs.is-boxed a,html.theme--documenter-dark .hero.is-info .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-info .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-info .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-info .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-info .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-info .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-info .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#024c7d}html.theme--documenter-dark .hero.is-info.is-bold{background-image:linear-gradient(141deg, #003a4c 0%, #024c7d 71%, #004299 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-info.is-bold .navbar-menu{background-image:linear-gradient(141deg, #003a4c 0%, #024c7d 71%, #004299 100%)}}html.theme--documenter-dark .hero.is-success{background-color:#008438;color:#fff}html.theme--documenter-dark .hero.is-success a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-success strong{color:inherit}html.theme--documenter-dark .hero.is-success .title{color:#fff}html.theme--documenter-dark .hero.is-success .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-success .subtitle a:not(.button),html.theme--documenter-dark .hero.is-success .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-success .navbar-menu{background-color:#008438}}html.theme--documenter-dark .hero.is-success .navbar-item,html.theme--documenter-dark .hero.is-success .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-success a.navbar-item:hover,html.theme--documenter-dark .hero.is-success a.navbar-item.is-active,html.theme--documenter-dark .hero.is-success .navbar-link:hover,html.theme--documenter-dark .hero.is-success .navbar-link.is-active{background-color:#006b2d;color:#fff}html.theme--documenter-dark .hero.is-success .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-success .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-success .tabs li.is-active a{color:#008438 !important;opacity:1}html.theme--documenter-dark .hero.is-success .tabs.is-boxed a,html.theme--documenter-dark .hero.is-success .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-success .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-success .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-success .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-success .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-success .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-success .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#008438}html.theme--documenter-dark .hero.is-success.is-bold{background-image:linear-gradient(141deg, #005115 0%, #008438 71%, #009e5d 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-success.is-bold .navbar-menu{background-image:linear-gradient(141deg, #005115 0%, #008438 71%, #009e5d 100%)}}html.theme--documenter-dark .hero.is-warning{background-color:#ad8100;color:#fff}html.theme--documenter-dark .hero.is-warning a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-warning strong{color:inherit}html.theme--documenter-dark .hero.is-warning .title{color:#fff}html.theme--documenter-dark .hero.is-warning .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-warning .subtitle a:not(.button),html.theme--documenter-dark .hero.is-warning .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-warning .navbar-menu{background-color:#ad8100}}html.theme--documenter-dark .hero.is-warning .navbar-item,html.theme--documenter-dark .hero.is-warning .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-warning a.navbar-item:hover,html.theme--documenter-dark .hero.is-warning a.navbar-item.is-active,html.theme--documenter-dark .hero.is-warning .navbar-link:hover,html.theme--documenter-dark .hero.is-warning .navbar-link.is-active{background-color:#946e00;color:#fff}html.theme--documenter-dark .hero.is-warning .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-warning .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-warning .tabs li.is-active a{color:#ad8100 !important;opacity:1}html.theme--documenter-dark .hero.is-warning .tabs.is-boxed a,html.theme--documenter-dark .hero.is-warning .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-warning .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-warning .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-warning .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-warning .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-warning .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-warning .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#ad8100}html.theme--documenter-dark .hero.is-warning.is-bold{background-image:linear-gradient(141deg, #7a4700 0%, #ad8100 71%, #c7b500 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-warning.is-bold .navbar-menu{background-image:linear-gradient(141deg, #7a4700 0%, #ad8100 71%, #c7b500 100%)}}html.theme--documenter-dark .hero.is-danger{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .hero.is-danger a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),html.theme--documenter-dark .hero.is-danger strong{color:inherit}html.theme--documenter-dark .hero.is-danger .title{color:#fff}html.theme--documenter-dark .hero.is-danger .subtitle{color:rgba(255,255,255,0.9)}html.theme--documenter-dark .hero.is-danger .subtitle a:not(.button),html.theme--documenter-dark .hero.is-danger .subtitle strong{color:#fff}@media screen and (max-width: 1055px){html.theme--documenter-dark .hero.is-danger .navbar-menu{background-color:#9e1b0d}}html.theme--documenter-dark .hero.is-danger .navbar-item,html.theme--documenter-dark .hero.is-danger .navbar-link{color:rgba(255,255,255,0.7)}html.theme--documenter-dark .hero.is-danger a.navbar-item:hover,html.theme--documenter-dark .hero.is-danger a.navbar-item.is-active,html.theme--documenter-dark .hero.is-danger .navbar-link:hover,html.theme--documenter-dark .hero.is-danger .navbar-link.is-active{background-color:#86170b;color:#fff}html.theme--documenter-dark .hero.is-danger .tabs a{color:#fff;opacity:0.9}html.theme--documenter-dark .hero.is-danger .tabs a:hover{opacity:1}html.theme--documenter-dark .hero.is-danger .tabs li.is-active a{color:#9e1b0d !important;opacity:1}html.theme--documenter-dark .hero.is-danger .tabs.is-boxed a,html.theme--documenter-dark .hero.is-danger .tabs.is-toggle a{color:#fff}html.theme--documenter-dark .hero.is-danger .tabs.is-boxed a:hover,html.theme--documenter-dark .hero.is-danger .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}html.theme--documenter-dark .hero.is-danger .tabs.is-boxed li.is-active a,html.theme--documenter-dark .hero.is-danger .tabs.is-boxed li.is-active a:hover,html.theme--documenter-dark .hero.is-danger .tabs.is-toggle li.is-active a,html.theme--documenter-dark .hero.is-danger .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#9e1b0d}html.theme--documenter-dark .hero.is-danger.is-bold{background-image:linear-gradient(141deg, #75030b 0%, #9e1b0d 71%, #ba380a 100%)}@media screen and (max-width: 768px){html.theme--documenter-dark .hero.is-danger.is-bold .navbar-menu{background-image:linear-gradient(141deg, #75030b 0%, #9e1b0d 71%, #ba380a 100%)}}html.theme--documenter-dark .hero.is-small .hero-body,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.hero .hero-body{padding:1.5rem}@media screen and (min-width: 769px),print{html.theme--documenter-dark .hero.is-medium .hero-body{padding:9rem 4.5rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .hero.is-large .hero-body{padding:18rem 6rem}}html.theme--documenter-dark .hero.is-halfheight .hero-body,html.theme--documenter-dark .hero.is-fullheight .hero-body,html.theme--documenter-dark .hero.is-fullheight-with-navbar .hero-body{align-items:center;display:flex}html.theme--documenter-dark .hero.is-halfheight .hero-body>.container,html.theme--documenter-dark .hero.is-fullheight .hero-body>.container,html.theme--documenter-dark .hero.is-fullheight-with-navbar .hero-body>.container{flex-grow:1;flex-shrink:1}html.theme--documenter-dark .hero.is-halfheight{min-height:50vh}html.theme--documenter-dark .hero.is-fullheight{min-height:100vh}html.theme--documenter-dark .hero-video{overflow:hidden}html.theme--documenter-dark .hero-video video{left:50%;min-height:100%;min-width:100%;position:absolute;top:50%;transform:translate3d(-50%, -50%, 0)}html.theme--documenter-dark .hero-video.is-transparent{opacity:0.3}@media screen and (max-width: 768px){html.theme--documenter-dark .hero-video{display:none}}html.theme--documenter-dark .hero-buttons{margin-top:1.5rem}@media screen and (max-width: 768px){html.theme--documenter-dark .hero-buttons .button{display:flex}html.theme--documenter-dark .hero-buttons .button:not(:last-child){margin-bottom:0.75rem}}@media screen and (min-width: 769px),print{html.theme--documenter-dark .hero-buttons{display:flex;justify-content:center}html.theme--documenter-dark .hero-buttons .button:not(:last-child){margin-right:1.5rem}}html.theme--documenter-dark .hero-head,html.theme--documenter-dark .hero-foot{flex-grow:0;flex-shrink:0}html.theme--documenter-dark .hero-body{flex-grow:1;flex-shrink:0;padding:3rem 1.5rem}@media screen and (min-width: 769px),print{html.theme--documenter-dark .hero-body{padding:3rem 3rem}}html.theme--documenter-dark .section{padding:3rem 1.5rem}@media screen and (min-width: 1056px){html.theme--documenter-dark .section{padding:3rem 3rem}html.theme--documenter-dark .section.is-medium{padding:9rem 4.5rem}html.theme--documenter-dark .section.is-large{padding:18rem 6rem}}html.theme--documenter-dark .footer{background-color:#282f2f;padding:3rem 1.5rem 6rem}html.theme--documenter-dark hr{height:1px}html.theme--documenter-dark h6{text-transform:uppercase;letter-spacing:0.5px}html.theme--documenter-dark .hero{background-color:#343c3d}html.theme--documenter-dark a{transition:all 200ms ease}html.theme--documenter-dark .button{transition:all 200ms ease;border-width:1px;color:#fff}html.theme--documenter-dark .button.is-active,html.theme--documenter-dark .button.is-focused,html.theme--documenter-dark .button:active,html.theme--documenter-dark .button:focus{box-shadow:0 0 0 2px rgba(140,155,157,0.5)}html.theme--documenter-dark .button.is-white.is-hovered,html.theme--documenter-dark .button.is-white:hover{background-color:#fff}html.theme--documenter-dark .button.is-white.is-active,html.theme--documenter-dark .button.is-white.is-focused,html.theme--documenter-dark .button.is-white:active,html.theme--documenter-dark .button.is-white:focus{border-color:#fff;box-shadow:0 0 0 2px rgba(255,255,255,0.5)}html.theme--documenter-dark .button.is-black.is-hovered,html.theme--documenter-dark .button.is-black:hover{background-color:#1d1d1d}html.theme--documenter-dark .button.is-black.is-active,html.theme--documenter-dark .button.is-black.is-focused,html.theme--documenter-dark .button.is-black:active,html.theme--documenter-dark .button.is-black:focus{border-color:#0a0a0a;box-shadow:0 0 0 2px rgba(10,10,10,0.5)}html.theme--documenter-dark .button.is-light.is-hovered,html.theme--documenter-dark .button.is-light:hover{background-color:#fff}html.theme--documenter-dark .button.is-light.is-active,html.theme--documenter-dark .button.is-light.is-focused,html.theme--documenter-dark .button.is-light:active,html.theme--documenter-dark .button.is-light:focus{border-color:#ecf0f1;box-shadow:0 0 0 2px rgba(236,240,241,0.5)}html.theme--documenter-dark .button.is-dark.is-hovered,html.theme--documenter-dark .content kbd.button.is-hovered,html.theme--documenter-dark .button.is-dark:hover,html.theme--documenter-dark .content kbd.button:hover{background-color:#3a4344}html.theme--documenter-dark .button.is-dark.is-active,html.theme--documenter-dark .content kbd.button.is-active,html.theme--documenter-dark .button.is-dark.is-focused,html.theme--documenter-dark .content kbd.button.is-focused,html.theme--documenter-dark .button.is-dark:active,html.theme--documenter-dark .content kbd.button:active,html.theme--documenter-dark .button.is-dark:focus,html.theme--documenter-dark .content kbd.button:focus{border-color:#282f2f;box-shadow:0 0 0 2px rgba(40,47,47,0.5)}html.theme--documenter-dark .button.is-primary.is-hovered,html.theme--documenter-dark .docstring>section>a.button.is-hovered.docs-sourcelink,html.theme--documenter-dark .button.is-primary:hover,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:hover{background-color:#436d9a}html.theme--documenter-dark .button.is-primary.is-active,html.theme--documenter-dark .docstring>section>a.button.is-active.docs-sourcelink,html.theme--documenter-dark .button.is-primary.is-focused,html.theme--documenter-dark .docstring>section>a.button.is-focused.docs-sourcelink,html.theme--documenter-dark .button.is-primary:active,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:active,html.theme--documenter-dark .button.is-primary:focus,html.theme--documenter-dark .docstring>section>a.button.docs-sourcelink:focus{border-color:#375a7f;box-shadow:0 0 0 2px rgba(55,90,127,0.5)}html.theme--documenter-dark .button.is-link.is-hovered,html.theme--documenter-dark .button.is-link:hover{background-color:#1fdeb8}html.theme--documenter-dark .button.is-link.is-active,html.theme--documenter-dark .button.is-link.is-focused,html.theme--documenter-dark .button.is-link:active,html.theme--documenter-dark .button.is-link:focus{border-color:#1abc9c;box-shadow:0 0 0 2px rgba(26,188,156,0.5)}html.theme--documenter-dark .button.is-info.is-hovered,html.theme--documenter-dark .button.is-info:hover{background-color:#0363a3}html.theme--documenter-dark .button.is-info.is-active,html.theme--documenter-dark .button.is-info.is-focused,html.theme--documenter-dark .button.is-info:active,html.theme--documenter-dark .button.is-info:focus{border-color:#024c7d;box-shadow:0 0 0 2px rgba(2,76,125,0.5)}html.theme--documenter-dark .button.is-success.is-hovered,html.theme--documenter-dark .button.is-success:hover{background-color:#00aa48}html.theme--documenter-dark .button.is-success.is-active,html.theme--documenter-dark .button.is-success.is-focused,html.theme--documenter-dark .button.is-success:active,html.theme--documenter-dark .button.is-success:focus{border-color:#008438;box-shadow:0 0 0 2px rgba(0,132,56,0.5)}html.theme--documenter-dark .button.is-warning.is-hovered,html.theme--documenter-dark .button.is-warning:hover{background-color:#d39e00}html.theme--documenter-dark .button.is-warning.is-active,html.theme--documenter-dark .button.is-warning.is-focused,html.theme--documenter-dark .button.is-warning:active,html.theme--documenter-dark .button.is-warning:focus{border-color:#ad8100;box-shadow:0 0 0 2px rgba(173,129,0,0.5)}html.theme--documenter-dark .button.is-danger.is-hovered,html.theme--documenter-dark .button.is-danger:hover{background-color:#c12110}html.theme--documenter-dark .button.is-danger.is-active,html.theme--documenter-dark .button.is-danger.is-focused,html.theme--documenter-dark .button.is-danger:active,html.theme--documenter-dark .button.is-danger:focus{border-color:#9e1b0d;box-shadow:0 0 0 2px rgba(158,27,13,0.5)}html.theme--documenter-dark .label{color:#dbdee0}html.theme--documenter-dark .button,html.theme--documenter-dark .control.has-icons-left .icon,html.theme--documenter-dark .control.has-icons-right .icon,html.theme--documenter-dark .input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark .pagination-ellipsis,html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-previous,html.theme--documenter-dark .select,html.theme--documenter-dark .select select,html.theme--documenter-dark .textarea{height:2.5em}html.theme--documenter-dark .input,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark .textarea{transition:all 200ms ease;box-shadow:none;border-width:1px;padding-left:1em;padding-right:1em}html.theme--documenter-dark .select:after,html.theme--documenter-dark .select select{border-width:1px}html.theme--documenter-dark .control.has-addons .button,html.theme--documenter-dark .control.has-addons .input,html.theme--documenter-dark .control.has-addons #documenter .docs-sidebar form.docs-search>input,html.theme--documenter-dark #documenter .docs-sidebar .control.has-addons form.docs-search>input,html.theme--documenter-dark .control.has-addons .select{margin-right:-1px}html.theme--documenter-dark .notification{background-color:#343c3d}html.theme--documenter-dark .card{box-shadow:none;border:1px solid #343c3d;background-color:#282f2f;border-radius:.4em}html.theme--documenter-dark .card .card-image img{border-radius:.4em .4em 0 0}html.theme--documenter-dark .card .card-header{box-shadow:none;background-color:rgba(18,18,18,0.2);border-radius:.4em .4em 0 0}html.theme--documenter-dark .card .card-footer{background-color:rgba(18,18,18,0.2)}html.theme--documenter-dark .card .card-footer,html.theme--documenter-dark .card .card-footer-item{border-width:1px;border-color:#343c3d}html.theme--documenter-dark .notification.is-white a:not(.button){color:#0a0a0a;text-decoration:underline}html.theme--documenter-dark .notification.is-black a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-light a:not(.button){color:rgba(0,0,0,0.7);text-decoration:underline}html.theme--documenter-dark .notification.is-dark a:not(.button),html.theme--documenter-dark .content kbd.notification a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-primary a:not(.button),html.theme--documenter-dark .docstring>section>a.notification.docs-sourcelink a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-link a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-info a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-success a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-warning a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .notification.is-danger a:not(.button){color:#fff;text-decoration:underline}html.theme--documenter-dark .tag,html.theme--documenter-dark .content kbd,html.theme--documenter-dark .docstring>section>a.docs-sourcelink{border-radius:.4em}html.theme--documenter-dark .menu-list a{transition:all 300ms ease}html.theme--documenter-dark .modal-card-body{background-color:#282f2f}html.theme--documenter-dark .modal-card-foot,html.theme--documenter-dark .modal-card-head{border-color:#343c3d}html.theme--documenter-dark .message-header{font-weight:700;background-color:#343c3d;color:#fff}html.theme--documenter-dark .message-body{border-width:1px;border-color:#343c3d}html.theme--documenter-dark .navbar{border-radius:.4em}html.theme--documenter-dark .navbar.is-transparent{background:none}html.theme--documenter-dark .navbar.is-primary .navbar-dropdown a.navbar-item.is-active,html.theme--documenter-dark .docstring>section>a.navbar.docs-sourcelink .navbar-dropdown a.navbar-item.is-active{background-color:#1abc9c}@media screen and (max-width: 1055px){html.theme--documenter-dark .navbar .navbar-menu{background-color:#375a7f;border-radius:0 0 .4em .4em}}html.theme--documenter-dark .hero .navbar,html.theme--documenter-dark body>.navbar{border-radius:0}html.theme--documenter-dark .pagination-link,html.theme--documenter-dark .pagination-next,html.theme--documenter-dark .pagination-previous{border-width:1px}html.theme--documenter-dark .panel-block,html.theme--documenter-dark .panel-heading,html.theme--documenter-dark .panel-tabs{border-width:1px}html.theme--documenter-dark .panel-block:first-child,html.theme--documenter-dark .panel-heading:first-child,html.theme--documenter-dark .panel-tabs:first-child{border-top-width:1px}html.theme--documenter-dark .panel-heading{font-weight:700}html.theme--documenter-dark .panel-tabs a{border-width:1px;margin-bottom:-1px}html.theme--documenter-dark .panel-tabs a.is-active{border-bottom-color:#17a689}html.theme--documenter-dark .panel-block:hover{color:#1dd2af}html.theme--documenter-dark .panel-block:hover .panel-icon{color:#1dd2af}html.theme--documenter-dark .panel-block.is-active .panel-icon{color:#17a689}html.theme--documenter-dark .tabs a{border-bottom-width:1px;margin-bottom:-1px}html.theme--documenter-dark .tabs ul{border-bottom-width:1px}html.theme--documenter-dark .tabs.is-boxed a{border-width:1px}html.theme--documenter-dark .tabs.is-boxed li.is-active a{background-color:#1f2424}html.theme--documenter-dark .tabs.is-toggle li a{border-width:1px;margin-bottom:0}html.theme--documenter-dark .tabs.is-toggle li+li{margin-left:-1px}html.theme--documenter-dark .hero.is-white .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-black .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-light .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-dark .navbar .navbar-dropdown .navbar-item:hover,html.theme--documenter-dark .content kbd.hero .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-primary .navbar .navbar-dropdown .navbar-item:hover,html.theme--documenter-dark .docstring>section>a.hero.docs-sourcelink .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-link .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-info .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-success .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-warning .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark .hero.is-danger .navbar .navbar-dropdown .navbar-item:hover{background-color:rgba(0,0,0,0)}html.theme--documenter-dark h1 .docs-heading-anchor,html.theme--documenter-dark h1 .docs-heading-anchor:hover,html.theme--documenter-dark h1 .docs-heading-anchor:visited,html.theme--documenter-dark h2 .docs-heading-anchor,html.theme--documenter-dark h2 .docs-heading-anchor:hover,html.theme--documenter-dark h2 .docs-heading-anchor:visited,html.theme--documenter-dark h3 .docs-heading-anchor,html.theme--documenter-dark h3 .docs-heading-anchor:hover,html.theme--documenter-dark h3 .docs-heading-anchor:visited,html.theme--documenter-dark h4 .docs-heading-anchor,html.theme--documenter-dark h4 .docs-heading-anchor:hover,html.theme--documenter-dark h4 .docs-heading-anchor:visited,html.theme--documenter-dark h5 .docs-heading-anchor,html.theme--documenter-dark h5 .docs-heading-anchor:hover,html.theme--documenter-dark h5 .docs-heading-anchor:visited,html.theme--documenter-dark h6 .docs-heading-anchor,html.theme--documenter-dark h6 .docs-heading-anchor:hover,html.theme--documenter-dark h6 .docs-heading-anchor:visited{color:#f2f2f2}html.theme--documenter-dark h1 .docs-heading-anchor-permalink,html.theme--documenter-dark h2 .docs-heading-anchor-permalink,html.theme--documenter-dark h3 .docs-heading-anchor-permalink,html.theme--documenter-dark h4 .docs-heading-anchor-permalink,html.theme--documenter-dark h5 .docs-heading-anchor-permalink,html.theme--documenter-dark h6 .docs-heading-anchor-permalink{visibility:hidden;vertical-align:middle;margin-left:0.5em;font-size:0.7rem}html.theme--documenter-dark h1 .docs-heading-anchor-permalink::before,html.theme--documenter-dark h2 .docs-heading-anchor-permalink::before,html.theme--documenter-dark h3 .docs-heading-anchor-permalink::before,html.theme--documenter-dark h4 .docs-heading-anchor-permalink::before,html.theme--documenter-dark h5 .docs-heading-anchor-permalink::before,html.theme--documenter-dark h6 .docs-heading-anchor-permalink::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f0c1"}html.theme--documenter-dark h1:hover .docs-heading-anchor-permalink,html.theme--documenter-dark h2:hover .docs-heading-anchor-permalink,html.theme--documenter-dark h3:hover .docs-heading-anchor-permalink,html.theme--documenter-dark h4:hover .docs-heading-anchor-permalink,html.theme--documenter-dark h5:hover .docs-heading-anchor-permalink,html.theme--documenter-dark h6:hover .docs-heading-anchor-permalink{visibility:visible}html.theme--documenter-dark .docs-light-only{display:none !important}html.theme--documenter-dark pre{position:relative;overflow:hidden}html.theme--documenter-dark pre code,html.theme--documenter-dark pre code.hljs{padding:0 .75rem !important;overflow:auto;display:block}html.theme--documenter-dark pre code:first-of-type,html.theme--documenter-dark pre code.hljs:first-of-type{padding-top:0.5rem !important}html.theme--documenter-dark pre code:last-of-type,html.theme--documenter-dark pre code.hljs:last-of-type{padding-bottom:0.5rem !important}html.theme--documenter-dark pre .copy-button{opacity:0.2;transition:opacity 0.2s;position:absolute;right:0em;top:0em;padding:0.5em;width:2.5em;height:2.5em;background:transparent;border:none;font-family:"Font Awesome 6 Free";color:#fff;cursor:pointer;text-align:center}html.theme--documenter-dark pre .copy-button:focus,html.theme--documenter-dark pre .copy-button:hover{opacity:1;background:rgba(255,255,255,0.1);color:#1abc9c}html.theme--documenter-dark pre .copy-button.success{color:#259a12;opacity:1}html.theme--documenter-dark pre .copy-button.error{color:#cb3c33;opacity:1}html.theme--documenter-dark pre:hover .copy-button{opacity:1}html.theme--documenter-dark .admonition{background-color:#282f2f;border-style:solid;border-width:1px;border-color:#5e6d6f;border-radius:.4em;font-size:1rem}html.theme--documenter-dark .admonition strong{color:currentColor}html.theme--documenter-dark .admonition.is-small,html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input.admonition{font-size:.75rem}html.theme--documenter-dark .admonition.is-medium{font-size:1.25rem}html.theme--documenter-dark .admonition.is-large{font-size:1.5rem}html.theme--documenter-dark .admonition.is-default{background-color:#282f2f;border-color:#5e6d6f}html.theme--documenter-dark .admonition.is-default>.admonition-header{background-color:#5e6d6f;color:#fff}html.theme--documenter-dark .admonition.is-default>.admonition-body{color:#fff}html.theme--documenter-dark .admonition.is-info{background-color:#282f2f;border-color:#024c7d}html.theme--documenter-dark .admonition.is-info>.admonition-header{background-color:#024c7d;color:#fff}html.theme--documenter-dark .admonition.is-info>.admonition-body{color:#fff}html.theme--documenter-dark .admonition.is-success{background-color:#282f2f;border-color:#008438}html.theme--documenter-dark .admonition.is-success>.admonition-header{background-color:#008438;color:#fff}html.theme--documenter-dark .admonition.is-success>.admonition-body{color:#fff}html.theme--documenter-dark .admonition.is-warning{background-color:#282f2f;border-color:#ad8100}html.theme--documenter-dark .admonition.is-warning>.admonition-header{background-color:#ad8100;color:#fff}html.theme--documenter-dark .admonition.is-warning>.admonition-body{color:#fff}html.theme--documenter-dark .admonition.is-danger{background-color:#282f2f;border-color:#9e1b0d}html.theme--documenter-dark .admonition.is-danger>.admonition-header{background-color:#9e1b0d;color:#fff}html.theme--documenter-dark .admonition.is-danger>.admonition-body{color:#fff}html.theme--documenter-dark .admonition.is-compat{background-color:#282f2f;border-color:#137886}html.theme--documenter-dark .admonition.is-compat>.admonition-header{background-color:#137886;color:#fff}html.theme--documenter-dark .admonition.is-compat>.admonition-body{color:#fff}html.theme--documenter-dark .admonition-header{color:#fff;background-color:#5e6d6f;align-items:center;font-weight:700;justify-content:space-between;line-height:1.25;padding:0.5rem .75rem;position:relative}html.theme--documenter-dark .admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;margin-right:.75rem;content:"\f06a"}html.theme--documenter-dark details.admonition.is-details>.admonition-header{list-style:none}html.theme--documenter-dark details.admonition.is-details>.admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f055"}html.theme--documenter-dark details.admonition.is-details[open]>.admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f056"}html.theme--documenter-dark .admonition-body{color:#fff;padding:0.5rem .75rem}html.theme--documenter-dark .admonition-body pre{background-color:#282f2f}html.theme--documenter-dark .admonition-body code{background-color:rgba(255,255,255,0.05)}html.theme--documenter-dark .docstring{margin-bottom:1em;background-color:rgba(0,0,0,0);border:1px solid #5e6d6f;box-shadow:none;max-width:100%}html.theme--documenter-dark .docstring>header{cursor:pointer;display:flex;flex-grow:1;align-items:stretch;padding:0.5rem .75rem;background-color:#282f2f;box-shadow:0 0.125em 0.25em rgba(10,10,10,0.1);box-shadow:none;border-bottom:1px solid #5e6d6f}html.theme--documenter-dark .docstring>header code{background-color:transparent}html.theme--documenter-dark .docstring>header .docstring-article-toggle-button{min-width:1.1rem;padding:0.2rem 0.2rem 0.2rem 0}html.theme--documenter-dark .docstring>header .docstring-binding{margin-right:0.3em}html.theme--documenter-dark .docstring>header .docstring-category{margin-left:0.3em}html.theme--documenter-dark .docstring>section{position:relative;padding:.75rem .75rem;border-bottom:1px solid #5e6d6f}html.theme--documenter-dark .docstring>section:last-child{border-bottom:none}html.theme--documenter-dark .docstring>section>a.docs-sourcelink{transition:opacity 0.3s;opacity:0;position:absolute;right:.375rem;bottom:.375rem}html.theme--documenter-dark .docstring>section>a.docs-sourcelink:focus{opacity:1 !important}html.theme--documenter-dark .docstring:hover>section>a.docs-sourcelink{opacity:0.2}html.theme--documenter-dark .docstring:focus-within>section>a.docs-sourcelink{opacity:0.2}html.theme--documenter-dark .docstring>section:hover a.docs-sourcelink{opacity:1}html.theme--documenter-dark .documenter-example-output{background-color:#1f2424}html.theme--documenter-dark .outdated-warning-overlay{position:fixed;top:0;left:0;right:0;box-shadow:0 0 10px rgba(0,0,0,0.3);z-index:999;background-color:#282f2f;color:#fff;border-bottom:3px solid #9e1b0d;padding:10px 35px;text-align:center;font-size:15px}html.theme--documenter-dark .outdated-warning-overlay .outdated-warning-closer{position:absolute;top:calc(50% - 10px);right:18px;cursor:pointer;width:12px}html.theme--documenter-dark .outdated-warning-overlay a{color:#1abc9c}html.theme--documenter-dark .outdated-warning-overlay a:hover{color:#1dd2af}html.theme--documenter-dark .content pre{border:1px solid #5e6d6f}html.theme--documenter-dark .content code{font-weight:inherit}html.theme--documenter-dark .content a code{color:#1abc9c}html.theme--documenter-dark .content h1 code,html.theme--documenter-dark .content h2 code,html.theme--documenter-dark .content h3 code,html.theme--documenter-dark .content h4 code,html.theme--documenter-dark .content h5 code,html.theme--documenter-dark .content h6 code{color:#f2f2f2}html.theme--documenter-dark .content table{display:block;width:initial;max-width:100%;overflow-x:auto}html.theme--documenter-dark .content blockquote>ul:first-child,html.theme--documenter-dark .content blockquote>ol:first-child,html.theme--documenter-dark .content .admonition-body>ul:first-child,html.theme--documenter-dark .content .admonition-body>ol:first-child{margin-top:0}html.theme--documenter-dark pre,html.theme--documenter-dark code{font-variant-ligatures:no-contextual}html.theme--documenter-dark .breadcrumb a.is-disabled{cursor:default;pointer-events:none}html.theme--documenter-dark .breadcrumb a.is-disabled,html.theme--documenter-dark .breadcrumb a.is-disabled:hover{color:#f2f2f2}html.theme--documenter-dark .hljs{background:initial !important}html.theme--documenter-dark .katex .katex-mathml{top:0;right:0}html.theme--documenter-dark .katex-display,html.theme--documenter-dark mjx-container,html.theme--documenter-dark .MathJax_Display{margin:0.5em 0 !important}html.theme--documenter-dark html{-moz-osx-font-smoothing:auto;-webkit-font-smoothing:auto}html.theme--documenter-dark li.no-marker{list-style:none}html.theme--documenter-dark #documenter .docs-main>article{overflow-wrap:break-word}html.theme--documenter-dark #documenter .docs-main>article .math-container{overflow-x:auto;overflow-y:hidden}@media screen and (min-width: 1056px){html.theme--documenter-dark #documenter .docs-main{max-width:52rem;margin-left:20rem;padding-right:1rem}}@media screen and (max-width: 1055px){html.theme--documenter-dark #documenter .docs-main{width:100%}html.theme--documenter-dark #documenter .docs-main>article{max-width:52rem;margin-left:auto;margin-right:auto;margin-bottom:1rem;padding:0 1rem}html.theme--documenter-dark #documenter .docs-main>header,html.theme--documenter-dark #documenter .docs-main>nav{max-width:100%;width:100%;margin:0}}html.theme--documenter-dark #documenter .docs-main header.docs-navbar{background-color:#1f2424;border-bottom:1px solid #5e6d6f;z-index:2;min-height:4rem;margin-bottom:1rem;display:flex}html.theme--documenter-dark #documenter .docs-main header.docs-navbar .breadcrumb{flex-grow:1}html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-sidebar-button{display:block;font-size:1.5rem;padding-bottom:0.1rem;margin-right:1rem}html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-right{display:flex;white-space:nowrap;gap:1rem;align-items:center}html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-right .docs-icon,html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-right .docs-label{display:inline-block}html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-right .docs-label{padding:0;margin-left:0.3em}@media screen and (max-width: 1055px){html.theme--documenter-dark #documenter .docs-main header.docs-navbar .docs-right .docs-navbar-link{margin-left:0.4rem;margin-right:0.4rem}}html.theme--documenter-dark #documenter .docs-main header.docs-navbar>*{margin:auto 0}@media screen and (max-width: 1055px){html.theme--documenter-dark #documenter .docs-main header.docs-navbar{position:sticky;top:0;padding:0 1rem;transition-property:top, box-shadow;-webkit-transition-property:top, box-shadow;transition-duration:0.3s;-webkit-transition-duration:0.3s}html.theme--documenter-dark #documenter .docs-main header.docs-navbar.headroom--not-top{box-shadow:.2rem 0rem .4rem #171717;transition-duration:0.7s;-webkit-transition-duration:0.7s}html.theme--documenter-dark #documenter .docs-main header.docs-navbar.headroom--unpinned.headroom--not-top.headroom--not-bottom{top:-4.5rem;transition-duration:0.7s;-webkit-transition-duration:0.7s}}html.theme--documenter-dark #documenter .docs-main section.footnotes{border-top:1px solid #5e6d6f}html.theme--documenter-dark #documenter .docs-main section.footnotes li .tag:first-child,html.theme--documenter-dark #documenter .docs-main section.footnotes li .docstring>section>a.docs-sourcelink:first-child,html.theme--documenter-dark #documenter .docs-main section.footnotes li .content kbd:first-child,html.theme--documenter-dark .content #documenter .docs-main section.footnotes li kbd:first-child{margin-right:1em;margin-bottom:0.4em}html.theme--documenter-dark #documenter .docs-main .docs-footer{display:flex;flex-wrap:wrap;margin-left:0;margin-right:0;border-top:1px solid #5e6d6f;padding-top:1rem;padding-bottom:1rem}@media screen and (max-width: 1055px){html.theme--documenter-dark #documenter .docs-main .docs-footer{padding-left:1rem;padding-right:1rem}}html.theme--documenter-dark #documenter .docs-main .docs-footer .docs-footer-nextpage,html.theme--documenter-dark #documenter .docs-main .docs-footer .docs-footer-prevpage{flex-grow:1}html.theme--documenter-dark #documenter .docs-main .docs-footer .docs-footer-nextpage{text-align:right}html.theme--documenter-dark #documenter .docs-main .docs-footer .flexbox-break{flex-basis:100%;height:0}html.theme--documenter-dark #documenter .docs-main .docs-footer .footer-message{font-size:0.8em;margin:0.5em auto 0 auto;text-align:center}html.theme--documenter-dark #documenter .docs-sidebar{display:flex;flex-direction:column;color:#fff;background-color:#282f2f;border-right:1px solid #5e6d6f;padding:0;flex:0 0 18rem;z-index:5;font-size:1rem;position:fixed;left:-18rem;width:18rem;height:100%;transition:left 0.3s}html.theme--documenter-dark #documenter .docs-sidebar.visible{left:0;box-shadow:.4rem 0rem .8rem #171717}@media screen and (min-width: 1056px){html.theme--documenter-dark #documenter .docs-sidebar.visible{box-shadow:none}}@media screen and (min-width: 1056px){html.theme--documenter-dark #documenter .docs-sidebar{left:0;top:0}}html.theme--documenter-dark #documenter .docs-sidebar .docs-logo{margin-top:1rem;padding:0 1rem}html.theme--documenter-dark #documenter .docs-sidebar .docs-logo>img{max-height:6rem;margin:auto}html.theme--documenter-dark #documenter .docs-sidebar .docs-package-name{flex-shrink:0;font-size:1.5rem;font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;padding:0.5rem 0}html.theme--documenter-dark #documenter .docs-sidebar .docs-package-name .docs-autofit{max-width:16.2rem}html.theme--documenter-dark #documenter .docs-sidebar .docs-package-name a,html.theme--documenter-dark #documenter .docs-sidebar .docs-package-name a:hover{color:#fff}html.theme--documenter-dark #documenter .docs-sidebar .docs-version-selector{border-top:1px solid #5e6d6f;display:none;padding:0.5rem}html.theme--documenter-dark #documenter .docs-sidebar .docs-version-selector.visible{display:flex}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu{flex-grow:1;user-select:none;border-top:1px solid #5e6d6f;padding-bottom:1.5rem}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu>li>.tocitem{font-weight:bold}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu>li li{font-size:.95rem;margin-left:1em;border-left:1px solid #5e6d6f}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu input.collapse-toggle{display:none}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu ul.collapsed{display:none}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu input:checked~ul.collapsed{display:block}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu label.tocitem{display:flex}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu label.tocitem .docs-label{flex-grow:2}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu label.tocitem .docs-chevron{display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1;font-size:.75rem;margin-left:1rem;margin-top:auto;margin-bottom:auto}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu label.tocitem .docs-chevron::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f054"}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu input:checked~label.tocitem .docs-chevron::before{content:"\f078"}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu .tocitem{display:block;padding:0.5rem 0.5rem}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu .tocitem,html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu .tocitem:hover{color:#fff;background:#282f2f}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu a.tocitem:hover,html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu label.tocitem:hover{color:#fff;background-color:#32393a}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu li.is-active{border-top:1px solid #5e6d6f;border-bottom:1px solid #5e6d6f;background-color:#1f2424}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu li.is-active .tocitem,html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu li.is-active .tocitem:hover{background-color:#1f2424;color:#fff}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu li.is-active ul.internal .tocitem:hover{background-color:#32393a;color:#fff}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu>li.is-active:first-child{border-top:none}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu ul.internal{margin:0 0.5rem 0.5rem;border-top:1px solid #5e6d6f}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu ul.internal li{font-size:.85rem;border-left:none;margin-left:0;margin-top:0.5rem}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu ul.internal .tocitem{width:100%;padding:0}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu ul.internal .tocitem::before{content:"⚬";margin-right:0.4em}html.theme--documenter-dark #documenter .docs-sidebar form.docs-search{margin:auto;margin-top:0.5rem;margin-bottom:0.5rem}html.theme--documenter-dark #documenter .docs-sidebar form.docs-search>input{width:14.4rem}html.theme--documenter-dark #documenter .docs-sidebar #documenter-search-query{color:#868c98;width:14.4rem;box-shadow:inset 0 1px 2px rgba(10,10,10,0.1)}@media screen and (min-width: 1056px){html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu{overflow-y:auto;-webkit-overflow-scroll:touch}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar{width:.3rem;background:none}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar-thumb{border-radius:5px 0px 0px 5px;background:#3b4445}html.theme--documenter-dark #documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar-thumb:hover{background:#4e5a5c}}@media screen and (max-width: 1055px){html.theme--documenter-dark #documenter .docs-sidebar{overflow-y:auto;-webkit-overflow-scroll:touch}html.theme--documenter-dark #documenter .docs-sidebar::-webkit-scrollbar{width:.3rem;background:none}html.theme--documenter-dark #documenter .docs-sidebar::-webkit-scrollbar-thumb{border-radius:5px 0px 0px 5px;background:#3b4445}html.theme--documenter-dark #documenter .docs-sidebar::-webkit-scrollbar-thumb:hover{background:#4e5a5c}}html.theme--documenter-dark kbd.search-modal-key-hints{border-radius:0.25rem;border:1px solid rgba(245,245,245,0.6);box-shadow:0 2px 0 1px rgba(245,245,245,0.6);cursor:default;font-size:0.9rem;line-height:1.5;min-width:0.75rem;text-align:center;padding:0.1rem 0.3rem;position:relative;top:-1px}html.theme--documenter-dark .search-min-width-50{min-width:50%}html.theme--documenter-dark .search-min-height-100{min-height:100%}html.theme--documenter-dark .search-modal-card-body{max-height:calc(100vh - 15rem)}html.theme--documenter-dark .search-result-link{border-radius:0.7em;transition:all 300ms}html.theme--documenter-dark .search-result-link:hover,html.theme--documenter-dark .search-result-link:focus{background-color:rgba(0,128,128,0.1)}html.theme--documenter-dark .search-result-link .property-search-result-badge,html.theme--documenter-dark .search-result-link .search-filter{transition:all 300ms}html.theme--documenter-dark .property-search-result-badge,html.theme--documenter-dark .search-filter{padding:0.15em 0.5em;font-size:0.8em;font-style:italic;text-transform:none !important;line-height:1.5;color:#f5f5f5;background-color:rgba(51,65,85,0.501961);border-radius:0.6rem}html.theme--documenter-dark .search-result-link:hover .property-search-result-badge,html.theme--documenter-dark .search-result-link:hover .search-filter,html.theme--documenter-dark .search-result-link:focus .property-search-result-badge,html.theme--documenter-dark .search-result-link:focus .search-filter{color:#333;background-color:#f1f5f9}html.theme--documenter-dark .search-filter{color:#333;background-color:#f5f5f5;transition:all 300ms}html.theme--documenter-dark .search-filter:hover,html.theme--documenter-dark .search-filter:focus{color:#333}html.theme--documenter-dark .search-filter-selected{color:#f5f5f5;background-color:rgba(139,0,139,0.5)}html.theme--documenter-dark .search-filter-selected:hover,html.theme--documenter-dark .search-filter-selected:focus{color:#f5f5f5}html.theme--documenter-dark .search-result-highlight{background-color:#ffdd57;color:black}html.theme--documenter-dark .search-divider{border-bottom:1px solid #5e6d6f}html.theme--documenter-dark .search-result-title{width:85%;color:#f5f5f5}html.theme--documenter-dark .search-result-code-title{font-size:0.875rem;font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace}html.theme--documenter-dark #search-modal .modal-card-body::-webkit-scrollbar,html.theme--documenter-dark #search-modal .filter-tabs::-webkit-scrollbar{height:10px;width:10px;background-color:transparent}html.theme--documenter-dark #search-modal .modal-card-body::-webkit-scrollbar-thumb,html.theme--documenter-dark #search-modal .filter-tabs::-webkit-scrollbar-thumb{background-color:gray;border-radius:1rem}html.theme--documenter-dark #search-modal .modal-card-body::-webkit-scrollbar-track,html.theme--documenter-dark #search-modal .filter-tabs::-webkit-scrollbar-track{-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,0.6);background-color:transparent}html.theme--documenter-dark .w-100{width:100%}html.theme--documenter-dark .gap-2{gap:0.5rem}html.theme--documenter-dark .gap-4{gap:1rem}html.theme--documenter-dark .gap-8{gap:2rem}html.theme--documenter-dark{background-color:#1f2424;font-size:16px;min-width:300px;overflow-x:auto;overflow-y:scroll;text-rendering:optimizeLegibility;text-size-adjust:100%}html.theme--documenter-dark .ansi span.sgr1{font-weight:bolder}html.theme--documenter-dark .ansi span.sgr2{font-weight:lighter}html.theme--documenter-dark .ansi span.sgr3{font-style:italic}html.theme--documenter-dark .ansi span.sgr4{text-decoration:underline}html.theme--documenter-dark .ansi span.sgr7{color:#1f2424;background-color:#fff}html.theme--documenter-dark .ansi span.sgr8{color:transparent}html.theme--documenter-dark .ansi span.sgr8 span{color:transparent}html.theme--documenter-dark .ansi span.sgr9{text-decoration:line-through}html.theme--documenter-dark .ansi span.sgr30{color:#242424}html.theme--documenter-dark .ansi span.sgr31{color:#f6705f}html.theme--documenter-dark .ansi span.sgr32{color:#4fb43a}html.theme--documenter-dark .ansi span.sgr33{color:#f4c72f}html.theme--documenter-dark .ansi span.sgr34{color:#7587f0}html.theme--documenter-dark .ansi span.sgr35{color:#bc89d3}html.theme--documenter-dark .ansi span.sgr36{color:#49b6ca}html.theme--documenter-dark .ansi span.sgr37{color:#b3bdbe}html.theme--documenter-dark .ansi span.sgr40{background-color:#242424}html.theme--documenter-dark .ansi span.sgr41{background-color:#f6705f}html.theme--documenter-dark .ansi span.sgr42{background-color:#4fb43a}html.theme--documenter-dark .ansi span.sgr43{background-color:#f4c72f}html.theme--documenter-dark .ansi span.sgr44{background-color:#7587f0}html.theme--documenter-dark .ansi span.sgr45{background-color:#bc89d3}html.theme--documenter-dark .ansi span.sgr46{background-color:#49b6ca}html.theme--documenter-dark .ansi span.sgr47{background-color:#b3bdbe}html.theme--documenter-dark .ansi span.sgr90{color:#92a0a2}html.theme--documenter-dark .ansi span.sgr91{color:#ff8674}html.theme--documenter-dark .ansi span.sgr92{color:#79d462}html.theme--documenter-dark .ansi span.sgr93{color:#ffe76b}html.theme--documenter-dark .ansi span.sgr94{color:#8a98ff}html.theme--documenter-dark .ansi span.sgr95{color:#d2a4e6}html.theme--documenter-dark .ansi span.sgr96{color:#6bc8db}html.theme--documenter-dark .ansi span.sgr97{color:#ecf0f1}html.theme--documenter-dark .ansi span.sgr100{background-color:#92a0a2}html.theme--documenter-dark .ansi span.sgr101{background-color:#ff8674}html.theme--documenter-dark .ansi span.sgr102{background-color:#79d462}html.theme--documenter-dark .ansi span.sgr103{background-color:#ffe76b}html.theme--documenter-dark .ansi span.sgr104{background-color:#8a98ff}html.theme--documenter-dark .ansi span.sgr105{background-color:#d2a4e6}html.theme--documenter-dark .ansi span.sgr106{background-color:#6bc8db}html.theme--documenter-dark .ansi span.sgr107{background-color:#ecf0f1}html.theme--documenter-dark code.language-julia-repl>span.hljs-meta{color:#4fb43a;font-weight:bolder}html.theme--documenter-dark .hljs{background:#2b2b2b;color:#f8f8f2}html.theme--documenter-dark .hljs-comment,html.theme--documenter-dark .hljs-quote{color:#d4d0ab}html.theme--documenter-dark .hljs-variable,html.theme--documenter-dark .hljs-template-variable,html.theme--documenter-dark .hljs-tag,html.theme--documenter-dark .hljs-name,html.theme--documenter-dark .hljs-selector-id,html.theme--documenter-dark .hljs-selector-class,html.theme--documenter-dark .hljs-regexp,html.theme--documenter-dark .hljs-deletion{color:#ffa07a}html.theme--documenter-dark .hljs-number,html.theme--documenter-dark .hljs-built_in,html.theme--documenter-dark .hljs-literal,html.theme--documenter-dark .hljs-type,html.theme--documenter-dark .hljs-params,html.theme--documenter-dark .hljs-meta,html.theme--documenter-dark .hljs-link{color:#f5ab35}html.theme--documenter-dark .hljs-attribute{color:#ffd700}html.theme--documenter-dark .hljs-string,html.theme--documenter-dark .hljs-symbol,html.theme--documenter-dark .hljs-bullet,html.theme--documenter-dark .hljs-addition{color:#abe338}html.theme--documenter-dark .hljs-title,html.theme--documenter-dark .hljs-section{color:#00e0e0}html.theme--documenter-dark .hljs-keyword,html.theme--documenter-dark .hljs-selector-tag{color:#dcc6e0}html.theme--documenter-dark .hljs-emphasis{font-style:italic}html.theme--documenter-dark .hljs-strong{font-weight:bold}@media screen and (-ms-high-contrast: active){html.theme--documenter-dark .hljs-addition,html.theme--documenter-dark .hljs-attribute,html.theme--documenter-dark .hljs-built_in,html.theme--documenter-dark .hljs-bullet,html.theme--documenter-dark .hljs-comment,html.theme--documenter-dark .hljs-link,html.theme--documenter-dark .hljs-literal,html.theme--documenter-dark .hljs-meta,html.theme--documenter-dark .hljs-number,html.theme--documenter-dark .hljs-params,html.theme--documenter-dark .hljs-string,html.theme--documenter-dark .hljs-symbol,html.theme--documenter-dark .hljs-type,html.theme--documenter-dark .hljs-quote{color:highlight}html.theme--documenter-dark .hljs-keyword,html.theme--documenter-dark .hljs-selector-tag{font-weight:bold}}html.theme--documenter-dark .hljs-subst{color:#f8f8f2}html.theme--documenter-dark .search-result-link{border-radius:0.7em;transition:all 300ms}html.theme--documenter-dark .search-result-link:hover,html.theme--documenter-dark .search-result-link:focus{background-color:rgba(0,128,128,0.1)}html.theme--documenter-dark .search-result-link .property-search-result-badge,html.theme--documenter-dark .search-result-link .search-filter{transition:all 300ms}html.theme--documenter-dark .search-result-link:hover .property-search-result-badge,html.theme--documenter-dark .search-result-link:hover .search-filter,html.theme--documenter-dark .search-result-link:focus .property-search-result-badge,html.theme--documenter-dark .search-result-link:focus .search-filter{color:#333 !important;background-color:#f1f5f9 !important}html.theme--documenter-dark .property-search-result-badge,html.theme--documenter-dark .search-filter{padding:0.15em 0.5em;font-size:0.8em;font-style:italic;text-transform:none !important;line-height:1.5;color:whitesmoke;background-color:#33415580;border-radius:0.6rem}html.theme--documenter-dark .search-result-title{color:whitesmoke}html.theme--documenter-dark .search-result-highlight{background-color:greenyellow;color:black}html.theme--documenter-dark .search-divider{border-bottom:1px solid #5e6d6f50}html.theme--documenter-dark .w-100{width:100%}html.theme--documenter-dark .gap-2{gap:0.5rem}html.theme--documenter-dark .gap-4{gap:1rem} diff --git a/previews/PR1697/assets/themes/documenter-light.css b/previews/PR1697/assets/themes/documenter-light.css new file mode 100644 index 00000000000..1262ec5063f --- /dev/null +++ b/previews/PR1697/assets/themes/documenter-light.css @@ -0,0 +1,9 @@ +.pagination-previous,.pagination-next,.pagination-link,.pagination-ellipsis,.file-cta,.file-name,.select select,.textarea,.input,#documenter .docs-sidebar form.docs-search>input,.button{-moz-appearance:none;-webkit-appearance:none;align-items:center;border:1px solid transparent;border-radius:4px;box-shadow:none;display:inline-flex;font-size:1rem;height:2.5em;justify-content:flex-start;line-height:1.5;padding-bottom:calc(0.5em - 1px);padding-left:calc(0.75em - 1px);padding-right:calc(0.75em - 1px);padding-top:calc(0.5em - 1px);position:relative;vertical-align:top}.pagination-previous:focus,.pagination-next:focus,.pagination-link:focus,.pagination-ellipsis:focus,.file-cta:focus,.file-name:focus,.select select:focus,.textarea:focus,.input:focus,#documenter .docs-sidebar form.docs-search>input:focus,.button:focus,.is-focused.pagination-previous,.is-focused.pagination-next,.is-focused.pagination-link,.is-focused.pagination-ellipsis,.is-focused.file-cta,.is-focused.file-name,.select select.is-focused,.is-focused.textarea,.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-focused.button,.pagination-previous:active,.pagination-next:active,.pagination-link:active,.pagination-ellipsis:active,.file-cta:active,.file-name:active,.select select:active,.textarea:active,.input:active,#documenter .docs-sidebar form.docs-search>input:active,.button:active,.is-active.pagination-previous,.is-active.pagination-next,.is-active.pagination-link,.is-active.pagination-ellipsis,.is-active.file-cta,.is-active.file-name,.select select.is-active,.is-active.textarea,.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active,.is-active.button{outline:none}.pagination-previous[disabled],.pagination-next[disabled],.pagination-link[disabled],.pagination-ellipsis[disabled],.file-cta[disabled],.file-name[disabled],.select select[disabled],.textarea[disabled],.input[disabled],#documenter .docs-sidebar form.docs-search>input[disabled],.button[disabled],fieldset[disabled] .pagination-previous,fieldset[disabled] .pagination-next,fieldset[disabled] .pagination-link,fieldset[disabled] .pagination-ellipsis,fieldset[disabled] .file-cta,fieldset[disabled] .file-name,fieldset[disabled] .select select,.select fieldset[disabled] select,fieldset[disabled] .textarea,fieldset[disabled] .input,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input,fieldset[disabled] .button{cursor:not-allowed}.tabs,.pagination-previous,.pagination-next,.pagination-link,.pagination-ellipsis,.breadcrumb,.file,.button,.is-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.navbar-link:not(.is-arrowless)::after,.select:not(.is-multiple):not(.is-loading)::after{border:3px solid rgba(0,0,0,0);border-radius:2px;border-right:0;border-top:0;content:" ";display:block;height:0.625em;margin-top:-0.4375em;pointer-events:none;position:absolute;top:50%;transform:rotate(-45deg);transform-origin:center;width:0.625em}.admonition:not(:last-child),.tabs:not(:last-child),.pagination:not(:last-child),.message:not(:last-child),.level:not(:last-child),.breadcrumb:not(:last-child),.block:not(:last-child),.title:not(:last-child),.subtitle:not(:last-child),.table-container:not(:last-child),.table:not(:last-child),.progress:not(:last-child),.notification:not(:last-child),.content:not(:last-child),.box:not(:last-child){margin-bottom:1.5rem}.modal-close,.delete{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-moz-appearance:none;-webkit-appearance:none;background-color:rgba(10,10,10,0.2);border:none;border-radius:9999px;cursor:pointer;pointer-events:auto;display:inline-block;flex-grow:0;flex-shrink:0;font-size:0;height:20px;max-height:20px;max-width:20px;min-height:20px;min-width:20px;outline:none;position:relative;vertical-align:top;width:20px}.modal-close::before,.delete::before,.modal-close::after,.delete::after{background-color:#fff;content:"";display:block;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%) rotate(45deg);transform-origin:center center}.modal-close::before,.delete::before{height:2px;width:50%}.modal-close::after,.delete::after{height:50%;width:2px}.modal-close:hover,.delete:hover,.modal-close:focus,.delete:focus{background-color:rgba(10,10,10,0.3)}.modal-close:active,.delete:active{background-color:rgba(10,10,10,0.4)}.is-small.modal-close,#documenter .docs-sidebar form.docs-search>input.modal-close,.is-small.delete,#documenter .docs-sidebar form.docs-search>input.delete{height:16px;max-height:16px;max-width:16px;min-height:16px;min-width:16px;width:16px}.is-medium.modal-close,.is-medium.delete{height:24px;max-height:24px;max-width:24px;min-height:24px;min-width:24px;width:24px}.is-large.modal-close,.is-large.delete{height:32px;max-height:32px;max-width:32px;min-height:32px;min-width:32px;width:32px}.control.is-loading::after,.select.is-loading::after,.loader,.button.is-loading::after{animation:spinAround 500ms infinite linear;border:2px solid #dbdbdb;border-radius:9999px;border-right-color:transparent;border-top-color:transparent;content:"";display:block;height:1em;position:relative;width:1em}.hero-video,.modal-background,.modal,.image.is-square img,#documenter .docs-sidebar .docs-logo>img.is-square img,.image.is-square .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-square .has-ratio,.image.is-1by1 img,#documenter .docs-sidebar .docs-logo>img.is-1by1 img,.image.is-1by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by1 .has-ratio,.image.is-5by4 img,#documenter .docs-sidebar .docs-logo>img.is-5by4 img,.image.is-5by4 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-5by4 .has-ratio,.image.is-4by3 img,#documenter .docs-sidebar .docs-logo>img.is-4by3 img,.image.is-4by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-4by3 .has-ratio,.image.is-3by2 img,#documenter .docs-sidebar .docs-logo>img.is-3by2 img,.image.is-3by2 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by2 .has-ratio,.image.is-5by3 img,#documenter .docs-sidebar .docs-logo>img.is-5by3 img,.image.is-5by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-5by3 .has-ratio,.image.is-16by9 img,#documenter .docs-sidebar .docs-logo>img.is-16by9 img,.image.is-16by9 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-16by9 .has-ratio,.image.is-2by1 img,#documenter .docs-sidebar .docs-logo>img.is-2by1 img,.image.is-2by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-2by1 .has-ratio,.image.is-3by1 img,#documenter .docs-sidebar .docs-logo>img.is-3by1 img,.image.is-3by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by1 .has-ratio,.image.is-4by5 img,#documenter .docs-sidebar .docs-logo>img.is-4by5 img,.image.is-4by5 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-4by5 .has-ratio,.image.is-3by4 img,#documenter .docs-sidebar .docs-logo>img.is-3by4 img,.image.is-3by4 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by4 .has-ratio,.image.is-2by3 img,#documenter .docs-sidebar .docs-logo>img.is-2by3 img,.image.is-2by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-2by3 .has-ratio,.image.is-3by5 img,#documenter .docs-sidebar .docs-logo>img.is-3by5 img,.image.is-3by5 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by5 .has-ratio,.image.is-9by16 img,#documenter .docs-sidebar .docs-logo>img.is-9by16 img,.image.is-9by16 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-9by16 .has-ratio,.image.is-1by2 img,#documenter .docs-sidebar .docs-logo>img.is-1by2 img,.image.is-1by2 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by2 .has-ratio,.image.is-1by3 img,#documenter .docs-sidebar .docs-logo>img.is-1by3 img,.image.is-1by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by3 .has-ratio,.is-overlay{bottom:0;left:0;position:absolute;right:0;top:0}.navbar-burger{-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;color:currentColor;font-family:inherit;font-size:1em;margin:0;padding:0}.has-text-white{color:#fff !important}a.has-text-white:hover,a.has-text-white:focus{color:#e6e6e6 !important}.has-background-white{background-color:#fff !important}.has-text-black{color:#0a0a0a !important}a.has-text-black:hover,a.has-text-black:focus{color:#000 !important}.has-background-black{background-color:#0a0a0a !important}.has-text-light{color:#f5f5f5 !important}a.has-text-light:hover,a.has-text-light:focus{color:#dbdbdb !important}.has-background-light{background-color:#f5f5f5 !important}.has-text-dark{color:#363636 !important}a.has-text-dark:hover,a.has-text-dark:focus{color:#1c1c1c !important}.has-background-dark{background-color:#363636 !important}.has-text-primary{color:#4eb5de !important}a.has-text-primary:hover,a.has-text-primary:focus{color:#27a1d2 !important}.has-background-primary{background-color:#4eb5de !important}.has-text-primary-light{color:#eef8fc !important}a.has-text-primary-light:hover,a.has-text-primary-light:focus{color:#c3e6f4 !important}.has-background-primary-light{background-color:#eef8fc !important}.has-text-primary-dark{color:#1a6d8e !important}a.has-text-primary-dark:hover,a.has-text-primary-dark:focus{color:#228eb9 !important}.has-background-primary-dark{background-color:#1a6d8e !important}.has-text-link{color:#2e63b8 !important}a.has-text-link:hover,a.has-text-link:focus{color:#244d8f !important}.has-background-link{background-color:#2e63b8 !important}.has-text-link-light{color:#eff3fb !important}a.has-text-link-light:hover,a.has-text-link-light:focus{color:#c6d6f1 !important}.has-background-link-light{background-color:#eff3fb !important}.has-text-link-dark{color:#3169c4 !important}a.has-text-link-dark:hover,a.has-text-link-dark:focus{color:#5485d4 !important}.has-background-link-dark{background-color:#3169c4 !important}.has-text-info{color:#209cee !important}a.has-text-info:hover,a.has-text-info:focus{color:#1081cb !important}.has-background-info{background-color:#209cee !important}.has-text-info-light{color:#ecf7fe !important}a.has-text-info-light:hover,a.has-text-info-light:focus{color:#bde2fa !important}.has-background-info-light{background-color:#ecf7fe !important}.has-text-info-dark{color:#0e72b4 !important}a.has-text-info-dark:hover,a.has-text-info-dark:focus{color:#1190e3 !important}.has-background-info-dark{background-color:#0e72b4 !important}.has-text-success{color:#22c35b !important}a.has-text-success:hover,a.has-text-success:focus{color:#1a9847 !important}.has-background-success{background-color:#22c35b !important}.has-text-success-light{color:#eefcf3 !important}a.has-text-success-light:hover,a.has-text-success-light:focus{color:#c2f4d4 !important}.has-background-success-light{background-color:#eefcf3 !important}.has-text-success-dark{color:#198f43 !important}a.has-text-success-dark:hover,a.has-text-success-dark:focus{color:#21bb57 !important}.has-background-success-dark{background-color:#198f43 !important}.has-text-warning{color:#ffdd57 !important}a.has-text-warning:hover,a.has-text-warning:focus{color:#ffd324 !important}.has-background-warning{background-color:#ffdd57 !important}.has-text-warning-light{color:#fffbeb !important}a.has-text-warning-light:hover,a.has-text-warning-light:focus{color:#fff1b8 !important}.has-background-warning-light{background-color:#fffbeb !important}.has-text-warning-dark{color:#947600 !important}a.has-text-warning-dark:hover,a.has-text-warning-dark:focus{color:#c79f00 !important}.has-background-warning-dark{background-color:#947600 !important}.has-text-danger{color:#da0b00 !important}a.has-text-danger:hover,a.has-text-danger:focus{color:#a70800 !important}.has-background-danger{background-color:#da0b00 !important}.has-text-danger-light{color:#ffeceb !important}a.has-text-danger-light:hover,a.has-text-danger-light:focus{color:#ffbbb8 !important}.has-background-danger-light{background-color:#ffeceb !important}.has-text-danger-dark{color:#f50c00 !important}a.has-text-danger-dark:hover,a.has-text-danger-dark:focus{color:#ff3429 !important}.has-background-danger-dark{background-color:#f50c00 !important}.has-text-black-bis{color:#121212 !important}.has-background-black-bis{background-color:#121212 !important}.has-text-black-ter{color:#242424 !important}.has-background-black-ter{background-color:#242424 !important}.has-text-grey-darker{color:#363636 !important}.has-background-grey-darker{background-color:#363636 !important}.has-text-grey-dark{color:#4a4a4a !important}.has-background-grey-dark{background-color:#4a4a4a !important}.has-text-grey{color:#6b6b6b !important}.has-background-grey{background-color:#6b6b6b !important}.has-text-grey-light{color:#b5b5b5 !important}.has-background-grey-light{background-color:#b5b5b5 !important}.has-text-grey-lighter{color:#dbdbdb !important}.has-background-grey-lighter{background-color:#dbdbdb !important}.has-text-white-ter{color:#f5f5f5 !important}.has-background-white-ter{background-color:#f5f5f5 !important}.has-text-white-bis{color:#fafafa !important}.has-background-white-bis{background-color:#fafafa !important}.is-flex-direction-row{flex-direction:row !important}.is-flex-direction-row-reverse{flex-direction:row-reverse !important}.is-flex-direction-column{flex-direction:column !important}.is-flex-direction-column-reverse{flex-direction:column-reverse !important}.is-flex-wrap-nowrap{flex-wrap:nowrap !important}.is-flex-wrap-wrap{flex-wrap:wrap !important}.is-flex-wrap-wrap-reverse{flex-wrap:wrap-reverse !important}.is-justify-content-flex-start{justify-content:flex-start !important}.is-justify-content-flex-end{justify-content:flex-end !important}.is-justify-content-center{justify-content:center !important}.is-justify-content-space-between{justify-content:space-between !important}.is-justify-content-space-around{justify-content:space-around !important}.is-justify-content-space-evenly{justify-content:space-evenly !important}.is-justify-content-start{justify-content:start !important}.is-justify-content-end{justify-content:end !important}.is-justify-content-left{justify-content:left !important}.is-justify-content-right{justify-content:right !important}.is-align-content-flex-start{align-content:flex-start !important}.is-align-content-flex-end{align-content:flex-end !important}.is-align-content-center{align-content:center !important}.is-align-content-space-between{align-content:space-between !important}.is-align-content-space-around{align-content:space-around !important}.is-align-content-space-evenly{align-content:space-evenly !important}.is-align-content-stretch{align-content:stretch !important}.is-align-content-start{align-content:start !important}.is-align-content-end{align-content:end !important}.is-align-content-baseline{align-content:baseline !important}.is-align-items-stretch{align-items:stretch !important}.is-align-items-flex-start{align-items:flex-start !important}.is-align-items-flex-end{align-items:flex-end !important}.is-align-items-center{align-items:center !important}.is-align-items-baseline{align-items:baseline !important}.is-align-items-start{align-items:start !important}.is-align-items-end{align-items:end !important}.is-align-items-self-start{align-items:self-start !important}.is-align-items-self-end{align-items:self-end !important}.is-align-self-auto{align-self:auto !important}.is-align-self-flex-start{align-self:flex-start !important}.is-align-self-flex-end{align-self:flex-end !important}.is-align-self-center{align-self:center !important}.is-align-self-baseline{align-self:baseline !important}.is-align-self-stretch{align-self:stretch !important}.is-flex-grow-0{flex-grow:0 !important}.is-flex-grow-1{flex-grow:1 !important}.is-flex-grow-2{flex-grow:2 !important}.is-flex-grow-3{flex-grow:3 !important}.is-flex-grow-4{flex-grow:4 !important}.is-flex-grow-5{flex-grow:5 !important}.is-flex-shrink-0{flex-shrink:0 !important}.is-flex-shrink-1{flex-shrink:1 !important}.is-flex-shrink-2{flex-shrink:2 !important}.is-flex-shrink-3{flex-shrink:3 !important}.is-flex-shrink-4{flex-shrink:4 !important}.is-flex-shrink-5{flex-shrink:5 !important}.is-clearfix::after{clear:both;content:" ";display:table}.is-pulled-left{float:left !important}.is-pulled-right{float:right !important}.is-radiusless{border-radius:0 !important}.is-shadowless{box-shadow:none !important}.is-clickable{cursor:pointer !important;pointer-events:all !important}.is-clipped{overflow:hidden !important}.is-relative{position:relative !important}.is-marginless{margin:0 !important}.is-paddingless{padding:0 !important}.m-0{margin:0 !important}.mt-0{margin-top:0 !important}.mr-0{margin-right:0 !important}.mb-0{margin-bottom:0 !important}.ml-0{margin-left:0 !important}.mx-0{margin-left:0 !important;margin-right:0 !important}.my-0{margin-top:0 !important;margin-bottom:0 !important}.m-1{margin:.25rem !important}.mt-1{margin-top:.25rem !important}.mr-1{margin-right:.25rem !important}.mb-1{margin-bottom:.25rem !important}.ml-1{margin-left:.25rem !important}.mx-1{margin-left:.25rem !important;margin-right:.25rem !important}.my-1{margin-top:.25rem !important;margin-bottom:.25rem !important}.m-2{margin:.5rem !important}.mt-2{margin-top:.5rem !important}.mr-2{margin-right:.5rem !important}.mb-2{margin-bottom:.5rem !important}.ml-2{margin-left:.5rem !important}.mx-2{margin-left:.5rem !important;margin-right:.5rem !important}.my-2{margin-top:.5rem !important;margin-bottom:.5rem !important}.m-3{margin:.75rem !important}.mt-3{margin-top:.75rem !important}.mr-3{margin-right:.75rem !important}.mb-3{margin-bottom:.75rem !important}.ml-3{margin-left:.75rem !important}.mx-3{margin-left:.75rem !important;margin-right:.75rem !important}.my-3{margin-top:.75rem !important;margin-bottom:.75rem !important}.m-4{margin:1rem !important}.mt-4{margin-top:1rem !important}.mr-4{margin-right:1rem !important}.mb-4{margin-bottom:1rem !important}.ml-4{margin-left:1rem !important}.mx-4{margin-left:1rem !important;margin-right:1rem !important}.my-4{margin-top:1rem !important;margin-bottom:1rem !important}.m-5{margin:1.5rem !important}.mt-5{margin-top:1.5rem !important}.mr-5{margin-right:1.5rem !important}.mb-5{margin-bottom:1.5rem !important}.ml-5{margin-left:1.5rem !important}.mx-5{margin-left:1.5rem !important;margin-right:1.5rem !important}.my-5{margin-top:1.5rem !important;margin-bottom:1.5rem !important}.m-6{margin:3rem !important}.mt-6{margin-top:3rem !important}.mr-6{margin-right:3rem !important}.mb-6{margin-bottom:3rem !important}.ml-6{margin-left:3rem !important}.mx-6{margin-left:3rem !important;margin-right:3rem !important}.my-6{margin-top:3rem !important;margin-bottom:3rem !important}.m-auto{margin:auto !important}.mt-auto{margin-top:auto !important}.mr-auto{margin-right:auto !important}.mb-auto{margin-bottom:auto !important}.ml-auto{margin-left:auto !important}.mx-auto{margin-left:auto !important;margin-right:auto !important}.my-auto{margin-top:auto !important;margin-bottom:auto !important}.p-0{padding:0 !important}.pt-0{padding-top:0 !important}.pr-0{padding-right:0 !important}.pb-0{padding-bottom:0 !important}.pl-0{padding-left:0 !important}.px-0{padding-left:0 !important;padding-right:0 !important}.py-0{padding-top:0 !important;padding-bottom:0 !important}.p-1{padding:.25rem !important}.pt-1{padding-top:.25rem !important}.pr-1{padding-right:.25rem !important}.pb-1{padding-bottom:.25rem !important}.pl-1{padding-left:.25rem !important}.px-1{padding-left:.25rem !important;padding-right:.25rem !important}.py-1{padding-top:.25rem !important;padding-bottom:.25rem !important}.p-2{padding:.5rem !important}.pt-2{padding-top:.5rem !important}.pr-2{padding-right:.5rem !important}.pb-2{padding-bottom:.5rem !important}.pl-2{padding-left:.5rem !important}.px-2{padding-left:.5rem !important;padding-right:.5rem !important}.py-2{padding-top:.5rem !important;padding-bottom:.5rem !important}.p-3{padding:.75rem !important}.pt-3{padding-top:.75rem !important}.pr-3{padding-right:.75rem !important}.pb-3{padding-bottom:.75rem !important}.pl-3{padding-left:.75rem !important}.px-3{padding-left:.75rem !important;padding-right:.75rem !important}.py-3{padding-top:.75rem !important;padding-bottom:.75rem !important}.p-4{padding:1rem !important}.pt-4{padding-top:1rem !important}.pr-4{padding-right:1rem !important}.pb-4{padding-bottom:1rem !important}.pl-4{padding-left:1rem !important}.px-4{padding-left:1rem !important;padding-right:1rem !important}.py-4{padding-top:1rem !important;padding-bottom:1rem !important}.p-5{padding:1.5rem !important}.pt-5{padding-top:1.5rem !important}.pr-5{padding-right:1.5rem !important}.pb-5{padding-bottom:1.5rem !important}.pl-5{padding-left:1.5rem !important}.px-5{padding-left:1.5rem !important;padding-right:1.5rem !important}.py-5{padding-top:1.5rem !important;padding-bottom:1.5rem !important}.p-6{padding:3rem !important}.pt-6{padding-top:3rem !important}.pr-6{padding-right:3rem !important}.pb-6{padding-bottom:3rem !important}.pl-6{padding-left:3rem !important}.px-6{padding-left:3rem !important;padding-right:3rem !important}.py-6{padding-top:3rem !important;padding-bottom:3rem !important}.p-auto{padding:auto !important}.pt-auto{padding-top:auto !important}.pr-auto{padding-right:auto !important}.pb-auto{padding-bottom:auto !important}.pl-auto{padding-left:auto !important}.px-auto{padding-left:auto !important;padding-right:auto !important}.py-auto{padding-top:auto !important;padding-bottom:auto !important}.is-size-1{font-size:3rem !important}.is-size-2{font-size:2.5rem !important}.is-size-3{font-size:2rem !important}.is-size-4{font-size:1.5rem !important}.is-size-5{font-size:1.25rem !important}.is-size-6{font-size:1rem !important}.is-size-7,.docstring>section>a.docs-sourcelink{font-size:.75rem !important}@media screen and (max-width: 768px){.is-size-1-mobile{font-size:3rem !important}.is-size-2-mobile{font-size:2.5rem !important}.is-size-3-mobile{font-size:2rem !important}.is-size-4-mobile{font-size:1.5rem !important}.is-size-5-mobile{font-size:1.25rem !important}.is-size-6-mobile{font-size:1rem !important}.is-size-7-mobile{font-size:.75rem !important}}@media screen and (min-width: 769px),print{.is-size-1-tablet{font-size:3rem !important}.is-size-2-tablet{font-size:2.5rem !important}.is-size-3-tablet{font-size:2rem !important}.is-size-4-tablet{font-size:1.5rem !important}.is-size-5-tablet{font-size:1.25rem !important}.is-size-6-tablet{font-size:1rem !important}.is-size-7-tablet{font-size:.75rem !important}}@media screen and (max-width: 1055px){.is-size-1-touch{font-size:3rem !important}.is-size-2-touch{font-size:2.5rem !important}.is-size-3-touch{font-size:2rem !important}.is-size-4-touch{font-size:1.5rem !important}.is-size-5-touch{font-size:1.25rem !important}.is-size-6-touch{font-size:1rem !important}.is-size-7-touch{font-size:.75rem !important}}@media screen and (min-width: 1056px){.is-size-1-desktop{font-size:3rem !important}.is-size-2-desktop{font-size:2.5rem !important}.is-size-3-desktop{font-size:2rem !important}.is-size-4-desktop{font-size:1.5rem !important}.is-size-5-desktop{font-size:1.25rem !important}.is-size-6-desktop{font-size:1rem !important}.is-size-7-desktop{font-size:.75rem !important}}@media screen and (min-width: 1216px){.is-size-1-widescreen{font-size:3rem !important}.is-size-2-widescreen{font-size:2.5rem !important}.is-size-3-widescreen{font-size:2rem !important}.is-size-4-widescreen{font-size:1.5rem !important}.is-size-5-widescreen{font-size:1.25rem !important}.is-size-6-widescreen{font-size:1rem !important}.is-size-7-widescreen{font-size:.75rem !important}}@media screen and (min-width: 1408px){.is-size-1-fullhd{font-size:3rem !important}.is-size-2-fullhd{font-size:2.5rem !important}.is-size-3-fullhd{font-size:2rem !important}.is-size-4-fullhd{font-size:1.5rem !important}.is-size-5-fullhd{font-size:1.25rem !important}.is-size-6-fullhd{font-size:1rem !important}.is-size-7-fullhd{font-size:.75rem !important}}.has-text-centered{text-align:center !important}.has-text-justified{text-align:justify !important}.has-text-left{text-align:left !important}.has-text-right{text-align:right !important}@media screen and (max-width: 768px){.has-text-centered-mobile{text-align:center !important}}@media screen and (min-width: 769px),print{.has-text-centered-tablet{text-align:center !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-centered-tablet-only{text-align:center !important}}@media screen and (max-width: 1055px){.has-text-centered-touch{text-align:center !important}}@media screen and (min-width: 1056px){.has-text-centered-desktop{text-align:center !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-centered-desktop-only{text-align:center !important}}@media screen and (min-width: 1216px){.has-text-centered-widescreen{text-align:center !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-centered-widescreen-only{text-align:center !important}}@media screen and (min-width: 1408px){.has-text-centered-fullhd{text-align:center !important}}@media screen and (max-width: 768px){.has-text-justified-mobile{text-align:justify !important}}@media screen and (min-width: 769px),print{.has-text-justified-tablet{text-align:justify !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-justified-tablet-only{text-align:justify !important}}@media screen and (max-width: 1055px){.has-text-justified-touch{text-align:justify !important}}@media screen and (min-width: 1056px){.has-text-justified-desktop{text-align:justify !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-justified-desktop-only{text-align:justify !important}}@media screen and (min-width: 1216px){.has-text-justified-widescreen{text-align:justify !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-justified-widescreen-only{text-align:justify !important}}@media screen and (min-width: 1408px){.has-text-justified-fullhd{text-align:justify !important}}@media screen and (max-width: 768px){.has-text-left-mobile{text-align:left !important}}@media screen and (min-width: 769px),print{.has-text-left-tablet{text-align:left !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-left-tablet-only{text-align:left !important}}@media screen and (max-width: 1055px){.has-text-left-touch{text-align:left !important}}@media screen and (min-width: 1056px){.has-text-left-desktop{text-align:left !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-left-desktop-only{text-align:left !important}}@media screen and (min-width: 1216px){.has-text-left-widescreen{text-align:left !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-left-widescreen-only{text-align:left !important}}@media screen and (min-width: 1408px){.has-text-left-fullhd{text-align:left !important}}@media screen and (max-width: 768px){.has-text-right-mobile{text-align:right !important}}@media screen and (min-width: 769px),print{.has-text-right-tablet{text-align:right !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.has-text-right-tablet-only{text-align:right !important}}@media screen and (max-width: 1055px){.has-text-right-touch{text-align:right !important}}@media screen and (min-width: 1056px){.has-text-right-desktop{text-align:right !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.has-text-right-desktop-only{text-align:right !important}}@media screen and (min-width: 1216px){.has-text-right-widescreen{text-align:right !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.has-text-right-widescreen-only{text-align:right !important}}@media screen and (min-width: 1408px){.has-text-right-fullhd{text-align:right !important}}.is-capitalized{text-transform:capitalize !important}.is-lowercase{text-transform:lowercase !important}.is-uppercase{text-transform:uppercase !important}.is-italic{font-style:italic !important}.is-underlined{text-decoration:underline !important}.has-text-weight-light{font-weight:300 !important}.has-text-weight-normal{font-weight:400 !important}.has-text-weight-medium{font-weight:500 !important}.has-text-weight-semibold{font-weight:600 !important}.has-text-weight-bold{font-weight:700 !important}.is-family-primary{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-secondary{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-sans-serif{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif !important}.is-family-monospace{font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace !important}.is-family-code{font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace !important}.is-block{display:block !important}@media screen and (max-width: 768px){.is-block-mobile{display:block !important}}@media screen and (min-width: 769px),print{.is-block-tablet{display:block !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-block-tablet-only{display:block !important}}@media screen and (max-width: 1055px){.is-block-touch{display:block !important}}@media screen and (min-width: 1056px){.is-block-desktop{display:block !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-block-desktop-only{display:block !important}}@media screen and (min-width: 1216px){.is-block-widescreen{display:block !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-block-widescreen-only{display:block !important}}@media screen and (min-width: 1408px){.is-block-fullhd{display:block !important}}.is-flex{display:flex !important}@media screen and (max-width: 768px){.is-flex-mobile{display:flex !important}}@media screen and (min-width: 769px),print{.is-flex-tablet{display:flex !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-flex-tablet-only{display:flex !important}}@media screen and (max-width: 1055px){.is-flex-touch{display:flex !important}}@media screen and (min-width: 1056px){.is-flex-desktop{display:flex !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-flex-desktop-only{display:flex !important}}@media screen and (min-width: 1216px){.is-flex-widescreen{display:flex !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-flex-widescreen-only{display:flex !important}}@media screen and (min-width: 1408px){.is-flex-fullhd{display:flex !important}}.is-inline{display:inline !important}@media screen and (max-width: 768px){.is-inline-mobile{display:inline !important}}@media screen and (min-width: 769px),print{.is-inline-tablet{display:inline !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-tablet-only{display:inline !important}}@media screen and (max-width: 1055px){.is-inline-touch{display:inline !important}}@media screen and (min-width: 1056px){.is-inline-desktop{display:inline !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-desktop-only{display:inline !important}}@media screen and (min-width: 1216px){.is-inline-widescreen{display:inline !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-widescreen-only{display:inline !important}}@media screen and (min-width: 1408px){.is-inline-fullhd{display:inline !important}}.is-inline-block{display:inline-block !important}@media screen and (max-width: 768px){.is-inline-block-mobile{display:inline-block !important}}@media screen and (min-width: 769px),print{.is-inline-block-tablet{display:inline-block !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-block-tablet-only{display:inline-block !important}}@media screen and (max-width: 1055px){.is-inline-block-touch{display:inline-block !important}}@media screen and (min-width: 1056px){.is-inline-block-desktop{display:inline-block !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-block-desktop-only{display:inline-block !important}}@media screen and (min-width: 1216px){.is-inline-block-widescreen{display:inline-block !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-block-widescreen-only{display:inline-block !important}}@media screen and (min-width: 1408px){.is-inline-block-fullhd{display:inline-block !important}}.is-inline-flex{display:inline-flex !important}@media screen and (max-width: 768px){.is-inline-flex-mobile{display:inline-flex !important}}@media screen and (min-width: 769px),print{.is-inline-flex-tablet{display:inline-flex !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-inline-flex-tablet-only{display:inline-flex !important}}@media screen and (max-width: 1055px){.is-inline-flex-touch{display:inline-flex !important}}@media screen and (min-width: 1056px){.is-inline-flex-desktop{display:inline-flex !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-inline-flex-desktop-only{display:inline-flex !important}}@media screen and (min-width: 1216px){.is-inline-flex-widescreen{display:inline-flex !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-inline-flex-widescreen-only{display:inline-flex !important}}@media screen and (min-width: 1408px){.is-inline-flex-fullhd{display:inline-flex !important}}.is-hidden{display:none !important}.is-sr-only{border:none !important;clip:rect(0, 0, 0, 0) !important;height:0.01em !important;overflow:hidden !important;padding:0 !important;position:absolute !important;white-space:nowrap !important;width:0.01em !important}@media screen and (max-width: 768px){.is-hidden-mobile{display:none !important}}@media screen and (min-width: 769px),print{.is-hidden-tablet{display:none !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-hidden-tablet-only{display:none !important}}@media screen and (max-width: 1055px){.is-hidden-touch{display:none !important}}@media screen and (min-width: 1056px){.is-hidden-desktop{display:none !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-hidden-desktop-only{display:none !important}}@media screen and (min-width: 1216px){.is-hidden-widescreen{display:none !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-hidden-widescreen-only{display:none !important}}@media screen and (min-width: 1408px){.is-hidden-fullhd{display:none !important}}.is-invisible{visibility:hidden !important}@media screen and (max-width: 768px){.is-invisible-mobile{visibility:hidden !important}}@media screen and (min-width: 769px),print{.is-invisible-tablet{visibility:hidden !important}}@media screen and (min-width: 769px) and (max-width: 1055px){.is-invisible-tablet-only{visibility:hidden !important}}@media screen and (max-width: 1055px){.is-invisible-touch{visibility:hidden !important}}@media screen and (min-width: 1056px){.is-invisible-desktop{visibility:hidden !important}}@media screen and (min-width: 1056px) and (max-width: 1215px){.is-invisible-desktop-only{visibility:hidden !important}}@media screen and (min-width: 1216px){.is-invisible-widescreen{visibility:hidden !important}}@media screen and (min-width: 1216px) and (max-width: 1407px){.is-invisible-widescreen-only{visibility:hidden !important}}@media screen and (min-width: 1408px){.is-invisible-fullhd{visibility:hidden !important}}/*! minireset.css v0.0.6 | MIT License | github.com/jgthms/minireset.css */html,body,p,ol,ul,li,dl,dt,dd,blockquote,figure,fieldset,legend,textarea,pre,iframe,hr,h1,h2,h3,h4,h5,h6{margin:0;padding:0}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}ul{list-style:none}button,input,select,textarea{margin:0}html{box-sizing:border-box}*,*::before,*::after{box-sizing:inherit}img,video{height:auto;max-width:100%}iframe{border:0}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}td:not([align]),th:not([align]){text-align:inherit}html{background-color:#fff;font-size:16px;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;min-width:300px;overflow-x:auto;overflow-y:scroll;text-rendering:optimizeLegibility;text-size-adjust:100%}article,aside,figure,footer,header,hgroup,section{display:block}body,button,input,optgroup,select,textarea{font-family:"Lato Medium",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue","Helvetica","Arial",sans-serif}code,pre{-moz-osx-font-smoothing:auto;-webkit-font-smoothing:auto;font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace}body{color:#222;font-size:1em;font-weight:400;line-height:1.5}a{color:#2e63b8;cursor:pointer;text-decoration:none}a strong{color:currentColor}a:hover{color:#363636}code{background-color:rgba(0,0,0,0.05);color:#000;font-size:.875em;font-weight:normal;padding:.1em}hr{background-color:#f5f5f5;border:none;display:block;height:2px;margin:1.5rem 0}img{height:auto;max-width:100%}input[type="checkbox"],input[type="radio"]{vertical-align:baseline}small{font-size:.875em}span{font-style:inherit;font-weight:inherit}strong{color:#222;font-weight:700}fieldset{border:none}pre{-webkit-overflow-scrolling:touch;background-color:#f5f5f5;color:#222;font-size:.875em;overflow-x:auto;padding:1.25rem 1.5rem;white-space:pre;word-wrap:normal}pre code{background-color:transparent;color:currentColor;font-size:1em;padding:0}table td,table th{vertical-align:top}table td:not([align]),table th:not([align]){text-align:inherit}table th{color:#222}@keyframes spinAround{from{transform:rotate(0deg)}to{transform:rotate(359deg)}}.box{background-color:#fff;border-radius:6px;box-shadow:#bbb;color:#222;display:block;padding:1.25rem}a.box:hover,a.box:focus{box-shadow:0 0.5em 1em -0.125em rgba(10,10,10,0.1),0 0 0 1px #2e63b8}a.box:active{box-shadow:inset 0 1px 2px rgba(10,10,10,0.2),0 0 0 1px #2e63b8}.button{background-color:#fff;border-color:#dbdbdb;border-width:1px;color:#222;cursor:pointer;justify-content:center;padding-bottom:calc(0.5em - 1px);padding-left:1em;padding-right:1em;padding-top:calc(0.5em - 1px);text-align:center;white-space:nowrap}.button strong{color:inherit}.button .icon,.button .icon.is-small,.button #documenter .docs-sidebar form.docs-search>input.icon,#documenter .docs-sidebar .button form.docs-search>input.icon,.button .icon.is-medium,.button .icon.is-large{height:1.5em;width:1.5em}.button .icon:first-child:not(:last-child){margin-left:calc(-0.5em - 1px);margin-right:.25em}.button .icon:last-child:not(:first-child){margin-left:.25em;margin-right:calc(-0.5em - 1px)}.button .icon:first-child:last-child{margin-left:calc(-0.5em - 1px);margin-right:calc(-0.5em - 1px)}.button:hover,.button.is-hovered{border-color:#b5b5b5;color:#363636}.button:focus,.button.is-focused{border-color:#3c5dcd;color:#363636}.button:focus:not(:active),.button.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(46,99,184,0.25)}.button:active,.button.is-active{border-color:#4a4a4a;color:#363636}.button.is-text{background-color:transparent;border-color:transparent;color:#222;text-decoration:underline}.button.is-text:hover,.button.is-text.is-hovered,.button.is-text:focus,.button.is-text.is-focused{background-color:#f5f5f5;color:#222}.button.is-text:active,.button.is-text.is-active{background-color:#e8e8e8;color:#222}.button.is-text[disabled],fieldset[disabled] .button.is-text{background-color:transparent;border-color:transparent;box-shadow:none}.button.is-ghost{background:none;border-color:rgba(0,0,0,0);color:#2e63b8;text-decoration:none}.button.is-ghost:hover,.button.is-ghost.is-hovered{color:#2e63b8;text-decoration:underline}.button.is-white{background-color:#fff;border-color:transparent;color:#0a0a0a}.button.is-white:hover,.button.is-white.is-hovered{background-color:#f9f9f9;border-color:transparent;color:#0a0a0a}.button.is-white:focus,.button.is-white.is-focused{border-color:transparent;color:#0a0a0a}.button.is-white:focus:not(:active),.button.is-white.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}.button.is-white:active,.button.is-white.is-active{background-color:#f2f2f2;border-color:transparent;color:#0a0a0a}.button.is-white[disabled],fieldset[disabled] .button.is-white{background-color:#fff;border-color:#fff;box-shadow:none}.button.is-white.is-inverted{background-color:#0a0a0a;color:#fff}.button.is-white.is-inverted:hover,.button.is-white.is-inverted.is-hovered{background-color:#000}.button.is-white.is-inverted[disabled],fieldset[disabled] .button.is-white.is-inverted{background-color:#0a0a0a;border-color:transparent;box-shadow:none;color:#fff}.button.is-white.is-loading::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}.button.is-white.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-white.is-outlined:hover,.button.is-white.is-outlined.is-hovered,.button.is-white.is-outlined:focus,.button.is-white.is-outlined.is-focused{background-color:#fff;border-color:#fff;color:#0a0a0a}.button.is-white.is-outlined.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-white.is-outlined.is-loading:hover::after,.button.is-white.is-outlined.is-loading.is-hovered::after,.button.is-white.is-outlined.is-loading:focus::after,.button.is-white.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}.button.is-white.is-outlined[disabled],fieldset[disabled] .button.is-white.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-white.is-inverted.is-outlined{background-color:transparent;border-color:#0a0a0a;color:#0a0a0a}.button.is-white.is-inverted.is-outlined:hover,.button.is-white.is-inverted.is-outlined.is-hovered,.button.is-white.is-inverted.is-outlined:focus,.button.is-white.is-inverted.is-outlined.is-focused{background-color:#0a0a0a;color:#fff}.button.is-white.is-inverted.is-outlined.is-loading:hover::after,.button.is-white.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-white.is-inverted.is-outlined.is-loading:focus::after,.button.is-white.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-white.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-white.is-inverted.is-outlined{background-color:transparent;border-color:#0a0a0a;box-shadow:none;color:#0a0a0a}.button.is-black{background-color:#0a0a0a;border-color:transparent;color:#fff}.button.is-black:hover,.button.is-black.is-hovered{background-color:#040404;border-color:transparent;color:#fff}.button.is-black:focus,.button.is-black.is-focused{border-color:transparent;color:#fff}.button.is-black:focus:not(:active),.button.is-black.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}.button.is-black:active,.button.is-black.is-active{background-color:#000;border-color:transparent;color:#fff}.button.is-black[disabled],fieldset[disabled] .button.is-black{background-color:#0a0a0a;border-color:#0a0a0a;box-shadow:none}.button.is-black.is-inverted{background-color:#fff;color:#0a0a0a}.button.is-black.is-inverted:hover,.button.is-black.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-black.is-inverted[disabled],fieldset[disabled] .button.is-black.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#0a0a0a}.button.is-black.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-black.is-outlined{background-color:transparent;border-color:#0a0a0a;color:#0a0a0a}.button.is-black.is-outlined:hover,.button.is-black.is-outlined.is-hovered,.button.is-black.is-outlined:focus,.button.is-black.is-outlined.is-focused{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}.button.is-black.is-outlined.is-loading::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}.button.is-black.is-outlined.is-loading:hover::after,.button.is-black.is-outlined.is-loading.is-hovered::after,.button.is-black.is-outlined.is-loading:focus::after,.button.is-black.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-black.is-outlined[disabled],fieldset[disabled] .button.is-black.is-outlined{background-color:transparent;border-color:#0a0a0a;box-shadow:none;color:#0a0a0a}.button.is-black.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-black.is-inverted.is-outlined:hover,.button.is-black.is-inverted.is-outlined.is-hovered,.button.is-black.is-inverted.is-outlined:focus,.button.is-black.is-inverted.is-outlined.is-focused{background-color:#fff;color:#0a0a0a}.button.is-black.is-inverted.is-outlined.is-loading:hover::after,.button.is-black.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-black.is-inverted.is-outlined.is-loading:focus::after,.button.is-black.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #0a0a0a #0a0a0a !important}.button.is-black.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-black.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-light{background-color:#f5f5f5;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-light:hover,.button.is-light.is-hovered{background-color:#eee;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-light:focus,.button.is-light.is-focused{border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-light:focus:not(:active),.button.is-light.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(245,245,245,0.25)}.button.is-light:active,.button.is-light.is-active{background-color:#e8e8e8;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-light[disabled],fieldset[disabled] .button.is-light{background-color:#f5f5f5;border-color:#f5f5f5;box-shadow:none}.button.is-light.is-inverted{background-color:rgba(0,0,0,0.7);color:#f5f5f5}.button.is-light.is-inverted:hover,.button.is-light.is-inverted.is-hovered{background-color:rgba(0,0,0,0.7)}.button.is-light.is-inverted[disabled],fieldset[disabled] .button.is-light.is-inverted{background-color:rgba(0,0,0,0.7);border-color:transparent;box-shadow:none;color:#f5f5f5}.button.is-light.is-loading::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}.button.is-light.is-outlined{background-color:transparent;border-color:#f5f5f5;color:#f5f5f5}.button.is-light.is-outlined:hover,.button.is-light.is-outlined.is-hovered,.button.is-light.is-outlined:focus,.button.is-light.is-outlined.is-focused{background-color:#f5f5f5;border-color:#f5f5f5;color:rgba(0,0,0,0.7)}.button.is-light.is-outlined.is-loading::after{border-color:transparent transparent #f5f5f5 #f5f5f5 !important}.button.is-light.is-outlined.is-loading:hover::after,.button.is-light.is-outlined.is-loading.is-hovered::after,.button.is-light.is-outlined.is-loading:focus::after,.button.is-light.is-outlined.is-loading.is-focused::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}.button.is-light.is-outlined[disabled],fieldset[disabled] .button.is-light.is-outlined{background-color:transparent;border-color:#f5f5f5;box-shadow:none;color:#f5f5f5}.button.is-light.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);color:rgba(0,0,0,0.7)}.button.is-light.is-inverted.is-outlined:hover,.button.is-light.is-inverted.is-outlined.is-hovered,.button.is-light.is-inverted.is-outlined:focus,.button.is-light.is-inverted.is-outlined.is-focused{background-color:rgba(0,0,0,0.7);color:#f5f5f5}.button.is-light.is-inverted.is-outlined.is-loading:hover::after,.button.is-light.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-light.is-inverted.is-outlined.is-loading:focus::after,.button.is-light.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #f5f5f5 #f5f5f5 !important}.button.is-light.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-light.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);box-shadow:none;color:rgba(0,0,0,0.7)}.button.is-dark,.content kbd.button{background-color:#363636;border-color:transparent;color:#fff}.button.is-dark:hover,.content kbd.button:hover,.button.is-dark.is-hovered,.content kbd.button.is-hovered{background-color:#2f2f2f;border-color:transparent;color:#fff}.button.is-dark:focus,.content kbd.button:focus,.button.is-dark.is-focused,.content kbd.button.is-focused{border-color:transparent;color:#fff}.button.is-dark:focus:not(:active),.content kbd.button:focus:not(:active),.button.is-dark.is-focused:not(:active),.content kbd.button.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(54,54,54,0.25)}.button.is-dark:active,.content kbd.button:active,.button.is-dark.is-active,.content kbd.button.is-active{background-color:#292929;border-color:transparent;color:#fff}.button.is-dark[disabled],.content kbd.button[disabled],fieldset[disabled] .button.is-dark,fieldset[disabled] .content kbd.button,.content fieldset[disabled] kbd.button{background-color:#363636;border-color:#363636;box-shadow:none}.button.is-dark.is-inverted,.content kbd.button.is-inverted{background-color:#fff;color:#363636}.button.is-dark.is-inverted:hover,.content kbd.button.is-inverted:hover,.button.is-dark.is-inverted.is-hovered,.content kbd.button.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-dark.is-inverted[disabled],.content kbd.button.is-inverted[disabled],fieldset[disabled] .button.is-dark.is-inverted,fieldset[disabled] .content kbd.button.is-inverted,.content fieldset[disabled] kbd.button.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#363636}.button.is-dark.is-loading::after,.content kbd.button.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-dark.is-outlined,.content kbd.button.is-outlined{background-color:transparent;border-color:#363636;color:#363636}.button.is-dark.is-outlined:hover,.content kbd.button.is-outlined:hover,.button.is-dark.is-outlined.is-hovered,.content kbd.button.is-outlined.is-hovered,.button.is-dark.is-outlined:focus,.content kbd.button.is-outlined:focus,.button.is-dark.is-outlined.is-focused,.content kbd.button.is-outlined.is-focused{background-color:#363636;border-color:#363636;color:#fff}.button.is-dark.is-outlined.is-loading::after,.content kbd.button.is-outlined.is-loading::after{border-color:transparent transparent #363636 #363636 !important}.button.is-dark.is-outlined.is-loading:hover::after,.content kbd.button.is-outlined.is-loading:hover::after,.button.is-dark.is-outlined.is-loading.is-hovered::after,.content kbd.button.is-outlined.is-loading.is-hovered::after,.button.is-dark.is-outlined.is-loading:focus::after,.content kbd.button.is-outlined.is-loading:focus::after,.button.is-dark.is-outlined.is-loading.is-focused::after,.content kbd.button.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-dark.is-outlined[disabled],.content kbd.button.is-outlined[disabled],fieldset[disabled] .button.is-dark.is-outlined,fieldset[disabled] .content kbd.button.is-outlined,.content fieldset[disabled] kbd.button.is-outlined{background-color:transparent;border-color:#363636;box-shadow:none;color:#363636}.button.is-dark.is-inverted.is-outlined,.content kbd.button.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-dark.is-inverted.is-outlined:hover,.content kbd.button.is-inverted.is-outlined:hover,.button.is-dark.is-inverted.is-outlined.is-hovered,.content kbd.button.is-inverted.is-outlined.is-hovered,.button.is-dark.is-inverted.is-outlined:focus,.content kbd.button.is-inverted.is-outlined:focus,.button.is-dark.is-inverted.is-outlined.is-focused,.content kbd.button.is-inverted.is-outlined.is-focused{background-color:#fff;color:#363636}.button.is-dark.is-inverted.is-outlined.is-loading:hover::after,.content kbd.button.is-inverted.is-outlined.is-loading:hover::after,.button.is-dark.is-inverted.is-outlined.is-loading.is-hovered::after,.content kbd.button.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-dark.is-inverted.is-outlined.is-loading:focus::after,.content kbd.button.is-inverted.is-outlined.is-loading:focus::after,.button.is-dark.is-inverted.is-outlined.is-loading.is-focused::after,.content kbd.button.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #363636 #363636 !important}.button.is-dark.is-inverted.is-outlined[disabled],.content kbd.button.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-dark.is-inverted.is-outlined,fieldset[disabled] .content kbd.button.is-inverted.is-outlined,.content fieldset[disabled] kbd.button.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-primary,.docstring>section>a.button.docs-sourcelink{background-color:#4eb5de;border-color:transparent;color:#fff}.button.is-primary:hover,.docstring>section>a.button.docs-sourcelink:hover,.button.is-primary.is-hovered,.docstring>section>a.button.is-hovered.docs-sourcelink{background-color:#43b1dc;border-color:transparent;color:#fff}.button.is-primary:focus,.docstring>section>a.button.docs-sourcelink:focus,.button.is-primary.is-focused,.docstring>section>a.button.is-focused.docs-sourcelink{border-color:transparent;color:#fff}.button.is-primary:focus:not(:active),.docstring>section>a.button.docs-sourcelink:focus:not(:active),.button.is-primary.is-focused:not(:active),.docstring>section>a.button.is-focused.docs-sourcelink:not(:active){box-shadow:0 0 0 0.125em rgba(78,181,222,0.25)}.button.is-primary:active,.docstring>section>a.button.docs-sourcelink:active,.button.is-primary.is-active,.docstring>section>a.button.is-active.docs-sourcelink{background-color:#39acda;border-color:transparent;color:#fff}.button.is-primary[disabled],.docstring>section>a.button.docs-sourcelink[disabled],fieldset[disabled] .button.is-primary,fieldset[disabled] .docstring>section>a.button.docs-sourcelink{background-color:#4eb5de;border-color:#4eb5de;box-shadow:none}.button.is-primary.is-inverted,.docstring>section>a.button.is-inverted.docs-sourcelink{background-color:#fff;color:#4eb5de}.button.is-primary.is-inverted:hover,.docstring>section>a.button.is-inverted.docs-sourcelink:hover,.button.is-primary.is-inverted.is-hovered,.docstring>section>a.button.is-inverted.is-hovered.docs-sourcelink{background-color:#f2f2f2}.button.is-primary.is-inverted[disabled],.docstring>section>a.button.is-inverted.docs-sourcelink[disabled],fieldset[disabled] .button.is-primary.is-inverted,fieldset[disabled] .docstring>section>a.button.is-inverted.docs-sourcelink{background-color:#fff;border-color:transparent;box-shadow:none;color:#4eb5de}.button.is-primary.is-loading::after,.docstring>section>a.button.is-loading.docs-sourcelink::after{border-color:transparent transparent #fff #fff !important}.button.is-primary.is-outlined,.docstring>section>a.button.is-outlined.docs-sourcelink{background-color:transparent;border-color:#4eb5de;color:#4eb5de}.button.is-primary.is-outlined:hover,.docstring>section>a.button.is-outlined.docs-sourcelink:hover,.button.is-primary.is-outlined.is-hovered,.docstring>section>a.button.is-outlined.is-hovered.docs-sourcelink,.button.is-primary.is-outlined:focus,.docstring>section>a.button.is-outlined.docs-sourcelink:focus,.button.is-primary.is-outlined.is-focused,.docstring>section>a.button.is-outlined.is-focused.docs-sourcelink{background-color:#4eb5de;border-color:#4eb5de;color:#fff}.button.is-primary.is-outlined.is-loading::after,.docstring>section>a.button.is-outlined.is-loading.docs-sourcelink::after{border-color:transparent transparent #4eb5de #4eb5de !important}.button.is-primary.is-outlined.is-loading:hover::after,.docstring>section>a.button.is-outlined.is-loading.docs-sourcelink:hover::after,.button.is-primary.is-outlined.is-loading.is-hovered::after,.docstring>section>a.button.is-outlined.is-loading.is-hovered.docs-sourcelink::after,.button.is-primary.is-outlined.is-loading:focus::after,.docstring>section>a.button.is-outlined.is-loading.docs-sourcelink:focus::after,.button.is-primary.is-outlined.is-loading.is-focused::after,.docstring>section>a.button.is-outlined.is-loading.is-focused.docs-sourcelink::after{border-color:transparent transparent #fff #fff !important}.button.is-primary.is-outlined[disabled],.docstring>section>a.button.is-outlined.docs-sourcelink[disabled],fieldset[disabled] .button.is-primary.is-outlined,fieldset[disabled] .docstring>section>a.button.is-outlined.docs-sourcelink{background-color:transparent;border-color:#4eb5de;box-shadow:none;color:#4eb5de}.button.is-primary.is-inverted.is-outlined,.docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink{background-color:transparent;border-color:#fff;color:#fff}.button.is-primary.is-inverted.is-outlined:hover,.docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink:hover,.button.is-primary.is-inverted.is-outlined.is-hovered,.docstring>section>a.button.is-inverted.is-outlined.is-hovered.docs-sourcelink,.button.is-primary.is-inverted.is-outlined:focus,.docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink:focus,.button.is-primary.is-inverted.is-outlined.is-focused,.docstring>section>a.button.is-inverted.is-outlined.is-focused.docs-sourcelink{background-color:#fff;color:#4eb5de}.button.is-primary.is-inverted.is-outlined.is-loading:hover::after,.docstring>section>a.button.is-inverted.is-outlined.is-loading.docs-sourcelink:hover::after,.button.is-primary.is-inverted.is-outlined.is-loading.is-hovered::after,.docstring>section>a.button.is-inverted.is-outlined.is-loading.is-hovered.docs-sourcelink::after,.button.is-primary.is-inverted.is-outlined.is-loading:focus::after,.docstring>section>a.button.is-inverted.is-outlined.is-loading.docs-sourcelink:focus::after,.button.is-primary.is-inverted.is-outlined.is-loading.is-focused::after,.docstring>section>a.button.is-inverted.is-outlined.is-loading.is-focused.docs-sourcelink::after{border-color:transparent transparent #4eb5de #4eb5de !important}.button.is-primary.is-inverted.is-outlined[disabled],.docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink[disabled],fieldset[disabled] .button.is-primary.is-inverted.is-outlined,fieldset[disabled] .docstring>section>a.button.is-inverted.is-outlined.docs-sourcelink{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-primary.is-light,.docstring>section>a.button.is-light.docs-sourcelink{background-color:#eef8fc;color:#1a6d8e}.button.is-primary.is-light:hover,.docstring>section>a.button.is-light.docs-sourcelink:hover,.button.is-primary.is-light.is-hovered,.docstring>section>a.button.is-light.is-hovered.docs-sourcelink{background-color:#e3f3fa;border-color:transparent;color:#1a6d8e}.button.is-primary.is-light:active,.docstring>section>a.button.is-light.docs-sourcelink:active,.button.is-primary.is-light.is-active,.docstring>section>a.button.is-light.is-active.docs-sourcelink{background-color:#d8eff8;border-color:transparent;color:#1a6d8e}.button.is-link{background-color:#2e63b8;border-color:transparent;color:#fff}.button.is-link:hover,.button.is-link.is-hovered{background-color:#2b5eae;border-color:transparent;color:#fff}.button.is-link:focus,.button.is-link.is-focused{border-color:transparent;color:#fff}.button.is-link:focus:not(:active),.button.is-link.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(46,99,184,0.25)}.button.is-link:active,.button.is-link.is-active{background-color:#2958a4;border-color:transparent;color:#fff}.button.is-link[disabled],fieldset[disabled] .button.is-link{background-color:#2e63b8;border-color:#2e63b8;box-shadow:none}.button.is-link.is-inverted{background-color:#fff;color:#2e63b8}.button.is-link.is-inverted:hover,.button.is-link.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-link.is-inverted[disabled],fieldset[disabled] .button.is-link.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#2e63b8}.button.is-link.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-link.is-outlined{background-color:transparent;border-color:#2e63b8;color:#2e63b8}.button.is-link.is-outlined:hover,.button.is-link.is-outlined.is-hovered,.button.is-link.is-outlined:focus,.button.is-link.is-outlined.is-focused{background-color:#2e63b8;border-color:#2e63b8;color:#fff}.button.is-link.is-outlined.is-loading::after{border-color:transparent transparent #2e63b8 #2e63b8 !important}.button.is-link.is-outlined.is-loading:hover::after,.button.is-link.is-outlined.is-loading.is-hovered::after,.button.is-link.is-outlined.is-loading:focus::after,.button.is-link.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-link.is-outlined[disabled],fieldset[disabled] .button.is-link.is-outlined{background-color:transparent;border-color:#2e63b8;box-shadow:none;color:#2e63b8}.button.is-link.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-link.is-inverted.is-outlined:hover,.button.is-link.is-inverted.is-outlined.is-hovered,.button.is-link.is-inverted.is-outlined:focus,.button.is-link.is-inverted.is-outlined.is-focused{background-color:#fff;color:#2e63b8}.button.is-link.is-inverted.is-outlined.is-loading:hover::after,.button.is-link.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-link.is-inverted.is-outlined.is-loading:focus::after,.button.is-link.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #2e63b8 #2e63b8 !important}.button.is-link.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-link.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-link.is-light{background-color:#eff3fb;color:#3169c4}.button.is-link.is-light:hover,.button.is-link.is-light.is-hovered{background-color:#e4ecf8;border-color:transparent;color:#3169c4}.button.is-link.is-light:active,.button.is-link.is-light.is-active{background-color:#dae5f6;border-color:transparent;color:#3169c4}.button.is-info{background-color:#209cee;border-color:transparent;color:#fff}.button.is-info:hover,.button.is-info.is-hovered{background-color:#1497ed;border-color:transparent;color:#fff}.button.is-info:focus,.button.is-info.is-focused{border-color:transparent;color:#fff}.button.is-info:focus:not(:active),.button.is-info.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(32,156,238,0.25)}.button.is-info:active,.button.is-info.is-active{background-color:#1190e3;border-color:transparent;color:#fff}.button.is-info[disabled],fieldset[disabled] .button.is-info{background-color:#209cee;border-color:#209cee;box-shadow:none}.button.is-info.is-inverted{background-color:#fff;color:#209cee}.button.is-info.is-inverted:hover,.button.is-info.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-info.is-inverted[disabled],fieldset[disabled] .button.is-info.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#209cee}.button.is-info.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-info.is-outlined{background-color:transparent;border-color:#209cee;color:#209cee}.button.is-info.is-outlined:hover,.button.is-info.is-outlined.is-hovered,.button.is-info.is-outlined:focus,.button.is-info.is-outlined.is-focused{background-color:#209cee;border-color:#209cee;color:#fff}.button.is-info.is-outlined.is-loading::after{border-color:transparent transparent #209cee #209cee !important}.button.is-info.is-outlined.is-loading:hover::after,.button.is-info.is-outlined.is-loading.is-hovered::after,.button.is-info.is-outlined.is-loading:focus::after,.button.is-info.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-info.is-outlined[disabled],fieldset[disabled] .button.is-info.is-outlined{background-color:transparent;border-color:#209cee;box-shadow:none;color:#209cee}.button.is-info.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-info.is-inverted.is-outlined:hover,.button.is-info.is-inverted.is-outlined.is-hovered,.button.is-info.is-inverted.is-outlined:focus,.button.is-info.is-inverted.is-outlined.is-focused{background-color:#fff;color:#209cee}.button.is-info.is-inverted.is-outlined.is-loading:hover::after,.button.is-info.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-info.is-inverted.is-outlined.is-loading:focus::after,.button.is-info.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #209cee #209cee !important}.button.is-info.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-info.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-info.is-light{background-color:#ecf7fe;color:#0e72b4}.button.is-info.is-light:hover,.button.is-info.is-light.is-hovered{background-color:#e0f1fd;border-color:transparent;color:#0e72b4}.button.is-info.is-light:active,.button.is-info.is-light.is-active{background-color:#d4ecfc;border-color:transparent;color:#0e72b4}.button.is-success{background-color:#22c35b;border-color:transparent;color:#fff}.button.is-success:hover,.button.is-success.is-hovered{background-color:#20b856;border-color:transparent;color:#fff}.button.is-success:focus,.button.is-success.is-focused{border-color:transparent;color:#fff}.button.is-success:focus:not(:active),.button.is-success.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(34,195,91,0.25)}.button.is-success:active,.button.is-success.is-active{background-color:#1ead51;border-color:transparent;color:#fff}.button.is-success[disabled],fieldset[disabled] .button.is-success{background-color:#22c35b;border-color:#22c35b;box-shadow:none}.button.is-success.is-inverted{background-color:#fff;color:#22c35b}.button.is-success.is-inverted:hover,.button.is-success.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-success.is-inverted[disabled],fieldset[disabled] .button.is-success.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#22c35b}.button.is-success.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-success.is-outlined{background-color:transparent;border-color:#22c35b;color:#22c35b}.button.is-success.is-outlined:hover,.button.is-success.is-outlined.is-hovered,.button.is-success.is-outlined:focus,.button.is-success.is-outlined.is-focused{background-color:#22c35b;border-color:#22c35b;color:#fff}.button.is-success.is-outlined.is-loading::after{border-color:transparent transparent #22c35b #22c35b !important}.button.is-success.is-outlined.is-loading:hover::after,.button.is-success.is-outlined.is-loading.is-hovered::after,.button.is-success.is-outlined.is-loading:focus::after,.button.is-success.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-success.is-outlined[disabled],fieldset[disabled] .button.is-success.is-outlined{background-color:transparent;border-color:#22c35b;box-shadow:none;color:#22c35b}.button.is-success.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-success.is-inverted.is-outlined:hover,.button.is-success.is-inverted.is-outlined.is-hovered,.button.is-success.is-inverted.is-outlined:focus,.button.is-success.is-inverted.is-outlined.is-focused{background-color:#fff;color:#22c35b}.button.is-success.is-inverted.is-outlined.is-loading:hover::after,.button.is-success.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-success.is-inverted.is-outlined.is-loading:focus::after,.button.is-success.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #22c35b #22c35b !important}.button.is-success.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-success.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-success.is-light{background-color:#eefcf3;color:#198f43}.button.is-success.is-light:hover,.button.is-success.is-light.is-hovered{background-color:#e3faeb;border-color:transparent;color:#198f43}.button.is-success.is-light:active,.button.is-success.is-light.is-active{background-color:#d8f8e3;border-color:transparent;color:#198f43}.button.is-warning{background-color:#ffdd57;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-warning:hover,.button.is-warning.is-hovered{background-color:#ffda4a;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-warning:focus,.button.is-warning.is-focused{border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-warning:focus:not(:active),.button.is-warning.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(255,221,87,0.25)}.button.is-warning:active,.button.is-warning.is-active{background-color:#ffd83e;border-color:transparent;color:rgba(0,0,0,0.7)}.button.is-warning[disabled],fieldset[disabled] .button.is-warning{background-color:#ffdd57;border-color:#ffdd57;box-shadow:none}.button.is-warning.is-inverted{background-color:rgba(0,0,0,0.7);color:#ffdd57}.button.is-warning.is-inverted:hover,.button.is-warning.is-inverted.is-hovered{background-color:rgba(0,0,0,0.7)}.button.is-warning.is-inverted[disabled],fieldset[disabled] .button.is-warning.is-inverted{background-color:rgba(0,0,0,0.7);border-color:transparent;box-shadow:none;color:#ffdd57}.button.is-warning.is-loading::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}.button.is-warning.is-outlined{background-color:transparent;border-color:#ffdd57;color:#ffdd57}.button.is-warning.is-outlined:hover,.button.is-warning.is-outlined.is-hovered,.button.is-warning.is-outlined:focus,.button.is-warning.is-outlined.is-focused{background-color:#ffdd57;border-color:#ffdd57;color:rgba(0,0,0,0.7)}.button.is-warning.is-outlined.is-loading::after{border-color:transparent transparent #ffdd57 #ffdd57 !important}.button.is-warning.is-outlined.is-loading:hover::after,.button.is-warning.is-outlined.is-loading.is-hovered::after,.button.is-warning.is-outlined.is-loading:focus::after,.button.is-warning.is-outlined.is-loading.is-focused::after{border-color:transparent transparent rgba(0,0,0,0.7) rgba(0,0,0,0.7) !important}.button.is-warning.is-outlined[disabled],fieldset[disabled] .button.is-warning.is-outlined{background-color:transparent;border-color:#ffdd57;box-shadow:none;color:#ffdd57}.button.is-warning.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);color:rgba(0,0,0,0.7)}.button.is-warning.is-inverted.is-outlined:hover,.button.is-warning.is-inverted.is-outlined.is-hovered,.button.is-warning.is-inverted.is-outlined:focus,.button.is-warning.is-inverted.is-outlined.is-focused{background-color:rgba(0,0,0,0.7);color:#ffdd57}.button.is-warning.is-inverted.is-outlined.is-loading:hover::after,.button.is-warning.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-warning.is-inverted.is-outlined.is-loading:focus::after,.button.is-warning.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #ffdd57 #ffdd57 !important}.button.is-warning.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-warning.is-inverted.is-outlined{background-color:transparent;border-color:rgba(0,0,0,0.7);box-shadow:none;color:rgba(0,0,0,0.7)}.button.is-warning.is-light{background-color:#fffbeb;color:#947600}.button.is-warning.is-light:hover,.button.is-warning.is-light.is-hovered{background-color:#fff8de;border-color:transparent;color:#947600}.button.is-warning.is-light:active,.button.is-warning.is-light.is-active{background-color:#fff6d1;border-color:transparent;color:#947600}.button.is-danger{background-color:#da0b00;border-color:transparent;color:#fff}.button.is-danger:hover,.button.is-danger.is-hovered{background-color:#cd0a00;border-color:transparent;color:#fff}.button.is-danger:focus,.button.is-danger.is-focused{border-color:transparent;color:#fff}.button.is-danger:focus:not(:active),.button.is-danger.is-focused:not(:active){box-shadow:0 0 0 0.125em rgba(218,11,0,0.25)}.button.is-danger:active,.button.is-danger.is-active{background-color:#c10a00;border-color:transparent;color:#fff}.button.is-danger[disabled],fieldset[disabled] .button.is-danger{background-color:#da0b00;border-color:#da0b00;box-shadow:none}.button.is-danger.is-inverted{background-color:#fff;color:#da0b00}.button.is-danger.is-inverted:hover,.button.is-danger.is-inverted.is-hovered{background-color:#f2f2f2}.button.is-danger.is-inverted[disabled],fieldset[disabled] .button.is-danger.is-inverted{background-color:#fff;border-color:transparent;box-shadow:none;color:#da0b00}.button.is-danger.is-loading::after{border-color:transparent transparent #fff #fff !important}.button.is-danger.is-outlined{background-color:transparent;border-color:#da0b00;color:#da0b00}.button.is-danger.is-outlined:hover,.button.is-danger.is-outlined.is-hovered,.button.is-danger.is-outlined:focus,.button.is-danger.is-outlined.is-focused{background-color:#da0b00;border-color:#da0b00;color:#fff}.button.is-danger.is-outlined.is-loading::after{border-color:transparent transparent #da0b00 #da0b00 !important}.button.is-danger.is-outlined.is-loading:hover::after,.button.is-danger.is-outlined.is-loading.is-hovered::after,.button.is-danger.is-outlined.is-loading:focus::after,.button.is-danger.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #fff #fff !important}.button.is-danger.is-outlined[disabled],fieldset[disabled] .button.is-danger.is-outlined{background-color:transparent;border-color:#da0b00;box-shadow:none;color:#da0b00}.button.is-danger.is-inverted.is-outlined{background-color:transparent;border-color:#fff;color:#fff}.button.is-danger.is-inverted.is-outlined:hover,.button.is-danger.is-inverted.is-outlined.is-hovered,.button.is-danger.is-inverted.is-outlined:focus,.button.is-danger.is-inverted.is-outlined.is-focused{background-color:#fff;color:#da0b00}.button.is-danger.is-inverted.is-outlined.is-loading:hover::after,.button.is-danger.is-inverted.is-outlined.is-loading.is-hovered::after,.button.is-danger.is-inverted.is-outlined.is-loading:focus::after,.button.is-danger.is-inverted.is-outlined.is-loading.is-focused::after{border-color:transparent transparent #da0b00 #da0b00 !important}.button.is-danger.is-inverted.is-outlined[disabled],fieldset[disabled] .button.is-danger.is-inverted.is-outlined{background-color:transparent;border-color:#fff;box-shadow:none;color:#fff}.button.is-danger.is-light{background-color:#ffeceb;color:#f50c00}.button.is-danger.is-light:hover,.button.is-danger.is-light.is-hovered{background-color:#ffe0de;border-color:transparent;color:#f50c00}.button.is-danger.is-light:active,.button.is-danger.is-light.is-active{background-color:#ffd3d1;border-color:transparent;color:#f50c00}.button.is-small,#documenter .docs-sidebar form.docs-search>input.button{font-size:.75rem}.button.is-small:not(.is-rounded),#documenter .docs-sidebar form.docs-search>input.button:not(.is-rounded){border-radius:2px}.button.is-normal{font-size:1rem}.button.is-medium{font-size:1.25rem}.button.is-large{font-size:1.5rem}.button[disabled],fieldset[disabled] .button{background-color:#fff;border-color:#dbdbdb;box-shadow:none;opacity:.5}.button.is-fullwidth{display:flex;width:100%}.button.is-loading{color:transparent !important;pointer-events:none}.button.is-loading::after{position:absolute;left:calc(50% - (1em * 0.5));top:calc(50% - (1em * 0.5));position:absolute !important}.button.is-static{background-color:#f5f5f5;border-color:#dbdbdb;color:#6b6b6b;box-shadow:none;pointer-events:none}.button.is-rounded,#documenter .docs-sidebar form.docs-search>input.button{border-radius:9999px;padding-left:calc(1em + 0.25em);padding-right:calc(1em + 0.25em)}.buttons{align-items:center;display:flex;flex-wrap:wrap;justify-content:flex-start}.buttons .button{margin-bottom:0.5rem}.buttons .button:not(:last-child):not(.is-fullwidth){margin-right:.5rem}.buttons:last-child{margin-bottom:-0.5rem}.buttons:not(:last-child){margin-bottom:1rem}.buttons.are-small .button:not(.is-normal):not(.is-medium):not(.is-large){font-size:.75rem}.buttons.are-small .button:not(.is-normal):not(.is-medium):not(.is-large):not(.is-rounded){border-radius:2px}.buttons.are-medium .button:not(.is-small):not(.is-normal):not(.is-large){font-size:1.25rem}.buttons.are-large .button:not(.is-small):not(.is-normal):not(.is-medium){font-size:1.5rem}.buttons.has-addons .button:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.buttons.has-addons .button:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0;margin-right:-1px}.buttons.has-addons .button:last-child{margin-right:0}.buttons.has-addons .button:hover,.buttons.has-addons .button.is-hovered{z-index:2}.buttons.has-addons .button:focus,.buttons.has-addons .button.is-focused,.buttons.has-addons .button:active,.buttons.has-addons .button.is-active,.buttons.has-addons .button.is-selected{z-index:3}.buttons.has-addons .button:focus:hover,.buttons.has-addons .button.is-focused:hover,.buttons.has-addons .button:active:hover,.buttons.has-addons .button.is-active:hover,.buttons.has-addons .button.is-selected:hover{z-index:4}.buttons.has-addons .button.is-expanded{flex-grow:1;flex-shrink:1}.buttons.is-centered{justify-content:center}.buttons.is-centered:not(.has-addons) .button:not(.is-fullwidth){margin-left:0.25rem;margin-right:0.25rem}.buttons.is-right{justify-content:flex-end}.buttons.is-right:not(.has-addons) .button:not(.is-fullwidth){margin-left:0.25rem;margin-right:0.25rem}@media screen and (max-width: 768px){.button.is-responsive.is-small,#documenter .docs-sidebar form.docs-search>input.is-responsive{font-size:.5625rem}.button.is-responsive,.button.is-responsive.is-normal{font-size:.65625rem}.button.is-responsive.is-medium{font-size:.75rem}.button.is-responsive.is-large{font-size:1rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.button.is-responsive.is-small,#documenter .docs-sidebar form.docs-search>input.is-responsive{font-size:.65625rem}.button.is-responsive,.button.is-responsive.is-normal{font-size:.75rem}.button.is-responsive.is-medium{font-size:1rem}.button.is-responsive.is-large{font-size:1.25rem}}.container{flex-grow:1;margin:0 auto;position:relative;width:auto}.container.is-fluid{max-width:none !important;padding-left:32px;padding-right:32px;width:100%}@media screen and (min-width: 1056px){.container{max-width:992px}}@media screen and (max-width: 1215px){.container.is-widescreen:not(.is-max-desktop){max-width:1152px}}@media screen and (max-width: 1407px){.container.is-fullhd:not(.is-max-desktop):not(.is-max-widescreen){max-width:1344px}}@media screen and (min-width: 1216px){.container:not(.is-max-desktop){max-width:1152px}}@media screen and (min-width: 1408px){.container:not(.is-max-desktop):not(.is-max-widescreen){max-width:1344px}}.content li+li{margin-top:0.25em}.content p:not(:last-child),.content dl:not(:last-child),.content ol:not(:last-child),.content ul:not(:last-child),.content blockquote:not(:last-child),.content pre:not(:last-child),.content table:not(:last-child){margin-bottom:1em}.content h1,.content h2,.content h3,.content h4,.content h5,.content h6{color:#222;font-weight:600;line-height:1.125}.content h1{font-size:2em;margin-bottom:0.5em}.content h1:not(:first-child){margin-top:1em}.content h2{font-size:1.75em;margin-bottom:0.5714em}.content h2:not(:first-child){margin-top:1.1428em}.content h3{font-size:1.5em;margin-bottom:0.6666em}.content h3:not(:first-child){margin-top:1.3333em}.content h4{font-size:1.25em;margin-bottom:0.8em}.content h5{font-size:1.125em;margin-bottom:0.8888em}.content h6{font-size:1em;margin-bottom:1em}.content blockquote{background-color:#f5f5f5;border-left:5px solid #dbdbdb;padding:1.25em 1.5em}.content ol{list-style-position:outside;margin-left:2em;margin-top:1em}.content ol:not([type]){list-style-type:decimal}.content ol.is-lower-alpha:not([type]){list-style-type:lower-alpha}.content ol.is-lower-roman:not([type]){list-style-type:lower-roman}.content ol.is-upper-alpha:not([type]){list-style-type:upper-alpha}.content ol.is-upper-roman:not([type]){list-style-type:upper-roman}.content ul{list-style:disc outside;margin-left:2em;margin-top:1em}.content ul ul{list-style-type:circle;margin-top:0.5em}.content ul ul ul{list-style-type:square}.content dd{margin-left:2em}.content figure{margin-left:2em;margin-right:2em;text-align:center}.content figure:not(:first-child){margin-top:2em}.content figure:not(:last-child){margin-bottom:2em}.content figure img{display:inline-block}.content figure figcaption{font-style:italic}.content pre{-webkit-overflow-scrolling:touch;overflow-x:auto;padding:0;white-space:pre;word-wrap:normal}.content sup,.content sub{font-size:75%}.content table{width:100%}.content table td,.content table th{border:1px solid #dbdbdb;border-width:0 0 1px;padding:0.5em 0.75em;vertical-align:top}.content table th{color:#222}.content table th:not([align]){text-align:inherit}.content table thead td,.content table thead th{border-width:0 0 2px;color:#222}.content table tfoot td,.content table tfoot th{border-width:2px 0 0;color:#222}.content table tbody tr:last-child td,.content table tbody tr:last-child th{border-bottom-width:0}.content .tabs li+li{margin-top:0}.content.is-small,#documenter .docs-sidebar form.docs-search>input.content{font-size:.75rem}.content.is-normal{font-size:1rem}.content.is-medium{font-size:1.25rem}.content.is-large{font-size:1.5rem}.icon{align-items:center;display:inline-flex;justify-content:center;height:1.5rem;width:1.5rem}.icon.is-small,#documenter .docs-sidebar form.docs-search>input.icon{height:1rem;width:1rem}.icon.is-medium{height:2rem;width:2rem}.icon.is-large{height:3rem;width:3rem}.icon-text{align-items:flex-start;color:inherit;display:inline-flex;flex-wrap:wrap;line-height:1.5rem;vertical-align:top}.icon-text .icon{flex-grow:0;flex-shrink:0}.icon-text .icon:not(:last-child){margin-right:.25em}.icon-text .icon:not(:first-child){margin-left:.25em}div.icon-text{display:flex}.image,#documenter .docs-sidebar .docs-logo>img{display:block;position:relative}.image img,#documenter .docs-sidebar .docs-logo>img img{display:block;height:auto;width:100%}.image img.is-rounded,#documenter .docs-sidebar .docs-logo>img img.is-rounded{border-radius:9999px}.image.is-fullwidth,#documenter .docs-sidebar .docs-logo>img.is-fullwidth{width:100%}.image.is-square img,#documenter .docs-sidebar .docs-logo>img.is-square img,.image.is-square .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-square .has-ratio,.image.is-1by1 img,#documenter .docs-sidebar .docs-logo>img.is-1by1 img,.image.is-1by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by1 .has-ratio,.image.is-5by4 img,#documenter .docs-sidebar .docs-logo>img.is-5by4 img,.image.is-5by4 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-5by4 .has-ratio,.image.is-4by3 img,#documenter .docs-sidebar .docs-logo>img.is-4by3 img,.image.is-4by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-4by3 .has-ratio,.image.is-3by2 img,#documenter .docs-sidebar .docs-logo>img.is-3by2 img,.image.is-3by2 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by2 .has-ratio,.image.is-5by3 img,#documenter .docs-sidebar .docs-logo>img.is-5by3 img,.image.is-5by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-5by3 .has-ratio,.image.is-16by9 img,#documenter .docs-sidebar .docs-logo>img.is-16by9 img,.image.is-16by9 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-16by9 .has-ratio,.image.is-2by1 img,#documenter .docs-sidebar .docs-logo>img.is-2by1 img,.image.is-2by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-2by1 .has-ratio,.image.is-3by1 img,#documenter .docs-sidebar .docs-logo>img.is-3by1 img,.image.is-3by1 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by1 .has-ratio,.image.is-4by5 img,#documenter .docs-sidebar .docs-logo>img.is-4by5 img,.image.is-4by5 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-4by5 .has-ratio,.image.is-3by4 img,#documenter .docs-sidebar .docs-logo>img.is-3by4 img,.image.is-3by4 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by4 .has-ratio,.image.is-2by3 img,#documenter .docs-sidebar .docs-logo>img.is-2by3 img,.image.is-2by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-2by3 .has-ratio,.image.is-3by5 img,#documenter .docs-sidebar .docs-logo>img.is-3by5 img,.image.is-3by5 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-3by5 .has-ratio,.image.is-9by16 img,#documenter .docs-sidebar .docs-logo>img.is-9by16 img,.image.is-9by16 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-9by16 .has-ratio,.image.is-1by2 img,#documenter .docs-sidebar .docs-logo>img.is-1by2 img,.image.is-1by2 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by2 .has-ratio,.image.is-1by3 img,#documenter .docs-sidebar .docs-logo>img.is-1by3 img,.image.is-1by3 .has-ratio,#documenter .docs-sidebar .docs-logo>img.is-1by3 .has-ratio{height:100%;width:100%}.image.is-square,#documenter .docs-sidebar .docs-logo>img.is-square,.image.is-1by1,#documenter .docs-sidebar .docs-logo>img.is-1by1{padding-top:100%}.image.is-5by4,#documenter .docs-sidebar .docs-logo>img.is-5by4{padding-top:80%}.image.is-4by3,#documenter .docs-sidebar .docs-logo>img.is-4by3{padding-top:75%}.image.is-3by2,#documenter .docs-sidebar .docs-logo>img.is-3by2{padding-top:66.6666%}.image.is-5by3,#documenter .docs-sidebar .docs-logo>img.is-5by3{padding-top:60%}.image.is-16by9,#documenter .docs-sidebar .docs-logo>img.is-16by9{padding-top:56.25%}.image.is-2by1,#documenter .docs-sidebar .docs-logo>img.is-2by1{padding-top:50%}.image.is-3by1,#documenter .docs-sidebar .docs-logo>img.is-3by1{padding-top:33.3333%}.image.is-4by5,#documenter .docs-sidebar .docs-logo>img.is-4by5{padding-top:125%}.image.is-3by4,#documenter .docs-sidebar .docs-logo>img.is-3by4{padding-top:133.3333%}.image.is-2by3,#documenter .docs-sidebar .docs-logo>img.is-2by3{padding-top:150%}.image.is-3by5,#documenter .docs-sidebar .docs-logo>img.is-3by5{padding-top:166.6666%}.image.is-9by16,#documenter .docs-sidebar .docs-logo>img.is-9by16{padding-top:177.7777%}.image.is-1by2,#documenter .docs-sidebar .docs-logo>img.is-1by2{padding-top:200%}.image.is-1by3,#documenter .docs-sidebar .docs-logo>img.is-1by3{padding-top:300%}.image.is-16x16,#documenter .docs-sidebar .docs-logo>img.is-16x16{height:16px;width:16px}.image.is-24x24,#documenter .docs-sidebar .docs-logo>img.is-24x24{height:24px;width:24px}.image.is-32x32,#documenter .docs-sidebar .docs-logo>img.is-32x32{height:32px;width:32px}.image.is-48x48,#documenter .docs-sidebar .docs-logo>img.is-48x48{height:48px;width:48px}.image.is-64x64,#documenter .docs-sidebar .docs-logo>img.is-64x64{height:64px;width:64px}.image.is-96x96,#documenter .docs-sidebar .docs-logo>img.is-96x96{height:96px;width:96px}.image.is-128x128,#documenter .docs-sidebar .docs-logo>img.is-128x128{height:128px;width:128px}.notification{background-color:#f5f5f5;border-radius:4px;position:relative;padding:1.25rem 2.5rem 1.25rem 1.5rem}.notification a:not(.button):not(.dropdown-item){color:currentColor;text-decoration:underline}.notification strong{color:currentColor}.notification code,.notification pre{background:#fff}.notification pre code{background:transparent}.notification>.delete{right:.5rem;position:absolute;top:0.5rem}.notification .title,.notification .subtitle,.notification .content{color:currentColor}.notification.is-white{background-color:#fff;color:#0a0a0a}.notification.is-black{background-color:#0a0a0a;color:#fff}.notification.is-light{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.notification.is-dark,.content kbd.notification{background-color:#363636;color:#fff}.notification.is-primary,.docstring>section>a.notification.docs-sourcelink{background-color:#4eb5de;color:#fff}.notification.is-primary.is-light,.docstring>section>a.notification.is-light.docs-sourcelink{background-color:#eef8fc;color:#1a6d8e}.notification.is-link{background-color:#2e63b8;color:#fff}.notification.is-link.is-light{background-color:#eff3fb;color:#3169c4}.notification.is-info{background-color:#209cee;color:#fff}.notification.is-info.is-light{background-color:#ecf7fe;color:#0e72b4}.notification.is-success{background-color:#22c35b;color:#fff}.notification.is-success.is-light{background-color:#eefcf3;color:#198f43}.notification.is-warning{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.notification.is-warning.is-light{background-color:#fffbeb;color:#947600}.notification.is-danger{background-color:#da0b00;color:#fff}.notification.is-danger.is-light{background-color:#ffeceb;color:#f50c00}.progress{-moz-appearance:none;-webkit-appearance:none;border:none;border-radius:9999px;display:block;height:1rem;overflow:hidden;padding:0;width:100%}.progress::-webkit-progress-bar{background-color:#ededed}.progress::-webkit-progress-value{background-color:#222}.progress::-moz-progress-bar{background-color:#222}.progress::-ms-fill{background-color:#222;border:none}.progress.is-white::-webkit-progress-value{background-color:#fff}.progress.is-white::-moz-progress-bar{background-color:#fff}.progress.is-white::-ms-fill{background-color:#fff}.progress.is-white:indeterminate{background-image:linear-gradient(to right, #fff 30%, #ededed 30%)}.progress.is-black::-webkit-progress-value{background-color:#0a0a0a}.progress.is-black::-moz-progress-bar{background-color:#0a0a0a}.progress.is-black::-ms-fill{background-color:#0a0a0a}.progress.is-black:indeterminate{background-image:linear-gradient(to right, #0a0a0a 30%, #ededed 30%)}.progress.is-light::-webkit-progress-value{background-color:#f5f5f5}.progress.is-light::-moz-progress-bar{background-color:#f5f5f5}.progress.is-light::-ms-fill{background-color:#f5f5f5}.progress.is-light:indeterminate{background-image:linear-gradient(to right, #f5f5f5 30%, #ededed 30%)}.progress.is-dark::-webkit-progress-value,.content kbd.progress::-webkit-progress-value{background-color:#363636}.progress.is-dark::-moz-progress-bar,.content kbd.progress::-moz-progress-bar{background-color:#363636}.progress.is-dark::-ms-fill,.content kbd.progress::-ms-fill{background-color:#363636}.progress.is-dark:indeterminate,.content kbd.progress:indeterminate{background-image:linear-gradient(to right, #363636 30%, #ededed 30%)}.progress.is-primary::-webkit-progress-value,.docstring>section>a.progress.docs-sourcelink::-webkit-progress-value{background-color:#4eb5de}.progress.is-primary::-moz-progress-bar,.docstring>section>a.progress.docs-sourcelink::-moz-progress-bar{background-color:#4eb5de}.progress.is-primary::-ms-fill,.docstring>section>a.progress.docs-sourcelink::-ms-fill{background-color:#4eb5de}.progress.is-primary:indeterminate,.docstring>section>a.progress.docs-sourcelink:indeterminate{background-image:linear-gradient(to right, #4eb5de 30%, #ededed 30%)}.progress.is-link::-webkit-progress-value{background-color:#2e63b8}.progress.is-link::-moz-progress-bar{background-color:#2e63b8}.progress.is-link::-ms-fill{background-color:#2e63b8}.progress.is-link:indeterminate{background-image:linear-gradient(to right, #2e63b8 30%, #ededed 30%)}.progress.is-info::-webkit-progress-value{background-color:#209cee}.progress.is-info::-moz-progress-bar{background-color:#209cee}.progress.is-info::-ms-fill{background-color:#209cee}.progress.is-info:indeterminate{background-image:linear-gradient(to right, #209cee 30%, #ededed 30%)}.progress.is-success::-webkit-progress-value{background-color:#22c35b}.progress.is-success::-moz-progress-bar{background-color:#22c35b}.progress.is-success::-ms-fill{background-color:#22c35b}.progress.is-success:indeterminate{background-image:linear-gradient(to right, #22c35b 30%, #ededed 30%)}.progress.is-warning::-webkit-progress-value{background-color:#ffdd57}.progress.is-warning::-moz-progress-bar{background-color:#ffdd57}.progress.is-warning::-ms-fill{background-color:#ffdd57}.progress.is-warning:indeterminate{background-image:linear-gradient(to right, #ffdd57 30%, #ededed 30%)}.progress.is-danger::-webkit-progress-value{background-color:#da0b00}.progress.is-danger::-moz-progress-bar{background-color:#da0b00}.progress.is-danger::-ms-fill{background-color:#da0b00}.progress.is-danger:indeterminate{background-image:linear-gradient(to right, #da0b00 30%, #ededed 30%)}.progress:indeterminate{animation-duration:1.5s;animation-iteration-count:infinite;animation-name:moveIndeterminate;animation-timing-function:linear;background-color:#ededed;background-image:linear-gradient(to right, #222 30%, #ededed 30%);background-position:top left;background-repeat:no-repeat;background-size:150% 150%}.progress:indeterminate::-webkit-progress-bar{background-color:transparent}.progress:indeterminate::-moz-progress-bar{background-color:transparent}.progress:indeterminate::-ms-fill{animation-name:none}.progress.is-small,#documenter .docs-sidebar form.docs-search>input.progress{height:.75rem}.progress.is-medium{height:1.25rem}.progress.is-large{height:1.5rem}@keyframes moveIndeterminate{from{background-position:200% 0}to{background-position:-200% 0}}.table{background-color:#fff;color:#222}.table td,.table th{border:1px solid #dbdbdb;border-width:0 0 1px;padding:0.5em 0.75em;vertical-align:top}.table td.is-white,.table th.is-white{background-color:#fff;border-color:#fff;color:#0a0a0a}.table td.is-black,.table th.is-black{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}.table td.is-light,.table th.is-light{background-color:#f5f5f5;border-color:#f5f5f5;color:rgba(0,0,0,0.7)}.table td.is-dark,.table th.is-dark{background-color:#363636;border-color:#363636;color:#fff}.table td.is-primary,.table th.is-primary{background-color:#4eb5de;border-color:#4eb5de;color:#fff}.table td.is-link,.table th.is-link{background-color:#2e63b8;border-color:#2e63b8;color:#fff}.table td.is-info,.table th.is-info{background-color:#209cee;border-color:#209cee;color:#fff}.table td.is-success,.table th.is-success{background-color:#22c35b;border-color:#22c35b;color:#fff}.table td.is-warning,.table th.is-warning{background-color:#ffdd57;border-color:#ffdd57;color:rgba(0,0,0,0.7)}.table td.is-danger,.table th.is-danger{background-color:#da0b00;border-color:#da0b00;color:#fff}.table td.is-narrow,.table th.is-narrow{white-space:nowrap;width:1%}.table td.is-selected,.table th.is-selected{background-color:#4eb5de;color:#fff}.table td.is-selected a,.table td.is-selected strong,.table th.is-selected a,.table th.is-selected strong{color:currentColor}.table td.is-vcentered,.table th.is-vcentered{vertical-align:middle}.table th{color:#222}.table th:not([align]){text-align:left}.table tr.is-selected{background-color:#4eb5de;color:#fff}.table tr.is-selected a,.table tr.is-selected strong{color:currentColor}.table tr.is-selected td,.table tr.is-selected th{border-color:#fff;color:currentColor}.table thead{background-color:rgba(0,0,0,0)}.table thead td,.table thead th{border-width:0 0 2px;color:#222}.table tfoot{background-color:rgba(0,0,0,0)}.table tfoot td,.table tfoot th{border-width:2px 0 0;color:#222}.table tbody{background-color:rgba(0,0,0,0)}.table tbody tr:last-child td,.table tbody tr:last-child th{border-bottom-width:0}.table.is-bordered td,.table.is-bordered th{border-width:1px}.table.is-bordered tr:last-child td,.table.is-bordered tr:last-child th{border-bottom-width:1px}.table.is-fullwidth{width:100%}.table.is-hoverable tbody tr:not(.is-selected):hover{background-color:#fafafa}.table.is-hoverable.is-striped tbody tr:not(.is-selected):hover{background-color:#fafafa}.table.is-hoverable.is-striped tbody tr:not(.is-selected):hover:nth-child(even){background-color:#f5f5f5}.table.is-narrow td,.table.is-narrow th{padding:0.25em 0.5em}.table.is-striped tbody tr:not(.is-selected):nth-child(even){background-color:#fafafa}.table-container{-webkit-overflow-scrolling:touch;overflow:auto;overflow-y:hidden;max-width:100%}.tags{align-items:center;display:flex;flex-wrap:wrap;justify-content:flex-start}.tags .tag,.tags .content kbd,.content .tags kbd,.tags .docstring>section>a.docs-sourcelink{margin-bottom:0.5rem}.tags .tag:not(:last-child),.tags .content kbd:not(:last-child),.content .tags kbd:not(:last-child),.tags .docstring>section>a.docs-sourcelink:not(:last-child){margin-right:.5rem}.tags:last-child{margin-bottom:-0.5rem}.tags:not(:last-child){margin-bottom:1rem}.tags.are-medium .tag:not(.is-normal):not(.is-large),.tags.are-medium .content kbd:not(.is-normal):not(.is-large),.content .tags.are-medium kbd:not(.is-normal):not(.is-large),.tags.are-medium .docstring>section>a.docs-sourcelink:not(.is-normal):not(.is-large){font-size:1rem}.tags.are-large .tag:not(.is-normal):not(.is-medium),.tags.are-large .content kbd:not(.is-normal):not(.is-medium),.content .tags.are-large kbd:not(.is-normal):not(.is-medium),.tags.are-large .docstring>section>a.docs-sourcelink:not(.is-normal):not(.is-medium){font-size:1.25rem}.tags.is-centered{justify-content:center}.tags.is-centered .tag,.tags.is-centered .content kbd,.content .tags.is-centered kbd,.tags.is-centered .docstring>section>a.docs-sourcelink{margin-right:0.25rem;margin-left:0.25rem}.tags.is-right{justify-content:flex-end}.tags.is-right .tag:not(:first-child),.tags.is-right .content kbd:not(:first-child),.content .tags.is-right kbd:not(:first-child),.tags.is-right .docstring>section>a.docs-sourcelink:not(:first-child){margin-left:0.5rem}.tags.is-right .tag:not(:last-child),.tags.is-right .content kbd:not(:last-child),.content .tags.is-right kbd:not(:last-child),.tags.is-right .docstring>section>a.docs-sourcelink:not(:last-child){margin-right:0}.tags.has-addons .tag,.tags.has-addons .content kbd,.content .tags.has-addons kbd,.tags.has-addons .docstring>section>a.docs-sourcelink{margin-right:0}.tags.has-addons .tag:not(:first-child),.tags.has-addons .content kbd:not(:first-child),.content .tags.has-addons kbd:not(:first-child),.tags.has-addons .docstring>section>a.docs-sourcelink:not(:first-child){margin-left:0;border-top-left-radius:0;border-bottom-left-radius:0}.tags.has-addons .tag:not(:last-child),.tags.has-addons .content kbd:not(:last-child),.content .tags.has-addons kbd:not(:last-child),.tags.has-addons .docstring>section>a.docs-sourcelink:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.tag:not(body),.content kbd:not(body),.docstring>section>a.docs-sourcelink:not(body){align-items:center;background-color:#f5f5f5;border-radius:4px;color:#222;display:inline-flex;font-size:.75rem;height:2em;justify-content:center;line-height:1.5;padding-left:0.75em;padding-right:0.75em;white-space:nowrap}.tag:not(body) .delete,.content kbd:not(body) .delete,.docstring>section>a.docs-sourcelink:not(body) .delete{margin-left:.25rem;margin-right:-.375rem}.tag.is-white:not(body),.content kbd.is-white:not(body),.docstring>section>a.docs-sourcelink.is-white:not(body){background-color:#fff;color:#0a0a0a}.tag.is-black:not(body),.content kbd.is-black:not(body),.docstring>section>a.docs-sourcelink.is-black:not(body){background-color:#0a0a0a;color:#fff}.tag.is-light:not(body),.content kbd.is-light:not(body),.docstring>section>a.docs-sourcelink.is-light:not(body){background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.tag.is-dark:not(body),.content kbd:not(body),.docstring>section>a.docs-sourcelink.is-dark:not(body),.content .docstring>section>kbd:not(body){background-color:#363636;color:#fff}.tag.is-primary:not(body),.content kbd.is-primary:not(body),.docstring>section>a.docs-sourcelink:not(body){background-color:#4eb5de;color:#fff}.tag.is-primary.is-light:not(body),.content kbd.is-primary.is-light:not(body),.docstring>section>a.docs-sourcelink.is-light:not(body){background-color:#eef8fc;color:#1a6d8e}.tag.is-link:not(body),.content kbd.is-link:not(body),.docstring>section>a.docs-sourcelink.is-link:not(body){background-color:#2e63b8;color:#fff}.tag.is-link.is-light:not(body),.content kbd.is-link.is-light:not(body),.docstring>section>a.docs-sourcelink.is-link.is-light:not(body){background-color:#eff3fb;color:#3169c4}.tag.is-info:not(body),.content kbd.is-info:not(body),.docstring>section>a.docs-sourcelink.is-info:not(body){background-color:#209cee;color:#fff}.tag.is-info.is-light:not(body),.content kbd.is-info.is-light:not(body),.docstring>section>a.docs-sourcelink.is-info.is-light:not(body){background-color:#ecf7fe;color:#0e72b4}.tag.is-success:not(body),.content kbd.is-success:not(body),.docstring>section>a.docs-sourcelink.is-success:not(body){background-color:#22c35b;color:#fff}.tag.is-success.is-light:not(body),.content kbd.is-success.is-light:not(body),.docstring>section>a.docs-sourcelink.is-success.is-light:not(body){background-color:#eefcf3;color:#198f43}.tag.is-warning:not(body),.content kbd.is-warning:not(body),.docstring>section>a.docs-sourcelink.is-warning:not(body){background-color:#ffdd57;color:rgba(0,0,0,0.7)}.tag.is-warning.is-light:not(body),.content kbd.is-warning.is-light:not(body),.docstring>section>a.docs-sourcelink.is-warning.is-light:not(body){background-color:#fffbeb;color:#947600}.tag.is-danger:not(body),.content kbd.is-danger:not(body),.docstring>section>a.docs-sourcelink.is-danger:not(body){background-color:#da0b00;color:#fff}.tag.is-danger.is-light:not(body),.content kbd.is-danger.is-light:not(body),.docstring>section>a.docs-sourcelink.is-danger.is-light:not(body){background-color:#ffeceb;color:#f50c00}.tag.is-normal:not(body),.content kbd.is-normal:not(body),.docstring>section>a.docs-sourcelink.is-normal:not(body){font-size:.75rem}.tag.is-medium:not(body),.content kbd.is-medium:not(body),.docstring>section>a.docs-sourcelink.is-medium:not(body){font-size:1rem}.tag.is-large:not(body),.content kbd.is-large:not(body),.docstring>section>a.docs-sourcelink.is-large:not(body){font-size:1.25rem}.tag:not(body) .icon:first-child:not(:last-child),.content kbd:not(body) .icon:first-child:not(:last-child),.docstring>section>a.docs-sourcelink:not(body) .icon:first-child:not(:last-child){margin-left:-.375em;margin-right:.1875em}.tag:not(body) .icon:last-child:not(:first-child),.content kbd:not(body) .icon:last-child:not(:first-child),.docstring>section>a.docs-sourcelink:not(body) .icon:last-child:not(:first-child){margin-left:.1875em;margin-right:-.375em}.tag:not(body) .icon:first-child:last-child,.content kbd:not(body) .icon:first-child:last-child,.docstring>section>a.docs-sourcelink:not(body) .icon:first-child:last-child{margin-left:-.375em;margin-right:-.375em}.tag.is-delete:not(body),.content kbd.is-delete:not(body),.docstring>section>a.docs-sourcelink.is-delete:not(body){margin-left:1px;padding:0;position:relative;width:2em}.tag.is-delete:not(body)::before,.content kbd.is-delete:not(body)::before,.docstring>section>a.docs-sourcelink.is-delete:not(body)::before,.tag.is-delete:not(body)::after,.content kbd.is-delete:not(body)::after,.docstring>section>a.docs-sourcelink.is-delete:not(body)::after{background-color:currentColor;content:"";display:block;left:50%;position:absolute;top:50%;transform:translateX(-50%) translateY(-50%) rotate(45deg);transform-origin:center center}.tag.is-delete:not(body)::before,.content kbd.is-delete:not(body)::before,.docstring>section>a.docs-sourcelink.is-delete:not(body)::before{height:1px;width:50%}.tag.is-delete:not(body)::after,.content kbd.is-delete:not(body)::after,.docstring>section>a.docs-sourcelink.is-delete:not(body)::after{height:50%;width:1px}.tag.is-delete:not(body):hover,.content kbd.is-delete:not(body):hover,.docstring>section>a.docs-sourcelink.is-delete:not(body):hover,.tag.is-delete:not(body):focus,.content kbd.is-delete:not(body):focus,.docstring>section>a.docs-sourcelink.is-delete:not(body):focus{background-color:#e8e8e8}.tag.is-delete:not(body):active,.content kbd.is-delete:not(body):active,.docstring>section>a.docs-sourcelink.is-delete:not(body):active{background-color:#dbdbdb}.tag.is-rounded:not(body),#documenter .docs-sidebar form.docs-search>input:not(body),.content kbd.is-rounded:not(body),#documenter .docs-sidebar .content form.docs-search>input:not(body),.docstring>section>a.docs-sourcelink.is-rounded:not(body){border-radius:9999px}a.tag:hover,.docstring>section>a.docs-sourcelink:hover{text-decoration:underline}.title,.subtitle{word-break:break-word}.title em,.title span,.subtitle em,.subtitle span{font-weight:inherit}.title sub,.subtitle sub{font-size:.75em}.title sup,.subtitle sup{font-size:.75em}.title .tag,.title .content kbd,.content .title kbd,.title .docstring>section>a.docs-sourcelink,.subtitle .tag,.subtitle .content kbd,.content .subtitle kbd,.subtitle .docstring>section>a.docs-sourcelink{vertical-align:middle}.title{color:#222;font-size:2rem;font-weight:600;line-height:1.125}.title strong{color:inherit;font-weight:inherit}.title:not(.is-spaced)+.subtitle{margin-top:-1.25rem}.title.is-1{font-size:3rem}.title.is-2{font-size:2.5rem}.title.is-3{font-size:2rem}.title.is-4{font-size:1.5rem}.title.is-5{font-size:1.25rem}.title.is-6{font-size:1rem}.title.is-7{font-size:.75rem}.subtitle{color:#222;font-size:1.25rem;font-weight:400;line-height:1.25}.subtitle strong{color:#222;font-weight:600}.subtitle:not(.is-spaced)+.title{margin-top:-1.25rem}.subtitle.is-1{font-size:3rem}.subtitle.is-2{font-size:2.5rem}.subtitle.is-3{font-size:2rem}.subtitle.is-4{font-size:1.5rem}.subtitle.is-5{font-size:1.25rem}.subtitle.is-6{font-size:1rem}.subtitle.is-7{font-size:.75rem}.heading{display:block;font-size:11px;letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}.number{align-items:center;background-color:#f5f5f5;border-radius:9999px;display:inline-flex;font-size:1.25rem;height:2em;justify-content:center;margin-right:1.5rem;min-width:2.5em;padding:0.25rem 0.5rem;text-align:center;vertical-align:top}.select select,.textarea,.input,#documenter .docs-sidebar form.docs-search>input{background-color:#fff;border-color:#dbdbdb;border-radius:4px;color:#222}.select select::-moz-placeholder,.textarea::-moz-placeholder,.input::-moz-placeholder,#documenter .docs-sidebar form.docs-search>input::-moz-placeholder{color:#707070}.select select::-webkit-input-placeholder,.textarea::-webkit-input-placeholder,.input::-webkit-input-placeholder,#documenter .docs-sidebar form.docs-search>input::-webkit-input-placeholder{color:#707070}.select select:-moz-placeholder,.textarea:-moz-placeholder,.input:-moz-placeholder,#documenter .docs-sidebar form.docs-search>input:-moz-placeholder{color:#707070}.select select:-ms-input-placeholder,.textarea:-ms-input-placeholder,.input:-ms-input-placeholder,#documenter .docs-sidebar form.docs-search>input:-ms-input-placeholder{color:#707070}.select select:hover,.textarea:hover,.input:hover,#documenter .docs-sidebar form.docs-search>input:hover,.select select.is-hovered,.is-hovered.textarea,.is-hovered.input,#documenter .docs-sidebar form.docs-search>input.is-hovered{border-color:#b5b5b5}.select select:focus,.textarea:focus,.input:focus,#documenter .docs-sidebar form.docs-search>input:focus,.select select.is-focused,.is-focused.textarea,.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.select select:active,.textarea:active,.input:active,#documenter .docs-sidebar form.docs-search>input:active,.select select.is-active,.is-active.textarea,.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{border-color:#2e63b8;box-shadow:0 0 0 0.125em rgba(46,99,184,0.25)}.select select[disabled],.textarea[disabled],.input[disabled],#documenter .docs-sidebar form.docs-search>input[disabled],fieldset[disabled] .select select,.select fieldset[disabled] select,fieldset[disabled] .textarea,fieldset[disabled] .input,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input{background-color:#f5f5f5;border-color:#f5f5f5;box-shadow:none;color:#6b6b6b}.select select[disabled]::-moz-placeholder,.textarea[disabled]::-moz-placeholder,.input[disabled]::-moz-placeholder,#documenter .docs-sidebar form.docs-search>input[disabled]::-moz-placeholder,fieldset[disabled] .select select::-moz-placeholder,.select fieldset[disabled] select::-moz-placeholder,fieldset[disabled] .textarea::-moz-placeholder,fieldset[disabled] .input::-moz-placeholder,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input::-moz-placeholder,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input::-moz-placeholder{color:rgba(107,107,107,0.3)}.select select[disabled]::-webkit-input-placeholder,.textarea[disabled]::-webkit-input-placeholder,.input[disabled]::-webkit-input-placeholder,#documenter .docs-sidebar form.docs-search>input[disabled]::-webkit-input-placeholder,fieldset[disabled] .select select::-webkit-input-placeholder,.select fieldset[disabled] select::-webkit-input-placeholder,fieldset[disabled] .textarea::-webkit-input-placeholder,fieldset[disabled] .input::-webkit-input-placeholder,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input::-webkit-input-placeholder,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input::-webkit-input-placeholder{color:rgba(107,107,107,0.3)}.select select[disabled]:-moz-placeholder,.textarea[disabled]:-moz-placeholder,.input[disabled]:-moz-placeholder,#documenter .docs-sidebar form.docs-search>input[disabled]:-moz-placeholder,fieldset[disabled] .select select:-moz-placeholder,.select fieldset[disabled] select:-moz-placeholder,fieldset[disabled] .textarea:-moz-placeholder,fieldset[disabled] .input:-moz-placeholder,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input:-moz-placeholder,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input:-moz-placeholder{color:rgba(107,107,107,0.3)}.select select[disabled]:-ms-input-placeholder,.textarea[disabled]:-ms-input-placeholder,.input[disabled]:-ms-input-placeholder,#documenter .docs-sidebar form.docs-search>input[disabled]:-ms-input-placeholder,fieldset[disabled] .select select:-ms-input-placeholder,.select fieldset[disabled] select:-ms-input-placeholder,fieldset[disabled] .textarea:-ms-input-placeholder,fieldset[disabled] .input:-ms-input-placeholder,fieldset[disabled] #documenter .docs-sidebar form.docs-search>input:-ms-input-placeholder,#documenter .docs-sidebar fieldset[disabled] form.docs-search>input:-ms-input-placeholder{color:rgba(107,107,107,0.3)}.textarea,.input,#documenter .docs-sidebar form.docs-search>input{box-shadow:inset 0 0.0625em 0.125em rgba(10,10,10,0.05);max-width:100%;width:100%}.textarea[readonly],.input[readonly],#documenter .docs-sidebar form.docs-search>input[readonly]{box-shadow:none}.is-white.textarea,.is-white.input,#documenter .docs-sidebar form.docs-search>input.is-white{border-color:#fff}.is-white.textarea:focus,.is-white.input:focus,#documenter .docs-sidebar form.docs-search>input.is-white:focus,.is-white.is-focused.textarea,.is-white.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-white.textarea:active,.is-white.input:active,#documenter .docs-sidebar form.docs-search>input.is-white:active,.is-white.is-active.textarea,.is-white.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}.is-black.textarea,.is-black.input,#documenter .docs-sidebar form.docs-search>input.is-black{border-color:#0a0a0a}.is-black.textarea:focus,.is-black.input:focus,#documenter .docs-sidebar form.docs-search>input.is-black:focus,.is-black.is-focused.textarea,.is-black.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-black.textarea:active,.is-black.input:active,#documenter .docs-sidebar form.docs-search>input.is-black:active,.is-black.is-active.textarea,.is-black.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}.is-light.textarea,.is-light.input,#documenter .docs-sidebar form.docs-search>input.is-light{border-color:#f5f5f5}.is-light.textarea:focus,.is-light.input:focus,#documenter .docs-sidebar form.docs-search>input.is-light:focus,.is-light.is-focused.textarea,.is-light.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-light.textarea:active,.is-light.input:active,#documenter .docs-sidebar form.docs-search>input.is-light:active,.is-light.is-active.textarea,.is-light.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(245,245,245,0.25)}.is-dark.textarea,.content kbd.textarea,.is-dark.input,#documenter .docs-sidebar form.docs-search>input.is-dark,.content kbd.input{border-color:#363636}.is-dark.textarea:focus,.content kbd.textarea:focus,.is-dark.input:focus,#documenter .docs-sidebar form.docs-search>input.is-dark:focus,.content kbd.input:focus,.is-dark.is-focused.textarea,.content kbd.is-focused.textarea,.is-dark.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.content kbd.is-focused.input,#documenter .docs-sidebar .content form.docs-search>input.is-focused,.is-dark.textarea:active,.content kbd.textarea:active,.is-dark.input:active,#documenter .docs-sidebar form.docs-search>input.is-dark:active,.content kbd.input:active,.is-dark.is-active.textarea,.content kbd.is-active.textarea,.is-dark.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active,.content kbd.is-active.input,#documenter .docs-sidebar .content form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(54,54,54,0.25)}.is-primary.textarea,.docstring>section>a.textarea.docs-sourcelink,.is-primary.input,#documenter .docs-sidebar form.docs-search>input.is-primary,.docstring>section>a.input.docs-sourcelink{border-color:#4eb5de}.is-primary.textarea:focus,.docstring>section>a.textarea.docs-sourcelink:focus,.is-primary.input:focus,#documenter .docs-sidebar form.docs-search>input.is-primary:focus,.docstring>section>a.input.docs-sourcelink:focus,.is-primary.is-focused.textarea,.docstring>section>a.is-focused.textarea.docs-sourcelink,.is-primary.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.docstring>section>a.is-focused.input.docs-sourcelink,.is-primary.textarea:active,.docstring>section>a.textarea.docs-sourcelink:active,.is-primary.input:active,#documenter .docs-sidebar form.docs-search>input.is-primary:active,.docstring>section>a.input.docs-sourcelink:active,.is-primary.is-active.textarea,.docstring>section>a.is-active.textarea.docs-sourcelink,.is-primary.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active,.docstring>section>a.is-active.input.docs-sourcelink{box-shadow:0 0 0 0.125em rgba(78,181,222,0.25)}.is-link.textarea,.is-link.input,#documenter .docs-sidebar form.docs-search>input.is-link{border-color:#2e63b8}.is-link.textarea:focus,.is-link.input:focus,#documenter .docs-sidebar form.docs-search>input.is-link:focus,.is-link.is-focused.textarea,.is-link.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-link.textarea:active,.is-link.input:active,#documenter .docs-sidebar form.docs-search>input.is-link:active,.is-link.is-active.textarea,.is-link.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(46,99,184,0.25)}.is-info.textarea,.is-info.input,#documenter .docs-sidebar form.docs-search>input.is-info{border-color:#209cee}.is-info.textarea:focus,.is-info.input:focus,#documenter .docs-sidebar form.docs-search>input.is-info:focus,.is-info.is-focused.textarea,.is-info.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-info.textarea:active,.is-info.input:active,#documenter .docs-sidebar form.docs-search>input.is-info:active,.is-info.is-active.textarea,.is-info.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(32,156,238,0.25)}.is-success.textarea,.is-success.input,#documenter .docs-sidebar form.docs-search>input.is-success{border-color:#22c35b}.is-success.textarea:focus,.is-success.input:focus,#documenter .docs-sidebar form.docs-search>input.is-success:focus,.is-success.is-focused.textarea,.is-success.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-success.textarea:active,.is-success.input:active,#documenter .docs-sidebar form.docs-search>input.is-success:active,.is-success.is-active.textarea,.is-success.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(34,195,91,0.25)}.is-warning.textarea,.is-warning.input,#documenter .docs-sidebar form.docs-search>input.is-warning{border-color:#ffdd57}.is-warning.textarea:focus,.is-warning.input:focus,#documenter .docs-sidebar form.docs-search>input.is-warning:focus,.is-warning.is-focused.textarea,.is-warning.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-warning.textarea:active,.is-warning.input:active,#documenter .docs-sidebar form.docs-search>input.is-warning:active,.is-warning.is-active.textarea,.is-warning.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(255,221,87,0.25)}.is-danger.textarea,.is-danger.input,#documenter .docs-sidebar form.docs-search>input.is-danger{border-color:#da0b00}.is-danger.textarea:focus,.is-danger.input:focus,#documenter .docs-sidebar form.docs-search>input.is-danger:focus,.is-danger.is-focused.textarea,.is-danger.is-focused.input,#documenter .docs-sidebar form.docs-search>input.is-focused,.is-danger.textarea:active,.is-danger.input:active,#documenter .docs-sidebar form.docs-search>input.is-danger:active,.is-danger.is-active.textarea,.is-danger.is-active.input,#documenter .docs-sidebar form.docs-search>input.is-active{box-shadow:0 0 0 0.125em rgba(218,11,0,0.25)}.is-small.textarea,.is-small.input,#documenter .docs-sidebar form.docs-search>input{border-radius:2px;font-size:.75rem}.is-medium.textarea,.is-medium.input,#documenter .docs-sidebar form.docs-search>input.is-medium{font-size:1.25rem}.is-large.textarea,.is-large.input,#documenter .docs-sidebar form.docs-search>input.is-large{font-size:1.5rem}.is-fullwidth.textarea,.is-fullwidth.input,#documenter .docs-sidebar form.docs-search>input.is-fullwidth{display:block;width:100%}.is-inline.textarea,.is-inline.input,#documenter .docs-sidebar form.docs-search>input.is-inline{display:inline;width:auto}.input.is-rounded,#documenter .docs-sidebar form.docs-search>input{border-radius:9999px;padding-left:calc(calc(0.75em - 1px) + 0.375em);padding-right:calc(calc(0.75em - 1px) + 0.375em)}.input.is-static,#documenter .docs-sidebar form.docs-search>input.is-static{background-color:transparent;border-color:transparent;box-shadow:none;padding-left:0;padding-right:0}.textarea{display:block;max-width:100%;min-width:100%;padding:calc(0.75em - 1px);resize:vertical}.textarea:not([rows]){max-height:40em;min-height:8em}.textarea[rows]{height:initial}.textarea.has-fixed-size{resize:none}.radio,.checkbox{cursor:pointer;display:inline-block;line-height:1.25;position:relative}.radio input,.checkbox input{cursor:pointer}.radio:hover,.checkbox:hover{color:#222}.radio[disabled],.checkbox[disabled],fieldset[disabled] .radio,fieldset[disabled] .checkbox,.radio input[disabled],.checkbox input[disabled]{color:#6b6b6b;cursor:not-allowed}.radio+.radio{margin-left:.5em}.select{display:inline-block;max-width:100%;position:relative;vertical-align:top}.select:not(.is-multiple){height:2.5em}.select:not(.is-multiple):not(.is-loading)::after{border-color:#2e63b8;right:1.125em;z-index:4}.select.is-rounded select,#documenter .docs-sidebar form.docs-search>input.select select{border-radius:9999px;padding-left:1em}.select select{cursor:pointer;display:block;font-size:1em;max-width:100%;outline:none}.select select::-ms-expand{display:none}.select select[disabled]:hover,fieldset[disabled] .select select:hover{border-color:#f5f5f5}.select select:not([multiple]){padding-right:2.5em}.select select[multiple]{height:auto;padding:0}.select select[multiple] option{padding:0.5em 1em}.select:not(.is-multiple):not(.is-loading):hover::after{border-color:#222}.select.is-white:not(:hover)::after{border-color:#fff}.select.is-white select{border-color:#fff}.select.is-white select:hover,.select.is-white select.is-hovered{border-color:#f2f2f2}.select.is-white select:focus,.select.is-white select.is-focused,.select.is-white select:active,.select.is-white select.is-active{box-shadow:0 0 0 0.125em rgba(255,255,255,0.25)}.select.is-black:not(:hover)::after{border-color:#0a0a0a}.select.is-black select{border-color:#0a0a0a}.select.is-black select:hover,.select.is-black select.is-hovered{border-color:#000}.select.is-black select:focus,.select.is-black select.is-focused,.select.is-black select:active,.select.is-black select.is-active{box-shadow:0 0 0 0.125em rgba(10,10,10,0.25)}.select.is-light:not(:hover)::after{border-color:#f5f5f5}.select.is-light select{border-color:#f5f5f5}.select.is-light select:hover,.select.is-light select.is-hovered{border-color:#e8e8e8}.select.is-light select:focus,.select.is-light select.is-focused,.select.is-light select:active,.select.is-light select.is-active{box-shadow:0 0 0 0.125em rgba(245,245,245,0.25)}.select.is-dark:not(:hover)::after,.content kbd.select:not(:hover)::after{border-color:#363636}.select.is-dark select,.content kbd.select select{border-color:#363636}.select.is-dark select:hover,.content kbd.select select:hover,.select.is-dark select.is-hovered,.content kbd.select select.is-hovered{border-color:#292929}.select.is-dark select:focus,.content kbd.select select:focus,.select.is-dark select.is-focused,.content kbd.select select.is-focused,.select.is-dark select:active,.content kbd.select select:active,.select.is-dark select.is-active,.content kbd.select select.is-active{box-shadow:0 0 0 0.125em rgba(54,54,54,0.25)}.select.is-primary:not(:hover)::after,.docstring>section>a.select.docs-sourcelink:not(:hover)::after{border-color:#4eb5de}.select.is-primary select,.docstring>section>a.select.docs-sourcelink select{border-color:#4eb5de}.select.is-primary select:hover,.docstring>section>a.select.docs-sourcelink select:hover,.select.is-primary select.is-hovered,.docstring>section>a.select.docs-sourcelink select.is-hovered{border-color:#39acda}.select.is-primary select:focus,.docstring>section>a.select.docs-sourcelink select:focus,.select.is-primary select.is-focused,.docstring>section>a.select.docs-sourcelink select.is-focused,.select.is-primary select:active,.docstring>section>a.select.docs-sourcelink select:active,.select.is-primary select.is-active,.docstring>section>a.select.docs-sourcelink select.is-active{box-shadow:0 0 0 0.125em rgba(78,181,222,0.25)}.select.is-link:not(:hover)::after{border-color:#2e63b8}.select.is-link select{border-color:#2e63b8}.select.is-link select:hover,.select.is-link select.is-hovered{border-color:#2958a4}.select.is-link select:focus,.select.is-link select.is-focused,.select.is-link select:active,.select.is-link select.is-active{box-shadow:0 0 0 0.125em rgba(46,99,184,0.25)}.select.is-info:not(:hover)::after{border-color:#209cee}.select.is-info select{border-color:#209cee}.select.is-info select:hover,.select.is-info select.is-hovered{border-color:#1190e3}.select.is-info select:focus,.select.is-info select.is-focused,.select.is-info select:active,.select.is-info select.is-active{box-shadow:0 0 0 0.125em rgba(32,156,238,0.25)}.select.is-success:not(:hover)::after{border-color:#22c35b}.select.is-success select{border-color:#22c35b}.select.is-success select:hover,.select.is-success select.is-hovered{border-color:#1ead51}.select.is-success select:focus,.select.is-success select.is-focused,.select.is-success select:active,.select.is-success select.is-active{box-shadow:0 0 0 0.125em rgba(34,195,91,0.25)}.select.is-warning:not(:hover)::after{border-color:#ffdd57}.select.is-warning select{border-color:#ffdd57}.select.is-warning select:hover,.select.is-warning select.is-hovered{border-color:#ffd83e}.select.is-warning select:focus,.select.is-warning select.is-focused,.select.is-warning select:active,.select.is-warning select.is-active{box-shadow:0 0 0 0.125em rgba(255,221,87,0.25)}.select.is-danger:not(:hover)::after{border-color:#da0b00}.select.is-danger select{border-color:#da0b00}.select.is-danger select:hover,.select.is-danger select.is-hovered{border-color:#c10a00}.select.is-danger select:focus,.select.is-danger select.is-focused,.select.is-danger select:active,.select.is-danger select.is-active{box-shadow:0 0 0 0.125em rgba(218,11,0,0.25)}.select.is-small,#documenter .docs-sidebar form.docs-search>input.select{border-radius:2px;font-size:.75rem}.select.is-medium{font-size:1.25rem}.select.is-large{font-size:1.5rem}.select.is-disabled::after{border-color:#6b6b6b !important;opacity:0.5}.select.is-fullwidth{width:100%}.select.is-fullwidth select{width:100%}.select.is-loading::after{margin-top:0;position:absolute;right:.625em;top:0.625em;transform:none}.select.is-loading.is-small:after,#documenter .docs-sidebar form.docs-search>input.is-loading:after{font-size:.75rem}.select.is-loading.is-medium:after{font-size:1.25rem}.select.is-loading.is-large:after{font-size:1.5rem}.file{align-items:stretch;display:flex;justify-content:flex-start;position:relative}.file.is-white .file-cta{background-color:#fff;border-color:transparent;color:#0a0a0a}.file.is-white:hover .file-cta,.file.is-white.is-hovered .file-cta{background-color:#f9f9f9;border-color:transparent;color:#0a0a0a}.file.is-white:focus .file-cta,.file.is-white.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(255,255,255,0.25);color:#0a0a0a}.file.is-white:active .file-cta,.file.is-white.is-active .file-cta{background-color:#f2f2f2;border-color:transparent;color:#0a0a0a}.file.is-black .file-cta{background-color:#0a0a0a;border-color:transparent;color:#fff}.file.is-black:hover .file-cta,.file.is-black.is-hovered .file-cta{background-color:#040404;border-color:transparent;color:#fff}.file.is-black:focus .file-cta,.file.is-black.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(10,10,10,0.25);color:#fff}.file.is-black:active .file-cta,.file.is-black.is-active .file-cta{background-color:#000;border-color:transparent;color:#fff}.file.is-light .file-cta{background-color:#f5f5f5;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-light:hover .file-cta,.file.is-light.is-hovered .file-cta{background-color:#eee;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-light:focus .file-cta,.file.is-light.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(245,245,245,0.25);color:rgba(0,0,0,0.7)}.file.is-light:active .file-cta,.file.is-light.is-active .file-cta{background-color:#e8e8e8;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-dark .file-cta,.content kbd.file .file-cta{background-color:#363636;border-color:transparent;color:#fff}.file.is-dark:hover .file-cta,.content kbd.file:hover .file-cta,.file.is-dark.is-hovered .file-cta,.content kbd.file.is-hovered .file-cta{background-color:#2f2f2f;border-color:transparent;color:#fff}.file.is-dark:focus .file-cta,.content kbd.file:focus .file-cta,.file.is-dark.is-focused .file-cta,.content kbd.file.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(54,54,54,0.25);color:#fff}.file.is-dark:active .file-cta,.content kbd.file:active .file-cta,.file.is-dark.is-active .file-cta,.content kbd.file.is-active .file-cta{background-color:#292929;border-color:transparent;color:#fff}.file.is-primary .file-cta,.docstring>section>a.file.docs-sourcelink .file-cta{background-color:#4eb5de;border-color:transparent;color:#fff}.file.is-primary:hover .file-cta,.docstring>section>a.file.docs-sourcelink:hover .file-cta,.file.is-primary.is-hovered .file-cta,.docstring>section>a.file.is-hovered.docs-sourcelink .file-cta{background-color:#43b1dc;border-color:transparent;color:#fff}.file.is-primary:focus .file-cta,.docstring>section>a.file.docs-sourcelink:focus .file-cta,.file.is-primary.is-focused .file-cta,.docstring>section>a.file.is-focused.docs-sourcelink .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(78,181,222,0.25);color:#fff}.file.is-primary:active .file-cta,.docstring>section>a.file.docs-sourcelink:active .file-cta,.file.is-primary.is-active .file-cta,.docstring>section>a.file.is-active.docs-sourcelink .file-cta{background-color:#39acda;border-color:transparent;color:#fff}.file.is-link .file-cta{background-color:#2e63b8;border-color:transparent;color:#fff}.file.is-link:hover .file-cta,.file.is-link.is-hovered .file-cta{background-color:#2b5eae;border-color:transparent;color:#fff}.file.is-link:focus .file-cta,.file.is-link.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(46,99,184,0.25);color:#fff}.file.is-link:active .file-cta,.file.is-link.is-active .file-cta{background-color:#2958a4;border-color:transparent;color:#fff}.file.is-info .file-cta{background-color:#209cee;border-color:transparent;color:#fff}.file.is-info:hover .file-cta,.file.is-info.is-hovered .file-cta{background-color:#1497ed;border-color:transparent;color:#fff}.file.is-info:focus .file-cta,.file.is-info.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(32,156,238,0.25);color:#fff}.file.is-info:active .file-cta,.file.is-info.is-active .file-cta{background-color:#1190e3;border-color:transparent;color:#fff}.file.is-success .file-cta{background-color:#22c35b;border-color:transparent;color:#fff}.file.is-success:hover .file-cta,.file.is-success.is-hovered .file-cta{background-color:#20b856;border-color:transparent;color:#fff}.file.is-success:focus .file-cta,.file.is-success.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(34,195,91,0.25);color:#fff}.file.is-success:active .file-cta,.file.is-success.is-active .file-cta{background-color:#1ead51;border-color:transparent;color:#fff}.file.is-warning .file-cta{background-color:#ffdd57;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-warning:hover .file-cta,.file.is-warning.is-hovered .file-cta{background-color:#ffda4a;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-warning:focus .file-cta,.file.is-warning.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(255,221,87,0.25);color:rgba(0,0,0,0.7)}.file.is-warning:active .file-cta,.file.is-warning.is-active .file-cta{background-color:#ffd83e;border-color:transparent;color:rgba(0,0,0,0.7)}.file.is-danger .file-cta{background-color:#da0b00;border-color:transparent;color:#fff}.file.is-danger:hover .file-cta,.file.is-danger.is-hovered .file-cta{background-color:#cd0a00;border-color:transparent;color:#fff}.file.is-danger:focus .file-cta,.file.is-danger.is-focused .file-cta{border-color:transparent;box-shadow:0 0 0.5em rgba(218,11,0,0.25);color:#fff}.file.is-danger:active .file-cta,.file.is-danger.is-active .file-cta{background-color:#c10a00;border-color:transparent;color:#fff}.file.is-small,#documenter .docs-sidebar form.docs-search>input.file{font-size:.75rem}.file.is-normal{font-size:1rem}.file.is-medium{font-size:1.25rem}.file.is-medium .file-icon .fa{font-size:21px}.file.is-large{font-size:1.5rem}.file.is-large .file-icon .fa{font-size:28px}.file.has-name .file-cta{border-bottom-right-radius:0;border-top-right-radius:0}.file.has-name .file-name{border-bottom-left-radius:0;border-top-left-radius:0}.file.has-name.is-empty .file-cta{border-radius:4px}.file.has-name.is-empty .file-name{display:none}.file.is-boxed .file-label{flex-direction:column}.file.is-boxed .file-cta{flex-direction:column;height:auto;padding:1em 3em}.file.is-boxed .file-name{border-width:0 1px 1px}.file.is-boxed .file-icon{height:1.5em;width:1.5em}.file.is-boxed .file-icon .fa{font-size:21px}.file.is-boxed.is-small .file-icon .fa,#documenter .docs-sidebar form.docs-search>input.is-boxed .file-icon .fa{font-size:14px}.file.is-boxed.is-medium .file-icon .fa{font-size:28px}.file.is-boxed.is-large .file-icon .fa{font-size:35px}.file.is-boxed.has-name .file-cta{border-radius:4px 4px 0 0}.file.is-boxed.has-name .file-name{border-radius:0 0 4px 4px;border-width:0 1px 1px}.file.is-centered{justify-content:center}.file.is-fullwidth .file-label{width:100%}.file.is-fullwidth .file-name{flex-grow:1;max-width:none}.file.is-right{justify-content:flex-end}.file.is-right .file-cta{border-radius:0 4px 4px 0}.file.is-right .file-name{border-radius:4px 0 0 4px;border-width:1px 0 1px 1px;order:-1}.file-label{align-items:stretch;display:flex;cursor:pointer;justify-content:flex-start;overflow:hidden;position:relative}.file-label:hover .file-cta{background-color:#eee;color:#222}.file-label:hover .file-name{border-color:#d5d5d5}.file-label:active .file-cta{background-color:#e8e8e8;color:#222}.file-label:active .file-name{border-color:#cfcfcf}.file-input{height:100%;left:0;opacity:0;outline:none;position:absolute;top:0;width:100%}.file-cta,.file-name{border-color:#dbdbdb;border-radius:4px;font-size:1em;padding-left:1em;padding-right:1em;white-space:nowrap}.file-cta{background-color:#f5f5f5;color:#222}.file-name{border-color:#dbdbdb;border-style:solid;border-width:1px 1px 1px 0;display:block;max-width:16em;overflow:hidden;text-align:inherit;text-overflow:ellipsis}.file-icon{align-items:center;display:flex;height:1em;justify-content:center;margin-right:.5em;width:1em}.file-icon .fa{font-size:14px}.label{color:#222;display:block;font-size:1rem;font-weight:700}.label:not(:last-child){margin-bottom:0.5em}.label.is-small,#documenter .docs-sidebar form.docs-search>input.label{font-size:.75rem}.label.is-medium{font-size:1.25rem}.label.is-large{font-size:1.5rem}.help{display:block;font-size:.75rem;margin-top:0.25rem}.help.is-white{color:#fff}.help.is-black{color:#0a0a0a}.help.is-light{color:#f5f5f5}.help.is-dark,.content kbd.help{color:#363636}.help.is-primary,.docstring>section>a.help.docs-sourcelink{color:#4eb5de}.help.is-link{color:#2e63b8}.help.is-info{color:#209cee}.help.is-success{color:#22c35b}.help.is-warning{color:#ffdd57}.help.is-danger{color:#da0b00}.field:not(:last-child){margin-bottom:0.75rem}.field.has-addons{display:flex;justify-content:flex-start}.field.has-addons .control:not(:last-child){margin-right:-1px}.field.has-addons .control:not(:first-child):not(:last-child) .button,.field.has-addons .control:not(:first-child):not(:last-child) .input,.field.has-addons .control:not(:first-child):not(:last-child) #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar .field.has-addons .control:not(:first-child):not(:last-child) form.docs-search>input,.field.has-addons .control:not(:first-child):not(:last-child) .select select{border-radius:0}.field.has-addons .control:first-child:not(:only-child) .button,.field.has-addons .control:first-child:not(:only-child) .input,.field.has-addons .control:first-child:not(:only-child) #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar .field.has-addons .control:first-child:not(:only-child) form.docs-search>input,.field.has-addons .control:first-child:not(:only-child) .select select{border-bottom-right-radius:0;border-top-right-radius:0}.field.has-addons .control:last-child:not(:only-child) .button,.field.has-addons .control:last-child:not(:only-child) .input,.field.has-addons .control:last-child:not(:only-child) #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar .field.has-addons .control:last-child:not(:only-child) form.docs-search>input,.field.has-addons .control:last-child:not(:only-child) .select select{border-bottom-left-radius:0;border-top-left-radius:0}.field.has-addons .control .button:not([disabled]):hover,.field.has-addons .control .button.is-hovered:not([disabled]),.field.has-addons .control .input:not([disabled]):hover,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):hover,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):hover,.field.has-addons .control .input.is-hovered:not([disabled]),.field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-hovered:not([disabled]),#documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-hovered:not([disabled]),.field.has-addons .control .select select:not([disabled]):hover,.field.has-addons .control .select select.is-hovered:not([disabled]){z-index:2}.field.has-addons .control .button:not([disabled]):focus,.field.has-addons .control .button.is-focused:not([disabled]),.field.has-addons .control .button:not([disabled]):active,.field.has-addons .control .button.is-active:not([disabled]),.field.has-addons .control .input:not([disabled]):focus,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):focus,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):focus,.field.has-addons .control .input.is-focused:not([disabled]),.field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-focused:not([disabled]),#documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-focused:not([disabled]),.field.has-addons .control .input:not([disabled]):active,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):active,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):active,.field.has-addons .control .input.is-active:not([disabled]),.field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-active:not([disabled]),#documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-active:not([disabled]),.field.has-addons .control .select select:not([disabled]):focus,.field.has-addons .control .select select.is-focused:not([disabled]),.field.has-addons .control .select select:not([disabled]):active,.field.has-addons .control .select select.is-active:not([disabled]){z-index:3}.field.has-addons .control .button:not([disabled]):focus:hover,.field.has-addons .control .button.is-focused:not([disabled]):hover,.field.has-addons .control .button:not([disabled]):active:hover,.field.has-addons .control .button.is-active:not([disabled]):hover,.field.has-addons .control .input:not([disabled]):focus:hover,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):focus:hover,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):focus:hover,.field.has-addons .control .input.is-focused:not([disabled]):hover,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-focused:not([disabled]):hover,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-focused:not([disabled]):hover,.field.has-addons .control .input:not([disabled]):active:hover,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input:not([disabled]):active:hover,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input:not([disabled]):active:hover,.field.has-addons .control .input.is-active:not([disabled]):hover,.field.has-addons .control #documenter .docs-sidebar form.docs-search>input.is-active:not([disabled]):hover,#documenter .docs-sidebar .field.has-addons .control form.docs-search>input.is-active:not([disabled]):hover,.field.has-addons .control .select select:not([disabled]):focus:hover,.field.has-addons .control .select select.is-focused:not([disabled]):hover,.field.has-addons .control .select select:not([disabled]):active:hover,.field.has-addons .control .select select.is-active:not([disabled]):hover{z-index:4}.field.has-addons .control.is-expanded{flex-grow:1;flex-shrink:1}.field.has-addons.has-addons-centered{justify-content:center}.field.has-addons.has-addons-right{justify-content:flex-end}.field.has-addons.has-addons-fullwidth .control{flex-grow:1;flex-shrink:0}.field.is-grouped{display:flex;justify-content:flex-start}.field.is-grouped>.control{flex-shrink:0}.field.is-grouped>.control:not(:last-child){margin-bottom:0;margin-right:.75rem}.field.is-grouped>.control.is-expanded{flex-grow:1;flex-shrink:1}.field.is-grouped.is-grouped-centered{justify-content:center}.field.is-grouped.is-grouped-right{justify-content:flex-end}.field.is-grouped.is-grouped-multiline{flex-wrap:wrap}.field.is-grouped.is-grouped-multiline>.control:last-child,.field.is-grouped.is-grouped-multiline>.control:not(:last-child){margin-bottom:0.75rem}.field.is-grouped.is-grouped-multiline:last-child{margin-bottom:-0.75rem}.field.is-grouped.is-grouped-multiline:not(:last-child){margin-bottom:0}@media screen and (min-width: 769px),print{.field.is-horizontal{display:flex}}.field-label .label{font-size:inherit}@media screen and (max-width: 768px){.field-label{margin-bottom:0.5rem}}@media screen and (min-width: 769px),print{.field-label{flex-basis:0;flex-grow:1;flex-shrink:0;margin-right:1.5rem;text-align:right}.field-label.is-small,#documenter .docs-sidebar form.docs-search>input.field-label{font-size:.75rem;padding-top:0.375em}.field-label.is-normal{padding-top:0.375em}.field-label.is-medium{font-size:1.25rem;padding-top:0.375em}.field-label.is-large{font-size:1.5rem;padding-top:0.375em}}.field-body .field .field{margin-bottom:0}@media screen and (min-width: 769px),print{.field-body{display:flex;flex-basis:0;flex-grow:5;flex-shrink:1}.field-body .field{margin-bottom:0}.field-body>.field{flex-shrink:1}.field-body>.field:not(.is-narrow){flex-grow:1}.field-body>.field:not(:last-child){margin-right:.75rem}}.control{box-sizing:border-box;clear:both;font-size:1rem;position:relative;text-align:inherit}.control.has-icons-left .input:focus~.icon,.control.has-icons-left #documenter .docs-sidebar form.docs-search>input:focus~.icon,#documenter .docs-sidebar .control.has-icons-left form.docs-search>input:focus~.icon,.control.has-icons-left .select:focus~.icon,.control.has-icons-right .input:focus~.icon,.control.has-icons-right #documenter .docs-sidebar form.docs-search>input:focus~.icon,#documenter .docs-sidebar .control.has-icons-right form.docs-search>input:focus~.icon,.control.has-icons-right .select:focus~.icon{color:#222}.control.has-icons-left .input.is-small~.icon,.control.has-icons-left #documenter .docs-sidebar form.docs-search>input~.icon,#documenter .docs-sidebar .control.has-icons-left form.docs-search>input~.icon,.control.has-icons-left .select.is-small~.icon,.control.has-icons-right .input.is-small~.icon,.control.has-icons-right #documenter .docs-sidebar form.docs-search>input~.icon,#documenter .docs-sidebar .control.has-icons-right form.docs-search>input~.icon,.control.has-icons-right .select.is-small~.icon{font-size:.75rem}.control.has-icons-left .input.is-medium~.icon,.control.has-icons-left #documenter .docs-sidebar form.docs-search>input.is-medium~.icon,#documenter .docs-sidebar .control.has-icons-left form.docs-search>input.is-medium~.icon,.control.has-icons-left .select.is-medium~.icon,.control.has-icons-right .input.is-medium~.icon,.control.has-icons-right #documenter .docs-sidebar form.docs-search>input.is-medium~.icon,#documenter .docs-sidebar .control.has-icons-right form.docs-search>input.is-medium~.icon,.control.has-icons-right .select.is-medium~.icon{font-size:1.25rem}.control.has-icons-left .input.is-large~.icon,.control.has-icons-left #documenter .docs-sidebar form.docs-search>input.is-large~.icon,#documenter .docs-sidebar .control.has-icons-left form.docs-search>input.is-large~.icon,.control.has-icons-left .select.is-large~.icon,.control.has-icons-right .input.is-large~.icon,.control.has-icons-right #documenter .docs-sidebar form.docs-search>input.is-large~.icon,#documenter .docs-sidebar .control.has-icons-right form.docs-search>input.is-large~.icon,.control.has-icons-right .select.is-large~.icon{font-size:1.5rem}.control.has-icons-left .icon,.control.has-icons-right .icon{color:#dbdbdb;height:2.5em;pointer-events:none;position:absolute;top:0;width:2.5em;z-index:4}.control.has-icons-left .input,.control.has-icons-left #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar .control.has-icons-left form.docs-search>input,.control.has-icons-left .select select{padding-left:2.5em}.control.has-icons-left .icon.is-left{left:0}.control.has-icons-right .input,.control.has-icons-right #documenter .docs-sidebar form.docs-search>input,#documenter .docs-sidebar .control.has-icons-right form.docs-search>input,.control.has-icons-right .select select{padding-right:2.5em}.control.has-icons-right .icon.is-right{right:0}.control.is-loading::after{position:absolute !important;right:.625em;top:0.625em;z-index:4}.control.is-loading.is-small:after,#documenter .docs-sidebar form.docs-search>input.is-loading:after{font-size:.75rem}.control.is-loading.is-medium:after{font-size:1.25rem}.control.is-loading.is-large:after{font-size:1.5rem}.breadcrumb{font-size:1rem;white-space:nowrap}.breadcrumb a{align-items:center;color:#2e63b8;display:flex;justify-content:center;padding:0 .75em}.breadcrumb a:hover{color:#363636}.breadcrumb li{align-items:center;display:flex}.breadcrumb li:first-child a{padding-left:0}.breadcrumb li.is-active a{color:#222;cursor:default;pointer-events:none}.breadcrumb li+li::before{color:#b5b5b5;content:"\0002f"}.breadcrumb ul,.breadcrumb ol{align-items:flex-start;display:flex;flex-wrap:wrap;justify-content:flex-start}.breadcrumb .icon:first-child{margin-right:.5em}.breadcrumb .icon:last-child{margin-left:.5em}.breadcrumb.is-centered ol,.breadcrumb.is-centered ul{justify-content:center}.breadcrumb.is-right ol,.breadcrumb.is-right ul{justify-content:flex-end}.breadcrumb.is-small,#documenter .docs-sidebar form.docs-search>input.breadcrumb{font-size:.75rem}.breadcrumb.is-medium{font-size:1.25rem}.breadcrumb.is-large{font-size:1.5rem}.breadcrumb.has-arrow-separator li+li::before{content:"\02192"}.breadcrumb.has-bullet-separator li+li::before{content:"\02022"}.breadcrumb.has-dot-separator li+li::before{content:"\000b7"}.breadcrumb.has-succeeds-separator li+li::before{content:"\0227B"}.card{background-color:#fff;border-radius:.25rem;box-shadow:#bbb;color:#222;max-width:100%;position:relative}.card-footer:first-child,.card-content:first-child,.card-header:first-child{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card-footer:last-child,.card-content:last-child,.card-header:last-child{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}.card-header{background-color:rgba(0,0,0,0);align-items:stretch;box-shadow:0 0.125em 0.25em rgba(10,10,10,0.1);display:flex}.card-header-title{align-items:center;color:#222;display:flex;flex-grow:1;font-weight:700;padding:0.75rem 1rem}.card-header-title.is-centered{justify-content:center}.card-header-icon{-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;color:currentColor;font-family:inherit;font-size:1em;margin:0;padding:0;align-items:center;cursor:pointer;display:flex;justify-content:center;padding:0.75rem 1rem}.card-image{display:block;position:relative}.card-image:first-child img{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.card-image:last-child img{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}.card-content{background-color:rgba(0,0,0,0);padding:1.5rem}.card-footer{background-color:rgba(0,0,0,0);border-top:1px solid #ededed;align-items:stretch;display:flex}.card-footer-item{align-items:center;display:flex;flex-basis:0;flex-grow:1;flex-shrink:0;justify-content:center;padding:.75rem}.card-footer-item:not(:last-child){border-right:1px solid #ededed}.card .media:not(:last-child){margin-bottom:1.5rem}.dropdown{display:inline-flex;position:relative;vertical-align:top}.dropdown.is-active .dropdown-menu,.dropdown.is-hoverable:hover .dropdown-menu{display:block}.dropdown.is-right .dropdown-menu{left:auto;right:0}.dropdown.is-up .dropdown-menu{bottom:100%;padding-bottom:4px;padding-top:initial;top:auto}.dropdown-menu{display:none;left:0;min-width:12rem;padding-top:4px;position:absolute;top:100%;z-index:20}.dropdown-content{background-color:#fff;border-radius:4px;box-shadow:#bbb;padding-bottom:.5rem;padding-top:.5rem}.dropdown-item{color:#222;display:block;font-size:0.875rem;line-height:1.5;padding:0.375rem 1rem;position:relative}a.dropdown-item,button.dropdown-item{padding-right:3rem;text-align:inherit;white-space:nowrap;width:100%}a.dropdown-item:hover,button.dropdown-item:hover{background-color:#f5f5f5;color:#0a0a0a}a.dropdown-item.is-active,button.dropdown-item.is-active{background-color:#2e63b8;color:#fff}.dropdown-divider{background-color:#ededed;border:none;display:block;height:1px;margin:0.5rem 0}.level{align-items:center;justify-content:space-between}.level code{border-radius:4px}.level img{display:inline-block;vertical-align:top}.level.is-mobile{display:flex}.level.is-mobile .level-left,.level.is-mobile .level-right{display:flex}.level.is-mobile .level-left+.level-right{margin-top:0}.level.is-mobile .level-item:not(:last-child){margin-bottom:0;margin-right:.75rem}.level.is-mobile .level-item:not(.is-narrow){flex-grow:1}@media screen and (min-width: 769px),print{.level{display:flex}.level>.level-item:not(.is-narrow){flex-grow:1}}.level-item{align-items:center;display:flex;flex-basis:auto;flex-grow:0;flex-shrink:0;justify-content:center}.level-item .title,.level-item .subtitle{margin-bottom:0}@media screen and (max-width: 768px){.level-item:not(:last-child){margin-bottom:.75rem}}.level-left,.level-right{flex-basis:auto;flex-grow:0;flex-shrink:0}.level-left .level-item.is-flexible,.level-right .level-item.is-flexible{flex-grow:1}@media screen and (min-width: 769px),print{.level-left .level-item:not(:last-child),.level-right .level-item:not(:last-child){margin-right:.75rem}}.level-left{align-items:center;justify-content:flex-start}@media screen and (max-width: 768px){.level-left+.level-right{margin-top:1.5rem}}@media screen and (min-width: 769px),print{.level-left{display:flex}}.level-right{align-items:center;justify-content:flex-end}@media screen and (min-width: 769px),print{.level-right{display:flex}}.media{align-items:flex-start;display:flex;text-align:inherit}.media .content:not(:last-child){margin-bottom:.75rem}.media .media{border-top:1px solid rgba(219,219,219,0.5);display:flex;padding-top:.75rem}.media .media .content:not(:last-child),.media .media .control:not(:last-child){margin-bottom:.5rem}.media .media .media{padding-top:.5rem}.media .media .media+.media{margin-top:.5rem}.media+.media{border-top:1px solid rgba(219,219,219,0.5);margin-top:1rem;padding-top:1rem}.media.is-large+.media{margin-top:1.5rem;padding-top:1.5rem}.media-left,.media-right{flex-basis:auto;flex-grow:0;flex-shrink:0}.media-left{margin-right:1rem}.media-right{margin-left:1rem}.media-content{flex-basis:auto;flex-grow:1;flex-shrink:1;text-align:inherit}@media screen and (max-width: 768px){.media-content{overflow-x:auto}}.menu{font-size:1rem}.menu.is-small,#documenter .docs-sidebar form.docs-search>input.menu{font-size:.75rem}.menu.is-medium{font-size:1.25rem}.menu.is-large{font-size:1.5rem}.menu-list{line-height:1.25}.menu-list a{border-radius:2px;color:#222;display:block;padding:0.5em 0.75em}.menu-list a:hover{background-color:#f5f5f5;color:#222}.menu-list a.is-active{background-color:#2e63b8;color:#fff}.menu-list li ul{border-left:1px solid #dbdbdb;margin:.75em;padding-left:.75em}.menu-label{color:#6b6b6b;font-size:.75em;letter-spacing:.1em;text-transform:uppercase}.menu-label:not(:first-child){margin-top:1em}.menu-label:not(:last-child){margin-bottom:1em}.message{background-color:#f5f5f5;border-radius:4px;font-size:1rem}.message strong{color:currentColor}.message a:not(.button):not(.tag):not(.dropdown-item){color:currentColor;text-decoration:underline}.message.is-small,#documenter .docs-sidebar form.docs-search>input.message{font-size:.75rem}.message.is-medium{font-size:1.25rem}.message.is-large{font-size:1.5rem}.message.is-white{background-color:#fff}.message.is-white .message-header{background-color:#fff;color:#0a0a0a}.message.is-white .message-body{border-color:#fff}.message.is-black{background-color:#fafafa}.message.is-black .message-header{background-color:#0a0a0a;color:#fff}.message.is-black .message-body{border-color:#0a0a0a}.message.is-light{background-color:#fafafa}.message.is-light .message-header{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.message.is-light .message-body{border-color:#f5f5f5}.message.is-dark,.content kbd.message{background-color:#fafafa}.message.is-dark .message-header,.content kbd.message .message-header{background-color:#363636;color:#fff}.message.is-dark .message-body,.content kbd.message .message-body{border-color:#363636}.message.is-primary,.docstring>section>a.message.docs-sourcelink{background-color:#eef8fc}.message.is-primary .message-header,.docstring>section>a.message.docs-sourcelink .message-header{background-color:#4eb5de;color:#fff}.message.is-primary .message-body,.docstring>section>a.message.docs-sourcelink .message-body{border-color:#4eb5de;color:#1a6d8e}.message.is-link{background-color:#eff3fb}.message.is-link .message-header{background-color:#2e63b8;color:#fff}.message.is-link .message-body{border-color:#2e63b8;color:#3169c4}.message.is-info{background-color:#ecf7fe}.message.is-info .message-header{background-color:#209cee;color:#fff}.message.is-info .message-body{border-color:#209cee;color:#0e72b4}.message.is-success{background-color:#eefcf3}.message.is-success .message-header{background-color:#22c35b;color:#fff}.message.is-success .message-body{border-color:#22c35b;color:#198f43}.message.is-warning{background-color:#fffbeb}.message.is-warning .message-header{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.message.is-warning .message-body{border-color:#ffdd57;color:#947600}.message.is-danger{background-color:#ffeceb}.message.is-danger .message-header{background-color:#da0b00;color:#fff}.message.is-danger .message-body{border-color:#da0b00;color:#f50c00}.message-header{align-items:center;background-color:#222;border-radius:4px 4px 0 0;color:#fff;display:flex;font-weight:700;justify-content:space-between;line-height:1.25;padding:0.75em 1em;position:relative}.message-header .delete{flex-grow:0;flex-shrink:0;margin-left:.75em}.message-header+.message-body{border-width:0;border-top-left-radius:0;border-top-right-radius:0}.message-body{border-color:#dbdbdb;border-radius:4px;border-style:solid;border-width:0 0 0 4px;color:#222;padding:1.25em 1.5em}.message-body code,.message-body pre{background-color:#fff}.message-body pre code{background-color:rgba(0,0,0,0)}.modal{align-items:center;display:none;flex-direction:column;justify-content:center;overflow:hidden;position:fixed;z-index:40}.modal.is-active{display:flex}.modal-background{background-color:rgba(10,10,10,0.86)}.modal-content,.modal-card{margin:0 20px;max-height:calc(100vh - 160px);overflow:auto;position:relative;width:100%}@media screen and (min-width: 769px){.modal-content,.modal-card{margin:0 auto;max-height:calc(100vh - 40px);width:640px}}.modal-close{background:none;height:40px;position:fixed;right:20px;top:20px;width:40px}.modal-card{display:flex;flex-direction:column;max-height:calc(100vh - 40px);overflow:hidden;-ms-overflow-y:visible}.modal-card-head,.modal-card-foot{align-items:center;background-color:#f5f5f5;display:flex;flex-shrink:0;justify-content:flex-start;padding:20px;position:relative}.modal-card-head{border-bottom:1px solid #dbdbdb;border-top-left-radius:6px;border-top-right-radius:6px}.modal-card-title{color:#222;flex-grow:1;flex-shrink:0;font-size:1.5rem;line-height:1}.modal-card-foot{border-bottom-left-radius:6px;border-bottom-right-radius:6px;border-top:1px solid #dbdbdb}.modal-card-foot .button:not(:last-child){margin-right:.5em}.modal-card-body{-webkit-overflow-scrolling:touch;background-color:#fff;flex-grow:1;flex-shrink:1;overflow:auto;padding:20px}.navbar{background-color:#fff;min-height:3.25rem;position:relative;z-index:30}.navbar.is-white{background-color:#fff;color:#0a0a0a}.navbar.is-white .navbar-brand>.navbar-item,.navbar.is-white .navbar-brand .navbar-link{color:#0a0a0a}.navbar.is-white .navbar-brand>a.navbar-item:focus,.navbar.is-white .navbar-brand>a.navbar-item:hover,.navbar.is-white .navbar-brand>a.navbar-item.is-active,.navbar.is-white .navbar-brand .navbar-link:focus,.navbar.is-white .navbar-brand .navbar-link:hover,.navbar.is-white .navbar-brand .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}.navbar.is-white .navbar-brand .navbar-link::after{border-color:#0a0a0a}.navbar.is-white .navbar-burger{color:#0a0a0a}@media screen and (min-width: 1056px){.navbar.is-white .navbar-start>.navbar-item,.navbar.is-white .navbar-start .navbar-link,.navbar.is-white .navbar-end>.navbar-item,.navbar.is-white .navbar-end .navbar-link{color:#0a0a0a}.navbar.is-white .navbar-start>a.navbar-item:focus,.navbar.is-white .navbar-start>a.navbar-item:hover,.navbar.is-white .navbar-start>a.navbar-item.is-active,.navbar.is-white .navbar-start .navbar-link:focus,.navbar.is-white .navbar-start .navbar-link:hover,.navbar.is-white .navbar-start .navbar-link.is-active,.navbar.is-white .navbar-end>a.navbar-item:focus,.navbar.is-white .navbar-end>a.navbar-item:hover,.navbar.is-white .navbar-end>a.navbar-item.is-active,.navbar.is-white .navbar-end .navbar-link:focus,.navbar.is-white .navbar-end .navbar-link:hover,.navbar.is-white .navbar-end .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}.navbar.is-white .navbar-start .navbar-link::after,.navbar.is-white .navbar-end .navbar-link::after{border-color:#0a0a0a}.navbar.is-white .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-white .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-white .navbar-item.has-dropdown.is-active .navbar-link{background-color:#f2f2f2;color:#0a0a0a}.navbar.is-white .navbar-dropdown a.navbar-item.is-active{background-color:#fff;color:#0a0a0a}}.navbar.is-black{background-color:#0a0a0a;color:#fff}.navbar.is-black .navbar-brand>.navbar-item,.navbar.is-black .navbar-brand .navbar-link{color:#fff}.navbar.is-black .navbar-brand>a.navbar-item:focus,.navbar.is-black .navbar-brand>a.navbar-item:hover,.navbar.is-black .navbar-brand>a.navbar-item.is-active,.navbar.is-black .navbar-brand .navbar-link:focus,.navbar.is-black .navbar-brand .navbar-link:hover,.navbar.is-black .navbar-brand .navbar-link.is-active{background-color:#000;color:#fff}.navbar.is-black .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-black .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-black .navbar-start>.navbar-item,.navbar.is-black .navbar-start .navbar-link,.navbar.is-black .navbar-end>.navbar-item,.navbar.is-black .navbar-end .navbar-link{color:#fff}.navbar.is-black .navbar-start>a.navbar-item:focus,.navbar.is-black .navbar-start>a.navbar-item:hover,.navbar.is-black .navbar-start>a.navbar-item.is-active,.navbar.is-black .navbar-start .navbar-link:focus,.navbar.is-black .navbar-start .navbar-link:hover,.navbar.is-black .navbar-start .navbar-link.is-active,.navbar.is-black .navbar-end>a.navbar-item:focus,.navbar.is-black .navbar-end>a.navbar-item:hover,.navbar.is-black .navbar-end>a.navbar-item.is-active,.navbar.is-black .navbar-end .navbar-link:focus,.navbar.is-black .navbar-end .navbar-link:hover,.navbar.is-black .navbar-end .navbar-link.is-active{background-color:#000;color:#fff}.navbar.is-black .navbar-start .navbar-link::after,.navbar.is-black .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-black .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-black .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-black .navbar-item.has-dropdown.is-active .navbar-link{background-color:#000;color:#fff}.navbar.is-black .navbar-dropdown a.navbar-item.is-active{background-color:#0a0a0a;color:#fff}}.navbar.is-light{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-brand>.navbar-item,.navbar.is-light .navbar-brand .navbar-link{color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-brand>a.navbar-item:focus,.navbar.is-light .navbar-brand>a.navbar-item:hover,.navbar.is-light .navbar-brand>a.navbar-item.is-active,.navbar.is-light .navbar-brand .navbar-link:focus,.navbar.is-light .navbar-brand .navbar-link:hover,.navbar.is-light .navbar-brand .navbar-link.is-active{background-color:#e8e8e8;color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-brand .navbar-link::after{border-color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-burger{color:rgba(0,0,0,0.7)}@media screen and (min-width: 1056px){.navbar.is-light .navbar-start>.navbar-item,.navbar.is-light .navbar-start .navbar-link,.navbar.is-light .navbar-end>.navbar-item,.navbar.is-light .navbar-end .navbar-link{color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-start>a.navbar-item:focus,.navbar.is-light .navbar-start>a.navbar-item:hover,.navbar.is-light .navbar-start>a.navbar-item.is-active,.navbar.is-light .navbar-start .navbar-link:focus,.navbar.is-light .navbar-start .navbar-link:hover,.navbar.is-light .navbar-start .navbar-link.is-active,.navbar.is-light .navbar-end>a.navbar-item:focus,.navbar.is-light .navbar-end>a.navbar-item:hover,.navbar.is-light .navbar-end>a.navbar-item.is-active,.navbar.is-light .navbar-end .navbar-link:focus,.navbar.is-light .navbar-end .navbar-link:hover,.navbar.is-light .navbar-end .navbar-link.is-active{background-color:#e8e8e8;color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-start .navbar-link::after,.navbar.is-light .navbar-end .navbar-link::after{border-color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-light .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-light .navbar-item.has-dropdown.is-active .navbar-link{background-color:#e8e8e8;color:rgba(0,0,0,0.7)}.navbar.is-light .navbar-dropdown a.navbar-item.is-active{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}}.navbar.is-dark,.content kbd.navbar{background-color:#363636;color:#fff}.navbar.is-dark .navbar-brand>.navbar-item,.content kbd.navbar .navbar-brand>.navbar-item,.navbar.is-dark .navbar-brand .navbar-link,.content kbd.navbar .navbar-brand .navbar-link{color:#fff}.navbar.is-dark .navbar-brand>a.navbar-item:focus,.content kbd.navbar .navbar-brand>a.navbar-item:focus,.navbar.is-dark .navbar-brand>a.navbar-item:hover,.content kbd.navbar .navbar-brand>a.navbar-item:hover,.navbar.is-dark .navbar-brand>a.navbar-item.is-active,.content kbd.navbar .navbar-brand>a.navbar-item.is-active,.navbar.is-dark .navbar-brand .navbar-link:focus,.content kbd.navbar .navbar-brand .navbar-link:focus,.navbar.is-dark .navbar-brand .navbar-link:hover,.content kbd.navbar .navbar-brand .navbar-link:hover,.navbar.is-dark .navbar-brand .navbar-link.is-active,.content kbd.navbar .navbar-brand .navbar-link.is-active{background-color:#292929;color:#fff}.navbar.is-dark .navbar-brand .navbar-link::after,.content kbd.navbar .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-dark .navbar-burger,.content kbd.navbar .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-dark .navbar-start>.navbar-item,.content kbd.navbar .navbar-start>.navbar-item,.navbar.is-dark .navbar-start .navbar-link,.content kbd.navbar .navbar-start .navbar-link,.navbar.is-dark .navbar-end>.navbar-item,.content kbd.navbar .navbar-end>.navbar-item,.navbar.is-dark .navbar-end .navbar-link,.content kbd.navbar .navbar-end .navbar-link{color:#fff}.navbar.is-dark .navbar-start>a.navbar-item:focus,.content kbd.navbar .navbar-start>a.navbar-item:focus,.navbar.is-dark .navbar-start>a.navbar-item:hover,.content kbd.navbar .navbar-start>a.navbar-item:hover,.navbar.is-dark .navbar-start>a.navbar-item.is-active,.content kbd.navbar .navbar-start>a.navbar-item.is-active,.navbar.is-dark .navbar-start .navbar-link:focus,.content kbd.navbar .navbar-start .navbar-link:focus,.navbar.is-dark .navbar-start .navbar-link:hover,.content kbd.navbar .navbar-start .navbar-link:hover,.navbar.is-dark .navbar-start .navbar-link.is-active,.content kbd.navbar .navbar-start .navbar-link.is-active,.navbar.is-dark .navbar-end>a.navbar-item:focus,.content kbd.navbar .navbar-end>a.navbar-item:focus,.navbar.is-dark .navbar-end>a.navbar-item:hover,.content kbd.navbar .navbar-end>a.navbar-item:hover,.navbar.is-dark .navbar-end>a.navbar-item.is-active,.content kbd.navbar .navbar-end>a.navbar-item.is-active,.navbar.is-dark .navbar-end .navbar-link:focus,.content kbd.navbar .navbar-end .navbar-link:focus,.navbar.is-dark .navbar-end .navbar-link:hover,.content kbd.navbar .navbar-end .navbar-link:hover,.navbar.is-dark .navbar-end .navbar-link.is-active,.content kbd.navbar .navbar-end .navbar-link.is-active{background-color:#292929;color:#fff}.navbar.is-dark .navbar-start .navbar-link::after,.content kbd.navbar .navbar-start .navbar-link::after,.navbar.is-dark .navbar-end .navbar-link::after,.content kbd.navbar .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-dark .navbar-item.has-dropdown:focus .navbar-link,.content kbd.navbar .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-dark .navbar-item.has-dropdown:hover .navbar-link,.content kbd.navbar .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-dark .navbar-item.has-dropdown.is-active .navbar-link,.content kbd.navbar .navbar-item.has-dropdown.is-active .navbar-link{background-color:#292929;color:#fff}.navbar.is-dark .navbar-dropdown a.navbar-item.is-active,.content kbd.navbar .navbar-dropdown a.navbar-item.is-active{background-color:#363636;color:#fff}}.navbar.is-primary,.docstring>section>a.navbar.docs-sourcelink{background-color:#4eb5de;color:#fff}.navbar.is-primary .navbar-brand>.navbar-item,.docstring>section>a.navbar.docs-sourcelink .navbar-brand>.navbar-item,.navbar.is-primary .navbar-brand .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link{color:#fff}.navbar.is-primary .navbar-brand>a.navbar-item:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item:focus,.navbar.is-primary .navbar-brand>a.navbar-item:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item:hover,.navbar.is-primary .navbar-brand>a.navbar-item.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-brand>a.navbar-item.is-active,.navbar.is-primary .navbar-brand .navbar-link:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link:focus,.navbar.is-primary .navbar-brand .navbar-link:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link:hover,.navbar.is-primary .navbar-brand .navbar-link.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link.is-active{background-color:#39acda;color:#fff}.navbar.is-primary .navbar-brand .navbar-link::after,.docstring>section>a.navbar.docs-sourcelink .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-primary .navbar-burger,.docstring>section>a.navbar.docs-sourcelink .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-primary .navbar-start>.navbar-item,.docstring>section>a.navbar.docs-sourcelink .navbar-start>.navbar-item,.navbar.is-primary .navbar-start .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link,.navbar.is-primary .navbar-end>.navbar-item,.docstring>section>a.navbar.docs-sourcelink .navbar-end>.navbar-item,.navbar.is-primary .navbar-end .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link{color:#fff}.navbar.is-primary .navbar-start>a.navbar-item:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item:focus,.navbar.is-primary .navbar-start>a.navbar-item:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item:hover,.navbar.is-primary .navbar-start>a.navbar-item.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-start>a.navbar-item.is-active,.navbar.is-primary .navbar-start .navbar-link:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link:focus,.navbar.is-primary .navbar-start .navbar-link:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link:hover,.navbar.is-primary .navbar-start .navbar-link.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link.is-active,.navbar.is-primary .navbar-end>a.navbar-item:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item:focus,.navbar.is-primary .navbar-end>a.navbar-item:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item:hover,.navbar.is-primary .navbar-end>a.navbar-item.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-end>a.navbar-item.is-active,.navbar.is-primary .navbar-end .navbar-link:focus,.docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link:focus,.navbar.is-primary .navbar-end .navbar-link:hover,.docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link:hover,.navbar.is-primary .navbar-end .navbar-link.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link.is-active{background-color:#39acda;color:#fff}.navbar.is-primary .navbar-start .navbar-link::after,.docstring>section>a.navbar.docs-sourcelink .navbar-start .navbar-link::after,.navbar.is-primary .navbar-end .navbar-link::after,.docstring>section>a.navbar.docs-sourcelink .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-primary .navbar-item.has-dropdown:focus .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-primary .navbar-item.has-dropdown:hover .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-primary .navbar-item.has-dropdown.is-active .navbar-link,.docstring>section>a.navbar.docs-sourcelink .navbar-item.has-dropdown.is-active .navbar-link{background-color:#39acda;color:#fff}.navbar.is-primary .navbar-dropdown a.navbar-item.is-active,.docstring>section>a.navbar.docs-sourcelink .navbar-dropdown a.navbar-item.is-active{background-color:#4eb5de;color:#fff}}.navbar.is-link{background-color:#2e63b8;color:#fff}.navbar.is-link .navbar-brand>.navbar-item,.navbar.is-link .navbar-brand .navbar-link{color:#fff}.navbar.is-link .navbar-brand>a.navbar-item:focus,.navbar.is-link .navbar-brand>a.navbar-item:hover,.navbar.is-link .navbar-brand>a.navbar-item.is-active,.navbar.is-link .navbar-brand .navbar-link:focus,.navbar.is-link .navbar-brand .navbar-link:hover,.navbar.is-link .navbar-brand .navbar-link.is-active{background-color:#2958a4;color:#fff}.navbar.is-link .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-link .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-link .navbar-start>.navbar-item,.navbar.is-link .navbar-start .navbar-link,.navbar.is-link .navbar-end>.navbar-item,.navbar.is-link .navbar-end .navbar-link{color:#fff}.navbar.is-link .navbar-start>a.navbar-item:focus,.navbar.is-link .navbar-start>a.navbar-item:hover,.navbar.is-link .navbar-start>a.navbar-item.is-active,.navbar.is-link .navbar-start .navbar-link:focus,.navbar.is-link .navbar-start .navbar-link:hover,.navbar.is-link .navbar-start .navbar-link.is-active,.navbar.is-link .navbar-end>a.navbar-item:focus,.navbar.is-link .navbar-end>a.navbar-item:hover,.navbar.is-link .navbar-end>a.navbar-item.is-active,.navbar.is-link .navbar-end .navbar-link:focus,.navbar.is-link .navbar-end .navbar-link:hover,.navbar.is-link .navbar-end .navbar-link.is-active{background-color:#2958a4;color:#fff}.navbar.is-link .navbar-start .navbar-link::after,.navbar.is-link .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-link .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-link .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-link .navbar-item.has-dropdown.is-active .navbar-link{background-color:#2958a4;color:#fff}.navbar.is-link .navbar-dropdown a.navbar-item.is-active{background-color:#2e63b8;color:#fff}}.navbar.is-info{background-color:#209cee;color:#fff}.navbar.is-info .navbar-brand>.navbar-item,.navbar.is-info .navbar-brand .navbar-link{color:#fff}.navbar.is-info .navbar-brand>a.navbar-item:focus,.navbar.is-info .navbar-brand>a.navbar-item:hover,.navbar.is-info .navbar-brand>a.navbar-item.is-active,.navbar.is-info .navbar-brand .navbar-link:focus,.navbar.is-info .navbar-brand .navbar-link:hover,.navbar.is-info .navbar-brand .navbar-link.is-active{background-color:#1190e3;color:#fff}.navbar.is-info .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-info .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-info .navbar-start>.navbar-item,.navbar.is-info .navbar-start .navbar-link,.navbar.is-info .navbar-end>.navbar-item,.navbar.is-info .navbar-end .navbar-link{color:#fff}.navbar.is-info .navbar-start>a.navbar-item:focus,.navbar.is-info .navbar-start>a.navbar-item:hover,.navbar.is-info .navbar-start>a.navbar-item.is-active,.navbar.is-info .navbar-start .navbar-link:focus,.navbar.is-info .navbar-start .navbar-link:hover,.navbar.is-info .navbar-start .navbar-link.is-active,.navbar.is-info .navbar-end>a.navbar-item:focus,.navbar.is-info .navbar-end>a.navbar-item:hover,.navbar.is-info .navbar-end>a.navbar-item.is-active,.navbar.is-info .navbar-end .navbar-link:focus,.navbar.is-info .navbar-end .navbar-link:hover,.navbar.is-info .navbar-end .navbar-link.is-active{background-color:#1190e3;color:#fff}.navbar.is-info .navbar-start .navbar-link::after,.navbar.is-info .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-info .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-info .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-info .navbar-item.has-dropdown.is-active .navbar-link{background-color:#1190e3;color:#fff}.navbar.is-info .navbar-dropdown a.navbar-item.is-active{background-color:#209cee;color:#fff}}.navbar.is-success{background-color:#22c35b;color:#fff}.navbar.is-success .navbar-brand>.navbar-item,.navbar.is-success .navbar-brand .navbar-link{color:#fff}.navbar.is-success .navbar-brand>a.navbar-item:focus,.navbar.is-success .navbar-brand>a.navbar-item:hover,.navbar.is-success .navbar-brand>a.navbar-item.is-active,.navbar.is-success .navbar-brand .navbar-link:focus,.navbar.is-success .navbar-brand .navbar-link:hover,.navbar.is-success .navbar-brand .navbar-link.is-active{background-color:#1ead51;color:#fff}.navbar.is-success .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-success .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-success .navbar-start>.navbar-item,.navbar.is-success .navbar-start .navbar-link,.navbar.is-success .navbar-end>.navbar-item,.navbar.is-success .navbar-end .navbar-link{color:#fff}.navbar.is-success .navbar-start>a.navbar-item:focus,.navbar.is-success .navbar-start>a.navbar-item:hover,.navbar.is-success .navbar-start>a.navbar-item.is-active,.navbar.is-success .navbar-start .navbar-link:focus,.navbar.is-success .navbar-start .navbar-link:hover,.navbar.is-success .navbar-start .navbar-link.is-active,.navbar.is-success .navbar-end>a.navbar-item:focus,.navbar.is-success .navbar-end>a.navbar-item:hover,.navbar.is-success .navbar-end>a.navbar-item.is-active,.navbar.is-success .navbar-end .navbar-link:focus,.navbar.is-success .navbar-end .navbar-link:hover,.navbar.is-success .navbar-end .navbar-link.is-active{background-color:#1ead51;color:#fff}.navbar.is-success .navbar-start .navbar-link::after,.navbar.is-success .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-success .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-success .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-success .navbar-item.has-dropdown.is-active .navbar-link{background-color:#1ead51;color:#fff}.navbar.is-success .navbar-dropdown a.navbar-item.is-active{background-color:#22c35b;color:#fff}}.navbar.is-warning{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-brand>.navbar-item,.navbar.is-warning .navbar-brand .navbar-link{color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-brand>a.navbar-item:focus,.navbar.is-warning .navbar-brand>a.navbar-item:hover,.navbar.is-warning .navbar-brand>a.navbar-item.is-active,.navbar.is-warning .navbar-brand .navbar-link:focus,.navbar.is-warning .navbar-brand .navbar-link:hover,.navbar.is-warning .navbar-brand .navbar-link.is-active{background-color:#ffd83e;color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-brand .navbar-link::after{border-color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-burger{color:rgba(0,0,0,0.7)}@media screen and (min-width: 1056px){.navbar.is-warning .navbar-start>.navbar-item,.navbar.is-warning .navbar-start .navbar-link,.navbar.is-warning .navbar-end>.navbar-item,.navbar.is-warning .navbar-end .navbar-link{color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-start>a.navbar-item:focus,.navbar.is-warning .navbar-start>a.navbar-item:hover,.navbar.is-warning .navbar-start>a.navbar-item.is-active,.navbar.is-warning .navbar-start .navbar-link:focus,.navbar.is-warning .navbar-start .navbar-link:hover,.navbar.is-warning .navbar-start .navbar-link.is-active,.navbar.is-warning .navbar-end>a.navbar-item:focus,.navbar.is-warning .navbar-end>a.navbar-item:hover,.navbar.is-warning .navbar-end>a.navbar-item.is-active,.navbar.is-warning .navbar-end .navbar-link:focus,.navbar.is-warning .navbar-end .navbar-link:hover,.navbar.is-warning .navbar-end .navbar-link.is-active{background-color:#ffd83e;color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-start .navbar-link::after,.navbar.is-warning .navbar-end .navbar-link::after{border-color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-warning .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-warning .navbar-item.has-dropdown.is-active .navbar-link{background-color:#ffd83e;color:rgba(0,0,0,0.7)}.navbar.is-warning .navbar-dropdown a.navbar-item.is-active{background-color:#ffdd57;color:rgba(0,0,0,0.7)}}.navbar.is-danger{background-color:#da0b00;color:#fff}.navbar.is-danger .navbar-brand>.navbar-item,.navbar.is-danger .navbar-brand .navbar-link{color:#fff}.navbar.is-danger .navbar-brand>a.navbar-item:focus,.navbar.is-danger .navbar-brand>a.navbar-item:hover,.navbar.is-danger .navbar-brand>a.navbar-item.is-active,.navbar.is-danger .navbar-brand .navbar-link:focus,.navbar.is-danger .navbar-brand .navbar-link:hover,.navbar.is-danger .navbar-brand .navbar-link.is-active{background-color:#c10a00;color:#fff}.navbar.is-danger .navbar-brand .navbar-link::after{border-color:#fff}.navbar.is-danger .navbar-burger{color:#fff}@media screen and (min-width: 1056px){.navbar.is-danger .navbar-start>.navbar-item,.navbar.is-danger .navbar-start .navbar-link,.navbar.is-danger .navbar-end>.navbar-item,.navbar.is-danger .navbar-end .navbar-link{color:#fff}.navbar.is-danger .navbar-start>a.navbar-item:focus,.navbar.is-danger .navbar-start>a.navbar-item:hover,.navbar.is-danger .navbar-start>a.navbar-item.is-active,.navbar.is-danger .navbar-start .navbar-link:focus,.navbar.is-danger .navbar-start .navbar-link:hover,.navbar.is-danger .navbar-start .navbar-link.is-active,.navbar.is-danger .navbar-end>a.navbar-item:focus,.navbar.is-danger .navbar-end>a.navbar-item:hover,.navbar.is-danger .navbar-end>a.navbar-item.is-active,.navbar.is-danger .navbar-end .navbar-link:focus,.navbar.is-danger .navbar-end .navbar-link:hover,.navbar.is-danger .navbar-end .navbar-link.is-active{background-color:#c10a00;color:#fff}.navbar.is-danger .navbar-start .navbar-link::after,.navbar.is-danger .navbar-end .navbar-link::after{border-color:#fff}.navbar.is-danger .navbar-item.has-dropdown:focus .navbar-link,.navbar.is-danger .navbar-item.has-dropdown:hover .navbar-link,.navbar.is-danger .navbar-item.has-dropdown.is-active .navbar-link{background-color:#c10a00;color:#fff}.navbar.is-danger .navbar-dropdown a.navbar-item.is-active{background-color:#da0b00;color:#fff}}.navbar>.container{align-items:stretch;display:flex;min-height:3.25rem;width:100%}.navbar.has-shadow{box-shadow:0 2px 0 0 #f5f5f5}.navbar.is-fixed-bottom,.navbar.is-fixed-top{left:0;position:fixed;right:0;z-index:30}.navbar.is-fixed-bottom{bottom:0}.navbar.is-fixed-bottom.has-shadow{box-shadow:0 -2px 0 0 #f5f5f5}.navbar.is-fixed-top{top:0}html.has-navbar-fixed-top,body.has-navbar-fixed-top{padding-top:3.25rem}html.has-navbar-fixed-bottom,body.has-navbar-fixed-bottom{padding-bottom:3.25rem}.navbar-brand,.navbar-tabs{align-items:stretch;display:flex;flex-shrink:0;min-height:3.25rem}.navbar-brand a.navbar-item:focus,.navbar-brand a.navbar-item:hover{background-color:transparent}.navbar-tabs{-webkit-overflow-scrolling:touch;max-width:100vw;overflow-x:auto;overflow-y:hidden}.navbar-burger{color:#222;-moz-appearance:none;-webkit-appearance:none;appearance:none;background:none;border:none;cursor:pointer;display:block;height:3.25rem;position:relative;width:3.25rem;margin-left:auto}.navbar-burger span{background-color:currentColor;display:block;height:1px;left:calc(50% - 8px);position:absolute;transform-origin:center;transition-duration:86ms;transition-property:background-color, opacity, transform;transition-timing-function:ease-out;width:16px}.navbar-burger span:nth-child(1){top:calc(50% - 6px)}.navbar-burger span:nth-child(2){top:calc(50% - 1px)}.navbar-burger span:nth-child(3){top:calc(50% + 4px)}.navbar-burger:hover{background-color:rgba(0,0,0,0.05)}.navbar-burger.is-active span:nth-child(1){transform:translateY(5px) rotate(45deg)}.navbar-burger.is-active span:nth-child(2){opacity:0}.navbar-burger.is-active span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}.navbar-menu{display:none}.navbar-item,.navbar-link{color:#222;display:block;line-height:1.5;padding:0.5rem 0.75rem;position:relative}.navbar-item .icon:only-child,.navbar-link .icon:only-child{margin-left:-0.25rem;margin-right:-0.25rem}a.navbar-item,.navbar-link{cursor:pointer}a.navbar-item:focus,a.navbar-item:focus-within,a.navbar-item:hover,a.navbar-item.is-active,.navbar-link:focus,.navbar-link:focus-within,.navbar-link:hover,.navbar-link.is-active{background-color:#fafafa;color:#2e63b8}.navbar-item{flex-grow:0;flex-shrink:0}.navbar-item img{max-height:1.75rem}.navbar-item.has-dropdown{padding:0}.navbar-item.is-expanded{flex-grow:1;flex-shrink:1}.navbar-item.is-tab{border-bottom:1px solid transparent;min-height:3.25rem;padding-bottom:calc(0.5rem - 1px)}.navbar-item.is-tab:focus,.navbar-item.is-tab:hover{background-color:rgba(0,0,0,0);border-bottom-color:#2e63b8}.navbar-item.is-tab.is-active{background-color:rgba(0,0,0,0);border-bottom-color:#2e63b8;border-bottom-style:solid;border-bottom-width:3px;color:#2e63b8;padding-bottom:calc(0.5rem - 3px)}.navbar-content{flex-grow:1;flex-shrink:1}.navbar-link:not(.is-arrowless){padding-right:2.5em}.navbar-link:not(.is-arrowless)::after{border-color:#2e63b8;margin-top:-0.375em;right:1.125em}.navbar-dropdown{font-size:0.875rem;padding-bottom:0.5rem;padding-top:0.5rem}.navbar-dropdown .navbar-item{padding-left:1.5rem;padding-right:1.5rem}.navbar-divider{background-color:#f5f5f5;border:none;display:none;height:2px;margin:0.5rem 0}@media screen and (max-width: 1055px){.navbar>.container{display:block}.navbar-brand .navbar-item,.navbar-tabs .navbar-item{align-items:center;display:flex}.navbar-link::after{display:none}.navbar-menu{background-color:#fff;box-shadow:0 8px 16px rgba(10,10,10,0.1);padding:0.5rem 0}.navbar-menu.is-active{display:block}.navbar.is-fixed-bottom-touch,.navbar.is-fixed-top-touch{left:0;position:fixed;right:0;z-index:30}.navbar.is-fixed-bottom-touch{bottom:0}.navbar.is-fixed-bottom-touch.has-shadow{box-shadow:0 -2px 3px rgba(10,10,10,0.1)}.navbar.is-fixed-top-touch{top:0}.navbar.is-fixed-top .navbar-menu,.navbar.is-fixed-top-touch .navbar-menu{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 3.25rem);overflow:auto}html.has-navbar-fixed-top-touch,body.has-navbar-fixed-top-touch{padding-top:3.25rem}html.has-navbar-fixed-bottom-touch,body.has-navbar-fixed-bottom-touch{padding-bottom:3.25rem}}@media screen and (min-width: 1056px){.navbar,.navbar-menu,.navbar-start,.navbar-end{align-items:stretch;display:flex}.navbar{min-height:3.25rem}.navbar.is-spaced{padding:1rem 2rem}.navbar.is-spaced .navbar-start,.navbar.is-spaced .navbar-end{align-items:center}.navbar.is-spaced a.navbar-item,.navbar.is-spaced .navbar-link{border-radius:4px}.navbar.is-transparent a.navbar-item:focus,.navbar.is-transparent a.navbar-item:hover,.navbar.is-transparent a.navbar-item.is-active,.navbar.is-transparent .navbar-link:focus,.navbar.is-transparent .navbar-link:hover,.navbar.is-transparent .navbar-link.is-active{background-color:transparent !important}.navbar.is-transparent .navbar-item.has-dropdown.is-active .navbar-link,.navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:focus .navbar-link,.navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:focus-within .navbar-link,.navbar.is-transparent .navbar-item.has-dropdown.is-hoverable:hover .navbar-link{background-color:transparent !important}.navbar.is-transparent .navbar-dropdown a.navbar-item:focus,.navbar.is-transparent .navbar-dropdown a.navbar-item:hover{background-color:#f5f5f5;color:#0a0a0a}.navbar.is-transparent .navbar-dropdown a.navbar-item.is-active{background-color:#f5f5f5;color:#2e63b8}.navbar-burger{display:none}.navbar-item,.navbar-link{align-items:center;display:flex}.navbar-item.has-dropdown{align-items:stretch}.navbar-item.has-dropdown-up .navbar-link::after{transform:rotate(135deg) translate(0.25em, -0.25em)}.navbar-item.has-dropdown-up .navbar-dropdown{border-bottom:2px solid #dbdbdb;border-radius:6px 6px 0 0;border-top:none;bottom:100%;box-shadow:0 -8px 8px rgba(10,10,10,0.1);top:auto}.navbar-item.is-active .navbar-dropdown,.navbar-item.is-hoverable:focus .navbar-dropdown,.navbar-item.is-hoverable:focus-within .navbar-dropdown,.navbar-item.is-hoverable:hover .navbar-dropdown{display:block}.navbar.is-spaced .navbar-item.is-active .navbar-dropdown,.navbar-item.is-active .navbar-dropdown.is-boxed,.navbar.is-spaced .navbar-item.is-hoverable:focus .navbar-dropdown,.navbar-item.is-hoverable:focus .navbar-dropdown.is-boxed,.navbar.is-spaced .navbar-item.is-hoverable:focus-within .navbar-dropdown,.navbar-item.is-hoverable:focus-within .navbar-dropdown.is-boxed,.navbar.is-spaced .navbar-item.is-hoverable:hover .navbar-dropdown,.navbar-item.is-hoverable:hover .navbar-dropdown.is-boxed{opacity:1;pointer-events:auto;transform:translateY(0)}.navbar-menu{flex-grow:1;flex-shrink:0}.navbar-start{justify-content:flex-start;margin-right:auto}.navbar-end{justify-content:flex-end;margin-left:auto}.navbar-dropdown{background-color:#fff;border-bottom-left-radius:6px;border-bottom-right-radius:6px;border-top:2px solid #dbdbdb;box-shadow:0 8px 8px rgba(10,10,10,0.1);display:none;font-size:0.875rem;left:0;min-width:100%;position:absolute;top:100%;z-index:20}.navbar-dropdown .navbar-item{padding:0.375rem 1rem;white-space:nowrap}.navbar-dropdown a.navbar-item{padding-right:3rem}.navbar-dropdown a.navbar-item:focus,.navbar-dropdown a.navbar-item:hover{background-color:#f5f5f5;color:#0a0a0a}.navbar-dropdown a.navbar-item.is-active{background-color:#f5f5f5;color:#2e63b8}.navbar.is-spaced .navbar-dropdown,.navbar-dropdown.is-boxed{border-radius:6px;border-top:none;box-shadow:0 8px 8px rgba(10,10,10,0.1), 0 0 0 1px rgba(10,10,10,0.1);display:block;opacity:0;pointer-events:none;top:calc(100% + (-4px));transform:translateY(-5px);transition-duration:86ms;transition-property:opacity, transform}.navbar-dropdown.is-right{left:auto;right:0}.navbar-divider{display:block}.navbar>.container .navbar-brand,.container>.navbar .navbar-brand{margin-left:-.75rem}.navbar>.container .navbar-menu,.container>.navbar .navbar-menu{margin-right:-.75rem}.navbar.is-fixed-bottom-desktop,.navbar.is-fixed-top-desktop{left:0;position:fixed;right:0;z-index:30}.navbar.is-fixed-bottom-desktop{bottom:0}.navbar.is-fixed-bottom-desktop.has-shadow{box-shadow:0 -2px 3px rgba(10,10,10,0.1)}.navbar.is-fixed-top-desktop{top:0}html.has-navbar-fixed-top-desktop,body.has-navbar-fixed-top-desktop{padding-top:3.25rem}html.has-navbar-fixed-bottom-desktop,body.has-navbar-fixed-bottom-desktop{padding-bottom:3.25rem}html.has-spaced-navbar-fixed-top,body.has-spaced-navbar-fixed-top{padding-top:5.25rem}html.has-spaced-navbar-fixed-bottom,body.has-spaced-navbar-fixed-bottom{padding-bottom:5.25rem}a.navbar-item.is-active,.navbar-link.is-active{color:#0a0a0a}a.navbar-item.is-active:not(:focus):not(:hover),.navbar-link.is-active:not(:focus):not(:hover){background-color:rgba(0,0,0,0)}.navbar-item.has-dropdown:focus .navbar-link,.navbar-item.has-dropdown:hover .navbar-link,.navbar-item.has-dropdown.is-active .navbar-link{background-color:#fafafa}}.hero.is-fullheight-with-navbar{min-height:calc(100vh - 3.25rem)}.pagination{font-size:1rem;margin:-.25rem}.pagination.is-small,#documenter .docs-sidebar form.docs-search>input.pagination{font-size:.75rem}.pagination.is-medium{font-size:1.25rem}.pagination.is-large{font-size:1.5rem}.pagination.is-rounded .pagination-previous,#documenter .docs-sidebar form.docs-search>input.pagination .pagination-previous,.pagination.is-rounded .pagination-next,#documenter .docs-sidebar form.docs-search>input.pagination .pagination-next{padding-left:1em;padding-right:1em;border-radius:9999px}.pagination.is-rounded .pagination-link,#documenter .docs-sidebar form.docs-search>input.pagination .pagination-link{border-radius:9999px}.pagination,.pagination-list{align-items:center;display:flex;justify-content:center;text-align:center}.pagination-previous,.pagination-next,.pagination-link,.pagination-ellipsis{font-size:1em;justify-content:center;margin:.25rem;padding-left:.5em;padding-right:.5em;text-align:center}.pagination-previous,.pagination-next,.pagination-link{border-color:#dbdbdb;color:#222;min-width:2.5em}.pagination-previous:hover,.pagination-next:hover,.pagination-link:hover{border-color:#b5b5b5;color:#363636}.pagination-previous:focus,.pagination-next:focus,.pagination-link:focus{border-color:#3c5dcd}.pagination-previous:active,.pagination-next:active,.pagination-link:active{box-shadow:inset 0 1px 2px rgba(10,10,10,0.2)}.pagination-previous[disabled],.pagination-previous.is-disabled,.pagination-next[disabled],.pagination-next.is-disabled,.pagination-link[disabled],.pagination-link.is-disabled{background-color:#dbdbdb;border-color:#dbdbdb;box-shadow:none;color:#6b6b6b;opacity:0.5}.pagination-previous,.pagination-next{padding-left:.75em;padding-right:.75em;white-space:nowrap}.pagination-link.is-current{background-color:#2e63b8;border-color:#2e63b8;color:#fff}.pagination-ellipsis{color:#b5b5b5;pointer-events:none}.pagination-list{flex-wrap:wrap}.pagination-list li{list-style:none}@media screen and (max-width: 768px){.pagination{flex-wrap:wrap}.pagination-previous,.pagination-next{flex-grow:1;flex-shrink:1}.pagination-list li{flex-grow:1;flex-shrink:1}}@media screen and (min-width: 769px),print{.pagination-list{flex-grow:1;flex-shrink:1;justify-content:flex-start;order:1}.pagination-previous,.pagination-next,.pagination-link,.pagination-ellipsis{margin-bottom:0;margin-top:0}.pagination-previous{order:2}.pagination-next{order:3}.pagination{justify-content:space-between;margin-bottom:0;margin-top:0}.pagination.is-centered .pagination-previous{order:1}.pagination.is-centered .pagination-list{justify-content:center;order:2}.pagination.is-centered .pagination-next{order:3}.pagination.is-right .pagination-previous{order:1}.pagination.is-right .pagination-next{order:2}.pagination.is-right .pagination-list{justify-content:flex-end;order:3}}.panel{border-radius:6px;box-shadow:#bbb;font-size:1rem}.panel:not(:last-child){margin-bottom:1.5rem}.panel.is-white .panel-heading{background-color:#fff;color:#0a0a0a}.panel.is-white .panel-tabs a.is-active{border-bottom-color:#fff}.panel.is-white .panel-block.is-active .panel-icon{color:#fff}.panel.is-black .panel-heading{background-color:#0a0a0a;color:#fff}.panel.is-black .panel-tabs a.is-active{border-bottom-color:#0a0a0a}.panel.is-black .panel-block.is-active .panel-icon{color:#0a0a0a}.panel.is-light .panel-heading{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.panel.is-light .panel-tabs a.is-active{border-bottom-color:#f5f5f5}.panel.is-light .panel-block.is-active .panel-icon{color:#f5f5f5}.panel.is-dark .panel-heading,.content kbd.panel .panel-heading{background-color:#363636;color:#fff}.panel.is-dark .panel-tabs a.is-active,.content kbd.panel .panel-tabs a.is-active{border-bottom-color:#363636}.panel.is-dark .panel-block.is-active .panel-icon,.content kbd.panel .panel-block.is-active .panel-icon{color:#363636}.panel.is-primary .panel-heading,.docstring>section>a.panel.docs-sourcelink .panel-heading{background-color:#4eb5de;color:#fff}.panel.is-primary .panel-tabs a.is-active,.docstring>section>a.panel.docs-sourcelink .panel-tabs a.is-active{border-bottom-color:#4eb5de}.panel.is-primary .panel-block.is-active .panel-icon,.docstring>section>a.panel.docs-sourcelink .panel-block.is-active .panel-icon{color:#4eb5de}.panel.is-link .panel-heading{background-color:#2e63b8;color:#fff}.panel.is-link .panel-tabs a.is-active{border-bottom-color:#2e63b8}.panel.is-link .panel-block.is-active .panel-icon{color:#2e63b8}.panel.is-info .panel-heading{background-color:#209cee;color:#fff}.panel.is-info .panel-tabs a.is-active{border-bottom-color:#209cee}.panel.is-info .panel-block.is-active .panel-icon{color:#209cee}.panel.is-success .panel-heading{background-color:#22c35b;color:#fff}.panel.is-success .panel-tabs a.is-active{border-bottom-color:#22c35b}.panel.is-success .panel-block.is-active .panel-icon{color:#22c35b}.panel.is-warning .panel-heading{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.panel.is-warning .panel-tabs a.is-active{border-bottom-color:#ffdd57}.panel.is-warning .panel-block.is-active .panel-icon{color:#ffdd57}.panel.is-danger .panel-heading{background-color:#da0b00;color:#fff}.panel.is-danger .panel-tabs a.is-active{border-bottom-color:#da0b00}.panel.is-danger .panel-block.is-active .panel-icon{color:#da0b00}.panel-tabs:not(:last-child),.panel-block:not(:last-child){border-bottom:1px solid #ededed}.panel-heading{background-color:#ededed;border-radius:6px 6px 0 0;color:#222;font-size:1.25em;font-weight:700;line-height:1.25;padding:0.75em 1em}.panel-tabs{align-items:flex-end;display:flex;font-size:.875em;justify-content:center}.panel-tabs a{border-bottom:1px solid #dbdbdb;margin-bottom:-1px;padding:0.5em}.panel-tabs a.is-active{border-bottom-color:#4a4a4a;color:#363636}.panel-list a{color:#222}.panel-list a:hover{color:#2e63b8}.panel-block{align-items:center;color:#222;display:flex;justify-content:flex-start;padding:0.5em 0.75em}.panel-block input[type="checkbox"]{margin-right:.75em}.panel-block>.control{flex-grow:1;flex-shrink:1;width:100%}.panel-block.is-wrapped{flex-wrap:wrap}.panel-block.is-active{border-left-color:#2e63b8;color:#363636}.panel-block.is-active .panel-icon{color:#2e63b8}.panel-block:last-child{border-bottom-left-radius:6px;border-bottom-right-radius:6px}a.panel-block,label.panel-block{cursor:pointer}a.panel-block:hover,label.panel-block:hover{background-color:#f5f5f5}.panel-icon{display:inline-block;font-size:14px;height:1em;line-height:1em;text-align:center;vertical-align:top;width:1em;color:#6b6b6b;margin-right:.75em}.panel-icon .fa{font-size:inherit;line-height:inherit}.tabs{-webkit-overflow-scrolling:touch;align-items:stretch;display:flex;font-size:1rem;justify-content:space-between;overflow:hidden;overflow-x:auto;white-space:nowrap}.tabs a{align-items:center;border-bottom-color:#dbdbdb;border-bottom-style:solid;border-bottom-width:1px;color:#222;display:flex;justify-content:center;margin-bottom:-1px;padding:0.5em 1em;vertical-align:top}.tabs a:hover{border-bottom-color:#222;color:#222}.tabs li{display:block}.tabs li.is-active a{border-bottom-color:#2e63b8;color:#2e63b8}.tabs ul{align-items:center;border-bottom-color:#dbdbdb;border-bottom-style:solid;border-bottom-width:1px;display:flex;flex-grow:1;flex-shrink:0;justify-content:flex-start}.tabs ul.is-left{padding-right:0.75em}.tabs ul.is-center{flex:none;justify-content:center;padding-left:0.75em;padding-right:0.75em}.tabs ul.is-right{justify-content:flex-end;padding-left:0.75em}.tabs .icon:first-child{margin-right:.5em}.tabs .icon:last-child{margin-left:.5em}.tabs.is-centered ul{justify-content:center}.tabs.is-right ul{justify-content:flex-end}.tabs.is-boxed a{border:1px solid transparent;border-radius:4px 4px 0 0}.tabs.is-boxed a:hover{background-color:#f5f5f5;border-bottom-color:#dbdbdb}.tabs.is-boxed li.is-active a{background-color:#fff;border-color:#dbdbdb;border-bottom-color:rgba(0,0,0,0) !important}.tabs.is-fullwidth li{flex-grow:1;flex-shrink:0}.tabs.is-toggle a{border-color:#dbdbdb;border-style:solid;border-width:1px;margin-bottom:0;position:relative}.tabs.is-toggle a:hover{background-color:#f5f5f5;border-color:#b5b5b5;z-index:2}.tabs.is-toggle li+li{margin-left:-1px}.tabs.is-toggle li:first-child a{border-top-left-radius:4px;border-bottom-left-radius:4px}.tabs.is-toggle li:last-child a{border-top-right-radius:4px;border-bottom-right-radius:4px}.tabs.is-toggle li.is-active a{background-color:#2e63b8;border-color:#2e63b8;color:#fff;z-index:1}.tabs.is-toggle ul{border-bottom:none}.tabs.is-toggle.is-toggle-rounded li:first-child a{border-bottom-left-radius:9999px;border-top-left-radius:9999px;padding-left:1.25em}.tabs.is-toggle.is-toggle-rounded li:last-child a{border-bottom-right-radius:9999px;border-top-right-radius:9999px;padding-right:1.25em}.tabs.is-small,#documenter .docs-sidebar form.docs-search>input.tabs{font-size:.75rem}.tabs.is-medium{font-size:1.25rem}.tabs.is-large{font-size:1.5rem}.column{display:block;flex-basis:0;flex-grow:1;flex-shrink:1;padding:.75rem}.columns.is-mobile>.column.is-narrow{flex:none;width:unset}.columns.is-mobile>.column.is-full{flex:none;width:100%}.columns.is-mobile>.column.is-three-quarters{flex:none;width:75%}.columns.is-mobile>.column.is-two-thirds{flex:none;width:66.6666%}.columns.is-mobile>.column.is-half{flex:none;width:50%}.columns.is-mobile>.column.is-one-third{flex:none;width:33.3333%}.columns.is-mobile>.column.is-one-quarter{flex:none;width:25%}.columns.is-mobile>.column.is-one-fifth{flex:none;width:20%}.columns.is-mobile>.column.is-two-fifths{flex:none;width:40%}.columns.is-mobile>.column.is-three-fifths{flex:none;width:60%}.columns.is-mobile>.column.is-four-fifths{flex:none;width:80%}.columns.is-mobile>.column.is-offset-three-quarters{margin-left:75%}.columns.is-mobile>.column.is-offset-two-thirds{margin-left:66.6666%}.columns.is-mobile>.column.is-offset-half{margin-left:50%}.columns.is-mobile>.column.is-offset-one-third{margin-left:33.3333%}.columns.is-mobile>.column.is-offset-one-quarter{margin-left:25%}.columns.is-mobile>.column.is-offset-one-fifth{margin-left:20%}.columns.is-mobile>.column.is-offset-two-fifths{margin-left:40%}.columns.is-mobile>.column.is-offset-three-fifths{margin-left:60%}.columns.is-mobile>.column.is-offset-four-fifths{margin-left:80%}.columns.is-mobile>.column.is-0{flex:none;width:0%}.columns.is-mobile>.column.is-offset-0{margin-left:0%}.columns.is-mobile>.column.is-1{flex:none;width:8.33333337%}.columns.is-mobile>.column.is-offset-1{margin-left:8.33333337%}.columns.is-mobile>.column.is-2{flex:none;width:16.66666674%}.columns.is-mobile>.column.is-offset-2{margin-left:16.66666674%}.columns.is-mobile>.column.is-3{flex:none;width:25%}.columns.is-mobile>.column.is-offset-3{margin-left:25%}.columns.is-mobile>.column.is-4{flex:none;width:33.33333337%}.columns.is-mobile>.column.is-offset-4{margin-left:33.33333337%}.columns.is-mobile>.column.is-5{flex:none;width:41.66666674%}.columns.is-mobile>.column.is-offset-5{margin-left:41.66666674%}.columns.is-mobile>.column.is-6{flex:none;width:50%}.columns.is-mobile>.column.is-offset-6{margin-left:50%}.columns.is-mobile>.column.is-7{flex:none;width:58.33333337%}.columns.is-mobile>.column.is-offset-7{margin-left:58.33333337%}.columns.is-mobile>.column.is-8{flex:none;width:66.66666674%}.columns.is-mobile>.column.is-offset-8{margin-left:66.66666674%}.columns.is-mobile>.column.is-9{flex:none;width:75%}.columns.is-mobile>.column.is-offset-9{margin-left:75%}.columns.is-mobile>.column.is-10{flex:none;width:83.33333337%}.columns.is-mobile>.column.is-offset-10{margin-left:83.33333337%}.columns.is-mobile>.column.is-11{flex:none;width:91.66666674%}.columns.is-mobile>.column.is-offset-11{margin-left:91.66666674%}.columns.is-mobile>.column.is-12{flex:none;width:100%}.columns.is-mobile>.column.is-offset-12{margin-left:100%}@media screen and (max-width: 768px){.column.is-narrow-mobile{flex:none;width:unset}.column.is-full-mobile{flex:none;width:100%}.column.is-three-quarters-mobile{flex:none;width:75%}.column.is-two-thirds-mobile{flex:none;width:66.6666%}.column.is-half-mobile{flex:none;width:50%}.column.is-one-third-mobile{flex:none;width:33.3333%}.column.is-one-quarter-mobile{flex:none;width:25%}.column.is-one-fifth-mobile{flex:none;width:20%}.column.is-two-fifths-mobile{flex:none;width:40%}.column.is-three-fifths-mobile{flex:none;width:60%}.column.is-four-fifths-mobile{flex:none;width:80%}.column.is-offset-three-quarters-mobile{margin-left:75%}.column.is-offset-two-thirds-mobile{margin-left:66.6666%}.column.is-offset-half-mobile{margin-left:50%}.column.is-offset-one-third-mobile{margin-left:33.3333%}.column.is-offset-one-quarter-mobile{margin-left:25%}.column.is-offset-one-fifth-mobile{margin-left:20%}.column.is-offset-two-fifths-mobile{margin-left:40%}.column.is-offset-three-fifths-mobile{margin-left:60%}.column.is-offset-four-fifths-mobile{margin-left:80%}.column.is-0-mobile{flex:none;width:0%}.column.is-offset-0-mobile{margin-left:0%}.column.is-1-mobile{flex:none;width:8.33333337%}.column.is-offset-1-mobile{margin-left:8.33333337%}.column.is-2-mobile{flex:none;width:16.66666674%}.column.is-offset-2-mobile{margin-left:16.66666674%}.column.is-3-mobile{flex:none;width:25%}.column.is-offset-3-mobile{margin-left:25%}.column.is-4-mobile{flex:none;width:33.33333337%}.column.is-offset-4-mobile{margin-left:33.33333337%}.column.is-5-mobile{flex:none;width:41.66666674%}.column.is-offset-5-mobile{margin-left:41.66666674%}.column.is-6-mobile{flex:none;width:50%}.column.is-offset-6-mobile{margin-left:50%}.column.is-7-mobile{flex:none;width:58.33333337%}.column.is-offset-7-mobile{margin-left:58.33333337%}.column.is-8-mobile{flex:none;width:66.66666674%}.column.is-offset-8-mobile{margin-left:66.66666674%}.column.is-9-mobile{flex:none;width:75%}.column.is-offset-9-mobile{margin-left:75%}.column.is-10-mobile{flex:none;width:83.33333337%}.column.is-offset-10-mobile{margin-left:83.33333337%}.column.is-11-mobile{flex:none;width:91.66666674%}.column.is-offset-11-mobile{margin-left:91.66666674%}.column.is-12-mobile{flex:none;width:100%}.column.is-offset-12-mobile{margin-left:100%}}@media screen and (min-width: 769px),print{.column.is-narrow,.column.is-narrow-tablet{flex:none;width:unset}.column.is-full,.column.is-full-tablet{flex:none;width:100%}.column.is-three-quarters,.column.is-three-quarters-tablet{flex:none;width:75%}.column.is-two-thirds,.column.is-two-thirds-tablet{flex:none;width:66.6666%}.column.is-half,.column.is-half-tablet{flex:none;width:50%}.column.is-one-third,.column.is-one-third-tablet{flex:none;width:33.3333%}.column.is-one-quarter,.column.is-one-quarter-tablet{flex:none;width:25%}.column.is-one-fifth,.column.is-one-fifth-tablet{flex:none;width:20%}.column.is-two-fifths,.column.is-two-fifths-tablet{flex:none;width:40%}.column.is-three-fifths,.column.is-three-fifths-tablet{flex:none;width:60%}.column.is-four-fifths,.column.is-four-fifths-tablet{flex:none;width:80%}.column.is-offset-three-quarters,.column.is-offset-three-quarters-tablet{margin-left:75%}.column.is-offset-two-thirds,.column.is-offset-two-thirds-tablet{margin-left:66.6666%}.column.is-offset-half,.column.is-offset-half-tablet{margin-left:50%}.column.is-offset-one-third,.column.is-offset-one-third-tablet{margin-left:33.3333%}.column.is-offset-one-quarter,.column.is-offset-one-quarter-tablet{margin-left:25%}.column.is-offset-one-fifth,.column.is-offset-one-fifth-tablet{margin-left:20%}.column.is-offset-two-fifths,.column.is-offset-two-fifths-tablet{margin-left:40%}.column.is-offset-three-fifths,.column.is-offset-three-fifths-tablet{margin-left:60%}.column.is-offset-four-fifths,.column.is-offset-four-fifths-tablet{margin-left:80%}.column.is-0,.column.is-0-tablet{flex:none;width:0%}.column.is-offset-0,.column.is-offset-0-tablet{margin-left:0%}.column.is-1,.column.is-1-tablet{flex:none;width:8.33333337%}.column.is-offset-1,.column.is-offset-1-tablet{margin-left:8.33333337%}.column.is-2,.column.is-2-tablet{flex:none;width:16.66666674%}.column.is-offset-2,.column.is-offset-2-tablet{margin-left:16.66666674%}.column.is-3,.column.is-3-tablet{flex:none;width:25%}.column.is-offset-3,.column.is-offset-3-tablet{margin-left:25%}.column.is-4,.column.is-4-tablet{flex:none;width:33.33333337%}.column.is-offset-4,.column.is-offset-4-tablet{margin-left:33.33333337%}.column.is-5,.column.is-5-tablet{flex:none;width:41.66666674%}.column.is-offset-5,.column.is-offset-5-tablet{margin-left:41.66666674%}.column.is-6,.column.is-6-tablet{flex:none;width:50%}.column.is-offset-6,.column.is-offset-6-tablet{margin-left:50%}.column.is-7,.column.is-7-tablet{flex:none;width:58.33333337%}.column.is-offset-7,.column.is-offset-7-tablet{margin-left:58.33333337%}.column.is-8,.column.is-8-tablet{flex:none;width:66.66666674%}.column.is-offset-8,.column.is-offset-8-tablet{margin-left:66.66666674%}.column.is-9,.column.is-9-tablet{flex:none;width:75%}.column.is-offset-9,.column.is-offset-9-tablet{margin-left:75%}.column.is-10,.column.is-10-tablet{flex:none;width:83.33333337%}.column.is-offset-10,.column.is-offset-10-tablet{margin-left:83.33333337%}.column.is-11,.column.is-11-tablet{flex:none;width:91.66666674%}.column.is-offset-11,.column.is-offset-11-tablet{margin-left:91.66666674%}.column.is-12,.column.is-12-tablet{flex:none;width:100%}.column.is-offset-12,.column.is-offset-12-tablet{margin-left:100%}}@media screen and (max-width: 1055px){.column.is-narrow-touch{flex:none;width:unset}.column.is-full-touch{flex:none;width:100%}.column.is-three-quarters-touch{flex:none;width:75%}.column.is-two-thirds-touch{flex:none;width:66.6666%}.column.is-half-touch{flex:none;width:50%}.column.is-one-third-touch{flex:none;width:33.3333%}.column.is-one-quarter-touch{flex:none;width:25%}.column.is-one-fifth-touch{flex:none;width:20%}.column.is-two-fifths-touch{flex:none;width:40%}.column.is-three-fifths-touch{flex:none;width:60%}.column.is-four-fifths-touch{flex:none;width:80%}.column.is-offset-three-quarters-touch{margin-left:75%}.column.is-offset-two-thirds-touch{margin-left:66.6666%}.column.is-offset-half-touch{margin-left:50%}.column.is-offset-one-third-touch{margin-left:33.3333%}.column.is-offset-one-quarter-touch{margin-left:25%}.column.is-offset-one-fifth-touch{margin-left:20%}.column.is-offset-two-fifths-touch{margin-left:40%}.column.is-offset-three-fifths-touch{margin-left:60%}.column.is-offset-four-fifths-touch{margin-left:80%}.column.is-0-touch{flex:none;width:0%}.column.is-offset-0-touch{margin-left:0%}.column.is-1-touch{flex:none;width:8.33333337%}.column.is-offset-1-touch{margin-left:8.33333337%}.column.is-2-touch{flex:none;width:16.66666674%}.column.is-offset-2-touch{margin-left:16.66666674%}.column.is-3-touch{flex:none;width:25%}.column.is-offset-3-touch{margin-left:25%}.column.is-4-touch{flex:none;width:33.33333337%}.column.is-offset-4-touch{margin-left:33.33333337%}.column.is-5-touch{flex:none;width:41.66666674%}.column.is-offset-5-touch{margin-left:41.66666674%}.column.is-6-touch{flex:none;width:50%}.column.is-offset-6-touch{margin-left:50%}.column.is-7-touch{flex:none;width:58.33333337%}.column.is-offset-7-touch{margin-left:58.33333337%}.column.is-8-touch{flex:none;width:66.66666674%}.column.is-offset-8-touch{margin-left:66.66666674%}.column.is-9-touch{flex:none;width:75%}.column.is-offset-9-touch{margin-left:75%}.column.is-10-touch{flex:none;width:83.33333337%}.column.is-offset-10-touch{margin-left:83.33333337%}.column.is-11-touch{flex:none;width:91.66666674%}.column.is-offset-11-touch{margin-left:91.66666674%}.column.is-12-touch{flex:none;width:100%}.column.is-offset-12-touch{margin-left:100%}}@media screen and (min-width: 1056px){.column.is-narrow-desktop{flex:none;width:unset}.column.is-full-desktop{flex:none;width:100%}.column.is-three-quarters-desktop{flex:none;width:75%}.column.is-two-thirds-desktop{flex:none;width:66.6666%}.column.is-half-desktop{flex:none;width:50%}.column.is-one-third-desktop{flex:none;width:33.3333%}.column.is-one-quarter-desktop{flex:none;width:25%}.column.is-one-fifth-desktop{flex:none;width:20%}.column.is-two-fifths-desktop{flex:none;width:40%}.column.is-three-fifths-desktop{flex:none;width:60%}.column.is-four-fifths-desktop{flex:none;width:80%}.column.is-offset-three-quarters-desktop{margin-left:75%}.column.is-offset-two-thirds-desktop{margin-left:66.6666%}.column.is-offset-half-desktop{margin-left:50%}.column.is-offset-one-third-desktop{margin-left:33.3333%}.column.is-offset-one-quarter-desktop{margin-left:25%}.column.is-offset-one-fifth-desktop{margin-left:20%}.column.is-offset-two-fifths-desktop{margin-left:40%}.column.is-offset-three-fifths-desktop{margin-left:60%}.column.is-offset-four-fifths-desktop{margin-left:80%}.column.is-0-desktop{flex:none;width:0%}.column.is-offset-0-desktop{margin-left:0%}.column.is-1-desktop{flex:none;width:8.33333337%}.column.is-offset-1-desktop{margin-left:8.33333337%}.column.is-2-desktop{flex:none;width:16.66666674%}.column.is-offset-2-desktop{margin-left:16.66666674%}.column.is-3-desktop{flex:none;width:25%}.column.is-offset-3-desktop{margin-left:25%}.column.is-4-desktop{flex:none;width:33.33333337%}.column.is-offset-4-desktop{margin-left:33.33333337%}.column.is-5-desktop{flex:none;width:41.66666674%}.column.is-offset-5-desktop{margin-left:41.66666674%}.column.is-6-desktop{flex:none;width:50%}.column.is-offset-6-desktop{margin-left:50%}.column.is-7-desktop{flex:none;width:58.33333337%}.column.is-offset-7-desktop{margin-left:58.33333337%}.column.is-8-desktop{flex:none;width:66.66666674%}.column.is-offset-8-desktop{margin-left:66.66666674%}.column.is-9-desktop{flex:none;width:75%}.column.is-offset-9-desktop{margin-left:75%}.column.is-10-desktop{flex:none;width:83.33333337%}.column.is-offset-10-desktop{margin-left:83.33333337%}.column.is-11-desktop{flex:none;width:91.66666674%}.column.is-offset-11-desktop{margin-left:91.66666674%}.column.is-12-desktop{flex:none;width:100%}.column.is-offset-12-desktop{margin-left:100%}}@media screen and (min-width: 1216px){.column.is-narrow-widescreen{flex:none;width:unset}.column.is-full-widescreen{flex:none;width:100%}.column.is-three-quarters-widescreen{flex:none;width:75%}.column.is-two-thirds-widescreen{flex:none;width:66.6666%}.column.is-half-widescreen{flex:none;width:50%}.column.is-one-third-widescreen{flex:none;width:33.3333%}.column.is-one-quarter-widescreen{flex:none;width:25%}.column.is-one-fifth-widescreen{flex:none;width:20%}.column.is-two-fifths-widescreen{flex:none;width:40%}.column.is-three-fifths-widescreen{flex:none;width:60%}.column.is-four-fifths-widescreen{flex:none;width:80%}.column.is-offset-three-quarters-widescreen{margin-left:75%}.column.is-offset-two-thirds-widescreen{margin-left:66.6666%}.column.is-offset-half-widescreen{margin-left:50%}.column.is-offset-one-third-widescreen{margin-left:33.3333%}.column.is-offset-one-quarter-widescreen{margin-left:25%}.column.is-offset-one-fifth-widescreen{margin-left:20%}.column.is-offset-two-fifths-widescreen{margin-left:40%}.column.is-offset-three-fifths-widescreen{margin-left:60%}.column.is-offset-four-fifths-widescreen{margin-left:80%}.column.is-0-widescreen{flex:none;width:0%}.column.is-offset-0-widescreen{margin-left:0%}.column.is-1-widescreen{flex:none;width:8.33333337%}.column.is-offset-1-widescreen{margin-left:8.33333337%}.column.is-2-widescreen{flex:none;width:16.66666674%}.column.is-offset-2-widescreen{margin-left:16.66666674%}.column.is-3-widescreen{flex:none;width:25%}.column.is-offset-3-widescreen{margin-left:25%}.column.is-4-widescreen{flex:none;width:33.33333337%}.column.is-offset-4-widescreen{margin-left:33.33333337%}.column.is-5-widescreen{flex:none;width:41.66666674%}.column.is-offset-5-widescreen{margin-left:41.66666674%}.column.is-6-widescreen{flex:none;width:50%}.column.is-offset-6-widescreen{margin-left:50%}.column.is-7-widescreen{flex:none;width:58.33333337%}.column.is-offset-7-widescreen{margin-left:58.33333337%}.column.is-8-widescreen{flex:none;width:66.66666674%}.column.is-offset-8-widescreen{margin-left:66.66666674%}.column.is-9-widescreen{flex:none;width:75%}.column.is-offset-9-widescreen{margin-left:75%}.column.is-10-widescreen{flex:none;width:83.33333337%}.column.is-offset-10-widescreen{margin-left:83.33333337%}.column.is-11-widescreen{flex:none;width:91.66666674%}.column.is-offset-11-widescreen{margin-left:91.66666674%}.column.is-12-widescreen{flex:none;width:100%}.column.is-offset-12-widescreen{margin-left:100%}}@media screen and (min-width: 1408px){.column.is-narrow-fullhd{flex:none;width:unset}.column.is-full-fullhd{flex:none;width:100%}.column.is-three-quarters-fullhd{flex:none;width:75%}.column.is-two-thirds-fullhd{flex:none;width:66.6666%}.column.is-half-fullhd{flex:none;width:50%}.column.is-one-third-fullhd{flex:none;width:33.3333%}.column.is-one-quarter-fullhd{flex:none;width:25%}.column.is-one-fifth-fullhd{flex:none;width:20%}.column.is-two-fifths-fullhd{flex:none;width:40%}.column.is-three-fifths-fullhd{flex:none;width:60%}.column.is-four-fifths-fullhd{flex:none;width:80%}.column.is-offset-three-quarters-fullhd{margin-left:75%}.column.is-offset-two-thirds-fullhd{margin-left:66.6666%}.column.is-offset-half-fullhd{margin-left:50%}.column.is-offset-one-third-fullhd{margin-left:33.3333%}.column.is-offset-one-quarter-fullhd{margin-left:25%}.column.is-offset-one-fifth-fullhd{margin-left:20%}.column.is-offset-two-fifths-fullhd{margin-left:40%}.column.is-offset-three-fifths-fullhd{margin-left:60%}.column.is-offset-four-fifths-fullhd{margin-left:80%}.column.is-0-fullhd{flex:none;width:0%}.column.is-offset-0-fullhd{margin-left:0%}.column.is-1-fullhd{flex:none;width:8.33333337%}.column.is-offset-1-fullhd{margin-left:8.33333337%}.column.is-2-fullhd{flex:none;width:16.66666674%}.column.is-offset-2-fullhd{margin-left:16.66666674%}.column.is-3-fullhd{flex:none;width:25%}.column.is-offset-3-fullhd{margin-left:25%}.column.is-4-fullhd{flex:none;width:33.33333337%}.column.is-offset-4-fullhd{margin-left:33.33333337%}.column.is-5-fullhd{flex:none;width:41.66666674%}.column.is-offset-5-fullhd{margin-left:41.66666674%}.column.is-6-fullhd{flex:none;width:50%}.column.is-offset-6-fullhd{margin-left:50%}.column.is-7-fullhd{flex:none;width:58.33333337%}.column.is-offset-7-fullhd{margin-left:58.33333337%}.column.is-8-fullhd{flex:none;width:66.66666674%}.column.is-offset-8-fullhd{margin-left:66.66666674%}.column.is-9-fullhd{flex:none;width:75%}.column.is-offset-9-fullhd{margin-left:75%}.column.is-10-fullhd{flex:none;width:83.33333337%}.column.is-offset-10-fullhd{margin-left:83.33333337%}.column.is-11-fullhd{flex:none;width:91.66666674%}.column.is-offset-11-fullhd{margin-left:91.66666674%}.column.is-12-fullhd{flex:none;width:100%}.column.is-offset-12-fullhd{margin-left:100%}}.columns{margin-left:-.75rem;margin-right:-.75rem;margin-top:-.75rem}.columns:last-child{margin-bottom:-.75rem}.columns:not(:last-child){margin-bottom:calc(1.5rem - .75rem)}.columns.is-centered{justify-content:center}.columns.is-gapless{margin-left:0;margin-right:0;margin-top:0}.columns.is-gapless>.column{margin:0;padding:0 !important}.columns.is-gapless:not(:last-child){margin-bottom:1.5rem}.columns.is-gapless:last-child{margin-bottom:0}.columns.is-mobile{display:flex}.columns.is-multiline{flex-wrap:wrap}.columns.is-vcentered{align-items:center}@media screen and (min-width: 769px),print{.columns:not(.is-desktop){display:flex}}@media screen and (min-width: 1056px){.columns.is-desktop{display:flex}}.columns.is-variable{--columnGap: 0.75rem;margin-left:calc(-1 * var(--columnGap));margin-right:calc(-1 * var(--columnGap))}.columns.is-variable>.column{padding-left:var(--columnGap);padding-right:var(--columnGap)}.columns.is-variable.is-0{--columnGap: 0rem}@media screen and (max-width: 768px){.columns.is-variable.is-0-mobile{--columnGap: 0rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-0-tablet{--columnGap: 0rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-0-tablet-only{--columnGap: 0rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-0-touch{--columnGap: 0rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-0-desktop{--columnGap: 0rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-0-desktop-only{--columnGap: 0rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-0-widescreen{--columnGap: 0rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-0-widescreen-only{--columnGap: 0rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-0-fullhd{--columnGap: 0rem}}.columns.is-variable.is-1{--columnGap: .25rem}@media screen and (max-width: 768px){.columns.is-variable.is-1-mobile{--columnGap: .25rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-1-tablet{--columnGap: .25rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-1-tablet-only{--columnGap: .25rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-1-touch{--columnGap: .25rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-1-desktop{--columnGap: .25rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-1-desktop-only{--columnGap: .25rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-1-widescreen{--columnGap: .25rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-1-widescreen-only{--columnGap: .25rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-1-fullhd{--columnGap: .25rem}}.columns.is-variable.is-2{--columnGap: .5rem}@media screen and (max-width: 768px){.columns.is-variable.is-2-mobile{--columnGap: .5rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-2-tablet{--columnGap: .5rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-2-tablet-only{--columnGap: .5rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-2-touch{--columnGap: .5rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-2-desktop{--columnGap: .5rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-2-desktop-only{--columnGap: .5rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-2-widescreen{--columnGap: .5rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-2-widescreen-only{--columnGap: .5rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-2-fullhd{--columnGap: .5rem}}.columns.is-variable.is-3{--columnGap: .75rem}@media screen and (max-width: 768px){.columns.is-variable.is-3-mobile{--columnGap: .75rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-3-tablet{--columnGap: .75rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-3-tablet-only{--columnGap: .75rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-3-touch{--columnGap: .75rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-3-desktop{--columnGap: .75rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-3-desktop-only{--columnGap: .75rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-3-widescreen{--columnGap: .75rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-3-widescreen-only{--columnGap: .75rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-3-fullhd{--columnGap: .75rem}}.columns.is-variable.is-4{--columnGap: 1rem}@media screen and (max-width: 768px){.columns.is-variable.is-4-mobile{--columnGap: 1rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-4-tablet{--columnGap: 1rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-4-tablet-only{--columnGap: 1rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-4-touch{--columnGap: 1rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-4-desktop{--columnGap: 1rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-4-desktop-only{--columnGap: 1rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-4-widescreen{--columnGap: 1rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-4-widescreen-only{--columnGap: 1rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-4-fullhd{--columnGap: 1rem}}.columns.is-variable.is-5{--columnGap: 1.25rem}@media screen and (max-width: 768px){.columns.is-variable.is-5-mobile{--columnGap: 1.25rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-5-tablet{--columnGap: 1.25rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-5-tablet-only{--columnGap: 1.25rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-5-touch{--columnGap: 1.25rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-5-desktop{--columnGap: 1.25rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-5-desktop-only{--columnGap: 1.25rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-5-widescreen{--columnGap: 1.25rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-5-widescreen-only{--columnGap: 1.25rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-5-fullhd{--columnGap: 1.25rem}}.columns.is-variable.is-6{--columnGap: 1.5rem}@media screen and (max-width: 768px){.columns.is-variable.is-6-mobile{--columnGap: 1.5rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-6-tablet{--columnGap: 1.5rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-6-tablet-only{--columnGap: 1.5rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-6-touch{--columnGap: 1.5rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-6-desktop{--columnGap: 1.5rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-6-desktop-only{--columnGap: 1.5rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-6-widescreen{--columnGap: 1.5rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-6-widescreen-only{--columnGap: 1.5rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-6-fullhd{--columnGap: 1.5rem}}.columns.is-variable.is-7{--columnGap: 1.75rem}@media screen and (max-width: 768px){.columns.is-variable.is-7-mobile{--columnGap: 1.75rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-7-tablet{--columnGap: 1.75rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-7-tablet-only{--columnGap: 1.75rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-7-touch{--columnGap: 1.75rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-7-desktop{--columnGap: 1.75rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-7-desktop-only{--columnGap: 1.75rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-7-widescreen{--columnGap: 1.75rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-7-widescreen-only{--columnGap: 1.75rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-7-fullhd{--columnGap: 1.75rem}}.columns.is-variable.is-8{--columnGap: 2rem}@media screen and (max-width: 768px){.columns.is-variable.is-8-mobile{--columnGap: 2rem}}@media screen and (min-width: 769px),print{.columns.is-variable.is-8-tablet{--columnGap: 2rem}}@media screen and (min-width: 769px) and (max-width: 1055px){.columns.is-variable.is-8-tablet-only{--columnGap: 2rem}}@media screen and (max-width: 1055px){.columns.is-variable.is-8-touch{--columnGap: 2rem}}@media screen and (min-width: 1056px){.columns.is-variable.is-8-desktop{--columnGap: 2rem}}@media screen and (min-width: 1056px) and (max-width: 1215px){.columns.is-variable.is-8-desktop-only{--columnGap: 2rem}}@media screen and (min-width: 1216px){.columns.is-variable.is-8-widescreen{--columnGap: 2rem}}@media screen and (min-width: 1216px) and (max-width: 1407px){.columns.is-variable.is-8-widescreen-only{--columnGap: 2rem}}@media screen and (min-width: 1408px){.columns.is-variable.is-8-fullhd{--columnGap: 2rem}}.tile{align-items:stretch;display:block;flex-basis:0;flex-grow:1;flex-shrink:1;min-height:min-content}.tile.is-ancestor{margin-left:-.75rem;margin-right:-.75rem;margin-top:-.75rem}.tile.is-ancestor:last-child{margin-bottom:-.75rem}.tile.is-ancestor:not(:last-child){margin-bottom:.75rem}.tile.is-child{margin:0 !important}.tile.is-parent{padding:.75rem}.tile.is-vertical{flex-direction:column}.tile.is-vertical>.tile.is-child:not(:last-child){margin-bottom:1.5rem !important}@media screen and (min-width: 769px),print{.tile:not(.is-child){display:flex}.tile.is-1{flex:none;width:8.33333337%}.tile.is-2{flex:none;width:16.66666674%}.tile.is-3{flex:none;width:25%}.tile.is-4{flex:none;width:33.33333337%}.tile.is-5{flex:none;width:41.66666674%}.tile.is-6{flex:none;width:50%}.tile.is-7{flex:none;width:58.33333337%}.tile.is-8{flex:none;width:66.66666674%}.tile.is-9{flex:none;width:75%}.tile.is-10{flex:none;width:83.33333337%}.tile.is-11{flex:none;width:91.66666674%}.tile.is-12{flex:none;width:100%}}.hero{align-items:stretch;display:flex;flex-direction:column;justify-content:space-between}.hero .navbar{background:none}.hero .tabs ul{border-bottom:none}.hero.is-white{background-color:#fff;color:#0a0a0a}.hero.is-white a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-white strong{color:inherit}.hero.is-white .title{color:#0a0a0a}.hero.is-white .subtitle{color:rgba(10,10,10,0.9)}.hero.is-white .subtitle a:not(.button),.hero.is-white .subtitle strong{color:#0a0a0a}@media screen and (max-width: 1055px){.hero.is-white .navbar-menu{background-color:#fff}}.hero.is-white .navbar-item,.hero.is-white .navbar-link{color:rgba(10,10,10,0.7)}.hero.is-white a.navbar-item:hover,.hero.is-white a.navbar-item.is-active,.hero.is-white .navbar-link:hover,.hero.is-white .navbar-link.is-active{background-color:#f2f2f2;color:#0a0a0a}.hero.is-white .tabs a{color:#0a0a0a;opacity:0.9}.hero.is-white .tabs a:hover{opacity:1}.hero.is-white .tabs li.is-active a{color:#fff !important;opacity:1}.hero.is-white .tabs.is-boxed a,.hero.is-white .tabs.is-toggle a{color:#0a0a0a}.hero.is-white .tabs.is-boxed a:hover,.hero.is-white .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-white .tabs.is-boxed li.is-active a,.hero.is-white .tabs.is-boxed li.is-active a:hover,.hero.is-white .tabs.is-toggle li.is-active a,.hero.is-white .tabs.is-toggle li.is-active a:hover{background-color:#0a0a0a;border-color:#0a0a0a;color:#fff}.hero.is-white.is-bold{background-image:linear-gradient(141deg, #e8e3e4 0%, #fff 71%, #fff 100%)}@media screen and (max-width: 768px){.hero.is-white.is-bold .navbar-menu{background-image:linear-gradient(141deg, #e8e3e4 0%, #fff 71%, #fff 100%)}}.hero.is-black{background-color:#0a0a0a;color:#fff}.hero.is-black a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-black strong{color:inherit}.hero.is-black .title{color:#fff}.hero.is-black .subtitle{color:rgba(255,255,255,0.9)}.hero.is-black .subtitle a:not(.button),.hero.is-black .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-black .navbar-menu{background-color:#0a0a0a}}.hero.is-black .navbar-item,.hero.is-black .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-black a.navbar-item:hover,.hero.is-black a.navbar-item.is-active,.hero.is-black .navbar-link:hover,.hero.is-black .navbar-link.is-active{background-color:#000;color:#fff}.hero.is-black .tabs a{color:#fff;opacity:0.9}.hero.is-black .tabs a:hover{opacity:1}.hero.is-black .tabs li.is-active a{color:#0a0a0a !important;opacity:1}.hero.is-black .tabs.is-boxed a,.hero.is-black .tabs.is-toggle a{color:#fff}.hero.is-black .tabs.is-boxed a:hover,.hero.is-black .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-black .tabs.is-boxed li.is-active a,.hero.is-black .tabs.is-boxed li.is-active a:hover,.hero.is-black .tabs.is-toggle li.is-active a,.hero.is-black .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#0a0a0a}.hero.is-black.is-bold{background-image:linear-gradient(141deg, #000 0%, #0a0a0a 71%, #181616 100%)}@media screen and (max-width: 768px){.hero.is-black.is-bold .navbar-menu{background-image:linear-gradient(141deg, #000 0%, #0a0a0a 71%, #181616 100%)}}.hero.is-light{background-color:#f5f5f5;color:rgba(0,0,0,0.7)}.hero.is-light a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-light strong{color:inherit}.hero.is-light .title{color:rgba(0,0,0,0.7)}.hero.is-light .subtitle{color:rgba(0,0,0,0.9)}.hero.is-light .subtitle a:not(.button),.hero.is-light .subtitle strong{color:rgba(0,0,0,0.7)}@media screen and (max-width: 1055px){.hero.is-light .navbar-menu{background-color:#f5f5f5}}.hero.is-light .navbar-item,.hero.is-light .navbar-link{color:rgba(0,0,0,0.7)}.hero.is-light a.navbar-item:hover,.hero.is-light a.navbar-item.is-active,.hero.is-light .navbar-link:hover,.hero.is-light .navbar-link.is-active{background-color:#e8e8e8;color:rgba(0,0,0,0.7)}.hero.is-light .tabs a{color:rgba(0,0,0,0.7);opacity:0.9}.hero.is-light .tabs a:hover{opacity:1}.hero.is-light .tabs li.is-active a{color:#f5f5f5 !important;opacity:1}.hero.is-light .tabs.is-boxed a,.hero.is-light .tabs.is-toggle a{color:rgba(0,0,0,0.7)}.hero.is-light .tabs.is-boxed a:hover,.hero.is-light .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-light .tabs.is-boxed li.is-active a,.hero.is-light .tabs.is-boxed li.is-active a:hover,.hero.is-light .tabs.is-toggle li.is-active a,.hero.is-light .tabs.is-toggle li.is-active a:hover{background-color:rgba(0,0,0,0.7);border-color:rgba(0,0,0,0.7);color:#f5f5f5}.hero.is-light.is-bold{background-image:linear-gradient(141deg, #dfd8d9 0%, #f5f5f5 71%, #fff 100%)}@media screen and (max-width: 768px){.hero.is-light.is-bold .navbar-menu{background-image:linear-gradient(141deg, #dfd8d9 0%, #f5f5f5 71%, #fff 100%)}}.hero.is-dark,.content kbd.hero{background-color:#363636;color:#fff}.hero.is-dark a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.content kbd.hero a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-dark strong,.content kbd.hero strong{color:inherit}.hero.is-dark .title,.content kbd.hero .title{color:#fff}.hero.is-dark .subtitle,.content kbd.hero .subtitle{color:rgba(255,255,255,0.9)}.hero.is-dark .subtitle a:not(.button),.content kbd.hero .subtitle a:not(.button),.hero.is-dark .subtitle strong,.content kbd.hero .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-dark .navbar-menu,.content kbd.hero .navbar-menu{background-color:#363636}}.hero.is-dark .navbar-item,.content kbd.hero .navbar-item,.hero.is-dark .navbar-link,.content kbd.hero .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-dark a.navbar-item:hover,.content kbd.hero a.navbar-item:hover,.hero.is-dark a.navbar-item.is-active,.content kbd.hero a.navbar-item.is-active,.hero.is-dark .navbar-link:hover,.content kbd.hero .navbar-link:hover,.hero.is-dark .navbar-link.is-active,.content kbd.hero .navbar-link.is-active{background-color:#292929;color:#fff}.hero.is-dark .tabs a,.content kbd.hero .tabs a{color:#fff;opacity:0.9}.hero.is-dark .tabs a:hover,.content kbd.hero .tabs a:hover{opacity:1}.hero.is-dark .tabs li.is-active a,.content kbd.hero .tabs li.is-active a{color:#363636 !important;opacity:1}.hero.is-dark .tabs.is-boxed a,.content kbd.hero .tabs.is-boxed a,.hero.is-dark .tabs.is-toggle a,.content kbd.hero .tabs.is-toggle a{color:#fff}.hero.is-dark .tabs.is-boxed a:hover,.content kbd.hero .tabs.is-boxed a:hover,.hero.is-dark .tabs.is-toggle a:hover,.content kbd.hero .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-dark .tabs.is-boxed li.is-active a,.content kbd.hero .tabs.is-boxed li.is-active a,.hero.is-dark .tabs.is-boxed li.is-active a:hover,.hero.is-dark .tabs.is-toggle li.is-active a,.content kbd.hero .tabs.is-toggle li.is-active a,.hero.is-dark .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#363636}.hero.is-dark.is-bold,.content kbd.hero.is-bold{background-image:linear-gradient(141deg, #1f191a 0%, #363636 71%, #46403f 100%)}@media screen and (max-width: 768px){.hero.is-dark.is-bold .navbar-menu,.content kbd.hero.is-bold .navbar-menu{background-image:linear-gradient(141deg, #1f191a 0%, #363636 71%, #46403f 100%)}}.hero.is-primary,.docstring>section>a.hero.docs-sourcelink{background-color:#4eb5de;color:#fff}.hero.is-primary a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.docstring>section>a.hero.docs-sourcelink a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-primary strong,.docstring>section>a.hero.docs-sourcelink strong{color:inherit}.hero.is-primary .title,.docstring>section>a.hero.docs-sourcelink .title{color:#fff}.hero.is-primary .subtitle,.docstring>section>a.hero.docs-sourcelink .subtitle{color:rgba(255,255,255,0.9)}.hero.is-primary .subtitle a:not(.button),.docstring>section>a.hero.docs-sourcelink .subtitle a:not(.button),.hero.is-primary .subtitle strong,.docstring>section>a.hero.docs-sourcelink .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-primary .navbar-menu,.docstring>section>a.hero.docs-sourcelink .navbar-menu{background-color:#4eb5de}}.hero.is-primary .navbar-item,.docstring>section>a.hero.docs-sourcelink .navbar-item,.hero.is-primary .navbar-link,.docstring>section>a.hero.docs-sourcelink .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-primary a.navbar-item:hover,.docstring>section>a.hero.docs-sourcelink a.navbar-item:hover,.hero.is-primary a.navbar-item.is-active,.docstring>section>a.hero.docs-sourcelink a.navbar-item.is-active,.hero.is-primary .navbar-link:hover,.docstring>section>a.hero.docs-sourcelink .navbar-link:hover,.hero.is-primary .navbar-link.is-active,.docstring>section>a.hero.docs-sourcelink .navbar-link.is-active{background-color:#39acda;color:#fff}.hero.is-primary .tabs a,.docstring>section>a.hero.docs-sourcelink .tabs a{color:#fff;opacity:0.9}.hero.is-primary .tabs a:hover,.docstring>section>a.hero.docs-sourcelink .tabs a:hover{opacity:1}.hero.is-primary .tabs li.is-active a,.docstring>section>a.hero.docs-sourcelink .tabs li.is-active a{color:#4eb5de !important;opacity:1}.hero.is-primary .tabs.is-boxed a,.docstring>section>a.hero.docs-sourcelink .tabs.is-boxed a,.hero.is-primary .tabs.is-toggle a,.docstring>section>a.hero.docs-sourcelink .tabs.is-toggle a{color:#fff}.hero.is-primary .tabs.is-boxed a:hover,.docstring>section>a.hero.docs-sourcelink .tabs.is-boxed a:hover,.hero.is-primary .tabs.is-toggle a:hover,.docstring>section>a.hero.docs-sourcelink .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-primary .tabs.is-boxed li.is-active a,.docstring>section>a.hero.docs-sourcelink .tabs.is-boxed li.is-active a,.hero.is-primary .tabs.is-boxed li.is-active a:hover,.hero.is-primary .tabs.is-toggle li.is-active a,.docstring>section>a.hero.docs-sourcelink .tabs.is-toggle li.is-active a,.hero.is-primary .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#4eb5de}.hero.is-primary.is-bold,.docstring>section>a.hero.is-bold.docs-sourcelink{background-image:linear-gradient(141deg, #1bc7de 0%, #4eb5de 71%, #5fa9e7 100%)}@media screen and (max-width: 768px){.hero.is-primary.is-bold .navbar-menu,.docstring>section>a.hero.is-bold.docs-sourcelink .navbar-menu{background-image:linear-gradient(141deg, #1bc7de 0%, #4eb5de 71%, #5fa9e7 100%)}}.hero.is-link{background-color:#2e63b8;color:#fff}.hero.is-link a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-link strong{color:inherit}.hero.is-link .title{color:#fff}.hero.is-link .subtitle{color:rgba(255,255,255,0.9)}.hero.is-link .subtitle a:not(.button),.hero.is-link .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-link .navbar-menu{background-color:#2e63b8}}.hero.is-link .navbar-item,.hero.is-link .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-link a.navbar-item:hover,.hero.is-link a.navbar-item.is-active,.hero.is-link .navbar-link:hover,.hero.is-link .navbar-link.is-active{background-color:#2958a4;color:#fff}.hero.is-link .tabs a{color:#fff;opacity:0.9}.hero.is-link .tabs a:hover{opacity:1}.hero.is-link .tabs li.is-active a{color:#2e63b8 !important;opacity:1}.hero.is-link .tabs.is-boxed a,.hero.is-link .tabs.is-toggle a{color:#fff}.hero.is-link .tabs.is-boxed a:hover,.hero.is-link .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-link .tabs.is-boxed li.is-active a,.hero.is-link .tabs.is-boxed li.is-active a:hover,.hero.is-link .tabs.is-toggle li.is-active a,.hero.is-link .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#2e63b8}.hero.is-link.is-bold{background-image:linear-gradient(141deg, #1b6098 0%, #2e63b8 71%, #2d51d2 100%)}@media screen and (max-width: 768px){.hero.is-link.is-bold .navbar-menu{background-image:linear-gradient(141deg, #1b6098 0%, #2e63b8 71%, #2d51d2 100%)}}.hero.is-info{background-color:#209cee;color:#fff}.hero.is-info a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-info strong{color:inherit}.hero.is-info .title{color:#fff}.hero.is-info .subtitle{color:rgba(255,255,255,0.9)}.hero.is-info .subtitle a:not(.button),.hero.is-info .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-info .navbar-menu{background-color:#209cee}}.hero.is-info .navbar-item,.hero.is-info .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-info a.navbar-item:hover,.hero.is-info a.navbar-item.is-active,.hero.is-info .navbar-link:hover,.hero.is-info .navbar-link.is-active{background-color:#1190e3;color:#fff}.hero.is-info .tabs a{color:#fff;opacity:0.9}.hero.is-info .tabs a:hover{opacity:1}.hero.is-info .tabs li.is-active a{color:#209cee !important;opacity:1}.hero.is-info .tabs.is-boxed a,.hero.is-info .tabs.is-toggle a{color:#fff}.hero.is-info .tabs.is-boxed a:hover,.hero.is-info .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-info .tabs.is-boxed li.is-active a,.hero.is-info .tabs.is-boxed li.is-active a:hover,.hero.is-info .tabs.is-toggle li.is-active a,.hero.is-info .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#209cee}.hero.is-info.is-bold{background-image:linear-gradient(141deg, #05a6d6 0%, #209cee 71%, #3287f5 100%)}@media screen and (max-width: 768px){.hero.is-info.is-bold .navbar-menu{background-image:linear-gradient(141deg, #05a6d6 0%, #209cee 71%, #3287f5 100%)}}.hero.is-success{background-color:#22c35b;color:#fff}.hero.is-success a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-success strong{color:inherit}.hero.is-success .title{color:#fff}.hero.is-success .subtitle{color:rgba(255,255,255,0.9)}.hero.is-success .subtitle a:not(.button),.hero.is-success .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-success .navbar-menu{background-color:#22c35b}}.hero.is-success .navbar-item,.hero.is-success .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-success a.navbar-item:hover,.hero.is-success a.navbar-item.is-active,.hero.is-success .navbar-link:hover,.hero.is-success .navbar-link.is-active{background-color:#1ead51;color:#fff}.hero.is-success .tabs a{color:#fff;opacity:0.9}.hero.is-success .tabs a:hover{opacity:1}.hero.is-success .tabs li.is-active a{color:#22c35b !important;opacity:1}.hero.is-success .tabs.is-boxed a,.hero.is-success .tabs.is-toggle a{color:#fff}.hero.is-success .tabs.is-boxed a:hover,.hero.is-success .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-success .tabs.is-boxed li.is-active a,.hero.is-success .tabs.is-boxed li.is-active a:hover,.hero.is-success .tabs.is-toggle li.is-active a,.hero.is-success .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#22c35b}.hero.is-success.is-bold{background-image:linear-gradient(141deg, #12a02c 0%, #22c35b 71%, #1fdf83 100%)}@media screen and (max-width: 768px){.hero.is-success.is-bold .navbar-menu{background-image:linear-gradient(141deg, #12a02c 0%, #22c35b 71%, #1fdf83 100%)}}.hero.is-warning{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.hero.is-warning a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-warning strong{color:inherit}.hero.is-warning .title{color:rgba(0,0,0,0.7)}.hero.is-warning .subtitle{color:rgba(0,0,0,0.9)}.hero.is-warning .subtitle a:not(.button),.hero.is-warning .subtitle strong{color:rgba(0,0,0,0.7)}@media screen and (max-width: 1055px){.hero.is-warning .navbar-menu{background-color:#ffdd57}}.hero.is-warning .navbar-item,.hero.is-warning .navbar-link{color:rgba(0,0,0,0.7)}.hero.is-warning a.navbar-item:hover,.hero.is-warning a.navbar-item.is-active,.hero.is-warning .navbar-link:hover,.hero.is-warning .navbar-link.is-active{background-color:#ffd83e;color:rgba(0,0,0,0.7)}.hero.is-warning .tabs a{color:rgba(0,0,0,0.7);opacity:0.9}.hero.is-warning .tabs a:hover{opacity:1}.hero.is-warning .tabs li.is-active a{color:#ffdd57 !important;opacity:1}.hero.is-warning .tabs.is-boxed a,.hero.is-warning .tabs.is-toggle a{color:rgba(0,0,0,0.7)}.hero.is-warning .tabs.is-boxed a:hover,.hero.is-warning .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-warning .tabs.is-boxed li.is-active a,.hero.is-warning .tabs.is-boxed li.is-active a:hover,.hero.is-warning .tabs.is-toggle li.is-active a,.hero.is-warning .tabs.is-toggle li.is-active a:hover{background-color:rgba(0,0,0,0.7);border-color:rgba(0,0,0,0.7);color:#ffdd57}.hero.is-warning.is-bold{background-image:linear-gradient(141deg, #ffae24 0%, #ffdd57 71%, #fffa71 100%)}@media screen and (max-width: 768px){.hero.is-warning.is-bold .navbar-menu{background-image:linear-gradient(141deg, #ffae24 0%, #ffdd57 71%, #fffa71 100%)}}.hero.is-danger{background-color:#da0b00;color:#fff}.hero.is-danger a:not(.button):not(.dropdown-item):not(.tag):not(.pagination-link.is-current),.hero.is-danger strong{color:inherit}.hero.is-danger .title{color:#fff}.hero.is-danger .subtitle{color:rgba(255,255,255,0.9)}.hero.is-danger .subtitle a:not(.button),.hero.is-danger .subtitle strong{color:#fff}@media screen and (max-width: 1055px){.hero.is-danger .navbar-menu{background-color:#da0b00}}.hero.is-danger .navbar-item,.hero.is-danger .navbar-link{color:rgba(255,255,255,0.7)}.hero.is-danger a.navbar-item:hover,.hero.is-danger a.navbar-item.is-active,.hero.is-danger .navbar-link:hover,.hero.is-danger .navbar-link.is-active{background-color:#c10a00;color:#fff}.hero.is-danger .tabs a{color:#fff;opacity:0.9}.hero.is-danger .tabs a:hover{opacity:1}.hero.is-danger .tabs li.is-active a{color:#da0b00 !important;opacity:1}.hero.is-danger .tabs.is-boxed a,.hero.is-danger .tabs.is-toggle a{color:#fff}.hero.is-danger .tabs.is-boxed a:hover,.hero.is-danger .tabs.is-toggle a:hover{background-color:rgba(10,10,10,0.1)}.hero.is-danger .tabs.is-boxed li.is-active a,.hero.is-danger .tabs.is-boxed li.is-active a:hover,.hero.is-danger .tabs.is-toggle li.is-active a,.hero.is-danger .tabs.is-toggle li.is-active a:hover{background-color:#fff;border-color:#fff;color:#da0b00}.hero.is-danger.is-bold{background-image:linear-gradient(141deg, #a70013 0%, #da0b00 71%, #f43500 100%)}@media screen and (max-width: 768px){.hero.is-danger.is-bold .navbar-menu{background-image:linear-gradient(141deg, #a70013 0%, #da0b00 71%, #f43500 100%)}}.hero.is-small .hero-body,#documenter .docs-sidebar form.docs-search>input.hero .hero-body{padding:1.5rem}@media screen and (min-width: 769px),print{.hero.is-medium .hero-body{padding:9rem 4.5rem}}@media screen and (min-width: 769px),print{.hero.is-large .hero-body{padding:18rem 6rem}}.hero.is-halfheight .hero-body,.hero.is-fullheight .hero-body,.hero.is-fullheight-with-navbar .hero-body{align-items:center;display:flex}.hero.is-halfheight .hero-body>.container,.hero.is-fullheight .hero-body>.container,.hero.is-fullheight-with-navbar .hero-body>.container{flex-grow:1;flex-shrink:1}.hero.is-halfheight{min-height:50vh}.hero.is-fullheight{min-height:100vh}.hero-video{overflow:hidden}.hero-video video{left:50%;min-height:100%;min-width:100%;position:absolute;top:50%;transform:translate3d(-50%, -50%, 0)}.hero-video.is-transparent{opacity:0.3}@media screen and (max-width: 768px){.hero-video{display:none}}.hero-buttons{margin-top:1.5rem}@media screen and (max-width: 768px){.hero-buttons .button{display:flex}.hero-buttons .button:not(:last-child){margin-bottom:0.75rem}}@media screen and (min-width: 769px),print{.hero-buttons{display:flex;justify-content:center}.hero-buttons .button:not(:last-child){margin-right:1.5rem}}.hero-head,.hero-foot{flex-grow:0;flex-shrink:0}.hero-body{flex-grow:1;flex-shrink:0;padding:3rem 1.5rem}@media screen and (min-width: 769px),print{.hero-body{padding:3rem 3rem}}.section{padding:3rem 1.5rem}@media screen and (min-width: 1056px){.section{padding:3rem 3rem}.section.is-medium{padding:9rem 4.5rem}.section.is-large{padding:18rem 6rem}}.footer{background-color:#fafafa;padding:3rem 1.5rem 6rem}h1 .docs-heading-anchor,h1 .docs-heading-anchor:hover,h1 .docs-heading-anchor:visited,h2 .docs-heading-anchor,h2 .docs-heading-anchor:hover,h2 .docs-heading-anchor:visited,h3 .docs-heading-anchor,h3 .docs-heading-anchor:hover,h3 .docs-heading-anchor:visited,h4 .docs-heading-anchor,h4 .docs-heading-anchor:hover,h4 .docs-heading-anchor:visited,h5 .docs-heading-anchor,h5 .docs-heading-anchor:hover,h5 .docs-heading-anchor:visited,h6 .docs-heading-anchor,h6 .docs-heading-anchor:hover,h6 .docs-heading-anchor:visited{color:#222}h1 .docs-heading-anchor-permalink,h2 .docs-heading-anchor-permalink,h3 .docs-heading-anchor-permalink,h4 .docs-heading-anchor-permalink,h5 .docs-heading-anchor-permalink,h6 .docs-heading-anchor-permalink{visibility:hidden;vertical-align:middle;margin-left:0.5em;font-size:0.7rem}h1 .docs-heading-anchor-permalink::before,h2 .docs-heading-anchor-permalink::before,h3 .docs-heading-anchor-permalink::before,h4 .docs-heading-anchor-permalink::before,h5 .docs-heading-anchor-permalink::before,h6 .docs-heading-anchor-permalink::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f0c1"}h1:hover .docs-heading-anchor-permalink,h2:hover .docs-heading-anchor-permalink,h3:hover .docs-heading-anchor-permalink,h4:hover .docs-heading-anchor-permalink,h5:hover .docs-heading-anchor-permalink,h6:hover .docs-heading-anchor-permalink{visibility:visible}.docs-dark-only{display:none !important}pre{position:relative;overflow:hidden}pre code,pre code.hljs{padding:0 .75rem !important;overflow:auto;display:block}pre code:first-of-type,pre code.hljs:first-of-type{padding-top:0.5rem !important}pre code:last-of-type,pre code.hljs:last-of-type{padding-bottom:0.5rem !important}pre .copy-button{opacity:0.2;transition:opacity 0.2s;position:absolute;right:0em;top:0em;padding:0.5em;width:2.5em;height:2.5em;background:transparent;border:none;font-family:"Font Awesome 6 Free";color:#222;cursor:pointer;text-align:center}pre .copy-button:focus,pre .copy-button:hover{opacity:1;background:rgba(34,34,34,0.1);color:#2e63b8}pre .copy-button.success{color:#259a12;opacity:1}pre .copy-button.error{color:#cb3c33;opacity:1}pre:hover .copy-button{opacity:1}.admonition{background-color:#b5b5b5;border-style:solid;border-width:1px;border-color:#363636;border-radius:4px;font-size:1rem}.admonition strong{color:currentColor}.admonition.is-small,#documenter .docs-sidebar form.docs-search>input.admonition{font-size:.75rem}.admonition.is-medium{font-size:1.25rem}.admonition.is-large{font-size:1.5rem}.admonition.is-default{background-color:#b5b5b5;border-color:#363636}.admonition.is-default>.admonition-header{background-color:#363636;color:#fff}.admonition.is-default>.admonition-body{color:#fff}.admonition.is-info{background-color:#def0fc;border-color:#209cee}.admonition.is-info>.admonition-header{background-color:#209cee;color:#fff}.admonition.is-info>.admonition-body{color:rgba(0,0,0,0.7)}.admonition.is-success{background-color:#bdf4d1;border-color:#22c35b}.admonition.is-success>.admonition-header{background-color:#22c35b;color:#fff}.admonition.is-success>.admonition-body{color:rgba(0,0,0,0.7)}.admonition.is-warning{background-color:#fff3c5;border-color:#ffdd57}.admonition.is-warning>.admonition-header{background-color:#ffdd57;color:rgba(0,0,0,0.7)}.admonition.is-warning>.admonition-body{color:rgba(0,0,0,0.7)}.admonition.is-danger{background-color:#ffaba7;border-color:#da0b00}.admonition.is-danger>.admonition-header{background-color:#da0b00;color:#fff}.admonition.is-danger>.admonition-body{color:rgba(0,0,0,0.7)}.admonition.is-compat{background-color:#bdeff5;border-color:#1db5c9}.admonition.is-compat>.admonition-header{background-color:#1db5c9;color:#fff}.admonition.is-compat>.admonition-body{color:rgba(0,0,0,0.7)}.admonition-header{color:#fff;background-color:#363636;align-items:center;font-weight:700;justify-content:space-between;line-height:1.25;padding:0.5rem .75rem;position:relative}.admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;margin-right:.75rem;content:"\f06a"}details.admonition.is-details>.admonition-header{list-style:none}details.admonition.is-details>.admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f055"}details.admonition.is-details[open]>.admonition-header:before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f056"}.admonition-body{color:#222;padding:0.5rem .75rem}.admonition-body pre{background-color:#f5f5f5}.admonition-body code{background-color:rgba(0,0,0,0.05)}.docstring{margin-bottom:1em;background-color:rgba(0,0,0,0);border:1px solid #dbdbdb;box-shadow:2px 2px 3px rgba(10,10,10,0.1);max-width:100%}.docstring>header{cursor:pointer;display:flex;flex-grow:1;align-items:stretch;padding:0.5rem .75rem;background-color:#f5f5f5;box-shadow:0 0.125em 0.25em rgba(10,10,10,0.1);box-shadow:none;border-bottom:1px solid #dbdbdb}.docstring>header code{background-color:transparent}.docstring>header .docstring-article-toggle-button{min-width:1.1rem;padding:0.2rem 0.2rem 0.2rem 0}.docstring>header .docstring-binding{margin-right:0.3em}.docstring>header .docstring-category{margin-left:0.3em}.docstring>section{position:relative;padding:.75rem .75rem;border-bottom:1px solid #dbdbdb}.docstring>section:last-child{border-bottom:none}.docstring>section>a.docs-sourcelink{transition:opacity 0.3s;opacity:0;position:absolute;right:.375rem;bottom:.375rem}.docstring>section>a.docs-sourcelink:focus{opacity:1 !important}.docstring:hover>section>a.docs-sourcelink{opacity:0.2}.docstring:focus-within>section>a.docs-sourcelink{opacity:0.2}.docstring>section:hover a.docs-sourcelink{opacity:1}.documenter-example-output{background-color:#fff}.outdated-warning-overlay{position:fixed;top:0;left:0;right:0;box-shadow:0 0 10px rgba(0,0,0,0.3);z-index:999;background-color:#ffaba7;color:rgba(0,0,0,0.7);border-bottom:3px solid #da0b00;padding:10px 35px;text-align:center;font-size:15px}.outdated-warning-overlay .outdated-warning-closer{position:absolute;top:calc(50% - 10px);right:18px;cursor:pointer;width:12px}.outdated-warning-overlay a{color:#2e63b8}.outdated-warning-overlay a:hover{color:#363636}.content pre{border:1px solid #dbdbdb}.content code{font-weight:inherit}.content a code{color:#2e63b8}.content h1 code,.content h2 code,.content h3 code,.content h4 code,.content h5 code,.content h6 code{color:#222}.content table{display:block;width:initial;max-width:100%;overflow-x:auto}.content blockquote>ul:first-child,.content blockquote>ol:first-child,.content .admonition-body>ul:first-child,.content .admonition-body>ol:first-child{margin-top:0}pre,code{font-variant-ligatures:no-contextual}.breadcrumb a.is-disabled{cursor:default;pointer-events:none}.breadcrumb a.is-disabled,.breadcrumb a.is-disabled:hover{color:#222}.hljs{background:initial !important}.katex .katex-mathml{top:0;right:0}.katex-display,mjx-container,.MathJax_Display{margin:0.5em 0 !important}html{-moz-osx-font-smoothing:auto;-webkit-font-smoothing:auto}li.no-marker{list-style:none}#documenter .docs-main>article{overflow-wrap:break-word}#documenter .docs-main>article .math-container{overflow-x:auto;overflow-y:hidden}@media screen and (min-width: 1056px){#documenter .docs-main{max-width:52rem;margin-left:20rem;padding-right:1rem}}@media screen and (max-width: 1055px){#documenter .docs-main{width:100%}#documenter .docs-main>article{max-width:52rem;margin-left:auto;margin-right:auto;margin-bottom:1rem;padding:0 1rem}#documenter .docs-main>header,#documenter .docs-main>nav{max-width:100%;width:100%;margin:0}}#documenter .docs-main header.docs-navbar{background-color:#fff;border-bottom:1px solid #dbdbdb;z-index:2;min-height:4rem;margin-bottom:1rem;display:flex}#documenter .docs-main header.docs-navbar .breadcrumb{flex-grow:1}#documenter .docs-main header.docs-navbar .docs-sidebar-button{display:block;font-size:1.5rem;padding-bottom:0.1rem;margin-right:1rem}#documenter .docs-main header.docs-navbar .docs-right{display:flex;white-space:nowrap;gap:1rem;align-items:center}#documenter .docs-main header.docs-navbar .docs-right .docs-icon,#documenter .docs-main header.docs-navbar .docs-right .docs-label{display:inline-block}#documenter .docs-main header.docs-navbar .docs-right .docs-label{padding:0;margin-left:0.3em}@media screen and (max-width: 1055px){#documenter .docs-main header.docs-navbar .docs-right .docs-navbar-link{margin-left:0.4rem;margin-right:0.4rem}}#documenter .docs-main header.docs-navbar>*{margin:auto 0}@media screen and (max-width: 1055px){#documenter .docs-main header.docs-navbar{position:sticky;top:0;padding:0 1rem;transition-property:top, box-shadow;-webkit-transition-property:top, box-shadow;transition-duration:0.3s;-webkit-transition-duration:0.3s}#documenter .docs-main header.docs-navbar.headroom--not-top{box-shadow:.2rem 0rem .4rem #bbb;transition-duration:0.7s;-webkit-transition-duration:0.7s}#documenter .docs-main header.docs-navbar.headroom--unpinned.headroom--not-top.headroom--not-bottom{top:-4.5rem;transition-duration:0.7s;-webkit-transition-duration:0.7s}}#documenter .docs-main section.footnotes{border-top:1px solid #dbdbdb}#documenter .docs-main section.footnotes li .tag:first-child,#documenter .docs-main section.footnotes li .docstring>section>a.docs-sourcelink:first-child,#documenter .docs-main section.footnotes li .content kbd:first-child,.content #documenter .docs-main section.footnotes li kbd:first-child{margin-right:1em;margin-bottom:0.4em}#documenter .docs-main .docs-footer{display:flex;flex-wrap:wrap;margin-left:0;margin-right:0;border-top:1px solid #dbdbdb;padding-top:1rem;padding-bottom:1rem}@media screen and (max-width: 1055px){#documenter .docs-main .docs-footer{padding-left:1rem;padding-right:1rem}}#documenter .docs-main .docs-footer .docs-footer-nextpage,#documenter .docs-main .docs-footer .docs-footer-prevpage{flex-grow:1}#documenter .docs-main .docs-footer .docs-footer-nextpage{text-align:right}#documenter .docs-main .docs-footer .flexbox-break{flex-basis:100%;height:0}#documenter .docs-main .docs-footer .footer-message{font-size:0.8em;margin:0.5em auto 0 auto;text-align:center}#documenter .docs-sidebar{display:flex;flex-direction:column;color:#0a0a0a;background-color:#f5f5f5;border-right:1px solid #dbdbdb;padding:0;flex:0 0 18rem;z-index:5;font-size:1rem;position:fixed;left:-18rem;width:18rem;height:100%;transition:left 0.3s}#documenter .docs-sidebar.visible{left:0;box-shadow:.4rem 0rem .8rem #bbb}@media screen and (min-width: 1056px){#documenter .docs-sidebar.visible{box-shadow:none}}@media screen and (min-width: 1056px){#documenter .docs-sidebar{left:0;top:0}}#documenter .docs-sidebar .docs-logo{margin-top:1rem;padding:0 1rem}#documenter .docs-sidebar .docs-logo>img{max-height:6rem;margin:auto}#documenter .docs-sidebar .docs-package-name{flex-shrink:0;font-size:1.5rem;font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;padding:0.5rem 0}#documenter .docs-sidebar .docs-package-name .docs-autofit{max-width:16.2rem}#documenter .docs-sidebar .docs-package-name a,#documenter .docs-sidebar .docs-package-name a:hover{color:#0a0a0a}#documenter .docs-sidebar .docs-version-selector{border-top:1px solid #dbdbdb;display:none;padding:0.5rem}#documenter .docs-sidebar .docs-version-selector.visible{display:flex}#documenter .docs-sidebar ul.docs-menu{flex-grow:1;user-select:none;border-top:1px solid #dbdbdb;padding-bottom:1.5rem}#documenter .docs-sidebar ul.docs-menu>li>.tocitem{font-weight:bold}#documenter .docs-sidebar ul.docs-menu>li li{font-size:.95rem;margin-left:1em;border-left:1px solid #dbdbdb}#documenter .docs-sidebar ul.docs-menu input.collapse-toggle{display:none}#documenter .docs-sidebar ul.docs-menu ul.collapsed{display:none}#documenter .docs-sidebar ul.docs-menu input:checked~ul.collapsed{display:block}#documenter .docs-sidebar ul.docs-menu label.tocitem{display:flex}#documenter .docs-sidebar ul.docs-menu label.tocitem .docs-label{flex-grow:2}#documenter .docs-sidebar ul.docs-menu label.tocitem .docs-chevron{display:inline-block;font-style:normal;font-variant:normal;text-rendering:auto;line-height:1;font-size:.75rem;margin-left:1rem;margin-top:auto;margin-bottom:auto}#documenter .docs-sidebar ul.docs-menu label.tocitem .docs-chevron::before{font-family:"Font Awesome 6 Free";font-weight:900;content:"\f054"}#documenter .docs-sidebar ul.docs-menu input:checked~label.tocitem .docs-chevron::before{content:"\f078"}#documenter .docs-sidebar ul.docs-menu .tocitem{display:block;padding:0.5rem 0.5rem}#documenter .docs-sidebar ul.docs-menu .tocitem,#documenter .docs-sidebar ul.docs-menu .tocitem:hover{color:#0a0a0a;background:#f5f5f5}#documenter .docs-sidebar ul.docs-menu a.tocitem:hover,#documenter .docs-sidebar ul.docs-menu label.tocitem:hover{color:#0a0a0a;background-color:#ebebeb}#documenter .docs-sidebar ul.docs-menu li.is-active{border-top:1px solid #dbdbdb;border-bottom:1px solid #dbdbdb;background-color:#fff}#documenter .docs-sidebar ul.docs-menu li.is-active .tocitem,#documenter .docs-sidebar ul.docs-menu li.is-active .tocitem:hover{background-color:#fff;color:#0a0a0a}#documenter .docs-sidebar ul.docs-menu li.is-active ul.internal .tocitem:hover{background-color:#ebebeb;color:#0a0a0a}#documenter .docs-sidebar ul.docs-menu>li.is-active:first-child{border-top:none}#documenter .docs-sidebar ul.docs-menu ul.internal{margin:0 0.5rem 0.5rem;border-top:1px solid #dbdbdb}#documenter .docs-sidebar ul.docs-menu ul.internal li{font-size:.85rem;border-left:none;margin-left:0;margin-top:0.5rem}#documenter .docs-sidebar ul.docs-menu ul.internal .tocitem{width:100%;padding:0}#documenter .docs-sidebar ul.docs-menu ul.internal .tocitem::before{content:"⚬";margin-right:0.4em}#documenter .docs-sidebar form.docs-search{margin:auto;margin-top:0.5rem;margin-bottom:0.5rem}#documenter .docs-sidebar form.docs-search>input{width:14.4rem}#documenter .docs-sidebar #documenter-search-query{color:#707070;width:14.4rem;box-shadow:inset 0 1px 2px rgba(10,10,10,0.1)}@media screen and (min-width: 1056px){#documenter .docs-sidebar ul.docs-menu{overflow-y:auto;-webkit-overflow-scroll:touch}#documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar{width:.3rem;background:none}#documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar-thumb{border-radius:5px 0px 0px 5px;background:#e0e0e0}#documenter .docs-sidebar ul.docs-menu::-webkit-scrollbar-thumb:hover{background:#ccc}}@media screen and (max-width: 1055px){#documenter .docs-sidebar{overflow-y:auto;-webkit-overflow-scroll:touch}#documenter .docs-sidebar::-webkit-scrollbar{width:.3rem;background:none}#documenter .docs-sidebar::-webkit-scrollbar-thumb{border-radius:5px 0px 0px 5px;background:#e0e0e0}#documenter .docs-sidebar::-webkit-scrollbar-thumb:hover{background:#ccc}}kbd.search-modal-key-hints{border-radius:0.25rem;border:1px solid rgba(0,0,0,0.6);box-shadow:0 2px 0 1px rgba(0,0,0,0.6);cursor:default;font-size:0.9rem;line-height:1.5;min-width:0.75rem;text-align:center;padding:0.1rem 0.3rem;position:relative;top:-1px}.search-min-width-50{min-width:50%}.search-min-height-100{min-height:100%}.search-modal-card-body{max-height:calc(100vh - 15rem)}.search-result-link{border-radius:0.7em;transition:all 300ms}.search-result-link:hover,.search-result-link:focus{background-color:rgba(0,128,128,0.1)}.search-result-link .property-search-result-badge,.search-result-link .search-filter{transition:all 300ms}.property-search-result-badge,.search-filter{padding:0.15em 0.5em;font-size:0.8em;font-style:italic;text-transform:none !important;line-height:1.5;color:#f5f5f5;background-color:rgba(51,65,85,0.501961);border-radius:0.6rem}.search-result-link:hover .property-search-result-badge,.search-result-link:hover .search-filter,.search-result-link:focus .property-search-result-badge,.search-result-link:focus .search-filter{color:#f1f5f9;background-color:#333}.search-filter{color:#333;background-color:#f5f5f5;transition:all 300ms}.search-filter:hover,.search-filter:focus{color:#333}.search-filter-selected{color:#f5f5f5;background-color:rgba(139,0,139,0.5)}.search-filter-selected:hover,.search-filter-selected:focus{color:#f5f5f5}.search-result-highlight{background-color:#ffdd57;color:black}.search-divider{border-bottom:1px solid #dbdbdb}.search-result-title{width:85%;color:#333}.search-result-code-title{font-size:0.875rem;font-family:"JuliaMono","SFMono-Regular","Menlo","Consolas","Liberation Mono","DejaVu Sans Mono",monospace}#search-modal .modal-card-body::-webkit-scrollbar,#search-modal .filter-tabs::-webkit-scrollbar{height:10px;width:10px;background-color:transparent}#search-modal .modal-card-body::-webkit-scrollbar-thumb,#search-modal .filter-tabs::-webkit-scrollbar-thumb{background-color:gray;border-radius:1rem}#search-modal .modal-card-body::-webkit-scrollbar-track,#search-modal .filter-tabs::-webkit-scrollbar-track{-webkit-box-shadow:inset 0 0 6px rgba(0,0,0,0.6);background-color:transparent}.w-100{width:100%}.gap-2{gap:0.5rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.ansi span.sgr1{font-weight:bolder}.ansi span.sgr2{font-weight:lighter}.ansi span.sgr3{font-style:italic}.ansi span.sgr4{text-decoration:underline}.ansi span.sgr7{color:#fff;background-color:#222}.ansi span.sgr8{color:transparent}.ansi span.sgr8 span{color:transparent}.ansi span.sgr9{text-decoration:line-through}.ansi span.sgr30{color:#242424}.ansi span.sgr31{color:#a7201f}.ansi span.sgr32{color:#066f00}.ansi span.sgr33{color:#856b00}.ansi span.sgr34{color:#2149b0}.ansi span.sgr35{color:#7d4498}.ansi span.sgr36{color:#007989}.ansi span.sgr37{color:gray}.ansi span.sgr40{background-color:#242424}.ansi span.sgr41{background-color:#a7201f}.ansi span.sgr42{background-color:#066f00}.ansi span.sgr43{background-color:#856b00}.ansi span.sgr44{background-color:#2149b0}.ansi span.sgr45{background-color:#7d4498}.ansi span.sgr46{background-color:#007989}.ansi span.sgr47{background-color:gray}.ansi span.sgr90{color:#616161}.ansi span.sgr91{color:#cb3c33}.ansi span.sgr92{color:#0e8300}.ansi span.sgr93{color:#a98800}.ansi span.sgr94{color:#3c5dcd}.ansi span.sgr95{color:#9256af}.ansi span.sgr96{color:#008fa3}.ansi span.sgr97{color:#f5f5f5}.ansi span.sgr100{background-color:#616161}.ansi span.sgr101{background-color:#cb3c33}.ansi span.sgr102{background-color:#0e8300}.ansi span.sgr103{background-color:#a98800}.ansi span.sgr104{background-color:#3c5dcd}.ansi span.sgr105{background-color:#9256af}.ansi span.sgr106{background-color:#008fa3}.ansi span.sgr107{background-color:#f5f5f5}code.language-julia-repl>span.hljs-meta{color:#066f00;font-weight:bolder}/*! + Theme: Default + Description: Original highlight.js style + Author: (c) Ivan Sagalaev + Maintainer: @highlightjs/core-team + Website: https://highlightjs.org/ + License: see project LICENSE + Touched: 2021 +*/pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{background:#F3F3F3;color:#444}.hljs-comment{color:#697070}.hljs-tag,.hljs-punctuation{color:#444a}.hljs-tag .hljs-name,.hljs-tag .hljs-attr{color:#444}.hljs-keyword,.hljs-attribute,.hljs-selector-tag,.hljs-meta .hljs-keyword,.hljs-doctag,.hljs-name{font-weight:bold}.hljs-type,.hljs-string,.hljs-number,.hljs-selector-id,.hljs-selector-class,.hljs-quote,.hljs-template-tag,.hljs-deletion{color:#880000}.hljs-title,.hljs-section{color:#880000;font-weight:bold}.hljs-regexp,.hljs-symbol,.hljs-variable,.hljs-template-variable,.hljs-link,.hljs-selector-attr,.hljs-operator,.hljs-selector-pseudo{color:#ab5656}.hljs-literal{color:#695}.hljs-built_in,.hljs-bullet,.hljs-code,.hljs-addition{color:#397300}.hljs-meta{color:#1f7199}.hljs-meta .hljs-string{color:#38a}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:bold}.gap-4{gap:1rem} diff --git a/previews/PR1697/assets/themeswap.js b/previews/PR1697/assets/themeswap.js new file mode 100644 index 00000000000..9f5eebe6aa2 --- /dev/null +++ b/previews/PR1697/assets/themeswap.js @@ -0,0 +1,84 @@ +// Small function to quickly swap out themes. Gets put into the tag.. +function set_theme_from_local_storage() { + // Initialize the theme to null, which means default + var theme = null; + // If the browser supports the localstorage and is not disabled then try to get the + // documenter theme + if (window.localStorage != null) { + // Get the user-picked theme from localStorage. May be `null`, which means the default + // theme. + theme = window.localStorage.getItem("documenter-theme"); + } + // Check if the users preference is for dark color scheme + var darkPreference = + window.matchMedia("(prefers-color-scheme: dark)").matches === true; + // Initialize a few variables for the loop: + // + // - active: will contain the index of the theme that should be active. Note that there + // is no guarantee that localStorage contains sane values. If `active` stays `null` + // we either could not find the theme or it is the default (primary) theme anyway. + // Either way, we then need to stick to the primary theme. + // + // - disabled: style sheets that should be disabled (i.e. all the theme style sheets + // that are not the currently active theme) + var active = null; + var disabled = []; + var primaryLightTheme = null; + var primaryDarkTheme = null; + for (var i = 0; i < document.styleSheets.length; i++) { + var ss = document.styleSheets[i]; + // The tag of each style sheet is expected to have a data-theme-name attribute + // which must contain the name of the theme. The names in localStorage much match this. + var themename = ss.ownerNode.getAttribute("data-theme-name"); + // attribute not set => non-theme stylesheet => ignore + if (themename === null) continue; + // To distinguish the default (primary) theme, it needs to have the data-theme-primary + // attribute set. + if (ss.ownerNode.getAttribute("data-theme-primary") !== null) { + primaryLightTheme = themename; + } + // Check if the theme is primary dark theme so that we could store its name in darkTheme + if (ss.ownerNode.getAttribute("data-theme-primary-dark") !== null) { + primaryDarkTheme = themename; + } + // If we find a matching theme (and it's not the default), we'll set active to non-null + if (themename === theme) active = i; + // Store the style sheets of inactive themes so that we could disable them + if (themename !== theme) disabled.push(ss); + } + var activeTheme = null; + if (active !== null) { + // If we did find an active theme, we'll (1) add the theme--$(theme) class to + document.getElementsByTagName("html")[0].className = "theme--" + theme; + activeTheme = theme; + } else { + // If we did _not_ find an active theme, then we need to fall back to the primary theme + // which can either be dark or light, depending on the user's OS preference. + var activeTheme = darkPreference ? primaryDarkTheme : primaryLightTheme; + // In case it somehow happens that the relevant primary theme was not found in the + // preceding loop, we abort without doing anything. + if (activeTheme === null) { + console.error("Unable to determine primary theme."); + return; + } + // When switching to the primary light theme, then we must not have a class name + // for the tag. That's only for non-primary or the primary dark theme. + if (darkPreference) { + document.getElementsByTagName("html")[0].className = + "theme--" + activeTheme; + } else { + document.getElementsByTagName("html")[0].className = ""; + } + } + for (var i = 0; i < document.styleSheets.length; i++) { + var ss = document.styleSheets[i]; + // The tag of each style sheet is expected to have a data-theme-name attribute + // which must contain the name of the theme. The names in localStorage much match this. + var themename = ss.ownerNode.getAttribute("data-theme-name"); + // attribute not set => non-theme stylesheet => ignore + if (themename === null) continue; + // we'll disable all the stylesheets, except for the active one + ss.disabled = !(themename == activeTheme); + } +} +set_theme_from_local_storage(); diff --git a/previews/PR1697/assets/trixi.drawio b/previews/PR1697/assets/trixi.drawio new file mode 100644 index 00000000000..f13fe4a96ce --- /dev/null +++ b/previews/PR1697/assets/trixi.drawio @@ -0,0 +1 @@ +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 \ No newline at end of file diff --git a/previews/PR1697/assets/warner.js b/previews/PR1697/assets/warner.js new file mode 100644 index 00000000000..3f6f5d0083a --- /dev/null +++ b/previews/PR1697/assets/warner.js @@ -0,0 +1,52 @@ +function maybeAddWarning() { + // DOCUMENTER_NEWEST is defined in versions.js, DOCUMENTER_CURRENT_VERSION and DOCUMENTER_STABLE + // in siteinfo.js. + // If either of these are undefined something went horribly wrong, so we abort. + if ( + window.DOCUMENTER_NEWEST === undefined || + window.DOCUMENTER_CURRENT_VERSION === undefined || + window.DOCUMENTER_STABLE === undefined + ) { + return; + } + + // Current version is not a version number, so we can't tell if it's the newest version. Abort. + if (!/v(\d+\.)*\d+/.test(window.DOCUMENTER_CURRENT_VERSION)) { + return; + } + + // Current version is newest version, so no need to add a warning. + if (window.DOCUMENTER_NEWEST === window.DOCUMENTER_CURRENT_VERSION) { + return; + } + + // Add a noindex meta tag (unless one exists) so that search engines don't index this version of the docs. + if (document.body.querySelector('meta[name="robots"]') === null) { + const meta = document.createElement("meta"); + meta.name = "robots"; + meta.content = "noindex"; + + document.getElementsByTagName("head")[0].appendChild(meta); + } + + const div = document.createElement("div"); + div.classList.add("outdated-warning-overlay"); + const closer = document.createElement("button"); + closer.classList.add("outdated-warning-closer", "delete"); + closer.addEventListener("click", function () { + document.body.removeChild(div); + }); + const href = window.documenterBaseURL + "/../" + window.DOCUMENTER_STABLE; + div.innerHTML = + 'This documentation is not for the latest stable release, but for either the development version or an older release.
Click here to go to the documentation for the latest stable release.'; + div.appendChild(closer); + document.body.appendChild(div); +} + +if (document.readyState === "loading") { + document.addEventListener("DOMContentLoaded", maybeAddWarning); +} else { + maybeAddWarning(); +} diff --git a/previews/PR1697/authors/index.html b/previews/PR1697/authors/index.html new file mode 100644 index 00000000000..fdb20bd47ae --- /dev/null +++ b/previews/PR1697/authors/index.html @@ -0,0 +1,2 @@ + +Authors · Trixi.jl

Authors

Trixi.jl's development is coordinated by a group of principal developers, who are also its main contributors and who can be contacted in case of questions about Trixi.jl. In addition, there are contributors who have provided substantial additions or modifications. Together, these two groups form "The Trixi.jl Authors" as mentioned under License.

Principal Developers

Contributors

The following people contributed major additions or modifications to Trixi.jl and are listed in alphabetical order:

  • Maximilian D. Bertrand
  • Benjamin Bolm
  • Simon Candelaresi
  • Jesse Chan
  • Lars Christmann
  • Christof Czernik
  • Daniel Doehring
  • Patrick Ersing
  • Erik Faulhaber
  • Gregor Gassner
  • Lucas Gemein
  • Sven Goldberg
  • Joshua Lampert
  • Julia Odenthal
  • Sigrun Ortleb
  • Hendrik Ranocha
  • Andrés M. Rueda-Ramírez
  • Felipe Santillan
  • Michael Schlottke-Lakemper
  • Toskan Theine
  • Andrew Winters
diff --git a/previews/PR1697/callbacks/index.html b/previews/PR1697/callbacks/index.html new file mode 100644 index 00000000000..0f1029dd222 --- /dev/null +++ b/previews/PR1697/callbacks/index.html @@ -0,0 +1,15 @@ + +Callbacks · Trixi.jl

Callbacks

Many of the advanced features of Trixi.jl, such as adaptive mesh refinement, are implemented as callbacks. A callback is an algorithmic entity that gets passed to the ODE solver and is called at specific points during execution to perform certain tasks. Callbacks in Trixi.jl are either called after each time step (step callbacks) or after each stage of the ODE solver (stage callbacks).

callbacks_illustration

The advantage of callbacks over hard-coding all features is that it allows to extend Trixi.jl without modifying the internal source code. Trixi.jl provides callbacks for time step control, adaptive mesh refinement, I/O, and more.

Step callbacks

CFL-based time step control

Time step control can be performed with a StepsizeCallback. An example making use of this can be found at examples/tree_2d_dgsem/elixir_advection_basic.jl

Adaptive mesh refinement

Trixi.jl uses a hierarchical Cartesian mesh which can be locally refined in a solution-adaptive way. This can be used to speed up simulations with minimal loss in overall accuracy. Adaptive mesh refinement (AMR) can be used by passing an AMRCallback to the ODE solver. The AMRCallback requires a controller such as ControllerThreeLevel or ControllerThreeLevelCombined to tell the AMR algorithm which cells to refine/coarsen.

An example elixir using AMR can be found at examples/tree_2d_dgsem/elixir_advection_amr.jl.

Analyzing the numerical solution

The AnalysisCallback can be used to analyze the numerical solution, e.g. calculate errors or user-specified integrals, and print the results to the screen. The results can also be saved in a file. An example can be found at examples/tree_2d_dgsem/elixir_euler_vortex.jl. Note that the errors (e.g. L2 error or Linf error) are computed with respect to the initial condition. The percentage of the simulation time refers to the ratio of the current time and the final time, i.e. it does not consider the maximal number of iterations. So the simulation could finish before 100% are reached. Note that, e.g., due to AMR or smaller time step sizes, the simulation can actually take longer than the percentage indicates. In Performance metrics of the AnalysisCallback you can find a detailed description of the different performance metrics the AnalysisCallback computes.

I/O

Solution and restart files

To save the solution in regular intervals you can use a SaveSolutionCallback. It is also possible to create restart files using the SaveRestartCallback. An example making use of these can be found at examples/tree_2d_dgsem/elixir_advection_extended.jl. An example showing how to restart a simulation from a restart file can be found at examples/tree_2d_dgsem/elixir_advection_restart.jl.

Time series

Sometimes it is useful to record the evaluations of state variables over time at a given set of points. This can be achieved by the TimeSeriesCallback, which is used, e.g., in examples/tree_2d_dgsem/elixir_acoustics_gaussian_source.jl. The TimeSeriesCallback constructor expects a semidiscretization and a list of points at which the solution should be recorded in regular time step intervals. After the last time step, the entire record is stored in an HDF5 file.

For the points, two different input formats are supported: You can either provide them as a list of tuples, which is handy if you specify them by hand on the REPL. Alternatively, you can provide them as a two-dimensional array, where the first dimension is the point number and the second dimension is the coordinate dimension. This is especially useful when reading them from a file.

For example, to record the primitive variables at the points (0.0, 0.0) and (-1.0, 0.5) every five timesteps and storing the collected data in the file tseries.h5, you can create the TimeSeriesCallback as

time_series = TimeSeriesCallback(semi, [(0.0, 0.0), (-1.0, 0.5)];
+                                 interval=5,
+                                 solution_variables=cons2prim,
+                                 filename="tseries.h5")

For a full list of possible arguments, please check the documentation for the TimeSeriesCallback. As an alternative to specifying the point coordinates directly in the elixir or on the REPL, you can read them from a file. For instance, with a text file points.dat with content

 0.0 0.0
+-1.0 0.5

you can create a time series callback with

using DelimitedFiles: readdlm
+time_series = TimeSeriesCallback(semi, readdlm("points.dat"))

To plot the individual point data series over time, you can create a PlotData1D from the TimeSeriesCallback and a given point ID. For example, executing

julia> using Trixi, Plots
+
+julia> trixi_include(joinpath(examples_dir(), "tree_2d_dgsem", "elixir_acoustics_gaussian_source.jl"))
+
+julia> pd1 = PlotData1D(time_series, 1)
+
+julia> pd2 = PlotData1D(time_series, 2)
+
+julia> plot(pd1["p_prime"]); plot!(pd2["p_prime"], xguide="t")

will yield the following plot:

image

Miscellaneous

Equation-specific callbacks

Some callbacks provided by Trixi.jl implement specific features for certain equations:

Usage of step callbacks

Step callbacks are passed to the solve method from the ODE solver via the keyword argument callback. If you want to use a single callback cb, pass it as callback=cb. When using two or more callbacks, you need to turn them into a CallbackSet first by calling callbacks = CallbackSet(cb1, cb2) and passing it as callback=callbacks.

Note

There are some restrictions regarding the order of callbacks in a CallbackSet.

The callbacks are called after each time step but some callbacks actually belong to the next time step. Therefore, the callbacks should be ordered in the following way:

  • Callbacks that belong to the current time step:
    • SummaryCallback controls, among other things, timers and should thus be first
    • SteadyStateCallback may mark a time step as the last one
    • AnalysisCallback may do some checks that mark a time step as the last one
    • AliveCallback should be nearby AnalysisCallback
    • SaveSolutionCallback/SaveRestartCallback should save the current solution before it is degraded by AMR
    • VisualizationCallback should be called before the mesh is adapted
  • Callbacks that belong to the next time step:
    • AMRCallback
    • StepsizeCallback must be called after AMRCallback to accommodate potential changes to the mesh
    • GlmSpeedCallback must be called after StepsizeCallback because the step size affects the value of c_h
    • LBMCollisionCallback is already part of the calculations of the next time step and should therefore be called after StepsizeCallback

Stage callbacks

PositivityPreservingLimiterZhangShu is a positivity-preserving limiter, used to enforce physical constraints. An example elixir using this feature can be found at examples/tree_2d_dgsem/elixir_euler_positivity.jl.

Implementing new callbacks

Since Trixi.jl is compatible with OrdinaryDiffEq.jl, both packages share the same callback interface. A detailed description of it can be found in the OrdinaryDiffEq.jl documentation. Step callbacks are just called callbacks. Stage callbacks are called stage_limiter!.

An example elixir showing how to implement a new simple stage callback and a new simple step callback can be found at examples/tree_2d_dgsem/elixir_advection_callbacks.jl.

diff --git a/previews/PR1697/code_of_conduct/index.html b/previews/PR1697/code_of_conduct/index.html new file mode 100644 index 00000000000..64b50c76402 --- /dev/null +++ b/previews/PR1697/code_of_conduct/index.html @@ -0,0 +1,2 @@ + +Code of Conduct · Trixi.jl

Code of Conduct

Contributor Covenant Code of Conduct

Our Pledge

We as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, religion, or sexual identity and orientation.

We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.

Our Standards

Examples of behavior that contributes to a positive environment for our community include:

  • Demonstrating empathy and kindness toward other people
  • Being respectful of differing opinions, viewpoints, and experiences
  • Giving and gracefully accepting constructive feedback
  • Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
  • Focusing on what is best not just for us as individuals, but for the overall community

Examples of unacceptable behavior include:

  • The use of sexualized language or imagery, and sexual attention or advances of any kind
  • Trolling, insulting or derogatory comments, and personal or political attacks
  • Public or private harassment
  • Publishing others' private information, such as a physical or email address, without their explicit permission
  • Other conduct which could reasonably be considered inappropriate in a professional setting

Enforcement Responsibilities

Community leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.

Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.

Scope

This Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.

Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to Michael Schlottke-Lakemper, Hendrik Ranocha, or any other of the principal developers responsible for enforcement listed in Authors. All complaints will be reviewed and investigated promptly and fairly.

All community leaders are obligated to respect the privacy and security of the reporter of any incident.

Enforcement Guidelines

Community leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:

1. Correction

Community Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.

Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.

2. Warning

Community Impact: A violation through a single incident or series of actions.

Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.

3. Temporary Ban

Community Impact: A serious violation of community standards, including sustained inappropriate behavior.

Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.

4. Permanent Ban

Community Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.

Consequence: A permanent ban from any sort of public interaction within the community.

Attribution

This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 2.0, available at https://www.contributor-covenant.org/version/2/0/codeofconduct.html.

Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.

[homepage]: https://www.contributor-covenant.org

For answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.

diff --git a/previews/PR1697/contributing/index.html b/previews/PR1697/contributing/index.html new file mode 100644 index 00000000000..1c139748b46 --- /dev/null +++ b/previews/PR1697/contributing/index.html @@ -0,0 +1,38 @@ + +Contributing · Trixi.jl

Contributing

Trixi.jl is an open-source project and we are very happy to accept contributions from the community. Please feel free to open issues or submit patches (preferably as merge requests) any time. For planned larger contributions, it is often beneficial to get in contact with one of the principal developers first (see Authors).

Trixi.jl and its contributions are licensed under the MIT license (see License). As a contributor, you certify that all your contributions are in conformance with the Developer Certificate of Origin (Version 1.1), which is reproduced below.

Developer Certificate of Origin (Version 1.1)

The following text was taken from https://developercertificate.org:

Developer Certificate of Origin
+Version 1.1
+
+Copyright (C) 2004, 2006 The Linux Foundation and its contributors.
+1 Letterman Drive
+Suite D4700
+San Francisco, CA, 94129
+
+Everyone is permitted to copy and distribute verbatim copies of this
+license document, but changing it is not allowed.
+
+
+Developer's Certificate of Origin 1.1
+
+By making a contribution to this project, I certify that:
+
+(a) The contribution was created in whole or in part by me and I
+    have the right to submit it under the open source license
+    indicated in the file; or
+
+(b) The contribution is based upon previous work that, to the best
+    of my knowledge, is covered under an appropriate open source
+    license and I have the right under that license to submit that
+    work with modifications, whether created in whole or in part
+    by me, under the same open source license (unless I am
+    permitted to submit under a different license), as indicated
+    in the file; or
+
+(c) The contribution was provided directly to me by some other
+    person who certified (a), (b) or (c) and I have not modified
+    it.
+
+(d) I understand and agree that this project and the contribution
+    are public and that a record of the contribution (including all
+    personal information I submit with it, including my sign-off) is
+    maintained indefinitely and may be redistributed consistent with
+    this project or the open source license(s) involved.
diff --git a/previews/PR1697/conventions/index.html b/previews/PR1697/conventions/index.html new file mode 100644 index 00000000000..013317adc36 --- /dev/null +++ b/previews/PR1697/conventions/index.html @@ -0,0 +1,2 @@ + +Conventions · Trixi.jl

Conventions

Spatial dimensions and directions

We use the following numbering schemes on Cartesian or curved structured meshes.

  • The orientations are numbered as 1 => x, 2 => y, 3 => z. For example, numerical fluxes such as flux_central(u_ll, u_rr, orientation, equations::AbstractEquations) use the orientation in this way.
  • The directions are numbered as 1 => -x, 2 => +x, 3 => -y, 4 => +y, 5 => -z, 6 => +z. For example, the boundary_conditions are ordered in this way when a Tuple of boundary conditions per direction is passed to the constructor of a SemidiscretizationHyperbolic.
  • For structured and unstructured curved meshes the concept of direction is generalized via the variable normal_direction. This variable points in the normal direction at a given, curved surface. For the computation of boundary fluxes the normal_direction is normalized to be a normal_vector used, for example, in FluxRotated.

Cells vs. elements vs. nodes

To uniquely distinguish between different components of the discretization, we use the following naming conventions:

  • The computational domain is discretized by a mesh, which is made up of individual cells. In general, neither the mesh nor the cells should be aware of any solver-specific knowledge, i.e., they should not store anything that goes beyond the geometrical information and the connectivity.
  • The numerical solvers do not directly store their information inside the mesh, but use own data structures. Specifically, for each cell on which a solver wants to operate, the solver creates an element to store solver-specific data.
  • For discretization schemes such as the discontinuous Galerkin or the finite element method, inside each element multiple nodes may be defined, which hold nodal information. The nodes are again a solver-specific component, just like the elements.
  • We often identify elements, nodes, etc. with their (local or global) integer index. Convenience iterators such as eachelement, eachnode use these indices.

Keywords in elixirs

Trixi.jl is distributed with several examples in the form of elixirs, small Julia scripts containing everything to set up and run a simulation. Working interactively from the Julia REPL with these scripts can be quite convenient while for exploratory research and development of Trixi.jl. For example, you can use the convenience function trixi_include to include an elixir with some modified arguments. To enable this, it is helpful to use a consistent naming scheme in elixirs, since trixi_include can only perform simple replacements. Some standard variables names are

  • polydeg for the polynomial degree of a solver
  • surface_flux for the numerical flux at surfaces
  • volume_flux for the numerical flux used in flux differencing volume terms

Moreover, convergence_test requires that the spatial resolution is set via the keywords

Variable names

  • Use descriptive names (using snake_case for variables/functions and CamelCase for types)
  • Use a suffix _ as in name_ for local variables that would otherwise hide existing symbols.
  • Use a prefix _ as in _name to indicate internal methods/data that are "fragile" in the sense that there's no guarantee that they might get changed without notice. These are also not documented with a docstring (but maybe with comments using #).

Array types and wrapping

To allow adaptive mesh refinement efficiently when using time integrators from OrdinaryDiffEq, Trixi.jl allows to represent numerical solutions in two different ways. Some discussion can be found online and in form of comments describing Trixi.wrap_array and Trixi.wrap_array_native in the source code of Trixi.jl. The flexibility introduced by this possible wrapping enables additional performance optimizations. However, it comes at the cost of some additional abstractions (and needs to be used with caution, as described in the source code of Trixi.jl). Thus, we use the following conventions to distinguish between arrays visible to the time integrator and wrapped arrays mainly used internally.

  • Arrays visible to the time integrator have a suffix _ode, e.g., du_ode, u_ode.
  • Wrapped arrays do not have a suffix, e.g., du, u.

Methods either accept arrays visible to the time integrator or wrapped arrays based on the following rules.

  • When some solution is passed together with a semidiscretization semi, the solution must be a u_ode that needs to be wrapped via wrap_array(u_ode, semi) (or wrap_array_native(u_ode, semi)) for further processing.
  • When some solution is passed together with the mesh, equations, solver, cache, ..., it is already wrapped via wrap_array (or wrap_array_native).
  • Exceptions of this rule are possible, e.g. for AMR, but must be documented in the code.
  • wrap_array should be used as default option. wrap_array_native should only be used when necessary, e.g., to avoid additional overhead when interfacing with external C libraries such as HDF5, MPI, or visualization.
diff --git a/previews/PR1697/development/index.html b/previews/PR1697/development/index.html new file mode 100644 index 00000000000..355bcefa47d --- /dev/null +++ b/previews/PR1697/development/index.html @@ -0,0 +1,42 @@ + +Development · Trixi.jl

Development

Interactive use of Julia

When a Julia program is executed, Julia first loads and parses all code. Then, the just-in-time compiler has to compile all functions at their first use, which incurs an overhead each time a program is run. For proper packages and commands executed in the REPL (= "return-eval-print loop", which is what the Julia community calls the interactive command-line prompt that opens when executing julia without any files as arguments), however, the previously compiled functions are cached. Therefore, Trixi.jl should generally always be used interactively from the REPL without closing Julia during development, as it allows much faster turnaround times.

If you naively run Trixi.jl from the REPL, you will not be able to change your Trixi.jl source files and then run the changed code without restarting the REPL, which destroys any potential benefits from caching. However, restarting Julia can be avoided by using the Revise.jl package, which tracks changed files and re-loads them automatically. Therefore, it is highly recommended to first install Revise with the following command in Julia: To enter the package REPL mode, press ] in the standard Julia REPL mode. Then, execute

(@v1.9) pkg> add Revise

Now you are able to run Trixi.jl from the REPL, change Trixi.jl code between runs, and enjoy the advantages of the compilation cache! Before you start using Revise regularly, please be aware of some of the Pitfalls when using Revise.

Another recommended package for working from the REPL is OhMyREPL.jl. It can be installed by running

(@v1.9) pkg> add OhMyREPL

and adds syntax highlighting, bracket highlighting, and other helpful improvements for using Julia interactively. To automatically use OhMyREPL when starting the REPL, follow the instructions given in the official documentation.

Running Trixi.jl interactively in the global environment

If you've installed Trixi.jl and Revise in your default environment, begin by executing:

julia

This will start the Julia REPL. Then, run

julia> using Revise; using Trixi

You can run a simulation by executing

julia> trixi_include(default_example())

Together, all of these commands can take some time, roughly half a minute on a modern workstation. Most of the time is spent on compilation of Julia code etc. If you execute the last command again in the same REPL, it will finish within a few milliseconds (maybe ~45 on a modern workstation). This demonstrates the second reason for using the REPL: the compilation cache. That is, those parts of the code that do not change between two Trixi.jl runs do not need to be recompiled and thus execute much faster after the first run.

Manually starting Trixi.jl in the local environment

If you followed the installation instructions for developers, execute Julia with the project directory set to the run directory of the program/tool you want to use. For example, to run Trixi.jl this way, you need to start the REPL with

julia --project=path/to/Trixi.jl/run

and execute

julia> using Revise; using Trixi

to load Revise and Trixi.jl. You can then proceed with the usual commands and run Trixi.jl as in the example above. The --project flag is required such that Julia can properly load Trixi.jl and all dependencies if Trixi.jl is not installed in the global environment. The same procedure also applies should you opt to install the postprocessing tool Trixi2Vtk manually such that you can modify their implementations.

Pitfalls when using Revise

While Revise is a great help for developing Julia code, there are a few situations to watch out for when using Revise. The following list of potential issues is based on personal experiences of the Trixi.jl developers and probably incomplete. Further information on limitations and possible issues with Revise can be found in the official documentation.

If in doubt, restart the REPL

Oftentimes, it is possible to recover from issues with Revise by fixing the offending code. Sometimes, however, this is not possible or you might have troubles finding out what exactly caused the problems. Therefore, in these cases, or if in doubt, restart the REPL to get a fresh start.

Syntax errors are easy to miss

Revise does not stop on syntax errors, e.g., when you accidentally write a[i) instead of a[i]. In this case, Revise reports an error but continues to use the old version of your files! This is especially dangerous for syntax errors, as they are detected while Revise reloads changed code, which happens in the beginning of a new execution. Thus, the syntax error message quickly disappears from the terminal once Trixi.jl starts writing output to the screen and you might not even have noticed that an error occurred at all.

Therefore, when you are deep in a coding/debugging session and wonder why your code modifications do not seem to have any effect, scroll up in your terminal to check if you missed earlier syntax errors, or - if in doubt - restart your REPL.

Files are not tracked after changing branches

Sometimes, Revise stops tracking files when changing the Git branch. That is, modifications to Trixi.jl's source files will not be reloaded by Revise and thus have no effect of a currently running REPL session. This issue is particularly annoying for a developer, since it does not come with any warning! Therefore, it is good practice to always restart the REPL after changing branches.

Changes to type definitions are not allowed

Revise cannot handle changes to type definitions, e.g., when modifying the fields in a struct. In this case, Revise reports an error and refuses to run your code unless you undo the modifications. Once you undo the changes, Revise will usually continue to work as expected again. However, if you want to keep your type modifications, you need to restart the REPL.

Using the Julia REPL effectively

The Julia manual is an excellent resource to learn Julia. Here, we list some helpful commands than can increase your productivity in the Julia REPL.

  • Use the REPL help mode entered by typing ?.

    julia> using Trixi
    +
    +help?> trixi_include
    +search: trixi_include
    +
    +  trixi_include([mod::Module=Main,] elixir::AbstractString; kwargs...)
    +
    +  include the file elixir and evaluate its content in the global scope of module mod. You can override specific
    +  assignments in elixir by supplying keyword arguments. It's basic purpose is to make it easier to modify some
    +  parameters while running Trixi.jl from the REPL. Additionally, this is used in tests to reduce the computational
    +  burden for CI while still providing examples with sensible default values for users.
    +
    +  Examples
    +  ≡≡≡≡≡≡≡≡≡≡
    +
    +  julia> trixi_include(@__MODULE__, default_example(), tspan=(0.0, 0.1))
    +  [...]
    +
    +  julia> sol.t[end]
    +  0.1
  • You can copy and paste REPL history including julia> prompts into the REPL.

  • Use tab completion in the REPL, both for names of functions/types/variables and for function arguments.

    julia> flux_ranocha( # and TAB
    +flux_ranocha(u_ll, u_rr, orientation::Integer, equations::CompressibleEulerEquations1D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_1d.jl:390
    +flux_ranocha(u_ll, u_rr, orientation::Integer, equations::CompressibleEulerEquations2D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_2d.jl:839
    +[...]
  • Use methodswith to discover methods associated to a given type etc.

    julia> methodswith(CompressibleEulerEquations2D)
    +[1] initial_condition_convergence_test(x, t, equations::CompressibleEulerEquations2D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_2d.jl:51
    +[...]
  • Use @which (or @edit) for method calls.

    julia> @which trixi_include(default_example())
    +trixi_include(elixir::AbstractString; kwargs...) in Trixi at ~/.julia/dev/Trixi/src/auxiliary/special_elixirs.jl:36
  • Use apropos to search through the documentation and docstrings.

    julia> apropos("MHD")
    +Trixi.IdealGlmMhdEquations3D
    +Trixi.IdealGlmMhdMulticomponentEquations2D
    +Trixi.calc_fast_wavespeed_roe
    +Trixi.IdealGlmMhdEquations1D
    +Trixi.initial_condition_constant
    +Trixi.flux_nonconservative_powell
    +Trixi.GlmSpeedCallback
    +Trixi.flux_derigs_etal
    +Trixi.flux_hindenlang_gassner
    +Trixi.initial_condition_convergence_test
    +Trixi.min_max_speed_naive
    +Trixi.IdealGlmMhdEquations2D
    +Trixi.IdealGlmMhdMulticomponentEquations1D
    +[...]

Text editors

When writing code, the choice of text editor can have a significant impact on productivity and developer satisfaction. While using the default text editor of the operating system has its own benefits (specifically the lack of an explicit installation procure), usually it makes sense to switch to a more programming-friendly tool. In the following, a few of the many options are listed and discussed:

VS Code

Visual Studio Code is a modern open source editor with good support for Julia. While Juno had some better support in the past, the developers of Juno and the Julia VS Code plugin are joining forces and concentrating on VS Code since support of Atom has been suspended. Basically, all comments on Juno below also apply to VS Code.

Juno

If you are new to programming or do not have a preference for a text editor yet, Juno is a good choice for developing Julia code. It is based on Atom, a sophisticated and widely used editor for software developers, and is enhanced with several Julia-specific features. Furthermore and especially helpful for novice programmers, it has a MATLAB-like appearance with easy and interactive access to the current variables, the help system, and a debugger.

Vim or Emacs

Vim and Emacs are both very popular editors that work great with Julia. One of their advantages is that they are text editors without a GUI and as such are available for almost any operating system. They also are preinstalled on virtually all Unix-like systems. However, Vim and Emacs come with their own, steep learning curve if they have never been used before. Therefore, if in doubt, it is probably easier to get started with a classic GUI-based text editor (like Juno). If you decide to use Vim or Emacs, make sure that you install the corresponding Vim plugin julia-vim or Emacs major mode julia-emacs.

Debugging

Julia offers several options for debugging. A classical debugger is available with the Debugger.jl package or in the Julia extension for VS Code. However, it can be quite slow and, at the time of writing (January 2023), currently does not work properly with Trixi.jl. The Infiltrator.jl package on the other hand does not offer all features of a full debugger, but is a fast and simple tool that allows users to set breakpoints to open a local REPL session and access the call stack and variables.

Infiltrator

The Infiltrator package provides fast, interactive breakpoints using the @infiltrate command, which drops the user into a local REPL session. From there, it is possible to access local variables, see the call stack, and execute statements.

The package can be installed in the Julia REPL by executing

(@v1.9) pkg> add Infiltrator

To load the package in the Julia REPL execute

julia> using Infiltrator

Breakpoints can be set by adding a line with the @infiltrate macro at the respective position in the code. Use Revise if you want to set and delete breakpoints in your package without having to restart Julia.

Use `@autoinfiltrate` when debugging Trixi.jl

When running Julia inside a package environment, e.g., inside the source code of Trixi.jl itself, the @infiltrate macro only works if Infiltrator has been added to the package dependencies. To avoid this, you can use the (non-exported) @autoinfiltrate macro in Trixi.jl, which only requires Infiltrator.jl to be available in the current environment stack and will auto-load it for you.

Triggering the breakpoint starts a REPL session where it is possible to interact with the current local scope. Possible commands are:

  • @locals: Print the local variables.
  • @exfiltrate: Save the local variables to a global storage, which can be accessed with the safehouse variable outside the Infiltrator session.
  • @trace: Print the current stack trace.
  • Execute other arbitrary statements
  • ?: Print a help list with all options

To finish a debugging session, either use @continue to continue and eventually stop at the next breakpoint or @exit to skip further breakpoints. After the code has finished, local variables saved with @exfiltrate can be accessed in the REPL using the safehouse variable.

Limitations of using Infiltrator.jl are that local variables cannot be changed, and that it is not possible to step into further calls or access other function scopes.

Releasing a new version of Trixi.jl, Trixi2Vtk

  • Check whether everything is okay, tests pass etc.

  • Set the new version number in Project.toml according to the Julian version of semver. Commit and push.

  • Comment @JuliaRegistrator register on the commit setting the version number.

  • JuliaRegistrator will create a PR with the new version in the General registry. Wait for it to be merged.

  • Increment the version number in Project.toml again with suffix -pre. For example, if you have released version v0.2.0, use v0.2.1-pre as new version number.

  • When a new version of Trixi.jl was released, check whether the [compat] entries in test/Project.toml in Trixi2Vtk should be updated. When a new version of Trixi2Vtk was released, check whether the [compat] entries in docs/Project.toml in Trixi.jl should be updated.

    These entries will also be checked regularly by CompatHelper (once a day). Hence, if everything was released correctly, you should only need to do these checks manually if new minor versions with changes in the docs of Trixi2Vtk were released but no new version of Trixi.jl was released afterwards.

Preview of the documentation

You can build the documentation of Trixi.jl locally by running

julia --project=docs -e 'using Pkg; Pkg.develop(PackageSpec(path=pwd())); Pkg.instantiate()'
+julia --project=docs --color=yes docs/make.jl

from the Trixi.jl main directory. Then, you can look at the html files generated in docs/build. For PRs triggered from branches inside the Trixi.jl main repository previews of the new documentation are generated at https://trixi-framework.github.io/Trixi.jl/previews/PRXXX, where XXX is the number of the PR. This does not work for PRs from forks for security reasons (since anyone could otherwise push arbitrary stuff to the Trixi.jl website, including malicious code).

Developing Trixi2Vtk

Trixi2Vtk has Trixi.jl as dependency and uses Trixi.jl's implementation to, e.g., load mesh files. When developing Trixi2Vtk, one may want to change functions in Trixi.jl to allow them to be reused in Trixi2Vtk. To use a locally modified Trixi.jl clone instead of a Trixi.jl release, one can tell Pkg to use the local source code of Trixi.jl instead of a registered version by running

(@v1.9) pkg> develop path/to/Trixi.jl
diff --git a/previews/PR1697/github-git/index.html b/previews/PR1697/github-git/index.html new file mode 100644 index 00000000000..73810b718c8 --- /dev/null +++ b/previews/PR1697/github-git/index.html @@ -0,0 +1,44 @@ + +GitHub & Git · Trixi.jl

GitHub & Git

This page contains information on how to use GitHub and Git when developing Trixi.jl.

Development workflow

For adding modifications to Trixi.jl, we generally follow these steps:

Create an issue (optional)

In many cases it makes sense to start by creating an issue on GitHub. For example, if the implementation approach for a new feature is not yet clear or if there should be a discussion about the desired outcome, it is good practice to first get a consensus on what is the expected result of this modification. A GitHub issue is the place to lead this discussion, as it preserves it in the project and - together with the actual code changes - allows in the future to revisit the reasons for a particular choice of implementation or feature.

Create a branch and immediately create a pull request

All feature development, bug fixes etc. should be developed in a branch and not directly on main. If you do not have write access to the main repository on GitHub, first create a fork of the Trixi.jl repository and clone the fork to your machine. Then, create a branch locally by executing git checkout -b yourbranch, push it to the repository, and create a pull request (PR).

If you have already cloned Trixi.jl from the main repo to your local machine, you can also work in that clone. You just need to add your fork as additional remote repository and push your new branch there.

git remote add myfork git@github.com:YOUR_NAME/Trixi.jl.git
+# get latest main from the main repo
+git checkout main
+git pull
+# create a new branch for a cool new feature, bug fix, ...
+git checkout -b YOUR_BRANCH_NAME
+# do some work and push it to your fork
+git push -u myfork
+# go to https://github.com/trixi-framework/Trixi.jl/pull
+# and create a PR from your new branch
Why using pull requests?

Immediately creating a PR for your branch has the benefit that all code discussions can now be held directly next to the corresponding code. Also, the PR allows to easily compare your branch to the upstream branch (usually main) to see what you have changed. Moreover, tests will run automatically.

Make changes

With a branch and PR in place, you can now write your code and commit it to your branch. If you request feedback from someone else, make sure to push your branch to the repository such that the others can easily review your changes or dive in and change something themselves.

Avoid committing unwanted files

When you use git add . or similar catch-all versions, make sure you do not accidentally commit unwanted files (e.g., Trixi.jl output files, images or videos etc.). If it happens anyways, you can undo the last commit (also multiple times) by running git reset HEAD~ (see also Undo last commit). However, this strategy only works if you have not yet pushed your changes. If you did push your changes, please talk to one of the core developers on how to proceed.

Keep your branch in sync with main

For larger features with longer-living branches, it may make sense to synchronize your branch with the current main, e.g., if there was a bug fix in main that is relevant for you. In this case, perform the following steps to merge the current main to your branch:

  1. Commit all your local changes to your branch and push it. This allows you to delete your clone in case you make a mistake and need to abort the merge.
  2. Execute git fetch to get the latest changes from the repository.
  3. Make sure you are in the correct branch by checking the output of git status or by running git checkout yourbranch.
  4. Merge main using git merge main. If there were no conflicts, hooray!, you are done. Otherwise you need to resolve your merge conflicts and commit the changes afterwards. A good guide for resolving merge conflicts can be found here.

In general, always use git merge and not git rebase to get the latest changes from main. It is less error-prone and does not create problems on branches that are worked on collaboratively.

Prepare for review

If you feel like your branch is ready to be merged to main, prepare it for review. That is, you should

  • merge the current main to your branch
  • run tests if available, but at least ensure that you did not accidentally change the results for one of the existing example elixirs
  • properly comment your code
  • delete old/unused code, especially commented lines (unless they contain helpful code, in which case you should add a comment on why you keep this around)
  • remove debug statements
  • add a elixir_xxx.jl that uses your feature (only relevant for new features)
  • make sure your code formatting adheres to the Style guide
  • describe changes in NEWS.md if appropriate

After you are confident that your branch is cleaned up properly, commit all changes and push them to the repository.

Get reviewed

Ask one of the core developers to review your code. Sometimes this will be done directly, either face-to-face or via a video call. Other times a review will be conducted asynchronously, with the reviewer leaving comments and annotations. In some cases it will be necessary to do multiple rounds of reviews, especially if there are larger changes to be added. Just commit and push your changes to your branch, and the corresponding pull request will be updated automatically.

Please note that a review has nothing to do with the lack of experience of the person developing changes: We try to review all code before it gets added to main, even from the most experienced developers. This is good practice and helps to keep the error rate low while ensuring that the code is developed in a consistent fashion. Furthermore, do not take criticism of your code personally - we just try to keep Trixi.jl as accessible and easy to use for everyone.

Merge branch

Once your branch is reviewed and declared ready for merging by the reviewer, make sure that all the latest changes have been pushed. Then, one of the developers will merge your PR. If you are one of the developers, you can also go to the pull request page on GitHub and and click on Merge pull request. Voilà, you are done! Your branch will have been merged to main and the source branch will have been deleted in the GitHub repository (if you are not working in your own fork).

Update your working copy

Once you have merged your branch by accepting the PR on GitHub, you should clean up your local working copy of the repository by performing the following steps:

  1. Update your clone by running git fetch.
  2. Check out main using git checkout main.
  3. Delete merged branch locally with git branch -d yourbranch.
  4. Remove local references to deleted remote branch by executing git remote prune origin.

You can now proceed with your next changes by starting again at the top.

Using Git

Resources for learning Git

Here are a few resources for learning do use Git that at least one of us found helpful in the past (roughly ordered from novice to advanced to expert):

Tips and tricks

This is an unordered collection of different tips and tricks that can be helpful while working with Git. As usual, your mileage might vary.

Undo last commit

If you made a mistake in your last commit, e.g., by committing an unwanted file, you can undo the latest commit by running

git reset HEAD~

This only works if you have not yet pushed your branch to the GitHub repository. In this case, please talk to one of the core developers on how to proceed. Especially when you accidentally committed a large file (image, or video), please let us know as fast as possible, since the effort to fix the repository grows considerably over time.

Remove large file from repository

If a large file was accidentally committed and pushed to the Trixi.jl repository, please talk to one of the core developers as soon as possible so that they can fix it.

Large files

You should never try to fix this yourself, as it potentially disrupts/destroys the work of others!

Based on the instructions found here and here, the following steps need to be taken (as documented for GitLab in issue #33):

  1. Tell everyone to commit and push their changes to the repository.

  2. Fix the branch in which the file was committed by removing it and committing the removal. This is especially important on main.

  3. Perform the following steps to clean up the Git repository:

    cd /tmp
    +
    +# Download bfg-1.13.0.jar from https://rtyley.github.io/bfg-repo-cleaner/
    +
    +# Get fresh clone of repo (so you can throw it away in case there is a problem)
    +git clone --mirror git@github.com:trixi-framework/Trixi.jl.git
    +
    +# Clean up repo of all files larger than 10M
    +java -jar bfg-1.13.0.jar --strip-blobs-bigger-than 10M Trixi.jl.git
    +
    +# Enter repo
    +cd Trixi.jl.git
    +
    +# Clean up reflog and force aggressive garbage collection
    +git reflog expire --expire=now --all && git gc --prune=now --aggressive
    +
    +# Push changes
    +git push
    +
    +# Delete clone
    +rm -rf Trixi.jl.git
  4. Tell everyone to clean up their local working copies by performing the following steps (also do this yourself):

    # Enter repo
    +cd Trixi.jl
    +
    +# Get current changes
    +git fetch
    +
    +# Check out the fixed branch
    +git checkout branchname
    +
    +# IMPORTANT: Do a rebase instead of a pull!
    +git rebase
    +
    +# Clean reflog and force garbage collection
    +git reflog expire --expire=now --all && git gc --prune=now --aggressive

    IMPORTANT: You need to do a git rebase instead of a git pull when updating the fixed branch.

diff --git a/previews/PR1697/index.html b/previews/PR1697/index.html new file mode 100644 index 00000000000..35516017452 --- /dev/null +++ b/previews/PR1697/index.html @@ -0,0 +1,104 @@ + +Home · Trixi.jl

Trixi.jl

Docs-stable Docs-dev Slack Youtube Build Status Codecov Coveralls Aqua QA License: MIT DOI

Trixi.jl is a numerical simulation framework for hyperbolic conservation laws written in Julia. A key objective for the framework is to be useful to both scientists and students. Therefore, next to having an extensible design with a fast implementation, Trixi.jl is focused on being easy to use for new or inexperienced users, including the installation and postprocessing procedures. Its features include:

  • 1D, 2D, and 3D simulations on line/quad/hex/simplex meshes
    • Cartesian and curvilinear meshes
    • Conforming and non-conforming meshes
    • Structured and unstructured meshes
    • Hierarchical quadtree/octree grid with adaptive mesh refinement
    • Forests of quadtrees/octrees with p4est via P4est.jl
  • High-order accuracy in space and time
  • Discontinuous Galerkin methods
  • Compatible with the SciML ecosystem for ordinary differential equations
  • Native support for differentiable programming
  • Periodic and weakly-enforced boundary conditions
  • Multiple governing equations:
    • Compressible Euler equations
    • Magnetohydrodynamics (MHD) equations
    • Multi-component compressible Euler and MHD equations
    • Linearized Euler and acoustic perturbation equations
    • Hyperbolic diffusion equations for elliptic problems
    • Lattice-Boltzmann equations (D2Q9 and D3Q27 schemes)
    • Shallow water equations
    • Scalar advection
  • Multi-physics simulations
  • Shared-memory parallelization via multithreading
  • Visualization and postprocessing of the results
    • In-situ and a posteriori visualization with Plots.jl
    • Interactive visualization with Makie.jl
    • Postprocessing with ParaView/VisIt via Trixi2Vtk

Installation

If you have not yet installed Julia, please follow the instructions for your operating system. Trixi.jl works with Julia v1.8 and newer. We recommend using the latest stable release of Julia.

For users

Trixi.jl and its related tools are registered Julia packages. Hence, you can install Trixi.jl, the visualization tool Trixi2Vtk, OrdinaryDiffEq.jl, and Plots.jl by executing the following commands in the Julia REPL:

julia> using Pkg
+
+julia> Pkg.add(["Trixi", "Trixi2Vtk", "OrdinaryDiffEq", "Plots"])

You can copy and paste all commands to the REPL including the leading julia> prompts - they will automatically be stripped away by Julia. The package OrdinaryDiffEq.jl provides time integration schemes used by Trixi.jl, while Plots.jl can be used to directly visualize Trixi.jl's results from the REPL.

Note on package versions: If some of the examples for how to use Trixi.jl do not work, verify that you are using a recent Trixi.jl release by comparing the installed Trixi.jl version from

julia> using Pkg; Pkg.update("Trixi"); Pkg.status("Trixi")

to the latest release. If the installed version does not match the current release, please check the Troubleshooting section.

The commands above can also be used to update Trixi.jl. A brief list of notable changes to Trixi.jl is available in NEWS.md.

For developers

If you plan on editing Trixi.jl itself, you can download Trixi.jl to a local folder and use the code from the cloned directory:

git clone git@github.com:trixi-framework/Trixi.jl.git
+cd Trixi.jl
+mkdir run
+cd run
+julia --project=. -e 'using Pkg; Pkg.develop(PackageSpec(path=".."))'

If you installed Trixi.jl this way, you always have to start Julia with the --project flag set to your run directory, e.g.,

julia --project=.

if already inside the run directory.

The advantage of using a separate run directory is that you can also add other related packages (see below, e.g., for time integration or visualization) to the project in the run folder and always have a reproducible environment at hand to share with others.

Since the postprocessing tool Trixi2Vtk.jl typically does not need to be modified, it is recommended to install it as a normal package. Likewise, you can install OrdinaryDiffEq.jl and Plots.jl as ordinary packages. To achieve this, use the following REPL commands:

julia> using Pkg
+
+julia> Pkg.add(["OrdinaryDiffEq", "Trixi2Vtk", "Plots"])

Note that the postprocessing tools Trixi2Vtk.jl and Plots.jl are optional and can be omitted.

Example: Installing Trixi.jl as a package

Please note that the playback speed is set to 3x, thus the entire installation procedure lasts around 45 seconds in real time (depending on the performance of your computer and on how many dependencies had already been installed before).

Usage

In the Julia REPL, first load the package Trixi.jl

julia> using Trixi

Then start a simulation by executing

julia> trixi_include(default_example())

Please be patient since Julia will compile the code just before running it. To visualize the results, load the package Plots

julia> using Plots

and generate a heatmap plot of the results with

julia> plot(sol) # No trailing semicolon, otherwise no plot is shown

This will open a new window with a 2D visualization of the final solution:

image

The method trixi_include(...) expects a single string argument with the path to a Trixi.jl elixir, i.e., a text file containing Julia code necessary to set up and run a simulation. To quickly see Trixi.jl in action, default_example() returns the path to an example elixir with a short, two-dimensional problem setup. A list of all example elixirs packaged with Trixi.jl can be obtained by running get_examples(). Alternatively, you can also browse the examples/ subdirectory. If you want to modify one of the elixirs to set up your own simulation, download it to your machine, edit the configuration, and pass the file path to trixi_include(...).

Example: Running a simulation with Trixi.jl

If this produces weird symbols or question marks in the terminal on your system, you are probably using Mac OS with problematic fonts. In that case, please check the Troubleshooting section.

Note on performance: Julia uses just-in-time compilation to transform its source code to native, optimized machine code at the time of execution and caches the compiled methods for further use. That means that the first execution of a Julia method is typically slow, with subsequent runs being much faster. For instance, in the example above the first execution of trixi_include takes about 20 seconds, while subsequent runs require less than 60 milliseconds.

Performing a convergence analysis

To automatically determine the experimental order of convergence (EOC) for a given setup, execute

julia> convergence_test(default_example(), 4)

This will run a convergence test with the elixir default_example(), using four iterations with different initial refinement levels. The initial iteration will use the elixir unchanged, while for each subsequent iteration the initial_refinement_level parameter is incremented by one. Finally, the measured $l^2$ and $l^\infty$ errors and the determined EOCs will be displayed like this:

[...]
+l2
+scalar
+error     EOC
+9.14e-06  -
+5.69e-07  4.01
+3.55e-08  4.00
+2.22e-09  4.00
+
+mean      4.00
+--------------------------------------------------------------------------------
+linf
+scalar
+error     EOC
+6.44e-05  -
+4.11e-06  3.97
+2.58e-07  3.99
+1.62e-08  4.00
+
+mean      3.99
+--------------------------------------------------------------------------------

An example with multiple variables looks like this:

julia> convergence_test(joinpath(examples_dir(), "tree_2d_dgsem", "elixir_euler_source_terms.jl"), 3)
[...]
+l2
+rho                 rho_v1              rho_v2              rho_e
+error     EOC       error     EOC       error     EOC       error     EOC
+9.32e-07  -         1.42e-06  -         1.42e-06  -         4.82e-06  -
+7.03e-08  3.73      9.53e-08  3.90      9.53e-08  3.90      3.30e-07  3.87
+4.65e-09  3.92      6.09e-09  3.97      6.09e-09  3.97      2.12e-08  3.96
+
+mean      3.82      mean      3.93      mean      3.93      mean      3.91
+--------------------------------------------------------------------------------
+linf
+rho                 rho_v1              rho_v2              rho_e
+error     EOC       error     EOC       error     EOC       error     EOC
+9.58e-06  -         1.17e-05  -         1.17e-05  -         4.89e-05  -
+6.23e-07  3.94      7.48e-07  3.97      7.48e-07  3.97      3.22e-06  3.92
+4.05e-08  3.94      4.97e-08  3.91      4.97e-08  3.91      2.10e-07  3.94
+
+mean      3.94      mean      3.94      mean      3.94      mean      3.93
+--------------------------------------------------------------------------------

Showcase of advanced features

The presentation From Mesh Generation to Adaptive Simulation: A Journey in Julia, originally given as part of JuliaCon 2022, outlines how to use Trixi.jl for an adaptive simulation of the compressible Euler equations in two spatial dimensions on a complex domain. More details as well as code to run the simulation presented can be found at the reproducibility repository for the presentation.

Referencing

If you use Trixi.jl in your own research or write a paper using results obtained with the help of Trixi.jl, please cite the following articles:

@article{ranocha2022adaptive,
+  title={Adaptive numerical simulations with {T}rixi.jl:
+         {A} case study of {J}ulia for scientific computing},
+  author={Ranocha, Hendrik and Schlottke-Lakemper, Michael and Winters, Andrew Ross
+          and Faulhaber, Erik and Chan, Jesse and Gassner, Gregor},
+  journal={Proceedings of the JuliaCon Conferences},
+  volume={1},
+  number={1},
+  pages={77},
+  year={2022},
+  doi={10.21105/jcon.00077},
+  eprint={2108.06476},
+  eprinttype={arXiv},
+  eprintclass={cs.MS}
+}
+
+@article{schlottkelakemper2021purely,
+  title={A purely hyperbolic discontinuous {G}alerkin approach for
+         self-gravitating gas dynamics},
+  author={Schlottke-Lakemper, Michael and Winters, Andrew R and
+          Ranocha, Hendrik and Gassner, Gregor J},
+  journal={Journal of Computational Physics},
+  pages={110467},
+  year={2021},
+  month={06},
+  volume={442},
+  publisher={Elsevier},
+  doi={10.1016/j.jcp.2021.110467},
+  eprint={2008.10593},
+  eprinttype={arXiv},
+  eprintclass={math.NA}
+}

In addition, you can also refer to Trixi.jl directly as

@misc{schlottkelakemper2020trixi,
+  title={{T}rixi.jl: {A}daptive high-order numerical simulations
+         of hyperbolic {PDE}s in {J}ulia},
+  author={Schlottke-Lakemper, Michael and Gassner, Gregor J and
+          Ranocha, Hendrik and Winters, Andrew R and Chan, Jesse},
+  year={2021},
+  month={09},
+  howpublished={\url{https://github.com/trixi-framework/Trixi.jl}},
+  doi={10.5281/zenodo.3996439}
+}

Authors

Trixi.jl was initiated by Michael Schlottke-Lakemper (RWTH Aachen University/High-Performance Computing Center Stuttgart (HLRS), Germany) and Gregor Gassner (University of Cologne, Germany). Together with Hendrik Ranocha (Johannes Gutenberg University Mainz, Germany) and Andrew Winters (Linköping University, Sweden), and Jesse Chan (Rice University, US), they are the principal developers of Trixi.jl. The full list of contributors can be found under Authors.

License and contributing

Trixi.jl is licensed under the MIT license (see License). Since Trixi.jl is an open-source project, we are very happy to accept contributions from the community. Please refer to Contributing for more details. Note that we strive to be a friendly, inclusive open-source community and ask all members of our community to adhere to our Code of Conduct. To get in touch with the developers, join us on Slack or create an issue.

Acknowledgments

+ +

This project has benefited from funding by the Deutsche Forschungsgemeinschaft (DFG, German Research Foundation) through the following grants:

  • Excellence Strategy EXC 2044-390685587, Mathematics Münster: Dynamics-Geometry-Structure.
  • Research unit FOR 5409 "Structure-Preserving Numerical Methods for Bulk- and Interface Coupling of Heterogeneous Models (SNuBIC)" (project number 463312734).
  • Individual grant no. 528753982.

This project has benefited from funding from the European Research Council through the ERC Starting Grant "An Exascale aware and Un-crashable Space-Time-Adaptive Discontinuous Spectral Element Solver for Non-Linear Conservation Laws" (Extreme), ERC grant agreement no. 714487.

This project has benefited from funding from Vetenskapsrådet (VR, Swedish Research Council), Sweden through the VR Starting Grant "Shallow water flows including sediment transport and morphodynamics", VR grant agreement 2020-03642 VR.

This project has benefited from funding from the United States National Science Foundation (NSF) under awards DMS-1719818 and DMS-1943186.

This project has benefited from funding from the German Federal Ministry of Education and Research (BMBF) through the project grant "Adaptive earth system modeling with significantly reduced computation time for exascale supercomputers (ADAPTEX)" (funding id: 16ME0668K).

Trixi.jl is supported by NumFOCUS as an Affiliated Project.

diff --git a/previews/PR1697/license/index.html b/previews/PR1697/license/index.html new file mode 100644 index 00000000000..bf71a2bc29e --- /dev/null +++ b/previews/PR1697/license/index.html @@ -0,0 +1,2 @@ + +License · Trixi.jl

License

MIT License

Copyright (c) 2020-present The Trixi.jl Authors (see Authors)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

diff --git a/previews/PR1697/meshes/dgmulti_mesh/index.html b/previews/PR1697/meshes/dgmulti_mesh/index.html new file mode 100644 index 00000000000..d31d20c6041 --- /dev/null +++ b/previews/PR1697/meshes/dgmulti_mesh/index.html @@ -0,0 +1,8 @@ + +DGMulti mesh · Trixi.jl

Unstructured meshes and the DGMulti solver

Trixi.jl includes support for simplicial and tensor product meshes via the DGMulti solver type, which is based on the StartUpDG.jl package. DGMulti solvers also provide support for quadrilateral and hexahedral meshes, though this feature is currently restricted to Cartesian grids. On these line/quad/hex meshes, the DGMulti solver also allows to use all (finite domain) SBP derivative operators provided by SummationByPartsOperators.jl, including several finite difference SBP methods.

We make a few simplifying assumptions about supported meshes:

  • meshes consist of a single type of element
  • meshes are conforming (e.g., each face of an element is shared with at most one other element).
  • the geometric mapping from reference to physical elements is polynomial (currently, only affine mappings are supported).

StartUpDG.jl includes both simple uniform meshes via uniform_mesh, as well as support for triangular meshes constructed using Triangulate.jl, a wrapper around Jonathan Shewchuk's Triangle package.

The DGMulti solver type

Trixi.jl solvers on simplicial meshes use the [DGMulti](@ref) solver type, which allows users to specify element_type and approximation_type in addition to polydeg, surface_flux, surface_integral, and volume_integral.

DGMulti(; polydeg::Integer,
+          element_type::AbstractElemShape,
+          approximation_type=Polynomial(),
+          surface_flux=flux_central,
+          surface_integral=SurfaceIntegralWeakForm(surface_flux),
+          volume_integral=VolumeIntegralWeakForm(),
+          RefElemData_kwargs...)

Here, element_type can be Tri(), Quad(), Tet(), or Hex(), and approximation_type can be

  • Polynomial(), which specifies a DG discretization using a polynomial basis using quadrature rules which are exact for degree 2 * polydeg integrands, or
  • SBP(), which specifies a DG discretization using multi-dimensional SBP operators. Types of SBP discretizations available include: SBP{Kubatko{LobattoFaceNodes}}() (the default choice), SBP{Kubatko{LegendreFaceNodes}}(), and SBP{Hicken}(). For polydeg = 1, ..., 4, the SBP{Kubatko{LegendreFaceNodes}}() SBP nodes are identical to the SBP nodes of Chen and Shu. More detailed descriptions of each SBP node set can be found in the StartUpDG.jl docs. Trixi.jl will also specialize certain parts of the solver based on the SBP approximation type.
  • a (periodic or non-periodic) derivative operator from SummationByPartsOperators.jl, usually constructed as D = derivative_operator(...). In this case, you do not need to pass a polydeg. Periodic derivative operators will only work with single-element meshes constructed using DGMultiMesh.

Additional options can also be specified through RefElemData_kwargs:

  • quad_rule_vol = quad_nodes(Tri(), Nq) will substitute in a volume quadrature rule of degree Nq instead of the default (which is a quadrature rule of degree polydeg). Here, a degree Nq rule will be exact for at least degree 2*Nq integrands (such that the mass matrix is integrated exactly). Quadrature rules of which exactly integrate degree Nq integrands may also be specified (for example, quad_rule_vol = StartUpDG.quad_nodes_tri(Nq) on triangles).
  • quad_rule_face = quad_nodes(Line(), Nq)) will use a face quadrature rule of degree Nq rather than the default. This rule is also exact for at least degree 2*Nq integrands.

The GaussSBP() approximation type on Quad() and Hex() meshes

When using VolumeIntegralFluxDifferencing on Quad() and Hex() meshes, one can also specify approximation_type = GaussSBP() to use an entropy stable Gauss collocation scheme. Here, GaussSBP() refers to "generalized" summation-by-parts operators (see for example Ranocha 2018 or Fernandez and Zingg 2015).

Unlike traditional SBP operators, generalized SBP operators are constructed from nodes which do not include boundary nodes (i.e., Gauss quadrature nodes as opposed to Gauss-Lobatto quadrature nodes). This makes the computation of interface fluxes slightly more expensive, but also usually results in a more accurate solution. Roughly speaking, an entropy stable Gauss collocation scheme will yield results similar to a modal entropy stable scheme using a Polynomial() approximation type, but will be more efficient at high orders of approximation.

Trixi.jl elixirs on simplicial and tensor product element meshes

Example elixirs with triangular, quadrilateral, and tetrahedral meshes can be found in the examples/dgmulti_2d/ and examples/dgmulti_3d/ folders. Some key elixirs to look at:

For developers

DGMultiMesh wrapper type

DGMulti meshes in Trixi.jl are represented using a DGMultiMesh{NDIMS, ...} type. This mesh type is assumed to have fields md::MeshData, which contains geometric terms derived from the mapping between the reference and physical elements, and boundary_faces, which contains a Dict of boundary segment names (symbols) and list of faces which lie on that boundary segment.

A DGMultiMesh can be constructed in several ways. For example, DGMultiMesh(dg::DGMulti) will return a Cartesian mesh on $[-1, 1]^d$ with element types specified by dg. DGMulti meshes can also be constructed by specifying a list of vertex coordinates vertex_coordinates_x, vertex_coordinates_y, vertex_coordinates_z and a connectivity matrix EToV where EToV[e,:] gives the vertices which correspond to element e. These quantities are available from most unstructured mesh generators.

Initial support for curved DGMultiMeshes is available for flux differencing solvers using SBP and GaussSBP approximation types on quadrilateral and hexahedral meshes. These can be called by specifying mesh = DGMultiMesh(dg, cells_per_dimension, mapping), where mapping is a function which specifies the warping of the mesh (e.g., mapping(xi, eta) = SVector{2}(xi, eta) is the identity mapping) similar to the mapping argument used by StructuredMesh.

Variable naming conventions

We use the convention that coordinates on the reference element are $r$ in 1D, $r, s$ in 2D, or $r, s, t$ in 3D. Physical coordinates use the standard conventions $x$ (1D), $x, y$ (2D), and $x, y, z$ (3D).

"Ref-to-physical mapping"

Derivatives of reference coordinates with respect to physical coordinates are abbreviated, e.g., $\frac{\partial r}{\partial x} = r_x$. Additionally, $J$ is used to denote the determinant of the Jacobian of the reference-to-physical mapping.

Variable meanings and conventions in StartUpDG.jl

StartUpDG.jl exports structs RefElemData{NDIMS, ElemShape, ...} (which contains data associated with the reference element, such as interpolation points, quadrature rules, face nodes, normals, and differentiation/interpolation/projection matrices) and MeshData{NDIMS} (which contains geometric data associated with a mesh). These are currently used for evaluating DG formulations in a matrix-free fashion. These structs contain fields similar (but not identical) to those in Globals1D, Globals2D, Globals3D in the Matlab codes from "Nodal Discontinuous Galerkin Methods" by Hesthaven and Warburton (2007).

In general, we use the following code conventions:

  • variables such as r, s,... and x, y,... correspond to values at nodal interpolation points.
  • variables ending in q (e.g., rq, sq,... and xq, yq,...) correspond to values at volume quadrature points.
  • variables ending in f (e.g., rf, sf,... and xf, yf,...) correspond to values at face quadrature points.
  • variables ending in p (e.g., rp, sp,...) correspond to "plotting" points, which are usually a fine grid of equispaced points.
  • V matrices correspond to interpolation matrices from nodal interpolation points, e.g., Vq interpolates to volume quadrature points, Vf interpolates to face quadrature points.
  • geometric quantities in MeshData are stored as matrices of dimension $\text{number of points per element} \times \text{number of elements}$.

Quantities in rd::RefElemData:

  • rd.Np, rd.Nq, rd.Nf: the number of nodal interpolation points, volume quadrature points, and face quadrature points on the reference element, respectively.
  • rd.Vq: interpolation matrices from values at nodal interpolation points to volume quadrature points
  • rd.wq: volume quadrature weights on the reference element
  • rd.Vf: interpolation matrices from values at nodal interpolation points to face quadrature points
  • rd.wf: a vector containing face quadrature weights on the reference element
  • rd.M: the quadrature-based mass matrix, computed via rd.Vq' * diagm(rd.wq) * rd.Vq.
  • rd.Pq: a quadrature-based $L^2$ projection matrix rd.Pq = rd.M \ rd.Vq' * diagm(rd.wq) which maps between values at quadrature points and values at nodal points.
  • Dr, Ds, Dt matrices are nodal differentiation matrices with respect to the $r,s,t$ coordinates, e.g., Dr*f.(r,s) approximates the derivative of $f(r,s)$ at nodal points.

Quantities in md::MeshData:

  • md.xyz is a tuple of matrices md.x, md.y, md.z, where column e contains coordinates of physical interpolation points.
  • md.xyzq is a tuple of matrices md.xq, md.yq, md.zq, where column e contains coordinates of physical quadrature points.
  • md.rxJ, md.sxJ, ... are matrices where column e contains values of $J\frac{\partial r}{\partial x}$, $J\frac{\partial s}{\partial x}$, etc. at nodal interpolation points on the element e.
  • md.J is a matrix where column e contains values of the Jacobian $J$ at nodal interpolation points.
  • md.Jf is a matrix where column e contains values of the face Jacobian (e.g., determinant of the geometric mapping between a physical face and a reference face) at face quadrature points.
  • md.nxJ, md.nyJ, ... are matrices where column e contains values of components of the unit normal scaled by the face Jacobian md.Jf at face quadrature points.

For more details, please see the StartUpDG.jl docs.

diff --git a/previews/PR1697/meshes/p4est_mesh/index.html b/previews/PR1697/meshes/p4est_mesh/index.html new file mode 100644 index 00000000000..3b97e15a7de --- /dev/null +++ b/previews/PR1697/meshes/p4est_mesh/index.html @@ -0,0 +1,136 @@ + +P4est-based mesh · Trixi.jl

P4est-based mesh

The P4estMesh is an unstructured, curvilinear, nonconforming mesh type for quadrilateral (2D) and hexahedral (3D) cells. It supports quadtree/octree-based adaptive mesh refinement (AMR) via the C library p4est. See AMRCallback for further information.

Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.

Construction of a P4estMesh from an Abaqus file

One available option to construct a P4estMesh is to read in an Abaqus (.inp) mesh file. We briefly describe the structure of this file, the conventions it uses, and how the mesh file is parsed to create an initial unstructured, curvilinear, and conforming mesh.

Mesh in two spatial dimensions

For this discussion we use the following two-dimensional unstructured curved mesh with three elements:

abaqus-2dmesh-docs

We note that the corner and element connectivity information parsed from the Abaqus file creates a straight sided (linear) mesh. From this linear mesh there are two strategies available to make the mesh curvilinear:

  1. Apply a mapping function to describe a transformation of the linear mesh to another physical domain. The mapping is approximated using interpolation polynomial of a user specified polynomial degree. The default value of this polynomial degree is 1 that corresponds to an uncurved geometry.
  2. High-order boundary information is available in the .inp mesh file because it was created with the HOHQMesh mesh generator, which is available via the Julia package HOHQMesh.jl. This information is used to create appropriate transfinite mappings during the mesh construction.

We divide our discussion into two parts. The first part discusses the standard corner and element information contained in the .inp mesh file. The second part specifically deals with the mesh file parsing of an Abaqus file created by HOHQMesh.jl.

Mesh file header

An Abaqus .inp mesh file typically begins with a *Heading. Though optional, the *Heading is helpful to give users some information about the mesh described by the mesh file. In particular, a .inp mesh file created with HOHQMesh will contain the header

*Heading
+ File created by HOHQMesh

This heading is used to indicate to the mesh constructor which of the above mapping strategies to apply in order to create a curvilinear mesh. If the Abaqus file header is not present then the P4estMesh is created with the first strategy above.

List of corner nodes

Next, prefaced with *NODE, comes a list of the physical (x,y,z) coordinates of all the corners. The first integer in the list of the corners provides its id number. Thus, for the two-dimensional example mesh this block of corner information is

*NODE
+1, 1.0, -1.0, 0.0
+2, 3.0,  0.0, 0.0
+3, 1.0,  1.0, 0.0
+4, 2.0,  0.0, 0.0
+5, 0.0,  0.0, 0.0
+6, 3.0,  1.0, 0.0
+7, 3.0, -1.0, 0.0

List of elements

The element connectivity is given after the list of corners. The header for this information block is

*ELEMENT, type=CPS4, ELSET=Surface1

The Abaqus element type CPS4 corresponds to a quadrilateral element. Each quadrilateral element in the unstructured mesh is dictated by four corner points with indexing taken from the numbering given by the corner list above. The elements connect a set of four corner points (starting from the bottom left) in an anti-clockwise fashion; making the element right-handed. This element handedness is indicated using the circular arrow in the figure above. Just as with the corner list, the first integer in the element connectivity list indicates the element id number. Thus, the element connectivity list for the three element example mesh is

*ELEMENT, type=CPS4, ELSET=Surface1
+1, 5, 1, 4, 3
+2, 4, 2, 6, 3
+3, 7, 2, 4, 1

Element neighbor connectivity

The construction of the element neighbor ids and identifying physical boundary surfaces is done using functionality directly from the p4est library. For example, the neighbor connectivity is created in the mesh constructor using the wrapper read_inp_p4est function.

HOHQMesh boundary information

If present, any additional information in the mesh file that was created by HOHQMesh is prefaced with ** to make it an Abaqus comment. This ensures that the read in of the file by a standard Abaqus file parser, as done in the read_inp_p4est function, is done correctly.

The high-order, curved boundary information and labels of the physical boundary created by HOHQMesh is found below the comment line

** ***** HOHQMesh boundary information ***** **

Next comes the polynomial degree that the mesh will use to represent any curved sides

** mesh polynomial degree = 8

The mesh file then, again, provides the element connectivity as well as information for curved surfaces either interior to the domain or along the physical boundaries. A set of check digits are included directly below the four corner indexes to indicate whether the local surface index (-y, +x, +y, or -x) within the element is straight sided, 0, or is curved, 1. If the local surface is straight sided no additional information is necessary during the mesh file read in. But for any curved surfaces the mesh file provides (x,y,z) coordinate values in order to construct an interpolant of this surface with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes. This list of (x,y,z) data will be given in the direction of the local coordinate system. Given below is the element curvature information for the example mesh:

**  5 1 4 3
+**  0 0 1 1
+**   1.000000000000000   1.000000000000000   0.0
+**   1.024948365654583   0.934461926834452   0.0
+**   1.116583018200151   0.777350964621867   0.0
+**   1.295753434047077   0.606254343587194   0.0
+**   1.537500000000000   0.462500000000000   0.0
+**   1.768263070247418   0.329729152118310   0.0
+**   1.920916981799849   0.185149035378133   0.0
+**   1.986035130050921   0.054554577460044   0.0
+**   2.000000000000000                 0.0   0.0
+**                 0.0                 0.0   0.0
+**   0.035513826946206   0.105291711848750   0.0
+**   0.148591270347399   0.317731556850611   0.0
+**   0.340010713990041   0.452219430075470   0.0
+**   0.575000000000000   0.462500000000000   0.0
+**   0.788022294598950   0.483764065630034   0.0
+**   0.926408729652601   0.644768443149389   0.0
+**   0.986453164464803   0.883724792445746   0.0
+**   1.000000000000000   1.000000000000000   0.0
+**  4 2 6 3
+**  0 0 0 1
+**   2.000000000000000                 0.0   0.0
+**   1.986035130050921   0.054554577460044   0.0
+**   1.920916981799849   0.185149035378133   0.0
+**   1.768263070247418   0.329729152118310   0.0
+**   1.537500000000000   0.462500000000000   0.0
+**   1.295753434047077   0.606254343587194   0.0
+**   1.116583018200151   0.777350964621867   0.0
+**   1.024948365654583   0.934461926834452   0.0
+**   1.000000000000000   1.000000000000000   0.0
+**  7 2 4 1
+**  0 0 0 0

The last piece of information provided by HOHQMesh are labels for the different surfaces of an element. These labels are useful to set boundary conditions along physical surfaces. The labels can be short descriptive words up to 32 characters in length. The label --- indicates an internal surface where no boundary condition is required.

It is important to note that these labels are given in the following order according to the local surface index -x +x -y +y as required by the p4est library.

**  Bezier --- Slant ---
+**  --- Right --- Top
+**  Bottom --- Right ---

For completeness, we provide the entire Abaqus mesh file for the example mesh in the figure above:

*Heading
+ File created by HOHQMesh
+*NODE
+1, 1.0, -1.0, 0.0
+2, 3.0,  0.0, 0.0
+3, 1.0,  1.0, 0.0
+4, 2.0,  0.0, 0.0
+5, 0.0,  0.0, 0.0
+6, 3.0,  1.0, 0.0
+7, 3.0, -1.0, 0.0
+*ELEMENT, type=CPS4, ELSET=Surface1
+1, 5, 1, 4, 3
+2, 4, 2, 6, 3
+3, 7, 2, 4, 1
+** ***** HOHQMesh boundary information ***** **
+** mesh polynomial degree = 8
+**  5 1 4 3
+**  0 0 1 1
+**   1.000000000000000   1.000000000000000   0.0
+**   1.024948365654583   0.934461926834452   0.0
+**   1.116583018200151   0.777350964621867   0.0
+**   1.295753434047077   0.606254343587194   0.0
+**   1.537500000000000   0.462500000000000   0.0
+**   1.768263070247418   0.329729152118310   0.0
+**   1.920916981799849   0.185149035378133   0.0
+**   1.986035130050921   0.054554577460044   0.0
+**   2.000000000000000                 0.0   0.0
+**                 0.0                 0.0   0.0
+**   0.035513826946206   0.105291711848750   0.0
+**   0.148591270347399   0.317731556850611   0.0
+**   0.340010713990041   0.452219430075470   0.0
+**   0.575000000000000   0.462500000000000   0.0
+**   0.788022294598950   0.483764065630034   0.0
+**   0.926408729652601   0.644768443149389   0.0
+**   0.986453164464803   0.883724792445746   0.0
+**   1.000000000000000   1.000000000000000   0.0
+**  4 2 6 3
+**  0 0 0 1
+**   2.000000000000000                 0.0   0.0
+**   1.986035130050921   0.054554577460044   0.0
+**   1.920916981799849   0.185149035378133   0.0
+**   1.768263070247418   0.329729152118310   0.0
+**   1.537500000000000   0.462500000000000   0.0
+**   1.295753434047077   0.606254343587194   0.0
+**   1.116583018200151   0.777350964621867   0.0
+**   1.024948365654583   0.934461926834452   0.0
+**   1.000000000000000   1.000000000000000   0.0
+**  7 2 4 1
+**  0 0 0 0
+**  Bezier --- Slant ---
+**  --- Right --- Top
+**  Bottom --- Right ---

Mesh in three spatial dimensions

The 3D Abaqus file format with high-order boundary information from HOHQMesh is very similar to the 2D version discussed above. There are only three changes:

  1. The element connectivity would be given in terms of the eight corners that define a hexahedron. The corners are numbered as shown in the figure below. The header of the element list changes to be
    *ELEMENT, type=C3D8, ELSET=Volume1
    where C3D8 corresponds to a Abaqus hexahedral element.
  2. There are six check digits included directly below the eight corner indexes to indicate whether the local face within the element is straight sided, 0, or is curved, 1. For curved faces (x,y,z) coordinate values are available in order to construct an face interpolant with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes.
  3. The boundary labels are given in the following order according to the local surface index -x +x -y +y -z +z as required by the p4est library.

For completeness, we also give a short description and derivation of the three-dimensional transfinite mapping formulas used to compute the physical coordinates $\mathbf{x}=(x,y,z)$ of a (possibly curved) hexahedral element give the reference coordinates $\boldsymbol{\xi} = (\xi, \eta, \zeta)$ which lie in $[-1,1]^3$. That is, we will create an expression $\mathbf{x}= \mathbf{X}(\boldsymbol{\xi})$.

Below we provide a sketch of a single hexahedral element with curved faces. This is done to introduce the numbering conventions for corners, edges, and faces of the element.

abaqus-3dmesh-docs

When the hexahedron is a straight sided (linear) element we compute the transfinite mapping directly from the element corner points according to

\[\begin{aligned} +\mathbf{X}_{linear}(\boldsymbol{\xi}) &= \frac{1}{8}[\quad\, \mathbf{x}_1(1-\xi)(1-\eta)(1-\zeta) + + \mathbf{x}_2(1+\xi)(1-\eta)(1-\zeta)\\[-0.15cm] + & \qquad\; + \mathbf{x}_3(1+\xi)(1+\eta)(1-\zeta) + + \mathbf{x}_4(1-\xi)(1+\eta)(1-\zeta) \\ + & \qquad\; + \mathbf{x}_5(1-\xi)(1-\eta)(1+\zeta) + + \mathbf{x}_6(1+\xi)(1-\eta)(1+\zeta) \\ + & \qquad\; + \mathbf{x}_7(1+\xi)(1+\eta)(1+\zeta) + + \mathbf{x}_8(1-\xi)(1+\eta)(1+\zeta)\quad]. +\end{aligned}\]

Next, we create a transfinite mapping function, $\mathbf{X}(\boldsymbol{\xi})$, for a hexahedron that has one or more curved faces. For this we assume that have a set of six interpolating polynomials $\{\Gamma_i\}_{i=1}^6$ that approximate the faces. The interpolating polynomial for any curved faces is provided by the information in a HOHQMesh Abaqus mesh file or is constructed on the fly via a bi-linear interpolation routine for any linear faces. Explicitly, these six face interpolation polynomials depend on the computational coordinates $\boldsymbol{\xi}$ as follows

\[ \begin{aligned} + \Gamma_1(\xi, \zeta), \quad && \quad \Gamma_3(\xi, \eta), \quad && \quad \Gamma_4(\eta, \zeta),\\[0.1cm] + \Gamma_2(\xi, \zeta), \quad && \quad \Gamma_5(\xi, \eta), \quad && \quad \Gamma_6(\eta, \zeta). + \end{aligned}\]

To determine the form of the mapping we first create linear interpolations between two opposing faces, e.g., $\Gamma_3$ and $\Gamma_5$ and sum them together to have

\[\begin{aligned} + \boldsymbol\Sigma(\boldsymbol{\xi}) &= \frac{1}{2}[\quad\,(1-\xi)\Gamma_6(\eta,\zeta) + (1+\xi)\Gamma_4(\eta,\zeta) \\[-0.15cm] + &\qquad\;+ (1-\eta)\Gamma_1(\xi,\zeta) + (1+\eta)\Gamma_2(\xi,\zeta) \\%[-0.15cm] + &\qquad\; +(1-\zeta)\Gamma_3(\xi,\eta) + (1+\zeta)\Gamma_5(\xi,\eta)\quad]. +\end{aligned}\]

Unfortunately, the linear interpolations $\boldsymbol\Sigma(\boldsymbol{\xi})$ no longer match at the faces, e.g., evaluating at $\eta = -1$ we have

\[\boldsymbol\Sigma(\xi,-1,\zeta) = \Gamma_1(\xi,\zeta) + \frac{1}{2}[\;(1-\xi)\Gamma_6(-1,\zeta) + (1+\xi)\Gamma_4(-1,\zeta) + +(1-\zeta)\Gamma_3(\xi,-1) + (1+\zeta)\Gamma_5(\xi,-1)\;],\]

which is the desired face $\Gamma_1(\xi,\zeta)$ plus four edge error terms. Analogous edge error terms occur at the other faces evaluating $\boldsymbol\Sigma(\boldsymbol{\xi})$ at $\eta=1$, $\xi=\pm 1$, and $\zeta=\pm 1$. In order to match the faces, we subtract a linear interpolant in the $\xi$, $\eta$, and $\zeta$ directions of the edge error terms, e.g., the terms in braces in the above equation. So, continuing the example above, the correction term to be subtracted for face $\Gamma_1$ to match would be

\[\left(\frac{1-\eta}{2}\right) \bigg[ \frac{1}{2} [ \; (1-\xi)\Gamma_6(-1,\zeta) + (1+\xi)\Gamma_4(-1,\zeta)+(1-\zeta)\Gamma_3(\xi,-1) + + (1+\zeta)\Gamma_5(\xi,-1)\;] \bigg].\]

For clarity, and to allow an easier comparison to the implementation, we introduce auxiliary notation for the 12 edge values present in the complete correction term. That is, for given values of $\xi$, $\eta$, and $\zeta$ we have

\[ \begin{aligned} + \texttt{edge}_{1} &= \Gamma_1(\xi, -1), \quad && \quad \texttt{edge}_{5} = \Gamma_2(\xi, -1), \quad & \quad \texttt{edge}_{9} &= \Gamma_6(\eta, -1),\\[0.1cm] + \texttt{edge}_{2} &= \Gamma_1(1, \zeta), \quad && \quad\texttt{edge}_{6} = \Gamma_2(1, \zeta), \quad & \quad \texttt{edge}_{10} &= \Gamma_4(\eta, -1),\\[0.1cm] + \texttt{edge}_{3} &= \Gamma_1(\xi, 1), \quad && \quad \texttt{edge}_{7} = \Gamma_2(\xi, 1), \quad & \quad \texttt{edge}_{11} &= \Gamma_4(\eta, 1),\\[0.1cm] + \texttt{edge}_{4} &= \Gamma_1(-1, \zeta), \quad && \quad \texttt{edge}_{8} = \Gamma_2(-1, \zeta), \quad & \quad \texttt{edge}_{12} &= \Gamma_6(\eta, 1). + \end{aligned}\]

With this notation for the edge terms (and after some algebraic manipulation) we write the complete edge correction term, $\mathcal{C}_{\texttt{edge}}(\boldsymbol{\xi})$, as

\[\begin{aligned} +\mathcal{C}_{\texttt{edge}}(\boldsymbol{\xi}) &= \frac{1}{4}[\quad\, (1-\eta)(1-\zeta)\texttt{edge}_{1}\\[-0.15cm] + & \qquad\; + (1+\xi)(1-\eta)\texttt{edge}_{2} \\ + & \qquad\; + (1-\eta)(1+\zeta)\texttt{edge}_{3} \\ + & \qquad\; + (1-\xi)(1-\eta)\texttt{edge}_{4} \\ + & \qquad\; + (1+\eta)(1-\zeta)\texttt{edge}_{5} \\ + & \qquad\; + (1+\xi)(1+\eta)\texttt{edge}_{6} \\ + & \qquad\; + (1+\eta)(1+\zeta)\texttt{edge}_{7} \\ + & \qquad\; + (1-\xi)(1+\eta)\texttt{edge}_{8} \\ + & \qquad\; + (1-\xi)(1-\zeta)\texttt{edge}_{9} \\ + & \qquad\; + (1+\xi)(1-\zeta)\texttt{edge}_{10} \\ + & \qquad\; + (1+\xi)(1+\zeta)\texttt{edge}_{11} \\ + & \qquad\; + (1-\xi)(1+\zeta)\texttt{edge}_{12}\quad]. +\end{aligned}\]

However, subtracting the edge correction terms $\mathcal{C}_{\texttt{edge}}(\boldsymbol{\xi})$ from $\boldsymbol\Sigma(\boldsymbol{\xi})$ removes the interior element contributions twice. Thus, to complete the construction of the transfinite mapping $\mathbf{X}(\boldsymbol{\xi})$ we add the transfinite map of the straight sided hexahedral element to find

\[\mathbf{X}(\boldsymbol{\xi}) = \boldsymbol\Sigma(\boldsymbol{\xi}) + - \mathcal{C}_{\texttt{edge}}(\boldsymbol{\xi}) + + \mathbf{X}_{linear}(\boldsymbol{\xi}).\]

diff --git a/previews/PR1697/meshes/structured_mesh/index.html b/previews/PR1697/meshes/structured_mesh/index.html new file mode 100644 index 00000000000..7f2fb0fdabb --- /dev/null +++ b/previews/PR1697/meshes/structured_mesh/index.html @@ -0,0 +1,2 @@ + +Structured mesh · Trixi.jl

Structured mesh

The StructuredMesh is a structured, curvilinear, conforming mesh type available for one-, two-, and three-dimensional simulations.

Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.

diff --git a/previews/PR1697/meshes/tree_mesh/index.html b/previews/PR1697/meshes/tree_mesh/index.html new file mode 100644 index 00000000000..eae1e7fede7 --- /dev/null +++ b/previews/PR1697/meshes/tree_mesh/index.html @@ -0,0 +1,2 @@ + +Tree mesh · Trixi.jl

Tree mesh

The TreeMesh is a Cartesian, $h$-non-conforming mesh type used in many parts of Trixi.jl. Often, the support for this mesh type is developed best since it was the first mesh type in Trixi.jl, and it is available in one, two, and three space dimensions.

It is limited to hypercube domains but supports AMR via the AMRCallback. Due to its Cartesian nature, (numerical) fluxes need to implement methods dispatching on the orientation::Integer as described in the conventions.

diff --git a/previews/PR1697/meshes/unstructured_quad_mesh/index.html b/previews/PR1697/meshes/unstructured_quad_mesh/index.html new file mode 100644 index 00000000000..acd6ae3d678 --- /dev/null +++ b/previews/PR1697/meshes/unstructured_quad_mesh/index.html @@ -0,0 +1,79 @@ + +Unstructured mesh · Trixi.jl

Unstructured quadrilateral mesh

The UnstructuredMesh2D is an unstructured, curvilinear, conforming mesh type in two space dimensions.

Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.

Next, we describe the conventions taken in the implementation for two-dimensional unstructured quadrilateral meshes. Principally, this relates to how a file with the extension .mesh encodes information about the numbering and orientation of elements in an unstructured quadrilateral mesh with possibly curved boundaries.

We use the following unstructured mesh with three elements for this discussion:

example-mesh

Further, a simulation using Trixi.jl on this example unstructured mesh is provided in examples/unstructured_2d_dgsem/elixir_euler_basic.jl.

Mesh file header

The first two lines of the mesh file lists the mesh file type as well as the total number of corners, surfaces, elements, and the polynomial degree that the mesh will use to represent any curved sides. For the example mesh these quantities are

ISM-V2
+    7    9    3    8

corresponding to seven corners, nine surfaces, and three elements. The mesh polynomial degree of eight is taken only for illustrative purposes. In practice, this mesh polynomial degree depends on the particular application for which the curved, unstructured mesh is required.

List of corner nodes

After these global counts that prescribe information about the mesh skeleton, the mesh file give a list of the physical (x,y) coordinates of all the corners. The corner nodes are listed in the order prescribed by mesh generator. Thus, for the example mesh this node list would be

 1.0    -1.0
+ 3.0    0.0
+ 1.0    1.0
+ 2.0    0.0
+ 0.0    0.0
+ 3.0    1.0
+ 3.0    -1.0

The corner nodes are internally referenced by their position in the list above. For example, here the node at (1.0, -1.0) would have node id 1, node id 2 would be at (3.0, 0.0) etc.

List of neighbor connectivity

After the corner list comes the neighbor connectivity along each surface in the mesh. This includes local indexing and orientation information necessary to compute the coupling between elements in the mesh. In 2D each surface is defined by connecting two nodes indexed as with the numbering above. We adopt the convention that node id 1 < node id 2.

Each surface will have two neighbors where the element on the left locally as one "walks" from node id 1 to node id 2 is taken to be the primary element and the element locally on the right is taken to be the secondary element. If, however, there is no secondary element index, then the surface lies along a physical boundary. In this case the only available element index is considered to be primary and the secondary index is set to zero.

The final two index numbers within the neighbor information list are used to identify the local surface within each element. The first local surface index (on the primary element) will always be positive whereas the second local surface index (on the primary element) can be positive or negative. If the second local surface index is positive, then the local coordinate systems in the primary element and secondary element match, i.e., the indexing on either side runs from 1:polydeg+1. However, if the local surface index of the secondary element is negative in the mesh file, then the coordinate system in the secondary element is flipped with respect to the primary element. Therefore, care must be taken in the implementation to ensure that the primary element indexing runs from 1:polydeg+1 whereas the secondary element indexing must run in reverse from polydeg+1:-1:1. Finally, if the secondary element index is zero, then so will be the local surface index because the surface is on a physical boundary. Also, there is no flipping of coordinate indexing required at the physical boundary because only the primary element's coordinate system exists.

Three examples: One along a physical boundary and two along interior surfaces.

Along edge {8} we connect node (2) to node (7) and are along a physical boundary in element 3 with the local surface index 1 and the neighbor information:

    2    7    3    0    1    0

Along edge {1} we connect node (2) to node (4) such that the primary element is 3 with local surface index 2 and the secondary element is 2 with local surface index 1. Furthermore, we see that coordinate system in the secondary element 2 is flipped with respect to the primary element's coordinate system such that the sign of the local surface index in the secondary element flips. This gives the following neighbor information:

    2    4    3    2    2    -1

Along edge {4} we connect node (1) to node (4) such that the primary element is 1 with local surface index 2 and the secondary element is 3 with local surface index 3. The coordinate systems in both elements match and no sign change is required on the local surface index in the secondary element:

    1    4    1    3    2    3

We collect the complete neighbor information for the example mesh above:

    2    4    3    2    2    -1
+    3    5    1    0    4    0
+    1    5    1    0    1    0
+    1    4    1    3    2    3
+    2    6    2    0    2    0
+    1    7    3    0    4    0
+    3    6    2    0    3    0
+    2    7    3    0    1    0
+    3    4    2    1    4    -3

List of elements

Each quadrilateral element in the unstructured mesh is dictated by four corner points with indexing taken from the numbering given by the corner list above. We connect a set of four corner points (starting from the bottom left) in an anti-clockwise fashion thus making the element right-handed indicated using the circular arrow in the figure above. In turn, this right-handedness defines the local surface indexing (i.e. the four local sides) and the local $(\xi, \eta)$ coordinate system. For example, the four corners for element 1 would be listed as

    5    1    4    3

The mesh file also encodes information for curved surfaces either interior to the domain (as surface {9} above) or along the physical boundaries. A set of check digits are included directly below the four corner indexes to indicate whether the local surface index (1, 2, 3, or 4) within the element is straight sided, 0, or is curved, 1. If the local surface is straight sided no additional information is necessary during the mesh file read in. But for any curved surfaces the mesh file provides (x,y) coordinate values in order to construct an interpolant of this surface with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes. This list of (x,y) data will be given in the direction of the local coordinate system.

The last piece of information provided by the mesh file are labels for the different surfaces of an element. These labels are useful to set boundary conditions along physical surfaces. The labels can be short descriptive words. The label --- indicates an internal surface where no boundary condition is required.

As an example, the complete information for element 1 in the example mesh would be

    5    1    4    3
+    0    0    1    1
+ 1.000000000000000   1.000000000000000
+ 1.024948365654583   0.934461926834452
+ 1.116583018200151   0.777350964621867
+ 1.295753434047077   0.606254343587194
+ 1.537500000000000   0.462500000000000
+ 1.768263070247418   0.329729152118310
+ 1.920916981799849   0.185149035378133
+ 1.986035130050921   0.054554577460044
+ 2.000000000000000                 0.0
+               0.0                 0.0
+ 0.035513826946206   0.105291711848750
+ 0.148591270347399   0.317731556850611
+ 0.340010713990041   0.452219430075470
+ 0.575000000000000   0.462500000000000
+ 0.788022294598950   0.483764065630034
+ 0.926408729652601   0.644768443149389
+ 0.986453164464803   0.883724792445746
+ 1.000000000000000   1.000000000000000
+ Slant --- --- Bezier

where the curved boundary information is encoded "back to back". That is, the first nine (x,y) nodes in the list above correspond to the interior boundary curve along local side 3 in element 1 and the next nine (x,y) nodes denote the curved physical boundary named Bezier along local side 4.

We collect the complete set of element information for the example mesh

    5    1    4    3
+    0    0    1    1
+ 1.000000000000000   1.000000000000000
+ 1.024948365654583   0.934461926834452
+ 1.116583018200151   0.777350964621867
+ 1.295753434047077   0.606254343587194
+ 1.537500000000000   0.462500000000000
+ 1.768263070247418   0.329729152118310
+ 1.920916981799849   0.185149035378133
+ 1.986035130050921   0.054554577460044
+ 2.000000000000000                 0.0
+               0.0                 0.0
+ 0.035513826946206   0.105291711848750
+ 0.148591270347399   0.317731556850611
+ 0.340010713990041   0.452219430075470
+ 0.575000000000000   0.462500000000000
+ 0.788022294598950   0.483764065630034
+ 0.926408729652601   0.644768443149389
+ 0.986453164464803   0.883724792445746
+ 1.000000000000000   1.000000000000000
+ Slant --- --- Bezier
+    4    2    6    3
+    0    0    0    1
+ 2.000000000000000                 0.0
+ 1.986035130050921   0.054554577460044
+ 1.920916981799849   0.185149035378133
+ 1.768263070247418   0.329729152118310
+ 1.537500000000000   0.462500000000000
+ 1.295753434047077   0.606254343587194
+ 1.116583018200151   0.777350964621867
+ 1.024948365654583   0.934461926834452
+ 1.000000000000000   1.000000000000000
+ --- Right Top ---
+    7    2    4    1
+    0    0    0    0
+ Right --- --- Bottom

Trixi.jl on an unstructured quadrilateral mesh

We provide an example simulation on an unstructured quadrilateral mesh by executing

julia> trixi_include(default_example_unstructured())

Note this may download a copy of the mesh file described above for the three element unstructured mesh. This elixir provides the solution for the compressible Euler equations in two spatial dimensions for a smooth propagating wave solution. Below we provide the time evolution of the pressure wave for this example created with the Trixi2Vtk tool and visualized using ParaView.

+
diff --git a/previews/PR1697/overview/index.html b/previews/PR1697/overview/index.html new file mode 100644 index 00000000000..eeb80b74f2c --- /dev/null +++ b/previews/PR1697/overview/index.html @@ -0,0 +1,2 @@ + +Overview · Trixi.jl

Overview of the structure of Trixi.jl

Trixi.jl is designed as a library of components for discretizations of hyperbolic conservation laws. Thus, it is not a monolithic PDE solver that is configured at runtime via parameter files, as it is often found in classical numerical simulation codes. Instead, each simulation is configured by pure Julia code. Many examples of such simulation setups, called elixirs in Trixi.jl, are provided in the examples/ folder.

Trixi.jl uses the method of lines, i.e., the full space-time discretization is separated into two steps; the spatial semidiscretization is performed at first and the resulting ODE system is solved numerically using a suitable time integration method. Thus, the main ingredients of an elixir designed to solve a PDE numerically are the spatial semidiscretization and the time integration scheme.

Semidiscretizations

Semidiscretizations are high-level descriptions of spatial discretizations specialized for certain PDEs. Trixi.jl's main focus is on hyperbolic conservation laws represented in a SemidiscretizationHyperbolic. Such semidiscretizations are usually named semi in Trixi.jl

semidiscretization_overview

The basic building blocks of a semidiscretization are

  • a mesh describing the geometry of the domain
  • a set of equations describing the physical model
  • a solver describing the numerical approach

In addition, a semidiscretization bundles initial and boundary conditions, and possible source terms. These different ingredients of a semidiscretization can be configured individually and combined together. When a semidiscretization is constructed, it will create an internal cache, i.e., a collection of setup-specific data structures, that is usually passed to all lower level functions.

Due to Trixi.jl's modular nature using Julia's multiple dispatch features, new ingredients can be created specifically for a certain combination of other ingredients. For example, a new mesh type can be created and implemented at first only for a specific solver. Thus, there is no need to consider all possible combinations of meshes, equations, and solvers when implementing new features. This allows rapid prototyping of new ideas and is one of the main design goals behind Trixi.jl. Below is a brief overview of the availability of different features on different mesh types.

FeatureTreeMeshStructuredMeshUnstructuredMesh2DP4estMeshDGMultiMeshFurther reading
Spatial dimension1D, 2D, 3D1D, 2D, 3D2D2D, 3D1D, 2D, 3D
CoordinatesCartesiancurvilinearcurvilinearcurvilinearcurvilinear
Connectivityh-nonconformingconformingconformingh-nonconformingconforming
Element typeline, square, cubeline, quadᵃ, hexᵃquadᵃquadᵃ, hexᵃsimplex, quadᵃ, hexᵃ
Adaptive mesh refinementAMRCallback
Solver typeDGSEMDGSEMDGSEMDGSEMDGMulti
Domainhypercubemapped hypercubearbitraryarbitraryarbitrary
Weak formVolumeIntegralWeakForm
Flux differencingVolumeIntegralFluxDifferencing
Shock capturingVolumeIntegralShockCapturingHG
Nonconservative equationse.g., GLM MHD or shallow water equations
Parabolic termsᵇe.g., CompressibleNavierStokesDiffusion2D

ᵃ: quad = quadrilateral, hex = hexahedron ᵇ: Parabolic terms do not currently support adaptivity.

Time integration methods

Trixi.jl is compatible with the SciML ecosystem for ordinary differential equations. In particular, a spatial semidiscretization can be wrapped in an ODE problem using semidiscretize, which returns an ODEProblem. This ODEProblem is a wrapper of Trixi.rhs!(du_ode, u_ode, semi, t), which gets called in ODE solvers. Further information can be found in the section on time integration methods.

Next steps

We explicitly encourage people interested in Trixi.jl to have a look at the examples/ bundled with Trixi.jl to get an impression of what is possible and the general look and feel of Trixi.jl. Before doing that, it is usually good to get an idea of how to visualize numerical results.

If you like learning by doing, looking at the tutorials and trying to mix your own elixirs based thereon is probably a good next step. Otherwise, you can further dig into the documentation by looking at Trixi.jl's basic building blocks.

diff --git a/previews/PR1697/parallelization/index.html b/previews/PR1697/parallelization/index.html new file mode 100644 index 00000000000..a0124ef12a9 --- /dev/null +++ b/previews/PR1697/parallelization/index.html @@ -0,0 +1,36 @@ + +Parallelization · Trixi.jl

Parallelization

Shared-memory parallelization with threads

Many compute-intensive loops in Trixi.jl are parallelized using the multi-threading support provided by Julia. You can recognize those loops by the @threaded macro prefixed to them, e.g.,

@threaded for element in eachelement(dg, cache)
+  ...
+end

This will statically assign an equal iteration count to each available thread.

To use multi-threading, you need to tell Julia at startup how many threads you want to use by either setting the environment variable JULIA_NUM_THREADS or by providing the -t/--threads command line argument. For example, to start Julia with four threads, start Julia with

julia --threads=4

If both the environment variable and the command line argument are specified at the same time, the latter takes precedence.

If you use time integration methods from OrdinaryDiffEq.jl and want to use multiple threads therein, you need to set the keyword argument thread=OrdinaryDiffEq.True() of the algorithms, as described in the section on time integration methods.

Warning

Not everything is parallelized yet and there are likely opportunities to improve scalability. Multi-threading isn't considered part of the public API of Trixi.jl yet.

Distributed computing with MPI

In addition to the shared memory parallelization with multi-threading, Trixi.jl supports distributed parallelism via MPI.jl, which leverages the Message Passing Interface (MPI). MPI.jl comes with its own MPI library binaries such that there is no need to install MPI yourself. However, it is also possible to instead use an existing MPI installation, which is recommended if you are running MPI programs on a cluster or supercomputer (see the MPI.jl docs to find out how to select the employed MPI library). Additional notes on how to use a system-provided MPI installation with Trixi.jl can be found in the following subsection.

Work in progress

MPI-based parallelization is work in progress and not finished yet. Nothing related to MPI is part of the official API of Trixi.jl yet.

Using a system-provided MPI installation

When using Trixi.jl with a system-provided MPI backend the underlying p4est and t8code libraries need to be compiled with the same MPI installation. Therefore, you also need to use system-provided p4est and t8code installations (for notes on how to install p4est and t8code see e.g. here and here, use the configure option --enable-mpi). Note that t8code already comes with a p4est installation, so it suffices to install t8code. In addition, P4est.jl and T8code.jl need to be configured to use the custom installations. Follow the steps described here and here for the configuration. The paths that point to libp4est.so (and potentially to libsc.so) need to be the same for P4est.jl and T8code.jl. This could e.g. be libp4est.so that usually can be found in lib/ or local/lib/ in the installation directory of t8code. In total, in your active Julia project you should have a LocalPreferences.toml file with sections [MPIPreferences], [T8code] and [P4est] as well as an entry MPIPreferences in your Project.toml to use a custom MPI installation. A LocalPreferences.toml file created as described above might look something like the following:

[HDF5]
+libhdf5 = "/usr/lib/x86_64-linux-gnu/hdf5/openmpi/libhdf5.so"
+libhdf5_hl = "/usr/lib/x86_64-linux-gnu/hdf5/openmpi/libhdf5_hl.so"
+
+[MPIPreferences]
+__clear__ = ["preloads_env_switch"]
+_format = "1.0"
+abi = "OpenMPI"
+binary = "system"
+cclibs = []
+libmpi = "/lib/x86_64-linux-gnu/libmpi.so"
+mpiexec = "mpiexec"
+preloads = []
+
+[P4est]
+libp4est = "/home/mschlott/hackathon/libtrixi/t8code/install/lib/libp4est.so"
+libsc = "/home/mschlott/hackathon/libtrixi/t8code/install/lib/libsc.so"
+
+[T8code]
+libp4est = "/home/mschlott/hackathon/libtrixi/t8code/install/lib/libp4est.so"
+libsc = "/home/mschlott/hackathon/libtrixi/t8code/install/lib/libsc.so"
+libt8 = "/home/mschlott/hackathon/libtrixi/t8code/install/lib/libt8.so"

Usage

To start Trixi.jl in parallel with MPI, there are three options:

  1. Run from the REPL with mpiexec(): You can start a parallel execution directly from the REPL by executing

    julia> using MPI
    +
    +julia> mpiexec() do cmd
    +         run(`$cmd -n 3 $(Base.julia_cmd()) --threads=1 --project=@. -e 'using Trixi; trixi_include(default_example())'`)
    +       end

    The parameter -n 3 specifies that Trixi.jl should run with three processes (or ranks in MPI parlance) and should be adapted to your available computing resources and problem size. The $(Base.julia_cmd()) argument ensures that Julia is executed in parallel with the same optimization level etc. as you used for the REPL; if this is unnecessary or undesired, you can also just use julia. Further, if you are not running Trixi.jl from a local clone but have installed it as a package, you need to omit the --project=@..

  2. Run from the command line with mpiexecjl: Alternatively, you can use the mpiexecjl script provided by MPI.jl, which allows you to start Trixi.jl in parallel directly from the command line. As a preparation, you need to install the script once by running

    julia> using MPI
    +
    +julia> MPI.install_mpiexecjl(destdir="/somewhere/in/your/PATH")

    Then, to execute Trixi.jl in parallel, execute the following command from your command line:

    mpiexecjl -n 3 julia --threads=1 --project=@. -e 'using Trixi; trixi_include(default_example())'
  3. Run interactively with tmpi (Linux/MacOS only): If you are on a Linux/macOS system, you have a third option which lets you run Julia in parallel interactively from the REPL. This comes in handy especially during development, as in contrast to the first two options, it allows to reuse the compilation cache and thus facilitates much faster startup times after the first execution. It requires tmux and the OpenMPI library to be installed before, both of which are usually available through a package manager. Once you have installed both tools, you need to configure MPI.jl to use the OpenMPI for your system, which is explained here. Then, you can download and install the tmpi script by executing

    curl https://raw.githubusercontent.com/Azrael3000/tmpi/master/tmpi -o /somewhere/in/your/PATH/tmpi

    Finally, you can start and control multiple Julia REPLs simultaneously by running

    tmpi 3 julia --threads=1 --project=@.

    This will start Julia inside tmux three times and multiplexes all commands you enter in one REPL to all other REPLs (try for yourself to understand what it means). If you have no prior experience with tmux, handling the REPL this way feels slightly weird in the beginning. However, there is a lot of documentation for tmux available and once you get the hang of it, developing Trixi.jl in parallel becomes much smoother this way. Some helpful commands are the following. To close a single pane you can press Ctrl+b and then x followed by y to confirm. To quit the whole session you press Ctrl+b followed by :kill-session. Often you would like to scroll up. You can do that by pressing Ctrl+b and then [, which allows you to use the arrow keys to scroll up and down. To leave the scroll mode you press q. Switching between panes can be done by Ctrl+b followed by o. As of March 2022, newer versions of tmpi also support mpich, which is the default backend of MPI.jl (via MPICH_Jll.jl). To use this setup, you need to install mpiexecjl as described in the documentation of MPI.jl and make it available as mpirun, e.g., via a symlink of the form

    ln -s ~/.julia/bin/mpiexecjl /somewhere/in/your/path/mpirun

    (assuming default installations).

Hybrid parallelism

It is possible to combine MPI with shared memory parallelism via threads by starting Julia with more than one thread, e.g. by passing the command line argument julia --threads=2 instead of julia --threads=1 used in the examples above. In that case, you should make sure that your system supports the number of processes/threads that you try to start.

Performance

For information on how to evaluate the parallel performance of Trixi.jl, please have a look at the Performance metrics of the AnalysisCallback section, specifically at the descriptions of the performance index (PID).

Using error-based step size control with MPI

If you use error-based step size control (see also the section on error-based adaptive step sizes) together with MPI you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to OrdinaryDiffEq's solve, which are both included in ode_default_options.

Using parallel input and output

Trixi.jl allows parallel I/O using MPI by leveraging parallel HDF5.jl. On most systems, this is enabled by default. Additionally, you can also use a local installation of the HDF5 library (with MPI support). For this, you first need to use a system-provided MPI library, see also here and you need to tell HDF5.jl to use this library. To do so with HDF5.jl v0.17 and newer, set the preferences libhdf5 and libhdf5_hl to the local paths of the libraries libhdf5 and libhdf5_hl, which can be done by

julia> using Preferences, UUIDs
+julia> set_preferences!(
+           UUID("f67ccb44-e63f-5c2f-98bd-6dc0ccc4ba2f"), # UUID of HDF5.jl
+           "libhdf5" => "/path/to/your/libhdf5.so",
+           "libhdf5_hl" => "/path/to/your/libhdf5_hl.so", force = true)

Alternatively, with HDF5.jl v0.17.1 or higher you can use

julia> using HDF5
+julia> HDF5.API.set_libraries!("/path/to/your/libhdf5.so", "/path/to/your/libhdf5_hl.so")

For more information see also the documentation of HDF5.jl. In total, you should have a file called LocalPreferences.toml in the project directory that contains a section [MPIPreferences], a section [HDF5] with entries libhdf5 and libhdf5_hl, a section [P4est] with the entry libp4est as well as a section [T8code] with the entries libt8, libp4est and libsc. If you use HDF5.jl v0.16 or older, instead of setting the preferences for HDF5.jl, you need to set the environment variable JULIA_HDF5_PATH to the path, where the HDF5 binaries are located and then call ]build HDF5 from Julia.

If HDF5 is not MPI-enabled, Trixi.jl will fall back on a less efficient I/O mechanism. In that case, all disk I/O is performed only on rank zero and data is distributed to/gathered from the other ranks using regular MPI communication.

diff --git a/previews/PR1697/performance/index.html b/previews/PR1697/performance/index.html new file mode 100644 index 00000000000..ed49a407240 --- /dev/null +++ b/previews/PR1697/performance/index.html @@ -0,0 +1,55 @@ + +Performance · Trixi.jl

Performance

Trixi.jl is designed to balance performance and readability. Since Julia provides a lot of zero-cost abstractions, it is often possible to optimize both goals simultaneously.

The usual development workflow in Julia is

  1. Make it work.
  2. Make it nice.
  3. Make it fast.

To achieve the third step, you should be familiar with (at least) the section on performance tips in the Julia manual. Here, we just list some important aspects you should consider when developing Trixi.jl.

  • Consider using @views/view(...) when using array slices, except on the left-side of an assignment (further details).
  • Functions are essentially for free, since they are usually automatically inlined where it makes sense (using @inline can be used as an additional hint to the compiler) (further details).
  • Function barriers can improve performance due to type stability (further details).
  • Look for type instabilities using @code_warntype. Consider using @descend from Cthulhu.jl to investigate deeper call chains.

Manual benchmarking

If you modify some internal parts of Trixi.jl, you should check the impact on performance. Hence, you should at least investigate the performance roughly by comparing the reported timings of several elixirs. Deeper investigations and micro-benchmarks should usually use BenchmarkTools.jl. For example, the following steps were used to benchmark the changes introduced in https://github.com/trixi-framework/Trixi.jl/pull/256.

  1. git checkout e7ebf3846b3fd62ee1d0042e130afb50d7fe8e48 (new version)

  2. Start julia --threads=1 --check-bounds=no.

  3. Execute the following code in the REPL to benchmark the rhs! call at the final state.

    julia> using BenchmarkTools, Revise; using Trixi
    +
    +julia> trixi_include("examples/2d/elixir_euler_sedov_blast_wave.jl")
    +
    +julia> du_test = copy(sol.u[end]); u_test = copy(sol.u[end]);
    +
    +julia> @benchmark Trixi.rhs!(
    +          $(du_test),
    +          $(u_test),
    +          $(semi),
    +          $(sol.t[end]))
    +BenchmarkTools.Trial:
    + memory estimate:  10.48 KiB
    + allocs estimate:  67
    + --------------
    + minimum time:     4.510 ms (0.00% GC)
    + median time:      4.646 ms (0.00% GC)
    + mean time:        4.699 ms (0.00% GC)
    + maximum time:     7.183 ms (0.00% GC)
    + --------------
    + samples:          1065
    + evals/sample:     1
    +
    +shell> git checkout 222241ff54f8a4ca9876cc1fc25ae262416a4ea0
    +
    +julia> trixi_include("examples/2d/elixir_euler_sedov_blast_wave.jl")
    +
    +julia> @benchmark Trixi.rhs!(
    +          $(du_test),
    +          $(u_test),
    +          $(semi),
    +          $(sol.t[end]))
    +BenchmarkTools.Trial:
    + memory estimate:  10.36 KiB
    + allocs estimate:  67
    + --------------
    + minimum time:     4.500 ms (0.00% GC)
    + median time:      4.635 ms (0.00% GC)
    + mean time:        4.676 ms (0.00% GC)
    + maximum time:     5.880 ms (0.00% GC)
    + --------------
    + samples:          1070
    + evals/sample:     1

    Run the @benchmark ... commands multiple times to see whether there are any significant fluctuations.

Follow these steps for both commits you want to compare. The relevant benchmark results you should typically be looking at are the median and mean values of the runtime and the memory/allocs estimate. In this example, the differences of the runtimes are of the order of the fluctuations one gets when running the benchmarks multiple times. Since the memory/allocs are (roughly) the same, there doesn't seem to be a significant performance regression here.

You can also make it more detailed by benchmarking only, e.g., the calculation of the volume terms, but whether that's necessary depends on the modifications you made and their (potential) impact.

Some more detailed description of manual profiling and benchmarking as well as resulting performance improvements of Trixi.jl are given in the following blog posts.

Automated benchmarking

We use PkgBenchmark.jl to provide a standard set of benchmarks for Trixi.jl. The relevant benchmark script is benchmark/benchmarks.jl. You can run a standard set of benchmarks via

julia> using PkgBenchmark, Trixi
+
+julia> results = benchmarkpkg(Trixi, BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`))
+
+julia> export_markdown(pkgdir(Trixi, "benchmark", "single_benchmark.md"), results)

This will save a markdown file with a summary of the benchmark results similar to this example. Note that this will take quite some time. Additional options are described in the docs of PkgBenchmark.jl. A particularly useful option is to specify a BenchmarkConfig including Julia command line options affecting the performance such as disabling bounds-checking and setting the number of threads.

A useful feature when developing Trixi.jl is to compare the performance of Trixi.jl's current state vs. the main branch. This can be achieved by executing

julia> using PkgBenchmark, Trixi
+
+julia> results = judge(Trixi,
+             BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`), # target
+             BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`, id="main") # baseline
+       )
+
+julia> export_markdown(pkgdir(Trixi, "benchmark", "results.md"), results)

By default, the target is the current state of the repository. Remember that you need to be in a clean state (commit or stash your changes) to run this successfully. You can also run this comparison and an additional one using two threads via

julia> include("benchmark/run_benchmarks.jl")

Then, markdown files including the results are saved in benchmark/. This example result was obtained using a GitHub action for the PR #535. Note that GitHub actions run on in the cloud in a virtual machine. Hence, we do not really have control over it and performance results must be taken with a grain of salt. Nevertheless, significant runtime differences and differences of memory allocations should be robust indicators of performance changes.

Runtime performance vs. latency aka using @nospecialize selectively

Usually, Julia will compile specialized versions of each method, using as much information from the types of function arguments as possible (based on some heuristics). The compiler will generate code that is as efficient as comparable code written in a low-level language such as C or Fortran. However, there are cases where the runtime performance does not really matter but the time needed to compile specializations becomes significant. This is related to latency or the time-to-first-plot problem, well-known in the Julia community. In such a case, it can be useful to remove some burden from the compiler by avoiding specialization on every possible argument types using the macro @nospecialize. A prime example of such a case is pretty printing of structs in the Julia REPL, see the associated PR for further discussions.

As a rule of thumb:

  • Do not use @nospecialize in performance-critical parts, in particular not for methods involved in computing Trixi.rhs!.
  • Consider using @nospecialize for methods like custom implementations of Base.show.

Performance metrics of the AnalysisCallback

The AnalysisCallback computes two performance indicators that you can use to evaluate the serial and parallel performance of Trixi.jl. They represent measured run times that are normalized by the number of rhs! evaluations and the number of degrees of freedom of the problem setup. The normalization ensures that we can compare different measurements for each type of indicator independent of the number of time steps or mesh size. All indicators have in common that they are still in units of time, thus lower is better for each of them.

Here, the term "degrees of freedom" (DOFs) refers to the number of independent state vectors that are used to represent the numerical solution. For example, if you use a DGSEM-type scheme in 2D on a mesh with 8 elements and with 5-by-5 Gauss-Lobatto nodes in each element (i.e., a polynomial degree of 4), the total number of DOFs would be

\[n_\text{DOFs,DGSEM} = \{\text{number of elements}\} \cdot \{\text{number of nodes per element}\} = 8 \cdot (5 \cdot 5) = 200.\]

In contrast, for a finite volume-type scheme on a mesh with 8 elements, the total number of DOFs would be (independent of the number of spatial dimensions)

\[n_\text{DOFs,FV} = \{\text{number of elements}\} = 8,\]

since for standard finite volume methods you store a single state vector in each element. Note that we specifically count the number of state vectors and not the number of state variables for the DOFs. That is, in the previous example $n_\text{DOFs,FV}$ is equal to 8 independent of whether this is a compressible Euler setup with 5 state variables or a linear scalar advection setup with one state variable.

For each indicator, the measurements are always since the last invocation of the AnalysisCallback. That is, if the analysis callback is called multiple times, the indicators are repeatedly computed and can thus also be used to track the performance over the course of a longer simulation, e.g., to analyze setups with varying performance characteristics. Note that the time spent in the AnalysisCallback itself is always excluded, i.e., the performance measurements are not distorted by potentially expensive solution analysis computations. All other parts of a Trixi.jl simulation are included, however, thus make sure that you disable everything you do not want to be measured (such as I/O callbacks, visualization etc.).

Performance indicators and adaptive mesh refinement

Currently it is not possible to compute meaningful performance indicators for a simulation with arbitrary adaptive mesh refinement, since this would require to explicitly keep track of the number of DOF updates due to the mesh size changing repeatedly. The only way to do this at the moment is by setting the analysis interval to the same value as the AMR interval.

Local, rhs!-only indicator

The local, rhs!-only indicator is computed as

\[\text{time/DOF/rhs!} = \frac{t_\text{\texttt{rhs!}}}{n_\text{DOFs,local} \cdot n_\text{calls,\texttt{rhs!}}},\]

where $t_\text{\texttt{rhs!}}$ is the accumulated time spent in rhs!, $n_\text{DOFs,local}$ is the local number of DOFs (i.e., on the current MPI rank; if doing a serial run, you can just think of this as the number of DOFs), and $n_\text{calls,\texttt{rhs!}}$ is the number of times the rhs! function has been evaluated. Note that for this indicator, we measure only the time spent in rhs!, i.e., by definition all computations outside of rhs! - specifically all other callbacks and the time integration method - are not taken into account.

The local, rhs!-only indicator is usually most useful if you do serial measurements and are interested in the performance of the implementation of your core numerical methods (e.g., when doing performance tuning).

Performance index (PID)

The performance index (PID) is computed as

\[\text{PID} = \frac{t_\text{wall} \cdot n_\text{ranks,MPI}}{n_\text{DOFs,global} \cdot n_\text{calls,\texttt{rhs!}}},\]

where $t_\text{wall}$ is the walltime since the last call to the AnalysisCallback, $n_\text{ranks,MPI}$ is the number of MPI ranks used, $n_\text{DOFs,global}$ is the global number of DOFs (i.e., the sum of DOFs over all MPI ranks; if doing a serial run, you can just think of this as the number of DOFs), and $n_\text{calls,\texttt{rhs!}}$ is the number of times the rhs! function has been evaluated since the last call to the AnalysisCallback. The PID measures everything except the time spent in the AnalysisCallback itself - specifically, all other callbacks and the time integration method itself are included.

The PID is usually most useful if you would like to compare the parallel performance of your code to its serial performance. Specifically, it allows you to evaluate the parallelization overhead of your code by giving you a measure of the resources that are necessary to solve a given simulation setup. In a sense, it mimics the "core hours" metric that is often used by supercomputer centers to measure how many resources a particular compute job requires. It can thus be seen as a proxy for "energy used" and, as an extension, "monetary cost".

Initialization overhead in measurements

When using one of the integration schemes from OrdinaryDiffEq.jl, their implementation will initialize some OrdinaryDiffEq.jl-specific information during the first time step. Among other things, one additional call to rhs! is performed. Therefore, make sure that for performance measurements using the PID either the number of timesteps or the workload per rhs! call is large enough to make the initialization overhead negligible. Note that the extra call to rhs! is properly accounted for in both the number of calls and the measured time, so you do not need to worry about it being expensive. If you want a perfect timing result, you need to set the analysis interval such that the AnalysisCallback is invoked at least once during the course of the simulation and discard the first PID value.

diff --git a/previews/PR1697/reference-trixi/index.html b/previews/PR1697/reference-trixi/index.html new file mode 100644 index 00000000000..21fd9882690 --- /dev/null +++ b/previews/PR1697/reference-trixi/index.html @@ -0,0 +1,573 @@ + +Trixi.jl · Trixi.jl

Trixi.jl API

Trixi.TrixiModule
Trixi

Trixi.jl is a numerical simulation framework for hyperbolic conservation laws. A key objective for the framework is to be useful to both scientists and students. Therefore, next to having an extensible design with a fast implementation, Trixi.jl is focused on being easy to use for new or inexperienced users, including the installation and postprocessing procedures.

To get started, run your first simulation with Trixi.jl using

trixi_include(default_example())

See also: trixi-framework/Trixi.jl

source
Trixi.flux_hll_chen_noelleConstant
flux_hll_chen_noelle = FluxHLL(min_max_speed_chen_noelle)

An instance of FluxHLL specific to the shallow water equations that uses the wave speed estimates from min_max_speed_chen_noelle. This HLL flux is guaranteed to have zero numerical mass flux out of a "dry" element, maintain positivity of the water height, and satisfy an entropy inequality.

For complete details see Section 2.4 of the following reference

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI: 10.1137/15M1053074
source
Trixi.AMRCallbackType
AMRCallback(semi, controller [,adaptor=AdaptorAMR(semi)];
+            interval,
+            adapt_initial_condition=true,
+            adapt_initial_condition_only_refine=true,
+            dynamic_load_balancing=true)

Performs adaptive mesh refinement (AMR) every interval time steps for a given semidiscretization semi using the chosen controller.

source
Trixi.AbstractEquationsType
AbstractEquations{NDIMS, NVARS}

An abstract supertype of specific equations such as the compressible Euler equations. The type parameters encode the number of spatial dimensions (NDIMS) and the number of primary variables (NVARS) of the physics model.

source
Trixi.AbstractMeshType
AbstractMesh{NDIMS}

An abstract supertype of specific mesh types such as TreeMesh or StructuredMesh. The type parameters encode the number of spatial dimensions (NDIMS).

source
Trixi.AcousticPerturbationEquations2DType
AcousticPerturbationEquations2D(v_mean_global, c_mean_global, rho_mean_global)

Acoustic perturbation equations (APE) in two space dimensions. The equations are given by

\[\begin{aligned} + \frac{\partial\mathbf{v'}}{\partial t} + \nabla (\bar{\mathbf{v}}\cdot\mathbf{v'}) + + \nabla\left( \frac{\bar{c}^2 \tilde{p}'}{\bar{\rho}} \right) &= 0 \\ + \frac{\partial \tilde{p}'}{\partial t} + + \nabla\cdot (\bar{\rho} \mathbf{v'} + \bar{\mathbf{v}} \tilde{p}') &= 0. +\end{aligned}\]

The bar $\bar{(\cdot)}$ indicates time-averaged quantities. The unknowns of the APE are the perturbed velocities $\mathbf{v'} = (v_1', v_2')^T$ and the scaled perturbed pressure $\tilde{p}' = \frac{p'}{\bar{c}^2}$, where $p'$ denotes the perturbed pressure and the perturbed variables are defined by $\phi' = \phi - \bar{\phi}$.

In addition to the unknowns, Trixi.jl currently stores the mean values in the state vector, i.e. the state vector used internally is given by

\[\mathbf{u} = + \begin{pmatrix} + v_1' \\ v_2' \\ \tilde{p}' \\ \bar{v}_1 \\ \bar{v}_2 \\ \bar{c} \\ \bar{\rho} + \end{pmatrix}.\]

This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the mean values must be zero.
  • The mean values have to be considered when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes these variables too.
  • Trixi.jl's visualization tools will visualize the mean values by default.

The constructor accepts a 2-tuple v_mean_global and scalars c_mean_global and rho_mean_global which can be used to make the definition of initial conditions for problems with constant mean flow more flexible. These values are ignored if the mean values are defined internally in an initial condition.

The equations are based on the APE-4 system introduced in the following paper:

source
Trixi.AdiabaticType
struct Adiabatic

Used to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_normal_flux_function should be a function with signature boundary_value_normal_flux_function(x, t, equations) and return a scalar value for the normal heat flux at point x and time t.

source
Trixi.AliveCallbackType
AliveCallback(analysis_interval=0, alive_interval=analysis_interval÷10)

Inexpensive callback showing that a simulation is still running by printing some information such as the current time to the screen every alive_interval time steps. If analysis_interval ≂̸ 0, the output is omitted every analysis_interval time steps.

source
Trixi.AnalysisCallbackType
AnalysisCallback(semi; interval=0,
+                       save_analysis=false,
+                       output_directory="out",
+                       analysis_filename="analysis.dat",
+                       extra_analysis_errors=Symbol[],
+                       extra_analysis_integrals=())

Analyze a numerical solution every interval time steps and print the results to the screen. If save_analysis, the results are also saved in joinpath(output_directory, analysis_filename).

Additional errors can be computed, e.g. by passing extra_analysis_errors = (:l2_error_primitive, :linf_error_primitive) or extra_analysis_errors = (:conservation_error,).

Further scalar functions func in extra_analysis_integrals are applied to the numerical solution and integrated over the computational domain. Some examples for this are entropy, energy_kinetic, energy_internal, and energy_total. You can also write your own function with the same signature as the examples listed above and pass it via extra_analysis_integrals. See the developer comments about Trixi.analyze, Trixi.pretty_form_utf, and Trixi.pretty_form_ascii for further information on how to create custom analysis quantities.

In addition, the analysis callback records and outputs a number of quantities that are useful for evaluating the computational performance, such as the total runtime, the performance index (time/DOF/rhs!), the time spent in garbage collection (GC), or the current memory usage (alloc'd memory).

source
Trixi.AnalysisCallbackCoupledType
AnalysisCallbackCoupled(semi, callbacks...)

Combine multiple analysis callbacks for coupled simulations with a SemidiscretizationCoupled. For each coupled system, an indididual AnalysisCallback must be created and passed to the AnalysisCallbackCoupled in order, i.e., in the same sequence as the indidvidual semidiscretizations are stored in the SemidiscretizationCoupled.

Experimental code

This is an experimental feature and can change any time.

source
Trixi.AveragingCallbackType
AveragingCallback(semi::SemidiscretizationHyperbolic, tspan; output_directory="out",
+                  filename="averaging.h5")
Experimental code

This callback is experimental and may change in any future release.

A callback that averages the flow field described by semi which must be a semidiscretization of the compressible Euler equations in two dimensions. The callback records the mean velocity, mean speed of sound, mean density, and mean vorticity for each node over the time interval given by tspan and stores the results in an HDF5 file filename in the directory output_directory. Note that this callback does not support adaptive mesh refinement (AMRCallback).

source
Trixi.BoundaryConditionCoupledType
BoundaryConditionCoupled(other_semi_index, indices, uEltype)

Boundary condition to glue two meshes together. Solution values at the boundary of another mesh will be used as boundary values. This requires the use of SemidiscretizationCoupled. The other mesh is specified by other_semi_index, which is the index of the mesh in the tuple of semidiscretizations.

Note that the elements and nodes of the two meshes at the coupled boundary must coincide. This is currently only implemented for StructuredMesh.

Arguments

  • other_semi_index: the index in SemidiscretizationCoupled of the semidiscretization from which the values are copied
  • indices::Tuple: node/cell indices at the boundary of the mesh in the other semidiscretization. See examples below.
  • uEltype::Type: element type of solution

Examples

# Connect the left boundary of mesh 2 to our boundary such that our positive
+# boundary direction will match the positive y direction of the other boundary
+BoundaryConditionCoupled(2, (:begin, :i), Float64)
+
+# Connect the same two boundaries oppositely oriented
+BoundaryConditionCoupled(2, (:begin, :i_backwards), Float64)
+
+# Using this as y_neg boundary will connect `our_cells[i, 1, j]` to `other_cells[j, end-i, end]`
+BoundaryConditionCoupled(2, (:j, :i_backwards, :end), Float64)
Experimental code

This is an experimental feature and can change any time.

source
Trixi.BoundaryConditionDirichletType
BoundaryConditionDirichlet(boundary_value_function)

Create a Dirichlet boundary condition that uses the function boundary_value_function to specify the values at the boundary. This can be used to create a boundary condition that specifies exact boundary values by passing the exact solution of the equation. The passed boundary value function will be called with the same arguments as an initial condition function is called, i.e., as

boundary_value_function(x, t, equations)

where x specifies the coordinates, t is the current time, and equation is the corresponding system of equations.

Examples

julia> BoundaryConditionDirichlet(initial_condition_convergence_test)
source
Trixi.BoundaryConditionNavierStokesWallType
struct BoundaryConditionNavierStokesWall

Creates a wall-type boundary conditions for the compressible Navier-Stokes equations. The fields boundary_condition_velocity and boundary_condition_heat_flux are intended to be boundary condition types such as the NoSlip velocity boundary condition and the Adiabatic or Isothermal heat boundary condition.

Experimental feature

This is an experimental feature and may change in future releases.

source
Trixi.BoundaryConditionNeumannType
BoundaryConditionNeumann(boundary_normal_flux_function)

Similar to BoundaryConditionDirichlet, but creates a Neumann boundary condition for parabolic equations that uses the function boundary_normal_flux_function to specify the values of the normal flux at the boundary. The passed boundary value function will be called with the same arguments as an initial condition function is called, i.e., as

boundary_normal_flux_function(x, t, equations)

where x specifies the coordinates, t is the current time, and equation is the corresponding system of equations.

source
Trixi.BoundsCheckCallbackType
BoundsCheckCallback(; output_directory="out", save_errors=false, interval=1)

Subcell limiting techniques with SubcellLimiterIDP are constructed to adhere certain local or global bounds. To make sure that these bounds are actually met, this callback calculates the maximum deviation from the bounds. The maximum deviation per applied bound is printed to the screen at the end of the simulation. For more insights, when setting save_errors=true the occurring errors are exported every interval time steps during the simulation. Then, the maximum deviations since the last export are saved in "output_directory/deviations.txt". The BoundsCheckCallback has to be applied as a stage callback for the SSPRK time integration scheme.

Note

For SubcellLimiterIDP, the solution is corrected in the a posteriori correction stage SubcellLimiterIDPCorrection. So, to check the final solution, this bounds check callback must be called after the correction stage.

source
Trixi.CarpenterKennedy2N54Type
CarpenterKennedy2N54()

The following structures and methods provide a minimal implementation of the low-storage explicit Runge-Kutta method of

Carpenter, Kennedy (1994) Fourth order 2N storage RK schemes, Solution 3

using the same interface as OrdinaryDiffEq.jl.

source
Trixi.CompressibleEulerEquations1DType
CompressibleEulerEquations1D(gamma)

The compressible Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho v_1 \\ \rho e +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} +\rho v_1 \\ \rho v_1^2 + p \\ (\rho e +p) v_1 +\end{pmatrix} += +\begin{pmatrix} +0 \\ 0 \\ 0 +\end{pmatrix}\]

for an ideal gas with ratio of specific heats gamma in one space dimension. Here, $\rho$ is the density, $v_1$ the velocity, $e$ the specific total energy rather than specific internal energy, and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho v_1^2 \right)\]

the pressure.

source
Trixi.CompressibleEulerEquations2DType
CompressibleEulerEquations2D(gamma)

The compressible Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho v_1 \\ \rho v_2 \\ \rho e +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} + \rho v_1 \\ \rho v_1^2 + p \\ \rho v_1 v_2 \\ (\rho e +p) v_1 +\end{pmatrix} ++ +\frac{\partial}{\partial y} +\begin{pmatrix} +\rho v_2 \\ \rho v_1 v_2 \\ \rho v_2^2 + p \\ (\rho e +p) v_2 +\end{pmatrix} += +\begin{pmatrix} +0 \\ 0 \\ 0 \\ 0 +\end{pmatrix}\]

for an ideal gas with ratio of specific heats gamma in two space dimensions. Here, $\rho$ is the density, $v_1$, $v_2$ the velocities, $e$ the specific total energy rather than specific internal energy, and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2+v_2^2) \right)\]

the pressure.

source
Trixi.CompressibleEulerEquations3DType
CompressibleEulerEquations3D(gamma)

The compressible Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho v_1 \\ \rho v_2 \\ \rho v_3 \\ \rho e +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} + \rho v_1 \\ \rho v_1^2 + p \\ \rho v_1 v_2 \\ \rho v_1 v_3 \\ ( \rho e +p) v_1 +\end{pmatrix} ++ +\frac{\partial}{\partial y} +\begin{pmatrix} +\rho v_2 \\ \rho v_1 v_2 \\ \rho v_2^2 + p \\ \rho v_1 v_3 \\ ( \rho e +p) v_2 +\end{pmatrix} ++ +\frac{\partial}{\partial z} +\begin{pmatrix} +\rho v_3 \\ \rho v_1 v_3 \\ \rho v_2 v_3 \\ \rho v_3^2 + p \\ ( \rho e +p) v_3 +\end{pmatrix} += +\begin{pmatrix} +0 \\ 0 \\ 0 \\ 0 \\ 0 +\end{pmatrix}\]

for an ideal gas with ratio of specific heats gamma in three space dimensions. Here, $\rho$ is the density, $v_1$, $v_2$, $v_3$ the velocities, $e$ the specific total energy rather than specific internal energy, and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2+v_2^2+v_3^2) \right)\]

the pressure.

source
Trixi.CompressibleEulerMulticomponentEquations1DType
CompressibleEulerMulticomponentEquations1D(; gammas, gas_constants)

Multicomponent version of the compressible Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho v_1 \\ \rho e \\ \rho_1 \\ \rho_2 \\ \vdots \\ \rho_{n} +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} +\rho v_1^2 + p \\ (\rho e +p) v_1 \\ \rho_1 v_1 \\ \rho_2 v_1 \\ \vdots \\ \rho_{n} v_1 +\end{pmatrix} + += +\begin{pmatrix} +0 \\ 0 \\ 0 \\ 0 \\ \vdots \\ 0 +\end{pmatrix}\]

for calorically perfect gas in one space dimension. Here, $\rho_i$ is the density of component $i$, $\rho=\sum_{i=1}^n\rho_i$ the sum of the individual $\rho_i$, $v_1$ the velocity, $e$ the specific total energy rather than specific internal energy, and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho v_1^2 \right)\]

the pressure,

\[\gamma=\frac{\sum_{i=1}^n\rho_i C_{v,i}\gamma_i}{\sum_{i=1}^n\rho_i C_{v,i}}\]

total heat capacity ratio, $\gamma_i$ heat capacity ratio of component $i$,

\[C_{v,i}=\frac{R}{\gamma_i-1}\]

specific heat capacity at constant volume of component $i$.

In case of more than one component, the specific heat ratios gammas and the gas constants gas_constants should be passed as tuples, e.g., gammas=(1.4, 1.667).

The remaining variables like the specific heats at constant volume cv or the specific heats at constant pressure cp are then calculated considering a calorically perfect gas.

source
Trixi.CompressibleEulerMulticomponentEquations2DType
CompressibleEulerMulticomponentEquations2D(; gammas, gas_constants)

Multicomponent version of the compressible Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho v_1 \\ \rho v_2 \\ \rho e \\ \rho_1 \\ \rho_2 \\ \vdots \\ \rho_{n} +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} +\rho v_1^2 + p \\ \rho v_1 v_2 \\ ( \rho e +p) v_1 \\ \rho_1 v_1 \\ \rho_2 v_1 \\ \vdots \\ \rho_{n} v_1 +\end{pmatrix} ++ +\frac{\partial}{\partial y} +\begin{pmatrix} +\rho v_1 v_2 \\ \rho v_2^2 + p \\ ( \rho e +p) v_2 \\ \rho_1 v_2 \\ \rho_2 v_2 \\ \vdots \\ \rho_{n} v_2 +\end{pmatrix} += +\begin{pmatrix} +0 \\ 0 \\ 0 \\ 0 \\ 0 \\ \vdots \\ 0 +\end{pmatrix}\]

for calorically perfect gas in two space dimensions. Here, $\rho_i$ is the density of component $i$, $\rho=\sum_{i=1}^n\rho_i$ the sum of the individual $\rho_i$, $v_1$, $v_2$ the velocities, $e$ the specific total energy rather than specific internal energy, and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2 + v_2^2) \right)\]

the pressure,

\[\gamma=\frac{\sum_{i=1}^n\rho_i C_{v,i}\gamma_i}{\sum_{i=1}^n\rho_i C_{v,i}}\]

total heat capacity ratio, $\gamma_i$ heat capacity ratio of component $i$,

\[C_{v,i}=\frac{R}{\gamma_i-1}\]

specific heat capacity at constant volume of component $i$.

In case of more than one component, the specific heat ratios gammas and the gas constants gas_constants in [kJ/(kg*K)] should be passed as tuples, e.g., gammas=(1.4, 1.667).

The remaining variables like the specific heats at constant volume cv or the specific heats at constant pressure cp are then calculated considering a calorically perfect gas.

source
Trixi.CompressibleNavierStokesDiffusion1DType
CompressibleNavierStokesDiffusion1D(equations; mu, Pr,
+                                    gradient_variables=GradientVariablesPrimitive())

Contains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations1D.

  • equations: instance of the CompressibleEulerEquations1D
  • mu: dynamic viscosity,
  • Pr: Prandtl number,
  • gradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().

Fluid properties such as the dynamic viscosity $\mu$ can be provided in any consistent unit system, e.g., [$\mu$] = kg m⁻¹ s⁻¹.

The particular form of the compressible Navier-Stokes implemented is

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho v \\ \rho e +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} + \rho v \\ \rho v^2 + p \\ (\rho e + p) v +\end{pmatrix} += +\frac{\partial}{\partial x} +\begin{pmatrix} +0 \\ \tau \\ \tau v - q +\end{pmatrix}\]

where the system is closed with the ideal gas assumption giving

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho v^2 \right)\]

as the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations1D. The terms on the right hand side of the system above are built from the viscous stress

\[\tau = \mu \frac{\partial}{\partial x} v\]

where the heat flux is

\[q = -\kappa \frac{\partial}{\partial x} \left(T\right),\quad T = \frac{p}{R\rho}\]

where $T$ is the temperature and $\kappa$ is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is

\[\kappa = \frac{\gamma \mu R}{(\gamma - 1)\textrm{Pr}}.\]

From this combination of temperature $T$ and thermal conductivity $\kappa$ we see that the gas constant R cancels and the heat flux becomes

\[q = -\kappa \frac{\partial}{\partial x} \left(T\right) = -\frac{\gamma \mu}{(\gamma - 1)\textrm{Pr}} \frac{\partial}{\partial x} \left(\frac{p}{\rho}\right)\]

which is the form implemented below in the flux function.

In one spatial dimensions we require gradients for two quantities, e.g., primitive quantities

\[\frac{\partial}{\partial x} v,\, \frac{\partial}{\partial x} T\]

or the entropy variables

\[\frac{\partial}{\partial x} w_2,\, \frac{\partial}{\partial x} w_3\]

where

\[w_2 = \frac{\rho v1}{p},\, w_3 = -\frac{\rho}{p}\]

Experimental code

This code is experimental and may be changed or removed in any future release.

source
Trixi.CompressibleNavierStokesDiffusion2DType
CompressibleNavierStokesDiffusion2D(equations; mu, Pr,
+                                    gradient_variables=GradientVariablesPrimitive())

Contains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations2D.

  • equations: instance of the CompressibleEulerEquations2D
  • mu: dynamic viscosity,
  • Pr: Prandtl number,
  • gradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().

Fluid properties such as the dynamic viscosity $\mu$ can be provided in any consistent unit system, e.g., [$\mu$] = kg m⁻¹ s⁻¹.

The particular form of the compressible Navier-Stokes implemented is

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho \mathbf{v} \\ \rho e +\end{pmatrix} ++ +\nabla \cdot +\begin{pmatrix} + \rho \mathbf{v} \\ \rho \mathbf{v}\mathbf{v}^T + p \underline{I} \\ (\rho e + p) \mathbf{v} +\end{pmatrix} += +\nabla \cdot +\begin{pmatrix} +0 \\ \underline{\tau} \\ \underline{\tau}\mathbf{v} - \mathbf{q} +\end{pmatrix}\]

where the system is closed with the ideal gas assumption giving

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2+v_2^2) \right)\]

as the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations2D. The terms on the right hand side of the system above are built from the viscous stress tensor

\[\underline{\tau} = \mu \left(\nabla\mathbf{v} + \left(\nabla\mathbf{v}\right)^T\right) - \frac{2}{3} \mu \left(\nabla\cdot\mathbf{v}\right)\underline{I}\]

where $\underline{I}$ is the $2\times 2$ identity matrix and the heat flux is

\[\mathbf{q} = -\kappa\nabla\left(T\right),\quad T = \frac{p}{R\rho}\]

where $T$ is the temperature and $\kappa$ is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is

\[\kappa = \frac{\gamma \mu R}{(\gamma - 1)\textrm{Pr}}.\]

From this combination of temperature $T$ and thermal conductivity $\kappa$ we see that the gas constant R cancels and the heat flux becomes

\[\mathbf{q} = -\kappa\nabla\left(T\right) = -\frac{\gamma \mu}{(\gamma - 1)\textrm{Pr}}\nabla\left(\frac{p}{\rho}\right)\]

which is the form implemented below in the flux function.

In two spatial dimensions we require gradients for three quantities, e.g., primitive quantities

\[\nabla v_1,\, \nabla v_2,\, \nabla T\]

or the entropy variables

\[\nabla w_2,\, \nabla w_3,\, \nabla w_4\]

where

\[w_2 = \frac{\rho v_1}{p},\, w_3 = \frac{\rho v_2}{p},\, w_4 = -\frac{\rho}{p}\]

Experimental code

This code is experimental and may be changed or removed in any future release.

source
Trixi.CompressibleNavierStokesDiffusion3DType
CompressibleNavierStokesDiffusion3D(equations; mu, Pr,
+                                    gradient_variables=GradientVariablesPrimitive())

Contains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations3D.

  • equations: instance of the CompressibleEulerEquations3D
  • mu: dynamic viscosity,
  • Pr: Prandtl number,
  • gradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().

Fluid properties such as the dynamic viscosity $\mu$ can be provided in any consistent unit system, e.g., [$\mu$] = kg m⁻¹ s⁻¹.

The particular form of the compressible Navier-Stokes implemented is

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho \mathbf{v} \\ \rho e +\end{pmatrix} ++ +\nabla \cdot +\begin{pmatrix} + \rho \mathbf{v} \\ \rho \mathbf{v}\mathbf{v}^T + p \underline{I} \\ (\rho e + p) \mathbf{v} +\end{pmatrix} += +\nabla \cdot +\begin{pmatrix} +0 \\ \underline{\tau} \\ \underline{\tau}\mathbf{v} - \mathbf{q} +\end{pmatrix}\]

where the system is closed with the ideal gas assumption giving

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2+v_2^2+v_3^2) \right)\]

as the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations2D. The terms on the right hand side of the system above are built from the viscous stress tensor

\[\underline{\tau} = \mu \left(\nabla\mathbf{v} + \left(\nabla\mathbf{v}\right)^T\right) - \frac{2}{3} \mu \left(\nabla\cdot\mathbf{v}\right)\underline{I}\]

where $\underline{I}$ is the $3\times 3$ identity matrix and the heat flux is

\[\mathbf{q} = -\kappa\nabla\left(T\right),\quad T = \frac{p}{R\rho}\]

where $T$ is the temperature and $\kappa$ is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is

\[\kappa = \frac{\gamma \mu R}{(\gamma - 1)\textrm{Pr}}.\]

From this combination of temperature $T$ and thermal conductivity $\kappa$ we see that the gas constant R cancels and the heat flux becomes

\[\mathbf{q} = -\kappa\nabla\left(T\right) = -\frac{\gamma \mu}{(\gamma - 1)\textrm{Pr}}\nabla\left(\frac{p}{\rho}\right)\]

which is the form implemented below in the flux function.

In two spatial dimensions we require gradients for three quantities, e.g., primitive quantities

\[\nabla v_1,\, \nabla v_2,\, \nabla v_3,\, \nabla T\]

or the entropy variables

\[\nabla w_2,\, \nabla w_3,\, \nabla w_4\, \nabla w_5\]

where

\[w_2 = \frac{\rho v_1}{p},\, w_3 = \frac{\rho v_2}{p},\, w_4 = \frac{\rho v_3}{p},\, w_5 = -\frac{\rho}{p}\]

Experimental code

This code is experimental and may be changed or removed in any future release.

source
Trixi.ControllerThreeLevelType
ControllerThreeLevel(semi, indicator; base_level=1,
+                                      med_level=base_level, med_threshold=0.0,
+                                      max_level=base_level, max_threshold=1.0)

An AMR controller based on three levels (in descending order of precedence):

  • set the target level to max_level if indicator > max_threshold
  • set the target level to med_level if indicator > med_threshold; if med_level < 0, set the target level to the current level
  • set the target level to base_level otherwise
source
Trixi.ControllerThreeLevelCombinedType
ControllerThreeLevelCombined(semi, indicator_primary, indicator_secondary;
+                             base_level=1,
+                             med_level=base_level, med_threshold=0.0,
+                             max_level=base_level, max_threshold=1.0,
+                             max_threshold_secondary=1.0)

An AMR controller based on three levels (in descending order of precedence):

  • set the target level to max_level if indicator_primary > max_threshold
  • set the target level to med_level if indicator_primary > med_threshold; if med_level < 0, set the target level to the current level
  • set the target level to base_level otherwise

If indicator_secondary >= max_threshold_secondary, set the target level to max_level.

source
Trixi.DGMultiMethod
DGMulti(approximation_type::AbstractDerivativeOperator;
+        element_type::AbstractElemShape,
+        surface_flux=flux_central,
+        surface_integral=SurfaceIntegralWeakForm(surface_flux),
+        volume_integral=VolumeIntegralWeakForm(),
+        kwargs...)

Create a summation by parts (SBP) discretization on the given element_type using a tensor product structure based on the 1D SBP derivative operator passed as approximation_type.

For more info, see the documentations of StartUpDG.jl and SummationByPartsOperators.jl.

source
Trixi.DGMultiMethod
DGMulti(; polydeg::Integer,
+          element_type::AbstractElemShape,
+          approximation_type=Polynomial(),
+          surface_flux=flux_central,
+          surface_integral=SurfaceIntegralWeakForm(surface_flux),
+          volume_integral=VolumeIntegralWeakForm(),
+          RefElemData_kwargs...)

Create a discontinuous Galerkin method which uses

  • approximations of polynomial degree polydeg
  • element type element_type (Tri(), Quad(), Tet(), and Hex() currently supported)

Optional:

  • approximation_type (default is Polynomial(); SBP() also supported for Tri(), Quad(), and Hex() element types).
  • RefElemData_kwargs are additional keyword arguments for RefElemData, such as quad_rule_vol. For more info, see the StartUpDG.jl docs.
source
Trixi.DGMultiMeshType
DGMultiMesh{NDIMS, ...}

DGMultiMesh describes a mesh type which wraps StartUpDG.MeshData and boundary_faces in a dispatchable type. This is intended to store geometric data and connectivities for any type of mesh (Cartesian, affine, curved, structured/unstructured).

source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti{2, Tri}, triangulateIO, boundary_dict::Dict{Symbol, Int})
  • dg::DGMulti contains information associated with to the reference element (e.g., quadrature, basis evaluation, differentiation, etc).
  • triangulateIO is a TriangulateIO mesh representation
  • boundary_dict is a Dict{Symbol, Int} which associates each integer TriangulateIO boundary tag with a Symbol.
source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti)

Constructs a single-element DGMultiMesh for a single periodic element given a DGMulti with approximation_type set to a periodic (finite difference) SBP operator from SummationByPartsOperators.jl.

source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti{NDIMS}, vertex_coordinates, EToV;
+            is_on_boundary=nothing,
+            periodicity=ntuple(_->false, NDIMS)) where {NDIMS}
  • dg::DGMulti contains information associated with to the reference element (e.g., quadrature, basis evaluation, differentiation, etc).
  • vertex_coordinates is a tuple of vectors containing x,y,... components of the vertex coordinates
  • EToV is a 2D array containing element-to-vertex connectivities for each element
  • is_on_boundary specifies boundary using a Dict{Symbol, <:Function}
  • periodicity is a tuple of booleans specifying if the domain is periodic true/false in the (x,y,z) direction.
source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti{NDIMS}, cells_per_dimension, mapping;
+            is_on_boundary=nothing,
+            periodicity=ntuple(_ -> false, NDIMS), kwargs...) where {NDIMS}

Constructs a Curved() DGMultiMesh with element type dg.basis.element_type.

  • mapping is a function which maps from a reference [-1, 1]^NDIMS domain to a mapped domain, e.g., xy = mapping(x, y) in 2D.
  • is_on_boundary specifies boundary using a Dict{Symbol, <:Function}
  • periodicity is a tuple of Bools specifying periodicity = true/false in the (x,y,z) direction.
source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti, cells_per_dimension;
+            coordinates_min=(-1.0, -1.0), coordinates_max=(1.0, 1.0),
+            is_on_boundary=nothing,
+            periodicity=ntuple(_ -> false, NDIMS))

Constructs a Cartesian DGMultiMesh with element type dg.basis.element_type. The domain is the tensor product of the intervals [coordinates_min[i], coordinates_max[i]].

  • is_on_boundary specifies boundary using a Dict{Symbol, <:Function}
  • periodicity is a tuple of Bools specifying periodicity = true/false in the (x,y,z) direction.
source
Trixi.DGMultiMeshMethod
DGMultiMesh(dg::DGMulti, filename::String)
  • dg::DGMulti contains information associated with the reference element (e.g., quadrature, basis evaluation, differentiation, etc).
  • filename is a path specifying a .mesh file generated by HOHQMesh.
source
Trixi.DGSEMType
DGSEM(; RealT=Float64, polydeg::Integer,
+        surface_flux=flux_central,
+        surface_integral=SurfaceIntegralWeakForm(surface_flux),
+        volume_integral=VolumeIntegralWeakForm(),
+        mortar=MortarL2(basis))

Create a discontinuous Galerkin spectral element method (DGSEM) using a LobattoLegendreBasis with polynomials of degree polydeg.

source
Trixi.DissipationLocalLaxFriedrichsType
DissipationLocalLaxFriedrichs(max_abs_speed=max_abs_speed_naive)

Create a local Lax-Friedrichs dissipation operator where the maximum absolute wave speed is estimated as max_abs_speed(u_ll, u_rr, orientation_or_normal_direction, equations), defaulting to max_abs_speed_naive.

source
Trixi.EulerAcousticsCouplingCallbackType
EulerAcousticsCouplingCallback
Experimental code

This callback is experimental and may change in any future release.

A callback that couples the acoustic perturbation equations and compressible Euler equations. Must be used in conjunction with SemidiscretizationEulerAcoustics. This callback manages the flow solver - which is always one time step ahead of the acoustics solver - and calculates the acoustic source term after each time step. The linearized Lamb vector is used as the source term, i.e.

\[\mathbf{s} = -(\mathbf{\omega'} \times \bar{\mathbf{v}} + + \bar{\mathbf{\omega}} \times \mathbf{v'}),\]

where $\mathbf{v}$ denotes the velocity, $\mathbf{\omega}$ denotes the vorticity, the bar $\bar{(\cdot)}$ indicates time-averaged quantities (see AveragingCallback) and prime $(\cdot)'$ denotes perturbed quantities defined by $\phi' = \phi - \bar{\phi}$. Note that the perturbed quantities here are based entirely on the pure flow solution and should not be confused with the state variables of the acoustic perturbation equations.

In addition, this callback manages the time step size for both solvers and initializes the mean values of the acoustic perturbation equations using results obtained with the AveragingCallback.

source
Trixi.EulerAcousticsCouplingCallbackMethod
EulerAcousticsCouplingCallback(ode_euler, averaging_file::AbstractString, alg,
+                               cfl_acoustics::Real, cfl_euler::Real; kwargs...)
Experimental code

This callback is experimental and may change in any future release.

Creates an EulerAcousticsCouplingCallback based on the pure flow ODEProblem given by ode_euler. Creates an integrator using the time integration method alg and the keyword arguments to solve ode_euler (consult the OrdinaryDiffEq documentation for further information). Manages the step size for both solvers by using the minimum of the maximum step size obtained with CFL numbers cfl_acoustics for the acoustics solver and cfl_euler for and flow solver, respectively. The mean values for the acoustic perturbation equations are read from averaging_file (see AveragingCallback).

source
Trixi.EulerAcousticsCouplingCallbackMethod
EulerAcousticsCouplingCallback(ode_euler,
+                               averaging_callback::DiscreteCallback{<:Any, <:AveragingCallback},
+                               alg, cfl_acoustics::Real, cfl_euler::Real; kwargs...)
Experimental code

This callback is experimental and may change in any future release.

Creates an EulerAcousticsCouplingCallback based on the pure flow ODEProblem given by ode_euler. Creates an integrator using the time integration method alg and the keyword arguments to solve ode_euler (consult the OrdinaryDiffEq documentation for further information). Manages the step size for both solvers by using the minimum of the maximum step size obtained with CFL numbers cfl_acoustics for the acoustics solver and cfl_euler for and flow solver, respectively. The mean values for the acoustic perturbation equations are read from averaging_callback (see AveragingCallback).

source
Trixi.FDSBPType
FDSBP(D_SBP; surface_integral, volume_integral)

Specialization of DG methods that uses general summation by parts (SBP) operators from SummationByPartsOperators.jl. In particular, this includes classical finite difference (FD) SBP methods. These methods have the same structure as classical DG methods - local operations on elements with connectivity through interfaces without imposing any continuity constraints.

D_SBP is an SBP derivative operator from SummationByPartsOperators.jl. The other arguments have the same meaning as in DG or DGSEM.

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.FluxHLLType
FluxHLL(min_max_speed=min_max_speed_naive)

Create an HLL (Harten, Lax, van Leer) numerical flux where the minimum and maximum wave speeds are estimated as λ_min, λ_max = min_max_speed(u_ll, u_rr, orientation_or_normal_direction, equations), defaulting to min_max_speed_naive. Original paper:

  • Amiram Harten, Peter D. Lax, Bram van Leer (1983) On Upstream Differencing and Godunov-Type Schemes for Hyperbolic Conservation Laws DOI: 10.1137/1025002
source
Trixi.FluxHydrostaticReconstructionType
FluxHydrostaticReconstruction(numerical_flux, hydrostatic_reconstruction)
Experimental code

This numerical flux is experimental and may change in any future release.

Allow for some kind of hydrostatic reconstruction of the solution state prior to the surface flux computation. This is a particular strategy to ensure that the method remains well-balanced for the shallow water equations, see ShallowWaterEquations1D or ShallowWaterEquations2D.

For example, the hydrostatic reconstruction from Audusse et al. is implemented in one and two spatial dimensions, see hydrostatic_reconstruction_audusse_etal or the original paper

  • Emmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090

Other hydrostatic reconstruction techniques are available, particularly to handle wet / dry fronts. A good overview of the development and application of hydrostatic reconstruction can be found in

  • Guoxian Chen and Sebastian Noelle A unified surface-gradient and hydrostatic reconstruction scheme for the shallow water equations (2021) RWTH Aachen preprint
  • Andreas Buttinger-Kreuzhuber, Zsolt Horváth, Sebastian Noelle, Günter Blöschl and Jürgen Waser (2019) A fast second-order shallow water scheme on two-dimensional structured grids over abrupt topography DOI: 10.1016/j.advwatres.2019.03.010
source
Trixi.FluxLMARSType
FluxLMARS(c)(u_ll, u_rr, orientation_or_normal_direction,
+             equations::CompressibleEulerEquations3D)

Low Mach number approximate Riemann solver (LMARS) for atmospheric flows using an estimate c of the speed of sound.

References:

  • Xi Chen et al. (2013) A Control-Volume Model of the Compressible Euler Equations with a Vertical Lagrangian Coordinate DOI: 10.1175/MWR-D-12-00129.1
source
Trixi.FluxPlusDissipationType
FluxPlusDissipation(numerical_flux, dissipation)

Combine a numerical_flux with a dissipation operator to create a new numerical flux.

source
Trixi.FluxRotatedType
FluxRotated(numerical_flux)

Compute a numerical_flux flux in direction of a normal vector by rotating the solution, computing the numerical flux in x-direction, and rotating the calculated flux back.

Requires a rotationally invariant equation with equation-specific functions rotate_to_x and rotate_from_x.

source
Trixi.FluxUpwindType
FluxUpwind(splitting)

A numerical flux f(u_left, u_right) = f⁺(u_left) + f⁻(u_right) based on flux vector splitting.

The SurfaceIntegralUpwind with a given splitting is equivalent to the SurfaceIntegralStrongForm with FluxUpwind(splitting) as numerical flux (up to floating point differences).

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.GlmSpeedCallbackType
GlmSpeedCallback(; glm_scale=0.5, cfl)

Update the divergence cleaning wave speed c_h according to the time step computed in StepsizeCallback for the ideal GLM-MHD equations. The cfl number should be set to the same value as for the time step size calculation. The glm_scale ensures that the GLM wave speed is lower than the fastest physical waves in the MHD solution and should thus be set to a value within the interval [0,1]. Note that glm_scale = 0 deactivates the divergence cleaning.

source
Trixi.GradientVariablesPrimitiveType
Experimental code

This code is experimental and may be changed or removed in any future release.

GradientVariablesPrimitive and GradientVariablesEntropy are gradient variable type parameters for CompressibleNavierStokesDiffusion1D. By default, the gradient variables are set to be GradientVariablesPrimitive. Specifying GradientVariablesEntropy instead uses the entropy variable formulation from

  • Hughes, Mallet, Franca (1986) A new finite element formulation for computational fluid dynamics: I. Symmetric forms of the compressible Euler and Navier-Stokes equations and the second law of thermodynamics. https://doi.org/10.1016/0045-7825(86)90127-1

Under GradientVariablesEntropy, the Navier-Stokes discretization is provably entropy stable.

source
Trixi.HypDiffN3Erk3Sstar52Type
HypDiffN3Erk3Sstar52()

Five stage, second-order accurate explicit Runge-Kutta scheme with stability region optimized for the hyperbolic diffusion equation with LLF flux and polynomials of degree polydeg=3.

source
Trixi.HyperbolicDiffusionEquations1DType
HyperbolicDiffusionEquations1D

The linear hyperbolic diffusion equations in one space dimension. A description of this system can be found in Sec. 2.5 of the book

Further analysis can be found in the paper

source
Trixi.IdealGlmMhdEquations1DType
IdealGlmMhdEquations1D(gamma)

The ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in one space dimension.

Note

There is no divergence cleaning variable psi because the divergence-free constraint is satisfied trivially in one spatial dimension.

source
Trixi.IdealGlmMhdEquations2DType
IdealGlmMhdEquations2D(gamma)

The ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in two space dimensions.

source
Trixi.IdealGlmMhdEquations3DType
IdealGlmMhdEquations3D(gamma)

The ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in three space dimensions.

source
Trixi.IndicatorHennemannGassnerType
IndicatorHennemannGassner(equations::AbstractEquations, basis;
+                          alpha_max=0.5,
+                          alpha_min=0.001,
+                          alpha_smooth=true,
+                          variable)
+IndicatorHennemannGassner(semi::AbstractSemidiscretization;
+                          alpha_max=0.5,
+                          alpha_min=0.001,
+                          alpha_smooth=true,
+                          variable)

Indicator used for shock-capturing (when passing the equations and the basis) or adaptive mesh refinement (AMR, when passing the semi).

See also VolumeIntegralShockCapturingHG.

References

  • Hennemann, Gassner (2020) "A provably entropy stable subcell shock capturing approach for high order split form DG" arXiv: 2008.12044
source
Trixi.IndicatorHennemannGassnerShallowWaterType
IndicatorHennemannGassnerShallowWater(equations::AbstractEquations, basis;
+                                      alpha_max=0.5,
+                                      alpha_min=0.001,
+                                      alpha_smooth=true,
+                                      variable)

Modified version of the IndicatorHennemannGassner indicator used for shock-capturing for shallow water equations. After the element-wise values for the blending factors are computed an additional check is made to see if the element is partially wet. In this case, partially wet elements are set to use the pure finite volume scheme that is guaranteed to be well-balanced for this wet/dry transition state of the flow regime.

See also VolumeIntegralShockCapturingHG.

References

  • Hennemann, Gassner (2020) "A provably entropy stable subcell shock capturing approach for high order split form DG" arXiv: 2008.12044
source
Trixi.IndicatorLöhnerType
IndicatorLöhner (equivalent to IndicatorLoehner)
+
+IndicatorLöhner(equations::AbstractEquations, basis;
+                f_wave=0.2, variable)
+IndicatorLöhner(semi::AbstractSemidiscretization;
+                f_wave=0.2, variable)

AMR indicator adapted from a FEM indicator by Löhner (1987), also used in the FLASH code as standard AMR indicator. The indicator estimates a weighted second derivative of a specified variable locally.

When constructed to be used for AMR, pass the semi. Pass the equations, and basis if this indicator should be used for shock capturing.

References

source
Trixi.IndicatorMaxType
IndicatorMax(equations::AbstractEquations, basis; variable)
+IndicatorMax(semi::AbstractSemidiscretization; variable)

A simple indicator returning the maximum of variable in an element. When constructed to be used for AMR, pass the semi. Pass the equations, and basis if this indicator should be used for shock capturing.

source
Trixi.IndicatorNeuralNetworkType
IndicatorNeuralNetwork

Artificial neural network based indicator used for shock-capturing or AMR. Depending on the indicator_type, different input values and corresponding trained networks are used.

indicator_type = NeuralNetworkPerssonPeraire()

  • Input: The energies in lower modes as well as nnodes(dg).

indicator_type = NeuralNetworkRayHesthaven()

  • 1d Input: Cell average of the cell and its neighboring cells as well as the interface values.

  • 2d Input: Linear modal values of the cell and its neighboring cells.

  • Ray, Hesthaven (2018) "An artificial neural network as a troubled-cell indicator" doi:10.1016/j.jcp.2018.04.029

  • Ray, Hesthaven (2019) "Detecting troubled-cells on two-dimensional unstructured grids using a neural network" doi:10.1016/j.jcp.2019.07.043

indicator_type = CNN (Only in 2d)

  • Based on convolutional neural network.
  • 2d Input: Interpolation of the nodal values of the indicator.variable to the 4x4 LGL nodes.

If alpha_continuous == true the continuous network output for troubled cells (alpha > 0.5) is considered. If the cells are good (alpha < 0.5), alpha is set to 0. If alpha_continuous == false, the blending factor is set to alpha = 0 for good cells and alpha = 1 for troubled cells.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.IsothermalType
struct Isothermal

Used to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_function should be a function with signature boundary_value_function(x, t, equations) and return a scalar value for the temperature at point x and time t.

source
Trixi.LaplaceDiffusion1DType
LaplaceDiffusion1D(diffusivity, equations)

LaplaceDiffusion1D represents a scalar diffusion term $\nabla \cdot (\kappa\nabla u))$ with diffusivity $\kappa$ applied to each solution component defined by equations.

source
Trixi.LaplaceDiffusion2DType
LaplaceDiffusion2D(diffusivity, equations)

LaplaceDiffusion2D represents a scalar diffusion term $\nabla \cdot (\kappa\nabla u))$ with diffusivity $\kappa$ applied to each solution component defined by equations.

source
Trixi.LaplaceDiffusion3DType
LaplaceDiffusion3D(diffusivity, equations)

LaplaceDiffusion3D represents a scalar diffusion term $\nabla \cdot (\kappa\nabla u))$ with diffusivity $\kappa$ applied to each solution component defined by equations.

source
Trixi.LatticeBoltzmannEquations2DType
LatticeBoltzmannEquations2D(; Ma, Re, collision_op=collision_bgk,
+                           c=1, L=1, rho0=1, u0=nothing, nu=nothing)

The Lattice-Boltzmann equations

\[\partial_t u_\alpha + v_{\alpha,1} \partial_1 u_\alpha + v_{\alpha,2} \partial_2 u_\alpha = 0\]

in two space dimensions for the D2Q9 scheme.

The characteristic Mach number and Reynolds numbers are specified as Ma and Re. By the default, the collision operator collision_op is set to the BGK model. c, L, and rho0 specify the mean thermal molecular velocity, the characteristic length, and the reference density, respectively. They can usually be left to the default values. If desired, instead of the Mach number, one can set the macroscopic reference velocity u0 directly (Ma needs to be set to nothing in this case). Likewise, instead of the Reynolds number one can specify the kinematic viscosity nu directly (in this case, Re needs to be set to nothing).

The nine discrete velocity directions of the D2Q9 scheme are sorted as follows [4]:

  6     2     5       y
+    ┌───┼───┐         │
+    │       │         │
+  3 ┼   9   ┼ 1        ──── x
+    │       │        ╱
+    └───┼───┘       ╱
+  7     4     8    z

Note that usually the velocities are numbered from 0 to 8, where 0 corresponds to the zero velocity. Due to Julia using 1-based indexing, here we use indices from 1 to 9, where 1 through 8 correspond to the velocity directions in [4] and 9 is the zero velocity.

The corresponding opposite directions are:

  • 1 ←→ 3
  • 2 ←→ 4
  • 3 ←→ 1
  • 4 ←→ 2
  • 5 ←→ 7
  • 6 ←→ 8
  • 7 ←→ 5
  • 8 ←→ 6
  • 9 ←→ 9

The main sources for the base implementation were

  1. Misun Min, Taehun Lee, A spectral-element discontinuous Galerkin lattice Boltzmann method for nearly incompressible flows, J Comput Phys 230(1), 2011 doi:10.1016/j.jcp.2010.09.024
  2. Karsten Golly, Anwendung der Lattice-Boltzmann Discontinuous Galerkin Spectral Element Method (LB-DGSEM) auf laminare und turbulente nahezu inkompressible Strömungen im dreidimensionalen Raum, Master Thesis, University of Cologne, 2018.
  3. Dieter Hänel, Molekulare Gasdynamik, Springer-Verlag Berlin Heidelberg, 2004 doi:10.1007/3-540-35047-0
  4. Dieter Krüger et al., The Lattice Boltzmann Method, Springer International Publishing, 2017 doi:10.1007/978-3-319-44649-3
source
Trixi.LatticeBoltzmannEquations3DType
LatticeBoltzmannEquations3D(; Ma, Re, collision_op=collision_bgk,
+                           c=1, L=1, rho0=1, u0=nothing, nu=nothing)

The Lattice-Boltzmann equations

\[\partial_t u_\alpha + v_{\alpha,1} \partial_1 u_\alpha + v_{\alpha,2} \partial_2 u_\alpha + v_{\alpha,3} \partial_3 u_\alpha = 0\]

in three space dimensions for the D3Q27 scheme.

The characteristic Mach number and Reynolds numbers are specified as Ma and Re. By the default, the collision operator collision_op is set to the BGK model. c, L, and rho0 specify the mean thermal molecular velocity, the characteristic length, and the reference density, respectively. They can usually be left to the default values. If desired, instead of the Mach number, one can set the macroscopic reference velocity u0 directly (Ma needs to be set to nothing in this case). Likewise, instead of the Reynolds number one can specify the kinematic viscosity nu directly (in this case, Re needs to be set to nothing).

The twenty-seven discrete velocity directions of the D3Q27 scheme are sorted as follows [4]:

  • plane at z = -1:
      24    17     21       y
    +     ┌───┼───┐          │
    +     │       │          │
    +  10 ┼   6   ┼ 15        ──── x
    +     │       │         ╱
    +     └───┼───┘        ╱
    +  20    12     26    z
  • plane at z = 0:
      14     3     7        y
    +     ┌───┼───┐          │
    +     │       │          │
    +   2 ┼  27   ┼ 1         ──── x
    +     │       │         ╱
    +     └───┼───┘        ╱
    +   8     4     13    z
  • plane at z = +1:
      25    11     19       y
    +     ┌───┼───┐          │
    +     │       │          │
    +  16 ┼   5   ┼ 9         ──── x
    +     │       │         ╱
    +     └───┼───┘        ╱
    +  22    18     23    z

Note that usually the velocities are numbered from 0 to 26, where 0 corresponds to the zero velocity. Due to Julia using 1-based indexing, here we use indices from 1 to 27, where 1 through 26 correspond to the velocity directions in [4] and 27 is the zero velocity.

The corresponding opposite directions are:

  • 1 ←→ 2
  • 2 ←→ 1
  • 3 ←→ 4
  • 4 ←→ 3
  • 5 ←→ 6
  • 6 ←→ 5
  • 7 ←→ 8
  • 8 ←→ 7
  • 9 ←→ 10
  • 10 ←→ 9
  • 11 ←→ 12
  • 12 ←→ 11
  • 13 ←→ 14
  • 14 ←→ 13
  • 15 ←→ 16
  • 16 ←→ 15
  • 17 ←→ 18
  • 18 ←→ 17
  • 19 ←→ 20
  • 20 ←→ 19
  • 21 ←→ 22
  • 22 ←→ 21
  • 23 ←→ 24
  • 24 ←→ 23
  • 25 ←→ 26
  • 26 ←→ 25
  • 27 ←→ 27

The main sources for the base implementation were

  1. Misun Min, Taehun Lee, A spectral-element discontinuous Galerkin lattice Boltzmann method for nearly incompressible flows, J Comput Phys 230(1), 2011 doi:10.1016/j.jcp.2010.09.024
  2. Karsten Golly, Anwendung der Lattice-Boltzmann Discontinuous Galerkin Spectral Element Method (LB-DGSEM) auf laminare und turbulente nahezu inkompressible Strömungen im dreidimensionalen Raum, Master Thesis, University of Cologne, 2018.
  3. Dieter Hänel, Molekulare Gasdynamik, Springer-Verlag Berlin Heidelberg, 2004 doi:10.1007/3-540-35047-0
  4. Dieter Krüger et al., The Lattice Boltzmann Method, Springer International Publishing, 2017 doi:10.1007/978-3-319-44649-3
source
Trixi.LinearScalarAdvectionEquation2DType
LinearScalarAdvectionEquation2D

The linear scalar advection equation

\[\partial_t u + a_1 \partial_1 u + a_2 \partial_2 u = 0\]

in two space dimensions with constant velocity a.

source
Trixi.LinearScalarAdvectionEquation3DType
LinearScalarAdvectionEquation3D

The linear scalar advection equation

\[\partial_t u + a_1 \partial_1 u + a_2 \partial_2 u + a_3 \partial_3 u = 0\]

in three space dimensions with constant velocity a.

source
Trixi.LinearizedEulerEquations2DType
LinearizedEulerEquations2D(v_mean_global, c_mean_global, rho_mean_global)

Linearized euler equations in two space dimensions. The equations are given by

\[\partial_t +\begin{pmatrix} + \rho' \\ v_1' \\ v_2' \\ p' +\end{pmatrix} ++ +\partial_x +\begin{pmatrix} + \bar{\rho} v_1' + \bar{v_1} \rho ' \\ \bar{v_1} v_1' + \frac{p'}{\bar{\rho}} \\ \bar{v_1} v_2' \\ \bar{v_1} p' + c^2 \bar{\rho} v_1' +\end{pmatrix} ++ +\partial_y +\begin{pmatrix} + \bar{\rho} v_2' + \bar{v_2} \rho ' \\ \bar{v_2} v_1' \\ \bar{v_2} v_2' + \frac{p'}{\bar{\rho}} \\ \bar{v_2} p' + c^2 \bar{\rho} v_2' +\end{pmatrix} += +\begin{pmatrix} + 0 \\ 0 \\ 0 \\ 0 +\end{pmatrix}\]

The bar $\bar{(\cdot)}$ indicates uniform mean flow variables and c is the speed of sound. The unknowns are the acoustic velocities $v' = (v_1', v_2')$, the pressure $p'$ and the density $\rho'$.

source
Trixi.LobattoLegendreBasisType
LobattoLegendreBasis([RealT=Float64,] polydeg::Integer)

Create a nodal Lobatto-Legendre basis for polynomials of degree polydeg.

For the special case polydeg=0 the DG method reduces to a finite volume method. Therefore, this function sets the center point of the cell as single node.

source
Trixi.NoSlipType
struct NoSlip

Use to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_function should be a function with signature boundary_value_function(x, t, equations) and should return a SVector{NDIMS} whose entries are the velocity vector at a point x and time t.

source
Trixi.P4estMeshType
P4estMesh{NDIMS} <: AbstractMesh{NDIMS}

An unstructured curved mesh based on trees that uses the C library p4est to manage trees and mesh refinement.

source
Trixi.P4estMeshMethod
P4estMesh(trees_per_dimension; polydeg,
+          mapping=nothing, faces=nothing, coordinates_min=nothing, coordinates_max=nothing,
+          RealT=Float64, initial_refinement_level=0, periodicity=true, unsaved_changes=true,
+          p4est_partition_allow_for_coarsening=true)

Create a structured curved P4estMesh of the specified size.

There are three ways to map the mesh to the physical domain.

  1. Define a mapping that maps the hypercube [-1, 1]^n.
  2. Specify a Tuple faces of functions that parametrize each face.
  3. Create a rectangular mesh by specifying coordinates_min and coordinates_max.

Non-periodic boundaries will be called :x_neg, :x_pos, :y_neg, :y_pos, :z_neg, :z_pos.

Arguments

  • trees_per_dimension::NTupleE{NDIMS, Int}: the number of trees in each dimension.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • mapping: a function of NDIMS variables to describe the mapping that transforms the reference mesh ([-1, 1]^n) to the physical domain. Use only one of mapping, faces and coordinates_min/coordinates_max.
  • faces::NTuple{2*NDIMS}: a tuple of 2 * NDIMS functions that describe the faces of the domain. Each function must take NDIMS-1 arguments. faces[1] describes the face onto which the face in negative x-direction of the unit hypercube is mapped. The face in positive x-direction of the unit hypercube will be mapped onto the face described by faces[2]. faces[3:4] describe the faces in positive and negative y-direction respectively (in 2D and 3D). faces[5:6] describe the faces in positive and negative z-direction respectively (in 3D). Use only one of mapping, faces and coordinates_min/coordinates_max.
  • coordinates_min: vector or tuple of the coordinates of the corner in the negative direction of each dimension to create a rectangular mesh. Use only one of mapping, faces and coordinates_min/coordinates_max.
  • coordinates_max: vector or tuple of the coordinates of the corner in the positive direction of each dimension to create a rectangular mesh. Use only one of mapping, faces and coordinates_min/coordinates_max.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • periodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
source
Trixi.P4estMeshMethod
P4estMesh{NDIMS}(meshfile::String;
+                 mapping=nothing, polydeg=1, RealT=Float64,
+                 initial_refinement_level=0, unsaved_changes=true,
+                 p4est_partition_allow_for_coarsening=true)

Main mesh constructor for the P4estMesh that imports an unstructured, conforming mesh from an Abaqus mesh file (.inp). Each element of the conforming mesh parsed from the meshfile is created as a p4est tree datatype.

To create a curved unstructured mesh P4estMesh two strategies are available:

  • p4est_mesh_from_hohqmesh_abaqus: High-order, curved boundary information created by HOHQMesh.jl is available in the meshfile. The mesh polynomial degree polydeg of the boundaries is provided from the meshfile. The computation of the mapped tree coordinates is done with transfinite interpolation with linear blending similar to UnstructuredMesh2D. Boundary name information is also parsed from the meshfile such that different boundary conditions can be set at each named boundary on a given tree.
  • p4est_mesh_from_standard_abaqus: By default, with mapping=nothing and polydeg=1, this creates a straight-sided from the information parsed from the meshfile. If a mapping function is specified then it computes the mapped tree coordinates via polynomial interpolants with degree polydeg. The mesh created by this function will only have one boundary :all, as distinguishing different physical boundaries is non-trivial.

Note that the mapping and polydeg keyword arguments are only used by the p4est_mesh_from_standard_abaqus function. The p4est_mesh_from_hohqmesh_abaqus function obtains the mesh polydeg directly from the meshfile and constructs the transfinite mapping internally.

The particular strategy is selected according to the header present in the meshfile where the constructor checks whether or not the meshfile was created with HOHQMesh.jl. If the Abaqus file header is not present in the meshfile then the P4estMesh is created with the function p4est_mesh_from_standard_abaqus.

The default keyword argument initial_refinement_level=0 corresponds to a forest where the number of trees is the same as the number of elements in the original meshfile. Increasing the initial_refinement_level allows one to uniformly refine the base mesh given in the meshfile to create a forest with more trees before the simulation begins. For example, if a two-dimensional base mesh contains 25 elements then setting initial_refinement_level=1 creates an initial forest of 2^2 * 25 = 100 trees.

Arguments

  • meshfile::String: an uncurved Abaqus mesh file that can be imported by p4est.
  • mapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
source
Trixi.PerformanceCounterType
PerformanceCounter()

A PerformanceCounter can be used to track the runtime performance of some calls. Add a new runtime measurement via put!(counter, runtime) and get the averaged runtime of all measurements added so far via take!(counter), resetting the counter.

source
Trixi.PerformanceCounterListType
PerformanceCounterList{N}()

A PerformanceCounterList{N} can be used to track the runtime performance of calls to multiple functions, adding them up. Add a new runtime measurement via put!(counter.counters[i], runtime) and get the averaged runtime of all measurements added so far via take!(counter), resetting the counter.

source
Trixi.PlotData1DType
PlotData1D

Holds all relevant data for creating 1D plots of multiple solution variables and to visualize the mesh.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.PlotData1DMethod
PlotData1D(u, semi [or mesh, equations, solver, cache];
+           solution_variables=nothing, nvisnodes=nothing)

Create a new PlotData1D object that can be used for visualizing 1D DGSEM solution data array u with Plots.jl. All relevant geometrical information is extracted from the semidiscretization semi. By default, the primitive variables (if existent) or the conservative variables (otherwise) from the solution are used for plotting. This can be changed by passing an appropriate conversion function to solution_variables.

nvisnodes specifies the number of visualization nodes to be used. If it is nothing, twice the number of solution DG nodes are used for visualization, and if set to 0, exactly the number of nodes in the DG elements are used.

When visualizing data from a two-dimensional simulation, a 1D slice is extracted for plotting. slice specifies the axis along which the slice is extracted and may be :x, or :y. The slice position is specified by a point that lies on it, which defaults to (0.0, 0.0). Both of these values are ignored when visualizing 1D data. This applies analogously to three-dimensional simulations, where slice may be :xy, :xz, or :yz.

Another way to visualize 2D/3D data is by creating a plot along a given curve. This is done with the keyword argument curve. It can be set to a list of 2D/3D points which define the curve. When using curve any other input from slice or point will be ignored.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.PlotData1DMethod
PlotData1D(sol; kwargs...)

Create a PlotData1D object from a solution object created by either OrdinaryDiffEq.solve! (which returns a SciMLBase.ODESolution) or Trixi.jl's own solve! (which returns a TimeIntegratorSolution).

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.PlotData2DCartesianType
PlotData2D

Holds all relevant data for creating 2D plots of multiple solution variables and to visualize the mesh.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.PolytropicEulerEquations2DType
PolytropicEulerEquations2D(gamma, kappa)

The polytropic Euler equations

\[\frac{\partial}{\partial t} +\begin{pmatrix} +\rho \\ \rho v_1 \\ \rho v_2 +\end{pmatrix} ++ +\frac{\partial}{\partial x} +\begin{pmatrix} + \rho v_1 \\ \rho v_1^2 + \kappa\rho^\gamma \\ \rho v_1 v_2 +\end{pmatrix} ++ +\frac{\partial}{\partial y} +\begin{pmatrix} +\rho v_2 \\ \rho v_1 v_2 \\ \rho v_2^2 + \kappa\rho^\gamma +\end{pmatrix} += +\begin{pmatrix} +0 \\ 0 \\ 0 +\end{pmatrix}\]

for an ideal gas with ratio of specific heats gamma in two space dimensions. Here, $\rho$ is the density and $v_1$ andv_2 the velocities and

\[p = \kappa\rho^\gamma\]

the pressure, which we replaced using this relation.

source
Trixi.PositivityPreservingLimiterShallowWaterType
PositivityPreservingLimiterShallowWater(; variables)

The limiter is specifically designed for the shallow water equations. It is applied to all scalar variables in their given order using the defined threshold_limiter from the ShallowWaterEquations1D struct or the ShallowWaterEquations2D struct to determine the minimal acceptable values. The order of the variables is important and might have a strong influence on the robustness.

As opposed to the standard version of the PositivityPreservingLimiterZhangShu, nodes with a water height below the threshold_limiter are treated in a special way. To avoid numerical problems caused by velocities close to zero, the velocity is cut off, such that the node can be identified as "dry". The special feature of the ShallowWaterEquations used here is that the bottom topography is stored as an additional quantity in the solution vector u. However, the value of the bottom topography should not be changed. That is why, it is not limited.

After the limiting process is applied to all degrees of freedom, for safety reasons, the threshold_limiter is applied again on all the DG nodes in order to avoid water height below. In the case where the cell mean value is below the threshold before applying the limiter, there could still be dry nodes afterwards due to the logic of the limiter.

This fully-discrete positivity-preserving limiter is based on the work of

  • Zhang, Shu (2011) Maximum-principle-satisfying and positivity-preserving high-order schemes for conservation laws: survey and new developments doi: 10.1098/rspa.2011.0153
source
Trixi.PositivityPreservingLimiterZhangShuType
PositivityPreservingLimiterZhangShu(; threshold, variables)

The fully-discrete positivity-preserving limiter of

  • Zhang, Shu (2011) Maximum-principle-satisfying and positivity-preserving high-order schemes for conservation laws: survey and new developments doi: 10.1098/rspa.2011.0153

The limiter is applied to all scalar variables in their given order using the associated thresholds to determine the minimal acceptable values. The order of the variables is important and might have a strong influence on the robustness.

source
Trixi.SaveRestartCallbackType
SaveRestartCallback(; interval=0,
+                      save_final_restart=true,
+                      output_directory="out")

Save the current numerical solution in a restart file every interval time steps.

source
Trixi.SaveSolutionCallbackType
SaveSolutionCallback(; interval::Integer=0,
+                       dt=nothing,
+                       save_initial_solution=true,
+                       save_final_solution=true,
+                       output_directory="out",
+                       solution_variables=cons2prim)

Save the current numerical solution in regular intervals. Either pass interval to save every interval time steps or pass dt to save in intervals of dt in terms of integration time by adding additional (shortened) time steps where necessary (note that this may change the solution). solution_variables can be any callable that converts the conservative variables at a single point to a set of solution variables. The first parameter passed to solution_variables will be the set of conservative variables and the second parameter is the equation struct.

source
Trixi.SemidiscretizationCoupledType
SemidiscretizationCoupled

A struct used to bundle multiple semidiscretizations. semidiscretize will return an ODEProblem that synchronizes time steps between the semidiscretizations. Each call of rhs! will call rhs! for each semidiscretization individually. The semidiscretizations can be coupled by gluing meshes together using BoundaryConditionCoupled.

Experimental code

This is an experimental feature and can change any time.

source
Trixi.SemidiscretizationEulerAcousticsType
SemidiscretizationEulerAcoustics(semi_acoustics::SemiAcoustics, semi_euler::SemiEuler;
+                                 source_region=x->true, weights=x->1.0)
Experimental code

This semidiscretization is experimental and may change in any future release.

Construct a semidiscretization of the acoustic perturbation equations that is coupled with the compressible Euler equations via source terms for the perturbed velocity. Both semidiscretizations have to use the same mesh and solvers with a shared basis. The coupling region is described by a function source_region that maps the coordinates of a single node to true or false depending on whether the point lies within the coupling region or not. A weighting function weights that maps coordinates to weights is applied to the acoustic source terms. Note that this semidiscretization should be used in conjunction with EulerAcousticsCouplingCallback and only works in two dimensions.

source
Trixi.SemidiscretizationEulerGravityType
SemidiscretizationEulerGravity

A struct containing everything needed to describe a spatial semidiscretization of a the compressible Euler equations with self-gravity, reformulating the Poisson equation for the gravitational potential as steady-state problem of the hyperblic diffusion equations.

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) "A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics" arXiv: 2008.10593
source
Trixi.SemidiscretizationHyperbolicMethod
SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver;
+                             source_terms=nothing,
+                             boundary_conditions=boundary_condition_periodic,
+                             RealT=real(solver),
+                             uEltype=RealT,
+                             initial_cache=NamedTuple())

Construct a semidiscretization of a hyperbolic PDE.

source
Trixi.SemidiscretizationHyperbolicParabolicMethod
SemidiscretizationHyperbolicParabolic(mesh, both_equations, initial_condition, solver;
+                                      solver_parabolic=default_parabolic_solver(),
+                                      source_terms=nothing,
+                                      both_boundary_conditions=(boundary_condition_periodic, boundary_condition_periodic),
+                                      RealT=real(solver),
+                                      uEltype=RealT,
+                                      both_initial_caches=(NamedTuple(), NamedTuple()))

Construct a semidiscretization of a hyperbolic-parabolic PDE.

source
Trixi.ShallowWaterEquations1DType
ShallowWaterEquations1D(; gravity, H0 = 0, threshold_limiter = nothing threshold_wet = nothing)

Shallow water equations (SWE) in one space dimension. The equations are given by

\[\begin{aligned} + \frac{\partial h}{\partial t} + \frac{\partial}{\partial x}(h v) &= 0 \\ + \frac{\partial}{\partial t}(h v) + \frac{\partial}{\partial x}\left(h v^2 + \frac{g}{2}h^2\right) + + g h \frac{\partial b}{\partial x} &= 0 +\end{aligned}\]

The unknown quantities of the SWE are the water height $h$ and the velocity $v$. The gravitational constant is denoted by g and the (possibly) variable bottom topography function $b(x)$. Conservative variable water height $h$ is measured from the bottom topography $b$, therefore one also defines the total water height as $H = h + b$.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

Also, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is "wet" before calculating the numerical flux.

The bottom topography function $b(x)$ is set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero.

In addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi.jl's visualization tools will visualize the bottom topography by default.

References for the SWE are many but a good introduction is available in Chapter 13 of the book:

source
Trixi.ShallowWaterEquations2DType
ShallowWaterEquations2D(; gravity, H0 = 0, threshold_limiter = nothing, threshold_wet = nothing)

Shallow water equations (SWE) in two space dimensions. The equations are given by

\[\begin{aligned} + \frac{\partial h}{\partial t} + \frac{\partial}{\partial x}(h v_1) + + \frac{\partial}{\partial y}(h v_2) &= 0 \\ + \frac{\partial}{\partial t}(h v_1) + \frac{\partial}{\partial x}\left(h v_1^2 + \frac{g}{2}h^2\right) + + \frac{\partial}{\partial y}(h v_1 v_2) + g h \frac{\partial b}{\partial x} &= 0 \\ + \frac{\partial}{\partial t}(h v_2) + \frac{\partial}{\partial x}(h v_1 v_2) + + \frac{\partial}{\partial y}\left(h v_2^2 + \frac{g}{2}h^2\right) + g h \frac{\partial b}{\partial y} &= 0. +\end{aligned}\]

The unknown quantities of the SWE are the water height $h$ and the velocities $\mathbf{v} = (v_1, v_2)^T$. The gravitational constant is denoted by g and the (possibly) variable bottom topography function $b(x,y)$. Conservative variable water height $h$ is measured from the bottom topography $b$, therefore one also defines the total water height as $H = h + b$.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

Also, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is "wet" before calculating the numerical flux.

The bottom topography function $b(x,y)$ is set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero.

In addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi.jl's visualization tools will visualize the bottom topography by default.

References for the SWE are many but a good introduction is available in Chapter 13 of the book:

source
Trixi.ShallowWaterEquationsQuasi1DType
ShallowWaterEquationsQuasi1D(; gravity, H0 = 0, threshold_limiter = nothing threshold_wet = nothing)

The quasi-1D shallow water equations (SWE). The equations are given by

\[\begin{aligned} + \frac{\partial}{\partial t}(a h) + \frac{\partial}{\partial x}(a h v) &= 0 \\ + \frac{\partial}{\partial t}(a h v) + \frac{\partial}{\partial x}(a h v^2) + + g a h \frac{\partial}{\partial x}(h + b) &= 0 +\end{aligned}\]

The unknown quantities of the Quasi-1D SWE are the water height $h$ and the scaled velocity $v$. The gravitational constant is denoted by g, the (possibly) variable bottom topography function $b(x)$, and (possibly) variable channel width $a(x)$. The water height $h$ is measured from the bottom topography $b$, therefore one also defines the total water height as $H = h + b$.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

Also, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is "wet" before calculating the numerical flux.

The bottom topography function $b(x)$ and channel width $a(x)$ are set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero and $a$ to one.

In addition to the unknowns, Trixi.jl currently stores the bottom topography and channel width values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography and channel width must be zero.
  • The bottom topography and channel width values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi.jl's visualization tools will visualize the bottom topography and channel width by default.
source
Trixi.ShallowWaterTwoLayerEquations1DType
ShallowWaterTwoLayerEquations1D(gravity, H0, rho_upper, rho_lower)

Two-Layer Shallow Water equations (2LSWE) in one space dimension. The equations are given by

\[\begin{alignat*}{4} +&\frac{\partial}{\partial t}h_{upper} +&&+ \frac{\partial}{\partial x}\left(h_{upper} v_{1,upper}\right) +&&= 0 \\ +&\frac{\partial}{\partial t}\left(h_{upper}v_{1,upper}\right) +&&+ \frac{\partial}{\partial x}\left(h_{upper}v_{1,upper}^2 + \dfrac{gh_{upper}^2}{2}\right) +&&= -gh_{upper}\frac{\partial}{\partial x}\left(b+h_{lower}\right)\\ +&\frac{\partial}{\partial t}h_{lower} +&&+ \frac{\partial}{\partial x}\left(h_{lower}v_{1,lower}\right) +&&= 0 \\ +&\frac{\partial}{\partial t}\left(h_{lower}v_{1,lower}\right) +&&+ \frac{\partial}{\partial x}\left(h_{lower}v_{1,lower}^2 + \dfrac{gh_{lower}^2}{2}\right) +&&= -gh_{lower}\frac{\partial}{\partial x}\left(b+\dfrac{\rho_{upper}}{\rho_{lower}}h_{upper}\right). +\end{alignat*}\]

The unknown quantities of the 2LSWE are the water heights of the {lower} layer $h_{lower}$ and the {upper} layer $h_{upper}$ with respective velocities $v_{1,upper}$ and $v_{1,lower}$. The gravitational constant is denoted by g, the layer densitites by $\rho_{upper}$and $\rho_{lower}$ and the (possibly) variable bottom topography function $b(x)$. The conservative variable water height $h_{lower}$ is measured from the bottom topography $b$ and $h_{upper}$ relative to $h_{lower}$, therefore one also defines the total water heights as $H_{upper} = h_{upper} + h_{upper} + b$ and $H_{lower} = h_{lower} + b$.

The densities must be chosen such that $\rho_{upper} < \rho_{lower}$, to make sure that the heavier fluid $\rho_{lower}$ is in the bottom layer and the lighter fluid $\rho_{upper}$ in the {upper} layer.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

The bottom topography function $b(x)$ is set inside the initial condition routine for a particular problem setup.

In addition to the unknowns, Trixi currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi's visualization tools will visualize the bottom topography by default.

A good introduction for the 2LSWE is available in Chapter 12 of the book:

source
Trixi.ShallowWaterTwoLayerEquations2DType
ShallowWaterTwoLayerEquations2D(gravity, H0, rho_upper, rho_lower)

Two-Layer Shallow water equations (2LSWE) in two space dimension. The equations are given by

\[\begin{alignat*}{8} +&\frac{\partial}{\partial t}h_{upper} +&&+ \frac{\partial}{\partial x}\left(h_{upper} v_{1,upper}\right) +&&+ \frac{\partial}{\partial y}\left(h_{upper} v_{2,upper}\right) \quad +&&= \quad 0 \\ +&\frac{\partial}{\partial t}\left(h_{upper} v_{1,upper}\right) +&&+ \frac{\partial}{\partial x}\left(h_{upper} v_{1,upper}^2 + \frac{gh_{upper}^2}{2}\right) +&&+ \frac{\partial}{\partial y}\left(h_{upper} v_{1,upper} v_{2,upper}\right) \quad +&&= -gh_{upper}\frac{\partial}{\partial x}\left(b+h_{lower}\right) \\ +&\frac{\partial}{\partial t}\left(h_{upper} v_{2,upper}\right) +&&+ \frac{\partial}{\partial x}\left(h_{upper} v_{1,upper} v_{2,upper}\right) +&&+ \frac{\partial}{\partial y}\left(h_{upper} v_{2,upper}^2 + \frac{gh_{upper}^2}{2}\right) +&&= -gh_{upper}\frac{\partial}{\partial y}\left(b+h_{lower}\right)\\ +&\frac{\partial}{\partial t}h_{lower} +&&+ \frac{\partial}{\partial x}\left(h_{lower} v_{1,lower}\right) +&&+ \frac{\partial}{\partial y}\left(h_{lower} v_{2,lower}\right) +&&= \quad 0 \\ +&\frac{\partial}{\partial t}\left(h_{lower} v_{1,lower}\right) +&&+ \frac{\partial}{\partial x}\left(h_{lower} v_{1,lower}^2 + \frac{gh_{lower}^2}{2}\right) +&&+ \frac{\partial}{\partial y}\left(h_{lower} v_{1,lower} v_{2,lower}\right) +&&= -gh_{lower}\frac{\partial}{\partial x}\left(b+\frac{\rho_{upper}}{\rho_{lower}} h_{upper}\right)\\ +&\frac{\partial}{\partial t}\left(h_{lower} v_{2,lower}\right) +&&+ \frac{\partial}{\partial x}\left(h_{lower} v_{1,lower} v_{2,lower}\right) +&&+ \frac{\partial}{\partial y}\left(h_{lower} v_{2,lower}^2 + \frac{gh_{lower}^2}{2}\right) +&&= -gh_{lower}\frac{\partial}{\partial y}\left(b+\frac{\rho_{upper}}{\rho_{lower}} h_{upper}\right) +\end{alignat*}\]

The unknown quantities of the 2LSWE are the water heights of the lower layer $h_{lower}$ and the upper layer $h_{upper}$ and the respective velocities in x-direction $v_{1,lower}$ and $v_{1,upper}$ and in y-direction $v_{2,lower}$ and $v_{2,upper}$. The gravitational constant is denoted by g, the layer densitites by $\rho_{upper}$and $\rho_{lower}$ and the (possibly) variable bottom topography function by $b(x)$. Conservative variable water height $h_{lower}$ is measured from the bottom topography $b$ and $h_{upper}$ relative to $h_{lower}$, therefore one also defines the total water heights as $H_{lower} = h_{lower} + b$ and $H_{upper} = h_{upper} + h_{lower} + b$.

The densities must be chosen such that $\rho_{upper} < \rho_{lower}$, to make sure that the heavier fluid $\rho_{lower}$ is in the bottom layer and the lighter fluid $\rho_{upper}$ in the upper layer.

The additional quantity $H_0$ is also available to store a reference value for the total water height that is useful to set initial conditions or test the "lake-at-rest" well-balancedness.

The bottom topography function $b(x)$ is set inside the initial condition routine for a particular problem setup.

In addition to the unknowns, Trixi currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height $H$ or the entropy variables. This affects the implementation and use of these equations in various ways:

  • The flux values corresponding to the bottom topography must be zero.
  • The bottom topography values must be included when defining initial conditions, boundary conditions or source terms.
  • AnalysisCallback analyzes this variable.
  • Trixi's visualization tools will visualize the bottom topography by default.

A good introduction for the 2LSWE is available in Chapter 12 of the book:

source
Trixi.SimpleSSPRK33Type
SimpleSSPRK33(; stage_callbacks=())

The third-order SSP Runge-Kutta method of Shu and Osher.

References

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.StepsizeCallbackType
StepsizeCallback(; cfl=1.0)

Set the time step size according to a CFL condition with CFL number cfl if the time integration method isn't adaptive itself.

source
Trixi.StructuredMeshType
StructuredMesh{NDIMS} <: AbstractMesh{NDIMS}

A structured curved mesh.

Different numbers of cells per dimension are possible and arbitrary functions can be used as domain faces.

source
Trixi.StructuredMeshMethod
StructuredMesh(cells_per_dimension, coordinates_min, coordinates_max; periodicity=true)

Create a StructuredMesh that represents a uncurved structured mesh with a rectangular domain.

Arguments

  • cells_per_dimension::NTuple{NDIMS, Int}: the number of cells in each dimension.
  • coordinates_min::NTuple{NDIMS, RealT}: coordinate of the corner in the negative direction of each dimension.
  • coordinates_max::NTuple{NDIMS, RealT}: coordinate of the corner in the positive direction of each dimension.
  • periodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.
source
Trixi.StructuredMeshMethod
StructuredMesh(cells_per_dimension, mapping; RealT=Float64, unsaved_changes=true, mapping_as_string=mapping2string(mapping, length(cells_per_dimension)))

Create a StructuredMesh of the given size and shape that uses RealT as coordinate type.

Arguments

  • cells_per_dimension::NTupleE{NDIMS, Int}: the number of cells in each dimension.
  • mapping: a function of NDIMS variables to describe the mapping, which transforms the reference mesh to the physical domain. If no mapping_as_string is defined, this function must be defined with the name mapping to allow for restarts. This will be changed in the future, see https://github.com/trixi-framework/Trixi.jl/issues/541.
  • RealT::Type: the type that should be used for coordinates.
  • periodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • mapping_as_string::String: the code that defines the mapping. If CodeTracking can't find the function definition, it can be passed directly here. The code string must define the mapping function with the name mapping. This will be changed in the future, see https://github.com/trixi-framework/Trixi.jl/issues/541.
source
Trixi.StructuredMeshMethod
StructuredMesh(cells_per_dimension, faces; RealT=Float64, unsaved_changes=true, faces_as_string=faces2string(faces))

Create a StructuredMesh of the given size and shape that uses RealT as coordinate type.

Arguments

  • cells_per_dimension::NTupleE{NDIMS, Int}: the number of cells in each dimension.
  • faces::NTuple{2*NDIMS}: a tuple of 2 * NDIMS functions that describe the faces of the domain. Each function must take NDIMS-1 arguments. faces[1] describes the face onto which the face in negative x-direction of the unit hypercube is mapped. The face in positive x-direction of the unit hypercube will be mapped onto the face described by faces[2]. faces[3:4] describe the faces in positive and negative y-direction respectively (in 2D and 3D). faces[5:6] describe the faces in positive and negative z-direction respectively (in 3D).
  • RealT::Type: the type that should be used for coordinates.
  • periodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.
source
Trixi.SubcellLimiterIDPType
SubcellLimiterIDP(equations::AbstractEquations, basis;
+                  positivity_variables_cons = [],
+                  positivity_correction_factor = 0.1)

Subcell invariant domain preserving (IDP) limiting used with VolumeIntegralSubcellLimiting including:

  • positivity limiting for conservative variables (positivity_variables_cons)

The bounds are calculated using the low-order FV solution. The positivity limiter uses positivity_correction_factor such that u^new >= positivity_correction_factor * u^FV.

Note

This limiter and the correction callback SubcellLimiterIDPCorrection only work together. Without the callback, no correction takes place, leading to a standard low-order FV scheme.

References

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.SubcellLimiterIDPCorrectionType
SubcellLimiterIDPCorrection()

Perform antidiffusive correction stage for the a posteriori IDP limiter SubcellLimiterIDP called with VolumeIntegralSubcellLimiting.

Note

This callback and the actual limiter SubcellLimiterIDP only work together. This is not a replacement but a necessary addition.

References

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.SurfaceIntegralWeakFormType
SurfaceIntegralWeakForm(surface_flux=flux_central)

The classical weak form surface integral type for DG methods as explained in standard textbooks.

See also VolumeIntegralWeakForm.

References

source
Trixi.T8codeMeshType
T8codeMesh{NDIMS} <: AbstractMesh{NDIMS}

An unstructured curved mesh based on trees that uses the C library 't8code' to manage trees and mesh refinement.

source
Trixi.T8codeMeshMethod
T8codeMesh(trees_per_dimension; polydeg, mapping=identity,
+           RealT=Float64, initial_refinement_level=0, periodicity=true)

Create a structured potentially curved 'T8codeMesh' of the specified size.

Non-periodic boundaries will be called ':xneg', ':xpos', ':yneg', ':ypos', ':zneg', ':zpos'.

Arguments

  • 'treesperdimension::NTupleE{NDIMS, Int}': the number of trees in each dimension.
  • 'polydeg::Integer': polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • 'mapping': a function of 'NDIMS' variables to describe the mapping that transforms the reference mesh ('[-1, 1]^n') to the physical domain.
  • 'RealT::Type': the type that should be used for coordinates.
  • 'initialrefinementlevel::Integer': refine the mesh uniformly to this level before the simulation starts.
  • 'periodicity': either a 'Bool' deciding if all of the boundaries are periodic or an 'NTuple{NDIMS, Bool}' deciding for each dimension if the boundaries in this dimension are periodic.
source
Trixi.T8codeMeshMethod
T8codeMesh{NDIMS}(conn::Ptr{p4est_connectivity},
+                  mapping=nothing, polydeg=1, RealT=Float64,
+                  initial_refinement_level=0)

Main mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a p4est_connectivity data structure.

Arguments

  • conn::Ptr{p4est_connectivity}: Pointer to a P4est connectivity object.
  • mapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
source
Trixi.T8codeMeshMethod
T8codeMesh{NDIMS}(cmesh::Ptr{t8_cmesh},
+                 mapping=nothing, polydeg=1, RealT=Float64,
+                 initial_refinement_level=0)

Main mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a t8_cmesh data structure.

Arguments

  • cmesh::Ptr{t8_cmesh}: Pointer to a cmesh object.
  • mapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
source
Trixi.T8codeMeshMethod
T8codeMesh{NDIMS}(meshfile::String;
+                 mapping=nothing, polydeg=1, RealT=Float64,
+                 initial_refinement_level=0)

Main mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a Gmsh mesh file (.msh).

Arguments

  • meshfile::String: path to a Gmsh mesh file.
  • mapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
source
Trixi.TimeSeriesCallbackType
TimeSeriesCallback(semi, point_coordinates;
+                   interval=1, solution_variables=cons2cons,
+                   output_directory="out", filename="time_series.h5",
+                   RealT=real(solver), uEltype=eltype(cache.elements))

Create a callback that records point-wise data at points given in point_coordinates every interval time steps. The point coordinates are to be specified either as a vector of coordinate tuples or as a two-dimensional array where the first dimension is the point number and the second dimension is the coordinate dimension. By default, the conservative variables are recorded, but this can be controlled by passing a different conversion function to solution_variables.

After the last time step, the results are stored in an HDF5 file filename in directory output_directory.

The real data type RealT and data type for solution variables uEltype default to the respective types used in the solver and the cache.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.TreeMeshType
TreeMesh{NDIMS} <: AbstractMesh{NDIMS}

A Cartesian mesh based on trees of hypercubes to support adaptive mesh refinement.

source
Trixi.UnstructuredMesh2DType
UnstructuredMesh2D <: AbstractMesh{2}

An unstructured (possibly curved) quadrilateral mesh.

UnstructuredMesh2D(filename; RealT=Float64, periodicity=false)

All mesh information, neighbour coupling, and boundary curve information is read in from a mesh file filename.

source
Trixi.UnstructuredSortedBoundaryTypesType
UnstructuredSortedBoundaryTypes

General container to sort the boundary conditions by type for some unstructured meshes/solvers. It stores a set of global indices for each boundary condition type to expedite computation during the call to calc_boundary_flux!. The original dictionary form of the boundary conditions set by the user in the elixir file is also stored for printing.

source
Trixi.ViscousFormulationLocalDGType
ViscousFormulationLocalDG(penalty_parameter)

The local DG (LDG) flux from "The Local Discontinuous Galerkin Method for Time-Dependent Convection-Diffusion Systems" by Cockburn and Shu (1998).

Note that, since this implementation does not involve the parabolic "upwinding" vector, the LDG solver is equivalent to ViscousFormulationBassiRebay1 with an LDG-type penalization.

source
Trixi.VisualizationCallbackMethod
VisualizationCallback(; interval=0,
+                        solution_variables=cons2prim,
+                        variable_names=[],
+                        show_mesh=false,
+                        plot_data_creator=PlotData2D,
+                        plot_creator=show_plot,
+                        plot_arguments...)

Create a callback that visualizes results during a simulation, also known as in-situ visualization.

Experimental implementation

This is an experimental feature and may change in any future releases.

The interval specifies the number of time step iterations after which a new plot is generated. The available variables to plot are configured with the solution_variables parameter, which acts the same way as for the SaveSolutionCallback. The variables to be actually plotted can be selected by providing a single string or a list of strings to variable_names, and if show_mesh is true, an additional plot with the mesh will be generated.

To customize the generated figure, plot_data_creator allows to use different plot data types. With plot_creator you can further specify an own function to visualize results, which must support the same interface as the default implementation show_plot. All remaining keyword arguments are collected and passed as additional arguments to the plotting command.

source
Trixi.VolumeIntegralFluxDifferencingType
VolumeIntegralFluxDifferencing(volume_flux)

Volume integral type for DG methods based on SBP operators and flux differencing using a symmetric two-point volume_flux. This volume_flux needs to satisfy the interface of numerical fluxes in Trixi.jl.

References

source
Trixi.VolumeIntegralPureLGLFiniteVolumeType
VolumeIntegralPureLGLFiniteVolume(volume_flux_fv)

A volume integral that only uses the subcell finite volume schemes of the VolumeIntegralShockCapturingHG.

This gives a formally O(1)-accurate finite volume scheme on an LGL-type subcell mesh (LGL = Legendre-Gauss-Lobatto).

Experimental implementation

This is an experimental feature and may change in future releases.

References

  • Hennemann, Gassner (2020) "A provably entropy stable subcell shock capturing approach for high order split form DG" arXiv: 2008.12044
source
Trixi.VolumeIntegralShockCapturingHGType
VolumeIntegralShockCapturingHG(indicator; volume_flux_dg=flux_central,
+                                          volume_flux_fv=flux_lax_friedrichs)

Shock-capturing volume integral type for DG methods using a convex blending of the finite volume method with numerical flux volume_flux_fv and the VolumeIntegralFluxDifferencing with volume flux volume_flux_dg. The amount of blending is determined by the indicator, e.g., IndicatorHennemannGassner.

References

  • Hennemann, Gassner (2020) "A provably entropy stable subcell shock capturing approach for high order split form DG" arXiv: 2008.12044
source
Trixi.VolumeIntegralSubcellLimitingType
VolumeIntegralSubcellLimiting(limiter;
+                              volume_flux_dg, volume_flux_fv)

A subcell limiting volume integral type for DG methods based on subcell blending approaches with a low-order FV method. Used with limiter SubcellLimiterIDP.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.VolumeIntegralUpwindType
VolumeIntegralUpwind(splitting)

Specialized volume integral for finite difference summation-by-parts (FDSBP) solvers. Can be used together with the upwind SBP operators of Mattsson (2017) implemented in SummationByPartsOperators.jl. The splitting controls the discretization.

See also splitting_steger_warming, splitting_lax_friedrichs, splitting_vanleer_haenel.

References

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.VolumeIntegralWeakFormType
VolumeIntegralWeakForm()

The classical weak form volume integral type for DG methods as explained in standard textbooks.

References

VolumeIntegralWeakForm() is only implemented for conserved terms as non-conservative terms should always be discretized in conjunction with a flux-splitting scheme, see VolumeIntegralFluxDifferencing. This treatment is required to achieve, e.g., entropy-stability or well-balancedness.

source
Base.getindexMethod
Base.getindex(pd::AbstractPlotData, variable_name)

Extract a single variable variable_name from pd for plotting with Plots.plot.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Base.resize!Method
resize!(c::AbstractContainer, new_length) -> AbstractContainer

Resize c to contain new_length elements. If new_length is smaller than the current container length, the first new_length elements will be retained. If new_length is larger, the new elements are invalidated.

source
PolynomialBases.compute_coefficientsMethod
compute_coefficients(func, t, semi::AbstractSemidiscretization)

Compute the discrete coefficients of the continuous function func at time t associated with the semidiscretization semi. For example, the discrete coefficients of func for a discontinuous Galerkin spectral element method (DGSEM) are the values of func at the Lobatto-Legendre nodes. Similarly, a classical finite difference method will use the values of func at the nodes of the grid assoociated with the semidiscretization semi.

For semidiscretizations semi associated with an initial condition, func can be omitted to use the given initial condition at time t.

source
PolynomialBases.integrateMethod
integrate(f, u, basis::LobattoLegendreBasis)

Map the function f to the coefficients u and integrate with respect to the quadrature rule given by basis.

source
PolynomialBases.integrateMethod
integrate([func=(u_node,equations)->u_node,] u_ode, semi::AbstractSemidiscretization; normalize=true)

Call func(u_node, equations) for each vector of nodal variables u_node in u_ode and integrate the result using a quadrature associated with the semidiscretization semi.

If normalize is true, the result is divided by the total volume of the computational domain.

source
SummationByPartsOperators.semidiscretizeMethod
semidiscretize(semi::SemidiscretizationHyperbolicParabolic, tspan)

Wrap the semidiscretization semi as a split ODE problem in the time interval tspan that can be passed to solve from the SciML ecosystem. The parabolic right-hand side is the first function of the split ODE problem and will be used by default by the implicit part of IMEX methods from the SciML ecosystem.

source
SummationByPartsOperators.semidiscretizeMethod
semidiscretize(semi::AbstractSemidiscretization, tspan, restart_file::AbstractString)

Wrap the semidiscretization semi as an ODE problem in the time interval tspan that can be passed to solve from the SciML ecosystem. The initial condition etc. is taken from the restart_file.

source
Trixi.DGMultiBasisMethod
DGMultiBasis(element_type, polydeg; approximation_type = Polynomial(), kwargs...)

Constructs a basis for DGMulti solvers. Returns a "StartUpDG.RefElemData" object. The kwargs arguments are additional keyword arguments for RefElemData, such as quad_rule_vol. These are the same as the RefElemData_kwargs used in DGMulti. For more info, see the StartUpDG.jl docs.

source
Trixi.P4estMeshCubedSphereMethod
P4estMeshCubedSphere(trees_per_face_dimension, layers, inner_radius, thickness;
+                     polydeg, RealT=Float64,
+                     initial_refinement_level=0, unsaved_changes=true,
+                     p4est_partition_allow_for_coarsening=true)

Build a "Cubed Sphere" mesh as P4estMesh with 6 * trees_per_face_dimension^2 * layers trees.

The mesh will have two boundaries, :inside and :outside.

Arguments

  • trees_per_face_dimension::Integer: the number of trees in the first two local dimensions of each face.
  • layers::Integer: the number of trees in the third local dimension of each face, i.e., the number of layers of the sphere.
  • inner_radius::Integer: the inner radius of the sphere.
  • thickness::Integer: the thickness of the sphere. The outer radius will be inner_radius + thickness.
  • polydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.
  • RealT::Type: the type that should be used for coordinates.
  • initial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.
  • unsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.
  • p4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.
source
Trixi.PlotData2DMethod
PlotData2D(u, semi [or mesh, equations, solver, cache];
+           solution_variables=nothing,
+           grid_lines=true, max_supported_level=11, nvisnodes=nothing,
+           slice=:xy, point=(0.0, 0.0, 0.0))

Create a new PlotData2D object that can be used for visualizing 2D/3D DGSEM solution data array u with Plots.jl. All relevant geometrical information is extracted from the semidiscretization semi. By default, the primitive variables (if existent) or the conservative variables (otherwise) from the solution are used for plotting. This can be changed by passing an appropriate conversion function to solution_variables.

If grid_lines is true, also extract grid vertices for visualizing the mesh. The output resolution is indirectly set via max_supported_level: all data is interpolated to 2^max_supported_level uniformly distributed points in each spatial direction, also setting the maximum allowed refinement level in the solution. nvisnodes specifies the number of visualization nodes to be used. If it is nothing, twice the number of solution DG nodes are used for visualization, and if set to 0, exactly the number of nodes in the DG elements are used.

When visualizing data from a three-dimensional simulation, a 2D slice is extracted for plotting. slice specifies the plane that is being sliced and may be :xy, :xz, or :yz. The slice position is specified by a point that lies on it, which defaults to (0.0, 0.0, 0.0). Both of these values are ignored when visualizing 2D data.

Experimental implementation

This is an experimental feature and may change in future releases.

Examples

julia> using Trixi, Plots
+
+julia> trixi_include(default_example())
+[...]
+
+julia> pd = PlotData2D(sol)
+PlotData2D(...)
+
+julia> plot(pd) # To plot all available variables
+
+julia> plot(pd["scalar"]) # To plot only a single variable
+
+julia> plot!(getmesh(pd)) # To add grid lines to the plot
source
Trixi.PlotData2DMethod
PlotData2D(sol; kwargs...)

Create a PlotData2D object from a solution object created by either OrdinaryDiffEq.solve! (which returns a SciMLBase.ODESolution) or Trixi.jl's own solve! (which returns a TimeIntegratorSolution).

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.ScalarPlotData2DMethod
ScalarPlotData2D(u, semi::AbstractSemidiscretization; kwargs...)

Returns an PlotData2DTriangulated object which is used to visualize a single scalar field. u should be an array whose entries correspond to values of the scalar field at nodal points.

source
Trixi.SummaryCallbackFunction
SummaryCallback()

Create and return a callback that prints a human-readable summary of the simulation setup at the beginning of a simulation and then resets the timer. When the returned callback is executed directly, the current timer values are shown.

source
Trixi.adapt_to_mesh_level!Method
adapt_to_mesh_level!(u_ode, semi, level)
+adapt_to_mesh_level!(sol::Trixi.TrixiODESolution, level)

Like adapt_to_mesh_level, but modifies the solution and parts of the semidiscretization (mesh and caches) in place.

source
Trixi.adapt_to_mesh_levelMethod
adapt_to_mesh_level(u_ode, semi, level)
+adapt_to_mesh_level(sol::Trixi.TrixiODESolution, level)

Use the regular adaptive mesh refinement routines to adaptively refine/coarsen the solution u_ode with semidiscretization semi towards a uniformly refined grid with refinement level level. The solution and semidiscretization are copied such that the original objects remain unaltered.

A convenience method accepts an ODE solution object, from which solution and semidiscretization are extracted as needed.

See also: adapt_to_mesh_level!

source
Trixi.boundary_condition_noslip_wallMethod
boundary_condition_noslip_wall(u_inner, orientation, direction, x, t,
+                               surface_flux_function,
+                               equations::LatticeBoltzmannEquations2D)

No-slip wall boundary condition using the bounce-back approach.

source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,
+                             equations::AcousticPerturbationEquations2D)

Use an orthogonal projection of the perturbed velocities to zero out the normal velocity while retaining the possibility of a tangential velocity in the boundary state. Further details are available in the paper:

  • Marcus Bauer, Jürgen Dierke and Roland Ewert (2011) Application of a discontinuous Galerkin method to discretize acoustic perturbation equations DOI: 10.2514/1.J050333
source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,
+                             equations::CompressibleEulerEquations2D)

Determine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:

  • J. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF

Details about the 1D pressure Riemann solution can be found in Section 6.3.3 of the book

  • Eleuterio F. Toro (2009) Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction 3rd edition DOI: 10.1007/b79761

Should be used together with UnstructuredMesh2D.

source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,
+                             equations::CompressibleEulerEquations3D)

Determine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:

  • J. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF

Details about the 1D pressure Riemann solution can be found in Section 6.3.3 of the book

  • Eleuterio F. Toro (2009) Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction 3rd edition DOI: 10.1007/b79761
source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,
+                             equations::ShallowWaterEquations2D)

Create a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value. For details see Section 9.2.5 of the book:

  • Eleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662
source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,
+                             equations::ShallowWaterTwoLayerEquations2D)

Create a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.

For details see Section 9.2.5 of the book:

  • Eleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662
source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, orientation, direction, x, t,
+                             surface_flux_function, equations::CompressibleEulerEquations1D)

Determine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:

  • J. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF

    Should be used together with TreeMesh.

source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, orientation_or_normal, x, t, surface_flux_function,
+                              equations::ShallowWaterEquations1D)

Create a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.

For details see Section 9.2.5 of the book:

  • Eleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662
source
Trixi.boundary_condition_slip_wallMethod
boundary_condition_slip_wall(u_inner, orientation_or_normal, x, t, surface_flux_function,
+                             equations::ShallowWaterTwoLayerEquations1D)

Create a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.

For details see Section 9.2.5 of the book:

  • Eleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662
source
Trixi.boundary_condition_wallMethod
boundary_condition_wall(u_inner, orientation, direction, x, t, surface_flux_function,
+                        equations::AcousticPerturbationEquations2D)

Boundary conditions for a solid wall.

source
Trixi.boundary_condition_wallMethod
boundary_condition_wall(u_inner, orientation, direction, x, t, surface_flux_function,
+                            equations::LinearizedEulerEquations2D)

Boundary conditions for a solid wall.

source
Trixi.calc_error_normsMethod
calc_error_norms([func=(u_node,equations)->u_node,] u_ode, t, analyzer, semi::AbstractSemidiscretization, cache_analysis)

Calculate discrete L2 and L∞ error norms of func applied to each nodal variable u_node in u_ode. If no exact solution is available, "errors" are calculated using some reference state and can be useful for regression tests.

source
Trixi.calc_fast_wavespeed_roeMethod
calc_fast_wavespeed_roe(u_ll, u_rr, direction, equations::IdealGlmMhdEquations1D)

Compute the fast magnetoacoustic wave speed using Roe averages as given by

  • Cargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773
source
Trixi.calc_fast_wavespeed_roeMethod
calc_fast_wavespeed_roe(u_ll, u_rr, orientation_or_normal_direction, equations::IdealGlmMhdEquations2D)

Compute the fast magnetoacoustic wave speed using Roe averages as given by

  • Cargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773
source
Trixi.calc_fast_wavespeed_roeMethod
calc_fast_wavespeed_roe(u_ll, u_rr, orientation_or_normal_direction, equations::IdealGlmMhdEquations3D)

Compute the fast magnetoacoustic wave speed using Roe averages as given by

  • Cargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773
source
Trixi.calc_wavespeed_roeMethod
calc_wavespeed_roe(u_ll, u_rr, direction::Integer,
+                   equations::ShallowWaterEquations1D)

Calculate Roe-averaged velocity v_roe and wavespeed c_roe = sqrt{g * h_roe} See for instance equation (62) in

  • Paul A. Ullrich, Christiane Jablonowski, and Bram van Leer (2010) High-order finite-volume methods for the shallow-water equations on the sphere DOI: 10.1016/j.jcp.2010.04.044

Or equation (9.17) in this lecture notes.

source
Trixi.calc_wavespeed_roeMethod
calc_wavespeed_roe(u_ll, u_rr, direction::Integer,
+                   equations::ShallowWaterEquations2D)

Calculate Roe-averaged velocity v_roe and wavespeed c_roe = sqrt{g * h_roe} depending on direction. See for instance equation (62) in

  • Paul A. Ullrich, Christiane Jablonowski, and Bram van Leer (2010) High-order finite-volume methods for the shallow-water equations on the sphere DOI: 10.1016/j.jcp.2010.04.044

Or this slides, slides 8 and 9.

source
Trixi.collision_bgkMethod
collision_bgk(u, dt, equations::LatticeBoltzmannEquations2D)

Collision operator for the Bhatnagar, Gross, and Krook (BGK) model.

source
Trixi.collision_bgkMethod
collision_bgk(u, dt, equations::LatticeBoltzmannEquations3D)

Collision operator for the Bhatnagar, Gross, and Krook (BGK) model.

source
Trixi.cons2consMethod
cons2cons(u, equations)

Return the conserved variables u. While this function is as trivial as identity, it is also as useful.

source
Trixi.cons2entropyFunction
cons2entropy(u, equations)

Convert the conserved variables u to the entropy variables for a given set of equations with chosen standard entropy.

u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by entropy2cons.

source
Trixi.cons2primFunction
cons2prim(u, equations)

Convert the conserved variables u to the primitive variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by prim2cons.

source
Trixi.convergence_testMethod
convergence_test([mod::Module=Main,] elixir::AbstractString, iterations; kwargs...)

Run iterations Trixi.jl simulations using the setup given in elixir and compute the experimental order of convergence (EOC) in the $L^2$ and $L^\infty$ norm. In each iteration, the resolution of the respective mesh will be doubled. Additional keyword arguments kwargs... and the optional module mod are passed directly to trixi_include.

This function assumes that the spatial resolution is set via the keywords initial_refinement_level (an integer) or cells_per_dimension (a tuple of integers, one per spatial dimension).

source
Trixi.default_example_unstructuredMethod
default_example_unstructured()

Return the path to an example elixir that can be used to quickly see Trixi.jl in action on an UnstructuredMesh2D. This simulation is run on the example curved, unstructured mesh given in the Trixi.jl documentation regarding unstructured meshes.

source
Trixi.densityMethod
density(p::Real, equations::LatticeBoltzmannEquations2D)
+density(u, equations::LatticeBoltzmannEquations2D)

Calculate the macroscopic density from the pressure p or the particle distribution functions u.

source
Trixi.densityMethod
density(p::Real, equations::LatticeBoltzmannEquations3D)
+density(u, equations::LatticeBoltzmannEquations3D)

Calculate the macroscopic density from the pressure p or the particle distribution functions u.

source
Trixi.each_dof_globalMethod
each_dof_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the degrees of freedom (DOF) in dg. In particular, not the DOFs themselves are returned.

source
Trixi.each_face_nodeMethod
each_face_node(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the face nodes in dg. In particular, not the face_nodes themselves are returned.

source
Trixi.each_face_node_globalMethod
each_face_node_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the face nodes in mesh. In particular, not the face nodes themselves are returned.

source
Trixi.each_quad_nodeMethod
each_quad_node(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the quadrature nodes in dg. In particular, not the quadrature nodes themselves are returned.

source
Trixi.each_quad_node_globalMethod
each_quad_node_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the global quadrature nodes in mesh. In particular, not the quadrature nodes themselves are returned.

source
Trixi.eachboundaryMethod
eachboundary(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the boundaries in cache. In particular, not the boundaries themselves are returned.

source
Trixi.eachcomponentMethod
eachcomponent(equations::AbstractCompressibleEulerMulticomponentEquations)

Return an iterator over the indices that specify the location in relevant data structures for the components in AbstractCompressibleEulerMulticomponentEquations. In particular, not the components themselves are returned.

source
Trixi.eachcomponentMethod
eachcomponent(equations::AbstractIdealGlmMhdMulticomponentEquations)

Return an iterator over the indices that specify the location in relevant data structures for the components in AbstractIdealGlmMhdMulticomponentEquations. In particular, not the components themselves are returned.

source
Trixi.eachdimMethod
eachdim(mesh)

Return an iterator over the indices that specify the location in relevant data structures for the dimensions in AbstractTree. In particular, not the dimensions themselves are returned.

source
Trixi.eachdirectionMethod
eachdirection(tree::AbstractTree)

Return an iterator over the indices that specify the location in relevant data structures for the directions in AbstractTree. In particular, not the directions themselves are returned.

source
Trixi.eachelementMethod
eachelement(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the elements in cache. In particular, not the elements themselves are returned.

source
Trixi.eachelementMethod
eachelement(mesh::DGMultiMesh, dg::DGMulti, other_args...)

Return an iterator over the indices that specify the location in relevant data structures for the elements in mesh. In particular, not the elements themselves are returned.

source
Trixi.eachelementMethod
eachelement(elements::ElementContainer1D)

Return an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.

source
Trixi.eachelementMethod
eachelement(elements::ElementContainer2D)

Return an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.

source
Trixi.eachelementMethod
eachelement(elements::ElementContainer3D)

Return an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.

source
Trixi.eachelementMethod
eachelement(elements::UnstructuredElementContainer2D)

Return an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.

source
Trixi.eachinterfaceMethod
eachinterface(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the interfaces in cache. In particular, not the interfaces themselves are returned.

source
Trixi.eachmortarMethod
eachmortar(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the mortars in cache. In particular, not the mortars themselves are returned.

source
Trixi.eachmpiinterfaceMethod
eachmpiinterface(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the MPI interfaces in cache. In particular, not the interfaces themselves are returned.

source
Trixi.eachmpimortarMethod
eachmpimortar(dg::DG, cache)

Return an iterator over the indices that specify the location in relevant data structures for the MPI mortars in cache. In particular, not the mortars themselves are returned.

source
Trixi.eachnodeMethod
eachnode(dg::DG)

Return an iterator over the indices that specify the location in relevant data structures for the nodes in dg. In particular, not the nodes themselves are returned.

source
Trixi.eachnodeMethod
eachnode(basis::LobattoLegendreBasis)

Return an iterator over the indices that specify the location in relevant data structures for the nodes in basis. In particular, not the nodes themselves are returned.

source
Trixi.eachnodeMethod
eachnode(analyzer::LobattoLegendreAnalyzer)

Return an iterator over the indices that specify the location in relevant data structures for the nodes in analyzer. In particular, not the nodes themselves are returned.

source
Trixi.eachvariableMethod
eachvariable(equations::AbstractEquations)

Return an iterator over the indices that specify the location in relevant data structures for the variables in equations. In particular, not the variables themselves are returned.

source
Trixi.energy_internalFunction
energy_internal(u, equations)

Return the internal energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.

u is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).

source
Trixi.energy_kineticFunction
energy_kinetic(u, equations)

Return the kinetic energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.

u is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).

source
Trixi.energy_totalFunction
energy_total(u, equations)

Return the total energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.

u is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).

source
Trixi.entropyFunction
entropy(u, equations)

Return the chosen entropy of the conserved variables u for a given set of equations.

u is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).

source
Trixi.entropy2consFunction
entropy2cons(w, equations)

Convert the entropy variables w based on a standard entropy to the conserved variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by cons2entropy.

source
Trixi.equilibrium_distributionMethod
equilibrium_distribution(alpha, rho, v1, v2, v3, equations::LatticeBoltzmannEquations3D)

Calculate the local equilibrium distribution for the distribution function with index alpha and given the macroscopic state defined by rho, v1, v2, v3.

source
Trixi.equilibrium_distributionMethod
equilibrium_distribution(alpha, rho, v1, v2, equations::LatticeBoltzmannEquations2D)

Calculate the local equilibrium distribution for the distribution function with index alpha and given the macroscopic state defined by rho, v1, v2.

source
Trixi.examples_dirMethod
examples_dir()

Return the directory where the example files provided with Trixi.jl are located. If Trixi.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:

Examples

readdir(examples_dir())
source
Trixi.fluxFunction
flux(u, orientation_or_normal, equations)

Given the conservative variables u, calculate the (physical) flux in Cartesian direction orientation::Integer or in arbitrary direction normal::AbstractVector for the corresponding set of governing equations. orientation is 1, 2, and 3 for the x-, y-, and z-directions, respectively.

source
Trixi.fluxMethod
flux(u, normal_direction::AbstractVector, equations::AbstractEquations{1})

Enables calling flux with a non-integer argument normal_direction for one-dimensional equations. Returns the value of flux(u, 1, equations) scaled by normal_direction[1].

source
Trixi.flux_centralMethod
flux_central(u_ll, u_rr, orientation_or_normal_direction, equations::AbstractEquations)

The classical central numerical flux f((u_ll) + f(u_rr)) / 2. When this flux is used as volume flux, the discretization is equivalent to the classical weak form DG method (except floating point errors).

source
Trixi.flux_chan_etalMethod
flux_chan_etal(u_ll, u_rr, orientation,
+               equations::ShallowWaterEquationsQuasi1D)

Total energy conservative (mathematical entropy for quasi 1D shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., FluxPlusDissipation(flux_chan_etal, DissipationLocalLaxFriedrichs()).

Further details are available in the paper:

  • Jesse Chan, Khemraj Shukla, Xinhui Wu, Ruofeng Liu, Prani Nalluri (2023) High order entropy stable schemes for the quasi-one-dimensional shallow water and compressible Euler equations DOI: 10.48550/arXiv.2307.12089
source
Trixi.flux_chandrashekarMethod
flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)

Entropy conserving two-point flux by

  • Chandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a
source
Trixi.flux_chandrashekarMethod
flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations2D)

Entropy conserving two-point flux by

  • Chandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a
source
Trixi.flux_chandrashekarMethod
flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations3D)

Entropy conserving two-point flux by

  • Chandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a
source
Trixi.flux_chandrashekarMethod
flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerMulticomponentEquations1D)

Entropy conserving two-point flux by

  • Ayoub Gouasmi, Karthik Duraisamy (2020) "Formulation of Entropy-Stable schemes for the multicomponent compressible Euler equations" arXiv:1904.00972v3 [math.NA] 4 Feb 2020
source
Trixi.flux_chandrashekarMethod
flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerMulticomponentEquations2D)

Adaption of the entropy conserving two-point flux by

  • Ayoub Gouasmi, Karthik Duraisamy (2020) "Formulation of Entropy-Stable schemes for the multicomponent compressible Euler equations" arXiv:1904.00972v3 [math.NA] 4 Feb 2020
source
Trixi.flux_derigs_etalMethod
flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations1D)

Entropy conserving two-point flux by

  • Derigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002
source
Trixi.flux_derigs_etalMethod
flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations2D)

Entropy conserving two-point flux by

  • Derigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002
source
Trixi.flux_derigs_etalMethod
flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations3D)

Entropy conserving two-point flux by

  • Derigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002
source
Trixi.flux_derigs_etalMethod
flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations1D)

Entropy conserving two-point flux adapted by

  • Derigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations for multicomponent DOI: 10.1016/j.jcp.2018.03.002
source
Trixi.flux_derigs_etalMethod
flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdMulticomponentEquations2D)

Entropy conserving two-point flux adapted by

  • Derigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations for multicomponent DOI: 10.1016/j.jcp.2018.03.002
source
Trixi.flux_es_fjordholm_etalMethod
flux_es_fjordholm_etal(u_ll, u_rr, orientation_or_normal_direction,
+                       equations::ShallowWaterTwoLayerEquations1D)

Entropy stable surface flux for the two-layer shallow water equations. Uses the entropy conservative flux_fjordholm_etal and adds a Lax-Friedrichs type dissipation dependent on the jump of entropy variables.

Further details are available in the paper:

  • Ulrik Skre Fjordholm (2012)

Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039 It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_es_fjordholm_etalMethod
flux_es_fjordholm_etal(u_ll, u_rr, orientation,
+                       equations::ShallowWaterTwoLayerEquations1D)

Entropy stable surface flux for the two-layer shallow water equations. Uses the entropy conservative flux_fjordholm_etal and adds a Lax-Friedrichs type dissipation dependent on the jump of entropy variables.

Further details are available in the paper:

It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation,
+                    equations::ShallowWaterEquations1D)

Total energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042
source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation_or_normal_direction,
+                    equations::ShallowWaterEquations2D)

Total energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042
source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation,
+                    equations::ShallowWaterTwoLayerEquations1D)

Total energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishra and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042

and the application to two layers is shown in the paper:

It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_fjordholm_etalMethod
flux_fjordholm_etal(u_ll, u_rr, orientation,
+                    equations::ShallowWaterTwoLayerEquations2D)

Total energy conservative (mathematical entropy for two-layer shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.

Details are available in Eq. (4.1) in the paper:

  • Ulrik S. Fjordholm, Siddhartha Mishra and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042

and the application to two layers is shown in the paper:

It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_godunovMethod
flux_godunov(u_ll, u_rr, orientation_or_normal_direction,
+             equations::LinearizedEulerEquations2D)

An upwind flux for the linearized Euler equations based on diagonalization of the physical flux matrix. Given the physical flux $Au$, $A=T \Lambda T^{-1}$ with $\Lambda$ being a diagonal matrix that holds the eigenvalues of $A$, decompose $\Lambda = \Lambda^+ + \Lambda^-$ where $\Lambda^+$ and $\Lambda^-$ are diagonal matrices holding the positive and negative eigenvalues of $A$, respectively. Then for left and right states $u_L, u_R$, the numerical flux calculated by this function is given by $A^+ u_L + A^- u_R$ where $A^{\pm} = T \Lambda^{\pm} T^{-1}$.

The diagonalization of the flux matrix can be found in

source
Trixi.flux_hindenlang_gassnerMethod
flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,
+                        equations::IdealGlmMhdEquations1D)

Entropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.

References

  • Florian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications
  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig
  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_hindenlang_gassnerMethod
flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,
+                        equations::IdealGlmMhdEquations2D)

Entropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.

References

  • Florian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications
  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig
  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_hindenlang_gassnerMethod
flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,
+                        equations::IdealGlmMhdEquations3D)

Entropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.

References

  • Florian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications
  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig
  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_hindenlang_gassnerMethod
flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,
+                        equations::IdealGlmMhdMulticomponentEquations1D)

Adaption of the entropy conserving and kinetic energy preserving two-point flux of Hindenlang (2019), extending flux_ranocha to the MHD equations.

References

  • Florian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications
  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig
  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_hindenlang_gassnerMethod
flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,
+                        equations::IdealGlmMhdMulticomponentEquations2D)

Adaption of the entropy conserving and kinetic energy preserving two-point flux of Hindenlang (2019), extending flux_ranocha to the MHD equations.

References

  • Florian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications
  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig
  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_hlleMethod
flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)

Computes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.

Original publication:

Compactly summarized:

  • Siddhartha Mishra, Ulrik Skre Fjordholm and Rémi Abgrall Numerical methods for conservation laws and related equations. Link
source
Trixi.flux_hlleMethod
flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations2D)

Computes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.

source
Trixi.flux_hlleMethod
flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations3D)

Computes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.

source
Trixi.flux_kennedy_gruberMethod
flux_kennedy_gruber(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)

Kinetic energy preserving two-point flux by

  • Kennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020
source
Trixi.flux_kennedy_gruberMethod
flux_kennedy_gruber(u_ll, u_rr, orientation_or_normal_direction,
+                    equations::CompressibleEulerEquations2D)

Kinetic energy preserving two-point flux by

  • Kennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020
source
Trixi.flux_kennedy_gruberMethod
flux_kennedy_gruber(u_ll, u_rr, orientation_or_normal_direction,
+                    equations::CompressibleEulerEquations3D)

Kinetic energy preserving two-point flux by

  • Kennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020
source
Trixi.flux_nonconservative_audusse_etalMethod
flux_nonconservative_audusse_etal(u_ll, u_rr, orientation::Integer,
+                                  equations::ShallowWaterEquations1D)

Non-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_audusse_etal on the conservative variables.

This hydrostatic reconstruction ensures that the finite volume numerical fluxes remain well-balanced for discontinuous bottom topographies ShallowWaterEquations1D. Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_audusse_etal in the surface flux to ensure consistency.

Further details on the hydrostatic reconstruction and its motivation can be found in

  • Emmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090
source
Trixi.flux_nonconservative_audusse_etalMethod
flux_nonconservative_audusse_etal(u_ll, u_rr, orientation::Integer,
+                                  equations::ShallowWaterEquations2D)
+flux_nonconservative_audusse_etal(u_ll, u_rr,
+                                  normal_direction_ll     ::AbstractVector,
+                                  normal_direction_average::AbstractVector,
+                                  equations::ShallowWaterEquations2D)

Non-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_audusse_etal on the conservative variables.

This hydrostatic reconstruction ensures that the finite volume numerical fluxes remain well-balanced for discontinuous bottom topographies ShallowWaterEquations2D. Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_audusse_etal in the surface flux to ensure consistency.

Further details for the hydrostatic reconstruction and its motivation can be found in

  • Emmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090
source
Trixi.flux_nonconservative_chan_etalMethod
flux_nonconservative_chan_etal(u_ll, u_rr, orientation::Integer,
+                               equations::ShallowWaterEquationsQuasi1D)

Non-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquationsQuasi1D and the channel width.

Further details are available in the paper:

  • Jesse Chan, Khemraj Shukla, Xinhui Wu, Ruofeng Liu, Prani Nalluri (2023) High order entropy stable schemes for the quasi-one-dimensional shallow water and compressible Euler equations DOI: 10.48550/arXiv.2307.12089
source
Trixi.flux_nonconservative_chen_noelleMethod
flux_nonconservative_chen_noelle(u_ll, u_rr,
+                                 orientation::Integer,
+                                 equations::ShallowWaterEquations1D)

Non-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_chen_noelle on the conservative variables.

Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_chen_noelle in the surface flux to ensure consistency.

Further details on the hydrostatic reconstruction and its motivation can be found in

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.flux_nonconservative_chen_noelleMethod
flux_nonconservative_chen_noelle(u_ll, u_rr,
+                                 orientation::Integer,
+                                 equations::ShallowWaterEquations2D)
+flux_nonconservative_chen_noelle(u_ll, u_rr,
+                                 normal_direction_ll      ::AbstractVector,
+                                 normal_direction_average ::AbstractVector,
+                                 equations::ShallowWaterEquations2D)

Non-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_chen_noelle on the conservative variables.

Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_chen_noelle in the surface flux to ensure consistency.

Further details on the hydrostatic reconstruction and its motivation can be found in

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.flux_nonconservative_fjordholm_etalMethod
flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,
+                                    equations::ShallowWaterEquations1D)

Non-symmetric two-point surface flux discretizing the nonconservative (source) term of that contains the gradient of the bottom topography ShallowWaterEquations1D.

This contains additional terms compared to flux_nonconservative_wintermeyer_etal that account for possible discontinuities in the bottom topography function. Thus, this flux should be used in general at interfaces. For flux differencing volume terms, flux_nonconservative_wintermeyer_etal is analytically equivalent but slightly cheaper.

Further details for the original finite volume formulation are available in

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042

and for curvilinear 2D case in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_nonconservative_fjordholm_etalMethod
flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,
+                                    equations::ShallowWaterEquations2D)
+flux_nonconservative_fjordholm_etal(u_ll, u_rr,
+                                    normal_direction_ll     ::AbstractVector,
+                                    normal_direction_average::AbstractVector,
+                                    equations::ShallowWaterEquations2D)

Non-symmetric two-point surface flux discretizing the nonconservative (source) term of that contains the gradient of the bottom topography ShallowWaterEquations2D.

On curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.

This contains additional terms compared to flux_nonconservative_wintermeyer_etal that account for possible discontinuities in the bottom topography function. Thus, this flux should be used in general at interfaces. For flux differencing volume terms, flux_nonconservative_wintermeyer_etal is analytically equivalent but slightly cheaper.

Further details for the original finite volume formulation are available in

  • Ulrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042

and for curvilinear 2D case in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_nonconservative_fjordholm_etalMethod
flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,
+                                    equations::ShallowWaterTwoLayerEquations1D)
Experimental code

This numerical flux is experimental and may change in any future release.

Non-symmetric two-point surface flux discretizing the nonconservative (source) term that contains the gradients of the bottom topography and an additional term that couples the momentum of both layers ShallowWaterTwoLayerEquations2D.

Further details are available in the paper:

It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_nonconservative_fjordholm_etalMethod
flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,
+                                    equations::ShallowWaterTwoLayerEquations2D)
Experimental code

This numerical flux is experimental and may change in any future release.

Non-symmetric two-point surface flux discretizing the nonconservative (source) term that contains the gradients of the bottom topography and an additional term that couples the momentum of both layers ShallowWaterTwoLayerEquations2D.

Further details are available in the paper:

It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.

source
Trixi.flux_nonconservative_powellMethod
flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,
+                            equations::IdealGlmMhdEquations2D)
+flux_nonconservative_powell(u_ll, u_rr,
+                            normal_direction_ll     ::AbstractVector,
+                            normal_direction_average::AbstractVector,
+                            equations::IdealGlmMhdEquations2D)

Non-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdEquations2D.

On curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.

References

  • Marvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027
source
Trixi.flux_nonconservative_powellMethod
flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,
+                            equations::IdealGlmMhdEquations3D)
+flux_nonconservative_powell(u_ll, u_rr,
+                            normal_direction_ll     ::AbstractVector,
+                            normal_direction_average::AbstractVector,
+                            equations::IdealGlmMhdEquations3D)

Non-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdEquations3D.

On curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.

References

  • Marvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027
source
Trixi.flux_nonconservative_powellMethod
flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,
+                            equations::IdealGlmMhdMulticomponentEquations2D)

Non-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdMulticomponentEquations2D.

References

  • Marvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027
source
Trixi.flux_nonconservative_wintermeyer_etalMethod
flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,
+                                      equations::ShallowWaterEquations1D)

Non-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquations1D.

Further details are available in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_nonconservative_wintermeyer_etalMethod
flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,
+                                      equations::ShallowWaterEquations2D)
+flux_nonconservative_wintermeyer_etal(u_ll, u_rr,
+                                      normal_direction_ll     ::AbstractVector,
+                                      normal_direction_average::AbstractVector,
+                                      equations::ShallowWaterEquations2D)

Non-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquations2D.

On curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.

Further details are available in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_nonconservative_wintermeyer_etalMethod
flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,
+                                      equations::ShallowWaterTwoLayerEquations1D)
Experimental code

This numerical flux is experimental and may change in any future release.

Non-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterTwoLayerEquations2D and an additional term that couples the momentum of both layers. This is a slightly modified version to account for the additional source term compared to the standard SWE described in the paper.

Further details are available in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_nonconservative_wintermeyer_etalMethod
flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,
+                                      equations::ShallowWaterTwoLayerEquations2D)
Experimental code

This numerical flux is experimental and may change in any future release.

Non-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterTwoLayerEquations2D and an additional term that couples the momentum of both layers. This is a slightly modified version to account for the additional source term compared to the standard SWE described in the paper.

Further details are available in the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_ranochaMethod
flux_ranocha(u_ll, u_rr, orientation_or_normal_direction, equations::CompressibleEulerEquations1D)

Entropy conserving and kinetic energy preserving two-point flux by

  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig

See also

  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_ranochaMethod
flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,
+             equations::CompressibleEulerEquations2D)

Entropy conserving and kinetic energy preserving two-point flux by

  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig

See also

  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_ranochaMethod
flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,
+             equations::CompressibleEulerEquations3D)

Entropy conserving and kinetic energy preserving two-point flux by

  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig

See also

  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_ranochaMethod
flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,
+             equations::CompressibleEulerMulticomponentEquations1D)

Adaption of the entropy conserving and kinetic energy preserving two-point flux by

  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig

See also

  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_ranochaMethod
flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,
+             equations::CompressibleEulerMulticomponentEquations2D)

Adaption of the entropy conserving and kinetic energy preserving two-point flux by

  • Hendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig

See also

  • Hendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018
source
Trixi.flux_shima_etalMethod
flux_shima_etal(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)

This flux is is a modification of the original kinetic energy preserving two-point flux by

  • Yuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058

The modification is in the energy flux to guarantee pressure equilibrium and was developed by

  • Nao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060
source
Trixi.flux_shima_etalMethod
flux_shima_etal(u_ll, u_rr, orientation_or_normal_direction,
+                equations::CompressibleEulerEquations2D)

This flux is is a modification of the original kinetic energy preserving two-point flux by

  • Yuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058

The modification is in the energy flux to guarantee pressure equilibrium and was developed by

  • Nao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060
source
Trixi.flux_shima_etalMethod
flux_shima_etal(u_ll, u_rr, orientation_or_normal_direction,
+                equations::CompressibleEulerEquations3D)

This flux is is a modification of the original kinetic energy preserving two-point flux by

  • Yuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058

The modification is in the energy flux to guarantee pressure equilibrium and was developed by

  • Nao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation,
+                      equations::ShallowWaterEquations1D)

Total energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,
+                      equations::ShallowWaterEquations2D)

Total energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation,
+                      equations::ShallowWaterTwoLayerEquations1D)

Total energy conservative (mathematical entropy for two-layer shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal. To obtain the flux for the two-layer shallow water equations the flux that is described in the paper for the normal shallow water equations is used within each layer.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_wintermeyer_etalMethod
flux_wintermeyer_etal(u_ll, u_rr, orientation,
+                      equations::ShallowWaterTwoLayerEquations2D)

Total energy conservative (mathematical entropy for two-layer shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal. To obtain the flux for the two-layer shallow water equations the flux that is described in the paper for the normal shallow water equations is used within each layer.

Further details are available in Theorem 1 of the paper:

  • Niklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036
source
Trixi.flux_winters_etalMethod
flux_winters_etal(u_ll, u_rr, normal_direction,
+                  equations::PolytropicEulerEquations2D)

Entropy conserving two-point flux for isothermal or polytropic gases. Requires a special weighted Stolarsky mean for the evaluation of the density denoted here as stolarsky_mean. Note, for isothermal gases where gamma = 1 this stolarsky_mean becomes the ln_mean.

For details see Section 3.2 of the following reference

  • Andrew R. Winters, Christof Czernik, Moritz B. Schily & Gregor J. Gassner (2020) Entropy stable numerical approximations for the isothermal and polytropic Euler equations DOI: 10.1007/s10543-019-00789-w
source
Trixi.get_nameMethod
get_name(x)

Returns a name of x ready for pretty printing. By default, return string(y) if x isa Val{y} and return string(x) otherwise.

Examples

julia> Trixi.get_name("test")
+"test"
+
+julia> Trixi.get_name(Val(:test))
+"test"
source
Trixi.get_nameMethod
get_name(equations::AbstractEquations)

Returns the canonical, human-readable name for the given system of equations.

Examples

julia> Trixi.get_name(CompressibleEulerEquations1D(1.4))
+"CompressibleEulerEquations1D"
source
Trixi.getmeshMethod
getmesh(pd::AbstractPlotData)

Extract grid lines from pd for plotting with Plots.plot.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.global_mean_varsMethod
global_mean_vars(equations::AcousticPerturbationEquations2D)

Returns the global mean variables stored in equations. This makes it easier to define flexible initial conditions for problems with constant mean flow.

source
Trixi.have_nonconservative_termsMethod
have_nonconservative_terms(equations)

Trait function determining whether equations represent a conservation law with or without nonconservative terms. Classical conservation laws such as the CompressibleEulerEquations2D do not have nonconservative terms. The ShallowWaterEquations2D with non-constant bottom topography are an example of equations with nonconservative terms. The return value will be True() or False() to allow dispatching on the return type.

source
Trixi.hydrostatic_reconstruction_audusse_etalMethod
hydrostatic_reconstruction_audusse_etal(u_ll, u_rr, orientation::Integer,
+                                        equations::ShallowWaterEquations1D)

A particular type of hydrostatic reconstruction on the water height to guarantee well-balancedness for a general bottom topography ShallowWaterEquations1D. The reconstructed solution states u_ll_star and u_rr_star variables are then used to evaluate the surface numerical flux at the interface. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.

Further details on this hydrostatic reconstruction and its motivation can be found in

  • Emmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090
source
Trixi.hydrostatic_reconstruction_audusse_etalMethod
hydrostatic_reconstruction_audusse_etal(u_ll, u_rr, orientation_or_normal_direction,
+                                        equations::ShallowWaterEquations2D)

A particular type of hydrostatic reconstruction on the water height to guarantee well-balancedness for a general bottom topography ShallowWaterEquations2D. The reconstructed solution states u_ll_star and u_rr_star variables are used to evaluate the surface numerical flux at the interface. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.

Further details for the hydrostatic reconstruction and its motivation can be found in

  • Emmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090
source
Trixi.hydrostatic_reconstruction_chen_noelleMethod
hydrostatic_reconstruction_chen_noelle(u_ll, u_rr, orientation::Integer,
+                                       equations::ShallowWaterEquations1D)

A particular type of hydrostatic reconstruction of the water height to guarantee well-balancedness for a general bottom topography of the ShallowWaterEquations1D. The reconstructed solution states u_ll_star and u_rr_star variables are used to evaluate the surface numerical flux at the interface. The key idea is a linear reconstruction of the bottom and water height at the interfaces using subcells. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.

Further details on this hydrostatic reconstruction and its motivation can be found in

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.hydrostatic_reconstruction_chen_noelleMethod
hydrostatic_reconstruction_chen_noelle(u_ll, u_rr, orientation::Integer,
+                                       equations::ShallowWaterEquations2D)

A particular type of hydrostatic reconstruction of the water height to guarantee well-balancedness for a general bottom topography of the ShallowWaterEquations2D. The reconstructed solution states u_ll_star and u_rr_star variables are then used to evaluate the surface numerical flux at the interface. The key idea is a linear reconstruction of the bottom and water height at the interfaces using subcells. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.

Further details on this hydrostatic reconstruction and its motivation can be found in

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.init_mpiMethod
init_mpi()

Initialize MPI by calling MPI.Initialized(). The function will check if MPI is already initialized and if yes, do nothing, thus it is safe to call it multiple times.

source
Trixi.init_p4estMethod
init_p4est()

Initialize p4est by calling p4est_init and setting the log level to SC_LP_ERROR. This function will check if p4est is already initialized and if yes, do nothing, thus it is safe to call it multiple times.

source
Trixi.init_t8codeMethod
init_t8code()

Initialize t8code by calling sc_init, p4est_init, and t8_init while setting the log level to SC_LP_ERROR. This function will check if t8code is already initialized and if yes, do nothing, thus it is safe to call it multiple times.

source
Trixi.initial_condition_constantMethod
initial_condition_constant(x, t, equations::AcousticPerturbationEquations2D)

A constant initial condition where the state variables are zero and the mean flow is constant. Uses the global mean values from equations.

source
Trixi.initial_condition_density_waveMethod
initial_condition_density_wave(x, t, equations::CompressibleEulerEquations1D)

A sine wave in the density with constant velocity and pressure; reduces the compressible Euler equations to the linear advection equations. This setup is the test case for stability of EC fluxes from paper

  • Gregor J. Gassner, Magnus Svärd, Florian J. Hindenlang (2020) Stability issues of entropy-stable and/or split-form high-order schemes arXiv: 2007.09026

with the following parameters

  • domain [-1, 1]
  • mesh = 4x4
  • polydeg = 5
source
Trixi.initial_condition_density_waveMethod
initial_condition_density_wave(x, t, equations::CompressibleEulerEquations2D)

A sine wave in the density with constant velocity and pressure; reduces the compressible Euler equations to the linear advection equations. This setup is the test case for stability of EC fluxes from paper

  • Gregor J. Gassner, Magnus Svärd, Florian J. Hindenlang (2020) Stability issues of entropy-stable and/or split-form high-order schemes arXiv: 2007.09026

with the following parameters

  • domain [-1, 1]
  • mesh = 4x4
  • polydeg = 5
source
Trixi.initial_condition_eoc_test_coupled_euler_gravityMethod
initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations1D)

One dimensional variant of the setup used for convergence tests of the Euler equations with self-gravity from

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593
Note

There is no additional source term necessary for the manufactured solution in one spatial dimension. Thus, source_terms_eoc_test_coupled_euler_gravity is not present there.

source
Trixi.initial_condition_eoc_test_coupled_euler_gravityMethod
initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations2D)

Setup used for convergence tests of the Euler equations with self-gravity used in

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593

in combination with source_terms_eoc_test_coupled_euler_gravity or source_terms_eoc_test_euler.

source
Trixi.initial_condition_eoc_test_coupled_euler_gravityMethod
initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations3D)

Setup used for convergence tests of the Euler equations with self-gravity used in

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593

in combination with source_terms_eoc_test_coupled_euler_gravity or source_terms_eoc_test_euler.

source
Trixi.initial_condition_gaussMethod
initial_condition_gauss(x, t, equations::AcousticPerturbationEquations2D)

A Gaussian pulse in a constant mean flow. Uses the global mean values from equations.

source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations1D)

A weak blast wave taken from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations2D)

A weak blast wave taken from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations3D)

A weak blast wave taken from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerMulticomponentEquations1D)

A for multicomponent adapted weak blast wave adapted to multicomponent and taken from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerMulticomponentEquations2D)

A for multicomponent adapted weak blast wave taken from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations1D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations2D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations3D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdMulticomponentEquations1D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdMulticomponentEquations2D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::PolytropicEulerEquations2D)

A weak blast wave adapted from

  • Sebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044
source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::ShallowWaterEquations1D)

A weak blast wave discontinuity useful for testing, e.g., total energy conservation. Note for the shallow water equations to the total energy acts as a mathematical entropy function.

source
Trixi.initial_condition_weak_blast_waveMethod
initial_condition_weak_blast_wave(x, t, equations::ShallowWaterEquations2D)

A weak blast wave discontinuity useful for testing, e.g., total energy conservation. Note for the shallow water equations to the total energy acts as a mathematical entropy function.

source
Trixi.integrate_via_indicesMethod
integrate_via_indices(func, u_ode, semi::AbstractSemidiscretization, args...; normalize=true)

Call func(u, i..., element, equations, solver, args...) for all nodal indices i..., element and integrate the result using a quadrature associated with the semidiscretization semi.

If normalize is true, the result is divided by the total volume of the computational domain.

source
Trixi.inv_ln_meanMethod
inv_ln_mean(x, y)

Compute the inverse 1 / ln_mean(x, y) of the logarithmic mean ln_mean.

This function may be used to increase performance where the inverse of the logarithmic mean is needed, by replacing a (slow) division by a (fast) multiplication.

source
Trixi.jacobian_ad_forwardMethod
jacobian_ad_forward(semi::AbstractSemidiscretization;
+                    t0=zero(real(semi)),
+                    u0_ode=compute_coefficients(t0, semi))

Uses the right-hand side operator of the semidiscretization semi and forward mode automatic differentiation to compute the Jacobian J of the semidiscretization semi at state u0_ode.

source
Trixi.jacobian_fdMethod
jacobian_fd(semi::AbstractSemidiscretization;
+            t0=zero(real(semi)),
+            u0_ode=compute_coefficients(t0, semi))

Uses the right-hand side operator of the semidiscretization semi and simple second order finite difference to compute the Jacobian J of the semidiscretization semi at state u0_ode.

source
Trixi.linear_structureMethod
linear_structure(semi::AbstractSemidiscretization;
+                 t0=zero(real(semi)))

Wraps the right-hand side operator of the semidiscretization semi at time t0 as an affine-linear operator given by a linear operator A and a vector b.

source
Trixi.ln_meanMethod
ln_mean(x, y)

Compute the logarithmic mean

ln_mean(x, y) = (y - x) / (log(y) - log(x)) = (y - x) / log(y / x)

Problem: The formula above has a removable singularity at x == y. Thus, some care must be taken to implement it correctly without problems or loss of accuracy when x ≈ y. Here, we use the approach proposed by Ismail and Roe (2009). Set ξ = y / x. Then, we have

(y - x) / log(y / x) = (x + y) / log(ξ) * (ξ - 1) / (ξ + 1)

Set f = (ξ - 1) / (ξ + 1) = (y - x) / (x + y). Then, we use the expansion

log(ξ) = 2 * f * (1 + f^2 / 3 + f^4 / 5 + f^6 / 7) + O(ξ^9)

Inserting the first few terms of this expansion yields

(y - x) / log(ξ) ≈ (x + y) * f / (2 * f * (1 + f^2 / 3 + f^4 / 5 + f^6 / 7))
+                 = (x + y) / (2 + 2/3 * f^2 + 2/5 * f^4 + 2/7 * f^6)

Since divisions are usually more expensive on modern hardware than multiplications (Agner Fog), we try to avoid computing two divisions. Thus, we use

f^2 = (y - x)^2 / (x + y)^2
+    = (x * (x - 2 * y) + y * y) / (x * (x + 2 * y) + y * y)

Given ε = 1.0e-4, we use the following algorithm.

if f^2 < ε
+  # use the expansion above
+else
+  # use the direct formula (y - x) / log(y / x)
+end

References

source
Trixi.load_adaptive_time_integrator!Method
load_adaptive_time_integrator!(integrator, restart_file::AbstractString)

Load the context information for time integrators with error-based step size control saved in a restart_file.

source
Trixi.load_dtMethod
load_dt(restart_file::AbstractString)

Load the time step size (dt in OrdinaryDiffEq.jl) saved in a restart_file.

source
Trixi.load_meshMethod
load_mesh(restart_file::AbstractString; n_cells_max)

Load the mesh from the restart_file.

source
Trixi.load_timeMethod
load_time(restart_file::AbstractString)

Load the time saved in a restart_file.

source
Trixi.load_timestep!Method
load_timestep!(integrator, restart_file::AbstractString)

Load the time step number saved in a restart_file and assign it to both the time step number and and the number of accepted steps (iter and stats.naccept in OrdinaryDiffEq.jl, respectively) in integrator.

source
Trixi.load_timestepMethod
load_timestep(restart_file::AbstractString)

Load the time step number (iter in OrdinaryDiffEq.jl) saved in a restart_file.

source
Trixi.maxMethod
max(x, y, ...)

Return the maximum of the arguments. See also the maximum function to take the maximum element from a collection.

This version in Trixi.jl is semantically equivalent to Base.max but may be implemented differently. In particular, it may avoid potentially expensive checks necessary in the presence of NaNs (or signed zeros).

Examples

julia> max(2, 5, 1)
+5
source
Trixi.max_abs_speed_naiveFunction
max_abs_speed_naive(u_ll, u_rr, orientation::Integer,   equations)
+max_abs_speed_naive(u_ll, u_rr, normal_direction::AbstractVector, equations)

Simple and fast estimate of the maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, based only on the local wave speeds associated to u_ll and u_rr.

For non-integer arguments normal_direction in one dimension, max_abs_speed_naive returns abs(normal_direction[1]) * max_abs_speed_naive(u_ll, u_rr, 1, equations).

source
Trixi.minMethod
min(x, y, ...)

Return the minimum of the arguments. See also the minimum function to take the minimum element from a collection.

This version in Trixi.jl is semantically equivalent to Base.min but may be implemented differently. In particular, it may avoid potentially expensive checks necessary in the presence of NaNs (or signed zeros).

Examples

julia> min(2, 5, 1)
+1
source
Trixi.min_max_speed_chen_noelleMethod
min_max_speed_chen_noelle(u_ll, u_rr, orientation::Integer,
+                          equations::ShallowWaterEquations1D)

The approximated speeds for the HLL type numerical flux used by Chen and Noelle for their hydrostatic reconstruction. As they state in the paper, these speeds are chosen for the numerical flux to ensure positivity and to satisfy an entropy inequality.

Further details on this hydrostatic reconstruction and its motivation can be found in

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.min_max_speed_chen_noelleMethod
min_max_speed_chen_noelle(u_ll, u_rr, orientation::Integer,
+                          equations::ShallowWaterEquations2D)
+min_max_speed_chen_noelle(u_ll, u_rr, normal_direction::AbstractVector,
+                          equations::ShallowWaterEquations2D)

Special estimate of the minimal and maximal wave speed of the shallow water equations for the left and right states u_ll, u_rr. These approximate speeds are used for the HLL-type numerical flux flux_hll_chen_noelle. These wave speed estimates together with a particular hydrostatic reconstruction technique guarantee that the numerical flux is positive and satisfies an entropy inequality.

Further details on this hydrostatic reconstruction and its motivation can be found in the reference below. The definition of the wave speeds are given in Equation (2.20).

  • Guoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074
source
Trixi.min_max_speed_davisFunction
min_max_speed_davis(u_ll, u_rr, orientation::Integer, equations)
+min_max_speed_davis(u_ll, u_rr, normal_direction::AbstractVector, equations)

Simple and fast estimates of the minimal and maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, usually based only on the local wave speeds associated to u_ll and u_rr.

See also FluxHLL, min_max_speed_naive, min_max_speed_einfeldt.

source
Trixi.min_max_speed_einfeldtFunction
min_max_speed_einfeldt(u_ll, u_rr, orientation::Integer, equations)
+min_max_speed_einfeldt(u_ll, u_rr, normal_direction::AbstractVector, equations)

More advanced mininmal and maximal wave speed computation based on

originally developed for the compressible Euler equations. A compact representation can be found in this lecture notes, eq. (9.28).

See also FluxHLL, min_max_speed_naive, min_max_speed_davis.

source
Trixi.min_max_speed_naiveFunction
min_max_speed_naive(u_ll, u_rr, orientation::Integer, equations)
+min_max_speed_naive(u_ll, u_rr, normal_direction::AbstractVector, equations)

Simple and fast estimate(!) of the minimal and maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, usually based only on the local wave speeds associated to u_ll and u_rr.

  • Amiram Harten, Peter D. Lax, Bram van Leer (1983) On Upstream Differencing and Godunov-Type Schemes for Hyperbolic Conservation Laws DOI: 10.1137/1025002

See also FluxHLL, min_max_speed_davis, min_max_speed_einfeldt.

source
Trixi.multiply_dimensionwiseMethod
multiply_dimensionwise(matrix::AbstractMatrix, data_in::AbstractArray{<:Any, NDIMS+1})

Multiply the array data_in by matrix in each coordinate direction, where data_in is assumed to have the first coordinate for the number of variables and the remaining coordinates are multiplied by matrix.

source
Trixi.ndofsMethod
ndofs(semi::AbstractSemidiscretization)

Return the number of degrees of freedom associated with each scalar variable.

source
Trixi.negative_partMethod
negative_part(x)

Return x if x is negative, else zero. In other words, return (x - abs(x)) / 2 for real numbers x.

source
Trixi.ode_default_optionsMethod
ode_default_options()

Return the default options for OrdinaryDiffEq's solve. Pass ode_default_options()... to solve to only return the solution at the final time and enable MPI aware error-based step size control, whenever MPI is used. For example, use solve(ode, alg; ode_default_options()...).

source
Trixi.ode_normMethod
ode_norm(u, t)

Implementation of the weighted L2 norm of Hairer and Wanner used for error-based step size control in OrdinaryDiffEq.jl. This function is aware of MPI and uses global MPI communication when running in parallel.

You must pass this function as a keyword argument internalnorm=ode_norm to OrdinaryDiffEq.jl's solve when using error-based step size control with MPI parallel execution of Trixi.jl.

See the "Advanced Adaptive Stepsize Control" section of the documentation.

source
Trixi.ode_unstable_checkMethod
ode_unstable_check(dt, u, semi, t)

Implementation of the basic check for instability used in OrdinaryDiffEq.jl. Instead of checking something like any(isnan, u), this function just checks isnan(dt). This helps when using MPI parallelization, since no additional global communication is required and all ranks will return the same result.

You should pass this function as a keyword argument unstable_check=ode_unstable_check to OrdinaryDiffEq.jl's solve when using error-based step size control with MPI parallel execution of Trixi.jl.

See the "Miscellaneous" section of the documentation.

source
Trixi.partition!Method
partition!(mesh::ParallelTreeMesh, allow_coarsening=true)

Partition mesh using a static domain decomposition algorithm based on leaf cell count and tree structure. If allow_coarsening is true, the algorithm will keep leaf cells together on one rank when needed for local coarsening (i.e. when all children of a cell are leaves).

source
Trixi.positive_partMethod
positive_part(x)

Return x if x is positive, else zero. In other words, return (x + abs(x)) / 2 for real numbers x.

source
Trixi.pressureMethod
pressure(rho::Real, equations::LatticeBoltzmannEquations2D)
+pressure(u, equations::LatticeBoltzmannEquations2D)

Calculate the macroscopic pressure from the density rho or the particle distribution functions u.

source
Trixi.pressureMethod
pressure(rho::Real, equations::LatticeBoltzmannEquations3D)
+pressure(u, equations::LatticeBoltzmannEquations3D)

Calculate the macroscopic pressure from the density rho or the particle distribution functions u.

source
Trixi.prim2consFunction
prim2cons(u, equations)

Convert the primitive variables u to the conserved variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by cons2prim.

source
Trixi.rotate_from_xFunction
rotate_from_x(u, normal, equations)

Apply the rotation that maps the x-axis onto normal to the convservative variables u. This is used by FluxRotated to calculate the numerical flux of rotationally invariant equations in arbitrary normal directions.

See also: rotate_to_x

source
Trixi.rotate_to_xFunction
rotate_to_x(u, normal, equations)

Apply the rotation that maps normal onto the x-axis to the convservative variables u. This is used by FluxRotated to calculate the numerical flux of rotationally invariant equations in arbitrary normal directions.

See also: rotate_from_x

source
Trixi.save_plotMethod
save_plot(plot_data, variable_names;
+          show_mesh=true, plot_arguments=Dict{Symbol,Any}(),
+          time=nothing, timestep=nothing)

Visualize the plot data object provided in plot_data and save result as a PNG file in the out directory, plotting only the variables in variable_names and, optionally, the mesh (if show_mesh is true). Additionally, plot_arguments will be unpacked and passed as keyword arguments to the Plots.plot command.

The timestep is used in the filename. time is currently unused by this function.

Experimental implementation

This is an experimental feature and may change in future releases.

See also: VisualizationCallback, show_plot

source
Trixi.show_plotMethod
show_plot(plot_data, variable_names;
+          show_mesh=true, plot_arguments=Dict{Symbol,Any}(),
+          time=nothing, timestep=nothing)

Visualize the plot data object provided in plot_data and display result, plotting only the variables in variable_names and, optionally, the mesh (if show_mesh is true). Additionally, plot_arguments will be unpacked and passed as keyword arguments to the Plots.plot command.

This function is the default plot_creator argument for the VisualizationCallback. time and timestep are currently unused by this function.

Experimental implementation

This is an experimental feature and may change in future releases.

See also: VisualizationCallback, save_plot

source
Trixi.solveFunction
solve(ode, alg; dt, callbacks, kwargs...)

The following structures and methods provide the infrastructure for SSP Runge-Kutta methods of type SimpleAlgorithmSSP.

Experimental implementation

This is an experimental feature and may change in future releases.

source
Trixi.source_terms_convergence_testMethod
source_terms_convergence_test(u, x, t, equations::ShallowWaterEquations2D)

Source terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).

This manufactured solution source term is specifically designed for the bottom topography function b(x,y) = 2 + 0.5 * sin(sqrt(2)*pi*x) + 0.5 * sin(sqrt(2)*pi*y) as defined in initial_condition_convergence_test.

source
Trixi.source_terms_convergence_testMethod
source_terms_convergence_test(u, x, t, equations::ShallowWaterEquationsQuasi1D)

Source terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).

This manufactured solution source term is specifically designed for the bottom topography function b(x) = 0.2 - 0.05 * sin(sqrt(2) * pi *x[1]) and channel width 'a(x)= 1 + 0.1 * cos(sqrt(2) * pi * x[1])' as defined in initial_condition_convergence_test.

source
Trixi.source_terms_eoc_test_coupled_euler_gravityMethod
source_terms_eoc_test_coupled_euler_gravity(u, x, t, equations::CompressibleEulerEquations2D)

Setup used for convergence tests of the Euler equations with self-gravity used in

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593

in combination with initial_condition_eoc_test_coupled_euler_gravity.

source
Trixi.source_terms_eoc_test_coupled_euler_gravityMethod
source_terms_eoc_test_coupled_euler_gravity(u, x, t, equations::CompressibleEulerEquations3D)

Setup used for convergence tests of the Euler equations with self-gravity used in

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593

in combination with initial_condition_eoc_test_coupled_euler_gravity.

source
Trixi.source_terms_eoc_test_eulerMethod
source_terms_eoc_test_euler(u, x, t, equations::CompressibleEulerEquations3D)

Setup used for convergence tests of the Euler equations with self-gravity used in

  • Michael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593

in combination with initial_condition_eoc_test_coupled_euler_gravity.

Note

This method is to be used for testing pure Euler simulations with analytic self-gravity. If you intend to do coupled Euler-gravity simulations, you need to use source_terms_eoc_test_coupled_euler_gravity instead.

source
Trixi.source_terms_harmonicMethod
source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations1D)

Source term that only includes the forcing from the hyperbolic diffusion system.

source
Trixi.source_terms_harmonicMethod
source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations2D)

Source term that only includes the forcing from the hyperbolic diffusion system.

source
Trixi.source_terms_harmonicMethod
source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations3D)

Source term that only includes the forcing from the hyperbolic diffusion system.

source
Trixi.splitting_coirier_vanleerMethod
splitting_coirier_vanleer(u, orientation::Integer,
+                          equations::CompressibleEulerEquations1D)
+splitting_coirier_vanleer(u, which::Union{Val{:minus}, Val{:plus}}
+                          orientation::Integer,
+                          equations::CompressibleEulerEquations1D)

Splitting of the compressible Euler flux from Coirier and van Leer. The splitting has correction terms in the pressure splitting as well as the mass and energy flux components. The motivation for these corrections are to handle flows at the low Mach number limit.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

  • William Coirier and Bram van Leer (1991) Numerical flux formulas for the Euler and Navier-Stokes equations. II - Progress in flux-vector splitting DOI: 10.2514/6.1991-1566
source
Trixi.splitting_lax_friedrichsMethod
splitting_lax_friedrichs(u, orientation::Integer,
+                         equations::CompressibleEulerEquations2D)
+splitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations2D)

Naive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) similar to a flux splitting one would apply, e.g., to Burgers' equation.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.splitting_lax_friedrichsMethod
splitting_lax_friedrichs(u, orientation::Integer,
+                         equations::InviscidBurgersEquation1D)
+splitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::InviscidBurgersEquation1D)

Naive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) where λ = abs(u).

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.splitting_lax_friedrichsMethod
splitting_lax_friedrichs(u, orientation::Integer,
+                         equations::LinearScalarAdvectionEquation1D)
+splitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::LinearScalarAdvectionEquation1D)

Naive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) where λ is the absolute value of the advection velocity.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

source
Trixi.splitting_steger_warmingMethod
splitting_steger_warming(u, orientation::Integer,
+                         equations::CompressibleEulerEquations1D)
+splitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations1D)

Splitting of the compressible Euler flux of Steger and Warming.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

  • Joseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum
source
Trixi.splitting_steger_warmingMethod
splitting_steger_warming(u, orientation::Integer,
+                         equations::CompressibleEulerEquations2D)
+splitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations2D)

Splitting of the compressible Euler flux of Steger and Warming.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

  • Joseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum
source
Trixi.splitting_steger_warmingMethod
splitting_steger_warming(u, orientation::Integer,
+                         equations::CompressibleEulerEquations3D)
+splitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations3D)

Splitting of the compressible Euler flux of Steger and Warming.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

  • Joseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum
source
Trixi.splitting_vanleer_haenelMethod
splitting_vanleer_haenel(u, orientation::Integer,
+                         equations::CompressibleEulerEquations1D)
+splitting_vanleer_haenel(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations1D)

Splitting of the compressible Euler flux from van Leer. This splitting further contains a reformulation due to Hänel et al. where the energy flux uses the enthalpy. The pressure splitting is independent from the splitting of the convective terms. As such there are many pressure splittings suggested across the literature. We implement the 'p4' variant suggested by Liou and Steffen as it proved the most robust in practice.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

source
Trixi.splitting_vanleer_haenelMethod
splitting_vanleer_haenel(u, orientation::Integer,
+                         equations::CompressibleEulerEquations2D)
+splitting_vanleer_haenel(u, which::Union{Val{:minus}, Val{:plus}}
+                         orientation::Integer,
+                         equations::CompressibleEulerEquations2D)

Splitting of the compressible Euler flux from van Leer. This splitting further contains a reformulation due to Hänel et al. where the energy flux uses the enthalpy. The pressure splitting is independent from the splitting of the convective terms. As such there are many pressure splittings suggested across the literature. We implement the 'p4' variant suggested by Liou and Steffen as it proved the most robust in practice.

Returns a tuple of the fluxes "minus" (associated with waves going into the negative axis direction) and "plus" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().

Experimental implementation (upwind SBP)

This is an experimental feature and may change in future releases.

References

source
Trixi.stolarsky_meanMethod
stolarsky_mean(x, y, gamma)

Compute an instance of a weighted Stolarsky mean of the form

stolarsky_mean(x, y, gamma) = (gamma - 1)/gamma * (y^gamma - x^gamma) / (y^(gamma-1) - x^(gamma-1))

where gamma > 1.

Problem: The formula above has a removable singularity at x == y. Thus, some care must be taken to implement it correctly without problems or loss of accuracy when x ≈ y. Here, we use the approach proposed by Winters et al. (2020). Set f = (y - x) / (y + x) and g = gamma (for compact notation). Then, we use the expansions

((1+f)^g - (1-f)^g) / g = 2*f + (g-1)(g-2)/3 * f^3 + (g-1)(g-2)(g-3)(g-4)/60 * f^5 + O(f^7)

and

((1+f)^(g-1) - (1-f)^(g-1)) / (g-1) = 2*f + (g-2)(g-3)/3 * f^3 + (g-2)(g-3)(g-4)(g-5)/60 * f^5 + O(f^7)

Inserting the first few terms of these expansions and performing polynomial long division we find that

stolarsky_mean(x, y, gamma) ≈ (y + x) / 2 * (1 + (g-2)/3 * f^2 - (g+1)(g-2)(g-3)/45 * f^4 + (g+1)(g-2)(g-3)(2g(g-2)-9)/945 * f^6)

Since divisions are usually more expensive on modern hardware than multiplications (Agner Fog), we try to avoid computing two divisions. Thus, we use

f^2 = (y - x)^2 / (x + y)^2
+    = (x * (x - 2 * y) + y * y) / (x * (x + 2 * y) + y * y)

Given ε = 1.0e-4, we use the following algorithm.

if f^2 < ε
+  # use the expansion above
+else
+  # use the direct formula (gamma - 1)/gamma * (y^gamma - x^gamma) / (y^(gamma-1) - x^(gamma-1))
+end

References

source
Trixi.totalgammaMethod
totalgamma(u, equations::CompressibleEulerMulticomponentEquations1D)

Function that calculates the total gamma out of all partial gammas using the partial density fractions as well as the partial specific heats at constant volume.

source
Trixi.totalgammaMethod
totalgamma(u, equations::CompressibleEulerMulticomponentEquations2D)

Function that calculates the total gamma out of all partial gammas using the partial density fractions as well as the partial specific heats at constant volume.

source
Trixi.trixi_includeMethod
trixi_include([mod::Module=Main,] elixir::AbstractString; kwargs...)

include the file elixir and evaluate its content in the global scope of module mod. You can override specific assignments in elixir by supplying keyword arguments. It's basic purpose is to make it easier to modify some parameters while running Trixi.jl from the REPL. Additionally, this is used in tests to reduce the computational burden for CI while still providing examples with sensible default values for users.

Before replacing assignments in elixir, the keyword argument maxiters is inserted into calls to solve and Trixi.solve with it's default value used in the SciML ecosystem for ODEs, see the "Miscellaneous" section of the documentation.

Examples

julia> redirect_stdout(devnull) do
+         trixi_include(@__MODULE__, joinpath(examples_dir(), "tree_1d_dgsem", "elixir_advection_extended.jl"),
+                       tspan=(0.0, 0.1))
+         sol.t[end]
+       end
+[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.
+0.1
source
Trixi.varnamesFunction
varnames(conversion_function, equations)

Return the list of variable names when applying conversion_function to the conserved variables associated to equations. This function is mainly used internally to determine output to screen and for IO, e.g., for the AnalysisCallback and the SaveSolutionCallback. Common choices of the conversion_function are cons2cons and cons2prim.

source
Trixi.velocityMethod
velocity(u, orientation, equations::LatticeBoltzmannEquations2D)

Calculate the macroscopic velocity for the given orientation (1 -> x, 2 -> y) from the particle distribution functions u.

source
Trixi.velocityMethod
velocity(u, orientation, equations::LatticeBoltzmannEquations3D)

Calculate the macroscopic velocity for the given orientation (1 -> x, 2 -> y, 3 -> z) from the particle distribution functions u.

source
Trixi.velocityMethod
velocity(u, equations::LatticeBoltzmannEquations2D)

Calculate the macroscopic velocity vector from the particle distribution functions u.

source
Trixi.velocityMethod
velocity(u, equations::LatticeBoltzmannEquations3D)

Calculate the macroscopic velocity vector from the particle distribution functions u.

source
Trixi.@autoinfiltrateMacro
@autoinfiltrate
+@autoinfiltrate condition::Bool

Invoke the @infiltrate macro of the package Infiltrator.jl to create a breakpoint for ad-hoc interactive debugging in the REPL. If the optional argument condition is given, the breakpoint is only enabled if condition evaluates to true.

As opposed to using Infiltrator.@infiltrate directly, this macro does not require Infiltrator.jl to be added as a dependency to Trixi.jl. As a bonus, the macro will also attempt to load the Infiltrator module if it has not yet been loaded manually.

Note: For this macro to work, the Infiltrator.jl package needs to be installed in your current Julia environment stack.

See also: Infiltrator.jl

Internal use only

Please note that this macro is intended for internal use only. It is not part of the public API of Trixi.jl, and it thus can altered (or be removed) at any time without it being considered a breaking change.

source
Trixi.@threadedMacro
@threaded for ... end

Semantically the same as Threads.@threads when iterating over a AbstractUnitRange but without guarantee that the underlying implementation uses Threads.@threads or works for more general for loops. In particular, there may be an additional check whether only one thread is used to reduce the overhead of serial execution or the underlying threading capabilities might be provided by other packages such as Polyester.jl.

Warn

This macro does not necessarily work for general for loops. For example, it does not necessarily support general iterables such as eachline(filename).

Some discussion can be found at https://discourse.julialang.org/t/overhead-of-threads-threads/53964 and https://discourse.julialang.org/t/threads-threads-with-one-thread-how-to-remove-the-overhead/58435.

source
diff --git a/previews/PR1697/reference-trixi2vtk/index.html b/previews/PR1697/reference-trixi2vtk/index.html new file mode 100644 index 00000000000..214b7b752f9 --- /dev/null +++ b/previews/PR1697/reference-trixi2vtk/index.html @@ -0,0 +1,6 @@ + +Trixi2Vtk.jl · Trixi.jl

Trixi2Vtk.jl API

Trixi2Vtk.trixi2vtkMethod
trixi2vtk(filename::AbstractString...;
+          format=:vtu, verbose=false, hide_progress=false, pvd=nothing,
+          output_directory=".", nvisnodes=nothing, save_celldata=true,
+          reinterpolate=true, data_is_uniform=false)

Convert Trixi-generated output files to VTK files (VTU or VTI).

Arguments

  • filename: One or more Trixi solution/restart/mesh files to convert to a VTK file. Filenames support file globbing, e.g., "solution*" to match all files starting with solution.
  • format: Output format for solution/restart files. Can be 'vtu' or 'vti'.
  • verbose: Set to true to enable verbose output.
  • hide_progress: Hide progress bar (will be hidden automatically if verbose is true).
  • pvd: Use this filename to store PVD file (instead of auto-detecting name). Note that only the name will be used (directory and file extension are ignored).
  • output_directory: Output directory where generated files are stored.
  • nvisnodes: Number of visualization nodes per element. (default: number of DG nodes for StructuredMesh or UnstructuredMesh2D, twice the number of DG nodes for TreeMesh). A value of 0 (zero) uses the number of nodes in the DG elements.
  • save_celldata: Boolean value to determine if cell-based data should be saved. (default: true)
  • reinterpolate: Boolean value to determine if data should be reinterpolated onto uniform points. When false the raw data at the compute nodes is copied into the appropriate format. (default: true)
  • data_is_uniform: Boolean to indicate if the data to be converted is from a finite difference method on a uniform grid of points. (default: false)

Examples

julia> trixi2vtk("out/solution_000*.h5")
+[...]
source
diff --git a/previews/PR1697/restart/index.html b/previews/PR1697/restart/index.html new file mode 100644 index 00000000000..1071dcaa80b --- /dev/null +++ b/previews/PR1697/restart/index.html @@ -0,0 +1,6 @@ + +Restart simulation · Trixi.jl

Restart simulation

You can continue running an already finished simulation by first preparing the simulation for the restart and then performing the restart. Here we suppose that in the first run your simulation stops at time 1.0 and then you want it to run further to time 2.0.

Prepare the simulation for a restart

In you original elixir you need to specify to write out restart files. Those will later be read for the restart of your simulation. This is done almost the same way as writing the snapshots using the SaveSolutionCallback callback. For the restart files it is called SaveRestartCallback:

save_restart = SaveRestartCallback(interval=100,
+                                   save_final_restart=true)

Make this part of your CallbackSet.

An example is examples/examples/structured_2d_dgsem/elixir_advection_extended.jl.

Perform the simulation restart

Since all of the information about the simulation can be obtained from the last snapshot, the restart can be done with relatively few lines in an extra elixir file. However, some might prefer to keep everything in one elixir and conditionals like if restart with a boolean variable restart that is user defined.

First we need to define from which file we want to restart, e.g.

restart_file = "restart_000021.h5"
+restart_filename = joinpath("out", restart_file)

Then we load the mesh file:

mesh = load_mesh(restart_filename)

This is then needed for the semidiscretization:

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

We then define a new time span for the simulation that takes as starting time the one form the snapshot:

tspan = (load_time(restart_filename), 2.0)

We now also take the last dt, so that our solver does not need to first find one to fulfill the CFL condition:

dt = load_dt(restart_filename)

The ODE that we will pass to the solver is now:

ode = semidiscretize(semi, tspan, restart_filename)

You should now define a SaveSolutionCallback similar to the original simulation, but with save_initial_solution=false, otherwise our initial snapshot will be overwritten. If you are using one file for the original simulation and the restart you can reuse your SaveSolutionCallback, but need to set

save_solution.condition.save_initial_solution = false

Before we compute the solution using OrdinaryDiffEq.jl we need to set the integrator and its time step number, e.g.:

integrator = init(ode, CarpenterKennedy2N54(williamson_condition=false),
+                  dt=dt, save_everystep=false, callback=callbacks);
+load_timestep!(integrator, restart_filename)

Now we can compute the solution:

sol = solve!(integrator)

An example is in examples/structured_2d_dgsem/elixir_advection_restart.jl.

diff --git a/previews/PR1697/search_index.js b/previews/PR1697/search_index.js new file mode 100644 index 00000000000..f47ab77b3bc --- /dev/null +++ b/previews/PR1697/search_index.js @@ -0,0 +1,3 @@ +var documenterSearchIndex = {"docs": +[{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"EditURL = \"../../literate/src/files/adaptive_mesh_refinement.jl\"","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#adaptive_mesh_refinement","page":"12 Adaptive mesh refinement","title":"12: Adaptive mesh refinement","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Adaptive mesh refinement (AMR) is a method of adapting the resolution of the numerical method to the solution features such as turbulent regions or shocks. In those critical regions of the domain, we want the simulation to use elements with smaller mesh sizes compared to other regions. This should be automatically and dynamically adapted during the run of the simulation.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Implementation-in-Trixi.jl","page":"12 Adaptive mesh refinement","title":"Implementation in Trixi.jl","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"In Trixi.jl, AMR is possible for the mesh types TreeMesh and P4estMesh. Both meshes are organized in a tree structure and therefore, each element can be refined independently. In Trixi.jl, AMR is restricted to a 2:1 refinement ratio between neighbor elements. This means that the maximum resolution difference of neighboring elements is a factor of two.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"The implementation of AMR is divided into different steps. The basic refinement setting contains an indicator and a controller. These are added to the simulation by using an AMR callback.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Indicators","page":"12 Adaptive mesh refinement","title":"Indicators","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"An indicator estimates the current accuracy of the numerical approximation. It indicates which regions of the domain need finer or coarser resolutions. In Trixi.jl, you can use for instance IndicatorLöhner and IndicatorHennemannGassner.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"IndicatorLöhner (also callable with IndicatorLoehner) is an interpretation and adaptation of a FEM indicator by Löhner (1987) and estimates a weighted second derivative of a specified variable locally.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_indicator = IndicatorLöhner(semi, variable=variable)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"All indicators have the parameter variable which is used to specify the variable for the indicator calculation. You can use for instance density, pressure or density_pressure for the compressible Euler equations. Moreover, you have the option to use simply the first conservation variable with first for any equations. This might be a good choice for a starting example.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"IndicatorHennemannGassner, also used as a shock-capturing indicator, was developed by Hennemann et al. (2021) and is explained in detail in the tutorial about shock-capturing. It can be constructed as follows.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_indicator = IndicatorHennemannGassner(semi,\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable=variable)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Another indicator is the very basic IndicatorMax. It indicates the maximal value of a variable and is therefore mostly used for verification and testing. But it might be useful for the basic understanding of the implementation of indicators and AMR in Trixi.jl.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_indicator = IndicatorMax(semi, variable=variable)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Controllers","page":"12 Adaptive mesh refinement","title":"Controllers","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"The spatial discretization into elements is tree-based for both AMR supporting mesh types TreeMesh and P4estMesh. Thus, the higher the level in the tree the higher the level of refinement. For instance, a mesh element of level 3 has double resolution in each direction compared to another element with level 2.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"To map specific indicator values to a desired level of refinement, Trixi.jl uses controllers. They are build in three levels: There is a base level of refinement base_level, which is the minimum allowed refinement level. Then, there is a medium level med_level, which corresponds to the initial level of refinement, for indicator values above the threshold med_threshold and equally, a maximal level max_level for values above max_threshold. This variant of controller is called ControllerThreeLevel in Trixi.jl.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_controller = ControllerThreeLevel(semi, amr_indicator;\n base_level=4,\n med_level=5, med_threshold=0.1,\n max_level=6, max_threshold=0.6)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"You can also set med_level=0 to use the current level as target, see the docstring of ControllerThreeLevel.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"An extension is ControllerThreeLevelCombined, which uses two different indicators. The primary indicator works the same as the single indicator for ControllerThreeLevel. The second indicator with its own maximum threshold adds the property, that the target level is set to max_level additionally if this indicator's value is greater than max_threshold_secondary. This is for instance used to assure that a shock has always the maximum refinement level.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_controller = ControllerThreeLevelCombined(semi, indicator_primary, indicator_secondary;\n base_level=2,\n med_level=6, med_threshold=0.0003,\n max_level=8, max_threshold=0.003,\n max_threshold_secondary=0.3)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"This controller is for instance used in elixir_euler_astro_jet_amr.jl.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Callback","page":"12 Adaptive mesh refinement","title":"Callback","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"The AMR indicator and controller are added to the simulation through the callback AMRCallback. It contains a semidiscretization semi, the controller amr_controller and the parameters interval, adapt_initial_condition, and adapt_initial_condition_only_refine.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Adaptive mesh refinement will be performed every interval time steps. adapt_initial_condition indicates whether the initial condition already should be adapted before the first time step. And with adapt_initial_condition_only_refine=true the mesh is only refined at the beginning but not coarsened.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_callback = AMRCallback(semi, amr_controller,\n interval=5,\n adapt_initial_condition=true,\n adapt_initial_condition_only_refine=true)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Exemplary-simulation","page":"12 Adaptive mesh refinement","title":"Exemplary simulation","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Here, we want to implement a simple AMR simulation of the 2D linear advection equation for a Gaussian pulse.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"using OrdinaryDiffEq\nusing Trixi\n\nadvection_velocity = (0.2, -0.7)\nequations = LinearScalarAdvectionEquation2D(advection_velocity)\n\ninitial_condition = initial_condition_gauss\nsolver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n\ncoordinates_min = (-5.0, -5.0)\ncoordinates_max = ( 5.0, 5.0)\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4,\n n_cells_max=30_000)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n\n\ntspan = (0.0, 10.0)\node = semidiscretize(semi, tspan);\nnothing #hide","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"For the best understanding about indicators and controllers, we use the simple AMR indicator IndicatorMax. As described before, it returns the maximal value of the specified variable (here the only conserved variable). Therefore, regions with a high maximum are refined. This is not really useful numerical application, but a nice demonstration example.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_indicator = IndicatorMax(semi, variable=first)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"These values are transferred to a refinement level with the ControllerThreeLevel, such that every element with maximal value greater than 0.1 is refined once and elements with maximum above 0.6 are refined twice.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"amr_controller = ControllerThreeLevel(semi, amr_indicator,\n base_level=4,\n med_level=5, med_threshold=0.1,\n max_level=6, max_threshold=0.6)\n\namr_callback = AMRCallback(semi, amr_controller,\n interval=5,\n adapt_initial_condition=true,\n adapt_initial_condition_only_refine=true)\n\nstepsize_callback = StepsizeCallback(cfl=0.9)\n\ncallbacks = CallbackSet(amr_callback, stepsize_callback);\nnothing #hide","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Running the simulation.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"We plot the solution and add the refined mesh at the end of the simulation.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"using Plots\npd = PlotData2D(sol)\nplot(pd)\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#More-examples","page":"12 Adaptive mesh refinement","title":"More examples","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Trixi.jl provides many elixirs using AMR. We want to give some examples for different mesh types:","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"elixir_euler_blast_wave_amr.jl for TreeMesh and P4estMesh\nelixir_euler_kelvin_helmholtz_instability_amr.jl for TreeMesh\nelixir_euler_double_mach_amr.jl for P4estMesh","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Animations of more interesting and complicated AMR simulations can be found below and on Trixi.jl's youtube channel \"Trixi Framework\".","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"First, we give a purely hyperbolic simulation of a Sedov blast wave with self-gravity. This simulation uses the mesh type TreeMesh as we did and the AMR indicator IndicatorHennemannGassner.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":" \n
","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Source: Trixi.jl's YouTube channel Trixi Framework","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"The next example is a numerical simulation of an ideal MHD rotor on an unstructured AMR mesh. The used mesh type is a P4estMesh.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":" \n
","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"Source: Trixi.jl's YouTube channel Trixi Framework","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"For more information, please have a look at the respective links.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/#Package-versions","page":"12 Adaptive mesh refinement","title":"Package versions","text":"","category":"section"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"","category":"page"},{"location":"tutorials/adaptive_mesh_refinement/","page":"12 Adaptive mesh refinement","title":"12 Adaptive mesh refinement","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"EditURL = \"../../literate/src/files/structured_mesh_mapping.jl\"","category":"page"},{"location":"tutorials/structured_mesh_mapping/#structured_mesh_mapping","page":"13 Structured mesh with curvilinear mapping","title":"13: Structured mesh with curvilinear mapping","text":"","category":"section"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Here, we want to introduce another mesh type of Trixi.jl. More precisely, this tutorial is about the curved mesh type StructuredMesh supporting curved meshes.","category":"page"},{"location":"tutorials/structured_mesh_mapping/#Creating-a-curved-mesh","page":"13 Structured mesh with curvilinear mapping","title":"Creating a curved mesh","text":"","category":"section"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"There are two basic options to define a curved StructuredMesh in Trixi.jl. You can implement curves for the domain boundaries, or alternatively, set up directly the complete transformation mapping. We now present one short example each.","category":"page"},{"location":"tutorials/structured_mesh_mapping/#Mesh-defined-by-domain-boundary-curves","page":"13 Structured mesh with curvilinear mapping","title":"Mesh defined by domain boundary curves","text":"","category":"section"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Both examples are based on a semdiscretization of the 2D compressible Euler equations.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"using OrdinaryDiffEq\nusing Trixi\n\nequations = CompressibleEulerEquations2D(1.4)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"We start with a pressure perturbation at (xs, 0.0) as initial condition.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"function initial_condition_pressure_perturbation(x, t, equations::CompressibleEulerEquations2D)\n xs = 1.5 # location of the initial disturbance on the x axis\n w = 1/8 # half width\n p = exp(-log(2) * ((x[1]-xs)^2 + x[2]^2)/w^2) + 1.0\n v1 = 0.0\n v2 = 0.0\n rho = 1.0\n\n return prim2cons(SVector(rho, v1, v2, p), equations)\nend\ninitial_condition = initial_condition_pressure_perturbation","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Initialize every boundary as a boundary_condition_slip_wall.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"boundary_conditions = boundary_condition_slip_wall","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"The approximation setup is an entropy-stable split-form DG method with polydeg=4. We are using the two fluxes flux_ranocha and flux_lax_friedrichs.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"solver = DGSEM(polydeg=4, surface_flux=flux_lax_friedrichs,\n volume_integral=VolumeIntegralFluxDifferencing(flux_ranocha))","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"We want to define a circular cylinder as physical domain. It contains an inner semicircle with radius r0 and an outer semicircle of radius r1.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"(Image: )","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"The domain boundary curves with curve parameter in -11 are sorted as shown in the sketch. They always are orientated from negative to positive coordinate, such that the corners have to fit like this f_1(+1) = f_4(-1), f_3(+1) = f_2(-1), etc.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"In our case we can define the domain boundary curves as follows:","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"r0 = 0.5 # inner radius\nr1 = 5.0 # outer radius\nf1(xi) = SVector( r0 + 0.5 * (r1 - r0) * (xi + 1), 0.0) # right line\nf2(xi) = SVector(-r0 - 0.5 * (r1 - r0) * (xi + 1), 0.0) # left line\nf3(eta) = SVector(r0 * cos(0.5 * pi * (eta + 1)), r0 * sin(0.5 * pi * (eta + 1))) # inner circle\nf4(eta) = SVector(r1 * cos(0.5 * pi * (eta + 1)), r1 * sin(0.5 * pi * (eta + 1))) # outer circle","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"We create a curved mesh with 16 x 16 elements. The defined domain boundary curves are passed as a tuple.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"cells_per_dimension = (16, 16)\nmesh = StructuredMesh(cells_per_dimension, (f1, f2, f3, f4), periodicity=false)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Then, we define the simulation with endtime T=3 with semi, ode and callbacks.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n boundary_conditions=boundary_conditions)\n\ntspan = (0.0, 3.0)\node = semidiscretize(semi, tspan)\n\nanalysis_interval = 100\nanalysis_callback = AnalysisCallback(semi, interval=analysis_interval)\n\nalive_callback = AliveCallback(analysis_interval=analysis_interval)\n\nstepsize_callback = StepsizeCallback(cfl=0.9)\n\ncallbacks = CallbackSet(analysis_callback,\n alive_callback,\n stepsize_callback);\nnothing #hide","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Running the simulation","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, callback=callbacks);\n\nusing Plots\nplot(sol)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"pd = PlotData2D(sol)\nplot(pd[\"p\"])\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/structured_mesh_mapping/#Mesh-directly-defined-by-the-transformation-mapping","page":"13 Structured mesh with curvilinear mapping","title":"Mesh directly defined by the transformation mapping","text":"","category":"section"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"As mentioned before, you can also define the domain for a StructuredMesh by directly setting up a transformation mapping. Here, we want to present a nice mapping, which is often used to test free-stream preservation. Exact free-stream preservation is a crucial property of any numerical method on curvilinear grids. The mapping is a reduced 2D version of the mapping described in Rueda-Ramírez et al. (2021), p.18.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"using OrdinaryDiffEq\nusing Trixi\n\nequations = CompressibleEulerEquations2D(1.4)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"As mentioned, this mapping is used for testing free-stream preservation. So, we use a constant initial condition.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"initial_condition = initial_condition_constant\n\nsolver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"We define the transformation mapping with variables in -1 1 as described in Rueda-Ramírez et al. (2021), p.18 (reduced to 2D):","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"function mapping(xi_, eta_)\n # Transform input variables between -1 and 1 onto [0,3]\n xi = 1.5 * xi_ + 1.5\n eta = 1.5 * eta_ + 1.5\n\n y = eta + 3/8 * (cos(1.5 * pi * (2 * xi - 3)/3) *\n cos(0.5 * pi * (2 * eta - 3)/3))\n\n x = xi + 3/8 * (cos(0.5 * pi * (2 * xi - 3)/3) *\n cos(2 * pi * (2 * y - 3)/3))\n\n return SVector(x, y)\nend","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Instead of a tuple of boundary functions, the mesh now has the mapping as its parameter.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"cells_per_dimension = (16, 16)\nmesh = StructuredMesh(cells_per_dimension, mapping)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n\ntspan = (0.0, 1.0)\node = semidiscretize(semi, tspan)\n\nanalysis_callback = AnalysisCallback(semi, interval=250)\n\nstepsize_callback = StepsizeCallback(cfl=0.8)\n\ncallbacks = CallbackSet(analysis_callback,\n stepsize_callback)\n\nsol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Now, we want to verify the free-stream preservation property and plot the mesh. For the verification, we calculate the absolute difference of the first conservation variable density u[1] and 1.0. To plot this error and the mesh, we are using the visualization feature ScalarPlotData2D, explained in visualization.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"error_density = let u = Trixi.wrap_array(sol.u[end], semi)\n abs.(u[1, :, :, :] .- 1.0) # density, x, y, elements\nend\npd = ScalarPlotData2D(error_density, semi)\n\nusing Plots\nplot(pd, title=\"Error in density\")\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"We observe that the errors in the variable density are at the level of machine accuracy. Moreover, the plot shows the mesh structure resulting from our transformation mapping.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"Of course, you can also use other mappings as for instance shifts by (x y)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"mapping(xi, eta) = SVector(xi + x, eta + y)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"or rotations with a rotation matrix T","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"mapping(xi, eta) = T * SVector(xi, eta).","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"For more curved mesh mappings, please have a look at some elixirs for StructuredMesh. For another curved mesh type, there is a tutorial about Trixi.jl's unstructured mesh type [UnstructuredMesh2D] and its use of the High-Order Hex-Quad Mesh (HOHQMesh) generator, created and developed by David Kopriva.","category":"page"},{"location":"tutorials/structured_mesh_mapping/#Package-versions","page":"13 Structured mesh with curvilinear mapping","title":"Package versions","text":"","category":"section"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"","category":"page"},{"location":"tutorials/structured_mesh_mapping/","page":"13 Structured mesh with curvilinear mapping","title":"13 Structured mesh with curvilinear mapping","text":"This page was generated using Literate.jl.","category":"page"},{"location":"github-git/#GitHub-and-Git","page":"GitHub & Git","title":"GitHub & Git","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"This page contains information on how to use GitHub and Git when developing Trixi.jl.","category":"page"},{"location":"github-git/#Development-workflow","page":"GitHub & Git","title":"Development workflow","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"For adding modifications to Trixi.jl, we generally follow these steps:","category":"page"},{"location":"github-git/#Create-an-issue-(optional)","page":"GitHub & Git","title":"Create an issue (optional)","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"In many cases it makes sense to start by creating an issue on GitHub. For example, if the implementation approach for a new feature is not yet clear or if there should be a discussion about the desired outcome, it is good practice to first get a consensus on what is the expected result of this modification. A GitHub issue is the place to lead this discussion, as it preserves it in the project and - together with the actual code changes - allows in the future to revisit the reasons for a particular choice of implementation or feature.","category":"page"},{"location":"github-git/#Create-a-branch-and-*immediately*-create-a-pull-request","page":"GitHub & Git","title":"Create a branch and immediately create a pull request","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"All feature development, bug fixes etc. should be developed in a branch and not directly on main. If you do not have write access to the main repository on GitHub, first create a fork of the Trixi.jl repository and clone the fork to your machine. Then, create a branch locally by executing git checkout -b yourbranch, push it to the repository, and create a pull request (PR).","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"If you have already cloned Trixi.jl from the main repo to your local machine, you can also work in that clone. You just need to add your fork as additional remote repository and push your new branch there.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"git remote add myfork git@github.com:YOUR_NAME/Trixi.jl.git\n# get latest main from the main repo\ngit checkout main\ngit pull\n# create a new branch for a cool new feature, bug fix, ...\ngit checkout -b YOUR_BRANCH_NAME\n# do some work and push it to your fork\ngit push -u myfork\n# go to https://github.com/trixi-framework/Trixi.jl/pull\n# and create a PR from your new branch","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"info: Why using pull requests?\nImmediately creating a PR for your branch has the benefit that all code discussions can now be held directly next to the corresponding code. Also, the PR allows to easily compare your branch to the upstream branch (usually main) to see what you have changed. Moreover, tests will run automatically.","category":"page"},{"location":"github-git/#Make-changes","page":"GitHub & Git","title":"Make changes","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"With a branch and PR in place, you can now write your code and commit it to your branch. If you request feedback from someone else, make sure to push your branch to the repository such that the others can easily review your changes or dive in and change something themselves.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"warning: Avoid committing unwanted files\nWhen you use git add . or similar catch-all versions, make sure you do not accidentally commit unwanted files (e.g., Trixi.jl output files, images or videos etc.). If it happens anyways, you can undo the last commit (also multiple times) by running git reset HEAD~ (see also Undo last commit). However, this strategy only works if you have not yet pushed your changes. If you did push your changes, please talk to one of the core developers on how to proceed.","category":"page"},{"location":"github-git/#Keep-your-branch-in-sync-with-main","page":"GitHub & Git","title":"Keep your branch in sync with main","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"For larger features with longer-living branches, it may make sense to synchronize your branch with the current main, e.g., if there was a bug fix in main that is relevant for you. In this case, perform the following steps to merge the current main to your branch:","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Commit all your local changes to your branch and push it. This allows you to delete your clone in case you make a mistake and need to abort the merge.\nExecute git fetch to get the latest changes from the repository.\nMake sure you are in the correct branch by checking the output of git status or by running git checkout yourbranch.\nMerge main using git merge main. If there were no conflicts, hooray!, you are done. Otherwise you need to resolve your merge conflicts and commit the changes afterwards. A good guide for resolving merge conflicts can be found here.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"In general, always use git merge and not git rebase to get the latest changes from main. It is less error-prone and does not create problems on branches that are worked on collaboratively.","category":"page"},{"location":"github-git/#Prepare-for-review","page":"GitHub & Git","title":"Prepare for review","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"If you feel like your branch is ready to be merged to main, prepare it for review. That is, you should","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"merge the current main to your branch\nrun tests if available, but at least ensure that you did not accidentally change the results for one of the existing example elixirs\nproperly comment your code\ndelete old/unused code, especially commented lines (unless they contain helpful code, in which case you should add a comment on why you keep this around)\nremove debug statements\nadd a elixir_xxx.jl that uses your feature (only relevant for new features)\nmake sure your code formatting adheres to the Style guide\ndescribe changes in NEWS.md if appropriate","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"After you are confident that your branch is cleaned up properly, commit all changes and push them to the repository.","category":"page"},{"location":"github-git/#Get-reviewed","page":"GitHub & Git","title":"Get reviewed","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Ask one of the core developers to review your code. Sometimes this will be done directly, either face-to-face or via a video call. Other times a review will be conducted asynchronously, with the reviewer leaving comments and annotations. In some cases it will be necessary to do multiple rounds of reviews, especially if there are larger changes to be added. Just commit and push your changes to your branch, and the corresponding pull request will be updated automatically.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Please note that a review has nothing to do with the lack of experience of the person developing changes: We try to review all code before it gets added to main, even from the most experienced developers. This is good practice and helps to keep the error rate low while ensuring that the code is developed in a consistent fashion. Furthermore, do not take criticism of your code personally - we just try to keep Trixi.jl as accessible and easy to use for everyone.","category":"page"},{"location":"github-git/#Merge-branch","page":"GitHub & Git","title":"Merge branch","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Once your branch is reviewed and declared ready for merging by the reviewer, make sure that all the latest changes have been pushed. Then, one of the developers will merge your PR. If you are one of the developers, you can also go to the pull request page on GitHub and and click on Merge pull request. Voilà, you are done! Your branch will have been merged to main and the source branch will have been deleted in the GitHub repository (if you are not working in your own fork).","category":"page"},{"location":"github-git/#Update-your-working-copy","page":"GitHub & Git","title":"Update your working copy","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Once you have merged your branch by accepting the PR on GitHub, you should clean up your local working copy of the repository by performing the following steps:","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Update your clone by running git fetch.\nCheck out main using git checkout main.\nDelete merged branch locally with git branch -d yourbranch.\nRemove local references to deleted remote branch by executing git remote prune origin.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"You can now proceed with your next changes by starting again at the top.","category":"page"},{"location":"github-git/#Using-Git","page":"GitHub & Git","title":"Using Git","text":"","category":"section"},{"location":"github-git/#Resources-for-learning-Git","page":"GitHub & Git","title":"Resources for learning Git","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Here are a few resources for learning do use Git that at least one of us found helpful in the past (roughly ordered from novice to advanced to expert):","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Git Handbook by GitHub\nLearn Git Branching","category":"page"},{"location":"github-git/#Tips-and-tricks","page":"GitHub & Git","title":"Tips and tricks","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"This is an unordered collection of different tips and tricks that can be helpful while working with Git. As usual, your mileage might vary.","category":"page"},{"location":"github-git/#Undo-last-commit","page":"GitHub & Git","title":"Undo last commit","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"If you made a mistake in your last commit, e.g., by committing an unwanted file, you can undo the latest commit by running","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"git reset HEAD~","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"This only works if you have not yet pushed your branch to the GitHub repository. In this case, please talk to one of the core developers on how to proceed. Especially when you accidentally committed a large file (image, or video), please let us know as fast as possible, since the effort to fix the repository grows considerably over time.","category":"page"},{"location":"github-git/#Remove-large-file-from-repository","page":"GitHub & Git","title":"Remove large file from repository","text":"","category":"section"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"If a large file was accidentally committed and pushed to the Trixi.jl repository, please talk to one of the core developers as soon as possible so that they can fix it.","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"danger: Large files\nYou should never try to fix this yourself, as it potentially disrupts/destroys the work of others!","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Based on the instructions found here and here, the following steps need to be taken (as documented for GitLab in issue #33):","category":"page"},{"location":"github-git/","page":"GitHub & Git","title":"GitHub & Git","text":"Tell everyone to commit and push their changes to the repository.\nFix the branch in which the file was committed by removing it and committing the removal. This is especially important on main.\nPerform the following steps to clean up the Git repository:\ncd /tmp\n\n# Download bfg-1.13.0.jar from https://rtyley.github.io/bfg-repo-cleaner/\n\n# Get fresh clone of repo (so you can throw it away in case there is a problem)\ngit clone --mirror git@github.com:trixi-framework/Trixi.jl.git\n\n# Clean up repo of all files larger than 10M\njava -jar bfg-1.13.0.jar --strip-blobs-bigger-than 10M Trixi.jl.git\n\n# Enter repo\ncd Trixi.jl.git\n\n# Clean up reflog and force aggressive garbage collection\ngit reflog expire --expire=now --all && git gc --prune=now --aggressive\n\n# Push changes\ngit push\n\n# Delete clone\nrm -rf Trixi.jl.git\nTell everyone to clean up their local working copies by performing the following steps (also do this yourself):\n# Enter repo\ncd Trixi.jl\n\n# Get current changes\ngit fetch\n\n# Check out the fixed branch\ngit checkout branchname\n\n# IMPORTANT: Do a rebase instead of a pull!\ngit rebase\n\n# Clean reflog and force garbage collection\ngit reflog expire --expire=now --all && git gc --prune=now --aggressive\nIMPORTANT: You need to do a git rebase instead of a git pull when updating the fixed branch.","category":"page"},{"location":"testing/#Testing","page":"Testing","title":"Testing","text":"","category":"section"},{"location":"testing/","page":"Testing","title":"Testing","text":"During the development of Trixi.jl, we rely on continuous testing to ensure that modifications or new features do not break existing functionality or add other errors. In the main Trixi.jl repository (and the repositories for the visualization tool Trixi2Vtk), this is facilitated by GitHub Actions, which allows to run tests automatically upon certain events. When, how, and what is tested by GitHub Actions is controlled by the workflow file .github/workflows/ci.yml. In Trixi.jl and its related repositories, tests are triggered by","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"each git push to main and\neach git push to any pull request.","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"Besides checking functionality, we also analyse the Test coverage to ensure that we do not miss important parts during testing.","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"note: Test and coverage requirements\nBefore merging a pull request (PR) to main, we require thatthe code passes all functional tests\ncode coverage does not decrease.","category":"page"},{"location":"testing/#Testing-setup","page":"Testing","title":"Testing setup","text":"","category":"section"},{"location":"testing/","page":"Testing","title":"Testing","text":"The entry point for all testing is the file test/runtests.jl, which is run by the automated tests and which can be triggered manually by executing","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"julia> using Pkg; Pkg.test(\"Trixi\")","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"in the REPL. Since there already exist many tests, we have split them up into multiple files in the test directory to allow for faster testing of individual parts of the code. Thus in addition to performing all tests, you can also just include one of the files named test_xxx.jl to run only a specific subset, e.g.,","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"julia> # Run all 2D tests on the P4estMesh\n include(joinpath(\"test\", \"test_p4est_2d.jl\"))\n\njulia> # Run all 1D tests for the Euler equations on the TreeMesh\n include(joinpath(\"test\", \"test_tree_1d_euler.jl\"))","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"For the automated tests with GitHub Actions, we run multiple jobs in parallel to reduce the waiting time until all tests are finished. You can see the different components that are run as jobs by looking at the TRIXI_TEST variable in test/runtests.jl.","category":"page"},{"location":"testing/#Adding-new-tests","page":"Testing","title":"Adding new tests","text":"","category":"section"},{"location":"testing/","page":"Testing","title":"Testing","text":"We use Julia's built-in unit testing capabilities to configure tests. In general, newly added code must be covered by at least one test, and all new elixirs added to the examples/ directory must be used at least once during testing. New tests should be added to the corresponding test/test_xxx.jl file, e.g., a test involving the 3D linear advection equation on the TreeMesh would go into test/test_tree_3d_advection.jl. Please study one of the existing tests and stay consistent to the current style when creating new tests.","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"Since we want to test as much as possible, we have a lot of tests and frequently create new ones. Naturally, this increases the time to wait for all tests to pass with each novel feature added to Trixi.jl. Therefore, new tests should be as short as reasonably possible, i.e., without being too insensitive to pick up changes or errors in the code.","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"When you add new tests, please check whether all CI jobs still take approximately the same time. If the job where you added new tests takes much longer than everything else, please consider moving some tests from one job to another (or report this incident and ask the main developers for help).","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"note: Test duration\nAs a general rule, tests should last no more than 10 seconds when run with a single thread and after compilation (i.e., excluding the first run).","category":"page"},{"location":"testing/#Test-coverage","page":"Testing","title":"Test coverage","text":"","category":"section"},{"location":"testing/","page":"Testing","title":"Testing","text":"In addition to ensuring that the code produces the expected results, the automated tests also record the code coverage. The resulting coverage reports, i.e., which lines of code were executed by at least one test and are thus considered \"covered\" by testing, are automatically uploaded to Coveralls for easy analysis. Typically, you see a number of Coveralls results at the bottom of each pull request: One for each parallel job (see Testing setup), which can usually be ignored since they only cover parts of the code by definition, and a cumulative coverage result named coverage/coveralls. The \"Details\" link takes you to a detailed report on which lines of code are covered by tests, which ones are missed, and especially which new lines the pull requests adds to Trixi.jl's code base that are not yet covered by testing.","category":"page"},{"location":"testing/","page":"Testing","title":"Testing","text":"note: Coverage requirements\nIn general, we require pull requests to not decrease the overall test coverage percentage in main, with a hard lower bound of 97%.","category":"page"},{"location":"authors/#Authors","page":"Authors","title":"Authors","text":"","category":"section"},{"location":"authors/","page":"Authors","title":"Authors","text":"Trixi.jl's development is coordinated by a group of principal developers, who are also its main contributors and who can be contacted in case of questions about Trixi.jl. In addition, there are contributors who have provided substantial additions or modifications. Together, these two groups form \"The Trixi.jl Authors\" as mentioned under License.","category":"page"},{"location":"authors/#Principal-Developers","page":"Authors","title":"Principal Developers","text":"","category":"section"},{"location":"authors/","page":"Authors","title":"Authors","text":"Michael Schlottke-Lakemper, RWTH Aachen University/High-Performance Computing Center Stuttgart (HLRS), Germany\nGregor Gassner, University of Cologne, Germany\nHendrik Ranocha, Johannes Gutenberg University Mainz, Germany\nAndrew Winters, Linköping University, Sweden\nJesse Chan, Rice University, US","category":"page"},{"location":"authors/#Contributors","page":"Authors","title":"Contributors","text":"","category":"section"},{"location":"authors/","page":"Authors","title":"Authors","text":"The following people contributed major additions or modifications to Trixi.jl and are listed in alphabetical order:","category":"page"},{"location":"authors/","page":"Authors","title":"Authors","text":"Maximilian D. Bertrand\nBenjamin Bolm\nSimon Candelaresi\nJesse Chan\nLars Christmann\nChristof Czernik\nDaniel Doehring\nPatrick Ersing\nErik Faulhaber\nGregor Gassner\nLucas Gemein\nSven Goldberg\nJoshua Lampert\nJulia Odenthal\nSigrun Ortleb\nHendrik Ranocha\nAndrés M. Rueda-Ramírez\nFelipe Santillan\nMichael Schlottke-Lakemper\nToskan Theine\nAndrew Winters","category":"page"},{"location":"license/#License","page":"License","title":"License","text":"","category":"section"},{"location":"license/","page":"License","title":"License","text":"MIT LicenseCopyright (c) 2020-present The Trixi.jl Authors (see Authors)Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.","category":"page"},{"location":"restart/#restart","page":"Restart simulation","title":"Restart simulation","text":"","category":"section"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"You can continue running an already finished simulation by first preparing the simulation for the restart and then performing the restart. Here we suppose that in the first run your simulation stops at time 1.0 and then you want it to run further to time 2.0.","category":"page"},{"location":"restart/#restart_preparation","page":"Restart simulation","title":"Prepare the simulation for a restart","text":"","category":"section"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"In you original elixir you need to specify to write out restart files. Those will later be read for the restart of your simulation. This is done almost the same way as writing the snapshots using the SaveSolutionCallback callback. For the restart files it is called SaveRestartCallback:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"save_restart = SaveRestartCallback(interval=100,\n save_final_restart=true)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"Make this part of your CallbackSet.","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"An example is examples/examples/structured_2d_dgsem/elixir_advection_extended.jl.","category":"page"},{"location":"restart/#restart_perform","page":"Restart simulation","title":"Perform the simulation restart","text":"","category":"section"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"Since all of the information about the simulation can be obtained from the last snapshot, the restart can be done with relatively few lines in an extra elixir file. However, some might prefer to keep everything in one elixir and conditionals like if restart with a boolean variable restart that is user defined.","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"First we need to define from which file we want to restart, e.g.","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"restart_file = \"restart_000021.h5\"\nrestart_filename = joinpath(\"out\", restart_file)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"Then we load the mesh file:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"mesh = load_mesh(restart_filename)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"This is then needed for the semidiscretization:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"We then define a new time span for the simulation that takes as starting time the one form the snapshot:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"tspan = (load_time(restart_filename), 2.0)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"We now also take the last dt, so that our solver does not need to first find one to fulfill the CFL condition:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"dt = load_dt(restart_filename)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"The ODE that we will pass to the solver is now:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"ode = semidiscretize(semi, tspan, restart_filename)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"You should now define a SaveSolutionCallback similar to the original simulation, but with save_initial_solution=false, otherwise our initial snapshot will be overwritten. If you are using one file for the original simulation and the restart you can reuse your SaveSolutionCallback, but need to set","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"save_solution.condition.save_initial_solution = false","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"Before we compute the solution using OrdinaryDiffEq.jl we need to set the integrator and its time step number, e.g.:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"integrator = init(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=dt, save_everystep=false, callback=callbacks);\nload_timestep!(integrator, restart_filename)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"Now we can compute the solution:","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"sol = solve!(integrator)","category":"page"},{"location":"restart/","page":"Restart simulation","title":"Restart simulation","text":"An example is in examples/structured_2d_dgsem/elixir_advection_restart.jl.","category":"page"},{"location":"meshes/structured_mesh/#Structured-mesh","page":"Structured mesh","title":"Structured mesh","text":"","category":"section"},{"location":"meshes/structured_mesh/","page":"Structured mesh","title":"Structured mesh","text":"The StructuredMesh is a structured, curvilinear, conforming mesh type available for one-, two-, and three-dimensional simulations.","category":"page"},{"location":"meshes/structured_mesh/","page":"Structured mesh","title":"Structured mesh","text":"Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.","category":"page"},{"location":"development/#Development","page":"Development","title":"Development","text":"","category":"section"},{"location":"development/#interactive-use-of-julia","page":"Development","title":"Interactive use of Julia","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"When a Julia program is executed, Julia first loads and parses all code. Then, the just-in-time compiler has to compile all functions at their first use, which incurs an overhead each time a program is run. For proper packages and commands executed in the REPL (= \"return-eval-print loop\", which is what the Julia community calls the interactive command-line prompt that opens when executing julia without any files as arguments), however, the previously compiled functions are cached. Therefore, Trixi.jl should generally always be used interactively from the REPL without closing Julia during development, as it allows much faster turnaround times.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"If you naively run Trixi.jl from the REPL, you will not be able to change your Trixi.jl source files and then run the changed code without restarting the REPL, which destroys any potential benefits from caching. However, restarting Julia can be avoided by using the Revise.jl package, which tracks changed files and re-loads them automatically. Therefore, it is highly recommended to first install Revise with the following command in Julia: To enter the package REPL mode, press ] in the standard Julia REPL mode. Then, execute","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"(@v1.9) pkg> add Revise","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Now you are able to run Trixi.jl from the REPL, change Trixi.jl code between runs, and enjoy the advantages of the compilation cache! Before you start using Revise regularly, please be aware of some of the Pitfalls when using Revise.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Another recommended package for working from the REPL is OhMyREPL.jl. It can be installed by running","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"(@v1.9) pkg> add OhMyREPL","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"and adds syntax highlighting, bracket highlighting, and other helpful improvements for using Julia interactively. To automatically use OhMyREPL when starting the REPL, follow the instructions given in the official documentation.","category":"page"},{"location":"development/#Running-Trixi.jl-interactively-in-the-global-environment","page":"Development","title":"Running Trixi.jl interactively in the global environment","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"If you've installed Trixi.jl and Revise in your default environment, begin by executing:","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"This will start the Julia REPL. Then, run","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia> using Revise; using Trixi","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"You can run a simulation by executing","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia> trixi_include(default_example())","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Together, all of these commands can take some time, roughly half a minute on a modern workstation. Most of the time is spent on compilation of Julia code etc. If you execute the last command again in the same REPL, it will finish within a few milliseconds (maybe ~45 on a modern workstation). This demonstrates the second reason for using the REPL: the compilation cache. That is, those parts of the code that do not change between two Trixi.jl runs do not need to be recompiled and thus execute much faster after the first run.","category":"page"},{"location":"development/#Manually-starting-Trixi.jl-in-the-local-environment","page":"Development","title":"Manually starting Trixi.jl in the local environment","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"If you followed the installation instructions for developers, execute Julia with the project directory set to the run directory of the program/tool you want to use. For example, to run Trixi.jl this way, you need to start the REPL with","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia --project=path/to/Trixi.jl/run","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"and execute","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia> using Revise; using Trixi","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"to load Revise and Trixi.jl. You can then proceed with the usual commands and run Trixi.jl as in the example above. The --project flag is required such that Julia can properly load Trixi.jl and all dependencies if Trixi.jl is not installed in the global environment. The same procedure also applies should you opt to install the postprocessing tool Trixi2Vtk manually such that you can modify their implementations.","category":"page"},{"location":"development/#Pitfalls-when-using-Revise","page":"Development","title":"Pitfalls when using Revise","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"While Revise is a great help for developing Julia code, there are a few situations to watch out for when using Revise. The following list of potential issues is based on personal experiences of the Trixi.jl developers and probably incomplete. Further information on limitations and possible issues with Revise can be found in the official documentation.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"tip: If in doubt, restart the REPL\nOftentimes, it is possible to recover from issues with Revise by fixing the offending code. Sometimes, however, this is not possible or you might have troubles finding out what exactly caused the problems. Therefore, in these cases, or if in doubt, restart the REPL to get a fresh start.","category":"page"},{"location":"development/#Syntax-errors-are-easy-to-miss","page":"Development","title":"Syntax errors are easy to miss","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Revise does not stop on syntax errors, e.g., when you accidentally write a[i) instead of a[i]. In this case, Revise reports an error but continues to use the old version of your files! This is especially dangerous for syntax errors, as they are detected while Revise reloads changed code, which happens in the beginning of a new execution. Thus, the syntax error message quickly disappears from the terminal once Trixi.jl starts writing output to the screen and you might not even have noticed that an error occurred at all.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Therefore, when you are deep in a coding/debugging session and wonder why your code modifications do not seem to have any effect, scroll up in your terminal to check if you missed earlier syntax errors, or - if in doubt - restart your REPL.","category":"page"},{"location":"development/#Files-are-not-tracked-after-changing-branches","page":"Development","title":"Files are not tracked after changing branches","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Sometimes, Revise stops tracking files when changing the Git branch. That is, modifications to Trixi.jl's source files will not be reloaded by Revise and thus have no effect of a currently running REPL session. This issue is particularly annoying for a developer, since it does not come with any warning! Therefore, it is good practice to always restart the REPL after changing branches.","category":"page"},{"location":"development/#Changes-to-type-definitions-are-not-allowed","page":"Development","title":"Changes to type definitions are not allowed","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Revise cannot handle changes to type definitions, e.g., when modifying the fields in a struct. In this case, Revise reports an error and refuses to run your code unless you undo the modifications. Once you undo the changes, Revise will usually continue to work as expected again. However, if you want to keep your type modifications, you need to restart the REPL.","category":"page"},{"location":"development/#Using-the-Julia-REPL-effectively","page":"Development","title":"Using the Julia REPL effectively","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"The Julia manual is an excellent resource to learn Julia. Here, we list some helpful commands than can increase your productivity in the Julia REPL.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Use the REPL help mode entered by typing ?.\njulia> using Trixi\n\nhelp?> trixi_include\nsearch: trixi_include\n\n trixi_include([mod::Module=Main,] elixir::AbstractString; kwargs...)\n\n include the file elixir and evaluate its content in the global scope of module mod. You can override specific\n assignments in elixir by supplying keyword arguments. It's basic purpose is to make it easier to modify some\n parameters while running Trixi.jl from the REPL. Additionally, this is used in tests to reduce the computational\n burden for CI while still providing examples with sensible default values for users.\n\n Examples\n ≡≡≡≡≡≡≡≡≡≡\n\n julia> trixi_include(@__MODULE__, default_example(), tspan=(0.0, 0.1))\n [...]\n\n julia> sol.t[end]\n 0.1\nYou can copy and paste REPL history including julia> prompts into the REPL.\nUse tab completion in the REPL, both for names of functions/types/variables and for function arguments.\njulia> flux_ranocha( # and TAB\nflux_ranocha(u_ll, u_rr, orientation::Integer, equations::CompressibleEulerEquations1D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_1d.jl:390\nflux_ranocha(u_ll, u_rr, orientation::Integer, equations::CompressibleEulerEquations2D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_2d.jl:839\n[...]\nUse methodswith to discover methods associated to a given type etc.\njulia> methodswith(CompressibleEulerEquations2D)\n[1] initial_condition_convergence_test(x, t, equations::CompressibleEulerEquations2D) in Trixi at ~/.julia/dev/Trixi/src/equations/compressible_euler_2d.jl:51\n[...]\nUse @which (or @edit) for method calls.\njulia> @which trixi_include(default_example())\ntrixi_include(elixir::AbstractString; kwargs...) in Trixi at ~/.julia/dev/Trixi/src/auxiliary/special_elixirs.jl:36\nUse apropos to search through the documentation and docstrings.\njulia> apropos(\"MHD\")\nTrixi.IdealGlmMhdEquations3D\nTrixi.IdealGlmMhdMulticomponentEquations2D\nTrixi.calc_fast_wavespeed_roe\nTrixi.IdealGlmMhdEquations1D\nTrixi.initial_condition_constant\nTrixi.flux_nonconservative_powell\nTrixi.GlmSpeedCallback\nTrixi.flux_derigs_etal\nTrixi.flux_hindenlang_gassner\nTrixi.initial_condition_convergence_test\nTrixi.min_max_speed_naive\nTrixi.IdealGlmMhdEquations2D\nTrixi.IdealGlmMhdMulticomponentEquations1D\n[...]","category":"page"},{"location":"development/#Text-editors","page":"Development","title":"Text editors","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"When writing code, the choice of text editor can have a significant impact on productivity and developer satisfaction. While using the default text editor of the operating system has its own benefits (specifically the lack of an explicit installation procure), usually it makes sense to switch to a more programming-friendly tool. In the following, a few of the many options are listed and discussed:","category":"page"},{"location":"development/#VS-Code","page":"Development","title":"VS Code","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Visual Studio Code is a modern open source editor with good support for Julia. While Juno had some better support in the past, the developers of Juno and the Julia VS Code plugin are joining forces and concentrating on VS Code since support of Atom has been suspended. Basically, all comments on Juno below also apply to VS Code.","category":"page"},{"location":"development/#Juno","page":"Development","title":"Juno","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"If you are new to programming or do not have a preference for a text editor yet, Juno is a good choice for developing Julia code. It is based on Atom, a sophisticated and widely used editor for software developers, and is enhanced with several Julia-specific features. Furthermore and especially helpful for novice programmers, it has a MATLAB-like appearance with easy and interactive access to the current variables, the help system, and a debugger.","category":"page"},{"location":"development/#Vim-or-Emacs","page":"Development","title":"Vim or Emacs","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Vim and Emacs are both very popular editors that work great with Julia. One of their advantages is that they are text editors without a GUI and as such are available for almost any operating system. They also are preinstalled on virtually all Unix-like systems. However, Vim and Emacs come with their own, steep learning curve if they have never been used before. Therefore, if in doubt, it is probably easier to get started with a classic GUI-based text editor (like Juno). If you decide to use Vim or Emacs, make sure that you install the corresponding Vim plugin julia-vim or Emacs major mode julia-emacs.","category":"page"},{"location":"development/#Debugging","page":"Development","title":"Debugging","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Julia offers several options for debugging. A classical debugger is available with the Debugger.jl package or in the Julia extension for VS Code. However, it can be quite slow and, at the time of writing (January 2023), currently does not work properly with Trixi.jl. The Infiltrator.jl package on the other hand does not offer all features of a full debugger, but is a fast and simple tool that allows users to set breakpoints to open a local REPL session and access the call stack and variables.","category":"page"},{"location":"development/#Infiltrator","page":"Development","title":"Infiltrator","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"The Infiltrator package provides fast, interactive breakpoints using the @infiltrate command, which drops the user into a local REPL session. From there, it is possible to access local variables, see the call stack, and execute statements.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"The package can be installed in the Julia REPL by executing","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"(@v1.9) pkg> add Infiltrator","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"To load the package in the Julia REPL execute","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia> using Infiltrator","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Breakpoints can be set by adding a line with the @infiltrate macro at the respective position in the code. Use Revise if you want to set and delete breakpoints in your package without having to restart Julia.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"note: Use `@autoinfiltrate` when debugging Trixi.jl\nWhen running Julia inside a package environment, e.g., inside the source code of Trixi.jl itself, the @infiltrate macro only works if Infiltrator has been added to the package dependencies. To avoid this, you can use the (non-exported) @autoinfiltrate macro in Trixi.jl, which only requires Infiltrator.jl to be available in the current environment stack and will auto-load it for you.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Triggering the breakpoint starts a REPL session where it is possible to interact with the current local scope. Possible commands are:","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"@locals: Print the local variables.\n@exfiltrate: Save the local variables to a global storage, which can be accessed with the safehouse variable outside the Infiltrator session.\n@trace: Print the current stack trace.\nExecute other arbitrary statements\n?: Print a help list with all options","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"To finish a debugging session, either use @continue to continue and eventually stop at the next breakpoint or @exit to skip further breakpoints. After the code has finished, local variables saved with @exfiltrate can be accessed in the REPL using the safehouse variable.","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"Limitations of using Infiltrator.jl are that local variables cannot be changed, and that it is not possible to step into further calls or access other function scopes.","category":"page"},{"location":"development/#Releasing-a-new-version-of-Trixi.jl,-Trixi2Vtk","page":"Development","title":"Releasing a new version of Trixi.jl, Trixi2Vtk","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Check whether everything is okay, tests pass etc.\nSet the new version number in Project.toml according to the Julian version of semver. Commit and push.\nComment @JuliaRegistrator register on the commit setting the version number.\nJuliaRegistrator will create a PR with the new version in the General registry. Wait for it to be merged.\nIncrement the version number in Project.toml again with suffix -pre. For example, if you have released version v0.2.0, use v0.2.1-pre as new version number.\nWhen a new version of Trixi.jl was released, check whether the [compat] entries in test/Project.toml in Trixi2Vtk should be updated. When a new version of Trixi2Vtk was released, check whether the [compat] entries in docs/Project.toml in Trixi.jl should be updated.\nThese entries will also be checked regularly by CompatHelper (once a day). Hence, if everything was released correctly, you should only need to do these checks manually if new minor versions with changes in the docs of Trixi2Vtk were released but no new version of Trixi.jl was released afterwards.","category":"page"},{"location":"development/#Preview-of-the-documentation","page":"Development","title":"Preview of the documentation","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"You can build the documentation of Trixi.jl locally by running","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"julia --project=docs -e 'using Pkg; Pkg.develop(PackageSpec(path=pwd())); Pkg.instantiate()'\njulia --project=docs --color=yes docs/make.jl","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"from the Trixi.jl main directory. Then, you can look at the html files generated in docs/build. For PRs triggered from branches inside the Trixi.jl main repository previews of the new documentation are generated at https://trixi-framework.github.io/Trixi.jl/previews/PRXXX, where XXX is the number of the PR. This does not work for PRs from forks for security reasons (since anyone could otherwise push arbitrary stuff to the Trixi.jl website, including malicious code).","category":"page"},{"location":"development/#trixi2vtk-dev","page":"Development","title":"Developing Trixi2Vtk","text":"","category":"section"},{"location":"development/","page":"Development","title":"Development","text":"Trixi2Vtk has Trixi.jl as dependency and uses Trixi.jl's implementation to, e.g., load mesh files. When developing Trixi2Vtk, one may want to change functions in Trixi.jl to allow them to be reused in Trixi2Vtk. To use a locally modified Trixi.jl clone instead of a Trixi.jl release, one can tell Pkg to use the local source code of Trixi.jl instead of a registered version by running","category":"page"},{"location":"development/","page":"Development","title":"Development","text":"(@v1.9) pkg> develop path/to/Trixi.jl","category":"page"},{"location":"visualization/#visualization","page":"Visualization","title":"Visualization","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"There are two possible approaches to visualize results from Trixi.jl: either directly from the REPL using Plots.jl or with ParaView/VisIt by postprocessing Trixi.jl's output files with Trixi2Vtk.","category":"page"},{"location":"visualization/#Plots.jl","page":"Visualization","title":"Plots.jl [experimental]","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"By far the easiest and most convenient plotting approach is to use the powerful Plots.jl package to directly visualize Trixi.jl's results from the REPL. In the following, you will find more information on a number of topics for how to use Plots.jl together with Trixi.jl:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Getting started\nCustomizing plot results via a PlotData2D object\nPlotting a 3D solution as a 2D plot\nCreating a 1D plot\nPlotting a 2D or 3D solutions as a 1D plot\nVisualizing results during a simulation","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"note: Note\nPlotting via Plots.jl is still considered an experimental feature and might change in any future releases.","category":"page"},{"location":"visualization/#getting-started-plots-jl","page":"Visualization","title":"Getting started","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"After running a simulation with Trixi.jl in the REPL, load the Plots package with","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> using Plots","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To visualize the solution, execute","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(sol)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Here we assume that sol holds the return value of the solve(...) method (with type SciMLBase.ODESolution), which is the default variable name when you use one of the example elixirs. This will generate a grid layout with one subplot for each solution variable, convenient for getting an overview of the current solution:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-sol)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"You can save the resulting file as a PNG image file by calling savefig(...) with an output file name that ends in .png, e.g.,","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> savefig(\"solution-overview.png\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In Trixi.jl, two plot types are available: 2D heatmap plots and 1D line plots. If you use plot(sol), Trixi.jl will automatically choose the plot type that fits the dimensions of the sol input: 2D/3D data will be visualized as a heatmap, 1D data as a line plot. For more fine-grained control over what to plot, you can create such an object yourself, which can either be a PlotData2D or a PlotData1D object. For further details on both of these see below:","category":"page"},{"location":"visualization/#Customizing-plot-results-via-a-PlotData2D-object","page":"Visualization","title":"Customizing plot results via a PlotData2D object","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"For more fine-grained control over what to plot, first create a PlotData2D object by executing","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData2D(sol)\njulia> pd = PlotData2D(u, semi)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"where u is an array containing the solution and semi is the semidiscretization. For example, if PlotData2D(sol.u[2], semi) is specified, this will create a PlotData2D instance from the 2nd saved time-step. If PlotData2D(sol(0.5), semi) is specified, it will construct a PlotData2D instance using OrdinaryDiffEq.jl's interpolation to evaluate the solution at time t=0.5.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This takes the results generated by Trixi.jl and stores them in a data format that can be understood by the Plots package, and pd holds all data relevant for plotting sol. You can pass variable names as strings to pd using a dictionary-like syntax, e.g.,","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(pd[\"rho\"])","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This will create a single 2D heatmap plot of the variable rho:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-rho)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The default plot type and style can be overridden by passing any additional arguments that are understood by the Plots package. For example, to change the color scheme and add names to the axes, modify the previous command to","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(pd[\"rho\"], seriescolor = :heat, xguide=\"x\", yguide=\"y\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"to yield","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-rho-modified)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"For more details on the various format options for plot, please consult the Plots documentation.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In addition, you can plot the mesh lines on top of the solution variables by calling the getmesh(...) function on the PlotData2D object","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot!(getmesh(pd)) # here we use `plot!` with an `!` to add to the previous plot","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"which modifies the previous plot to","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-rho-modified-mesh)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"By default, PlotData2D will convert the conserved variables to primitive variables, but this can be changed by passing an appropriate conversion function in the solution_variables keyword argument, similar to the behavior of the SaveSolutionCallback:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData2D(sol; solution_variables=cons2cons) # Plot conservative variables","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"There are several other keyword arguments that influence how the solution data is processed for visualization with the Plots package. A detailed explanation can be found in the docstring of the PlotData2D constructor.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Another way to change the appearance of a plot is to convert the solution to a uniformly refined mesh before plotting. This can be helpful, e.g., when trying different settings for a simulation with adaptive mesh refinement, where one would like to ignore the mesh changes when comparing solutions. This is achieved with adapt_to_mesh_level, which uses the mesh adaptation routines to adapt the solution to a uniform grid. For example, the AMR solution from above could be preprocessed with","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData2D(adapt_to_mesh_level(sol, 4)...)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"When plotted together with the mesh, this will yield the following visualization:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-rho-uniform-mesh)","category":"page"},{"location":"visualization/#Plotting-a-user-defined-scalar-field","page":"Visualization","title":"Plotting a user-defined scalar field","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To plot a scalar quantity, one can call plot(ScalarPlotData2D(u, semi)), where u is an array of nodal values of the scalar field to plot. The layout of u should match the layout of the x and y nodal coordinates of the respective solver. For example, after running trixi_include(joinpath(\"examples\", \"unstructured_2d_dgsem\", \"elixir_euler_wall_bc.jl\")), the following can be used to plot the function f(x, y) = x * y:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"x = view(semi.cache.elements.node_coordinates, 1, :, :, :)\ny = view(semi.cache.elements.node_coordinates, 2, :, :, :)\nplot(ScalarPlotData2D(x .* y, semi))","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This produces the following plot:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: scalar-plotting-example)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This routine can be used to visualize scalar quantities which depend on the solution, such as the norm of a velocity vector or two-dimensional vorticity. For example, we can visualize vorticity for a compressible version of the Brown-Minion vortex problem:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> using Trixi, Plots\n\njulia> redirect_stdout(devnull) do\n # runs the elixir without any output from callbacks etc.\n trixi_include(@__MODULE__,\n joinpath(examples_dir(), \"dgmulti_2d\", \"elixir_euler_brown_minion_vortex.jl\"))\n end\n[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.\n\njulia> function compute_vorticity(velocity, mesh, equations::CompressibleEulerEquations2D,\n dg::DGMulti, cache)\n rd = dg.basis\n md = mesh.md\n @unpack Dr, Ds = rd\n @unpack rxJ, sxJ, ryJ, syJ, J = md\n v1, v2 = velocity\n dv1dy = ryJ .* (Dr * v1) + syJ .* (Ds * v1)\n dv2dx = rxJ .* (Dr * v2) + sxJ .* (Ds * v2)\n return dv2dx - dv1dy\n end;\n\njulia> compute_vorticity(velocity, semi) =\n compute_vorticity(velocity, Trixi.mesh_equations_solver_cache(semi)...);\n\njulia> function get_velocity(sol)\n rho, rhou, rhov, E = StructArrays.components(sol.u[end])\n v1 = rhou ./ rho\n v2 = rhov ./ rho\n return v1, v2\n end;\n\njulia> vorticity = compute_vorticity(get_velocity(sol), semi);\n\njulia> plot(ScalarPlotData2D(vorticity, semi;\n variable_name = \"Vorticity at t = $(sol.prob.tspan[end])\"))\nPlot{Plots.GRBackend() n=1}","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This produces the following plot of vorticity.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: vorticity-example)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Since the mesh is fairly coarse, we observe numerical artifacts due to the low resolution. These errors vanish under mesh refinement; for example, doubling the mesh resolution by running","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi_include(joinpath(examples_dir(), \"dgmulti_2d\", \"elixir_euler_BM_vortex.jl\"), cells_per_dimension = 32)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"yields the following plot of vorticity:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: vorticity-example-refined)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"note: Note\nWhen visualizing a scalar field, the plotted solution is reinterpolated using a high order polynomial approximation. Thus, small discrepancies may be observed when the underlying data is highly non-smooth or under-resolved.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"ScalarPlotData2D objects can also be used with Makie through iplot. For example, the following code plots two surfaces:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> using Trixi, CairoMakie\n\njulia> redirect_stdout(devnull) do\n # runs the elixir without any output from callbacks etc.\n trixi_include(@__MODULE__,\n joinpath(examples_dir(), \"unstructured_2d_dgsem\", \"elixir_euler_wall_bc.jl\"))\n end\n[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.\n\njulia> x = view(semi.cache.elements.node_coordinates, 1, :, :, :); # extracts the node x coordinates\n\njulia> y = view(semi.cache.elements.node_coordinates, 2, :, :, :); # extracts the node y coordinates\n\njulia> fig_ax_plt = iplot(ScalarPlotData2D((@. 1 - .25*(x^2 + y^2)), semi), plot_mesh=true, colormap=:viridis);\n\njulia> fig_ax_plt2 = iplot!(fig_ax_plt, ScalarPlotData2D((@. .125*(x+y)), semi), plot_mesh=true, colormap=:blues)\nFigureAxisPlot()","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This creates the following plot:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: ScalarPlotData2D_example)","category":"page"},{"location":"visualization/#Plotting-a-3D-solution-as-a-2D-plot","page":"Visualization","title":"Plotting a 3D solution as a 2D plot","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"It is possible to plot 2D slices from 3D simulation data using the TreeMesh with the same commands as above:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(sol) # `sol` is from a 3D simulation","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"By default, plotting sol or creating a PlotData2D object from a 3D simulation will create a 2D slice of the solution in the xy-plane. You can customize this behavior by explicitly creating a PlotData2D object and passing appropriate keyword arguments:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"slice specifies the plane which is being sliced and can be :xy, :xz, or :yz (default: :xy)\npoint specifies a three-dimensional point. The sliced plane is then created such that it lies on the point (default: (0.0, 0.0, 0.0)).","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"All other attributes for PlotData2D objects apply here as well.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"For example, to plot the velocity field orthogonal to the yz-plane at different x-axis locations, you can execute","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi_include(joinpath(examples_dir(), \"tree_3d_dgsem\", \"elixir_euler_taylor_green_vortex.jl\"), tspan=(0.0, 1.0))\n[...]\n\njulia> plots = []\nAny[]\n\njulia> for x in range(0, stop=pi/2, length=6)\n pd = PlotData2D(sol, slice=:yz, point=(x, 0.0, 0.0))\n push!(plots, plot(pd[\"v1\"], clims=(-1,1), title=\"x = \"*string(round(x, digits=2))))\n end\n\njulia> plot(plots..., layout=(2, 3), size=(750,350))","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"which results in a 2x3 grid of slices of the yz-plane:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: plot-v1-0.0-to-0.5pi)","category":"page"},{"location":"visualization/#Creating-a-1D-plot","page":"Visualization","title":"Creating a 1D plot","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"When plotting a 1D solution with","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(sol) # `sol` is from a 1D simulation","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Trixi.jl automatically creates a PlotData1D object and visualizes it as a line plot: (Image: 1d-plot)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To customize your 1D plot, you can create a PlotData1D object manually as follows:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData1D(sol)\njulia> pd = PlotData1D(u, semi)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The behavior is analogous to the PlotData2D behavior.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In a very similar fashion to PlotData2D, you can customize your plot:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"plot(pd) creates the same plot as in plot(sol).\nplot(pd[\"rho\", \"p\"]) only plots specific variables. In this case rho and p.\nplot!(getmesh(pd)) adds mesh lines after creating a plot.\nAny attributes from Plots can be used, e.g., plot(pd, yguide=:temperature).\npd = PlotData1D(adapt_to_mesh_level(sol, 4)...) adapts the mesh before plotting (in this example to a mesh with refinement level 4).","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"You can also customize the PlotData1D object itself by passing attributes to the PlotData1D constructor:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"solution_variables specifies the variables to be plotted.\nnvisnodes sets the amount of nodes per element which the solution then is interpolated on.","category":"page"},{"location":"visualization/#Plotting-a-2D-or-3D-solutions-as-a-1D-plot","page":"Visualization","title":"Plotting a 2D or 3D solutions as a 1D plot","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"It is possible to extract a straight, axis-parallel line from a 2D or 3D solution and visualize it as a 1D plot. This is done by creating a PlotData1D object with a 2D/3D solution sol as input:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData1D(sol)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The plot is then created with:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(pd)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"By default the x-axis is extracted, which can be changed with following attributes:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"slice specifies the axis which is being extracted and can be :x, :y or :z (:z is only for 3D input and default is :x)\npoint specifies a two or three dimensional point. The sliced axis is then created in such a way, that it lies on the point. (default: (0.0, 0.0) or (0.0, 0.0, 0.0))","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"All other attributes for PlotData1D objects apply here as well.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In the following, is an example for a 2D simulation of the linear scalar advection equation. First, we have the regular 2D heatmap plot:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: 2d-plot-for-slice)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"From this, we can extract a line plot parallel to the y-axis going through the point (1.0, 0.0) with the following commands:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData1D(sol, slice=:y, point=(1.0, 0.0))\njulia> plot(pd)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: 1d-plot-for-slice)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This convenient method of slicing is limited to axis-parallel slices, but for 2D/3D solutions it is also possible to create a plot along any curve you want. To do so, you first need to create a list of 2D/3D points that define your curve. Then you can create a PlotData1D with the keyword argument curve set to your list.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Let's give an example of this with the basic advection equation from above by creating a plot along the circle marked in green:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: 2d-plot-along-circle)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"We can write a function like this, that outputs a list of points on a circle:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"function circle(radius, center, n_points)\n coordinates = zeros(2, n_points)\n for i in 1:n_points\n coordinates[:,i] = radius*[cospi(2*i/n_points), sinpi(2*i/n_points)] .+ center\n end\n return coordinates\nend","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Then create and plot a PlotData1D object along a circle with radius one, center at (1,1), and 100 points:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"pd = PlotData1D(sol, curve=circle(1.0, (1.0, 1.0), 100))\nplot(pd)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This gives you the following plot: (Image: 1d-plot-along-circle)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Creating a plot like this has its downsides. For one, it is unclear what to put on the abscissa of the plot. By default, the arc length of the given curve is used. Also, with this way of plotting you lose the ability to use a mesh plot from getmesh.","category":"page"},{"location":"visualization/#Visualizing-results-during-a-simulation","page":"Visualization","title":"Visualizing results during a simulation","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To visualize solutions while a simulation is still running (also known as in-situ visualization), you can use the VisualizationCallback. It is created as a regular callback and accepts upon creation a number of keyword arguments that allow, e.g., to control the visualization interval, to specify the variables to plot, or to customize the plotting style.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"During the simulation, the visualization callback creates and displays visualizations of the current solution in regular intervals. This can be useful to, e.g., monitor the validity of a long-running simulation or for illustrative purposes. An example for how to create a VisualizationCallback can be found in examples/tree_2d_dgsem/elixir_advection_amr_visualization.jl:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"[...]\n\n# Enable in-situ visualization with a new plot generated every 20 time steps\n# and additional plotting options passed as keyword arguments\nvisualization = VisualizationCallback(interval=20; clims=(0,1))\n\n[...]","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The resulting output of the referenced elixir can be seen in the embedded video below:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":" \n
","category":"page"},{"location":"visualization/#Trixi2Vtk","page":"Visualization","title":"Trixi2Vtk","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Trixi2Vtk converts Trixi.jl's .h5 output files to VTK files, which can be read by ParaView, VisIt, and other visualization tools. It automatically interpolates solution data from the original quadrature node locations to equidistant visualization nodes at a higher resolution, to make up for the loss of accuracy from going from a high-order polynomial representation to a piecewise constant representation in VTK.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In the Julia REPL, first load the package Trixi2Vtk","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> using Trixi2Vtk","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To process an HDF5 file generated by Trixi.jl, execute","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi2vtk(joinpath(\"out\", \"solution_000000.h5\"), output_directory=\"out\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This will create two unstructured VTK files in the out subdirectory that can be opened with ParaView or VisIt: solution_000000.vtu contains the discontinuous Galerkin solution data while solution_000000_celldata.vtu holds any cell-based values such as the current AMR indicator or the cell refinement level.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: \"solution_000000_scalar_mesh\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This allows you to generate VTK files for solution, restart and mesh files. By default, Trixi2Vtk generates .vtu (unstructured VTK) files for both cell/element data (e.g., cell ids, element ids) and node data (e.g., solution variables). This format visualizes each cell with the same number of nodes, independent of its size. Alternatively, you can provide format=:vti as a keyword argument to trixi2vtk, which causes Trixi2Vtk to generate .vti (image data VTK) files for the solution files, while still using .vtu files for cell-/element-based data. In .vti files, a uniform resolution is used throughout the entire domain, resulting in different number of visualization nodes for each element. This can be advantageous to create publication-quality images, but increases the file size.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"If you want to convert multiple solution/restart files at once, you can just supply multiple input files as the positional arguments to trixi2vtk, e.g.,","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi2vtk(\"out/solution_000000.h5\", \"out/solution_000040.h5\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"You may also use file globbing to select a range of files based on filename patterns, e.g.,","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi2vtk(\"out/solution_*.h5\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"to convert all solution files in the out/ directory or","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi2vtk(\"out/restart_00[0-9]000.h5\")","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"to convert every one-thousandth restart file (out/restart_000000.h5, out/restart_001000.h5 etc.).","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"When multiple solution/restart files are provided, Trixi2Vtk will also generate a .pvd file, which allows ParaView to read all .vtu/.vti files at once and which uses the time attribute in solution/restart files to inform ParaView about the solution time. A comprehensive list of all possible arguments for trixi2vtk can be found in the Trixi2Vtk.jl API.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Further information regarding the development of Trixi2Vtk can be found in the development section.","category":"page"},{"location":"visualization/#Makie.jl","page":"Visualization","title":"Makie.jl [experimental]","text":"","category":"section"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"In addition to Plots.jl support, Trixi.jl includes visualization utilities through Makie.jl. Trixi.jl provides Makie-based visualization options both for heatmap-type plots (similar to the Plots.jl recipes) as well as for interactive surface plots. Support is currently limited to the UnstructuredMesh2D type.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"note: Note\nPlotting via Makie.jl is still considered an experimental feature and might change in any future releases.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"A Makie plot can be created as follows: after running a simulation with Trixi.jl in the REPL, load a Makie backend (for example, GLMakie or CairoMakie).","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> using GLMakie","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"To visualize the solution and mesh with a heatmap-type plot, simply run","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(sol)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"note: Note\nBoth Makie.jl and Plots.jl export plot, so if you load both libraries, you will have to specify which plot function to call via Plots.plot or Makie.plot.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"As with Plots.jl recipes, one can view individual solution components by creating a PlotData2D object and indexing into it with the desired variable name","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> pd = PlotData2D(sol)\njulia> plot(pd[\"rho\"])","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Unlike the Plots.jl recipe, mesh plotting is controlled using the keyword argument plot_mesh = false, e.g.,","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> plot(sol; plot_mesh=false)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The plot command also returns figure and axis handles, which can be used to edit plot titles or labels:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> fig, axes = plot(sol)\njulia> axes[1,1].title = \"New title for subplot (1,1)\"","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Trixi.jl also supports interactive surface plots using iplot. After executing","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> trixi_include(joinpath(\"examples\", \"unstructured_2d_dgsem\", \"elixir_euler_wall_bc.jl\"))","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"we can run","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"julia> iplot(sol)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"This will open up an interactive visualization window:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: makie-example)","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"The plot can be rotated (click and hold), zoomed in and out (scroll up and down), and panned (hold right click and drag). Two toggle buttons control whether mesh lines are visible on top of and below the solution.","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"Both plot and iplot use colormap = :inferno by default. A different colormap can be selected by providing an appropriate keyword argument. For example, plot(sol, colormap=:blues) and iplot(sol, colormap=:blues) produce the following figures:","category":"page"},{"location":"visualization/","page":"Visualization","title":"Visualization","text":"(Image: makie-plot-example) (Image: makie-iplot-example)","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"EditURL = \"../../literate/src/files/adding_new_parabolic_terms.jl\"","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#adding_new_parabolic_terms","page":"11 Adding new parabolic terms","title":"11: Adding new parabolic terms","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"This demo illustrates the steps involved in adding new parabolic terms for the scalar advection equation. In particular, we will add an anisotropic diffusion. We begin by defining the hyperbolic (advection) part of the advection-diffusion equation.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"using OrdinaryDiffEq\nusing Trixi\n\n\nadvection_velocity = (1.0, 1.0)\nequations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);\nnothing #hide","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#Define-a-new-parabolic-equation-type","page":"11 Adding new parabolic terms","title":"Define a new parabolic equation type","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Next, we define a 2D parabolic diffusion term type. This is similar to LaplaceDiffusion2D except that the diffusivity field refers to a spatially constant diffusivity matrix now. Note that ConstantAnisotropicDiffusion2D has a field for equations_hyperbolic. It is useful to have information about the hyperbolic system available to the parabolic part so that we can reuse functions defined for hyperbolic equations (such as varnames).","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"struct ConstantAnisotropicDiffusion2D{E, T} <: Trixi.AbstractEquationsParabolic{2, 1}\n diffusivity::T\n equations_hyperbolic::E\nend\n\nvarnames(variable_mapping, equations_parabolic::ConstantAnisotropicDiffusion2D) =\n varnames(variable_mapping, equations_parabolic.equations_hyperbolic)","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Next, we define the viscous flux function. We assume that the mixed hyperbolic-parabolic system is of the form","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"partial_t u(tx) + partial_x (f_1(u) - g_1(u nabla u))\n + partial_y (f_2(u) - g_2(u nabla u)) = 0","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"where f_1(u), f_2(u) are the hyperbolic fluxes and g_1(u nabla u), g_2(u nabla u) denote the viscous fluxes. For anisotropic diffusion, the viscous fluxes are the first and second components of the matrix-vector product involving diffusivity and the gradient vector.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Here, we specialize the flux to our new parabolic equation type ConstantAnisotropicDiffusion2D.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"function Trixi.flux(u, gradients, orientation::Integer, equations_parabolic::ConstantAnisotropicDiffusion2D)\n @unpack diffusivity = equations_parabolic\n dudx, dudy = gradients\n if orientation == 1\n return SVector(diffusivity[1, 1] * dudx + diffusivity[1, 2] * dudy)\n else # if orientation == 2\n return SVector(diffusivity[2, 1] * dudx + diffusivity[2, 2] * dudy)\n end\nend","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#Defining-boundary-conditions","page":"11 Adding new parabolic terms","title":"Defining boundary conditions","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Trixi.jl's implementation of parabolic terms discretizes both the gradient and divergence using weak formulation. In other words, we discretize the system","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"beginaligned\nbmq = nabla u \nbmsigma = beginpmatrix g_1(u bmq) g_2(u bmq) endpmatrix \ntextviscous contribution = nabla cdot bmsigma\nendaligned","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Boundary data must be specified for all spatial derivatives, e.g., for both the gradient equation bmq = nabla u and the divergence of the viscous flux nabla cdot bmsigma. We account for this by introducing internal Gradient and Divergence types which are used to dispatch on each type of boundary condition.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"As an example, let us introduce a Dirichlet boundary condition with constant boundary data.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"struct BoundaryConditionConstantDirichlet{T <: Real}\n boundary_value::T\nend","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"This boundary condition contains only the field boundary_value, which we assume to be some real-valued constant which we will impose as the Dirichlet data on the boundary.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Boundary conditions have generally been defined as \"callable structs\" (also known as \"functors\"). For each boundary condition, we need to specify the appropriate boundary data to return for both the Gradient and Divergence. Since the gradient is operating on the solution u, the boundary data should be the value of u, and we can directly impose Dirichlet data.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,\n x, t, operator_type::Trixi.Gradient,\n equations_parabolic::ConstantAnisotropicDiffusion2D)\n return boundary_condition.boundary_value\nend","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"While the gradient acts on the solution u, the divergence acts on the viscous flux bmsigma. Thus, we have to supply boundary data for the Divergence operator that corresponds to bmsigma. However, we've already imposed boundary data on u for a Dirichlet boundary condition, and imposing boundary data for bmsigma might overconstrain our problem.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Thus, for the Divergence boundary data under a Dirichlet boundary condition, we simply return flux_inner, which is boundary data for bmsigma computed using the \"inner\" or interior solution. This way, we supply boundary data for the divergence operation without imposing any additional conditions.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,\n x, t, operator_type::Trixi.Divergence,\n equations_parabolic::ConstantAnisotropicDiffusion2D)\n return flux_inner\nend","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#A-note-on-the-choice-of-gradient-variables","page":"11 Adding new parabolic terms","title":"A note on the choice of gradient variables","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"It is often simpler to transform the solution variables (and solution gradients) to another set of variables prior to computing the viscous fluxes (see CompressibleNavierStokesDiffusion2D for an example of this). If this is done, then the boundary condition for the Gradient operator should be modified accordingly as well.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#Putting-things-together","page":"11 Adding new parabolic terms","title":"Putting things together","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"Finally, we can instantiate our new parabolic equation type, define boundary conditions, and run a simulation. The specific anisotropic diffusion matrix we use produces more dissipation in the direction (1 -1) as an isotropic diffusion.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"For boundary conditions, we impose that u=1 on the left wall, u=2 on the bottom wall, and u = 0 on the outflow walls. The initial condition is taken to be u = 0. Note that we use BoundaryConditionConstantDirichlet only for the parabolic boundary conditions, since we have not defined its behavior for the hyperbolic part.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"using Trixi: SMatrix\ndiffusivity = 5.0e-2 * SMatrix{2, 2}([2 -1; -1 2])\nequations_parabolic = ConstantAnisotropicDiffusion2D(diffusivity, equations_hyperbolic);\n\nboundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1.0)),\n y_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(2.0)),\n y_pos = boundary_condition_do_nothing,\n x_pos = boundary_condition_do_nothing)\n\nboundary_conditions_parabolic = (; x_neg = BoundaryConditionConstantDirichlet(1.0),\n y_neg = BoundaryConditionConstantDirichlet(2.0),\n y_pos = BoundaryConditionConstantDirichlet(0.0),\n x_pos = BoundaryConditionConstantDirichlet(0.0));\n\nsolver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\ncoordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))\ncoordinates_max = ( 1.0, 1.0) # maximum coordinates (max(x), max(y))\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4,\n periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure\n\ninitial_condition = (x, t, equations) -> SVector(0.0)\n\nsemi = SemidiscretizationHyperbolicParabolic(mesh,\n (equations_hyperbolic, equations_parabolic),\n initial_condition, solver;\n boundary_conditions=(boundary_conditions_hyperbolic,\n boundary_conditions_parabolic))\n\ntspan = (0.0, 2.0)\node = semidiscretize(semi, tspan)\ncallbacks = CallbackSet(SummaryCallback())\ntime_int_tol = 1.0e-6\nsol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,\n ode_default_options()..., callback=callbacks);\n\nusing Plots\nplot(sol)","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/#Package-versions","page":"11 Adding new parabolic terms","title":"Package versions","text":"","category":"section"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"","category":"page"},{"location":"tutorials/adding_new_parabolic_terms/","page":"11 Adding new parabolic terms","title":"11 Adding new parabolic terms","text":"This page was generated using Literate.jl.","category":"page"},{"location":"code_of_conduct/","page":"Code of Conduct","title":"Code of Conduct","text":"EditURL = \"https://github.com/trixi-framework/Trixi.jl/blob/main/CODE_OF_CONDUCT.md\"","category":"page"},{"location":"code_of_conduct/#code-of-conduct","page":"Code of Conduct","title":"Code of Conduct","text":"","category":"section"},{"location":"code_of_conduct/","page":"Code of Conduct","title":"Code of Conduct","text":"Contributor Covenant Code of ConductOur PledgeWe as members, contributors, and leaders pledge to make participation in our community a harassment-free experience for everyone, regardless of age, body size, visible or invisible disability, ethnicity, sex characteristics, gender identity and expression, level of experience, education, socio-economic status, nationality, personal appearance, race, religion, or sexual identity and orientation.We pledge to act and interact in ways that contribute to an open, welcoming, diverse, inclusive, and healthy community.Our StandardsExamples of behavior that contributes to a positive environment for our community include:Demonstrating empathy and kindness toward other people\nBeing respectful of differing opinions, viewpoints, and experiences\nGiving and gracefully accepting constructive feedback\nAccepting responsibility and apologizing to those affected by our mistakes, and learning from the experience\nFocusing on what is best not just for us as individuals, but for the overall communityExamples of unacceptable behavior include:The use of sexualized language or imagery, and sexual attention or advances of any kind\nTrolling, insulting or derogatory comments, and personal or political attacks\nPublic or private harassment\nPublishing others' private information, such as a physical or email address, without their explicit permission\nOther conduct which could reasonably be considered inappropriate in a professional settingEnforcement ResponsibilitiesCommunity leaders are responsible for clarifying and enforcing our standards of acceptable behavior and will take appropriate and fair corrective action in response to any behavior that they deem inappropriate, threatening, offensive, or harmful.Community leaders have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, and will communicate reasons for moderation decisions when appropriate.ScopeThis Code of Conduct applies within all community spaces, and also applies when an individual is officially representing the community in public spaces. Examples of representing our community include using an official e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event.EnforcementInstances of abusive, harassing, or otherwise unacceptable behavior may be reported to Michael Schlottke-Lakemper, Hendrik Ranocha, or any other of the principal developers responsible for enforcement listed in Authors. All complaints will be reviewed and investigated promptly and fairly.All community leaders are obligated to respect the privacy and security of the reporter of any incident.Enforcement GuidelinesCommunity leaders will follow these Community Impact Guidelines in determining the consequences for any action they deem in violation of this Code of Conduct:1. CorrectionCommunity Impact: Use of inappropriate language or other behavior deemed unprofessional or unwelcome in the community.Consequence: A private, written warning from community leaders, providing clarity around the nature of the violation and an explanation of why the behavior was inappropriate. A public apology may be requested.2. WarningCommunity Impact: A violation through a single incident or series of actions.Consequence: A warning with consequences for continued behavior. No interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, for a specified period of time. This includes avoiding interactions in community spaces as well as external channels like social media. Violating these terms may lead to a temporary or permanent ban.3. Temporary BanCommunity Impact: A serious violation of community standards, including sustained inappropriate behavior.Consequence: A temporary ban from any sort of interaction or public communication with the community for a specified period of time. No public or private interaction with the people involved, including unsolicited interaction with those enforcing the Code of Conduct, is allowed during this period. Violating these terms may lead to a permanent ban.4. Permanent BanCommunity Impact: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.Consequence: A permanent ban from any sort of public interaction within the community.AttributionThis Code of Conduct is adapted from the [Contributor Covenant][homepage], version 2.0, available at https://www.contributor-covenant.org/version/2/0/codeofconduct.html.Community Impact Guidelines were inspired by Mozilla's code of conduct enforcement ladder.[homepage]: https://www.contributor-covenant.orgFor answers to common questions about this code of conduct, see the FAQ at https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.","category":"page"},{"location":"conventions/#conventions","page":"Conventions","title":"Conventions","text":"","category":"section"},{"location":"conventions/#Spatial-dimensions-and-directions","page":"Conventions","title":"Spatial dimensions and directions","text":"","category":"section"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"We use the following numbering schemes on Cartesian or curved structured meshes.","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"The orientations are numbered as 1 => x, 2 => y, 3 => z. For example, numerical fluxes such as flux_central(u_ll, u_rr, orientation, equations::AbstractEquations) use the orientation in this way.\nThe directions are numbered as 1 => -x, 2 => +x, 3 => -y, 4 => +y, 5 => -z, 6 => +z. For example, the boundary_conditions are ordered in this way when a Tuple of boundary conditions per direction is passed to the constructor of a SemidiscretizationHyperbolic.\nFor structured and unstructured curved meshes the concept of direction is generalized via the variable normal_direction. This variable points in the normal direction at a given, curved surface. For the computation of boundary fluxes the normal_direction is normalized to be a normal_vector used, for example, in FluxRotated.","category":"page"},{"location":"conventions/#Cells-vs.-elements-vs.-nodes","page":"Conventions","title":"Cells vs. elements vs. nodes","text":"","category":"section"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"To uniquely distinguish between different components of the discretization, we use the following naming conventions:","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"The computational domain is discretized by a mesh, which is made up of individual cells. In general, neither the mesh nor the cells should be aware of any solver-specific knowledge, i.e., they should not store anything that goes beyond the geometrical information and the connectivity.\nThe numerical solvers do not directly store their information inside the mesh, but use own data structures. Specifically, for each cell on which a solver wants to operate, the solver creates an element to store solver-specific data.\nFor discretization schemes such as the discontinuous Galerkin or the finite element method, inside each element multiple nodes may be defined, which hold nodal information. The nodes are again a solver-specific component, just like the elements.\nWe often identify elements, nodes, etc. with their (local or global) integer index. Convenience iterators such as eachelement, eachnode use these indices.","category":"page"},{"location":"conventions/#Keywords-in-elixirs","page":"Conventions","title":"Keywords in elixirs","text":"","category":"section"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"Trixi.jl is distributed with several examples in the form of elixirs, small Julia scripts containing everything to set up and run a simulation. Working interactively from the Julia REPL with these scripts can be quite convenient while for exploratory research and development of Trixi.jl. For example, you can use the convenience function trixi_include to include an elixir with some modified arguments. To enable this, it is helpful to use a consistent naming scheme in elixirs, since trixi_include can only perform simple replacements. Some standard variables names are","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"polydeg for the polynomial degree of a solver\nsurface_flux for the numerical flux at surfaces\nvolume_flux for the numerical flux used in flux differencing volume terms","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"Moreover, convergence_test requires that the spatial resolution is set via the keywords","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"initial_refinement_level (an integer, e.g. for the TreeMesh and the P4estMesh) or\ncells_per_dimension (a tuple of integers, one per spatial dimension, e.g. for the StructuredMesh and the DGMultiMesh).","category":"page"},{"location":"conventions/#Variable-names","page":"Conventions","title":"Variable names","text":"","category":"section"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"Use descriptive names (using snake_case for variables/functions and CamelCase for types)\nUse a suffix _ as in name_ for local variables that would otherwise hide existing symbols.\nUse a prefix _ as in _name to indicate internal methods/data that are \"fragile\" in the sense that there's no guarantee that they might get changed without notice. These are also not documented with a docstring (but maybe with comments using #).","category":"page"},{"location":"conventions/#Array-types-and-wrapping","page":"Conventions","title":"Array types and wrapping","text":"","category":"section"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"To allow adaptive mesh refinement efficiently when using time integrators from OrdinaryDiffEq, Trixi.jl allows to represent numerical solutions in two different ways. Some discussion can be found online and in form of comments describing Trixi.wrap_array and Trixi.wrap_array_native in the source code of Trixi.jl. The flexibility introduced by this possible wrapping enables additional performance optimizations. However, it comes at the cost of some additional abstractions (and needs to be used with caution, as described in the source code of Trixi.jl). Thus, we use the following conventions to distinguish between arrays visible to the time integrator and wrapped arrays mainly used internally.","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"Arrays visible to the time integrator have a suffix _ode, e.g., du_ode, u_ode.\nWrapped arrays do not have a suffix, e.g., du, u.","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"Methods either accept arrays visible to the time integrator or wrapped arrays based on the following rules.","category":"page"},{"location":"conventions/","page":"Conventions","title":"Conventions","text":"When some solution is passed together with a semidiscretization semi, the solution must be a u_ode that needs to be wrapped via wrap_array(u_ode, semi) (or wrap_array_native(u_ode, semi)) for further processing.\nWhen some solution is passed together with the mesh, equations, solver, cache, ..., it is already wrapped via wrap_array (or wrap_array_native).\nExceptions of this rule are possible, e.g. for AMR, but must be documented in the code.\nwrap_array should be used as default option. wrap_array_native should only be used when necessary, e.g., to avoid additional overhead when interfacing with external C libraries such as HDF5, MPI, or visualization.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"EditURL = \"../../literate/src/files/non_periodic_boundaries.jl\"","category":"page"},{"location":"tutorials/non_periodic_boundaries/#non_periodic_boundaries","page":"4 Non-periodic boundaries","title":"4: Non-periodic boundaries","text":"","category":"section"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/non_periodic_boundaries/#Dirichlet-boundary-condition","page":"4 Non-periodic boundaries","title":"Dirichlet boundary condition","text":"","category":"section"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"First, let's look at the Dirichlet boundary condition BoundaryConditionDirichlet.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"BoundaryConditionDirichlet(boundary_value_function)","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"In Trixi.jl, this creates a Dirichlet boundary condition where the function boundary_value_function is used to set the values at the boundary. It can be used to create a boundary condition that sets exact boundary values by passing the exact solution of the equation.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"It is important to note that standard Dirichlet boundary conditions for hyperbolic PDEs do not make sense in most cases. However, we are using a special weak form of the Dirichlet boundary condition, based on the application of the numerical surface flux. The numerical surface flux takes the solution value from inside the domain and the prescribed value of the outer boundary state as arguments, and solves an approximate Riemann problem to introduce dissipation (and hence stabilization) at the boundary. Hence, the performance of the Dirichlet BC depends on the fidelity of the numerical surface flux.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"The passed boundary value function is called with the same arguments as an initial condition function, i.e.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"boundary_value_function(x, t, equations)","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"where x specifies the spatial coordinates, t is the current time, and equations is the corresponding system of equations.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"We want to give a short example for a simulation with such a Dirichlet BC.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Consider the one-dimensional linear advection equation with domain Omega=0 2 and a constant zero initial condition.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"using OrdinaryDiffEq, Trixi\n\nadvection_velocity = 1.0\nequations = LinearScalarAdvectionEquation1D(advection_velocity)\n\ninitial_condition_zero(x, t, equation::LinearScalarAdvectionEquation1D) = SVector(0.0)\ninitial_condition = initial_condition_zero\n\nusing Plots\nplot(x -> sum(initial_condition(x, 0.0, equations)), label=\"initial condition\", ylim=(-1.5, 1.5))","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Using an advection velocity of 1.0 and the (local) Lax-Friedrichs/Rusanov flux FluxLaxFriedrichs as a numerical surface flux, we are able to create an inflow boundary on the left and an outflow boundary on the right, as the Lax-Friedrichs flux is in this case an exact characteristics Riemann solver. We note that for more complex PDEs different strategies for inflow/outflow boundaries are necessary. To define the inflow values, we initialize a boundary_value_function.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"function boundary_condition_sine_sector(x, t, equation::LinearScalarAdvectionEquation1D)\n if 1 <= t <= 3\n scalar = sin(2 * pi * sum(t - 1))\n else\n scalar = zero(t)\n end\n return SVector(scalar)\nend\nboundary_condition = boundary_condition_sine_sector","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"We set the BC in negative and positive x-direction.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"boundary_conditions = (x_neg=BoundaryConditionDirichlet(boundary_condition),\n x_pos=BoundaryConditionDirichlet(boundary_condition))","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n\ncoordinates_min = (0.0,)\ncoordinates_max = (2.0,)","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"For the mesh type TreeMesh the parameter periodicity must be set to false in the corresponding direction.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"mesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4,\n n_cells_max=10_000,\n periodicity=false)\n\n\nsemi = SemidiscretizationHyperbolic(mesh, equations,\n initial_condition,\n solver,\n boundary_conditions=boundary_conditions)\n\ntspan = (0.0, 6.0)\node = semidiscretize(semi, tspan)\n\nanalysis_callback = AnalysisCallback(semi, interval=100,)\n\nstepsize_callback = StepsizeCallback(cfl=0.9)\n\ncallbacks = CallbackSet(analysis_callback,\n stepsize_callback);\nnothing #hide","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"We define some equidistant nodes for the visualization","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"visnodes = range(tspan[1], tspan[2], length=300)","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"and run the simulation.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=1, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, saveat=visnodes, callback=callbacks);\n\nusing Plots\n@gif for step in 1:length(sol.u)\n plot(sol.u[step], semi, ylim=(-1.5, 1.5), legend=true, label=\"approximation\", title=\"time t=$(round(sol.t[step], digits=5))\")\n scatter!([0.0], [sum(boundary_condition(SVector(0.0), sol.t[step], equations))], label=\"boundary condition\")\nend","category":"page"},{"location":"tutorials/non_periodic_boundaries/#Other-available-example-elixirs-with-non-trivial-BC","page":"4 Non-periodic boundaries","title":"Other available example elixirs with non-trivial BC","text":"","category":"section"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Moreover, there are other boundary conditions in Trixi.jl. For instance, you can use the slip wall boundary condition boundary_condition_slip_wall.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Trixi.jl provides some interesting examples with different combinations of boundary conditions, e.g. using boundary_condition_slip_wall and other self-defined boundary conditions using BoundaryConditionDirichlet.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"For instance, there is a 2D compressible Euler setup for a Mach 3 wind tunnel flow with a forward facing step in the elixir elixir_euler_forward_step_amr.jl discretized with a P4estMesh using adaptive mesh refinement (AMR).","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":" \n
","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Source: Video on Trixi.jl's YouTube channel Trixi Framework","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"A double Mach reflection problem for the 2D compressible Euler equations elixir_euler_double_mach_amr.jl exercises a special boundary conditions along the bottom of the domain that is a mixture of Dirichlet and slip wall.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":" \n
","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Source: Video on Trixi.jl's YouTube channel Trixi Framework","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"A channel flow around a cylinder at Mach 3 elixir_euler_supersonic_cylinder.jl contains supersonic Mach 3 inflow at the left portion of the domain and supersonic outflow at the right portion of the domain. The top and bottom of the channel as well as the cylinder are treated as Euler slip wall boundaries.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":" \n
","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"Source: Video on Trixi.jl's YouTube channel Trixi Framework","category":"page"},{"location":"tutorials/non_periodic_boundaries/#Package-versions","page":"4 Non-periodic boundaries","title":"Package versions","text":"","category":"section"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"","category":"page"},{"location":"tutorials/non_periodic_boundaries/","page":"4 Non-periodic boundaries","title":"4 Non-periodic boundaries","text":"This page was generated using Literate.jl.","category":"page"},{"location":"parallelization/#Parallelization","page":"Parallelization","title":"Parallelization","text":"","category":"section"},{"location":"parallelization/#Shared-memory-parallelization-with-threads","page":"Parallelization","title":"Shared-memory parallelization with threads","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"Many compute-intensive loops in Trixi.jl are parallelized using the multi-threading support provided by Julia. You can recognize those loops by the @threaded macro prefixed to them, e.g.,","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"@threaded for element in eachelement(dg, cache)\n ...\nend","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"This will statically assign an equal iteration count to each available thread.","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"To use multi-threading, you need to tell Julia at startup how many threads you want to use by either setting the environment variable JULIA_NUM_THREADS or by providing the -t/--threads command line argument. For example, to start Julia with four threads, start Julia with","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"julia --threads=4","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"If both the environment variable and the command line argument are specified at the same time, the latter takes precedence.","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"If you use time integration methods from OrdinaryDiffEq.jl and want to use multiple threads therein, you need to set the keyword argument thread=OrdinaryDiffEq.True() of the algorithms, as described in the section on time integration methods.","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"warning: Warning\nNot everything is parallelized yet and there are likely opportunities to improve scalability. Multi-threading isn't considered part of the public API of Trixi.jl yet.","category":"page"},{"location":"parallelization/#Distributed-computing-with-MPI","page":"Parallelization","title":"Distributed computing with MPI","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"In addition to the shared memory parallelization with multi-threading, Trixi.jl supports distributed parallelism via MPI.jl, which leverages the Message Passing Interface (MPI). MPI.jl comes with its own MPI library binaries such that there is no need to install MPI yourself. However, it is also possible to instead use an existing MPI installation, which is recommended if you are running MPI programs on a cluster or supercomputer (see the MPI.jl docs to find out how to select the employed MPI library). Additional notes on how to use a system-provided MPI installation with Trixi.jl can be found in the following subsection.","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"warning: Work in progress\nMPI-based parallelization is work in progress and not finished yet. Nothing related to MPI is part of the official API of Trixi.jl yet.","category":"page"},{"location":"parallelization/#parallel_system_MPI","page":"Parallelization","title":"Using a system-provided MPI installation","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"When using Trixi.jl with a system-provided MPI backend the underlying p4est and t8code libraries need to be compiled with the same MPI installation. Therefore, you also need to use system-provided p4est and t8code installations (for notes on how to install p4est and t8code see e.g. here and here, use the configure option --enable-mpi). Note that t8code already comes with a p4est installation, so it suffices to install t8code. In addition, P4est.jl and T8code.jl need to be configured to use the custom installations. Follow the steps described here and here for the configuration. The paths that point to libp4est.so (and potentially to libsc.so) need to be the same for P4est.jl and T8code.jl. This could e.g. be libp4est.so that usually can be found in lib/ or local/lib/ in the installation directory of t8code. In total, in your active Julia project you should have a LocalPreferences.toml file with sections [MPIPreferences], [T8code] and [P4est] as well as an entry MPIPreferences in your Project.toml to use a custom MPI installation. A LocalPreferences.toml file created as described above might look something like the following:","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"[HDF5]\nlibhdf5 = \"/usr/lib/x86_64-linux-gnu/hdf5/openmpi/libhdf5.so\"\nlibhdf5_hl = \"/usr/lib/x86_64-linux-gnu/hdf5/openmpi/libhdf5_hl.so\"\n\n[MPIPreferences]\n__clear__ = [\"preloads_env_switch\"]\n_format = \"1.0\"\nabi = \"OpenMPI\"\nbinary = \"system\"\ncclibs = []\nlibmpi = \"/lib/x86_64-linux-gnu/libmpi.so\"\nmpiexec = \"mpiexec\"\npreloads = []\n\n[P4est]\nlibp4est = \"/home/mschlott/hackathon/libtrixi/t8code/install/lib/libp4est.so\"\nlibsc = \"/home/mschlott/hackathon/libtrixi/t8code/install/lib/libsc.so\"\n\n[T8code]\nlibp4est = \"/home/mschlott/hackathon/libtrixi/t8code/install/lib/libp4est.so\"\nlibsc = \"/home/mschlott/hackathon/libtrixi/t8code/install/lib/libsc.so\"\nlibt8 = \"/home/mschlott/hackathon/libtrixi/t8code/install/lib/libt8.so\"","category":"page"},{"location":"parallelization/#parallel_usage","page":"Parallelization","title":"Usage","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"To start Trixi.jl in parallel with MPI, there are three options:","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"Run from the REPL with mpiexec(): You can start a parallel execution directly from the REPL by executing\njulia> using MPI\n\njulia> mpiexec() do cmd\n run(`$cmd -n 3 $(Base.julia_cmd()) --threads=1 --project=@. -e 'using Trixi; trixi_include(default_example())'`)\n end\nThe parameter -n 3 specifies that Trixi.jl should run with three processes (or ranks in MPI parlance) and should be adapted to your available computing resources and problem size. The $(Base.julia_cmd()) argument ensures that Julia is executed in parallel with the same optimization level etc. as you used for the REPL; if this is unnecessary or undesired, you can also just use julia. Further, if you are not running Trixi.jl from a local clone but have installed it as a package, you need to omit the --project=@..\nRun from the command line with mpiexecjl: Alternatively, you can use the mpiexecjl script provided by MPI.jl, which allows you to start Trixi.jl in parallel directly from the command line. As a preparation, you need to install the script once by running\njulia> using MPI\n\njulia> MPI.install_mpiexecjl(destdir=\"/somewhere/in/your/PATH\")\nThen, to execute Trixi.jl in parallel, execute the following command from your command line:\nmpiexecjl -n 3 julia --threads=1 --project=@. -e 'using Trixi; trixi_include(default_example())'\nRun interactively with tmpi (Linux/MacOS only): If you are on a Linux/macOS system, you have a third option which lets you run Julia in parallel interactively from the REPL. This comes in handy especially during development, as in contrast to the first two options, it allows to reuse the compilation cache and thus facilitates much faster startup times after the first execution. It requires tmux and the OpenMPI library to be installed before, both of which are usually available through a package manager. Once you have installed both tools, you need to configure MPI.jl to use the OpenMPI for your system, which is explained here. Then, you can download and install the tmpi script by executing\ncurl https://raw.githubusercontent.com/Azrael3000/tmpi/master/tmpi -o /somewhere/in/your/PATH/tmpi\nFinally, you can start and control multiple Julia REPLs simultaneously by running\ntmpi 3 julia --threads=1 --project=@.\nThis will start Julia inside tmux three times and multiplexes all commands you enter in one REPL to all other REPLs (try for yourself to understand what it means). If you have no prior experience with tmux, handling the REPL this way feels slightly weird in the beginning. However, there is a lot of documentation for tmux available and once you get the hang of it, developing Trixi.jl in parallel becomes much smoother this way. Some helpful commands are the following. To close a single pane you can press Ctrl+b and then x followed by y to confirm. To quit the whole session you press Ctrl+b followed by :kill-session. Often you would like to scroll up. You can do that by pressing Ctrl+b and then [, which allows you to use the arrow keys to scroll up and down. To leave the scroll mode you press q. Switching between panes can be done by Ctrl+b followed by o. As of March 2022, newer versions of tmpi also support mpich, which is the default backend of MPI.jl (via MPICH_Jll.jl). To use this setup, you need to install mpiexecjl as described in the documentation of MPI.jl and make it available as mpirun, e.g., via a symlink of the form\nln -s ~/.julia/bin/mpiexecjl /somewhere/in/your/path/mpirun\n(assuming default installations).","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"note: Hybrid parallelism\nIt is possible to combine MPI with shared memory parallelism via threads by starting Julia with more than one thread, e.g. by passing the command line argument julia --threads=2 instead of julia --threads=1 used in the examples above. In that case, you should make sure that your system supports the number of processes/threads that you try to start.","category":"page"},{"location":"parallelization/#parallel_performance","page":"Parallelization","title":"Performance","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"For information on how to evaluate the parallel performance of Trixi.jl, please have a look at the Performance metrics of the AnalysisCallback section, specifically at the descriptions of the performance index (PID).","category":"page"},{"location":"parallelization/#Using-error-based-step-size-control-with-MPI","page":"Parallelization","title":"Using error-based step size control with MPI","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"If you use error-based step size control (see also the section on error-based adaptive step sizes) together with MPI you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to OrdinaryDiffEq's solve, which are both included in ode_default_options.","category":"page"},{"location":"parallelization/#Using-parallel-input-and-output","page":"Parallelization","title":"Using parallel input and output","text":"","category":"section"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"Trixi.jl allows parallel I/O using MPI by leveraging parallel HDF5.jl. On most systems, this is enabled by default. Additionally, you can also use a local installation of the HDF5 library (with MPI support). For this, you first need to use a system-provided MPI library, see also here and you need to tell HDF5.jl to use this library. To do so with HDF5.jl v0.17 and newer, set the preferences libhdf5 and libhdf5_hl to the local paths of the libraries libhdf5 and libhdf5_hl, which can be done by","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"julia> using Preferences, UUIDs\njulia> set_preferences!(\n UUID(\"f67ccb44-e63f-5c2f-98bd-6dc0ccc4ba2f\"), # UUID of HDF5.jl\n \"libhdf5\" => \"/path/to/your/libhdf5.so\",\n \"libhdf5_hl\" => \"/path/to/your/libhdf5_hl.so\", force = true)","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"Alternatively, with HDF5.jl v0.17.1 or higher you can use","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"julia> using HDF5\njulia> HDF5.API.set_libraries!(\"/path/to/your/libhdf5.so\", \"/path/to/your/libhdf5_hl.so\")","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"For more information see also the documentation of HDF5.jl. In total, you should have a file called LocalPreferences.toml in the project directory that contains a section [MPIPreferences], a section [HDF5] with entries libhdf5 and libhdf5_hl, a section [P4est] with the entry libp4est as well as a section [T8code] with the entries libt8, libp4est and libsc. If you use HDF5.jl v0.16 or older, instead of setting the preferences for HDF5.jl, you need to set the environment variable JULIA_HDF5_PATH to the path, where the HDF5 binaries are located and then call ]build HDF5 from Julia.","category":"page"},{"location":"parallelization/","page":"Parallelization","title":"Parallelization","text":"If HDF5 is not MPI-enabled, Trixi.jl will fall back on a less efficient I/O mechanism. In that case, all disk I/O is performed only on rank zero and data is distributed to/gathered from the other ranks using regular MPI communication.","category":"page"},{"location":"overview/#Overview-of-the-structure-of-Trixi.jl","page":"Overview","title":"Overview of the structure of Trixi.jl","text":"","category":"section"},{"location":"overview/","page":"Overview","title":"Overview","text":"Trixi.jl is designed as a library of components for discretizations of hyperbolic conservation laws. Thus, it is not a monolithic PDE solver that is configured at runtime via parameter files, as it is often found in classical numerical simulation codes. Instead, each simulation is configured by pure Julia code. Many examples of such simulation setups, called elixirs in Trixi.jl, are provided in the examples/ folder.","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"Trixi.jl uses the method of lines, i.e., the full space-time discretization is separated into two steps; the spatial semidiscretization is performed at first and the resulting ODE system is solved numerically using a suitable time integration method. Thus, the main ingredients of an elixir designed to solve a PDE numerically are the spatial semidiscretization and the time integration scheme.","category":"page"},{"location":"overview/#overview-semidiscretizations","page":"Overview","title":"Semidiscretizations","text":"","category":"section"},{"location":"overview/","page":"Overview","title":"Overview","text":"Semidiscretizations are high-level descriptions of spatial discretizations specialized for certain PDEs. Trixi.jl's main focus is on hyperbolic conservation laws represented in a SemidiscretizationHyperbolic. Such semidiscretizations are usually named semi in Trixi.jl","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"(Image: semidiscretization_overview)","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"The basic building blocks of a semidiscretization are","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"a mesh describing the geometry of the domain\na set of equations describing the physical model\na solver describing the numerical approach","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"In addition, a semidiscretization bundles initial and boundary conditions, and possible source terms. These different ingredients of a semidiscretization can be configured individually and combined together. When a semidiscretization is constructed, it will create an internal cache, i.e., a collection of setup-specific data structures, that is usually passed to all lower level functions.","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"Due to Trixi.jl's modular nature using Julia's multiple dispatch features, new ingredients can be created specifically for a certain combination of other ingredients. For example, a new mesh type can be created and implemented at first only for a specific solver. Thus, there is no need to consider all possible combinations of meshes, equations, and solvers when implementing new features. This allows rapid prototyping of new ideas and is one of the main design goals behind Trixi.jl. Below is a brief overview of the availability of different features on different mesh types.","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"Feature TreeMesh StructuredMesh UnstructuredMesh2D P4estMesh DGMultiMesh Further reading\nSpatial dimension 1D, 2D, 3D 1D, 2D, 3D 2D 2D, 3D 1D, 2D, 3D \nCoordinates Cartesian curvilinear curvilinear curvilinear curvilinear \nConnectivity h-nonconforming conforming conforming h-nonconforming conforming \nElement type line, square, cube line, quadᵃ, hexᵃ quadᵃ quadᵃ, hexᵃ simplex, quadᵃ, hexᵃ \nAdaptive mesh refinement ✅ ❌ ❌ ✅ ❌ AMRCallback\nSolver type DGSEM DGSEM DGSEM DGSEM DGMulti \nDomain hypercube mapped hypercube arbitrary arbitrary arbitrary \nWeak form ✅ ✅ ✅ ✅ ✅ VolumeIntegralWeakForm\nFlux differencing ✅ ✅ ✅ ✅ ✅ VolumeIntegralFluxDifferencing\nShock capturing ✅ ✅ ✅ ✅ ❌ VolumeIntegralShockCapturingHG\nNonconservative equations ✅ ✅ ✅ ✅ ✅ e.g., GLM MHD or shallow water equations\nParabolic termsᵇ ✅ ✅ ❌ ✅ ✅ e.g., CompressibleNavierStokesDiffusion2D","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"ᵃ: quad = quadrilateral, hex = hexahedron ᵇ: Parabolic terms do not currently support adaptivity. ","category":"page"},{"location":"overview/#Time-integration-methods","page":"Overview","title":"Time integration methods","text":"","category":"section"},{"location":"overview/","page":"Overview","title":"Overview","text":"Trixi.jl is compatible with the SciML ecosystem for ordinary differential equations. In particular, a spatial semidiscretization can be wrapped in an ODE problem using semidiscretize, which returns an ODEProblem. This ODEProblem is a wrapper of Trixi.rhs!(du_ode, u_ode, semi, t), which gets called in ODE solvers. Further information can be found in the section on time integration methods.","category":"page"},{"location":"overview/#Next-steps","page":"Overview","title":"Next steps","text":"","category":"section"},{"location":"overview/","page":"Overview","title":"Overview","text":"We explicitly encourage people interested in Trixi.jl to have a look at the examples/ bundled with Trixi.jl to get an impression of what is possible and the general look and feel of Trixi.jl. Before doing that, it is usually good to get an idea of how to visualize numerical results.","category":"page"},{"location":"overview/","page":"Overview","title":"Overview","text":"If you like learning by doing, looking at the tutorials and trying to mix your own elixirs based thereon is probably a good next step. Otherwise, you can further dig into the documentation by looking at Trixi.jl's basic building blocks.","category":"page"},{"location":"callbacks/#callbacks-id","page":"Callbacks","title":"Callbacks","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Many of the advanced features of Trixi.jl, such as adaptive mesh refinement, are implemented as callbacks. A callback is an algorithmic entity that gets passed to the ODE solver and is called at specific points during execution to perform certain tasks. Callbacks in Trixi.jl are either called after each time step (step callbacks) or after each stage of the ODE solver (stage callbacks).","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"(Image: callbacks_illustration)","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"The advantage of callbacks over hard-coding all features is that it allows to extend Trixi.jl without modifying the internal source code. Trixi.jl provides callbacks for time step control, adaptive mesh refinement, I/O, and more.","category":"page"},{"location":"callbacks/#Step-callbacks","page":"Callbacks","title":"Step callbacks","text":"","category":"section"},{"location":"callbacks/#CFL-based-time-step-control","page":"Callbacks","title":"CFL-based time step control","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Time step control can be performed with a StepsizeCallback. An example making use of this can be found at examples/tree_2d_dgsem/elixir_advection_basic.jl","category":"page"},{"location":"callbacks/#Adaptive-mesh-refinement","page":"Callbacks","title":"Adaptive mesh refinement","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Trixi.jl uses a hierarchical Cartesian mesh which can be locally refined in a solution-adaptive way. This can be used to speed up simulations with minimal loss in overall accuracy. Adaptive mesh refinement (AMR) can be used by passing an AMRCallback to the ODE solver. The AMRCallback requires a controller such as ControllerThreeLevel or ControllerThreeLevelCombined to tell the AMR algorithm which cells to refine/coarsen.","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"An example elixir using AMR can be found at examples/tree_2d_dgsem/elixir_advection_amr.jl.","category":"page"},{"location":"callbacks/#Analyzing-the-numerical-solution","page":"Callbacks","title":"Analyzing the numerical solution","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"The AnalysisCallback can be used to analyze the numerical solution, e.g. calculate errors or user-specified integrals, and print the results to the screen. The results can also be saved in a file. An example can be found at examples/tree_2d_dgsem/elixir_euler_vortex.jl. Note that the errors (e.g. L2 error or Linf error) are computed with respect to the initial condition. The percentage of the simulation time refers to the ratio of the current time and the final time, i.e. it does not consider the maximal number of iterations. So the simulation could finish before 100% are reached. Note that, e.g., due to AMR or smaller time step sizes, the simulation can actually take longer than the percentage indicates. In Performance metrics of the AnalysisCallback you can find a detailed description of the different performance metrics the AnalysisCallback computes.","category":"page"},{"location":"callbacks/#I/O","page":"Callbacks","title":"I/O","text":"","category":"section"},{"location":"callbacks/#Solution-and-restart-files","page":"Callbacks","title":"Solution and restart files","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"To save the solution in regular intervals you can use a SaveSolutionCallback. It is also possible to create restart files using the SaveRestartCallback. An example making use of these can be found at examples/tree_2d_dgsem/elixir_advection_extended.jl. An example showing how to restart a simulation from a restart file can be found at examples/tree_2d_dgsem/elixir_advection_restart.jl.","category":"page"},{"location":"callbacks/#Time-series","page":"Callbacks","title":"Time series","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Sometimes it is useful to record the evaluations of state variables over time at a given set of points. This can be achieved by the TimeSeriesCallback, which is used, e.g., in examples/tree_2d_dgsem/elixir_acoustics_gaussian_source.jl. The TimeSeriesCallback constructor expects a semidiscretization and a list of points at which the solution should be recorded in regular time step intervals. After the last time step, the entire record is stored in an HDF5 file.","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"For the points, two different input formats are supported: You can either provide them as a list of tuples, which is handy if you specify them by hand on the REPL. Alternatively, you can provide them as a two-dimensional array, where the first dimension is the point number and the second dimension is the coordinate dimension. This is especially useful when reading them from a file.","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"For example, to record the primitive variables at the points (0.0, 0.0) and (-1.0, 0.5) every five timesteps and storing the collected data in the file tseries.h5, you can create the TimeSeriesCallback as","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"time_series = TimeSeriesCallback(semi, [(0.0, 0.0), (-1.0, 0.5)];\n interval=5,\n solution_variables=cons2prim,\n filename=\"tseries.h5\")","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"For a full list of possible arguments, please check the documentation for the TimeSeriesCallback. As an alternative to specifying the point coordinates directly in the elixir or on the REPL, you can read them from a file. For instance, with a text file points.dat with content","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":" 0.0 0.0\n-1.0 0.5","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"you can create a time series callback with","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"using DelimitedFiles: readdlm\ntime_series = TimeSeriesCallback(semi, readdlm(\"points.dat\"))","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"To plot the individual point data series over time, you can create a PlotData1D from the TimeSeriesCallback and a given point ID. For example, executing","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"julia> using Trixi, Plots\n\njulia> trixi_include(joinpath(examples_dir(), \"tree_2d_dgsem\", \"elixir_acoustics_gaussian_source.jl\"))\n\njulia> pd1 = PlotData1D(time_series, 1)\n\njulia> pd2 = PlotData1D(time_series, 2)\n\njulia> plot(pd1[\"p_prime\"]); plot!(pd2[\"p_prime\"], xguide=\"t\")","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"will yield the following plot:","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"(Image: image)","category":"page"},{"location":"callbacks/#Miscellaneous","page":"Callbacks","title":"Miscellaneous","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"The AliveCallback prints some information to the screen to show that a simulation is still running.\nThe SummaryCallback prints a human-readable summary of the simulation setup and controls the automated performance measurements, including an output of the recorded timers after a simulation.\nThe VisualizationCallback can be used for in-situ visualization. See Visualizing results during a simulation.\nThe TrivialCallback does nothing and can be used to easily disable some callbacks via trixi_include.","category":"page"},{"location":"callbacks/#Equation-specific-callbacks","page":"Callbacks","title":"Equation-specific callbacks","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Some callbacks provided by Trixi.jl implement specific features for certain equations:","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"The LBMCollisionCallback implements the Lattice-Boltzmann method (LBM) collision operator and should only be used when solving the Lattice-Boltzmann equations. See e.g. examples/tree_2d_dgsem/elixir_lbm_constant.jl\nThe SteadyStateCallback terminates the time integration when the residual steady state falls below a certain threshold. This checks the convergence of the potential phi for hyperbolic diffusion. See e.g. examples/tree_2d_dgsem/elixir_hypdiff_nonperiodic.jl.\nThe GlmSpeedCallback updates the divergence cleaning wave speed c_h for the ideal GLM-MHD equations. See e.g. examples/tree_2d_dgsem/elixir_mhd_alfven_wave.jl.","category":"page"},{"location":"callbacks/#Usage-of-step-callbacks","page":"Callbacks","title":"Usage of step callbacks","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Step callbacks are passed to the solve method from the ODE solver via the keyword argument callback. If you want to use a single callback cb, pass it as callback=cb. When using two or more callbacks, you need to turn them into a CallbackSet first by calling callbacks = CallbackSet(cb1, cb2) and passing it as callback=callbacks.","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"note: Note\nThere are some restrictions regarding the order of callbacks in a CallbackSet.The callbacks are called after each time step but some callbacks actually belong to the next time step. Therefore, the callbacks should be ordered in the following way:Callbacks that belong to the current time step:\nSummaryCallback controls, among other things, timers and should thus be first\nSteadyStateCallback may mark a time step as the last one\nAnalysisCallback may do some checks that mark a time step as the last one\nAliveCallback should be nearby AnalysisCallback\nSaveSolutionCallback/SaveRestartCallback should save the current solution before it is degraded by AMR\nVisualizationCallback should be called before the mesh is adapted\nCallbacks that belong to the next time step:\nAMRCallback\nStepsizeCallback must be called after AMRCallback to accommodate potential changes to the mesh\nGlmSpeedCallback must be called after StepsizeCallback because the step size affects the value of c_h\nLBMCollisionCallback is already part of the calculations of the next time step and should therefore be called after StepsizeCallback","category":"page"},{"location":"callbacks/#Stage-callbacks","page":"Callbacks","title":"Stage callbacks","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"PositivityPreservingLimiterZhangShu is a positivity-preserving limiter, used to enforce physical constraints. An example elixir using this feature can be found at examples/tree_2d_dgsem/elixir_euler_positivity.jl.","category":"page"},{"location":"callbacks/#Implementing-new-callbacks","page":"Callbacks","title":"Implementing new callbacks","text":"","category":"section"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"Since Trixi.jl is compatible with OrdinaryDiffEq.jl, both packages share the same callback interface. A detailed description of it can be found in the OrdinaryDiffEq.jl documentation. Step callbacks are just called callbacks. Stage callbacks are called stage_limiter!.","category":"page"},{"location":"callbacks/","page":"Callbacks","title":"Callbacks","text":"An example elixir showing how to implement a new simple stage callback and a new simple step callback can be found at examples/tree_2d_dgsem/elixir_advection_callbacks.jl.","category":"page"},{"location":"#Trixi.jl","page":"Home","title":"Trixi.jl","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"(Image: Docs-stable) (Image: Docs-dev) (Image: Slack) (Image: Youtube) (Image: Build Status) (Image: Codecov) (Image: Coveralls) (Image: Aqua QA) (Image: License: MIT) (Image: DOI)","category":"page"},{"location":"","page":"Home","title":"Home","text":"Trixi.jl is a numerical simulation framework for hyperbolic conservation laws written in Julia. A key objective for the framework is to be useful to both scientists and students. Therefore, next to having an extensible design with a fast implementation, Trixi.jl is focused on being easy to use for new or inexperienced users, including the installation and postprocessing procedures. Its features include:","category":"page"},{"location":"","page":"Home","title":"Home","text":"1D, 2D, and 3D simulations on line/quad/hex/simplex meshes\nCartesian and curvilinear meshes\nConforming and non-conforming meshes\nStructured and unstructured meshes\nHierarchical quadtree/octree grid with adaptive mesh refinement\nForests of quadtrees/octrees with p4est via P4est.jl\nHigh-order accuracy in space and time\nDiscontinuous Galerkin methods\nKinetic energy-preserving and entropy-stable methods based on flux differencing\nEntropy-stable shock capturing\nPositivity-preserving limiting\nFinite difference summation by parts (SBP) methods\nCompatible with the SciML ecosystem for ordinary differential equations\nExplicit low-storage Runge-Kutta time integration\nStrong stability preserving methods\nCFL-based and error-based time step control\nNative support for differentiable programming\nForward mode automatic differentiation via ForwardDiff.jl\nPeriodic and weakly-enforced boundary conditions\nMultiple governing equations:\nCompressible Euler equations\nMagnetohydrodynamics (MHD) equations\nMulti-component compressible Euler and MHD equations\nLinearized Euler and acoustic perturbation equations\nHyperbolic diffusion equations for elliptic problems\nLattice-Boltzmann equations (D2Q9 and D3Q27 schemes)\nShallow water equations\nScalar advection\nMulti-physics simulations\nSelf-gravitating gas dynamics\nShared-memory parallelization via multithreading\nVisualization and postprocessing of the results\nIn-situ and a posteriori visualization with Plots.jl\nInteractive visualization with Makie.jl\nPostprocessing with ParaView/VisIt via Trixi2Vtk","category":"page"},{"location":"#Installation","page":"Home","title":"Installation","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"If you have not yet installed Julia, please follow the instructions for your operating system. Trixi.jl works with Julia v1.8 and newer. We recommend using the latest stable release of Julia.","category":"page"},{"location":"#For-users","page":"Home","title":"For users","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"Trixi.jl and its related tools are registered Julia packages. Hence, you can install Trixi.jl, the visualization tool Trixi2Vtk, OrdinaryDiffEq.jl, and Plots.jl by executing the following commands in the Julia REPL:","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> using Pkg\n\njulia> Pkg.add([\"Trixi\", \"Trixi2Vtk\", \"OrdinaryDiffEq\", \"Plots\"])","category":"page"},{"location":"","page":"Home","title":"Home","text":"You can copy and paste all commands to the REPL including the leading julia> prompts - they will automatically be stripped away by Julia. The package OrdinaryDiffEq.jl provides time integration schemes used by Trixi.jl, while Plots.jl can be used to directly visualize Trixi.jl's results from the REPL.","category":"page"},{"location":"","page":"Home","title":"Home","text":"Note on package versions: If some of the examples for how to use Trixi.jl do not work, verify that you are using a recent Trixi.jl release by comparing the installed Trixi.jl version from","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> using Pkg; Pkg.update(\"Trixi\"); Pkg.status(\"Trixi\")","category":"page"},{"location":"","page":"Home","title":"Home","text":"to the latest release. If the installed version does not match the current release, please check the Troubleshooting section.","category":"page"},{"location":"","page":"Home","title":"Home","text":"The commands above can also be used to update Trixi.jl. A brief list of notable changes to Trixi.jl is available in NEWS.md.","category":"page"},{"location":"#for-developers","page":"Home","title":"For developers","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"If you plan on editing Trixi.jl itself, you can download Trixi.jl to a local folder and use the code from the cloned directory:","category":"page"},{"location":"","page":"Home","title":"Home","text":"git clone git@github.com:trixi-framework/Trixi.jl.git\ncd Trixi.jl\nmkdir run\ncd run\njulia --project=. -e 'using Pkg; Pkg.develop(PackageSpec(path=\"..\"))'","category":"page"},{"location":"","page":"Home","title":"Home","text":"If you installed Trixi.jl this way, you always have to start Julia with the --project flag set to your run directory, e.g.,","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia --project=.","category":"page"},{"location":"","page":"Home","title":"Home","text":"if already inside the run directory.","category":"page"},{"location":"","page":"Home","title":"Home","text":"The advantage of using a separate run directory is that you can also add other related packages (see below, e.g., for time integration or visualization) to the project in the run folder and always have a reproducible environment at hand to share with others.","category":"page"},{"location":"","page":"Home","title":"Home","text":"Since the postprocessing tool Trixi2Vtk.jl typically does not need to be modified, it is recommended to install it as a normal package. Likewise, you can install OrdinaryDiffEq.jl and Plots.jl as ordinary packages. To achieve this, use the following REPL commands:","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> using Pkg\n\njulia> Pkg.add([\"OrdinaryDiffEq\", \"Trixi2Vtk\", \"Plots\"])","category":"page"},{"location":"","page":"Home","title":"Home","text":"Note that the postprocessing tools Trixi2Vtk.jl and Plots.jl are optional and can be omitted.","category":"page"},{"location":"#Example:-Installing-Trixi.jl-as-a-package","page":"Home","title":"Example: Installing Trixi.jl as a package","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":" ","category":"page"},{"location":"","page":"Home","title":"Home","text":"Please note that the playback speed is set to 3x, thus the entire installation procedure lasts around 45 seconds in real time (depending on the performance of your computer and on how many dependencies had already been installed before).","category":"page"},{"location":"#Usage","page":"Home","title":"Usage","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"In the Julia REPL, first load the package Trixi.jl","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> using Trixi","category":"page"},{"location":"","page":"Home","title":"Home","text":"Then start a simulation by executing","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> trixi_include(default_example())","category":"page"},{"location":"","page":"Home","title":"Home","text":"Please be patient since Julia will compile the code just before running it. To visualize the results, load the package Plots","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> using Plots","category":"page"},{"location":"","page":"Home","title":"Home","text":"and generate a heatmap plot of the results with","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> plot(sol) # No trailing semicolon, otherwise no plot is shown","category":"page"},{"location":"","page":"Home","title":"Home","text":"This will open a new window with a 2D visualization of the final solution:","category":"page"},{"location":"","page":"Home","title":"Home","text":"(Image: image)","category":"page"},{"location":"","page":"Home","title":"Home","text":"The method trixi_include(...) expects a single string argument with the path to a Trixi.jl elixir, i.e., a text file containing Julia code necessary to set up and run a simulation. To quickly see Trixi.jl in action, default_example() returns the path to an example elixir with a short, two-dimensional problem setup. A list of all example elixirs packaged with Trixi.jl can be obtained by running get_examples(). Alternatively, you can also browse the examples/ subdirectory. If you want to modify one of the elixirs to set up your own simulation, download it to your machine, edit the configuration, and pass the file path to trixi_include(...).","category":"page"},{"location":"#Example:-Running-a-simulation-with-Trixi.jl","page":"Home","title":"Example: Running a simulation with Trixi.jl","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":" ","category":"page"},{"location":"","page":"Home","title":"Home","text":"If this produces weird symbols or question marks in the terminal on your system, you are probably using Mac OS with problematic fonts. In that case, please check the Troubleshooting section.","category":"page"},{"location":"","page":"Home","title":"Home","text":"Note on performance: Julia uses just-in-time compilation to transform its source code to native, optimized machine code at the time of execution and caches the compiled methods for further use. That means that the first execution of a Julia method is typically slow, with subsequent runs being much faster. For instance, in the example above the first execution of trixi_include takes about 20 seconds, while subsequent runs require less than 60 milliseconds.","category":"page"},{"location":"#Performing-a-convergence-analysis","page":"Home","title":"Performing a convergence analysis","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"To automatically determine the experimental order of convergence (EOC) for a given setup, execute","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> convergence_test(default_example(), 4)","category":"page"},{"location":"","page":"Home","title":"Home","text":"This will run a convergence test with the elixir default_example(), using four iterations with different initial refinement levels. The initial iteration will use the elixir unchanged, while for each subsequent iteration the initial_refinement_level parameter is incremented by one. Finally, the measured l^2 and l^infty errors and the determined EOCs will be displayed like this:","category":"page"},{"location":"","page":"Home","title":"Home","text":"[...]\nl2\nscalar\nerror EOC\n9.14e-06 -\n5.69e-07 4.01\n3.55e-08 4.00\n2.22e-09 4.00\n\nmean 4.00\n--------------------------------------------------------------------------------\nlinf\nscalar\nerror EOC\n6.44e-05 -\n4.11e-06 3.97\n2.58e-07 3.99\n1.62e-08 4.00\n\nmean 3.99\n--------------------------------------------------------------------------------","category":"page"},{"location":"","page":"Home","title":"Home","text":"An example with multiple variables looks like this:","category":"page"},{"location":"","page":"Home","title":"Home","text":"julia> convergence_test(joinpath(examples_dir(), \"tree_2d_dgsem\", \"elixir_euler_source_terms.jl\"), 3)","category":"page"},{"location":"","page":"Home","title":"Home","text":"[...]\nl2\nrho rho_v1 rho_v2 rho_e\nerror EOC error EOC error EOC error EOC\n9.32e-07 - 1.42e-06 - 1.42e-06 - 4.82e-06 -\n7.03e-08 3.73 9.53e-08 3.90 9.53e-08 3.90 3.30e-07 3.87\n4.65e-09 3.92 6.09e-09 3.97 6.09e-09 3.97 2.12e-08 3.96\n\nmean 3.82 mean 3.93 mean 3.93 mean 3.91\n--------------------------------------------------------------------------------\nlinf\nrho rho_v1 rho_v2 rho_e\nerror EOC error EOC error EOC error EOC\n9.58e-06 - 1.17e-05 - 1.17e-05 - 4.89e-05 -\n6.23e-07 3.94 7.48e-07 3.97 7.48e-07 3.97 3.22e-06 3.92\n4.05e-08 3.94 4.97e-08 3.91 4.97e-08 3.91 2.10e-07 3.94\n\nmean 3.94 mean 3.94 mean 3.94 mean 3.93\n--------------------------------------------------------------------------------","category":"page"},{"location":"#Showcase-of-advanced-features","page":"Home","title":"Showcase of advanced features","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"The presentation From Mesh Generation to Adaptive Simulation: A Journey in Julia, originally given as part of JuliaCon 2022, outlines how to use Trixi.jl for an adaptive simulation of the compressible Euler equations in two spatial dimensions on a complex domain. More details as well as code to run the simulation presented can be found at the reproducibility repository for the presentation.","category":"page"},{"location":"#Referencing","page":"Home","title":"Referencing","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"If you use Trixi.jl in your own research or write a paper using results obtained with the help of Trixi.jl, please cite the following articles:","category":"page"},{"location":"","page":"Home","title":"Home","text":"@article{ranocha2022adaptive,\n title={Adaptive numerical simulations with {T}rixi.jl:\n {A} case study of {J}ulia for scientific computing},\n author={Ranocha, Hendrik and Schlottke-Lakemper, Michael and Winters, Andrew Ross\n and Faulhaber, Erik and Chan, Jesse and Gassner, Gregor},\n journal={Proceedings of the JuliaCon Conferences},\n volume={1},\n number={1},\n pages={77},\n year={2022},\n doi={10.21105/jcon.00077},\n eprint={2108.06476},\n eprinttype={arXiv},\n eprintclass={cs.MS}\n}\n\n@article{schlottkelakemper2021purely,\n title={A purely hyperbolic discontinuous {G}alerkin approach for\n self-gravitating gas dynamics},\n author={Schlottke-Lakemper, Michael and Winters, Andrew R and\n Ranocha, Hendrik and Gassner, Gregor J},\n journal={Journal of Computational Physics},\n pages={110467},\n year={2021},\n month={06},\n volume={442},\n publisher={Elsevier},\n doi={10.1016/j.jcp.2021.110467},\n eprint={2008.10593},\n eprinttype={arXiv},\n eprintclass={math.NA}\n}","category":"page"},{"location":"","page":"Home","title":"Home","text":"In addition, you can also refer to Trixi.jl directly as","category":"page"},{"location":"","page":"Home","title":"Home","text":"@misc{schlottkelakemper2020trixi,\n title={{T}rixi.jl: {A}daptive high-order numerical simulations\n of hyperbolic {PDE}s in {J}ulia},\n author={Schlottke-Lakemper, Michael and Gassner, Gregor J and\n Ranocha, Hendrik and Winters, Andrew R and Chan, Jesse},\n year={2021},\n month={09},\n howpublished={\\url{https://github.com/trixi-framework/Trixi.jl}},\n doi={10.5281/zenodo.3996439}\n}","category":"page"},{"location":"#authors-index-md","page":"Home","title":"Authors","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"Trixi.jl was initiated by Michael Schlottke-Lakemper (RWTH Aachen University/High-Performance Computing Center Stuttgart (HLRS), Germany) and Gregor Gassner (University of Cologne, Germany). Together with Hendrik Ranocha (Johannes Gutenberg University Mainz, Germany) and Andrew Winters (Linköping University, Sweden), and Jesse Chan (Rice University, US), they are the principal developers of Trixi.jl. The full list of contributors can be found under Authors.","category":"page"},{"location":"#License-and-contributing","page":"Home","title":"License and contributing","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"Trixi.jl is licensed under the MIT license (see License). Since Trixi.jl is an open-source project, we are very happy to accept contributions from the community. Please refer to Contributing for more details. Note that we strive to be a friendly, inclusive open-source community and ask all members of our community to adhere to our Code of Conduct. To get in touch with the developers, join us on Slack or create an issue.","category":"page"},{"location":"#Acknowledgments","page":"Home","title":"Acknowledgments","text":"","category":"section"},{"location":"","page":"Home","title":"Home","text":"

\n \n

","category":"page"},{"location":"","page":"Home","title":"Home","text":"This project has benefited from funding by the Deutsche Forschungsgemeinschaft (DFG, German Research Foundation) through the following grants:","category":"page"},{"location":"","page":"Home","title":"Home","text":"Excellence Strategy EXC 2044-390685587, Mathematics Münster: Dynamics-Geometry-Structure.\nResearch unit FOR 5409 \"Structure-Preserving Numerical Methods for Bulk- and Interface Coupling of Heterogeneous Models (SNuBIC)\" (project number 463312734).\nIndividual grant no. 528753982.","category":"page"},{"location":"","page":"Home","title":"Home","text":"This project has benefited from funding from the European Research Council through the ERC Starting Grant \"An Exascale aware and Un-crashable Space-Time-Adaptive Discontinuous Spectral Element Solver for Non-Linear Conservation Laws\" (Extreme), ERC grant agreement no. 714487.","category":"page"},{"location":"","page":"Home","title":"Home","text":"This project has benefited from funding from Vetenskapsrådet (VR, Swedish Research Council), Sweden through the VR Starting Grant \"Shallow water flows including sediment transport and morphodynamics\", VR grant agreement 2020-03642 VR.","category":"page"},{"location":"","page":"Home","title":"Home","text":"This project has benefited from funding from the United States National Science Foundation (NSF) under awards DMS-1719818 and DMS-1943186.","category":"page"},{"location":"","page":"Home","title":"Home","text":"This project has benefited from funding from the German Federal Ministry of Education and Research (BMBF) through the project grant \"Adaptive earth system modeling with significantly reduced computation time for exascale supercomputers (ADAPTEX)\" (funding id: 16ME0668K).","category":"page"},{"location":"","page":"Home","title":"Home","text":"Trixi.jl is supported by NumFOCUS as an Affiliated Project.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"EditURL = \"../../literate/src/files/adding_nonconservative_equation.jl\"","category":"page"},{"location":"tutorials/adding_nonconservative_equation/#adding_nonconservative_equation","page":"9 Adding a non-conservative equation","title":"9: Adding a non-conservative equation","text":"","category":"section"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"If you want to use Trixi.jl for your own research, you might be interested in a new physics model that is not present in Trixi.jl. In this tutorial, we will implement the nonconservative linear advection equation in a periodic domain","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"left\nbeginalignedpartial_t u(tx) + a(x) partial_x u(tx) = 0 \nu(0x)=sin(x) \nu(t-pi)=u(tpi)\nendaligned\nright","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"where a(x) = 2 + cos(x). The analytic solution is","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"u(tx)=-sin left(2 tan ^-1left(sqrt3 tan left(fracsqrt3 t2-tan ^-1left(frac1sqrt3tan left(fracx2right)right)right)right)right)","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"In Trixi.jl, such a mathematical model is encoded as a subtype of Trixi.AbstractEquations.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/#Basic-setup","page":"9 Adding a non-conservative equation","title":"Basic setup","text":"","category":"section"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"Since there is no native support for variable coefficients, we need to transform the PDE to the following system:","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"left\nbeginalignedpartial_t beginpmatrixu(tx)a(tx) endpmatrix +beginpmatrix a(tx) partial_x u(tx) 0 endpmatrix = 0 \nu(0x)=sin(x) \na(0x)=2+cos(x) \nu(t-pi)=u(tpi)\nendaligned\nright","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"# Define new physics\nusing Trixi\nusing Trixi: AbstractEquations, get_node_vars\nimport Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,\n have_nonconservative_terms\n\n# Since there is no native support for variable coefficients, we use two\n# variables: one for the basic unknown `u` and another one for the coefficient `a`\nstruct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,\n 2 #= two variables (u,a) =#}\nend\n\nvarnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = (\"scalar\", \"advection_velocity\")\n\ndefault_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()\n\n\n# The conservative part of the flux is zero\nflux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)\n\n# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation\nfunction max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)\n _, advection_velocity_ll = u_ll\n _, advection_velocity_rr = u_rr\n\n return max(abs(advection_velocity_ll), abs(advection_velocity_rr))\nend\n\n\n# We use nonconservative terms\nhave_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()\n\n# This \"nonconservative numerical flux\" implements the nonconservative terms.\n# In general, nonconservative terms can be written in the form\n# g(u) ∂ₓ h(u)\n# Thus, a discrete difference approximation of this nonconservative term needs\n# - `u mine`: the value of `u` at the current position (for g(u))\n# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))\nfunction flux_nonconservative(u_mine, u_other, orientation,\n equations::NonconservativeLinearAdvectionEquation)\n _, advection_velocity = u_mine\n scalar, _ = u_other\n\n return SVector(advection_velocity * scalar, zero(scalar))\nend","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"The implementation of nonconservative terms uses a single \"nonconservative flux\" function flux_nonconservative. It will basically be applied in a loop of the form","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"du_m(D, u) = sum(D[m, l] * flux_nonconservative(u[m], u[l], 1, equations)) # orientation 1: x","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"where D is the derivative matrix and u contains the nodal solution values.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"Now, we can run a simple simulation using a DGSEM discretization.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"# Create a simulation setup\nusing Trixi\nusing OrdinaryDiffEq\n\nequation = NonconservativeLinearAdvectionEquation()\n\n# You can derive the exact solution for this setup using the method of\n# characteristics\nfunction initial_condition_sine(x, t, equation::NonconservativeLinearAdvectionEquation)\n x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))\n scalar = sin(x0)\n advection_velocity = 2 + cos(x[1])\n SVector(scalar, advection_velocity)\nend\n\n# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries\nmesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n initial_refinement_level=4, n_cells_max=10^4)\n\n# Create a DGSEM solver with polynomials of degree `polydeg`\n# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`\n# as `surface_flux` and `volume_flux` when working with nonconservative terms\nvolume_flux = (flux_central, flux_nonconservative)\nsurface_flux = (flux_lax_friedrichs, flux_nonconservative)\nsolver = DGSEM(polydeg=3, surface_flux=surface_flux,\n volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n\n# Setup the spatial semidiscretization containing all ingredients\nsemi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n\n# Create an ODE problem with given time span\ntspan = (0.0, 1.0)\node = semidiscretize(semi, tspan)\n\n# Set up some standard callbacks summarizing the simulation setup and computing\n# errors of the numerical solution\nsummary_callback = SummaryCallback()\nanalysis_callback = AnalysisCallback(semi, interval=50)\ncallbacks = CallbackSet(summary_callback, analysis_callback)\n\n# OrdinaryDiffEq's `solve` method evolves the solution in time and executes\n# the passed callbacks\nsol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n save_everystep=false, callback=callbacks)\n\n# Print the timer summary\nsummary_callback()\n\n# Plot the numerical solution at the final time\nusing Plots: plot\nplot(sol)","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"You see a plot of the final solution.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"We can check whether everything fits together by refining the grid and comparing the numerical errors. First, we look at the error using the grid resolution above.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"error_1 = analysis_callback(sol).l2 |> first","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"Next, we increase the grid resolution by one refinement level and run the simulation again.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n initial_refinement_level=5, n_cells_max=10^4)\n\nsemi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n\ntspan = (0.0, 1.0)\node = semidiscretize(semi, tspan);\n\nsummary_callback = SummaryCallback()\nanalysis_callback = AnalysisCallback(semi, interval=50)\ncallbacks = CallbackSet(summary_callback, analysis_callback);\n\nsol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n save_everystep=false, callback=callbacks);\nsummary_callback()\n\nerror_2 = analysis_callback(sol).l2 |> first","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"error_1 / error_2","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"As expected, the new error is roughly reduced by a factor of 16, corresponding to an experimental order of convergence of 4 (for polynomials of degree 3).","category":"page"},{"location":"tutorials/adding_nonconservative_equation/#Summary-of-the-code","page":"9 Adding a non-conservative equation","title":"Summary of the code","text":"","category":"section"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"Here is the complete code that we used (without the callbacks since these create a lot of unnecessary output in the doctests of this tutorial). In addition, we create the struct inside the new module NonconservativeLinearAdvection. That ensures that we can re-create structs defined therein without having to restart Julia.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"Define new physics","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"module NonconservativeLinearAdvection\n\nusing Trixi\nusing Trixi: AbstractEquations, get_node_vars\nimport Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,\n have_nonconservative_terms\n\n# Since there is not yet native support for variable coefficients, we use two\n# variables: one for the basic unknown `u` and another one for the coefficient `a`\nstruct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,\n 2 #= two variables (u,a) =#}\nend\n\nvarnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = (\"scalar\", \"advection_velocity\")\n\ndefault_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()\n\n\n# The conservative part of the flux is zero\nflux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)\n\n# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation\nfunction max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)\n _, advection_velocity_ll = u_ll\n _, advection_velocity_rr = u_rr\n\n return max(abs(advection_velocity_ll), abs(advection_velocity_rr))\nend\n\n\n# We use nonconservative terms\nhave_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()\n\n# This \"nonconservative numerical flux\" implements the nonconservative terms.\n# In general, nonconservative terms can be written in the form\n# g(u) ∂ₓ h(u)\n# Thus, a discrete difference approximation of this nonconservative term needs\n# - `u mine`: the value of `u` at the current position (for g(u))\n# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))\nfunction flux_nonconservative(u_mine, u_other, orientation,\n equations::NonconservativeLinearAdvectionEquation)\n _, advection_velocity = u_mine\n scalar, _ = u_other\n\n return SVector(advection_velocity * scalar, zero(scalar))\nend\n\nend # module\n\n\n\n# Create a simulation setup\nimport .NonconservativeLinearAdvection\nusing Trixi\nusing OrdinaryDiffEq\n\nequation = NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation()\n\n# You can derive the exact solution for this setup using the method of\n# characteristics\nfunction initial_condition_sine(x, t, equation::NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation)\n x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))\n scalar = sin(x0)\n advection_velocity = 2 + cos(x[1])\n SVector(scalar, advection_velocity)\nend\n\n# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries\nmesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n initial_refinement_level=4, n_cells_max=10^4)\n\n# Create a DGSEM solver with polynomials of degree `polydeg`\n# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`\n# as `surface_flux` and `volume_flux` when working with nonconservative terms\nvolume_flux = (flux_central, NonconservativeLinearAdvection.flux_nonconservative)\nsurface_flux = (flux_lax_friedrichs, NonconservativeLinearAdvection.flux_nonconservative)\nsolver = DGSEM(polydeg=3, surface_flux=surface_flux,\n volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n\n# Setup the spatial semidiscretization containing all ingredients\nsemi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n\n# Create an ODE problem with given time span\ntspan = (0.0, 1.0)\node = semidiscretize(semi, tspan);\n\n# Set up some standard callbacks summarizing the simulation setup and computing\n# errors of the numerical solution\nsummary_callback = SummaryCallback()\nanalysis_callback = AnalysisCallback(semi, interval=50)\ncallbacks = CallbackSet(summary_callback, analysis_callback);\n\n# OrdinaryDiffEq's `solve` method evolves the solution in time and executes\n# the passed callbacks\nsol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n save_everystep=false);\n\n# Plot the numerical solution at the final time\nusing Plots: plot\nplot(sol);\nnothing #hide","category":"page"},{"location":"tutorials/adding_nonconservative_equation/#Package-versions","page":"9 Adding a non-conservative equation","title":"Package versions","text":"","category":"section"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"","category":"page"},{"location":"tutorials/adding_nonconservative_equation/","page":"9 Adding a non-conservative equation","title":"9 Adding a non-conservative equation","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"EditURL = \"../../literate/src/files/differentiable_programming.jl\"","category":"page"},{"location":"tutorials/differentiable_programming/#differentiable_programming","page":"16 Differentiable programming","title":"16: Differentiable programming","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Julia and its ecosystem provide some tools for differentiable programming. Trixi.jl is designed to be flexible, extendable, and composable with Julia's growing ecosystem for scientific computing and machine learning. Thus, the ultimate goal is to have fast implementations that allow automatic differentiation (AD) without too much hassle for users. If some parts do not meet these requirements, please feel free to open an issue or propose a fix in a PR.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"In the following, we will walk through some examples demonstrating how to differentiate through Trixi.jl.","category":"page"},{"location":"tutorials/differentiable_programming/#Forward-mode-automatic-differentiation","page":"16 Differentiable programming","title":"Forward mode automatic differentiation","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Trixi.jl integrates well with ForwardDiff.jl for forward mode AD.","category":"page"},{"location":"tutorials/differentiable_programming/#Computing-the-Jacobian","page":"16 Differentiable programming","title":"Computing the Jacobian","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"The high-level interface to compute the Jacobian this way is jacobian_ad_forward. First, we load the required packages and compute the Jacobian of a semidiscretization of the compressible Euler equations, a system of nonlinear conservation laws.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, LinearAlgebra, Plots\n\nequations = CompressibleEulerEquations2D(1.4)\n\nsolver = DGSEM(3, flux_central)\nmesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n\nJ = jacobian_ad_forward(semi);\nsize(J)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Next, we compute the eigenvalues of the Jacobian.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ = eigvals(J)\nscatter(real.(λ), imag.(λ), label=\"central flux\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"As you can see here, the maximal real part is close to zero.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"relative_maximum = maximum(real, λ) / maximum(abs, λ)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Interestingly, if we add dissipation by switching to the flux_lax_friedrichs at the interfaces, the maximal real part of the eigenvalues increases.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"solver = DGSEM(3, flux_lax_friedrichs)\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n\nJ = jacobian_ad_forward(semi)\nλ = eigvals(J)\n\nscatter!(real.(λ), imag.(λ), label=\"Lax-Friedrichs flux\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Although the maximal real part is still somewhat small, it's larger than for the purely central discretization.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"relative_maximum = maximum(real, λ) / maximum(abs, λ)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"However, we should be careful when using this analysis, since the eigenvectors are not necessarily well-conditioned.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ, V = eigen(J)\ncondition_number = cond(V)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"In one space dimension, the situation is a bit different.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"equations = CompressibleEulerEquations1D(1.4)\n\nsolver = DGSEM(3, flux_central)\nmesh = TreeMesh((-1.0,), (1.0,), initial_refinement_level=6, n_cells_max=10^5)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n\nJ = jacobian_ad_forward(semi)\n\nλ = eigvals(J)\n\nscatter(real.(λ), imag.(λ), label=\"central flux\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Here, the maximal real part is basically zero to machine accuracy.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"relative_maximum = maximum(real, λ) / maximum(abs, λ)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Moreover, the eigenvectors are not as ill-conditioned as in 2D.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ, V = eigen(J)\ncondition_number = cond(V)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"If we add dissipation, the maximal real part is still approximately zero.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"solver = DGSEM(3, flux_lax_friedrichs)\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n\nJ = jacobian_ad_forward(semi)\nλ = eigvals(J)\n\nscatter!(real.(λ), imag.(λ), label=\"Lax-Friedrichs flux\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"As you can see from the plot generated above, the maximal real part is still basically zero to machine precision.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"relative_maximum = maximum(real, λ) / maximum(abs, λ)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Let's check the condition number of the eigenvectors.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ, V = eigen(J)\n\ncondition_number = cond(V)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Note that the condition number of the eigenvector matrix increases but is still smaller than for the example in 2D.","category":"page"},{"location":"tutorials/differentiable_programming/#Computing-other-derivatives","page":"16 Differentiable programming","title":"Computing other derivatives","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"It is also possible to compute derivatives of other dependencies using AD in Trixi.jl. For example, you can compute the gradient of an entropy-dissipative semidiscretization with respect to the ideal gas constant of the compressible Euler equations as described in the following. This example is also available as the elixir examples/special_elixirs/elixir_euler_ad.jl","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"First, we create a semidiscretization of the compressible Euler equations.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, LinearAlgebra, ForwardDiff\n\nequations = CompressibleEulerEquations2D(1.4)\n\n\"\"\"\n initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)\n\nThe classical isentropic vortex test case of\n- Chi-Wang Shu (1997)\n Essentially Non-Oscillatory and Weighted Essentially Non-Oscillatory\n Schemes for Hyperbolic Conservation Laws\n [NASA/CR-97-206253](https://ntrs.nasa.gov/citations/19980007543)\n\"\"\"\nfunction initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)\n inicenter = SVector(0.0, 0.0) # initial center of the vortex\n iniamplitude = 5.0 # size and strength of the vortex\n\n rho = 1.0 # base flow\n v1 = 1.0\n v2 = 1.0\n vel = SVector(v1, v2)\n p = 25.0\n\n rt = p / rho # ideal gas equation\n t_loc = 0.0\n\n cent = inicenter + vel*t_loc # shift advection of center to handle periodic BC, but only for v1 = v2 = 1.0\n cent = x - cent # distance to center point\n cent = SVector(-cent[2], cent[1])\n\n r2 = cent[1]^2 + cent[2]^2\n du = iniamplitude / (2*π) * exp(0.5 * (1 - r2)) # vel. perturbation\n dtemp = -(equations.gamma - 1) / (2 * equations.gamma * rt) * du^2 # isentropic\n\n rho = rho * (1 + dtemp)^(1 / (equations.gamma - 1))\n vel = vel + du * cent\n v1, v2 = vel\n p = p * (1 + dtemp)^(equations.gamma / (equations.gamma - 1))\n\n prim = SVector(rho, v1, v2, p)\n return prim2cons(prim, equations)\nend\n\nmesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n\nsolver = DGSEM(3, flux_lax_friedrichs, VolumeIntegralFluxDifferencing(flux_ranocha))\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_isentropic_vortex, solver)\n\nu0_ode = Trixi.compute_coefficients(0.0, semi)\nsize(u0_ode)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Next, we compute the Jacobian using ForwardDiff.jacobian.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"J = ForwardDiff.jacobian((du_ode, γ) -> begin\n equations_inner = CompressibleEulerEquations2D(first(γ))\n semi_inner = Trixi.remake(semi, equations=equations_inner, uEltype=eltype(γ))\n Trixi.rhs!(du_ode, u0_ode, semi_inner, 0.0)\nend, similar(u0_ode), [1.4]); # γ needs to be an `AbstractArray`\n\nround.(extrema(J), sigdigits=2)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Note that we create a semidiscretization semi at first to determine the state u0_ode around which we want to perform the linearization. Next, we wrap the RHS evaluation inside a closure and pass that to ForwardDiff.jacobian. There, we need to make sure that the internal caches are able to store dual numbers from ForwardDiff.jl by setting uEltype appropriately. A similar approach is used by jacobian_ad_forward.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Note that the ideal gas constant does not influence the semidiscrete rate of change of the density, as demonstrated by","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"norm(J[1:4:end])","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Here, we used some knowledge about the internal memory layout of Trixi.jl, an array of structs with the conserved variables as fastest-varying index in memory.","category":"page"},{"location":"tutorials/differentiable_programming/#Differentiating-through-a-complete-simulation","page":"16 Differentiable programming","title":"Differentiating through a complete simulation","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"It is also possible to differentiate through a complete simulation. As an example, let's differentiate the total energy of a simulation using the linear scalar advection equation with respect to the wave number (frequency) of the initial data.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, OrdinaryDiffEq, ForwardDiff, Plots\n\nfunction energy_at_final_time(k) # k is the wave number of the initial condition\n equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\n solver = DGSEM(3, flux_lax_friedrichs)\n initial_condition = (x, t, equation) -> begin\n x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n return SVector(sinpi(k * sum(x_trans)))\n end\n semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n uEltype=typeof(k))\n ode = semidiscretize(semi, (0.0, 1.0))\n sol = solve(ode, BS3(), save_everystep=false)\n Trixi.integrate(energy_total, sol.u[end], semi)\nend\n\nk_values = range(0.9, 1.1, length=101)\n\nplot(k_values, energy_at_final_time.(k_values), label=\"Energy\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"You see a plot of a curve that resembles a parabola with local maximum around k = 1.0. Why's that? Well, the domain is fixed but the wave number changes. Thus, if the wave number is not chosen as an integer, the initial condition will not be a smooth periodic function in the given domain. Hence, the dissipative surface flux (flux_lax_friedrichs in this example) will introduce more dissipation. In particular, it will introduce more dissipation for \"less smooth\" initial data, corresponding to wave numbers k further away from integers.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"We can compute the discrete derivative of the energy at the final time with respect to the wave number k as follows.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"round(ForwardDiff.derivative(energy_at_final_time, 1.0), sigdigits=2)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"This is rather small and we can treat it as zero in comparison to the value of this derivative at other wave numbers k.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"dk_values = ForwardDiff.derivative.((energy_at_final_time,), k_values);\n\nplot(k_values, dk_values, label=\"Derivative\")","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"If you remember basic calculus, a sufficient condition for a local maximum is that the first derivative vanishes and the second derivative is negative. We can also check this discretely.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"second_derivative = round(ForwardDiff.derivative(\n k -> Trixi.ForwardDiff.derivative(energy_at_final_time, k), 1.0),\n sigdigits=2)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Having seen this application, let's break down what happens step by step.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"function energy_at_final_time(k) # k is the wave number of the initial condition\n equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\n solver = DGSEM(3, flux_lax_friedrichs)\n initial_condition = (x, t, equation) -> begin\n x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n return SVector(sinpi(k * sum(x_trans)))\n end\n semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n uEltype=typeof(k))\n ode = semidiscretize(semi, (0.0, 1.0))\n sol = solve(ode, BS3(), save_everystep=false)\n Trixi.integrate(energy_total, sol.u[end], semi)\nend\n\nk = 1.0\nround(ForwardDiff.derivative(energy_at_final_time, k), sigdigits=2)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"When calling ForwardDiff.derivative(energy_at_final_time, k) with k=1.0, ForwardDiff.jl will basically use the chain rule and known derivatives of existing basic functions to calculate the derivative of the energy at the final time with respect to the wave number k at k0 = 1.0. To do this, ForwardDiff.jl uses dual numbers, which basically store the result and its derivative w.r.t. a specified parameter at the same time. Thus, we need to make sure that we can treat these ForwardDiff.Dual numbers everywhere during the computation. Fortunately, generic Julia code usually supports these operations. The most basic problem for a developer is to ensure that all types are generic enough, in particular the ones of internal caches.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"The first step in this example creates some basic ingredients of our simulation.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\nmesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\nsolver = DGSEM(3, flux_lax_friedrichs);\nnothing #hide","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"These do not have internal caches storing intermediate values of the numerical solution, so we do not need to adapt them. In fact, we could also define them outside of energy_at_final_time (but would need to take care of globals or wrap everything in another function).","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Next, we define the initial condition","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"initial_condition = (x, t, equation) -> begin\n x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n return SVector(sinpi(k * sum(x_trans)))\nend;\nnothing #hide","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"as a closure capturing the wave number k passed to energy_at_final_time. If you call energy_at_final_time(1.0), k will be a Float64. Thus, the return values of initial_condition will be SVectors of Float64s. When calculating the ForwardDiff.derivative, k will be a ForwardDiff.Dual number. Hence, the initial_condition will return SVectors of ForwardDiff.Dual numbers.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"The semidiscretization semi uses some internal caches to avoid repeated allocations and speed up the computations, e.g. for numerical fluxes at interfaces. Thus, we need to tell Trixi.jl to allow ForwardDiff.Dual numbers in these caches. That's what the keyword argument uEltype=typeof(k) in","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n uEltype=typeof(k));\nnothing #hide","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"does. This is basically the only part where you need to modify your standard Trixi.jl code to enable automatic differentiation. From there on, the remaining steps","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"ode = semidiscretize(semi, (0.0, 1.0))\nsol = solve(ode, BS3(), save_everystep=false)\nround(Trixi.integrate(energy_total, sol.u[end], semi), sigdigits=5)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"do not need any modifications since they are sufficiently generic (and enough effort has been spend to allow general types inside these calls).","category":"page"},{"location":"tutorials/differentiable_programming/#Propagating-errors-using-Measurements.jl","page":"16 Differentiable programming","title":"Propagating errors using Measurements.jl","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"(Image: Error bars by Randall Munroe) \"Error bars\" by Randall Munroe, linked from https://xkcd.com/2110","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Similar to AD, Trixi.jl also allows propagating uncertainties using linear error propagation theory via Measurements.jl. As an example, let's create a system representing the linear advection equation in 1D with an uncertain velocity. Then, we create a semidiscretization using a sine wave as initial condition, solve the ODE, and plot the resulting uncertainties in the primitive variables.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, OrdinaryDiffEq, Measurements, Plots, LaTeXStrings\n\nequations = LinearScalarAdvectionEquation1D(1.0 ± 0.1)\n\nmesh = TreeMesh((-1.0,), (1.0,), n_cells_max=10^5, initial_refinement_level=5)\n\nsolver = DGSEM(3)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test,\n solver, uEltype=Measurement{Float64})\n\node = semidiscretize(semi, (0.0, 1.5))\n\nsol = solve(ode, BS3(), save_everystep=false);\n\nplot(sol)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"You should see a plot where small error bars are shown around the extrema and larger error bars are shown in the remaining parts. This result is in accordance with expectations. Indeed, the uncertain propagation speed will affect the extrema less since the local variation of the solution is relatively small there. In contrast, the local variation of the solution is large around the turning points of the sine wave, so the uncertainties will be relatively large there.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"All this is possible due to allowing generic types and having good abstractions in Julia that allow packages to work together seamlessly.","category":"page"},{"location":"tutorials/differentiable_programming/#Finite-difference-approximations","page":"16 Differentiable programming","title":"Finite difference approximations","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Trixi.jl provides the convenience function jacobian_fd to approximate the Jacobian via central finite differences.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, LinearAlgebra\n\nequations = CompressibleEulerEquations2D(1.4)\n\nsolver = DGSEM(3, flux_central)\n\nmesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n\nJ_fd = jacobian_fd(semi)\n\nJ_ad = jacobian_ad_forward(semi)\n\nrelative_difference = norm(J_fd - J_ad) / size(J_fd, 1)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"This discrepancy is of the expected order of magnitude for central finite difference approximations.","category":"page"},{"location":"tutorials/differentiable_programming/#Linear-systems","page":"16 Differentiable programming","title":"Linear systems","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"When a linear PDE is discretized using a linear scheme such as a standard DG method, the resulting semidiscretization yields an affine ODE of the form","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"partial_t u(t) = A u(t) + b","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"where A is a linear operator (\"matrix\") and b is a vector. Trixi.jl allows you to obtain this linear structure in a matrix-free way by using linear_structure. The resulting operator A can be used in multiplication, e.g. mul! from LinearAlgebra, converted to a sparse matrix using sparse from SparseArrays, or converted to a dense matrix using Matrix for detailed eigenvalue analyses. For example,","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using Trixi, LinearAlgebra, Plots\n\nequations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n\nsolver = DGSEM(3, flux_lax_friedrichs)\n\nmesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test, solver)\n\nA, b = linear_structure(semi)\n\nsize(A), size(b)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"Next, we compute the eigenvalues of the linear operator.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ = eigvals(Matrix(A))\n\nscatter(real.(λ), imag.(λ))","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"As you can see here, the maximal real part is close to machine precision.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"λ = eigvals(Matrix(A))\nrelative_maximum = maximum(real, λ) / maximum(abs, λ)","category":"page"},{"location":"tutorials/differentiable_programming/#Package-versions","page":"16 Differentiable programming","title":"Package versions","text":"","category":"section"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\", \"ForwardDiff\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"","category":"page"},{"location":"tutorials/differentiable_programming/","page":"16 Differentiable programming","title":"16 Differentiable programming","text":"This page was generated using Literate.jl.","category":"page"},{"location":"meshes/tree_mesh/#Tree-mesh","page":"Tree mesh","title":"Tree mesh","text":"","category":"section"},{"location":"meshes/tree_mesh/","page":"Tree mesh","title":"Tree mesh","text":"The TreeMesh is a Cartesian, h-non-conforming mesh type used in many parts of Trixi.jl. Often, the support for this mesh type is developed best since it was the first mesh type in Trixi.jl, and it is available in one, two, and three space dimensions.","category":"page"},{"location":"meshes/tree_mesh/","page":"Tree mesh","title":"Tree mesh","text":"It is limited to hypercube domains but supports AMR via the AMRCallback. Due to its Cartesian nature, (numerical) fluxes need to implement methods dispatching on the orientation::Integer as described in the conventions.","category":"page"},{"location":"meshes/unstructured_quad_mesh/#Unstructured-quadrilateral-mesh","page":"Unstructured mesh","title":"Unstructured quadrilateral mesh","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The UnstructuredMesh2D is an unstructured, curvilinear, conforming mesh type in two space dimensions.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Next, we describe the conventions taken in the implementation for two-dimensional unstructured quadrilateral meshes. Principally, this relates to how a file with the extension .mesh encodes information about the numbering and orientation of elements in an unstructured quadrilateral mesh with possibly curved boundaries.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"We use the following unstructured mesh with three elements for this discussion:","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"(Image: example-mesh)","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Further, a simulation using Trixi.jl on this example unstructured mesh is provided in examples/unstructured_2d_dgsem/elixir_euler_basic.jl.","category":"page"},{"location":"meshes/unstructured_quad_mesh/#Mesh-file-header","page":"Unstructured mesh","title":"Mesh file header","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The first two lines of the mesh file lists the mesh file type as well as the total number of corners, surfaces, elements, and the polynomial degree that the mesh will use to represent any curved sides. For the example mesh these quantities are","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"ISM-V2\n 7 9 3 8","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"corresponding to seven corners, nine surfaces, and three elements. The mesh polynomial degree of eight is taken only for illustrative purposes. In practice, this mesh polynomial degree depends on the particular application for which the curved, unstructured mesh is required.","category":"page"},{"location":"meshes/unstructured_quad_mesh/#List-of-corner-nodes","page":"Unstructured mesh","title":"List of corner nodes","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"After these global counts that prescribe information about the mesh skeleton, the mesh file give a list of the physical (x,y) coordinates of all the corners. The corner nodes are listed in the order prescribed by mesh generator. Thus, for the example mesh this node list would be","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 1.0 -1.0\n 3.0 0.0\n 1.0 1.0\n 2.0 0.0\n 0.0 0.0\n 3.0 1.0\n 3.0 -1.0","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The corner nodes are internally referenced by their position in the list above. For example, here the node at (1.0, -1.0) would have node id 1, node id 2 would be at (3.0, 0.0) etc.","category":"page"},{"location":"meshes/unstructured_quad_mesh/#List-of-neighbor-connectivity","page":"Unstructured mesh","title":"List of neighbor connectivity","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"After the corner list comes the neighbor connectivity along each surface in the mesh. This includes local indexing and orientation information necessary to compute the coupling between elements in the mesh. In 2D each surface is defined by connecting two nodes indexed as with the numbering above. We adopt the convention that node id 1 < node id 2.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Each surface will have two neighbors where the element on the left locally as one \"walks\" from node id 1 to node id 2 is taken to be the primary element and the element locally on the right is taken to be the secondary element. If, however, there is no secondary element index, then the surface lies along a physical boundary. In this case the only available element index is considered to be primary and the secondary index is set to zero.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The final two index numbers within the neighbor information list are used to identify the local surface within each element. The first local surface index (on the primary element) will always be positive whereas the second local surface index (on the primary element) can be positive or negative. If the second local surface index is positive, then the local coordinate systems in the primary element and secondary element match, i.e., the indexing on either side runs from 1:polydeg+1. However, if the local surface index of the secondary element is negative in the mesh file, then the coordinate system in the secondary element is flipped with respect to the primary element. Therefore, care must be taken in the implementation to ensure that the primary element indexing runs from 1:polydeg+1 whereas the secondary element indexing must run in reverse from polydeg+1:-1:1. Finally, if the secondary element index is zero, then so will be the local surface index because the surface is on a physical boundary. Also, there is no flipping of coordinate indexing required at the physical boundary because only the primary element's coordinate system exists.","category":"page"},{"location":"meshes/unstructured_quad_mesh/#Three-examples:-One-along-a-physical-boundary-and-two-along-interior-surfaces.","page":"Unstructured mesh","title":"Three examples: One along a physical boundary and two along interior surfaces.","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Along edge {8} we connect node (2) to node (7) and are along a physical boundary in element 3 with the local surface index 1 and the neighbor information:","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 2 7 3 0 1 0","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Along edge {1} we connect node (2) to node (4) such that the primary element is 3 with local surface index 2 and the secondary element is 2 with local surface index 1. Furthermore, we see that coordinate system in the secondary element 2 is flipped with respect to the primary element's coordinate system such that the sign of the local surface index in the secondary element flips. This gives the following neighbor information:","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 2 4 3 2 2 -1","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Along edge {4} we connect node (1) to node (4) such that the primary element is 1 with local surface index 2 and the secondary element is 3 with local surface index 3. The coordinate systems in both elements match and no sign change is required on the local surface index in the secondary element:","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 1 4 1 3 2 3","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"We collect the complete neighbor information for the example mesh above:","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 2 4 3 2 2 -1\n 3 5 1 0 4 0\n 1 5 1 0 1 0\n 1 4 1 3 2 3\n 2 6 2 0 2 0\n 1 7 3 0 4 0\n 3 6 2 0 3 0\n 2 7 3 0 1 0\n 3 4 2 1 4 -3","category":"page"},{"location":"meshes/unstructured_quad_mesh/#List-of-elements","page":"Unstructured mesh","title":"List of elements","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Each quadrilateral element in the unstructured mesh is dictated by four corner points with indexing taken from the numbering given by the corner list above. We connect a set of four corner points (starting from the bottom left) in an anti-clockwise fashion thus making the element right-handed indicated using the circular arrow in the figure above. In turn, this right-handedness defines the local surface indexing (i.e. the four local sides) and the local (xi eta) coordinate system. For example, the four corners for element 1 would be listed as","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 5 1 4 3","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The mesh file also encodes information for curved surfaces either interior to the domain (as surface {9} above) or along the physical boundaries. A set of check digits are included directly below the four corner indexes to indicate whether the local surface index (1, 2, 3, or 4) within the element is straight sided, 0, or is curved, 1. If the local surface is straight sided no additional information is necessary during the mesh file read in. But for any curved surfaces the mesh file provides (x,y) coordinate values in order to construct an interpolant of this surface with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes. This list of (x,y) data will be given in the direction of the local coordinate system.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"The last piece of information provided by the mesh file are labels for the different surfaces of an element. These labels are useful to set boundary conditions along physical surfaces. The labels can be short descriptive words. The label --- indicates an internal surface where no boundary condition is required.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"As an example, the complete information for element 1 in the example mesh would be","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 5 1 4 3\n 0 0 1 1\n 1.000000000000000 1.000000000000000\n 1.024948365654583 0.934461926834452\n 1.116583018200151 0.777350964621867\n 1.295753434047077 0.606254343587194\n 1.537500000000000 0.462500000000000\n 1.768263070247418 0.329729152118310\n 1.920916981799849 0.185149035378133\n 1.986035130050921 0.054554577460044\n 2.000000000000000 0.0\n 0.0 0.0\n 0.035513826946206 0.105291711848750\n 0.148591270347399 0.317731556850611\n 0.340010713990041 0.452219430075470\n 0.575000000000000 0.462500000000000\n 0.788022294598950 0.483764065630034\n 0.926408729652601 0.644768443149389\n 0.986453164464803 0.883724792445746\n 1.000000000000000 1.000000000000000\n Slant --- --- Bezier","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"where the curved boundary information is encoded \"back to back\". That is, the first nine (x,y) nodes in the list above correspond to the interior boundary curve along local side 3 in element 1 and the next nine (x,y) nodes denote the curved physical boundary named Bezier along local side 4.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"We collect the complete set of element information for the example mesh","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" 5 1 4 3\n 0 0 1 1\n 1.000000000000000 1.000000000000000\n 1.024948365654583 0.934461926834452\n 1.116583018200151 0.777350964621867\n 1.295753434047077 0.606254343587194\n 1.537500000000000 0.462500000000000\n 1.768263070247418 0.329729152118310\n 1.920916981799849 0.185149035378133\n 1.986035130050921 0.054554577460044\n 2.000000000000000 0.0\n 0.0 0.0\n 0.035513826946206 0.105291711848750\n 0.148591270347399 0.317731556850611\n 0.340010713990041 0.452219430075470\n 0.575000000000000 0.462500000000000\n 0.788022294598950 0.483764065630034\n 0.926408729652601 0.644768443149389\n 0.986453164464803 0.883724792445746\n 1.000000000000000 1.000000000000000\n Slant --- --- Bezier\n 4 2 6 3\n 0 0 0 1\n 2.000000000000000 0.0\n 1.986035130050921 0.054554577460044\n 1.920916981799849 0.185149035378133\n 1.768263070247418 0.329729152118310\n 1.537500000000000 0.462500000000000\n 1.295753434047077 0.606254343587194\n 1.116583018200151 0.777350964621867\n 1.024948365654583 0.934461926834452\n 1.000000000000000 1.000000000000000\n --- Right Top ---\n 7 2 4 1\n 0 0 0 0\n Right --- --- Bottom","category":"page"},{"location":"meshes/unstructured_quad_mesh/#Trixi.jl-on-an-unstructured-quadrilateral-mesh","page":"Unstructured mesh","title":"Trixi.jl on an unstructured quadrilateral mesh","text":"","category":"section"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"We provide an example simulation on an unstructured quadrilateral mesh by executing","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"julia> trixi_include(default_example_unstructured())","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":"Note this may download a copy of the mesh file described above for the three element unstructured mesh. This elixir provides the solution for the compressible Euler equations in two spatial dimensions for a smooth propagating wave solution. Below we provide the time evolution of the pressure wave for this example created with the Trixi2Vtk tool and visualized using ParaView.","category":"page"},{"location":"meshes/unstructured_quad_mesh/","page":"Unstructured mesh","title":"Unstructured mesh","text":" \n
","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"EditURL = \"../../literate/src/files/time_stepping.jl\"","category":"page"},{"location":"tutorials/time_stepping/#time_stepping","page":"15 Explicit time stepping","title":"15: Explicit time stepping","text":"","category":"section"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"For the time integration, Trixi.jl uses the package OrdinaryDiffEq.jl from the SciML ecosystem. The interface to this package is the solve(...) function. It always requires an ODE problem and a time integration algorithm as input parameters.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"solve(ode, alg; kwargs...)","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"In Trixi.jl, the ODE problem is created by semidiscretize(semi, tspan) for a semidiscretization semi and the time span tspan. In particular, semidiscretize returns an ODEProblem used by OrdinaryDiffEq.jl.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"OrdinaryDiffEq.jl provides many integration algorithms, which are summarized in the documentation. Particularly interesting for Trixi.jl are their strong stability preserving (SSP) methods and low-storage methods. There are some differences regarding the choice of the used time step.","category":"page"},{"location":"tutorials/time_stepping/#adaptive_step_sizes","page":"15 Explicit time stepping","title":"Error-based adaptive step sizes","text":"","category":"section"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"First, we treat time integration algorithms with adaptive step sizes, such as SSPRK43. It is used in some elixirs, like elixir_euler_colliding_flow.jl or elixir_euler_astro_jet_amr.jl.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"Other error-based adaptive integration algorithms are for instance RDPK3SpFSAL35, RDPK3Sp35, RDPK3SpFSAL49, RDPK3Sp49, RDPK3SpFSAL510, RDPK3Sp510.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"They already contain an error-based adaptive step size control and heuristics to guess a starting step size. If this heuristic fails in your case, you can specify an appropriately small initial step size as keyword argument dt=... of solve.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"If you run Trixi in parallel with MPI you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to enable MPI aware error-based adaptive step size control. These keyword arguments are also included in ode_default_options.","category":"page"},{"location":"tutorials/time_stepping/#CFL-based-step-size-control","page":"15 Explicit time stepping","title":"CFL-based step size control","text":"","category":"section"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"The SciML ecosystem also provides time integration algorithms without adaptive time stepping on their own, such as CarpenterKennedy2N54. Moreover, you also can deactivate the automatic adaptivity of adaptive integration algorithms by passing adaptive=false in the solve function.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"These algorithms require another way of setting the step size. You have to pass dt=... in the solve function. Without other settings, the simulation uses this fixed time step.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"For hyperbolic PDEs, it is natural to use an adaptive CFL-based step size control. Here, the time step is proportional to a ratio of the local measure of mesh spacing Delta x_i for an element i and the maximum (local) wave speed lambda_max related to the largest-magnitude eigenvalue of the flux Jacobian of the hyperbolic system.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"Delta t_n = textCFL * min_i fracDelta x_ilambda_max(u_i^n)","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"We compute Delta x_i by scaling the element size by a factor of 1(N+1), cf. Gassner and Kopriva (2011), Section 5.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"Trixi.jl provides such a CFL-based step size control. It is implemented as the callback StepsizeCallback.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"stepsize_callback = StepsizeCallback(; cfl=1.0)","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"A suitable CFL number depends on many parameters such as the chosen grid, the integration algorithm and the polynomial degree of the spatial DG discretization. So, the optimal number for an example is mostly determined experimentally.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"You can add this CFL-based step size control to your simulation like any other callback.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"callbacks = CallbackSet(stepsize_callback)\nalg = CarpenterKennedy2N54(williamson_condition=false)\nsolve(ode, alg;\n dt=1.0 # solve needs some value here but it will be overwritten by the stepsize_callback\n callback=callbacks)","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"You can find simple examples with a CFL-based step size control for instance in the elixirs elixir_advection_basic.jl or elixir_euler_source_terms.jl.","category":"page"},{"location":"tutorials/time_stepping/#Package-versions","page":"15 Explicit time stepping","title":"Package versions","text":"","category":"section"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"","category":"page"},{"location":"tutorials/time_stepping/","page":"15 Explicit time stepping","title":"15 Explicit time stepping","text":"This page was generated using Literate.jl.","category":"page"},{"location":"contributing/#Contributing","page":"Contributing","title":"Contributing","text":"","category":"section"},{"location":"contributing/","page":"Contributing","title":"Contributing","text":"Trixi.jl is an open-source project and we are very happy to accept contributions from the community. Please feel free to open issues or submit patches (preferably as merge requests) any time. For planned larger contributions, it is often beneficial to get in contact with one of the principal developers first (see Authors).","category":"page"},{"location":"contributing/","page":"Contributing","title":"Contributing","text":"Trixi.jl and its contributions are licensed under the MIT license (see License). As a contributor, you certify that all your contributions are in conformance with the Developer Certificate of Origin (Version 1.1), which is reproduced below.","category":"page"},{"location":"contributing/#Developer-Certificate-of-Origin-(Version-1.1)","page":"Contributing","title":"Developer Certificate of Origin (Version 1.1)","text":"","category":"section"},{"location":"contributing/","page":"Contributing","title":"Contributing","text":"The following text was taken from https://developercertificate.org:","category":"page"},{"location":"contributing/","page":"Contributing","title":"Contributing","text":"Developer Certificate of Origin\nVersion 1.1\n\nCopyright (C) 2004, 2006 The Linux Foundation and its contributors.\n1 Letterman Drive\nSuite D4700\nSan Francisco, CA, 94129\n\nEveryone is permitted to copy and distribute verbatim copies of this\nlicense document, but changing it is not allowed.\n\n\nDeveloper's Certificate of Origin 1.1\n\nBy making a contribution to this project, I certify that:\n\n(a) The contribution was created in whole or in part by me and I\n have the right to submit it under the open source license\n indicated in the file; or\n\n(b) The contribution is based upon previous work that, to the best\n of my knowledge, is covered under an appropriate open source\n license and I have the right under that license to submit that\n work with modifications, whether created in whole or in part\n by me, under the same open source license (unless I am\n permitted to submit under a different license), as indicated\n in the file; or\n\n(c) The contribution was provided directly to me by some other\n person who certified (a), (b) or (c) and I have not modified\n it.\n\n(d) I understand and agree that this project and the contribution\n are public and that a record of the contribution (including all\n personal information I submit with it, including my sign-off) is\n maintained indefinitely and may be redistributed consistent with\n this project or the open source license(s) involved.","category":"page"},{"location":"performance/#Performance","page":"Performance","title":"Performance","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"Trixi.jl is designed to balance performance and readability. Since Julia provides a lot of zero-cost abstractions, it is often possible to optimize both goals simultaneously.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"The usual development workflow in Julia is","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Make it work.\nMake it nice.\nMake it fast.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"To achieve the third step, you should be familiar with (at least) the section on performance tips in the Julia manual. Here, we just list some important aspects you should consider when developing Trixi.jl.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Consider using @views/view(...) when using array slices, except on the left-side of an assignment (further details).\nFunctions are essentially for free, since they are usually automatically inlined where it makes sense (using @inline can be used as an additional hint to the compiler) (further details).\nFunction barriers can improve performance due to type stability (further details).\nLook for type instabilities using @code_warntype. Consider using @descend from Cthulhu.jl to investigate deeper call chains.","category":"page"},{"location":"performance/#Manual-benchmarking","page":"Performance","title":"Manual benchmarking","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"If you modify some internal parts of Trixi.jl, you should check the impact on performance. Hence, you should at least investigate the performance roughly by comparing the reported timings of several elixirs. Deeper investigations and micro-benchmarks should usually use BenchmarkTools.jl. For example, the following steps were used to benchmark the changes introduced in https://github.com/trixi-framework/Trixi.jl/pull/256.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"git checkout e7ebf3846b3fd62ee1d0042e130afb50d7fe8e48 (new version)\nStart julia --threads=1 --check-bounds=no.\nExecute the following code in the REPL to benchmark the rhs! call at the final state.\njulia> using BenchmarkTools, Revise; using Trixi\n\njulia> trixi_include(\"examples/2d/elixir_euler_sedov_blast_wave.jl\")\n\njulia> du_test = copy(sol.u[end]); u_test = copy(sol.u[end]);\n\njulia> @benchmark Trixi.rhs!(\n $(du_test),\n $(u_test),\n $(semi),\n $(sol.t[end]))\nBenchmarkTools.Trial:\n memory estimate: 10.48 KiB\n allocs estimate: 67\n --------------\n minimum time: 4.510 ms (0.00% GC)\n median time: 4.646 ms (0.00% GC)\n mean time: 4.699 ms (0.00% GC)\n maximum time: 7.183 ms (0.00% GC)\n --------------\n samples: 1065\n evals/sample: 1\n\nshell> git checkout 222241ff54f8a4ca9876cc1fc25ae262416a4ea0\n\njulia> trixi_include(\"examples/2d/elixir_euler_sedov_blast_wave.jl\")\n\njulia> @benchmark Trixi.rhs!(\n $(du_test),\n $(u_test),\n $(semi),\n $(sol.t[end]))\nBenchmarkTools.Trial:\n memory estimate: 10.36 KiB\n allocs estimate: 67\n --------------\n minimum time: 4.500 ms (0.00% GC)\n median time: 4.635 ms (0.00% GC)\n mean time: 4.676 ms (0.00% GC)\n maximum time: 5.880 ms (0.00% GC)\n --------------\n samples: 1070\n evals/sample: 1\nRun the @benchmark ... commands multiple times to see whether there are any significant fluctuations.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Follow these steps for both commits you want to compare. The relevant benchmark results you should typically be looking at are the median and mean values of the runtime and the memory/allocs estimate. In this example, the differences of the runtimes are of the order of the fluctuations one gets when running the benchmarks multiple times. Since the memory/allocs are (roughly) the same, there doesn't seem to be a significant performance regression here.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"You can also make it more detailed by benchmarking only, e.g., the calculation of the volume terms, but whether that's necessary depends on the modifications you made and their (potential) impact.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Some more detailed description of manual profiling and benchmarking as well as resulting performance improvements of Trixi.jl are given in the following blog posts.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Improving performance of AMR with p4est, cf. #638\nImproving performance of EC methods, cf. #643","category":"page"},{"location":"performance/#Automated-benchmarking","page":"Performance","title":"Automated benchmarking","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"We use PkgBenchmark.jl to provide a standard set of benchmarks for Trixi.jl. The relevant benchmark script is benchmark/benchmarks.jl. You can run a standard set of benchmarks via","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"julia> using PkgBenchmark, Trixi\n\njulia> results = benchmarkpkg(Trixi, BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`))\n\njulia> export_markdown(pkgdir(Trixi, \"benchmark\", \"single_benchmark.md\"), results)","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"This will save a markdown file with a summary of the benchmark results similar to this example. Note that this will take quite some time. Additional options are described in the docs of PkgBenchmark.jl. A particularly useful option is to specify a BenchmarkConfig including Julia command line options affecting the performance such as disabling bounds-checking and setting the number of threads.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"A useful feature when developing Trixi.jl is to compare the performance of Trixi.jl's current state vs. the main branch. This can be achieved by executing","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"julia> using PkgBenchmark, Trixi\n\njulia> results = judge(Trixi,\n BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`), # target\n BenchmarkConfig(juliacmd=`$(Base.julia_cmd()) --check-bounds=no --threads=1`, id=\"main\") # baseline\n )\n\njulia> export_markdown(pkgdir(Trixi, \"benchmark\", \"results.md\"), results)","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"By default, the target is the current state of the repository. Remember that you need to be in a clean state (commit or stash your changes) to run this successfully. You can also run this comparison and an additional one using two threads via","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"julia> include(\"benchmark/run_benchmarks.jl\")","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Then, markdown files including the results are saved in benchmark/. This example result was obtained using a GitHub action for the PR #535. Note that GitHub actions run on in the cloud in a virtual machine. Hence, we do not really have control over it and performance results must be taken with a grain of salt. Nevertheless, significant runtime differences and differences of memory allocations should be robust indicators of performance changes.","category":"page"},{"location":"performance/#Runtime-performance-vs.-latency-aka-using-@nospecialize-selectively","page":"Performance","title":"Runtime performance vs. latency aka using @nospecialize selectively","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"Usually, Julia will compile specialized versions of each method, using as much information from the types of function arguments as possible (based on some heuristics). The compiler will generate code that is as efficient as comparable code written in a low-level language such as C or Fortran. However, there are cases where the runtime performance does not really matter but the time needed to compile specializations becomes significant. This is related to latency or the time-to-first-plot problem, well-known in the Julia community. In such a case, it can be useful to remove some burden from the compiler by avoiding specialization on every possible argument types using the macro @nospecialize. A prime example of such a case is pretty printing of structs in the Julia REPL, see the associated PR for further discussions.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"As a rule of thumb:","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Do not use @nospecialize in performance-critical parts, in particular not for methods involved in computing Trixi.rhs!.\nConsider using @nospecialize for methods like custom implementations of Base.show.","category":"page"},{"location":"performance/#performance-metrics","page":"Performance","title":"Performance metrics of the AnalysisCallback","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"The AnalysisCallback computes two performance indicators that you can use to evaluate the serial and parallel performance of Trixi.jl. They represent measured run times that are normalized by the number of rhs! evaluations and the number of degrees of freedom of the problem setup. The normalization ensures that we can compare different measurements for each type of indicator independent of the number of time steps or mesh size. All indicators have in common that they are still in units of time, thus lower is better for each of them.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"Here, the term \"degrees of freedom\" (DOFs) refers to the number of independent state vectors that are used to represent the numerical solution. For example, if you use a DGSEM-type scheme in 2D on a mesh with 8 elements and with 5-by-5 Gauss-Lobatto nodes in each element (i.e., a polynomial degree of 4), the total number of DOFs would be","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"n_textDOFsDGSEM = textnumber of elements cdot textnumber of nodes per element = 8 cdot (5 cdot 5) = 200","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"In contrast, for a finite volume-type scheme on a mesh with 8 elements, the total number of DOFs would be (independent of the number of spatial dimensions)","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"n_textDOFsFV = textnumber of elements = 8","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"since for standard finite volume methods you store a single state vector in each element. Note that we specifically count the number of state vectors and not the number of state variables for the DOFs. That is, in the previous example n_textDOFsFV is equal to 8 independent of whether this is a compressible Euler setup with 5 state variables or a linear scalar advection setup with one state variable.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"For each indicator, the measurements are always since the last invocation of the AnalysisCallback. That is, if the analysis callback is called multiple times, the indicators are repeatedly computed and can thus also be used to track the performance over the course of a longer simulation, e.g., to analyze setups with varying performance characteristics. Note that the time spent in the AnalysisCallback itself is always excluded, i.e., the performance measurements are not distorted by potentially expensive solution analysis computations. All other parts of a Trixi.jl simulation are included, however, thus make sure that you disable everything you do not want to be measured (such as I/O callbacks, visualization etc.).","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"note: Performance indicators and adaptive mesh refinement\nCurrently it is not possible to compute meaningful performance indicators for a simulation with arbitrary adaptive mesh refinement, since this would require to explicitly keep track of the number of DOF updates due to the mesh size changing repeatedly. The only way to do this at the moment is by setting the analysis interval to the same value as the AMR interval.","category":"page"},{"location":"performance/#Local,-rhs!-only-indicator","page":"Performance","title":"Local, rhs!-only indicator","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"The local, rhs!-only indicator is computed as","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"texttimeDOFrhs = fract_texttextttrhsn_textDOFslocal cdot n_textcallstextttrhs","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"where t_texttextttrhs is the accumulated time spent in rhs!, n_textDOFslocal is the local number of DOFs (i.e., on the current MPI rank; if doing a serial run, you can just think of this as the number of DOFs), and n_textcallstextttrhs is the number of times the rhs! function has been evaluated. Note that for this indicator, we measure only the time spent in rhs!, i.e., by definition all computations outside of rhs! - specifically all other callbacks and the time integration method - are not taken into account.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"The local, rhs!-only indicator is usually most useful if you do serial measurements and are interested in the performance of the implementation of your core numerical methods (e.g., when doing performance tuning).","category":"page"},{"location":"performance/#Performance-index-(PID)","page":"Performance","title":"Performance index (PID)","text":"","category":"section"},{"location":"performance/","page":"Performance","title":"Performance","text":"The performance index (PID) is computed as","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"textPID = fract_textwall cdot n_textranksMPIn_textDOFsglobal cdot n_textcallstextttrhs","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"where t_textwall is the walltime since the last call to the AnalysisCallback, n_textranksMPI is the number of MPI ranks used, n_textDOFsglobal is the global number of DOFs (i.e., the sum of DOFs over all MPI ranks; if doing a serial run, you can just think of this as the number of DOFs), and n_textcallstextttrhs is the number of times the rhs! function has been evaluated since the last call to the AnalysisCallback. The PID measures everything except the time spent in the AnalysisCallback itself - specifically, all other callbacks and the time integration method itself are included.","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"The PID is usually most useful if you would like to compare the parallel performance of your code to its serial performance. Specifically, it allows you to evaluate the parallelization overhead of your code by giving you a measure of the resources that are necessary to solve a given simulation setup. In a sense, it mimics the \"core hours\" metric that is often used by supercomputer centers to measure how many resources a particular compute job requires. It can thus be seen as a proxy for \"energy used\" and, as an extension, \"monetary cost\".","category":"page"},{"location":"performance/","page":"Performance","title":"Performance","text":"note: Initialization overhead in measurements\nWhen using one of the integration schemes from OrdinaryDiffEq.jl, their implementation will initialize some OrdinaryDiffEq.jl-specific information during the first time step. Among other things, one additional call to rhs! is performed. Therefore, make sure that for performance measurements using the PID either the number of timesteps or the workload per rhs! call is large enough to make the initialization overhead negligible. Note that the extra call to rhs! is properly accounted for in both the number of calls and the measured time, so you do not need to worry about it being expensive. If you want a perfect timing result, you need to set the analysis interval such that the AnalysisCallback is invoked at least once during the course of the simulation and discard the first PID value.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"EditURL = \"../../literate/src/files/custom_semidiscretization.jl\"","category":"page"},{"location":"tutorials/custom_semidiscretization/#custom_semidiscretization","page":"17 Custom semidiscretizations","title":"17: Custom semidiscretizations","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"As described in the overview section, semidiscretizations are high-level descriptions of spatial discretizations in Trixi.jl. Trixi.jl's main focus is on hyperbolic conservation laws represented in a SemidiscretizationHyperbolic. Hyperbolic-parabolic problems based on the advection-diffusion equation or the compressible Navier-Stokes equations can be represented in a SemidiscretizationHyperbolicParabolic. This is described in the basic tutorial on parabolic terms and its extension to custom parabolic terms. In this tutorial, we will describe how these semidiscretizations work and how they can be used to create custom semidiscretizations involving also other tasks.","category":"page"},{"location":"tutorials/custom_semidiscretization/#Overview-of-the-right-hand-side-evaluation","page":"17 Custom semidiscretizations","title":"Overview of the right-hand side evaluation","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"The semidiscretizations provided by Trixi.jl are set up to create ODEProblems from the SciML ecosystem for ordinary differential equations. In particular, a spatial semidiscretization can be wrapped in an ODE problem using semidiscretize, which returns an ODEProblem. This ODEProblem bundles an initial condition, a right-hand side (RHS) function, the time span, and possible parameters. The ODEProblems created by Trixi.jl use the semidiscretization passed to semidiscretize as a parameter. For a SemidiscretizationHyperbolic, the ODEProblem wraps Trixi.rhs! as ODE RHS. For a SemidiscretizationHyperbolicParabolic, Trixi.jl uses a SplitODEProblem combining Trixi.rhs_parabolic! for the (potentially) stiff part and Trixi.rhs! for the other part.","category":"page"},{"location":"tutorials/custom_semidiscretization/#Standard-Trixi.jl-setup","page":"17 Custom semidiscretizations","title":"Standard Trixi.jl setup","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"In this tutorial, we will consider the linear advection equation with source term","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"partial_t u(tx) + partial_x u(tx) = -exp(-t) sinbigl(pi (x - t) bigr)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"with periodic boundary conditions in the domain [-1, 1] as a model problem. The initial condition is","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"u(0x) = sin(pi x)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"The source term results in some damping and the analytical solution","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"u(tx) = exp(-t) sinbigl(pi (x - t) bigr)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"First, we discretize this equation using the standard functionality of Trixi.jl.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"using Trixi, OrdinaryDiffEq, Plots","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"The linear scalar advection equation is already implemented in Trixi.jl as LinearScalarAdvectionEquation1D. We construct it with an advection velocity 1.0.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"equations = LinearScalarAdvectionEquation1D(1.0)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Next, we use a standard DGSEM solver.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"solver = DGSEM(polydeg = 3)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"We create a simple TreeMesh in 1D.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"coordinates_min = (-1.0,)\ncoordinates_max = (+1.0,)\nmesh = TreeMesh(coordinates_min, coordinates_max;\n initial_refinement_level = 4,\n n_cells_max = 10^4,\n periodicity = true)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"We wrap everything in in a semidiscretization and pass the source terms as a standard Julia function. Please note that Trixi.jl uses SVectors from StaticArrays.jl to store the conserved variables u. Thus, the return value of the source terms must be wrapped in an SVector - even if we consider just a scalar problem.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"function initial_condition(x, t, equations)\n return SVector(exp(-t) * sinpi(x[1] - t))\nend\n\nfunction source_terms_standard(u, x, t, equations)\n return -initial_condition(x, t, equations)\nend\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition,\n solver;\n source_terms = source_terms_standard)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Now, we can create the ODEProblem, solve the resulting ODE using a time integration method from OrdinaryDiffEq.jl, and visualize the numerical solution at the final time using Plots.jl.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"tspan = (0.0, 3.0)\node = semidiscretize(semi, tspan)\n\nsol = solve(ode, RDPK3SpFSAL49(); ode_default_options()...)\n\nplot(sol; label = \"numerical sol.\", legend = :topright)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"We can also plot the analytical solution for comparison. Since Trixi.jl uses SVectors for the variables, we take their first (and only) component to get the scalar value for manual plotting.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"let\n x = range(-1.0, 1.0; length = 200)\n plot!(x, first.(initial_condition.(x, sol.t[end], equations)),\n label = \"analytical sol.\", linestyle = :dash, legend = :topright)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"We can also add the initial condition to the plot.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"plot!(sol.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"You can of course also use some callbacks provided by Trixi.jl as usual.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"summary_callback = SummaryCallback()\nanalysis_interval = 100\nanalysis_callback = AnalysisCallback(semi; interval = analysis_interval)\nalive_callback = AliveCallback(; analysis_interval)\ncallbacks = CallbackSet(summary_callback,\n analysis_callback,\n alive_callback)\n\nsol = solve(ode, RDPK3SpFSAL49();\n ode_default_options()..., callback = callbacks)\nsummary_callback()","category":"page"},{"location":"tutorials/custom_semidiscretization/#Using-a-custom-ODE-right-hand-side-function","page":"17 Custom semidiscretizations","title":"Using a custom ODE right-hand side function","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Next, we will solve the same problem but use our own ODE RHS function. To demonstrate this, we will artificially create a global variable containing the current time of the simulation.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"const GLOBAL_TIME = Ref(0.0)\n\nfunction source_terms_custom(u, x, t, equations)\n t = GLOBAL_TIME[]\n return -initial_condition(x, t, equations)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Next, we create our own RHS function to update the global time of the simulation before calling the RHS function from Trixi.jl.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"function rhs_source_custom!(du_ode, u_ode, semi, t)\n GLOBAL_TIME[] = t\n Trixi.rhs!(du_ode, u_ode, semi, t)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Next, we create an ODEProblem manually copying over the data from the one we got from semidiscretize earlier.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"ode_source_custom = ODEProblem(rhs_source_custom!,\n ode.u0,\n ode.tspan,\n ode.p #= semi =#)\nsol_source_custom = solve(ode_source_custom, RDPK3SpFSAL49();\n ode_default_options()...)\n\nplot(sol_source_custom; label = \"numerical sol.\")\nlet\n x = range(-1.0, 1.0; length = 200)\n plot!(x, first.(initial_condition.(x, sol_source_custom.t[end], equations)),\n label = \"analytical sol.\", linestyle = :dash, legend = :topleft)\nend\nplot!(sol_source_custom.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"This also works with callbacks as usual.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"summary_callback = SummaryCallback()\nanalysis_interval = 100\nanalysis_callback = AnalysisCallback(semi; interval = analysis_interval)\nalive_callback = AliveCallback(; analysis_interval)\ncallbacks = CallbackSet(summary_callback,\n analysis_callback,\n alive_callback)\n\nsol = solve(ode_source_custom, RDPK3SpFSAL49();\n ode_default_options()..., callback = callbacks)\nsummary_callback()","category":"page"},{"location":"tutorials/custom_semidiscretization/#Setting-up-a-custom-semidiscretization","page":"17 Custom semidiscretizations","title":"Setting up a custom semidiscretization","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Using a global constant is of course not really nice from a software engineering point of view. Thus, it can often be useful to collect additional data in the parameters of the ODEProblem. Thus, it is time to create our own semidiscretization. Here, we create a small wrapper of a standard semidiscretization of Trixi.jl and the current global time of the simulation.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"struct CustomSemidiscretization{Semi, T} <: Trixi.AbstractSemidiscretization\n semi::Semi\n t::T\nend\n\nsemi_custom = CustomSemidiscretization(semi, Ref(0.0))","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"To get pretty printing in the REPL, you can consider specializing","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Base.show(io::IO, parameters::CustomSemidiscretization)\nBase.show(io::IO, ::MIME\"text/plain\", parameters::CustomSemidiscretization)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"for your custom semidiscretiation.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Next, we create our own source terms that use the global time stored in the custom semidiscretiation.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"source_terms_custom_semi = let semi_custom = semi_custom\n function source_terms_custom_semi(u, x, t, equations)\n t = semi_custom.t[]\n return -initial_condition(x, t, equations)\n end\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"We also create a custom ODE RHS to update the current global time stored in the custom semidiscretization. We unpack the standard semidiscretization created by Trixi.jl and pass it to Trixi.rhs!.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"function rhs_semi_custom!(du_ode, u_ode, semi_custom, t)\n semi_custom.t[] = t\n Trixi.rhs!(du_ode, u_ode, semi_custom.semi, t)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Finally, we set up an ODEProblem and solve it numerically.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"ode_semi_custom = ODEProblem(rhs_semi_custom!,\n ode.u0,\n ode.tspan,\n semi_custom)\nsol_semi_custom = solve(ode_semi_custom, RDPK3SpFSAL49();\n ode_default_options()...)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"If we want to make use of additional functionality provided by Trixi.jl, e.g., for plotting, we need to implement a few additional specializations. In this case, we forward everything to the standard semidiscretization provided by Trixi.jl wrapped in our custom semidiscretization.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Base.ndims(semi::CustomSemidiscretization) = ndims(semi.semi)\nfunction Trixi.mesh_equations_solver_cache(semi::CustomSemidiscretization)\n Trixi.mesh_equations_solver_cache(semi.semi)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Now, we can plot the numerical solution as usual.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"plot(sol_semi_custom; label = \"numerical sol.\")\nlet\n x = range(-1.0, 1.0; length = 200)\n plot!(x, first.(initial_condition.(x, sol_semi_custom.t[end], equations)),\n label = \"analytical sol.\", linestyle = :dash, legend = :topleft)\nend\nplot!(sol_semi_custom.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"This also works with many callbacks as usual. However, the AnalysisCallback requires some special handling since it makes use of a performance counter contained in the standard semidiscretizations of Trixi.jl to report some performance metrics. Here, we forward all accesses to the performance counter to the wrapped semidiscretization.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"function Base.getproperty(semi::CustomSemidiscretization, s::Symbol)\n if s === :performance_counter\n wrapped_semi = getfield(semi, :semi)\n wrapped_semi.performance_counter\n else\n getfield(semi, s)\n end\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Moreover, the AnalysisCallback also performs some error calculations. We also need to forward them to the wrapped semidiscretization.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"function Trixi.calc_error_norms(func, u, t, analyzer,\n semi::CustomSemidiscretization,\n cache_analysis)\n Trixi.calc_error_norms(func, u, t, analyzer,\n semi.semi,\n cache_analysis)\nend","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"Now, we can work with the callbacks used before as usual.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"summary_callback = SummaryCallback()\nanalysis_interval = 100\nanalysis_callback = AnalysisCallback(semi_custom;\n interval = analysis_interval)\nalive_callback = AliveCallback(; analysis_interval)\ncallbacks = CallbackSet(summary_callback,\n analysis_callback,\n alive_callback)\n\nsol = solve(ode_semi_custom, RDPK3SpFSAL49();\n ode_default_options()..., callback = callbacks)\nsummary_callback()","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"For even more advanced usage of custom semidiscretizations, you may look at the source code of the ones contained in Trixi.jl, e.g.,","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"SemidiscretizationHyperbolicParabolic\nSemidiscretizationEulerGravity\nSemidiscretizationEulerAcoustics\nSemidiscretizationCoupled","category":"page"},{"location":"tutorials/custom_semidiscretization/#Package-versions","page":"17 Custom semidiscretizations","title":"Package versions","text":"","category":"section"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"","category":"page"},{"location":"tutorials/custom_semidiscretization/","page":"17 Custom semidiscretizations","title":"17 Custom semidiscretizations","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"EditURL = \"../../literate/src/files/DGSEM_FluxDiff.jl\"","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/#DGSEM_FluxDiff","page":"2 DGSEM with flux differencing","title":"2: DGSEM with flux differencing","text":"","category":"section"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This tutorial starts with a presentation of the weak formulation of the discontinuous Galerkin spectral element method (DGSEM) in order to fix the notation of the used operators. Then, the DGSEM formulation with flux differencing (split form DGSEM) and its implementation in Trixi.jl is shown.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We start with the one-dimensional conservation law","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"u_t + f(u)_x = 0 qquad tin mathbbR^+ xinOmega","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"with the physical flux f.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We split the domain Omega into elements K with center x_K and size Delta x. With the transformation mapping x(xi)=x_K + fracDelta x2 xi we can transform the reference element -11 to every physical element. So, the equation can be restricted to the reference element using the determinant of the Jacobian matrix of the transformation mapping J=fracpartial xpartial xi=fracDelta x2.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"J u_t + f(u)_xi = 0 qquad tin mathbbR^+ xiin -11","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/#The-weak-form-of-the-DGSEM","page":"2 DGSEM with flux differencing","title":"The weak form of the DGSEM","text":"","category":"section"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We consider the so-called discontinuous Galerkin spectral element method (DGSEM) with collocation. It results from choosing a nodal DG ansatz using N+1 Gauss-Lobatto nodes xi_i in -11 with matching interpolation weights w_i, which are used for numerical integration and interpolation with the Lagrange polynomial basis l_i of degree N. The Lagrange functions are created with those nodes and hence fulfil a Kronecker property at the GL nodes. The weak formulation of the DGSEM for one element is","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"J underlinedotu(t) = - M^-1 B underlinef^* + M^-1 D^T M underlinef","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"where underlineu=(u_0 u_1 dots u_N)^TinmathbbR^N+1 is the collected pointwise evaluation of u at the discretization nodes and dotu = partial u partial t = u_t is the temporal derivative. The nodal values of the flux function f results with collocation in underlinef, since underlinef_j=f(underlineu_j). Moreover, we got the numerical flux f^*=f^*(u^- u^+).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We will now have a short overview over the operators we used.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The derivative matrix DinmathbbR^(N+1)times (N+1) mimics a spatial derivation on a discrete level with underlinef_x approx D underlinef. It is defined by D_ij = l_j(xi_i).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The diagonal mass matrix M is defined by M_ij=langle l_j l_irangle_N with the numerical scalar product langle cdot cdotrangle_N defined for functions f and g by","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"langle f grangle_N = int_-1 N^1 f(xi) g(xi) dxi = sum_k=0^N f(xi_k) g(xi_k) w_k","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The multiplication by M matches a discrete integration","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":" int_-1^1 f(xi) underlinel(xi) dxi approx M underlinef","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The boundary matrix B=textdiag(-1 0 0 1) represents an evaluation of a function at the boundaries xi_0=-1 and xi_N=1.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"For these operators the following property holds:","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":" M D + (M D)^T = B","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This is called the summation-by-parts (SBP) property since it mimics integration by parts on a discrete level (Gassner (2013)).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The explicit definitions of the operators and the construction of the 1D algorithm can be found for instance in the tutorial introduction to DG methods or in more detail in Kopriva (2009).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This property shows the equivalence between the weak form and the following strong formulation of the DGSEM.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"beginalign*\nJ underlinedotu(t)\n= - M^-1 B underlinef^* + M^-1 D^T M underlinef5pt\n= - M^-1 B underlinef^* + M^-1 (B - MD) underlinef5pt\n= - M^-1 B (underlinef^* - underlinef) - D underlinef\nendalign*","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"More information about the equivalence you can find in Kopriva, Gassner (2010).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/#DGSEM-with-flux-differencing","page":"2 DGSEM with flux differencing","title":"DGSEM with flux differencing","text":"","category":"section"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"When using the diagonal SBP property it is possible to rewrite the application of the derivative operator D in the calculation of the volume integral into a subcell based finite volume type differencing formulation (Fisher, Carpenter (2013)). Generalizing","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"(D underlinef)_i = sum_j D_ij underlinef_j\n= 2sum_j frac12 D_ij (underlinef_j + underlinef_i)\neqqcolon 2sum_j D_ij f_textcentral(u_i u_j)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"we replace D underlinef in the strong form by 2D underlinef_vol(u^- u^+) with the consistent two-point volume flux f_vol and receive the DGSEM formulation with flux differencing (split form DGSEM) (Gassner, Winters, Kopriva (2016)).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"beginalign*\nJ underlinedotu(t) = - M^-1 B (underlinef^* - underlinef) - 2D underlinef_vol(u^- u^+)5pt\n= - M^-1 B (underlinef^* - underlinef_vol(underlineu underlineu)) - 2D underlinef_vol(u^- u^+)5pt\n= - M^-1 B underlinef_surface^* - (2D - M^-1 B) underlinef_vol5pt\n= - M^-1 B underlinef_surface^* - D_split underlinef_vol\nendalign*","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This formulation is in a weak form type formulation and can be implemented by using the derivative split matrix D_split=(2D-M^-1B) and two different fluxes. We divide between the surface flux f=f_surface used for the numerical flux f_surface^* and the already mentioned volume flux f_vol especially for this formulation.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This formulation creates a more stable version of DGSEM, because it fulfils entropy stability. Moreover it allows the construction of entropy conserving discretizations without relying on exact integration. This is achieved when using a two-point entropy conserving flux function as volume flux in the volume flux differencing formulation. Then, the numerical surface flux can be used to control the dissipation of the discretization and to guarantee decreasing entropy, i.e. entropy stability.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/#fluxDiffExample","page":"2 DGSEM with flux differencing","title":"Implementation in Trixi.jl","text":"","category":"section"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"Now, we have a look at the implementation of DGSEM with flux differencing with Trixi.jl.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"using OrdinaryDiffEq, Trixi","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We implement a simulation for the compressible Euler equations in 2D","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"partial_t beginpmatrix rho rho v_1 rho v_2 rho e endpmatrix\n+ partial_x beginpmatrix rho v_1 rho v_1^2 + p rho v_1 v_2 (rho e +p) v_1 endpmatrix\n+ partial_y beginpmatrix rho v_2 rho v_1 v_2 rho v_2^2 + p (rho e +p) v_2 endpmatrix\n= beginpmatrix 0 0 0 0 endpmatrix","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"for an ideal gas with ratio of specific heats gamma=14. Here, rho is the density, v_1, v_2 the velocities, e the specific total energy and","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"p = (gamma - 1) left( rho e - frac12 rho (v_1^2+v_2^2) right)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"the pressure.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"gamma = 1.4\nequations = CompressibleEulerEquations2D(gamma)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"As our initial condition we will use a weak blast wave from Hennemann, Gassner (2020). The primitive variables are defined by","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"beginpmatrix rho v_1 v_2 p endpmatrix\n= beginpmatrix 10 00 00 10 endpmatrix textif x_2 05\ntextand beginpmatrix rho v_1 v_2 p endpmatrix\n= beginpmatrix 11691 01882 * cos(phi) 01882 * sin(phi) 1245 endpmatrix textelse","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"with phi = tan^-1(fracx_2x_1).","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This initial condition is implemented in Trixi.jl under the name initial_condition_weak_blast_wave.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"initial_condition = initial_condition_weak_blast_wave","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"In Trixi.jl, flux differencing for the volume integral can be implemented with VolumeIntegralFluxDifferencing using symmetric two-point volume fluxes. First, we set up a simulation with the entropy conserving and kinetic energy preserving flux flux_ranocha by Hendrik Ranocha (2018) as surface and volume flux.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We will confirm the entropy conservation property numerically.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"volume_flux = flux_ranocha # = f_vol\nsolver = DGSEM(polydeg=3, surface_flux=volume_flux,\n volume_integral=VolumeIntegralFluxDifferencing(volume_flux))","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"Now, we implement Trixi.jl's mesh, semi and ode in a simple framework. For more information please have a look at the documentation, the basic tutorial introduction to DG methods or some basic elixirs.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"coordinates_min = (-2.0, -2.0)\ncoordinates_max = ( 2.0, 2.0)\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=5,\n n_cells_max=10_000,\n periodicity=true)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n boundary_conditions=boundary_condition_periodic)\n\n# ODE solvers\ntspan = (0.0, 0.4)\node = semidiscretize(semi, tspan);\nnothing #hide","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"To analyse the entropy conservation of the approximation, we will use the analysis calllback implemented in Trixi. It provides some information about the approximation including the entropy change.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"analysis_callback = AnalysisCallback(semi, interval=100);\nnothing #hide","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We now run the simulation using flux_ranocha for both surface and volume flux.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n ode_default_options()..., callback=analysis_callback);\nnothing #hide","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"A look at the change in entropy sum partial Spartial U cdot U_t in the analysis callback confirms that the flux is entropy conserving since the change is about machine precision.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We can plot the approximated solution at the time t=0.4.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"using Plots\nplot(sol)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"Now, we can use for instance the dissipative flux flux_lax_friedrichs as surface flux to get an entropy stable method.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"using OrdinaryDiffEq, Trixi\n\ngamma = 1.4\nequations = CompressibleEulerEquations2D(gamma)\n\ninitial_condition = initial_condition_weak_blast_wave\n\nvolume_flux = flux_ranocha # = f_vol\nsolver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs,\n volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n\ncoordinates_min = (-2.0, -2.0)\ncoordinates_max = ( 2.0, 2.0)\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=5,\n n_cells_max=10_000,\n periodicity=true)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n boundary_conditions=boundary_condition_periodic)\n\n# ODE solvers\ntspan = (0.0, 0.4)\node = semidiscretize(semi, tspan);\n\nanalysis_callback = AnalysisCallback(semi, interval=100);\nnothing #hide","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"We now run the simulation using the volume flux flux_ranocha and surface flux flux_lax_friedrichs.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n ode_default_options()..., callback=analysis_callback);\nnothing #hide","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"The change in entropy confirms the expected entropy stability.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"using Plots\nplot(sol)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"Of course, you can use more than these two fluxes in Trixi. Here, we will give a short list of possible fluxes for the compressible Euler equations. For the volume flux Trixi.jl provides for example flux_ranocha, flux_shima_etal, flux_chandrashekar, flux_kennedy_gruber. As surface flux you can use all volume fluxes and additionally for instance flux_lax_friedrichs, flux_hll, flux_hllc.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/#Package-versions","page":"2 DGSEM with flux differencing","title":"Package versions","text":"","category":"section"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"","category":"page"},{"location":"tutorials/DGSEM_FluxDiff/","page":"2 DGSEM with flux differencing","title":"2 DGSEM with flux differencing","text":"This page was generated using Literate.jl.","category":"page"},{"location":"meshes/dgmulti_mesh/#DGMulti","page":"DGMulti mesh","title":"Unstructured meshes and the DGMulti solver","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Trixi.jl includes support for simplicial and tensor product meshes via the DGMulti solver type, which is based on the StartUpDG.jl package. DGMulti solvers also provide support for quadrilateral and hexahedral meshes, though this feature is currently restricted to Cartesian grids. On these line/quad/hex meshes, the DGMulti solver also allows to use all (finite domain) SBP derivative operators provided by SummationByPartsOperators.jl, including several finite difference SBP methods.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"We make a few simplifying assumptions about supported meshes:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"meshes consist of a single type of element\nmeshes are conforming (e.g., each face of an element is shared with at most one other element).\nthe geometric mapping from reference to physical elements is polynomial (currently, only affine mappings are supported).","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"StartUpDG.jl includes both simple uniform meshes via uniform_mesh, as well as support for triangular meshes constructed using Triangulate.jl, a wrapper around Jonathan Shewchuk's Triangle package.","category":"page"},{"location":"meshes/dgmulti_mesh/#The-DGMulti-solver-type","page":"DGMulti mesh","title":"The DGMulti solver type","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Trixi.jl solvers on simplicial meshes use the [DGMulti](@ref) solver type, which allows users to specify element_type and approximation_type in addition to polydeg, surface_flux, surface_integral, and volume_integral.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"DGMulti(; polydeg::Integer,\n element_type::AbstractElemShape,\n approximation_type=Polynomial(),\n surface_flux=flux_central,\n surface_integral=SurfaceIntegralWeakForm(surface_flux),\n volume_integral=VolumeIntegralWeakForm(),\n RefElemData_kwargs...)","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Here, element_type can be Tri(), Quad(), Tet(), or Hex(), and approximation_type can be","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Polynomial(), which specifies a DG discretization using a polynomial basis using quadrature rules which are exact for degree 2 * polydeg integrands, or\nSBP(), which specifies a DG discretization using multi-dimensional SBP operators. Types of SBP discretizations available include: SBP{Kubatko{LobattoFaceNodes}}() (the default choice), SBP{Kubatko{LegendreFaceNodes}}(), and SBP{Hicken}(). For polydeg = 1, ..., 4, the SBP{Kubatko{LegendreFaceNodes}}() SBP nodes are identical to the SBP nodes of Chen and Shu. More detailed descriptions of each SBP node set can be found in the StartUpDG.jl docs. Trixi.jl will also specialize certain parts of the solver based on the SBP approximation type.\na (periodic or non-periodic) derivative operator from SummationByPartsOperators.jl, usually constructed as D = derivative_operator(...). In this case, you do not need to pass a polydeg. Periodic derivative operators will only work with single-element meshes constructed using DGMultiMesh.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Additional options can also be specified through RefElemData_kwargs:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"quad_rule_vol = quad_nodes(Tri(), Nq) will substitute in a volume quadrature rule of degree Nq instead of the default (which is a quadrature rule of degree polydeg). Here, a degree Nq rule will be exact for at least degree 2*Nq integrands (such that the mass matrix is integrated exactly). Quadrature rules of which exactly integrate degree Nq integrands may also be specified (for example, quad_rule_vol = StartUpDG.quad_nodes_tri(Nq) on triangles).\nquad_rule_face = quad_nodes(Line(), Nq)) will use a face quadrature rule of degree Nq rather than the default. This rule is also exact for at least degree 2*Nq integrands.","category":"page"},{"location":"meshes/dgmulti_mesh/#The-GaussSBP()-approximation-type-on-Quad()-and-Hex()-meshes","page":"DGMulti mesh","title":"The GaussSBP() approximation type on Quad() and Hex() meshes","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"When using VolumeIntegralFluxDifferencing on Quad() and Hex() meshes, one can also specify approximation_type = GaussSBP() to use an entropy stable Gauss collocation scheme. Here, GaussSBP() refers to \"generalized\" summation-by-parts operators (see for example Ranocha 2018 or Fernandez and Zingg 2015).","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Unlike traditional SBP operators, generalized SBP operators are constructed from nodes which do not include boundary nodes (i.e., Gauss quadrature nodes as opposed to Gauss-Lobatto quadrature nodes). This makes the computation of interface fluxes slightly more expensive, but also usually results in a more accurate solution. Roughly speaking, an entropy stable Gauss collocation scheme will yield results similar to a modal entropy stable scheme using a Polynomial() approximation type, but will be more efficient at high orders of approximation.","category":"page"},{"location":"meshes/dgmulti_mesh/#Trixi.jl-elixirs-on-simplicial-and-tensor-product-element-meshes","page":"DGMulti mesh","title":"Trixi.jl elixirs on simplicial and tensor product element meshes","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Example elixirs with triangular, quadrilateral, and tetrahedral meshes can be found in the examples/dgmulti_2d/ and examples/dgmulti_3d/ folders. Some key elixirs to look at:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"examples/dgmulti_2d/elixir_euler_weakform.jl: basic weak form DG discretization on a uniform triangular mesh. Changing element_type = Quad() or approximation_type = SBP() will switch to a quadrilateral mesh or an SBP-type discretization. Changing surface_integral = SurfaceIntegralWeakForm(flux_ec) and volume_integral = VolumeIntegralFluxDifferencing(flux_ec) for some entropy conservative flux (e.g., flux_chandrashekar or flux_ranocha) will switch to an entropy conservative formulation.\nexamples/dgmulti_2d/elixir_euler_triangulate_pkg_mesh.jl: uses an unstructured mesh generated by Triangulate.jl.\nexamples/dgmulti_3d/elixir_euler_weakform.jl: ´basic weak form DG discretization on a uniform tetrahedral mesh. Changing element_type = Hex() will switch to a hexahedral mesh. Changing surface_integral = SurfaceIntegralWeakForm(flux_ec) and volume_integral = VolumeIntegralFluxDifferencing(flux_ec) for some entropy conservative flux (e.g., flux_chandrashekar or flux_ranocha) will switch to an entropy conservative formulation.","category":"page"},{"location":"meshes/dgmulti_mesh/#For-developers","page":"DGMulti mesh","title":"For developers","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/#DGMultiMesh-wrapper-type","page":"DGMulti mesh","title":"DGMultiMesh wrapper type","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"DGMulti meshes in Trixi.jl are represented using a DGMultiMesh{NDIMS, ...} type. This mesh type is assumed to have fields md::MeshData, which contains geometric terms derived from the mapping between the reference and physical elements, and boundary_faces, which contains a Dict of boundary segment names (symbols) and list of faces which lie on that boundary segment.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"A DGMultiMesh can be constructed in several ways. For example, DGMultiMesh(dg::DGMulti) will return a Cartesian mesh on -1 1^d with element types specified by dg. DGMulti meshes can also be constructed by specifying a list of vertex coordinates vertex_coordinates_x, vertex_coordinates_y, vertex_coordinates_z and a connectivity matrix EToV where EToV[e,:] gives the vertices which correspond to element e. These quantities are available from most unstructured mesh generators.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Initial support for curved DGMultiMeshes is available for flux differencing solvers using SBP and GaussSBP approximation types on quadrilateral and hexahedral meshes. These can be called by specifying mesh = DGMultiMesh(dg, cells_per_dimension, mapping), where mapping is a function which specifies the warping of the mesh (e.g., mapping(xi, eta) = SVector{2}(xi, eta) is the identity mapping) similar to the mapping argument used by StructuredMesh.","category":"page"},{"location":"meshes/dgmulti_mesh/#Variable-naming-conventions","page":"DGMulti mesh","title":"Variable naming conventions","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"We use the convention that coordinates on the reference element are r in 1D, r s in 2D, or r s t in 3D. Physical coordinates use the standard conventions x (1D), x y (2D), and x y z (3D).","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"(Image: \"Ref-to-physical mapping\")","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Derivatives of reference coordinates with respect to physical coordinates are abbreviated, e.g., fracpartial rpartial x = r_x. Additionally, J is used to denote the determinant of the Jacobian of the reference-to-physical mapping.","category":"page"},{"location":"meshes/dgmulti_mesh/#Variable-meanings-and-conventions-in-StartUpDG.jl","page":"DGMulti mesh","title":"Variable meanings and conventions in StartUpDG.jl","text":"","category":"section"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"StartUpDG.jl exports structs RefElemData{NDIMS, ElemShape, ...} (which contains data associated with the reference element, such as interpolation points, quadrature rules, face nodes, normals, and differentiation/interpolation/projection matrices) and MeshData{NDIMS} (which contains geometric data associated with a mesh). These are currently used for evaluating DG formulations in a matrix-free fashion. These structs contain fields similar (but not identical) to those in Globals1D, Globals2D, Globals3D in the Matlab codes from \"Nodal Discontinuous Galerkin Methods\" by Hesthaven and Warburton (2007).","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"In general, we use the following code conventions:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"variables such as r, s,... and x, y,... correspond to values at nodal interpolation points.\nvariables ending in q (e.g., rq, sq,... and xq, yq,...) correspond to values at volume quadrature points.\nvariables ending in f (e.g., rf, sf,... and xf, yf,...) correspond to values at face quadrature points.\nvariables ending in p (e.g., rp, sp,...) correspond to \"plotting\" points, which are usually a fine grid of equispaced points.\nV matrices correspond to interpolation matrices from nodal interpolation points, e.g., Vq interpolates to volume quadrature points, Vf interpolates to face quadrature points.\ngeometric quantities in MeshData are stored as matrices of dimension textnumber of points per element times textnumber of elements.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Quantities in rd::RefElemData:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"rd.Np, rd.Nq, rd.Nf: the number of nodal interpolation points, volume quadrature points, and face quadrature points on the reference element, respectively.\nrd.Vq: interpolation matrices from values at nodal interpolation points to volume quadrature points\nrd.wq: volume quadrature weights on the reference element\nrd.Vf: interpolation matrices from values at nodal interpolation points to face quadrature points\nrd.wf: a vector containing face quadrature weights on the reference element\nrd.M: the quadrature-based mass matrix, computed via rd.Vq' * diagm(rd.wq) * rd.Vq.\nrd.Pq: a quadrature-based L^2 projection matrix rd.Pq = rd.M \\ rd.Vq' * diagm(rd.wq) which maps between values at quadrature points and values at nodal points.\nDr, Ds, Dt matrices are nodal differentiation matrices with respect to the rst coordinates, e.g., Dr*f.(r,s) approximates the derivative of f(rs) at nodal points.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"Quantities in md::MeshData:","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"md.xyz is a tuple of matrices md.x, md.y, md.z, where column e contains coordinates of physical interpolation points.\nmd.xyzq is a tuple of matrices md.xq, md.yq, md.zq, where column e contains coordinates of physical quadrature points.\nmd.rxJ, md.sxJ, ... are matrices where column e contains values of Jfracpartial rpartial x, Jfracpartial spartial x, etc. at nodal interpolation points on the element e.\nmd.J is a matrix where column e contains values of the Jacobian J at nodal interpolation points.\nmd.Jf is a matrix where column e contains values of the face Jacobian (e.g., determinant of the geometric mapping between a physical face and a reference face) at face quadrature points.\nmd.nxJ, md.nyJ, ... are matrices where column e contains values of components of the unit normal scaled by the face Jacobian md.Jf at face quadrature points.","category":"page"},{"location":"meshes/dgmulti_mesh/","page":"DGMulti mesh","title":"DGMulti mesh","text":"For more details, please see the StartUpDG.jl docs.","category":"page"},{"location":"meshes/p4est_mesh/#P4est-based-mesh","page":"P4est-based mesh","title":"P4est-based mesh","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The P4estMesh is an unstructured, curvilinear, nonconforming mesh type for quadrilateral (2D) and hexahedral (3D) cells. It supports quadtree/octree-based adaptive mesh refinement (AMR) via the C library p4est. See AMRCallback for further information.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Due to its curvilinear nature, (numerical) fluxes need to implement methods dispatching on the normal::AbstractVector. Rotationally invariant equations such as the compressible Euler equations can use FluxRotated to wrap numerical fluxes implemented only for Cartesian meshes. This simplifies the re-use of existing functionality for the TreeMesh but is usually less efficient, cf. PR #550.","category":"page"},{"location":"meshes/p4est_mesh/#Construction-of-a-P4estMesh-from-an-Abaqus-file","page":"P4est-based mesh","title":"Construction of a P4estMesh from an Abaqus file","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"One available option to construct a P4estMesh is to read in an Abaqus (.inp) mesh file. We briefly describe the structure of this file, the conventions it uses, and how the mesh file is parsed to create an initial unstructured, curvilinear, and conforming mesh.","category":"page"},{"location":"meshes/p4est_mesh/#Mesh-in-two-spatial-dimensions","page":"P4est-based mesh","title":"Mesh in two spatial dimensions","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"For this discussion we use the following two-dimensional unstructured curved mesh with three elements:","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"(Image: abaqus-2dmesh-docs)","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"We note that the corner and element connectivity information parsed from the Abaqus file creates a straight sided (linear) mesh. From this linear mesh there are two strategies available to make the mesh curvilinear:","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Apply a mapping function to describe a transformation of the linear mesh to another physical domain. The mapping is approximated using interpolation polynomial of a user specified polynomial degree. The default value of this polynomial degree is 1 that corresponds to an uncurved geometry.\nHigh-order boundary information is available in the .inp mesh file because it was created with the HOHQMesh mesh generator, which is available via the Julia package HOHQMesh.jl. This information is used to create appropriate transfinite mappings during the mesh construction.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"We divide our discussion into two parts. The first part discusses the standard corner and element information contained in the .inp mesh file. The second part specifically deals with the mesh file parsing of an Abaqus file created by HOHQMesh.jl.","category":"page"},{"location":"meshes/p4est_mesh/#Mesh-file-header","page":"P4est-based mesh","title":"Mesh file header","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"An Abaqus .inp mesh file typically begins with a *Heading. Though optional, the *Heading is helpful to give users some information about the mesh described by the mesh file. In particular, a .inp mesh file created with HOHQMesh will contain the header","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"*Heading\n File created by HOHQMesh","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"This heading is used to indicate to the mesh constructor which of the above mapping strategies to apply in order to create a curvilinear mesh. If the Abaqus file header is not present then the P4estMesh is created with the first strategy above.","category":"page"},{"location":"meshes/p4est_mesh/#List-of-corner-nodes","page":"P4est-based mesh","title":"List of corner nodes","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Next, prefaced with *NODE, comes a list of the physical (x,y,z) coordinates of all the corners. The first integer in the list of the corners provides its id number. Thus, for the two-dimensional example mesh this block of corner information is","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"*NODE\n1, 1.0, -1.0, 0.0\n2, 3.0, 0.0, 0.0\n3, 1.0, 1.0, 0.0\n4, 2.0, 0.0, 0.0\n5, 0.0, 0.0, 0.0\n6, 3.0, 1.0, 0.0\n7, 3.0, -1.0, 0.0","category":"page"},{"location":"meshes/p4est_mesh/#List-of-elements","page":"P4est-based mesh","title":"List of elements","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The element connectivity is given after the list of corners. The header for this information block is","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"*ELEMENT, type=CPS4, ELSET=Surface1","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The Abaqus element type CPS4 corresponds to a quadrilateral element. Each quadrilateral element in the unstructured mesh is dictated by four corner points with indexing taken from the numbering given by the corner list above. The elements connect a set of four corner points (starting from the bottom left) in an anti-clockwise fashion; making the element right-handed. This element handedness is indicated using the circular arrow in the figure above. Just as with the corner list, the first integer in the element connectivity list indicates the element id number. Thus, the element connectivity list for the three element example mesh is","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"*ELEMENT, type=CPS4, ELSET=Surface1\n1, 5, 1, 4, 3\n2, 4, 2, 6, 3\n3, 7, 2, 4, 1","category":"page"},{"location":"meshes/p4est_mesh/#Element-neighbor-connectivity","page":"P4est-based mesh","title":"Element neighbor connectivity","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The construction of the element neighbor ids and identifying physical boundary surfaces is done using functionality directly from the p4est library. For example, the neighbor connectivity is created in the mesh constructor using the wrapper read_inp_p4est function.","category":"page"},{"location":"meshes/p4est_mesh/#HOHQMesh-boundary-information","page":"P4est-based mesh","title":"HOHQMesh boundary information","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"If present, any additional information in the mesh file that was created by HOHQMesh is prefaced with ** to make it an Abaqus comment. This ensures that the read in of the file by a standard Abaqus file parser, as done in the read_inp_p4est function, is done correctly.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The high-order, curved boundary information and labels of the physical boundary created by HOHQMesh is found below the comment line","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"** ***** HOHQMesh boundary information ***** **","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Next comes the polynomial degree that the mesh will use to represent any curved sides","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"** mesh polynomial degree = 8","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The mesh file then, again, provides the element connectivity as well as information for curved surfaces either interior to the domain or along the physical boundaries. A set of check digits are included directly below the four corner indexes to indicate whether the local surface index (-y, +x, +y, or -x) within the element is straight sided, 0, or is curved, 1. If the local surface is straight sided no additional information is necessary during the mesh file read in. But for any curved surfaces the mesh file provides (x,y,z) coordinate values in order to construct an interpolant of this surface with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes. This list of (x,y,z) data will be given in the direction of the local coordinate system. Given below is the element curvature information for the example mesh:","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"** 5 1 4 3\n** 0 0 1 1\n** 1.000000000000000 1.000000000000000 0.0\n** 1.024948365654583 0.934461926834452 0.0\n** 1.116583018200151 0.777350964621867 0.0\n** 1.295753434047077 0.606254343587194 0.0\n** 1.537500000000000 0.462500000000000 0.0\n** 1.768263070247418 0.329729152118310 0.0\n** 1.920916981799849 0.185149035378133 0.0\n** 1.986035130050921 0.054554577460044 0.0\n** 2.000000000000000 0.0 0.0\n** 0.0 0.0 0.0\n** 0.035513826946206 0.105291711848750 0.0\n** 0.148591270347399 0.317731556850611 0.0\n** 0.340010713990041 0.452219430075470 0.0\n** 0.575000000000000 0.462500000000000 0.0\n** 0.788022294598950 0.483764065630034 0.0\n** 0.926408729652601 0.644768443149389 0.0\n** 0.986453164464803 0.883724792445746 0.0\n** 1.000000000000000 1.000000000000000 0.0\n** 4 2 6 3\n** 0 0 0 1\n** 2.000000000000000 0.0 0.0\n** 1.986035130050921 0.054554577460044 0.0\n** 1.920916981799849 0.185149035378133 0.0\n** 1.768263070247418 0.329729152118310 0.0\n** 1.537500000000000 0.462500000000000 0.0\n** 1.295753434047077 0.606254343587194 0.0\n** 1.116583018200151 0.777350964621867 0.0\n** 1.024948365654583 0.934461926834452 0.0\n** 1.000000000000000 1.000000000000000 0.0\n** 7 2 4 1\n** 0 0 0 0","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The last piece of information provided by HOHQMesh are labels for the different surfaces of an element. These labels are useful to set boundary conditions along physical surfaces. The labels can be short descriptive words up to 32 characters in length. The label --- indicates an internal surface where no boundary condition is required.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"It is important to note that these labels are given in the following order according to the local surface index -x +x -y +y as required by the p4est library.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"** Bezier --- Slant ---\n** --- Right --- Top\n** Bottom --- Right ---","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"For completeness, we provide the entire Abaqus mesh file for the example mesh in the figure above:","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"*Heading\n File created by HOHQMesh\n*NODE\n1, 1.0, -1.0, 0.0\n2, 3.0, 0.0, 0.0\n3, 1.0, 1.0, 0.0\n4, 2.0, 0.0, 0.0\n5, 0.0, 0.0, 0.0\n6, 3.0, 1.0, 0.0\n7, 3.0, -1.0, 0.0\n*ELEMENT, type=CPS4, ELSET=Surface1\n1, 5, 1, 4, 3\n2, 4, 2, 6, 3\n3, 7, 2, 4, 1\n** ***** HOHQMesh boundary information ***** **\n** mesh polynomial degree = 8\n** 5 1 4 3\n** 0 0 1 1\n** 1.000000000000000 1.000000000000000 0.0\n** 1.024948365654583 0.934461926834452 0.0\n** 1.116583018200151 0.777350964621867 0.0\n** 1.295753434047077 0.606254343587194 0.0\n** 1.537500000000000 0.462500000000000 0.0\n** 1.768263070247418 0.329729152118310 0.0\n** 1.920916981799849 0.185149035378133 0.0\n** 1.986035130050921 0.054554577460044 0.0\n** 2.000000000000000 0.0 0.0\n** 0.0 0.0 0.0\n** 0.035513826946206 0.105291711848750 0.0\n** 0.148591270347399 0.317731556850611 0.0\n** 0.340010713990041 0.452219430075470 0.0\n** 0.575000000000000 0.462500000000000 0.0\n** 0.788022294598950 0.483764065630034 0.0\n** 0.926408729652601 0.644768443149389 0.0\n** 0.986453164464803 0.883724792445746 0.0\n** 1.000000000000000 1.000000000000000 0.0\n** 4 2 6 3\n** 0 0 0 1\n** 2.000000000000000 0.0 0.0\n** 1.986035130050921 0.054554577460044 0.0\n** 1.920916981799849 0.185149035378133 0.0\n** 1.768263070247418 0.329729152118310 0.0\n** 1.537500000000000 0.462500000000000 0.0\n** 1.295753434047077 0.606254343587194 0.0\n** 1.116583018200151 0.777350964621867 0.0\n** 1.024948365654583 0.934461926834452 0.0\n** 1.000000000000000 1.000000000000000 0.0\n** 7 2 4 1\n** 0 0 0 0\n** Bezier --- Slant ---\n** --- Right --- Top\n** Bottom --- Right ---","category":"page"},{"location":"meshes/p4est_mesh/#Mesh-in-three-spatial-dimensions","page":"P4est-based mesh","title":"Mesh in three spatial dimensions","text":"","category":"section"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The 3D Abaqus file format with high-order boundary information from HOHQMesh is very similar to the 2D version discussed above. There are only three changes:","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"The element connectivity would be given in terms of the eight corners that define a hexahedron. The corners are numbered as shown in the figure below. The header of the element list changes to be\n*ELEMENT, type=C3D8, ELSET=Volume1\nwhere C3D8 corresponds to a Abaqus hexahedral element.\nThere are six check digits included directly below the eight corner indexes to indicate whether the local face within the element is straight sided, 0, or is curved, 1. For curved faces (x,y,z) coordinate values are available in order to construct an face interpolant with the mesh polynomial order at the Chebyshev-Gauss-Lobatto nodes.\nThe boundary labels are given in the following order according to the local surface index -x +x -y +y -z +z as required by the p4est library.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"For completeness, we also give a short description and derivation of the three-dimensional transfinite mapping formulas used to compute the physical coordinates mathbfx=(xyz) of a (possibly curved) hexahedral element give the reference coordinates boldsymbolxi = (xi eta zeta) which lie in -11^3. That is, we will create an expression mathbfx= mathbfX(boldsymbolxi).","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Below we provide a sketch of a single hexahedral element with curved faces. This is done to introduce the numbering conventions for corners, edges, and faces of the element.","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"(Image: abaqus-3dmesh-docs)","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"When the hexahedron is a straight sided (linear) element we compute the transfinite mapping directly from the element corner points according to","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"beginaligned\nmathbfX_linear(boldsymbolxi) = frac18quad mathbfx_1(1-xi)(1-eta)(1-zeta)\n + mathbfx_2(1+xi)(1-eta)(1-zeta)-015cm\n qquad + mathbfx_3(1+xi)(1+eta)(1-zeta)\n + mathbfx_4(1-xi)(1+eta)(1-zeta) \n qquad + mathbfx_5(1-xi)(1-eta)(1+zeta)\n + mathbfx_6(1+xi)(1-eta)(1+zeta) \n qquad + mathbfx_7(1+xi)(1+eta)(1+zeta)\n + mathbfx_8(1-xi)(1+eta)(1+zeta)quad\nendaligned","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Next, we create a transfinite mapping function, mathbfX(boldsymbolxi), for a hexahedron that has one or more curved faces. For this we assume that have a set of six interpolating polynomials Gamma_i_i=1^6 that approximate the faces. The interpolating polynomial for any curved faces is provided by the information in a HOHQMesh Abaqus mesh file or is constructed on the fly via a bi-linear interpolation routine for any linear faces. Explicitly, these six face interpolation polynomials depend on the computational coordinates boldsymbolxi as follows","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":" beginaligned\n Gamma_1(xi zeta) quad quad Gamma_3(xi eta) quad quad Gamma_4(eta zeta)01cm\n Gamma_2(xi zeta) quad quad Gamma_5(xi eta) quad quad Gamma_6(eta zeta)\n endaligned","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"To determine the form of the mapping we first create linear interpolations between two opposing faces, e.g., Gamma_3 and Gamma_5 and sum them together to have","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"beginaligned\n boldsymbolSigma(boldsymbolxi) = frac12quad(1-xi)Gamma_6(etazeta) + (1+xi)Gamma_4(etazeta) -015cm\n qquad+ (1-eta)Gamma_1(xizeta) + (1+eta)Gamma_2(xizeta) -015cm\n qquad +(1-zeta)Gamma_3(xieta) + (1+zeta)Gamma_5(xieta)quad\nendaligned","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"Unfortunately, the linear interpolations boldsymbolSigma(boldsymbolxi) no longer match at the faces, e.g., evaluating at eta = -1 we have","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"boldsymbolSigma(xi-1zeta) = Gamma_1(xizeta) + frac12(1-xi)Gamma_6(-1zeta) + (1+xi)Gamma_4(-1zeta)\n +(1-zeta)Gamma_3(xi-1) + (1+zeta)Gamma_5(xi-1)","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"which is the desired face Gamma_1(xizeta) plus four edge error terms. Analogous edge error terms occur at the other faces evaluating boldsymbolSigma(boldsymbolxi) at eta=1, xi=pm 1, and zeta=pm 1. In order to match the faces, we subtract a linear interpolant in the xi, eta, and zeta directions of the edge error terms, e.g., the terms in braces in the above equation. So, continuing the example above, the correction term to be subtracted for face Gamma_1 to match would be","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"left(frac1-eta2right) bigg frac12 (1-xi)Gamma_6(-1zeta) + (1+xi)Gamma_4(-1zeta)+(1-zeta)Gamma_3(xi-1)\n + (1+zeta)Gamma_5(xi-1) bigg","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"For clarity, and to allow an easier comparison to the implementation, we introduce auxiliary notation for the 12 edge values present in the complete correction term. That is, for given values of xi, eta, and zeta we have","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":" beginaligned\n textttedge_1 = Gamma_1(xi -1) quad quad textttedge_5 = Gamma_2(xi -1) quad quad textttedge_9 = Gamma_6(eta -1)01cm\n textttedge_2 = Gamma_1(1 zeta) quad quadtextttedge_6 = Gamma_2(1 zeta) quad quad textttedge_10 = Gamma_4(eta -1)01cm\n textttedge_3 = Gamma_1(xi 1) quad quad textttedge_7 = Gamma_2(xi 1) quad quad textttedge_11 = Gamma_4(eta 1)01cm\n textttedge_4 = Gamma_1(-1 zeta) quad quad textttedge_8 = Gamma_2(-1 zeta) quad quad textttedge_12 = Gamma_6(eta 1)\n endaligned","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"With this notation for the edge terms (and after some algebraic manipulation) we write the complete edge correction term, mathcalC_textttedge(boldsymbolxi), as","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"beginaligned\nmathcalC_textttedge(boldsymbolxi) = frac14quad (1-eta)(1-zeta)textttedge_1-015cm\n qquad + (1+xi)(1-eta)textttedge_2 \n qquad + (1-eta)(1+zeta)textttedge_3 \n qquad + (1-xi)(1-eta)textttedge_4 \n qquad + (1+eta)(1-zeta)textttedge_5 \n qquad + (1+xi)(1+eta)textttedge_6 \n qquad + (1+eta)(1+zeta)textttedge_7 \n qquad + (1-xi)(1+eta)textttedge_8 \n qquad + (1-xi)(1-zeta)textttedge_9 \n qquad + (1+xi)(1-zeta)textttedge_10 \n qquad + (1+xi)(1+zeta)textttedge_11 \n qquad + (1-xi)(1+zeta)textttedge_12quad\nendaligned","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"However, subtracting the edge correction terms mathcalC_textttedge(boldsymbolxi) from boldsymbolSigma(boldsymbolxi) removes the interior element contributions twice. Thus, to complete the construction of the transfinite mapping mathbfX(boldsymbolxi) we add the transfinite map of the straight sided hexahedral element to find","category":"page"},{"location":"meshes/p4est_mesh/","page":"P4est-based mesh","title":"P4est-based mesh","text":"mathbfX(boldsymbolxi) = boldsymbolSigma(boldsymbolxi)\n - mathcalC_textttedge(boldsymbolxi)\n + mathbfX_linear(boldsymbolxi)","category":"page"},{"location":"troubleshooting/#Troubleshooting-and-FAQ","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"In general, Trixi.jl works best with the newest Julia release and up-to-date dependencies. If something does not work as expected, try updating your installed Julia packages via the package manager, e.g., by running","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"julia> import Pkg; Pkg.update()","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"If you do not use the latest stable release of Julia from the official website, consider updating your Julia installation.","category":"page"},{"location":"troubleshooting/#old-release","page":"Troubleshooting and FAQ","title":"Installing Trixi.jl as a package only provides an older release","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"Trixi.jl requires fairly recent versions of several of its dependencies, which sometimes causes issues when other installed packages have conflicting version requirements. In this case, Julia's package manager Pkg will try to handle this gracefully by going back in history until it finds a Trixi.jl release whose version requirements can be met, resulting in an older - and usually outdated - version of Trixi.jl being installed.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"The following example illustrates this issue:","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"The current Trixi.jl release v0.3.6 requires package Foo with a minimum version of v0.2.\nAn older Trixi.jl release v0.2.1 requires package Foo only with a minimum version of v0.1.\nA user has already installed package Bar, which itself requires Foo with a maximum version of v0.1.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"In this case, installing Trixi.jl via Pkg will result in version v0.2.1 to be installed instead of the current release v0.3.6. That is, a specific release of Trixi.jl may not be installable if it has a dependency with a higher minimum version that at the same time is restricted to a lower maximum version by another installed package.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"You can check whether an outdated version of Trixi.jl is installed by executing","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"julia> import Pkg; Pkg.update(\"Trixi\"); Pkg.status(\"Trixi\")","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"in the REPL and comparing the reported Trixi.jl version with the version of the latest release. If the versions differ, you can confirm that it is due to a version conflict by forcing Pkg to install the latest Trixi.jl release, where version is the current release:","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"julia> Pkg.add(name=\"Trixi\", version=\"0.3.6\")","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"In case of a conflict, the command above will produce an error that informs you about the offending packages, similar to the following:","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":" Updating registry at `~/.julia/registries/General`\n Resolving package versions...\nERROR: Unsatisfiable requirements detected for package DataStructures [864edb3b]:\n DataStructures [864edb3b] log:\n ├─possible versions are: [0.9.0, 0.10.0, 0.11.0-0.11.1, 0.12.0, 0.13.0, 0.14.0-0.14.1, 0.15.0, 0.16.1, 0.17.0-0.17.20, 0.18.0-0.18.8] or uninstalled\n ├─restricted by compatibility requirements with DiffEqCallbacks [459566f4] to versions: 0.18.0-0.18.8\n │ └─DiffEqCallbacks [459566f4] log:\n │ ├─possible versions are: [2.0.0, 2.1.0, 2.2.0, 2.3.0, 2.4.0, 2.5.0-2.5.2, 2.6.0, 2.7.0, 2.8.0, 2.9.0, 2.10.0, 2.11.0, 2.12.0-2.12.1, 2.13.0-2.13.5, 2.14.0-2.14.1, 2.15.0] or uninstalled\n │ ├─restricted by compatibility requirements with Trixi [a7f1ee26] to versions: [2.14.0-2.14.1, 2.15.0]\n │ │ └─Trixi [a7f1ee26] log:\n │ │ ├─possible versions are: [0.1.0-0.1.2, 0.2.0-0.2.6, 0.3.0-0.3.6] or uninstalled\n │ │ └─restricted to versions 0.3.6 by an explicit requirement, leaving only versions 0.3.6\n │ └─restricted by compatibility requirements with StaticArrays [90137ffa] to versions: 2.15.0 or uninstalled, leaving only versions: 2.15.0\n │ └─StaticArrays [90137ffa] log:\n │ ├─possible versions are: [0.8.0-0.8.3, 0.9.0-0.9.2, 0.10.0, 0.10.2-0.10.3, 0.11.0-0.11.1, 0.12.0-0.12.5, 1.0.0-1.0.1] or uninstalled\n │ └─restricted by compatibility requirements with Trixi [a7f1ee26] to versions: 1.0.0-1.0.1\n │ └─Trixi [a7f1ee26] log: see above\n └─restricted by compatibility requirements with JLD2 [033835bb] to versions: [0.9.0, 0.10.0, 0.11.0-0.11.1, 0.12.0, 0.13.0, 0.14.0-0.14.1, 0.15.0, 0.16.1, 0.17.0-0.17.20] — no versions left\n └─JLD2 [033835bb] log:\n ├─possible versions are: [0.1.0-0.1.14, 0.2.0-0.2.4, 0.3.0-0.3.1] or uninstalled\n └─restricted by compatibility requirements with BinaryBuilder [12aac903] to versions: 0.1.0-0.1.14\n └─BinaryBuilder [12aac903] log:\n ├─possible versions are: [0.1.0-0.1.2, 0.1.4, 0.2.0-0.2.6] or uninstalled\n └─restricted to versions * by an explicit requirement, leaving only versions [0.1.0-0.1.2, 0.1.4, 0.2.0-0.2.6]","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"From the error message, we can see that ultimately BinaryBuilder is the problem here: It restricts the package DataStructures to version v0.17 (via its dependency JLD2), while Trixi.jl requires at least v0.18 (via its dependency DiffEqCallbacks). Following the official Pkg documentation, there are a number of things you can try to fix such errors:","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"Try updating all packages with julia -e 'using Pkg; Pkg.update()'. A newer version of the problematic package may exist that has updated version requirements.\nRemove the offending package. Running\njulia> import Pkg; Pkg.rm(\"BinaryBuilder\"); Pkg.update(); Pkg.status()\nin the REPL will remove BinaryBuilder and (hopefully) update Trixi.jl to the latest version.\nReport the versioning issue to us and/or the development repository of the conflicting package. Maybe it is possible to lift the version restrictions such that both packages can live side by side.\nInstead of installing Trixi.jl and conflicting packages in the same (default) environment, consider creating new environments/projects and install only packages required for the specific tasks, as explained in the official Pkg documentation. For example, if you use Trixi.jl for a research project (Bachelor/Master thesis or a paper), you should create a new Julia project/environment for that research and add Trixi.jl as a dependency. If you track all your code and the Project.toml, Manifest.toml files (generated by Pkg) in a version control system such as git, you can make your research easily reproducible (if you also record the version of Julia you are using and leave some comments for others who do not know what you are trying to do, including your future self 😉).","category":"page"},{"location":"troubleshooting/#font-issues","page":"Troubleshooting and FAQ","title":"There are many questions marks and weird symbols in the output of Trixi.jl","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"This probably means that the default font used by your operating system does not support enough Unicode symbols. Try installing a modern font with decent unicode support, e.g. JuliaMono. Detailed installation instructions are available there.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"This problems affects users of Mac OS particularly often. At the time of writing, installing JuliaMono is as simple as","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"$ brew tap homebrew/cask-fonts\n$ brew install --cask font-juliamono","category":"page"},{"location":"troubleshooting/#There-are-no-timing-results-of-the-initial-mesh-creation","page":"Troubleshooting and FAQ","title":"There are no timing results of the initial mesh creation","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"By default, the SummaryCallback resets the timer used internally by Trixi.jl when it is initialized (when solve is called). If this step needs to be timed, e.g. to debug performance problems, explicit timings can be used as follows.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"using Trixi\n\nbegin\n Trixi.reset_timer!(Trixi.timer())\n\n equations = LinearScalarAdvectionEquation2D(0.2, -0.7)\n mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), n_cells_max=10^5, initial_refinement_level=5)\n solver = DGSEM(3)\n semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test, solver)\n\n Trixi.print_timer(Trixi.timer())\nend","category":"page"},{"location":"troubleshooting/#MPI-ranks-are-assigned-zero-cells-in-[P4estMesh](@ref)-even-though-there-are-enough-cells","page":"Troubleshooting and FAQ","title":"MPI ranks are assigned zero cells in P4estMesh even though there are enough cells","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"The P4estMesh allows one to coarsen the mesh by default. When Trixi.jl is parallelized with multiple MPI ranks, this has the consequence that sibling cells (i.e., child cells with the same parent cell) are kept on the same MPI rank to be able to coarsen them easily. This might cause an unbalanced distribution of cells on different ranks. For 2D meshes, this also means that initially each rank will at least own 4 cells, and for 3D meshes, initially each rank will at least own 8 cells. See issue #1329.","category":"page"},{"location":"troubleshooting/#Installing-and-updating-everything-takes-a-lot-of-time","page":"Troubleshooting and FAQ","title":"Installing and updating everything takes a lot of time","text":"","category":"section"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"Julia compiles code to get good (C/Fortran-like) performance. At the same time, Julia provides a dynamic environment and usually compiles code just before using it. Over time, Julia has improved its caching infrastructure, allowing to store and reuse more results from (pre-)compilation. This often results in an increased time to install/update packages, in particular when updating to Julia v1.8 or v1.9 from older versions.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"Some packages used together with Trixi.jl provide options to configure the amount of precompilation. For example, OrdinaryDiffEq.jl precompiles many ODE solvers for a good runtime experience of average users. Currently, Trixi.jl does not use all of the available solvers. Thus, you can save some time at every update by setting their precompilation options.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"At the time of writing, this could look as follows. First, you need to activate the environment where you have installed OrdinaryDiffEq.jl. Then, you need to execute the following Julia code.","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"using Preferences, UUIDs\nlet uuid = UUID(\"1dea7af3-3e70-54e6-95c3-0bf5283fa5ed\")\n set_preferences!(uuid, \"PrecompileAutoSpecialize\" => false)\n set_preferences!(uuid, \"PrecompileAutoSwitch\" => false)\n set_preferences!(uuid, \"PrecompileDefaultSpecialize\" => true)\n set_preferences!(uuid, \"PrecompileFunctionWrapperSpecialize\" => false)\n set_preferences!(uuid, \"PrecompileLowStorage\" => true)\n set_preferences!(uuid, \"PrecompileNoSpecialize\" => false)\n set_preferences!(uuid, \"PrecompileNonStiff\" => true)\n set_preferences!(uuid, \"PrecompileStiff\" => false)\nend","category":"page"},{"location":"troubleshooting/","page":"Troubleshooting and FAQ","title":"Troubleshooting and FAQ","text":"This disables precompilation of all implicit methods. This should usually not affect the runtime latency with Trixi.jl since most setups use explicit time integration methods.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"EditURL = \"../../literate/src/files/shock_capturing.jl\"","category":"page"},{"location":"tutorials/shock_capturing/#shock_capturing","page":"3 Shock capturing with flux differencing and stage limiter","title":"3: Shock capturing with flux differencing and stage limiter","text":"","category":"section"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"This tutorial contains a short summary of the idea of shock capturing for DGSEM with flux differencing and its implementation in Trixi.jl. In the second part, an implementation of a positivity preserving limiter is added to the simulation.","category":"page"},{"location":"tutorials/shock_capturing/#Shock-capturing-with-flux-differencing","page":"3 Shock capturing with flux differencing and stage limiter","title":"Shock capturing with flux differencing","text":"","category":"section"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"The following rough explanation is on a very basic level. More information about an entropy stable shock-capturing strategy for DGSEM discretizations of advection dominated problems, such as the compressible Euler equations or the compressible Navier-Stokes equations, can be found in Hennemann et al. (2021). In Rueda-Ramírez et al. (2021) you find the extension to the systems with non-conservative terms, such as the compressible magnetohydrodynamics (MHD) equations.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"The strategy for a shock-capturing method presented by Hennemann et al. is based on a hybrid blending of a high-order DG method with a low-order variant. The low-order subcell finite volume (FV) method is created directly with the Legendre-Gauss-Lobatto (LGL) nodes already used for the high-order DGSEM. Then, the final method is a convex combination with regulating indicator alpha of these two methods.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Since the surface integral is equal for both the DG and the subcell FV method, only the volume integral divides between the two methods.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"This strategy for the volume integral is implemented in Trixi.jl under the name of VolumeIntegralShockCapturingHG with the three parameters of the indicator and the volume fluxes for the DG and the subcell FV method.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Note, that the DG method is based on the flux differencing formulation. Hence, you have to use a two-point flux, such as flux_ranocha, flux_shima_etal, flux_chandrashekar or flux_kennedy_gruber, for the DG volume flux. We would recommend to use the entropy conserving flux flux_ranocha by Ranocha (2018) for the compressible Euler equations.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;\n volume_flux_dg=volume_flux_dg,\n volume_flux_fv=volume_flux_fv)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We now focus on a choice of the shock capturing indicator indicator_sc. A possible indicator is alpha_HG presented by Hennemann et al. (p.10), which depends on the current approximation with modal coefficients m_j_j=0^N of a given variable.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"The indicator is calculated for every DG element by itself. First, we calculate a smooth alpha by","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"alpha = frac11+exp(-frac-smathbbT(mathbbE-mathbbT))","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"with the total energy mathbbE=maxbig(fracm_N^2sum_j=0^N m_j^2 fracm_N-1^2sum_j=0^N-1 m_j^2big), threshold mathbbT= 05 * 10^-18*(N+1)^14 and parameter s=lnbig(frac1-0000100001big)approx 921024.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"For computational efficiency, alpha_min is introduced and used for","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"tildealpha = begincases\n0 textif alphaalpha_min\nalpha textif alpha_minleq alpha leq 1- alpha_min\n1 textif 1-alpha_minalpha\nendcases","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Moreover, the parameter alpha_max sets a maximal value for alpha by","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"alpha = mintildealpha alpha_max","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"This allows to control the maximal dissipation.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"To remove numerical artifact the final indicator is smoothed with all the neighboring elements' indicators. This is activated with alpha_smooth=true.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"alpha_HG = max_E alpha 05 * alpha_E","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"where E are all elements sharing a face with the current element.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Furthermore, you can specify the variable used for the calculation. For instance you can choose density, pressure or both with density_pressure for the compressible Euler equations. For every equation there is also the option to use the first conservation variable with first.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"This indicator is implemented in Trixi.jl and called IndicatorHennemannGassner with the parameters equations, basis, alpha_max, alpha_min, alpha_smooth and variable.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"indicator_sc = IndicatorHennemannGassner(equations, basis,\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable=variable)","category":"page"},{"location":"tutorials/shock_capturing/#Positivity-preserving-limiter","page":"3 Shock capturing with flux differencing and stage limiter","title":"Positivity preserving limiter","text":"","category":"section"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Some numerical solutions are physically meaningless, for instance negative values of pressure or density for the compressible Euler equations. This often results in crashed simulations since the calculation of numerical fluxes or stable time steps uses mathematical operations like roots or logarithms. One option to avoid these cases are a-posteriori positivity preserving limiters. Trixi.jl provides the fully-discrete positivity-preserving limiter of Zhang, Shu (2011).","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"It works the following way. For every passed (scalar) variable and for every DG element we calculate the minimal value value_min. If this value falls below the given threshold varepsilon, the approximation is slightly adapted such that the minimal value of the relevant variable lies now above the threshold.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"underlineu^new = theta * underlineu + (1-theta) * u_mean","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"where underlineu are the collected pointwise evaluation coefficients in element e and u_mean the integral mean of the quantity in e. The new coefficients are a convex combination of these two values with factor","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"theta = fracvalue_mean - varepsilonvalue_mean - value_min","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"where value_mean is the relevant variable evaluated for the mean value u_mean.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"The adapted approximation keeps the exact same mean value, but the relevant variable is now greater or equal the threshold varepsilon at every node in every element.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We specify the variables the way we did before for the shock capturing variables. For the compressible Euler equations density, pressure or the combined variable density_pressure are a reasonable choice.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"You can implement the limiter in Trixi.jl using PositivityPreservingLimiterZhangShu with parameters threshold and variables.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=thresholds,\n variables=variables)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Then, the limiter is added to the time integration method in the solve function. For instance, like","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"CarpenterKennedy2N54(stage_limiter!, williamson_condition=false)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"or","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"SSPRK43(stage_limiter!).","category":"page"},{"location":"tutorials/shock_capturing/#Simulation-with-shock-capturing-and-positivity-preserving","page":"3 Shock capturing with flux differencing and stage limiter","title":"Simulation with shock capturing and positivity preserving","text":"","category":"section"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Now, we can run a simulation using the described methods of shock capturing and positivity preserving limiters. We want to give an example for the 2D compressible Euler equations.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"using OrdinaryDiffEq, Trixi\n\nequations = CompressibleEulerEquations2D(1.4)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"As our initial condition we use the Sedov blast wave setup.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"function initial_condition_sedov_blast_wave(x, t, equations::CompressibleEulerEquations2D)\n # Set up polar coordinates\n inicenter = SVector(0.0, 0.0)\n x_norm = x[1] - inicenter[1]\n y_norm = x[2] - inicenter[2]\n r = sqrt(x_norm^2 + y_norm^2)\n\n r0 = 0.21875 # = 3.5 * smallest dx (for domain length=4 and max-ref=6)\n # r0 = 0.5 # = more reasonable setup\n E = 1.0\n p0_inner = 3 * (equations.gamma - 1) * E / (3 * pi * r0^2)\n p0_outer = 1.0e-5 # = true Sedov setup\n # p0_outer = 1.0e-3 # = more reasonable setup\n\n # Calculate primitive variables\n rho = 1.0\n v1 = 0.0\n v2 = 0.0\n p = r > r0 ? p0_outer : p0_inner\n\n return prim2cons(SVector(rho, v1, v2, p), equations)\nend\ninitial_condition = initial_condition_sedov_blast_wave","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"basis = LobattoLegendreBasis(3)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We set the numerical fluxes and divide between the surface flux and the two volume fluxes for the DG and FV method. Here, we are using flux_lax_friedrichs and flux_ranocha.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"surface_flux = flux_lax_friedrichs\nvolume_flux = flux_ranocha","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Now, we specify the shock capturing indicator alpha.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We implement the described indicator of Hennemann, Gassner as explained above with parameters equations, basis, alpha_max, alpha_min, alpha_smooth and variable. Since density and pressure are the critical variables in this example, we use density_pressure = density * pressure = rho * p as indicator variable.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"indicator_sc = IndicatorHennemannGassner(equations, basis,\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable=density_pressure)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"Now, we can use the defined fluxes and the indicator to implement the volume integral using shock capturing.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;\n volume_flux_dg=volume_flux,\n volume_flux_fv=surface_flux)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We finalize the discretization by implementing Trixi.jl's solver, mesh, semi and ode, while solver now has the extra parameter volume_integral.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"solver = DGSEM(basis, surface_flux, volume_integral)\n\ncoordinates_min = (-2.0, -2.0)\ncoordinates_max = ( 2.0, 2.0)\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=6,\n n_cells_max=10_000)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n\ntspan = (0.0, 1.0)\node = semidiscretize(semi, tspan);\nnothing #hide","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We add some callbacks to get an solution analysis and use a CFL-based time step size calculation.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"analysis_callback = AnalysisCallback(semi, interval=100)\n\nstepsize_callback = StepsizeCallback(cfl=0.8)\n\ncallbacks = CallbackSet(analysis_callback, stepsize_callback);\nnothing #hide","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"We now run the simulation using the positivity preserving limiter of Zhang and Shu for the variables density and pressure.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=(5.0e-6, 5.0e-6),\n variables=(Trixi.density, pressure))\n\nsol = solve(ode, CarpenterKennedy2N54(stage_limiter!, williamson_condition=false),\n dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, callback=callbacks);\n\nusing Plots\nplot(sol)","category":"page"},{"location":"tutorials/shock_capturing/#Package-versions","page":"3 Shock capturing with flux differencing and stage limiter","title":"Package versions","text":"","category":"section"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"","category":"page"},{"location":"tutorials/shock_capturing/","page":"3 Shock capturing with flux differencing and stage limiter","title":"3 Shock capturing with flux differencing and stage limiter","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"EditURL = \"../../literate/src/files/DGMulti_1.jl\"","category":"page"},{"location":"tutorials/DGMulti_1/#DGMulti_1","page":"5 DG schemes via DGMulti solver","title":"5: DG schemes via DGMulti solver","text":"","category":"section"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"DGMulti is a DG solver that allows meshes with simplex elements. The basic idea and implementation of this solver is explained in section \"Meshes\". Here, we want to give some examples and a quick overview about the options with DGMulti.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"We start with a simple example we already used in the tutorial about flux differencing. There, we implemented a simulation with initial_condition_weak_blast_wave for the 2D compressible Euler equations CompressibleEulerEquations2D and used the DG formulation with flux differencing using volume flux flux_ranocha and surface flux flux_lax_friedrichs.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"Here, we want to implement the equivalent example, only now using the DGMulti solver instead of DGSEM.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Trixi, OrdinaryDiffEq\n\nequations = CompressibleEulerEquations2D(1.4)\n\ninitial_condition = initial_condition_weak_blast_wave","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"To use the Gauss-Lobatto nodes again, we choose approximation_type=SBP() in the solver. Since we want to start with a Cartesian domain discretized with squares, we use the element type Quad().","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"dg = DGMulti(polydeg = 3,\n element_type = Quad(),\n approximation_type = SBP(),\n surface_flux = flux_lax_friedrichs,\n volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n\ncells_per_dimension = (32, 32)\nmesh = DGMultiMesh(dg,\n cells_per_dimension, # initial_refinement_level = 5\n coordinates_min=(-2.0, -2.0),\n coordinates_max=( 2.0, 2.0),\n periodicity=true)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n boundary_conditions=boundary_condition_periodic)\ntspan = (0.0, 0.4)\node = semidiscretize(semi, tspan)\n\nalive_callback = AliveCallback(alive_interval=10)\nanalysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\ncallbacks = CallbackSet(analysis_callback, alive_callback);\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"Run the simulation with the same time integration algorithm as before.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"sol = solve(ode, RDPK3SpFSAL49(), abstol=1.0e-6, reltol=1.0e-6,\n callback=callbacks, save_everystep=false);\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Plots\npd = PlotData2D(sol)\nplot(pd)","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"plot(pd[\"rho\"])\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"This simulation is not as fast as the equivalent with TreeMesh since no special optimizations for quads (for instance tensor product structure) have been implemented. Figure 4 in \"Efficient implementation of modern entropy stable and kinetic energy preserving discontinuous Galerkin methods for conservation laws\" (2021) provides a nice runtime comparison between the different mesh types. On the other hand, the functions are more general and thus we have more option we can choose from.","category":"page"},{"location":"tutorials/DGMulti_1/#Simulation-with-Gauss-nodes","page":"5 DG schemes via DGMulti solver","title":"Simulation with Gauss nodes","text":"","category":"section"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"For instance, we can change the approximation type of our simulation.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Trixi, OrdinaryDiffEq\nequations = CompressibleEulerEquations2D(1.4)\ninitial_condition = initial_condition_weak_blast_wave","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"We now use Gauss nodes instead of Gauss-Lobatto nodes which can be done for the element types Quad() and Hex(). Therefore, we set approximation_type=GaussSBP(). Alternatively, we can use a modal approach using the approximation type Polynomial().","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"dg = DGMulti(polydeg = 3,\n element_type = Quad(),\n approximation_type = GaussSBP(),\n surface_flux = flux_lax_friedrichs,\n volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n\ncells_per_dimension = (32, 32)\nmesh = DGMultiMesh(dg,\n cells_per_dimension, # initial_refinement_level = 5\n coordinates_min=(-2.0, -2.0),\n coordinates_max=( 2.0, 2.0),\n periodicity=true)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n boundary_conditions=boundary_condition_periodic)\ntspan = (0.0, 0.4)\node = semidiscretize(semi, tspan)\n\nalive_callback = AliveCallback(alive_interval=10)\nanalysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\ncallbacks = CallbackSet(analysis_callback, alive_callback);\n\nsol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n ode_default_options()..., callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Plots\npd = PlotData2D(sol)\nplot(pd)","category":"page"},{"location":"tutorials/DGMulti_1/#Simulation-with-triangular-elements","page":"5 DG schemes via DGMulti solver","title":"Simulation with triangular elements","text":"","category":"section"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"Also, we can set another element type. We want to use triangles now.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Trixi, OrdinaryDiffEq\nequations = CompressibleEulerEquations2D(1.4)\ninitial_condition = initial_condition_weak_blast_wave","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"Since there is no direct equivalent to Gauss-Lobatto nodes on triangles, the approximation type SBP() now uses Gauss-Lobatto nodes on faces and special nodes in the interior of the triangular. More details can be found in the documentation of StartUpDG.jl.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"dg = DGMulti(polydeg = 3,\n element_type = Tri(),\n approximation_type = SBP(),\n surface_flux = flux_lax_friedrichs,\n volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n\ncells_per_dimension = (32, 32)\nmesh = DGMultiMesh(dg,\n cells_per_dimension, # initial_refinement_level = 5\n coordinates_min=(-2.0, -2.0),\n coordinates_max=( 2.0, 2.0),\n periodicity=true)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n boundary_conditions=boundary_condition_periodic)\ntspan = (0.0, 0.4)\node = semidiscretize(semi, tspan)\n\nalive_callback = AliveCallback(alive_interval=10)\nanalysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\ncallbacks = CallbackSet(analysis_callback, alive_callback);\n\nsol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n ode_default_options()..., callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Plots\npd = PlotData2D(sol)\nplot(pd)","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"plot(pd[\"rho\"])\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/DGMulti_1/#Triangular-meshes-on-non-Cartesian-domains","page":"5 DG schemes via DGMulti solver","title":"Triangular meshes on non-Cartesian domains","text":"","category":"section"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"To use triangular meshes on a non-Cartesian domain, Trixi.jl uses the package StartUpDG.jl. The following example is based on elixir_euler_triangulate_pkg_mesh.jl and uses a pre-defined mesh from StartUpDG.jl.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Trixi, OrdinaryDiffEq","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"We want to simulate the smooth initial condition initial_condition_convergence_test with source terms source_terms_convergence_test for the 2D compressible Euler equations.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"equations = CompressibleEulerEquations2D(1.4)\ninitial_condition = initial_condition_convergence_test\nsource_terms = source_terms_convergence_test","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"We create the solver DGMulti with triangular elements (Tri()) as before.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"dg = DGMulti(polydeg = 3, element_type = Tri(),\n approximation_type=Polynomial(),\n surface_flux = flux_lax_friedrichs,\n volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"StartUpDG.jl provides for instance a pre-defined Triangulate geometry for a rectangular domain with hole RectangularDomainWithHole. Other pre-defined Triangulate geometries are e.g., SquareDomain, Scramjet, and CircularDomain.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"meshIO = StartUpDG.triangulate_domain(StartUpDG.RectangularDomainWithHole());\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"The pre-defined Triangulate geometry in StartUpDG has integer boundary tags. With DGMultiMesh we assign boundary faces based on these integer boundary tags and create a mesh compatible with Trixi.jl.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"mesh = DGMultiMesh(meshIO, dg, Dict(:outer_boundary=>1, :inner_boundary=>2))","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"boundary_condition_convergence_test = BoundaryConditionDirichlet(initial_condition)\nboundary_conditions = (; :outer_boundary => boundary_condition_convergence_test,\n :inner_boundary => boundary_condition_convergence_test)\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n source_terms = source_terms,\n boundary_conditions = boundary_conditions)\n\ntspan = (0.0, 0.2)\node = semidiscretize(semi, tspan)\n\nalive_callback = AliveCallback(alive_interval=20)\nanalysis_callback = AnalysisCallback(semi, interval=200, uEltype=real(dg))\ncallbacks = CallbackSet(alive_callback, analysis_callback);\n\nsol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt = 0.5 * estimate_dt(mesh, dg), save_everystep=false, callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using Plots\npd = PlotData2D(sol)\nplot(pd[\"rho\"])\nplot!(getmesh(pd))","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"For more information, please have a look in the StartUpDG.jl documentation.","category":"page"},{"location":"tutorials/DGMulti_1/#Package-versions","page":"5 DG schemes via DGMulti solver","title":"Package versions","text":"","category":"section"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"StartUpDG\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"","category":"page"},{"location":"tutorials/DGMulti_1/","page":"5 DG schemes via DGMulti solver","title":"5 DG schemes via DGMulti solver","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"EditURL = \"../../literate/src/files/adding_new_scalar_equations.jl\"","category":"page"},{"location":"tutorials/adding_new_scalar_equations/#adding_new_scalar_equations","page":"8 Adding a new scalar conservation law","title":"8: Adding a new scalar conservation law","text":"","category":"section"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"If you want to use Trixi.jl for your own research, you might be interested in a new physics model that's not already included in Trixi.jl. In this tutorial, we will implement the cubic conservation law","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"partial_t u(tx) + partial_x u(tx)^3 = 0","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"in a periodic domain in one space dimension. In Trixi.jl, such a mathematical model is encoded as a subtype of Trixi.AbstractEquations.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/#Basic-setup","page":"8 Adding a new scalar conservation law","title":"Basic setup","text":"","category":"section"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"using Trixi\n\nstruct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,\n 1 #= number of primary variables, i.e. scalar =#};\nend","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"We create CubicEquation as an empty struct since we do not use any parameters for this equation. Other models could bundle arbitrary parameters, e.g., the ideal gas constant for the compressible Euler equations.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Next, we define the physical flux f(u) = u^3 using the calling structure used in Trixi.jl.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Trixi.flux(u, orientation, equation::CubicEquation) = u.^3\nTrixi.varnames(_, ::CubicEquation) = (\"scalar\",)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"In Trixi.jl, the conserved variables u are usually passed as SVectors of variables at a single physical location. Hence, we must use u.^3 instead of the scalar operation u^3.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"That's already enough to run a simple simulation with a standard DGSEM discretization using the non-dissipative central flux at interfaces.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"using OrdinaryDiffEq\n\n# Create a simulation setup\nequation = CubicEquation()\n\ninitial_condition_sine(x, t, equation::CubicEquation) = SVector(sinpi(x[1]))\n\nmesh = TreeMesh(-1.0, 1.0, # min/max coordinates\n initial_refinement_level=4,\n n_cells_max=10^4)\n\nsolver = DGSEM(3 #= polynomial degree =#, flux_central)\n\nsemi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"We wrap the return value of the initial_condition_sine inside an SVector since that's the approach used in Trixi.jl also for systems of equations. We need to index the spatial coordinate x[1], since it is an SVector with one component. In multiple space dimensions, all spatial coordinates are passed together.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Next, we create an ODEProblem from the SciML/DifferentialEquations ecosystem. We can solve this ODE numerically using any time integration method, e.g., SSPRK43 from OrdinaryDiffEq.jl. Before, we set up a callback to summarize the simulation setup.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"# Create ODE problem with given time span\ntspan = (0.0, 0.09)\node = semidiscretize(semi, tspan)\n\nsummary_callback = SummaryCallback()\ncallbacks = CallbackSet(summary_callback)\n\n# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks\nsol = solve(ode, SSPRK43();\n ode_default_options()..., callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"That's it, you ran your first simulation using your new equation with Trixi.jl! Now, we can plot the solution at the final time using Plots.jl.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"using Plots\nplot(sol)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"You can already see that discontinuities will develop and oscillations start to occur around steep parts of the wave. That's expected from our central discretization. To avoid these issues, we need to use dissipative numerical fluxes (approximate Riemann solvers) at interfaces.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/#Advanced-setup","page":"8 Adding a new scalar conservation law","title":"Advanced setup","text":"","category":"section"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Thus, we add a Godunov's flux for our cubic equation. That is easy for this equation since the wave speed f'(u) = 3u^2 is always non-negative.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Let's run the example again but with a dissipative numerical flux at interfaces. remake will recreate the semidiscretization we used before and only change selected parameters, in this case the solver.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"# A new setup with dissipation\nsemi = remake(semi, solver=DGSEM(3, flux_godunov))\node = semidiscretize(semi, tspan)\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot!(sol)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"You can see that there are fewer oscillations, in particular around steep edges. Now let's increase the final time (and also the spatial resolution).","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)\nsemi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))\node = semidiscretize(semi, (0.0, 0.5) #= tspan =#)\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot(sol)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"You can observe that nonclassical shocks develop and are stable under grid refinement, e.g. for initial_refinement_level=12. In this case, these nonclassical shocks can be avoided by using an entropy-dissipative semidiscretization. Thus, we need to define an entropy-conservative numerical flux","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)\n return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))\nend","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"and use a VolumeIntegralFluxDifferencing instead of the standard VolumeIntegralWeakForm in the DGSEM.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"# Let's use a provably entropy-dissipative semidiscretization\nsemi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))\node = semidiscretize(semi, (0.0, 0.5))\nsol = solve(ode, SSPRK43(); ode_default_options()...);\nplot(sol)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"Possible next steps could be","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"to define Trixi.max_abs_speeds(u, equations::CubicEquation) = 3 * u[1]^2 to use CFL-based time step control via a StepsizeCallback\nto define quantities of interest like Trixi.entropy(u, equations::CubicEquation) = u[1]^2 and integrate them in a simulation using the AnalysisCallback\nto experiment with shock-capturing volume integrals VolumeIntegralShockCapturingHG and adaptive mesh refinement AMRCallback","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"For further reading, Trixi.jl provides another example on adding a scalar equation. In the elixir about the KPP problem, the 2D scalar \"KPP equation\" from Kurganov, Petrova, Popov (2007) is implemented.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/#Summary-of-the-code","page":"8 Adding a new scalar conservation law","title":"Summary of the code","text":"","category":"section"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"To sum up, here is the complete code that we used (without the callbacks since these create a lot of unnecessary output in the doctests of this tutorial). In addition, we create the struct inside the new module CubicConservationLaw. That ensures that we can re-create structs defined therein without having to restart Julia.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"# Define new physics\nmodule CubicConservationLaw\n\nusing Trixi\n\nstruct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,\n 1 #= number of primary variables, i.e. scalar =#}\nend\n\n@inline Trixi.flux(u, orientation, equation::CubicEquation) = u.^3\nTrixi.varnames(_, ::CubicEquation) = (\"scalar\",)\n\n@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)\n@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)\n return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))\nend\n\nend # module\n\n\n# Create a simulation setup\nimport .CubicConservationLaw\nusing Trixi\nusing OrdinaryDiffEq\nusing Plots\n\nequation = CubicConservationLaw.CubicEquation()\n\ninitial_condition_sine(x, t, equation::CubicConservationLaw.CubicEquation) = SVector(sinpi(x[1]))\n\nmesh = TreeMesh(-1.0, 1.0, # min/max coordinates\n initial_refinement_level=4,\n n_cells_max=10^4)\n\nsolver = DGSEM(3 #= polynomial degree =#, flux_central)\n\nsemi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n\n# Create ODE problem with given time span\ntspan = (0.0, 0.1)\node = semidiscretize(semi, tspan)\n\n# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot(sol)\n\n\n# A new setup with dissipation\nsemi = remake(semi, solver=DGSEM(3, flux_godunov))\node = semidiscretize(semi, tspan)\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot!(sol)\n\n\n# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)\nsemi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))\node = semidiscretize(semi, (0.0, 0.5))\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot(sol)\n\n\n# Let's use a provably entropy-dissipative semidiscretization\nsemi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))\node = semidiscretize(semi, (0.0, 0.5))\nsol = solve(ode, SSPRK43(); ode_default_options()...)\nplot(sol)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/#Package-versions","page":"8 Adding a new scalar conservation law","title":"Package versions","text":"","category":"section"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"","category":"page"},{"location":"tutorials/adding_new_scalar_equations/","page":"8 Adding a new scalar conservation law","title":"8 Adding a new scalar conservation law","text":"This page was generated using Literate.jl.","category":"page"},{"location":"time_integration/#time-integration","page":"Time integration","title":"Time integration methods","text":"","category":"section"},{"location":"time_integration/","page":"Time integration","title":"Time integration","text":"Trixi.jl is compatible with the SciML ecosystem for ordinary differential equations. In particular, explicit Runge-Kutta methods from OrdinaryDiffEq.jl are tested extensively. Interesting classes of time integration schemes are","category":"page"},{"location":"time_integration/","page":"Time integration","title":"Time integration","text":"Explicit low-storage Runge-Kutta methods\nStrong stability preserving methods","category":"page"},{"location":"time_integration/","page":"Time integration","title":"Time integration","text":"Some common options for solve from OrdinaryDiffEq.jl are the following. Further documentation can be found in the SciML docs.","category":"page"},{"location":"time_integration/","page":"Time integration","title":"Time integration","text":"If you use a fixed time step method like CarpenterKennedy2N54, you need to pass a time step as dt=.... If you use a StepsizeCallback, the value passed as dt=... is irrelevant since it will be overwritten by the StepsizeCallback. If you want to use an adaptive time step method such as SSPRK43 or RDPK3SpFSAL49 and still want to use CFL-based step size control via the StepsizeCallback, you need to pass the keyword argument adaptive=false to solve.\nYou should usually set save_everystep=false. Otherwise, OrdinaryDiffEq.jl will (try to) save the numerical solution after every time step in RAM (until you run out of memory or start to swap).\nYou can set the maximal number of time steps via maxiters=....\nSSP methods and many low-storage methods from OrdinaryDiffEq.jl support stage_limiter!s and step_limiter!s, e.g., PositivityPreservingLimiterZhangShu from Trixi.jl.\nIf you start Julia with multiple threads and want to use them also in the time integration method from OrdinaryDiffEq.jl, you need to pass the keyword argument thread=OrdinaryDiffEq.True() to the algorithm, e.g., RDPK3SpFSAL49(thread=OrdinaryDiffEq.True()) or CarpenterKennedy2N54(thread=OrdinaryDiffEq.True(), williamson_condition=false). For more information on using thread-based parallelism in Trixi.jl, please refer to Shared-memory parallelization with threads.\nIf you use error-based step size control (see also the section on error-based adaptive step sizes together with MPI, you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to OrdinaryDiffEq's solve, which are both included in ode_default_options.","category":"page"},{"location":"time_integration/","page":"Time integration","title":"Time integration","text":"note: Number of `rhs!` calls\nIf you use explicit Runge-Kutta methods from OrdinaryDiffEq.jl, the total number of rhs! calls can be (slightly) bigger than the number of steps times the number of stages, e.g. to allow for interpolation (dense output), root-finding for continuous callbacks, and error-based time step control. In general, you often should not need to worry about this if you use Trixi.jl.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"EditURL = \"../../literate/src/files/upwind_fdsbp.jl\"","category":"page"},{"location":"tutorials/upwind_fdsbp/#upwind_fdsbp","page":"7 Upwind FD SBP schemes","title":"7: Upwind FD SBP schemes","text":"","category":"section"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"General tensor product SBP methods are supported via the DGMulti solver in a reasonably complete way, see the previous tutorial. Nevertheless, there is also experimental support for SBP methods with other solver and mesh types.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"The first step is to set up an SBP operator. A classical (central) SBP operator can be created as follows.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"using Trixi\nD_SBP = derivative_operator(SummationByPartsOperators.MattssonNordström2004(),\n derivative_order=1, accuracy_order=2,\n xmin=0.0, xmax=1.0, N=11)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Instead of prefixing the source of coefficients MattssonNordström2004(), you can also load the package SummationByPartsOperators.jl. Either way, this yields an object representing the operator efficiently. If you want to compare it to coefficients presented in the literature, you can convert it to a matrix.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Matrix(D_SBP)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Upwind SBP operators are a concept introduced in 2017 by Ken Mattsson. You can create them as follows.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"D_upw = upwind_operators(SummationByPartsOperators.Mattsson2017,\n derivative_order=1, accuracy_order=2,\n xmin=0.0, xmax=1.0, N=11)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Upwind operators are derivative operators biased towards one direction. The \"minus\" variants has a bias towards the left side, i.e., it uses values from more nodes to the left than from the right to compute the discrete derivative approximation at a given node (in the interior of the domain). In matrix form, this means more non-zero entries are left from the diagonal.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Matrix(D_upw.minus)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Analogously, the \"plus\" variant has a bias towards the right side.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Matrix(D_upw.plus)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"For more information on upwind SBP operators, please refer to the documentation of SummationByPartsOperators.jl and references cited there.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"The basic idea of upwind SBP schemes is to apply a flux vector splitting and use appropriate upwind operators for both parts of the flux. In 1D, this means to split the flux","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"f(u) = f^-(u) + f^+(u)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"such that f^-(u) is associated with left-going waves and f^+(u) with right-going waves. Then, we apply upwind SBP operators D^- D^+ with an appropriate upwind bias, resulting in","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"partial_x f(u) approx D^+ f^-(u) + D^- f^+(u)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Note that the established notations of upwind operators D^pm and flux splittings f^pm clash. The right-going waves from f^+ need an operator biased towards their upwind side, i.e., the left side. This upwind bias is provided by the operator D^-.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Many classical flux vector splittings have been developed for finite volume methods and are described in the book \"Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction\" of Eleuterio F. Toro (2009), DOI: 10.1007/b79761. One such a well-known splitting provided by Trixi.jl is splitting_steger_warming.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"Trixi.jl comes with several example setups using upwind SBP methods with flux vector splitting, e.g.,","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"elixir_euler_vortex.jl\nelixir_euler_taylor_green_vortex.jl","category":"page"},{"location":"tutorials/upwind_fdsbp/#Package-versions","page":"7 Upwind FD SBP schemes","title":"Package versions","text":"","category":"section"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"SummationByPartsOperators\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"","category":"page"},{"location":"tutorials/upwind_fdsbp/","page":"7 Upwind FD SBP schemes","title":"7 Upwind FD SBP schemes","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"EditURL = \"../../literate/src/files/hohqmesh_tutorial.jl\"","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#hohqmesh_tutorial","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14: Unstructured meshes with HOHQMesh.jl","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Trixi.jl supports numerical approximations on unstructured quadrilateral meshes with the UnstructuredMesh2D mesh type.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The purpose of this tutorial is to demonstrate how to use the UnstructuredMesh2D functionality of Trixi.jl. This begins by running and visualizing an available unstructured quadrilateral mesh example. Then, the tutorial will demonstrate how to conceptualize a problem with curved boundaries, generate a curvilinear mesh using the available software in the Trixi.jl ecosystem, and then run a simulation using Trixi.jl on said mesh.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Unstructured quadrilateral meshes can be made with the High-Order Hex-Quad Mesh (HOHQMesh) generator created and developed by David Kopriva. HOHQMesh is a mesh generator specifically designed for spectral element methods. It provides high-order boundary curve information (needed to accurately set boundary conditions) and elements can be larger (due to the high accuracy of the spatial approximation) compared to traditional finite element mesh generators. For more information about the design and features of HOHQMesh one can refer to its official documentation.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"HOHQMesh is incorporated into the Trixi.jl framework via the registered Julia package HOHQMesh.jl. This package provides a Julia wrapper for the HOHQMesh generator that allows users to easily create mesh files without the need to build HOHQMesh from source. To install the HOHQMesh package execute","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"import Pkg; Pkg.add(\"HOHQMesh\")","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Now we are ready to generate an unstructured quadrilateral mesh that can be used by Trixi.jl.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Running-and-visualizing-an-unstructured-simulation","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Running and visualizing an unstructured simulation","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Trixi.jl supports solving hyperbolic problems on several mesh types. There is a default example for this mesh type that can be executed by","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using Trixi\nredirect_stdio(stdout=devnull, stderr=devnull) do # code that prints annoying stuff we don't want to see here #hide\ntrixi_include(default_example_unstructured())\nend #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"This will compute a smooth, manufactured solution test case for the 2D compressible Euler equations on the curved quadrilateral mesh described in the Trixi.jl documentation.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Apart from the usual error and timing output provided by the Trixi.jl run, it is useful to visualize and inspect the solution. One option available in the Trixi.jl framework to visualize the solution on unstructured quadrilateral meshes is post-processing the Trixi.jl output file(s) with the Trixi2Vtk tool and plotting them with ParaView.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"To convert the HDF5-formatted .h5 output file(s) from Trixi.jl into VTK format execute the following","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using Trixi2Vtk\nredirect_stdio(stdout=devnull, stderr=devnull) do # code that prints annoying stuff we don't want to see here #hide\ntrixi2vtk(\"out/solution_000180.h5\", output_directory=\"out\")\nend #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Note this step takes about 15-30 seconds as the package Trixi2Vtk must be precompiled and executed for the first time in your REPL session. The trixi2vtk command above will convert the solution file at the final time into a .vtu file which can be read in and visualized with ParaView. Optional arguments for trixi2vtk are: (1) Pointing to the output_directory where the new files will be saved; it defaults to the current directory. (2) Specifying a higher number of visualization nodes. For instance, if we want to use 12 uniformly spaced nodes for visualization we can execute","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"redirect_stdio(stdout=devnull, stderr=devnull) do # code that prints annoying stuff we don't want to see here #hide\ntrixi2vtk(\"out/solution_000180.h5\", output_directory=\"out\", nvisnodes=12)\nend #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"By default trixi2vtk sets nvisnodes to be the same as the number of nodes specified in the elixir file used to run the simulation.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Finally, if you want to convert all the solution files to VTK execute","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"redirect_stdio(stdout=devnull, stderr=devnull) do # code that prints annoying stuff we don't want to see here #hide\ntrixi2vtk(\"out/solution_000*.h5\", output_directory=\"out\", nvisnodes=12)\nend #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"then it is possible to open the .pvd file with ParaView and create a video of the simulation.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Creating-a-mesh-using-HOHQMesh","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Creating a mesh using HOHQMesh","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The creation of an unstructured quadrilateral mesh using HOHQMesh.jl is driven by a control file. In this file the user dictates the domain to be meshed, prescribes any desired boundary curvature, the polynomial order of said boundaries, etc. In this tutorial we cover several basic features of the possible control inputs. For a complete discussion on this topic see the HOHQMesh control file documentation.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"To begin, we provide a complete control file in this tutorial. After this we give a breakdown of the control file components to explain the chosen parameters.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Suppose we want to create a mesh of a domain with straight sided outer boundaries and a curvilinear \"ice cream cone\" shaped object at its center.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: mesh_boundary_cartoon)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The associated ice_cream_straight_sides.control file is created below.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"open(\"out/ice_cream_straight_sides.control\", \"w\") do io\n println(io, raw\"\"\"\n\\begin{CONTROL_INPUT}\n \\begin{RUN_PARAMETERS}\n mesh file name = ice_cream_straight_sides.mesh\n plot file name = ice_cream_straight_sides.tec\n stats file name = none\n mesh file format = ISM-v2\n polynomial order = 4\n plot file format = skeleton\n \\end{RUN_PARAMETERS}\n\n \\begin{BACKGROUND_GRID}\n x0 = [-8.0, -8.0, 0.0]\n dx = [1.0, 1.0, 0.0]\n N = [16,16,1]\n \\end{BACKGROUND_GRID}\n\n \\begin{SPRING_SMOOTHER}\n smoothing = ON\n smoothing type = LinearAndCrossBarSpring\n number of iterations = 25\n \\end{SPRING_SMOOTHER}\n\n\\end{CONTROL_INPUT}\n\n\\begin{MODEL}\n\n \\begin{INNER_BOUNDARIES}\n\n \\begin{CHAIN}\n name = IceCreamCone\n \\begin{END_POINTS_LINE}\n name = LeftSlant\n xStart = [-2.0, 1.0, 0.0]\n xEnd = [ 0.0, -3.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{END_POINTS_LINE}\n name = RightSlant\n xStart = [ 0.0, -3.0, 0.0]\n xEnd = [ 2.0, 1.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{CIRCULAR_ARC}\n name = IceCream\n units = degrees\n center = [ 0.0, 1.0, 0.0]\n radius = 2.0\n start angle = 0.0\n end angle = 180.0\n \\end{CIRCULAR_ARC}\n \\end{CHAIN}\n\n \\end{INNER_BOUNDARIES}\n\n\\end{MODEL}\n\\end{FILE}\n\"\"\")\nend","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The first three blocks of information are wrapped within a CONTROL_INPUT environment block as they define the core components of the quadrilateral mesh that will be generated.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The first block of information in RUN_PARAMETERS is","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"\\begin{RUN_PARAMETERS}\n mesh file name = ice_cream_straight_sides.mesh\n plot file name = ice_cream_straight_sides.tec\n stats file name = none\n mesh file format = ISM-v2\n polynomial order = 4\n plot file format = skeleton\n\\end{RUN_PARAMETERS}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The mesh and plot file names will be the files created by HOHQMesh once successfully executed. The stats file name is available if you wish to also save a collection of mesh statistics. For this example it is deactivated. These file names given within RUN_PARAMETERS should match that of the control file, and although this is not required by HOHQMesh, it is a useful style convention. The mesh file format ISM-v2 in the format currently required by Trixi.jl. The polynomial order prescribes the order of an interpolant constructed on the Chebyshev-Gauss-Lobatto nodes that is used to represent any curved boundaries on a particular element. The plot file format of skeleton means that visualizing the plot file will only draw the element boundaries (and no internal nodes). Alternatively, the format can be set to sem to visualize the interior nodes of the approximation as well.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The second block of information in BACKGROUND_GRID is","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"\\begin{BACKGROUND_GRID}\n x0 = [-8.0, -8.0, 0.0]\n dx = [1.0, 1.0, 0.0]\n N = [16,16,1]\n\\end{BACKGROUND_GRID}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"This lays a grid of Cartesian elements for the domain beginning at the point x0 as its bottom-left corner. The value of dx, which could differ in each direction if desired, controls the step size taken in each Cartesian direction. The values in N set how many Cartesian box elements are set in each coordinate direction. The above parameters define a 16times 16 element square mesh on -88^2. Further, this sets up four outer boundaries of the domain that are given the default names: Top, Left, Bottom, Right.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The third block of information in SPRING_SMOOTHER is","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"\\begin{SPRING_SMOOTHER}\n smoothing = ON\n smoothing type = LinearAndCrossBarSpring\n number of iterations = 25\n\\end{SPRING_SMOOTHER}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Once HOHQMesh generates the mesh, a spring-mass-dashpot model is created to smooth the mesh and create \"nicer\" quadrilateral elements. The default parameters of Hooke's law for the spring-mass-dashpot model have been selected after a fair amount of experimentation across many meshes. If you wish to deactivate this feature you can set smoothing = OFF (or remove this block from the control file).","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"After the CONTROL_INPUT environment block comes the MODEL environment block. It is here where the user prescribes curved boundary information with either:","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"An OUTER_BOUNDARY (covered in the next section of this tutorial).\nOne or more INNER_BOUNDARIES.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"There are several options to describe the boundary curve data to HOHQMesh like splines or parametric curves.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"For the example ice_cream_straight_sides.control we define three internal boundaries; two straight-sided and one as a circular arc. Within the HOHQMesh control input each curve must be assigned to a CHAIN as shown below in the complete INNER_BOUNDARIES block.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"\\begin{INNER_BOUNDARIES}\n\n \\begin{CHAIN}\n name = IceCreamCone\n \\begin{END_POINTS_LINE}\n name = LeftSlant\n xStart = [-2.0, 1.0, 0.0]\n xEnd = [ 0.0, -3.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{END_POINTS_LINE}\n name = RightSlant\n xStart = [ 0.0, -3.0, 0.0]\n xEnd = [ 2.0, 1.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{CIRCULAR_ARC}\n name = IceCream\n units = degrees\n center = [ 0.0, 1.0, 0.0]\n radius = 2.0\n start angle = 0.0\n end angle = 180.0\n \\end{CIRCULAR_ARC}\n \\end{CHAIN}\n\n\\end{INNER_BOUNDARIES}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"It is important to note there are two name quantities one for the CHAIN and one for the PARAMETRIC_EQUATION_CURVE. The name for the CHAIN is used internally by HOHQMesh, so if you have multiple CHAINs they must be given a unique name. The name for the PARAMETRIC_EQUATION_CURVE will be printed to the appropriate boundaries within the .mesh file produced by HOHQMesh.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We create the mesh file ice_cream_straight_sides.mesh and its associated file for plotting ice_cream_straight_sides.tec by using HOHQMesh.jl's function generate_mesh.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using HOHQMesh\ncontrol_file = joinpath(\"out\", \"ice_cream_straight_sides.control\")\noutput = generate_mesh(control_file);\nnothing #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The mesh file ice_cream_straight_sides.mesh and its associated file for plotting ice_cream_straight_sides.tec are placed in the out folder. The resulting mesh generated by HOHQMesh.jl is given in the following figure.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: mesh_straight_sides)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We note that Trixi.jl uses the boundary name information from the control file to assign boundary conditions in an elixir file. Therefore, the name should start with a letter and consist only of alphanumeric characters and underscores. Please note that the name will be treated as case sensitive.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Example-simulation-on-ice_cream_straight_sides.mesh","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Example simulation on ice_cream_straight_sides.mesh","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"With this newly generated mesh we are ready to run a Trixi.jl simulation on an unstructured quadrilateral mesh. For this we must create a new elixir file.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The elixir file given below creates an initial condition for a uniform background flow state with a free stream Mach number of 0.3. A focus for this part of the tutorial is to specify the boundary conditions and to construct the new mesh from the file that was generated in the previous exercise.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"It is straightforward to set the different boundary condition types in an elixir by assigning a particular function to a boundary name inside a Julia dictionary, Dict, variable. Observe that the names of these boundaries match those provided by HOHQMesh either by default, e.g. Bottom, or user assigned, e.g. IceCream. For this problem setup use","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Freestream boundary conditions on the four box edges.\nFree slip wall boundary condition on the interior curved boundaries.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"To construct the unstructured quadrilateral mesh from the HOHQMesh file we point to the appropriate location with the variable mesh_file and then feed this into the constructor for the UnstructuredMesh2D type in Trixi.jl","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"# create the unstructured mesh from your mesh file\nusing Trixi\nmesh_file = joinpath(\"out\", \"ice_cream_straight_sides.mesh\")\nmesh = UnstructuredMesh2D(mesh_file);","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The complete elixir file for this simulation example is given below.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using OrdinaryDiffEq, Trixi\n\nequations = CompressibleEulerEquations2D(1.4) # set gas gamma = 1.4\n\n# freestream flow state with Ma_inf = 0.3\n@inline function uniform_flow_state(x, t, equations::CompressibleEulerEquations2D)\n\n # set the freestream flow parameters\n rho_freestream = 1.0\n u_freestream = 0.3\n p_freestream = inv(equations.gamma)\n\n theta = 0.0 # zero angle of attack\n si, co = sincos(theta)\n v1 = u_freestream * co\n v2 = u_freestream * si\n\n prim = SVector(rho_freestream, v1, v2, p_freestream)\n return prim2cons(prim, equations)\nend\n\n# initial condition\ninitial_condition = uniform_flow_state\n\n# boundary condition types\nboundary_condition_uniform_flow = BoundaryConditionDirichlet(uniform_flow_state)\n\n# boundary condition dictionary\nboundary_conditions = Dict( :Bottom => boundary_condition_uniform_flow,\n :Top => boundary_condition_uniform_flow,\n :Right => boundary_condition_uniform_flow,\n :Left => boundary_condition_uniform_flow,\n :LeftSlant => boundary_condition_slip_wall,\n :RightSlant => boundary_condition_slip_wall,\n :IceCream => boundary_condition_slip_wall );\n\n# DGSEM solver.\n# 1) polydeg must be >= the polynomial order set in the HOHQMesh control file to guarantee\n# freestream preservation. As a extra task try setting polydeg=3\n# 2) VolumeIntegralFluxDifferencing with central volume flux is activated\n# for dealiasing\nvolume_flux = flux_ranocha\nsolver = DGSEM(polydeg=4, surface_flux=flux_hll,\n volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n\n# create the unstructured mesh from your mesh file\nmesh_file = joinpath(\"out\", \"ice_cream_straight_sides.mesh\")\nmesh = UnstructuredMesh2D(mesh_file)\n\n# Create semidiscretization with all spatial discretization-related components\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n boundary_conditions=boundary_conditions)\n\n# Create ODE problem from semidiscretization with time span from 0.0 to 2.0\ntspan = (0.0, 2.0)\node = semidiscretize(semi, tspan)\n\n\n# Create the callbacks to output solution files and adapt the time step\nsummary_callback = SummaryCallback()\nsave_solution = SaveSolutionCallback(interval=10,\n save_initial_solution=true,\n save_final_solution=true)\nstepsize_callback = StepsizeCallback(cfl=1.0)\n\ncallbacks = CallbackSet(summary_callback, save_solution, stepsize_callback)\n\nredirect_stdio(stdout=devnull, stderr=devnull) do # code that prints annoying stuff we don't want to see here #hide\n# Evolve ODE problem in time using `solve` from OrdinaryDiffEq\nsol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n save_everystep=false, callback=callbacks);\n# print the timer summary\nsummary_callback()\nend #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Visualization of the solution is carried out in a similar way as above. That is, one converts the .h5 output files with trixi2vtk and then plot the solution in ParaView. An example plot of the pressure at the final time is shown below.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: simulation_straight_sides)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Making-a-mesh-with-a-curved-outer-boundary","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Making a mesh with a curved outer boundary","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Let us modify the mesh from the previous task and place a circular outer boundary instead of straight-sided outer boundaries. Note, the \"ice cream cone\" shape is still placed at the center of the domain.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We create the new control file ice_cream_curved_sides.control file below and will then highlight the major differences compared to ice_cream_straight_sides.control.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"open(\"out/ice_cream_curved_sides.control\", \"w\") do io\n println(io, raw\"\"\"\n\\begin{CONTROL_INPUT}\n \\begin{RUN_PARAMETERS}\n mesh file name = ice_cream_curved_sides.mesh\n plot file name = ice_cream_curved_sides.tec\n stats file name = none\n mesh file format = ISM-v2\n polynomial order = 4\n plot file format = skeleton\n \\end{RUN_PARAMETERS}\n\n \\begin{BACKGROUND_GRID}\n background grid size = [1.0, 1.0, 0.0]\n \\end{BACKGROUND_GRID}\n\n \\begin{SPRING_SMOOTHER}\n smoothing = ON\n smoothing type = LinearAndCrossBarSpring\n number of iterations = 25\n \\end{SPRING_SMOOTHER}\n\n\\end{CONTROL_INPUT}\n\n\\begin{MODEL}\n\n \\begin{OUTER_BOUNDARY}\n \\begin{PARAMETRIC_EQUATION_CURVE}\n name = OuterCircle\n xEqn = x(t) = 8.0*sin(2.0*pi*t)\n yEqn = y(t) = 8.0*cos(2.0*pi*t)\n zEqn = z(t) = 0.0\n \\end{PARAMETRIC_EQUATION_CURVE}\n\n \\end{OUTER_BOUNDARY}\n\n \\begin{INNER_BOUNDARIES}\n\n \\begin{CHAIN}\n name = IceCreamCone\n \\begin{END_POINTS_LINE}\n name = LeftSlant\n xStart = [-2.0, 1.0, 0.0]\n xEnd = [ 0.0, -3.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{END_POINTS_LINE}\n name = RightSlant\n xStart = [ 0.0, -3.0, 0.0]\n xEnd = [ 2.0, 1.0, 0.0]\n \\end{END_POINTS_LINE}\n\n \\begin{CIRCULAR_ARC}\n name = IceCream\n units = degrees\n center = [ 0.0, 1.0, 0.0]\n radius = 2.0\n start angle = 0.0\n end angle = 180.0\n \\end{CIRCULAR_ARC}\n \\end{CHAIN}\n\n \\end{INNER_BOUNDARIES}\n\n\\end{MODEL}\n\\end{FILE}\n\"\"\")\nend","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The first alteration is that we have altered the second block of information BACKGROUND_GRID within the CONTROL_INPUT to be","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"\\begin{BACKGROUND_GRID}\n background grid size = [1.0, 1.0, 0.0]\n\\end{BACKGROUND_GRID}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"This mesh control file has an outer boundary that determines the extent of the domain to be meshed. Therefore, we only need to supply the background grid size to the BACKGROUND_GRID control input.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The second alteration is that the MODEL now contains information for an OUTER_BOUNDARY. In this case it is a circle of radius 8 centered at [0.0, 0.0, 0.0] written as a set of PARAMETRIC_EQUATION_CURVEs.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":" \\begin{OUTER_BOUNDARY}\n\n \\begin{PARAMETRIC_EQUATION_CURVE}\n name = OuterCircle\n xEqn = x(t) = 8.0*sin(2.0*pi*t)\n yEqn = y(t) = 8.0*cos(2.0*pi*t)\n zEqn = z(t) = 0.0\n \\end{PARAMETRIC_EQUATION_CURVE}\n\n \\end{OUTER_BOUNDARY}","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Just as with the inner boundary curves, we must assign a name to the OUTER_BOUNDARY. It will be included in the generated .mesh file and is used within the Trixi.jl elixir file to set boundary conditions.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Again, we create the .mesh and .tec files with HOHQMesh.jl's function generate_mesh","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"control_file = joinpath(\"out\", \"ice_cream_curved_sides.control\")\noutput = generate_mesh(control_file);\nnothing #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The files are placed in the out folder.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The resulting mesh generated by HOHQMesh.jl is given in the following figure.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: mesh_curved_sides)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Running-Trixi.jl-on-ice_cream_curved_sides.mesh","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Running Trixi.jl on ice_cream_curved_sides.mesh","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We can reuse much of the elixir file to setup the uniform flow over an ice cream cone from the previous part of this tutorial. The only component of the elixir file that must be changed is the boundary condition dictionary because we now have a boundary named OuterCircle instead of four edges of a bounding box.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"# boundary condition dictionary\nboundary_conditions = Dict( :OuterCircle => boundary_condition_uniform_flow,\n :LeftSlant => boundary_condition_slip_wall,\n :RightSlant => boundary_condition_slip_wall,\n :IceCream => boundary_condition_slip_wall );\nnothing #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Also, we must update the construction of the mesh from our new mesh file ice_cream_curved_sides.mesh that is located in the out folder.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"# create the unstructured mesh from your mesh file\nmesh_file = joinpath(\"out\", \"ice_cream_curved_sides.mesh\")\nmesh = UnstructuredMesh2D(mesh_file);\nnothing #hide","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We can then post-process the solution file at the final time on the new mesh with Trixi2Vtk and visualize with ParaView.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: simulation_curved_sides)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Setting-up-a-simulation-with-AMR-via-P4estMesh","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Setting up a simulation with AMR via P4estMesh","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"The above explained mesh file format of ISM-V2 only works with UnstructuredMesh2D and so does not support AMR. On the other hand, the mesh type P4estMesh allows AMR. The mesh constructor for the P4estMesh imports an unstructured, conforming mesh from an Abaqus mesh file (.inp).","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"As described above, the first block of the HOHQMesh control file contains the parameter mesh file format. If you set mesh file format = ABAQUS instead of ISM-V2, HOHQMesh.jl's function generate_mesh creates an Abaqus mesh file .inp.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using HOHQMesh\ncontrol_file = joinpath(\"out\", \"ice_cream_straight_sides.control\")\noutput = generate_mesh(control_file);","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Now, you can create a P4estMesh from your mesh file. It is described in detail in the P4est-based mesh part of the Trixi.jl docs.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using Trixi\nmesh_file = joinpath(\"out\", \"ice_cream_straight_sides.inp\")\nmesh = P4estMesh{2}(mesh_file)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"Since P4estMesh supports AMR, we just have to extend the setup from the first example by the standard AMR procedure. For more information about AMR in Trixi.jl, see the matching tutorial.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"amr_indicator = IndicatorLöhner(semi, variable=density)\n\namr_controller = ControllerThreeLevel(semi, amr_indicator,\n base_level=0,\n med_level =1, med_threshold=0.05,\n max_level =3, max_threshold=0.1)\n\namr_callback = AMRCallback(semi, amr_controller,\n interval=5,\n adapt_initial_condition=true,\n adapt_initial_condition_only_refine=true)\n\ncallbacks = CallbackSet(..., amr_callback)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"We can then post-process the solution file at the final time on the new mesh with Trixi2Vtk and visualize with ParaView, see the appropriate visualization section for details.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"(Image: simulation_straight_sides_p4est_amr)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/#Package-versions","page":"14 Unstructured meshes with HOHQMesh.jl","title":"Package versions","text":"","category":"section"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\", \"Trixi2Vtk\", \"HOHQMesh\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"","category":"page"},{"location":"tutorials/hohqmesh_tutorial/","page":"14 Unstructured meshes with HOHQMesh.jl","title":"14 Unstructured meshes with HOHQMesh.jl","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"EditURL = \"../../literate/src/files/DGMulti_2.jl\"","category":"page"},{"location":"tutorials/DGMulti_2/#DGMulti_2","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6: Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"","category":"section"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"For a tutorial about DG schemes via the DGMulti solver please visit the previous tutorial. The DGMulti solver also supports other methods than DG. The important property a method has to fulfill is the summation-by-parts (SBP) property. The package SummationByPartsOperators.jl provides such methods, like a finite difference SBP (FD SBP) scheme. To do this, you need to create an SBP derivative operator and pass that as approximation_type to the DGMulti constructor. For example, the classical second-order FD SBP operator can be created as","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly\nD = derivative_operator(MattssonNordström2004(), derivative_order=1, accuracy_order=2,\n xmin=0.0, xmax=1.0, N=11)","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"Here, the arguments xmin and xmax do not matter beyond setting the real type used for the operator - they just set a reference element and are rescaled on the physical elements. The parameter N determines the number of finite difference nodes. Then, D can be used as approximation_type like SBP() in a multi-block fashion. In multiple dimensions, such a 1D SBP operator will be used in a tensor product fashion, i.e., in each coordinate direction. In particular, you can use them only on 1D, 2D Quad(), and 3D Hex() elements.","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"You can also use fully periodic single-block FD methods by creating a periodic SBP operator. For example, a fully periodic FD operator can be constructed as","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"D = periodic_derivative_operator(derivative_order=1, accuracy_order=2,\n xmin=0.0, xmax=1.0, N=11)","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"An example using such an FD method is implemented in elixir_euler_fdsbp_periodic.jl. For all parameters and other calling options, please have a look in the documentation of SummationByPartsOperators.jl.","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"Another possible method is for instance a continuous Galerkin (CGSEM) method. You can use such a method with polynomial degree of 3 (N=4 Legendre Lobatto nodes on [0, 1]) coupled continuously on a uniform mesh with Nx=10 elements by setting approximation_type to","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly\nD = couple_continuously(legendre_derivative_operator(xmin=0.0, xmax=1.0, N=4),\n UniformPeriodicMesh1D(xmin=-1.0, xmax=1.0, Nx=10))","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"To choose a discontinuous coupling (DGSEM), use couple_discontinuously() instead of couple_continuously().","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"For more information and other SBP operators, see the documentations of StartUpDG.jl and SummationByPartsOperators.jl.","category":"page"},{"location":"tutorials/DGMulti_2/#Package-versions","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"Package versions","text":"","category":"section"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"StartUpDG\", \"SummationByPartsOperators\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"","category":"page"},{"location":"tutorials/DGMulti_2/","page":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"EditURL = \"../../literate/src/files/parabolic_terms.jl\"","category":"page"},{"location":"tutorials/parabolic_terms/#parabolic_terms","page":"10 Parabolic terms","title":"10: Parabolic terms","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"Experimental support for parabolic diffusion terms is available in Trixi.jl. This demo illustrates parabolic terms for the advection-diffusion equation.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"using OrdinaryDiffEq\nusing Trixi","category":"page"},{"location":"tutorials/parabolic_terms/#Splitting-a-system-into-hyperbolic-and-parabolic-parts.","page":"10 Parabolic terms","title":"Splitting a system into hyperbolic and parabolic parts.","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"For a mixed hyperbolic-parabolic system, we represent the hyperbolic and parabolic parts of the system separately. We first define the hyperbolic (advection) part of the advection-diffusion equation.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"advection_velocity = (1.5, 1.0)\nequations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);\nnothing #hide","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"Next, we define the parabolic diffusion term. The constructor requires knowledge of equations_hyperbolic to be passed in because the LaplaceDiffusion2D applies diffusion to every variable of the hyperbolic system.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"diffusivity = 5.0e-2\nequations_parabolic = LaplaceDiffusion2D(diffusivity, equations_hyperbolic);\nnothing #hide","category":"page"},{"location":"tutorials/parabolic_terms/#Boundary-conditions","page":"10 Parabolic terms","title":"Boundary conditions","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"As with the equations, we define boundary conditions separately for the hyperbolic and parabolic part of the system. For this example, we impose inflow BCs for the hyperbolic system (no condition is imposed on the outflow), and we impose Dirichlet boundary conditions for the parabolic equations. Both BoundaryConditionDirichlet and BoundaryConditionNeumann are defined for LaplaceDiffusion2D.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"The hyperbolic and parabolic boundary conditions are assumed to be consistent with each other.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"boundary_condition_zero_dirichlet = BoundaryConditionDirichlet((x, t, equations) -> SVector(0.0))\n\nboundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),\n y_neg = boundary_condition_zero_dirichlet,\n y_pos = boundary_condition_do_nothing,\n x_pos = boundary_condition_do_nothing)\n\nboundary_conditions_parabolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),\n y_neg = boundary_condition_zero_dirichlet,\n y_pos = boundary_condition_zero_dirichlet,\n x_pos = boundary_condition_zero_dirichlet);\nnothing #hide","category":"page"},{"location":"tutorials/parabolic_terms/#Defining-the-solver-and-mesh","page":"10 Parabolic terms","title":"Defining the solver and mesh","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"The process of creating the DG solver and mesh is the same as for a purely hyperbolic system of equations.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\ncoordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))\ncoordinates_max = ( 1.0, 1.0) # maximum coordinates (max(x), max(y))\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4,\n periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure\n\ninitial_condition = (x, t, equations) -> SVector(0.0);\nnothing #hide","category":"page"},{"location":"tutorials/parabolic_terms/#Semidiscretizing-and-solving","page":"10 Parabolic terms","title":"Semidiscretizing and solving","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"To semidiscretize a hyperbolic-parabolic system, we create a SemidiscretizationHyperbolicParabolic. This differs from a SemidiscretizationHyperbolic in that we pass in a Tuple containing both the hyperbolic and parabolic equation, as well as a Tuple containing the hyperbolic and parabolic boundary conditions.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"semi = SemidiscretizationHyperbolicParabolic(mesh,\n (equations_hyperbolic, equations_parabolic),\n initial_condition, solver;\n boundary_conditions=(boundary_conditions_hyperbolic,\n boundary_conditions_parabolic))","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"The rest of the code is identical to the hyperbolic case. We create a system of ODEs through semidiscretize, defining callbacks, and then passing the system to OrdinaryDiffEq.jl.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"tspan = (0.0, 1.5)\node = semidiscretize(semi, tspan)\ncallbacks = CallbackSet(SummaryCallback())\ntime_int_tol = 1.0e-6\nsol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,\n ode_default_options()..., callback=callbacks);\nnothing #hide","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"We can now visualize the solution, which develops a boundary layer at the outflow boundaries.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"using Plots\nplot(sol)","category":"page"},{"location":"tutorials/parabolic_terms/#Package-versions","page":"10 Parabolic terms","title":"Package versions","text":"","category":"section"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"","category":"page"},{"location":"tutorials/parabolic_terms/","page":"10 Parabolic terms","title":"10 Parabolic terms","text":"This page was generated using Literate.jl.","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"EditURL = \"../../literate/src/files/index.jl\"","category":"page"},{"location":"tutorials/introduction/#Tutorials-for-Trixi.jl","page":"Introduction","title":"Tutorials for Trixi.jl","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"The tutorial section for Trixi.jl also contains interactive step-by-step explanations via Binder.","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Right now, you are using the classic documentation. The corresponding interactive notebooks can be opened in Binder and viewed in nbviewer via the icons (Image: ) and (Image: ) in the respective tutorial. You can download the raw notebooks from GitHub via (Image: ).","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Note: To improve responsiveness via caching, the notebooks are updated only once a week. They are only available for the latest stable release of Trixi.jl at the time of caching.","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"There are tutorials for the following topics:","category":"page"},{"location":"tutorials/introduction/#[1-Introduction-to-DG-methods](@ref-scalar_linear_advection_1d)","page":"Introduction","title":"1 Introduction to DG methods","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial gives an introduction to discontinuous Galerkin (DG) methods with the example of the scalar linear advection equation in 1D. Starting with some theoretical explanations, we first implement a raw version of a discontinuous Galerkin spectral element method (DGSEM). Then, we will show how to use features of Trixi.jl to achieve the same result.","category":"page"},{"location":"tutorials/introduction/#[2-DGSEM-with-flux-differencing](@ref-DGSEM_FluxDiff)","page":"Introduction","title":"2 DGSEM with flux differencing","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"To improve stability often the flux differencing formulation of the DGSEM (split form) is used. We want to present the idea and formulation on a basic 1D level. Then, we show how this formulation can be implemented in Trixi.jl and analyse entropy conservation for two different flux combinations.","category":"page"},{"location":"tutorials/introduction/#[3-Shock-capturing-with-flux-differencing-and-stage-limiter](@ref-shock_capturing)","page":"Introduction","title":"3 Shock capturing with flux differencing and stage limiter","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Using the flux differencing formulation, a simple procedure to capture shocks is a hybrid blending of a high-order DG method and a low-order subcell finite volume (FV) method. We present the idea on a very basic level and show the implementation in Trixi.jl. Then, a positivity preserving limiter is explained and added to an exemplary simulation of the Sedov blast wave with the 2D compressible Euler equations.","category":"page"},{"location":"tutorials/introduction/#[4-Non-periodic-boundary-conditions](@ref-non_periodic_boundaries)","page":"Introduction","title":"4 Non-periodic boundary conditions","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Thus far, all examples used periodic boundaries. In Trixi.jl, you can also set up a simulation with non-periodic boundaries. This tutorial presents the implementation of the classical Dirichlet boundary condition with a following example. Then, other non-periodic boundaries are mentioned.","category":"page"},{"location":"tutorials/introduction/#[5-DG-schemes-via-DGMulti-solver](@ref-DGMulti_1)","page":"Introduction","title":"5 DG schemes via DGMulti solver","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial is about the more general DG solver DGMulti, introduced here. We are showing some examples for this solver, for instance with discretization nodes by Gauss or triangular elements. Moreover, we present a simple way to include pre-defined triangulate meshes for non-Cartesian domains using the package StartUpDG.jl.","category":"page"},{"location":"tutorials/introduction/#[6-Other-SBP-schemes-(FD,-CGSEM)-via-DGMulti-solver](@ref-DGMulti_2)","page":"Introduction","title":"6 Other SBP schemes (FD, CGSEM) via DGMulti solver","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Supplementary to the previous tutorial about DG schemes via the DGMulti solver we now present the possibility for DGMulti to use other SBP schemes via the package SummationByPartsOperators.jl. For instance, we show how to set up a finite differences (FD) scheme and a continuous Galerkin (CGSEM) method.","category":"page"},{"location":"tutorials/introduction/#[7-Upwind-FD-SBP-schemes](@ref-upwind_fdsbp)","page":"Introduction","title":"7 Upwind FD SBP schemes","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"General SBP schemes can not only be used via the DGMulti solver but also with a general DG solver. In particular, upwind finite difference SBP methods can be used together with the TreeMesh. Similar to general SBP schemes in the DGMulti framework, the interface is based on the package SummationByPartsOperators.jl.","category":"page"},{"location":"tutorials/introduction/#[8-Adding-a-new-scalar-conservation-law](@ref-adding_new_scalar_equations)","page":"Introduction","title":"8 Adding a new scalar conservation law","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial explains how to add a new physics model using the example of the cubic conservation law. First, we define the equation using a struct CubicEquation and the physical flux. Then, the corresponding standard setup in Trixi.jl (mesh, solver, semi and ode) is implemented and the ODE problem is solved by OrdinaryDiffEq's solve method.","category":"page"},{"location":"tutorials/introduction/#[9-Adding-a-non-conservative-equation](@ref-adding_nonconservative_equation)","page":"Introduction","title":"9 Adding a non-conservative equation","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"In this part, another physics model is implemented, the nonconservative linear advection equation. We run two different simulations with different levels of refinement and compare the resulting errors.","category":"page"},{"location":"tutorials/introduction/#[10-Parabolic-terms](@ref-parabolic_terms)","page":"Introduction","title":"10 Parabolic terms","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial describes how parabolic terms are implemented in Trixi.jl, e.g., to solve the advection-diffusion equation.","category":"page"},{"location":"tutorials/introduction/#[11-Adding-new-parabolic-terms](@ref-adding_new_parabolic_terms)","page":"Introduction","title":"11 Adding new parabolic terms","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial describes how new parabolic terms can be implemented using Trixi.jl.","category":"page"},{"location":"tutorials/introduction/#[12-Adaptive-mesh-refinement](@ref-adaptive_mesh_refinement)","page":"Introduction","title":"12 Adaptive mesh refinement","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Adaptive mesh refinement (AMR) helps to increase the accuracy in sensitive or turbolent regions while not wasting resources for less interesting parts of the domain. This leads to much more efficient simulations. This tutorial presents the implementation strategy of AMR in Trixi.jl, including the use of different indicators and controllers.","category":"page"},{"location":"tutorials/introduction/#[13-Structured-mesh-with-curvilinear-mapping](@ref-structured_mesh_mapping)","page":"Introduction","title":"13 Structured mesh with curvilinear mapping","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"In this tutorial, the use of Trixi.jl's structured curved mesh type StructuredMesh is explained. We present the two basic option to initialize such a mesh. First, the curved domain boundaries of a circular cylinder are set by explicit boundary functions. Then, a fully curved mesh is defined by passing the transformation mapping.","category":"page"},{"location":"tutorials/introduction/#[14-Unstructured-meshes-with-HOHQMesh.jl](@ref-hohqmesh_tutorial)","page":"Introduction","title":"14 Unstructured meshes with HOHQMesh.jl","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"The purpose of this tutorial is to demonstrate how to use the UnstructuredMesh2D functionality of Trixi.jl. This begins by running and visualizing an available unstructured quadrilateral mesh example. Then, the tutorial will demonstrate how to conceptualize a problem with curved boundaries, generate a curvilinear mesh using the available HOHQMesh software in the Trixi.jl ecosystem, and then run a simulation using Trixi.jl on said mesh. In the end, the tutorial briefly explains how to simulate an example using AMR via P4estMesh.","category":"page"},{"location":"tutorials/introduction/#[15-Explicit-time-stepping](@ref-time_stepping)","page":"Introduction","title":"15 Explicit time stepping","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial is about time integration using OrdinaryDiffEq.jl. It explains how to use their algorithms and presents two types of time step choices - with error-based and CFL-based adaptive step size control.","category":"page"},{"location":"tutorials/introduction/#[16-Differentiable-programming](@ref-differentiable_programming)","page":"Introduction","title":"16 Differentiable programming","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This part deals with some basic differentiable programming topics. For example, a Jacobian, its eigenvalues and a curve of total energy (through the simulation) are calculated and plotted for a few semidiscretizations. Moreover, we calculate an example for propagating errors with Measurement.jl at the end.","category":"page"},{"location":"tutorials/introduction/#[17-Custom-semidiscretization](@ref-custom_semidiscretization)","page":"Introduction","title":"17 Custom semidiscretization","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This tutorial describes the semidiscretiations of Trixi.jl and explains how to extend them for custom tasks.","category":"page"},{"location":"tutorials/introduction/#Examples-in-Trixi.jl","page":"Introduction","title":"Examples in Trixi.jl","text":"","category":"section"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"Trixi.jl already contains several more coding examples, the so-called elixirs. You can find them in the folder examples/. They are structured by the underlying mesh type and the respective number of spatial dimensions. The name of an elixir is composed of the underlying system of conservation equations (for instance advection or euler) and other special characteristics like the initial condition (e.g. gauss, astro_jet, blast_wave) or the included simulation features (e.g. amr, shockcapturing).","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"","category":"page"},{"location":"tutorials/introduction/","page":"Introduction","title":"Introduction","text":"This page was generated using Literate.jl.","category":"page"},{"location":"reference-trixi/#Trixi.jl-API","page":"Trixi.jl","title":"Trixi.jl API","text":"","category":"section"},{"location":"reference-trixi/","page":"Trixi.jl","title":"Trixi.jl","text":"CurrentModule = Trixi","category":"page"},{"location":"reference-trixi/","page":"Trixi.jl","title":"Trixi.jl","text":"Modules = [Trixi]","category":"page"},{"location":"reference-trixi/#Trixi.Trixi","page":"Trixi.jl","title":"Trixi.Trixi","text":"Trixi\n\nTrixi.jl is a numerical simulation framework for hyperbolic conservation laws. A key objective for the framework is to be useful to both scientists and students. Therefore, next to having an extensible design with a fast implementation, Trixi.jl is focused on being easy to use for new or inexperienced users, including the installation and postprocessing procedures.\n\nTo get started, run your first simulation with Trixi.jl using\n\ntrixi_include(default_example())\n\nSee also: trixi-framework/Trixi.jl\n\n\n\n\n\n","category":"module"},{"location":"reference-trixi/#Trixi.boundary_condition_do_nothing","page":"Trixi.jl","title":"Trixi.boundary_condition_do_nothing","text":"boundary_condition_do_nothing = Trixi.BoundaryConditionDoNothing()\n\nImposing no boundary condition just evaluates the flux at the inner state.\n\n\n\n\n\n","category":"constant"},{"location":"reference-trixi/#Trixi.boundary_condition_periodic","page":"Trixi.jl","title":"Trixi.boundary_condition_periodic","text":"boundary_condition_periodic = Trixi.BoundaryConditionPeriodic()\n\nA singleton struct indicating periodic boundary conditions.\n\n\n\n\n\n","category":"constant"},{"location":"reference-trixi/#Trixi.flux_hll","page":"Trixi.jl","title":"Trixi.flux_hll","text":"flux_hll\n\nSee FluxHLL.\n\n\n\n\n\n","category":"constant"},{"location":"reference-trixi/#Trixi.flux_hll_chen_noelle","page":"Trixi.jl","title":"Trixi.flux_hll_chen_noelle","text":"flux_hll_chen_noelle = FluxHLL(min_max_speed_chen_noelle)\n\nAn instance of FluxHLL specific to the shallow water equations that uses the wave speed estimates from min_max_speed_chen_noelle. This HLL flux is guaranteed to have zero numerical mass flux out of a \"dry\" element, maintain positivity of the water height, and satisfy an entropy inequality.\n\nFor complete details see Section 2.4 of the following reference\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI: 10.1137/15M1053074\n\n\n\n\n\n","category":"constant"},{"location":"reference-trixi/#Trixi.flux_lax_friedrichs","page":"Trixi.jl","title":"Trixi.flux_lax_friedrichs","text":"flux_lax_friedrichs\n\nSee FluxLaxFriedrichs.\n\n\n\n\n\n","category":"constant"},{"location":"reference-trixi/#Trixi.AMRCallback","page":"Trixi.jl","title":"Trixi.AMRCallback","text":"AMRCallback(semi, controller [,adaptor=AdaptorAMR(semi)];\n interval,\n adapt_initial_condition=true,\n adapt_initial_condition_only_refine=true,\n dynamic_load_balancing=true)\n\nPerforms adaptive mesh refinement (AMR) every interval time steps for a given semidiscretization semi using the chosen controller.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AbstractEquations","page":"Trixi.jl","title":"Trixi.AbstractEquations","text":"AbstractEquations{NDIMS, NVARS}\n\nAn abstract supertype of specific equations such as the compressible Euler equations. The type parameters encode the number of spatial dimensions (NDIMS) and the number of primary variables (NVARS) of the physics model.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AbstractMesh","page":"Trixi.jl","title":"Trixi.AbstractMesh","text":"AbstractMesh{NDIMS}\n\nAn abstract supertype of specific mesh types such as TreeMesh or StructuredMesh. The type parameters encode the number of spatial dimensions (NDIMS).\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AcousticPerturbationEquations2D","page":"Trixi.jl","title":"Trixi.AcousticPerturbationEquations2D","text":"AcousticPerturbationEquations2D(v_mean_global, c_mean_global, rho_mean_global)\n\nAcoustic perturbation equations (APE) in two space dimensions. The equations are given by\n\nbeginaligned\n fracpartialmathbfvpartial t + nabla (barmathbfvcdotmathbfv)\n + nablaleft( fracbarc^2 tildepbarrho right) = 0 \n fracpartial tildeppartial t +\n nablacdot (barrho mathbfv + barmathbfv tildep) = 0\nendaligned\n\nThe bar bar(cdot) indicates time-averaged quantities. The unknowns of the APE are the perturbed velocities mathbfv = (v_1 v_2)^T and the scaled perturbed pressure tildep = fracpbarc^2, where p denotes the perturbed pressure and the perturbed variables are defined by phi = phi - barphi.\n\nIn addition to the unknowns, Trixi.jl currently stores the mean values in the state vector, i.e. the state vector used internally is given by\n\nmathbfu =\n beginpmatrix\n v_1 v_2 tildep barv_1 barv_2 barc barrho\n endpmatrix\n\nThis affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the mean values must be zero.\nThe mean values have to be considered when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes these variables too.\nTrixi.jl's visualization tools will visualize the mean values by default.\n\nThe constructor accepts a 2-tuple v_mean_global and scalars c_mean_global and rho_mean_global which can be used to make the definition of initial conditions for problems with constant mean flow more flexible. These values are ignored if the mean values are defined internally in an initial condition.\n\nThe equations are based on the APE-4 system introduced in the following paper:\n\nRoland Ewert and Wolfgang Schröder (2003) Acoustic perturbation equations based on flow decomposition via source filtering DOI: 10.1016/S0021-9991(03)00168-2\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.Adiabatic","page":"Trixi.jl","title":"Trixi.Adiabatic","text":"struct Adiabatic\n\nUsed to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_normal_flux_function should be a function with signature boundary_value_normal_flux_function(x, t, equations) and return a scalar value for the normal heat flux at point x and time t.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AliveCallback","page":"Trixi.jl","title":"Trixi.AliveCallback","text":"AliveCallback(analysis_interval=0, alive_interval=analysis_interval÷10)\n\nInexpensive callback showing that a simulation is still running by printing some information such as the current time to the screen every alive_interval time steps. If analysis_interval ≂̸ 0, the output is omitted every analysis_interval time steps.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AnalysisCallback","page":"Trixi.jl","title":"Trixi.AnalysisCallback","text":"AnalysisCallback(semi; interval=0,\n save_analysis=false,\n output_directory=\"out\",\n analysis_filename=\"analysis.dat\",\n extra_analysis_errors=Symbol[],\n extra_analysis_integrals=())\n\nAnalyze a numerical solution every interval time steps and print the results to the screen. If save_analysis, the results are also saved in joinpath(output_directory, analysis_filename).\n\nAdditional errors can be computed, e.g. by passing extra_analysis_errors = (:l2_error_primitive, :linf_error_primitive) or extra_analysis_errors = (:conservation_error,).\n\nFurther scalar functions func in extra_analysis_integrals are applied to the numerical solution and integrated over the computational domain. Some examples for this are entropy, energy_kinetic, energy_internal, and energy_total. You can also write your own function with the same signature as the examples listed above and pass it via extra_analysis_integrals. See the developer comments about Trixi.analyze, Trixi.pretty_form_utf, and Trixi.pretty_form_ascii for further information on how to create custom analysis quantities.\n\nIn addition, the analysis callback records and outputs a number of quantities that are useful for evaluating the computational performance, such as the total runtime, the performance index (time/DOF/rhs!), the time spent in garbage collection (GC), or the current memory usage (alloc'd memory).\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AnalysisCallbackCoupled","page":"Trixi.jl","title":"Trixi.AnalysisCallbackCoupled","text":"AnalysisCallbackCoupled(semi, callbacks...)\n\nCombine multiple analysis callbacks for coupled simulations with a SemidiscretizationCoupled. For each coupled system, an indididual AnalysisCallback must be created and passed to the AnalysisCallbackCoupled in order, i.e., in the same sequence as the indidvidual semidiscretizations are stored in the SemidiscretizationCoupled.\n\nwarning: Experimental code\nThis is an experimental feature and can change any time.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.AveragingCallback","page":"Trixi.jl","title":"Trixi.AveragingCallback","text":"AveragingCallback(semi::SemidiscretizationHyperbolic, tspan; output_directory=\"out\",\n filename=\"averaging.h5\")\n\nwarning: Experimental code\nThis callback is experimental and may change in any future release.\n\nA callback that averages the flow field described by semi which must be a semidiscretization of the compressible Euler equations in two dimensions. The callback records the mean velocity, mean speed of sound, mean density, and mean vorticity for each node over the time interval given by tspan and stores the results in an HDF5 file filename in the directory output_directory. Note that this callback does not support adaptive mesh refinement (AMRCallback).\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.BoundaryConditionCoupled","page":"Trixi.jl","title":"Trixi.BoundaryConditionCoupled","text":"BoundaryConditionCoupled(other_semi_index, indices, uEltype)\n\nBoundary condition to glue two meshes together. Solution values at the boundary of another mesh will be used as boundary values. This requires the use of SemidiscretizationCoupled. The other mesh is specified by other_semi_index, which is the index of the mesh in the tuple of semidiscretizations.\n\nNote that the elements and nodes of the two meshes at the coupled boundary must coincide. This is currently only implemented for StructuredMesh.\n\nArguments\n\nother_semi_index: the index in SemidiscretizationCoupled of the semidiscretization from which the values are copied\nindices::Tuple: node/cell indices at the boundary of the mesh in the other semidiscretization. See examples below.\nuEltype::Type: element type of solution\n\nExamples\n\n# Connect the left boundary of mesh 2 to our boundary such that our positive\n# boundary direction will match the positive y direction of the other boundary\nBoundaryConditionCoupled(2, (:begin, :i), Float64)\n\n# Connect the same two boundaries oppositely oriented\nBoundaryConditionCoupled(2, (:begin, :i_backwards), Float64)\n\n# Using this as y_neg boundary will connect `our_cells[i, 1, j]` to `other_cells[j, end-i, end]`\nBoundaryConditionCoupled(2, (:j, :i_backwards, :end), Float64)\n\nwarning: Experimental code\nThis is an experimental feature and can change any time.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.BoundaryConditionDirichlet","page":"Trixi.jl","title":"Trixi.BoundaryConditionDirichlet","text":"BoundaryConditionDirichlet(boundary_value_function)\n\nCreate a Dirichlet boundary condition that uses the function boundary_value_function to specify the values at the boundary. This can be used to create a boundary condition that specifies exact boundary values by passing the exact solution of the equation. The passed boundary value function will be called with the same arguments as an initial condition function is called, i.e., as\n\nboundary_value_function(x, t, equations)\n\nwhere x specifies the coordinates, t is the current time, and equation is the corresponding system of equations.\n\nExamples\n\njulia> BoundaryConditionDirichlet(initial_condition_convergence_test)\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.BoundaryConditionNavierStokesWall","page":"Trixi.jl","title":"Trixi.BoundaryConditionNavierStokesWall","text":"struct BoundaryConditionNavierStokesWall\n\nCreates a wall-type boundary conditions for the compressible Navier-Stokes equations. The fields boundary_condition_velocity and boundary_condition_heat_flux are intended to be boundary condition types such as the NoSlip velocity boundary condition and the Adiabatic or Isothermal heat boundary condition.\n\nwarning: Experimental feature\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.BoundaryConditionNeumann","page":"Trixi.jl","title":"Trixi.BoundaryConditionNeumann","text":"BoundaryConditionNeumann(boundary_normal_flux_function)\n\nSimilar to BoundaryConditionDirichlet, but creates a Neumann boundary condition for parabolic equations that uses the function boundary_normal_flux_function to specify the values of the normal flux at the boundary. The passed boundary value function will be called with the same arguments as an initial condition function is called, i.e., as\n\nboundary_normal_flux_function(x, t, equations)\n\nwhere x specifies the coordinates, t is the current time, and equation is the corresponding system of equations.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.BoundsCheckCallback","page":"Trixi.jl","title":"Trixi.BoundsCheckCallback","text":"BoundsCheckCallback(; output_directory=\"out\", save_errors=false, interval=1)\n\nSubcell limiting techniques with SubcellLimiterIDP are constructed to adhere certain local or global bounds. To make sure that these bounds are actually met, this callback calculates the maximum deviation from the bounds. The maximum deviation per applied bound is printed to the screen at the end of the simulation. For more insights, when setting save_errors=true the occurring errors are exported every interval time steps during the simulation. Then, the maximum deviations since the last export are saved in \"output_directory/deviations.txt\". The BoundsCheckCallback has to be applied as a stage callback for the SSPRK time integration scheme.\n\nnote: Note\nFor SubcellLimiterIDP, the solution is corrected in the a posteriori correction stage SubcellLimiterIDPCorrection. So, to check the final solution, this bounds check callback must be called after the correction stage.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CarpenterKennedy2N43","page":"Trixi.jl","title":"Trixi.CarpenterKennedy2N43","text":" CarpenterKennedy2N43()\n\nCarpenter, Kennedy (1994) Third order 2N storage RK schemes with error control\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CarpenterKennedy2N54","page":"Trixi.jl","title":"Trixi.CarpenterKennedy2N54","text":"CarpenterKennedy2N54()\n\nThe following structures and methods provide a minimal implementation of the low-storage explicit Runge-Kutta method of\n\nCarpenter, Kennedy (1994) Fourth order 2N storage RK schemes, Solution 3\n\nusing the same interface as OrdinaryDiffEq.jl.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleEulerEquations1D","page":"Trixi.jl","title":"Trixi.CompressibleEulerEquations1D","text":"CompressibleEulerEquations1D(gamma)\n\nThe compressible Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho rho v_1 rho e\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\nrho v_1 rho v_1^2 + p (rho e +p) v_1\nendpmatrix\n=\nbeginpmatrix\n0 0 0\nendpmatrix\n\nfor an ideal gas with ratio of specific heats gamma in one space dimension. Here, rho is the density, v_1 the velocity, e the specific total energy rather than specific internal energy, and\n\np = (gamma - 1) left( rho e - frac12 rho v_1^2 right)\n\nthe pressure.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleEulerEquations2D","page":"Trixi.jl","title":"Trixi.CompressibleEulerEquations2D","text":"CompressibleEulerEquations2D(gamma)\n\nThe compressible Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho rho v_1 rho v_2 rho e\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\n rho v_1 rho v_1^2 + p rho v_1 v_2 (rho e +p) v_1\nendpmatrix\n+\nfracpartialpartial y\nbeginpmatrix\nrho v_2 rho v_1 v_2 rho v_2^2 + p (rho e +p) v_2\nendpmatrix\n=\nbeginpmatrix\n0 0 0 0\nendpmatrix\n\nfor an ideal gas with ratio of specific heats gamma in two space dimensions. Here, rho is the density, v_1, v_2 the velocities, e the specific total energy rather than specific internal energy, and\n\np = (gamma - 1) left( rho e - frac12 rho (v_1^2+v_2^2) right)\n\nthe pressure.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleEulerEquations3D","page":"Trixi.jl","title":"Trixi.CompressibleEulerEquations3D","text":"CompressibleEulerEquations3D(gamma)\n\nThe compressible Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho rho v_1 rho v_2 rho v_3 rho e\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\n rho v_1 rho v_1^2 + p rho v_1 v_2 rho v_1 v_3 ( rho e +p) v_1\nendpmatrix\n+\nfracpartialpartial y\nbeginpmatrix\nrho v_2 rho v_1 v_2 rho v_2^2 + p rho v_1 v_3 ( rho e +p) v_2\nendpmatrix\n+\nfracpartialpartial z\nbeginpmatrix\nrho v_3 rho v_1 v_3 rho v_2 v_3 rho v_3^2 + p ( rho e +p) v_3\nendpmatrix\n=\nbeginpmatrix\n0 0 0 0 0\nendpmatrix\n\nfor an ideal gas with ratio of specific heats gamma in three space dimensions. Here, rho is the density, v_1, v_2, v_3 the velocities, e the specific total energy rather than specific internal energy, and\n\np = (gamma - 1) left( rho e - frac12 rho (v_1^2+v_2^2+v_3^2) right)\n\nthe pressure.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleEulerMulticomponentEquations1D","page":"Trixi.jl","title":"Trixi.CompressibleEulerMulticomponentEquations1D","text":"CompressibleEulerMulticomponentEquations1D(; gammas, gas_constants)\n\nMulticomponent version of the compressible Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho v_1 rho e rho_1 rho_2 vdots rho_n\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\nrho v_1^2 + p (rho e +p) v_1 rho_1 v_1 rho_2 v_1 vdots rho_n v_1\nendpmatrix\n\n=\nbeginpmatrix\n0 0 0 0 vdots 0\nendpmatrix\n\nfor calorically perfect gas in one space dimension. Here, rho_i is the density of component i, rho=sum_i=1^nrho_i the sum of the individual rho_i, v_1 the velocity, e the specific total energy rather than specific internal energy, and\n\np = (gamma - 1) left( rho e - frac12 rho v_1^2 right)\n\nthe pressure,\n\ngamma=fracsum_i=1^nrho_i C_vigamma_isum_i=1^nrho_i C_vi\n\ntotal heat capacity ratio, gamma_i heat capacity ratio of component i,\n\nC_vi=fracRgamma_i-1\n\nspecific heat capacity at constant volume of component i.\n\nIn case of more than one component, the specific heat ratios gammas and the gas constants gas_constants should be passed as tuples, e.g., gammas=(1.4, 1.667).\n\nThe remaining variables like the specific heats at constant volume cv or the specific heats at constant pressure cp are then calculated considering a calorically perfect gas.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleEulerMulticomponentEquations2D","page":"Trixi.jl","title":"Trixi.CompressibleEulerMulticomponentEquations2D","text":"CompressibleEulerMulticomponentEquations2D(; gammas, gas_constants)\n\nMulticomponent version of the compressible Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho v_1 rho v_2 rho e rho_1 rho_2 vdots rho_n\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\nrho v_1^2 + p rho v_1 v_2 ( rho e +p) v_1 rho_1 v_1 rho_2 v_1 vdots rho_n v_1\nendpmatrix\n+\nfracpartialpartial y\nbeginpmatrix\nrho v_1 v_2 rho v_2^2 + p ( rho e +p) v_2 rho_1 v_2 rho_2 v_2 vdots rho_n v_2\nendpmatrix\n=\nbeginpmatrix\n0 0 0 0 0 vdots 0\nendpmatrix\n\nfor calorically perfect gas in two space dimensions. Here, rho_i is the density of component i, rho=sum_i=1^nrho_i the sum of the individual rho_i, v_1, v_2 the velocities, e the specific total energy rather than specific internal energy, and\n\np = (gamma - 1) left( rho e - frac12 rho (v_1^2 + v_2^2) right)\n\nthe pressure,\n\ngamma=fracsum_i=1^nrho_i C_vigamma_isum_i=1^nrho_i C_vi\n\ntotal heat capacity ratio, gamma_i heat capacity ratio of component i,\n\nC_vi=fracRgamma_i-1\n\nspecific heat capacity at constant volume of component i.\n\nIn case of more than one component, the specific heat ratios gammas and the gas constants gas_constants in [kJ/(kg*K)] should be passed as tuples, e.g., gammas=(1.4, 1.667).\n\nThe remaining variables like the specific heats at constant volume cv or the specific heats at constant pressure cp are then calculated considering a calorically perfect gas.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleNavierStokesDiffusion1D","page":"Trixi.jl","title":"Trixi.CompressibleNavierStokesDiffusion1D","text":"CompressibleNavierStokesDiffusion1D(equations; mu, Pr,\n gradient_variables=GradientVariablesPrimitive())\n\nContains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations1D.\n\nequations: instance of the CompressibleEulerEquations1D\nmu: dynamic viscosity,\nPr: Prandtl number,\ngradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().\n\nFluid properties such as the dynamic viscosity mu can be provided in any consistent unit system, e.g., [mu] = kg m⁻¹ s⁻¹.\n\nThe particular form of the compressible Navier-Stokes implemented is\n\nfracpartialpartial t\nbeginpmatrix\nrho rho v rho e\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\n rho v rho v^2 + p (rho e + p) v\nendpmatrix\n=\nfracpartialpartial x\nbeginpmatrix\n0 tau tau v - q\nendpmatrix\n\nwhere the system is closed with the ideal gas assumption giving\n\np = (gamma - 1) left( rho e - frac12 rho v^2 right)\n\nas the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations1D. The terms on the right hand side of the system above are built from the viscous stress\n\ntau = mu fracpartialpartial x v\n\nwhere the heat flux is\n\nq = -kappa fracpartialpartial x left(Tright)quad T = fracpRrho\n\nwhere T is the temperature and kappa is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is\n\nkappa = fracgamma mu R(gamma - 1)textrmPr\n\nFrom this combination of temperature T and thermal conductivity kappa we see that the gas constant R cancels and the heat flux becomes\n\nq = -kappa fracpartialpartial x left(Tright) = -fracgamma mu(gamma - 1)textrmPr fracpartialpartial x left(fracprhoright)\n\nwhich is the form implemented below in the flux function.\n\nIn one spatial dimensions we require gradients for two quantities, e.g., primitive quantities\n\nfracpartialpartial x v fracpartialpartial x T\n\nor the entropy variables\n\nfracpartialpartial x w_2 fracpartialpartial x w_3\n\nwhere\n\nw_2 = fracrho v1p w_3 = -fracrhop\n\nwarning: Experimental code\nThis code is experimental and may be changed or removed in any future release.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleNavierStokesDiffusion2D","page":"Trixi.jl","title":"Trixi.CompressibleNavierStokesDiffusion2D","text":"CompressibleNavierStokesDiffusion2D(equations; mu, Pr,\n gradient_variables=GradientVariablesPrimitive())\n\nContains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations2D.\n\nequations: instance of the CompressibleEulerEquations2D\nmu: dynamic viscosity,\nPr: Prandtl number,\ngradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().\n\nFluid properties such as the dynamic viscosity mu can be provided in any consistent unit system, e.g., [mu] = kg m⁻¹ s⁻¹.\n\nThe particular form of the compressible Navier-Stokes implemented is\n\nfracpartialpartial t\nbeginpmatrix\nrho rho mathbfv rho e\nendpmatrix\n+\nnabla cdot\nbeginpmatrix\n rho mathbfv rho mathbfvmathbfv^T + p underlineI (rho e + p) mathbfv\nendpmatrix\n=\nnabla cdot\nbeginpmatrix\n0 underlinetau underlinetaumathbfv - mathbfq\nendpmatrix\n\nwhere the system is closed with the ideal gas assumption giving\n\np = (gamma - 1) left( rho e - frac12 rho (v_1^2+v_2^2) right)\n\nas the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations2D. The terms on the right hand side of the system above are built from the viscous stress tensor\n\nunderlinetau = mu left(nablamathbfv + left(nablamathbfvright)^Tright) - frac23 mu left(nablacdotmathbfvright)underlineI\n\nwhere underlineI is the 2times 2 identity matrix and the heat flux is\n\nmathbfq = -kappanablaleft(Tright)quad T = fracpRrho\n\nwhere T is the temperature and kappa is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is\n\nkappa = fracgamma mu R(gamma - 1)textrmPr\n\nFrom this combination of temperature T and thermal conductivity kappa we see that the gas constant R cancels and the heat flux becomes\n\nmathbfq = -kappanablaleft(Tright) = -fracgamma mu(gamma - 1)textrmPrnablaleft(fracprhoright)\n\nwhich is the form implemented below in the flux function.\n\nIn two spatial dimensions we require gradients for three quantities, e.g., primitive quantities\n\nnabla v_1 nabla v_2 nabla T\n\nor the entropy variables\n\nnabla w_2 nabla w_3 nabla w_4\n\nwhere\n\nw_2 = fracrho v_1p w_3 = fracrho v_2p w_4 = -fracrhop\n\nwarning: Experimental code\nThis code is experimental and may be changed or removed in any future release.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.CompressibleNavierStokesDiffusion3D","page":"Trixi.jl","title":"Trixi.CompressibleNavierStokesDiffusion3D","text":"CompressibleNavierStokesDiffusion3D(equations; mu, Pr,\n gradient_variables=GradientVariablesPrimitive())\n\nContains the diffusion (i.e. parabolic) terms applied to mass, momenta, and total energy together with the advective terms from the CompressibleEulerEquations3D.\n\nequations: instance of the CompressibleEulerEquations3D\nmu: dynamic viscosity,\nPr: Prandtl number,\ngradient_variables: which variables the gradients are taken with respect to. Defaults to GradientVariablesPrimitive().\n\nFluid properties such as the dynamic viscosity mu can be provided in any consistent unit system, e.g., [mu] = kg m⁻¹ s⁻¹.\n\nThe particular form of the compressible Navier-Stokes implemented is\n\nfracpartialpartial t\nbeginpmatrix\nrho rho mathbfv rho e\nendpmatrix\n+\nnabla cdot\nbeginpmatrix\n rho mathbfv rho mathbfvmathbfv^T + p underlineI (rho e + p) mathbfv\nendpmatrix\n=\nnabla cdot\nbeginpmatrix\n0 underlinetau underlinetaumathbfv - mathbfq\nendpmatrix\n\nwhere the system is closed with the ideal gas assumption giving\n\np = (gamma - 1) left( rho e - frac12 rho (v_1^2+v_2^2+v_3^2) right)\n\nas the pressure. The value of the adiabatic constant gamma is taken from the CompressibleEulerEquations2D. The terms on the right hand side of the system above are built from the viscous stress tensor\n\nunderlinetau = mu left(nablamathbfv + left(nablamathbfvright)^Tright) - frac23 mu left(nablacdotmathbfvright)underlineI\n\nwhere underlineI is the 3times 3 identity matrix and the heat flux is\n\nmathbfq = -kappanablaleft(Tright)quad T = fracpRrho\n\nwhere T is the temperature and kappa is the thermal conductivity for Fick's law. Under the assumption that the gas has a constant Prandtl number, the thermal conductivity is\n\nkappa = fracgamma mu R(gamma - 1)textrmPr\n\nFrom this combination of temperature T and thermal conductivity kappa we see that the gas constant R cancels and the heat flux becomes\n\nmathbfq = -kappanablaleft(Tright) = -fracgamma mu(gamma - 1)textrmPrnablaleft(fracprhoright)\n\nwhich is the form implemented below in the flux function.\n\nIn two spatial dimensions we require gradients for three quantities, e.g., primitive quantities\n\nnabla v_1 nabla v_2 nabla v_3 nabla T\n\nor the entropy variables\n\nnabla w_2 nabla w_3 nabla w_4 nabla w_5\n\nwhere\n\nw_2 = fracrho v_1p w_3 = fracrho v_2p w_4 = fracrho v_3p w_5 = -fracrhop\n\nwarning: Experimental code\nThis code is experimental and may be changed or removed in any future release.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ControllerThreeLevel","page":"Trixi.jl","title":"Trixi.ControllerThreeLevel","text":"ControllerThreeLevel(semi, indicator; base_level=1,\n med_level=base_level, med_threshold=0.0,\n max_level=base_level, max_threshold=1.0)\n\nAn AMR controller based on three levels (in descending order of precedence):\n\nset the target level to max_level if indicator > max_threshold\nset the target level to med_level if indicator > med_threshold; if med_level < 0, set the target level to the current level\nset the target level to base_level otherwise\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ControllerThreeLevelCombined","page":"Trixi.jl","title":"Trixi.ControllerThreeLevelCombined","text":"ControllerThreeLevelCombined(semi, indicator_primary, indicator_secondary;\n base_level=1,\n med_level=base_level, med_threshold=0.0,\n max_level=base_level, max_threshold=1.0,\n max_threshold_secondary=1.0)\n\nAn AMR controller based on three levels (in descending order of precedence):\n\nset the target level to max_level if indicator_primary > max_threshold\nset the target level to med_level if indicator_primary > med_threshold; if med_level < 0, set the target level to the current level\nset the target level to base_level otherwise\n\nIf indicator_secondary >= max_threshold_secondary, set the target level to max_level.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.DG","page":"Trixi.jl","title":"Trixi.DG","text":"DG(; basis, mortar, surface_integral, volume_integral)\n\nCreate a discontinuous Galerkin method. If basis isa LobattoLegendreBasis, this creates a DGSEM.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.DGMulti-Tuple{SummationByPartsOperators.AbstractDerivativeOperator}","page":"Trixi.jl","title":"Trixi.DGMulti","text":"DGMulti(approximation_type::AbstractDerivativeOperator;\n element_type::AbstractElemShape,\n surface_flux=flux_central,\n surface_integral=SurfaceIntegralWeakForm(surface_flux),\n volume_integral=VolumeIntegralWeakForm(),\n kwargs...)\n\nCreate a summation by parts (SBP) discretization on the given element_type using a tensor product structure based on the 1D SBP derivative operator passed as approximation_type.\n\nFor more info, see the documentations of StartUpDG.jl and SummationByPartsOperators.jl.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMulti-Tuple{}","page":"Trixi.jl","title":"Trixi.DGMulti","text":"DGMulti(; polydeg::Integer,\n element_type::AbstractElemShape,\n approximation_type=Polynomial(),\n surface_flux=flux_central,\n surface_integral=SurfaceIntegralWeakForm(surface_flux),\n volume_integral=VolumeIntegralWeakForm(),\n RefElemData_kwargs...)\n\nCreate a discontinuous Galerkin method which uses\n\napproximations of polynomial degree polydeg\nelement type element_type (Tri(), Quad(), Tet(), and Hex() currently supported)\n\nOptional:\n\napproximation_type (default is Polynomial(); SBP() also supported for Tri(), Quad(), and Hex() element types).\nRefElemData_kwargs are additional keyword arguments for RefElemData, such as quad_rule_vol. For more info, see the StartUpDG.jl docs.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh{NDIMS, ...}\n\nDGMultiMesh describes a mesh type which wraps StartUpDG.MeshData and boundary_faces in a dispatchable type. This is intended to store geometric data and connectivities for any type of mesh (Cartesian, affine, curved, structured/unstructured).\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Tuple{DGMulti{2, Tri, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{2, Tri, ApproxType}} where {ApproxType, SurfaceIntegral, VolumeIntegral, Mortar}, Any, Dict{Symbol, Int64}}","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti{2, Tri}, triangulateIO, boundary_dict::Dict{Symbol, Int})\n\ndg::DGMulti contains information associated with to the reference element (e.g., quadrature, basis evaluation, differentiation, etc).\ntriangulateIO is a TriangulateIO mesh representation\nboundary_dict is a Dict{Symbol, Int} which associates each integer TriangulateIO boundary tag with a Symbol.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Union{Tuple{DGMulti{NDIMS, ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{NDIMS, ElemType, ApproxType}} where {ElemType, ApproxType<:SummationByPartsOperators.AbstractPeriodicDerivativeOperator, SurfaceIntegral, VolumeIntegral, Mortar}}, Tuple{NDIMS}} where NDIMS","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti)\n\nConstructs a single-element DGMultiMesh for a single periodic element given a DGMulti with approximation_type set to a periodic (finite difference) SBP operator from SummationByPartsOperators.jl.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Union{Tuple{NDIMS}, Tuple{DGMulti{NDIMS, ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{NDIMS, ElemType, ApproxType}} where {ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar}, Any, AbstractArray}} where NDIMS","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti{NDIMS}, vertex_coordinates, EToV;\n is_on_boundary=nothing,\n periodicity=ntuple(_->false, NDIMS)) where {NDIMS}\n\ndg::DGMulti contains information associated with to the reference element (e.g., quadrature, basis evaluation, differentiation, etc).\nvertex_coordinates is a tuple of vectors containing x,y,... components of the vertex coordinates\nEToV is a 2D array containing element-to-vertex connectivities for each element\nis_on_boundary specifies boundary using a Dict{Symbol, <:Function}\nperiodicity is a tuple of booleans specifying if the domain is periodic true/false in the (x,y,z) direction.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Union{Tuple{NDIMS}, Tuple{DGMulti{NDIMS, ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{NDIMS, ElemType, ApproxType}} where {ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar}, Any, Any}} where NDIMS","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti{NDIMS}, cells_per_dimension, mapping;\n is_on_boundary=nothing,\n periodicity=ntuple(_ -> false, NDIMS), kwargs...) where {NDIMS}\n\nConstructs a Curved() DGMultiMesh with element type dg.basis.element_type.\n\nmapping is a function which maps from a reference [-1, 1]^NDIMS domain to a mapped domain, e.g., xy = mapping(x, y) in 2D.\nis_on_boundary specifies boundary using a Dict{Symbol, <:Function}\nperiodicity is a tuple of Bools specifying periodicity = true/false in the (x,y,z) direction.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Union{Tuple{NDIMS}, Tuple{DGMulti{NDIMS, ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{NDIMS, ElemType, ApproxType}} where {ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar}, Any}} where NDIMS","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti, cells_per_dimension;\n coordinates_min=(-1.0, -1.0), coordinates_max=(1.0, 1.0),\n is_on_boundary=nothing,\n periodicity=ntuple(_ -> false, NDIMS))\n\nConstructs a Cartesian DGMultiMesh with element type dg.basis.element_type. The domain is the tensor product of the intervals [coordinates_min[i], coordinates_max[i]].\n\nis_on_boundary specifies boundary using a Dict{Symbol, <:Function}\nperiodicity is a tuple of Bools specifying periodicity = true/false in the (x,y,z) direction.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiMesh-Union{Tuple{NDIMS}, Tuple{DGMulti{NDIMS, ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar, <:StartUpDG.RefElemData{NDIMS, ElemType, ApproxType}} where {ElemType, ApproxType, SurfaceIntegral, VolumeIntegral, Mortar}, String}} where NDIMS","page":"Trixi.jl","title":"Trixi.DGMultiMesh","text":"DGMultiMesh(dg::DGMulti, filename::String)\n\ndg::DGMulti contains information associated with the reference element (e.g., quadrature, basis evaluation, differentiation, etc).\nfilename is a path specifying a .mesh file generated by HOHQMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGSEM","page":"Trixi.jl","title":"Trixi.DGSEM","text":"DGSEM(; RealT=Float64, polydeg::Integer,\n surface_flux=flux_central,\n surface_integral=SurfaceIntegralWeakForm(surface_flux),\n volume_integral=VolumeIntegralWeakForm(),\n mortar=MortarL2(basis))\n\nCreate a discontinuous Galerkin spectral element method (DGSEM) using a LobattoLegendreBasis with polynomials of degree polydeg.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.DissipationGlobalLaxFriedrichs","page":"Trixi.jl","title":"Trixi.DissipationGlobalLaxFriedrichs","text":"DissipationGlobalLaxFriedrichs(λ)\n\nCreate a global Lax-Friedrichs dissipation operator with dissipation coefficient λ.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.DissipationLocalLaxFriedrichs","page":"Trixi.jl","title":"Trixi.DissipationLocalLaxFriedrichs","text":"DissipationLocalLaxFriedrichs(max_abs_speed=max_abs_speed_naive)\n\nCreate a local Lax-Friedrichs dissipation operator where the maximum absolute wave speed is estimated as max_abs_speed(u_ll, u_rr, orientation_or_normal_direction, equations), defaulting to max_abs_speed_naive.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.EulerAcousticsCouplingCallback","page":"Trixi.jl","title":"Trixi.EulerAcousticsCouplingCallback","text":"EulerAcousticsCouplingCallback\n\nwarning: Experimental code\nThis callback is experimental and may change in any future release.\n\nA callback that couples the acoustic perturbation equations and compressible Euler equations. Must be used in conjunction with SemidiscretizationEulerAcoustics. This callback manages the flow solver - which is always one time step ahead of the acoustics solver - and calculates the acoustic source term after each time step. The linearized Lamb vector is used as the source term, i.e.\n\nmathbfs = -(mathbfomega times barmathbfv\n + barmathbfomega times mathbfv)\n\nwhere mathbfv denotes the velocity, mathbfomega denotes the vorticity, the bar bar(cdot) indicates time-averaged quantities (see AveragingCallback) and prime (cdot) denotes perturbed quantities defined by phi = phi - barphi. Note that the perturbed quantities here are based entirely on the pure flow solution and should not be confused with the state variables of the acoustic perturbation equations.\n\nIn addition, this callback manages the time step size for both solvers and initializes the mean values of the acoustic perturbation equations using results obtained with the AveragingCallback.\n\nMichael Schlottke-Lakemper (2017) A direct-hybrid method for aeroacoustic analysis DOI: 10.18154/RWTH-2017-04082\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.EulerAcousticsCouplingCallback-Tuple{Any, AbstractString, Any, Real, Real}","page":"Trixi.jl","title":"Trixi.EulerAcousticsCouplingCallback","text":"EulerAcousticsCouplingCallback(ode_euler, averaging_file::AbstractString, alg,\n cfl_acoustics::Real, cfl_euler::Real; kwargs...)\n\nwarning: Experimental code\nThis callback is experimental and may change in any future release.\n\nCreates an EulerAcousticsCouplingCallback based on the pure flow ODEProblem given by ode_euler. Creates an integrator using the time integration method alg and the keyword arguments to solve ode_euler (consult the OrdinaryDiffEq documentation for further information). Manages the step size for both solvers by using the minimum of the maximum step size obtained with CFL numbers cfl_acoustics for the acoustics solver and cfl_euler for and flow solver, respectively. The mean values for the acoustic perturbation equations are read from averaging_file (see AveragingCallback).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.EulerAcousticsCouplingCallback-Tuple{Any, DiscreteCallback{<:Any, <:AveragingCallback}, Any, Real, Real}","page":"Trixi.jl","title":"Trixi.EulerAcousticsCouplingCallback","text":"EulerAcousticsCouplingCallback(ode_euler,\n averaging_callback::DiscreteCallback{<:Any, <:AveragingCallback},\n alg, cfl_acoustics::Real, cfl_euler::Real; kwargs...)\n\nwarning: Experimental code\nThis callback is experimental and may change in any future release.\n\nCreates an EulerAcousticsCouplingCallback based on the pure flow ODEProblem given by ode_euler. Creates an integrator using the time integration method alg and the keyword arguments to solve ode_euler (consult the OrdinaryDiffEq documentation for further information). Manages the step size for both solvers by using the minimum of the maximum step size obtained with CFL numbers cfl_acoustics for the acoustics solver and cfl_euler for and flow solver, respectively. The mean values for the acoustic perturbation equations are read from averaging_callback (see AveragingCallback).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.FDSBP","page":"Trixi.jl","title":"Trixi.FDSBP","text":"FDSBP(D_SBP; surface_integral, volume_integral)\n\nSpecialization of DG methods that uses general summation by parts (SBP) operators from SummationByPartsOperators.jl. In particular, this includes classical finite difference (FD) SBP methods. These methods have the same structure as classical DG methods - local operations on elements with connectivity through interfaces without imposing any continuity constraints.\n\nD_SBP is an SBP derivative operator from SummationByPartsOperators.jl. The other arguments have the same meaning as in DG or DGSEM.\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxHLL","page":"Trixi.jl","title":"Trixi.FluxHLL","text":"FluxHLL(min_max_speed=min_max_speed_naive)\n\nCreate an HLL (Harten, Lax, van Leer) numerical flux where the minimum and maximum wave speeds are estimated as λ_min, λ_max = min_max_speed(u_ll, u_rr, orientation_or_normal_direction, equations), defaulting to min_max_speed_naive. Original paper:\n\nAmiram Harten, Peter D. Lax, Bram van Leer (1983) On Upstream Differencing and Godunov-Type Schemes for Hyperbolic Conservation Laws DOI: 10.1137/1025002\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxHydrostaticReconstruction","page":"Trixi.jl","title":"Trixi.FluxHydrostaticReconstruction","text":"FluxHydrostaticReconstruction(numerical_flux, hydrostatic_reconstruction)\n\nwarning: Experimental code\nThis numerical flux is experimental and may change in any future release.\n\nAllow for some kind of hydrostatic reconstruction of the solution state prior to the surface flux computation. This is a particular strategy to ensure that the method remains well-balanced for the shallow water equations, see ShallowWaterEquations1D or ShallowWaterEquations2D.\n\nFor example, the hydrostatic reconstruction from Audusse et al. is implemented in one and two spatial dimensions, see hydrostatic_reconstruction_audusse_etal or the original paper\n\nEmmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090\n\nOther hydrostatic reconstruction techniques are available, particularly to handle wet / dry fronts. A good overview of the development and application of hydrostatic reconstruction can be found in\n\nGuoxian Chen and Sebastian Noelle A unified surface-gradient and hydrostatic reconstruction scheme for the shallow water equations (2021) RWTH Aachen preprint\nAndreas Buttinger-Kreuzhuber, Zsolt Horváth, Sebastian Noelle, Günter Blöschl and Jürgen Waser (2019) A fast second-order shallow water scheme on two-dimensional structured grids over abrupt topography DOI: 10.1016/j.advwatres.2019.03.010\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxLMARS","page":"Trixi.jl","title":"Trixi.FluxLMARS","text":"FluxLMARS(c)(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations3D)\n\nLow Mach number approximate Riemann solver (LMARS) for atmospheric flows using an estimate c of the speed of sound.\n\nReferences:\n\nXi Chen et al. (2013) A Control-Volume Model of the Compressible Euler Equations with a Vertical Lagrangian Coordinate DOI: 10.1175/MWR-D-12-00129.1\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxLaxFriedrichs","page":"Trixi.jl","title":"Trixi.FluxLaxFriedrichs","text":"FluxLaxFriedrichs(max_abs_speed=max_abs_speed_naive)\n\nLocal Lax-Friedrichs (Rusanov) flux with maximum wave speed estimate provided by max_abs_speed, cf. DissipationLocalLaxFriedrichs and max_abs_speed_naive.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxPlusDissipation","page":"Trixi.jl","title":"Trixi.FluxPlusDissipation","text":"FluxPlusDissipation(numerical_flux, dissipation)\n\nCombine a numerical_flux with a dissipation operator to create a new numerical flux.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxRotated","page":"Trixi.jl","title":"Trixi.FluxRotated","text":"FluxRotated(numerical_flux)\n\nCompute a numerical_flux flux in direction of a normal vector by rotating the solution, computing the numerical flux in x-direction, and rotating the calculated flux back.\n\nRequires a rotationally invariant equation with equation-specific functions rotate_to_x and rotate_from_x.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.FluxUpwind","page":"Trixi.jl","title":"Trixi.FluxUpwind","text":"FluxUpwind(splitting)\n\nA numerical flux f(u_left, u_right) = f⁺(u_left) + f⁻(u_right) based on flux vector splitting.\n\nThe SurfaceIntegralUpwind with a given splitting is equivalent to the SurfaceIntegralStrongForm with FluxUpwind(splitting) as numerical flux (up to floating point differences).\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.GlmSpeedCallback","page":"Trixi.jl","title":"Trixi.GlmSpeedCallback","text":"GlmSpeedCallback(; glm_scale=0.5, cfl)\n\nUpdate the divergence cleaning wave speed c_h according to the time step computed in StepsizeCallback for the ideal GLM-MHD equations. The cfl number should be set to the same value as for the time step size calculation. The glm_scale ensures that the GLM wave speed is lower than the fastest physical waves in the MHD solution and should thus be set to a value within the interval [0,1]. Note that glm_scale = 0 deactivates the divergence cleaning.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.GradientVariablesPrimitive","page":"Trixi.jl","title":"Trixi.GradientVariablesPrimitive","text":"warning: Experimental code\nThis code is experimental and may be changed or removed in any future release.\n\nGradientVariablesPrimitive and GradientVariablesEntropy are gradient variable type parameters for CompressibleNavierStokesDiffusion1D. By default, the gradient variables are set to be GradientVariablesPrimitive. Specifying GradientVariablesEntropy instead uses the entropy variable formulation from\n\nHughes, Mallet, Franca (1986) A new finite element formulation for computational fluid dynamics: I. Symmetric forms of the compressible Euler and Navier-Stokes equations and the second law of thermodynamics. https://doi.org/10.1016/0045-7825(86)90127-1\n\nUnder GradientVariablesEntropy, the Navier-Stokes discretization is provably entropy stable.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.HypDiffN3Erk3Sstar52","page":"Trixi.jl","title":"Trixi.HypDiffN3Erk3Sstar52","text":"HypDiffN3Erk3Sstar52()\n\nFive stage, second-order accurate explicit Runge-Kutta scheme with stability region optimized for the hyperbolic diffusion equation with LLF flux and polynomials of degree polydeg=3.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.HyperbolicDiffusionEquations1D","page":"Trixi.jl","title":"Trixi.HyperbolicDiffusionEquations1D","text":"HyperbolicDiffusionEquations1D\n\nThe linear hyperbolic diffusion equations in one space dimension. A description of this system can be found in Sec. 2.5 of the book\n\nMasatsuka (2013) I Do Like CFD, Too: Vol 1. Freely available at http://www.cfdbooks.com/\n\nFurther analysis can be found in the paper\n\nNishikawa (2007) A first-order system approach for diffusion equation. I: Second-order residual-distribution schemes DOI: 10.1016/j.jcp.2007.07.029\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.HyperbolicDiffusionEquations2D","page":"Trixi.jl","title":"Trixi.HyperbolicDiffusionEquations2D","text":"HyperbolicDiffusionEquations2D\n\nThe linear hyperbolic diffusion equations in two space dimensions. A description of this system can be found in Sec. 2.5 of the book \"I Do Like CFD, Too: Vol 1\". The book is freely available at http://www.cfdbooks.com/ and further analysis can be found in the paper by Nishikawa DOI: 10.1016/j.jcp.2007.07.029\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.HyperbolicDiffusionEquations3D","page":"Trixi.jl","title":"Trixi.HyperbolicDiffusionEquations3D","text":"HyperbolicDiffusionEquations3D\n\nThe linear hyperbolic diffusion equations in three space dimensions. A description of this system can be found in Sec. 2.5 of the book \"I Do Like CFD, Too: Vol 1\". The book is freely available at http://www.cfdbooks.com/ and further analysis can be found in the paper by Nishikawa DOI: 10.1016/j.jcp.2007.07.029\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IdealGlmMhdEquations1D","page":"Trixi.jl","title":"Trixi.IdealGlmMhdEquations1D","text":"IdealGlmMhdEquations1D(gamma)\n\nThe ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in one space dimension.\n\nnote: Note\nThere is no divergence cleaning variable psi because the divergence-free constraint is satisfied trivially in one spatial dimension.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IdealGlmMhdEquations2D","page":"Trixi.jl","title":"Trixi.IdealGlmMhdEquations2D","text":"IdealGlmMhdEquations2D(gamma)\n\nThe ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in two space dimensions.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IdealGlmMhdEquations3D","page":"Trixi.jl","title":"Trixi.IdealGlmMhdEquations3D","text":"IdealGlmMhdEquations3D(gamma)\n\nThe ideal compressible GLM-MHD equations for an ideal gas with ratio of specific heats gamma in three space dimensions.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IdealGlmMhdMulticomponentEquations1D","page":"Trixi.jl","title":"Trixi.IdealGlmMhdMulticomponentEquations1D","text":"IdealGlmMhdMulticomponentEquations1D\n\nThe ideal compressible multicomponent GLM-MHD equations in one space dimension.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IdealGlmMhdMulticomponentEquations2D","page":"Trixi.jl","title":"Trixi.IdealGlmMhdMulticomponentEquations2D","text":"IdealGlmMhdMulticomponentEquations2D\n\nThe ideal compressible multicomponent GLM-MHD equations in two space dimensions.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IndicatorHennemannGassner","page":"Trixi.jl","title":"Trixi.IndicatorHennemannGassner","text":"IndicatorHennemannGassner(equations::AbstractEquations, basis;\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable)\nIndicatorHennemannGassner(semi::AbstractSemidiscretization;\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable)\n\nIndicator used for shock-capturing (when passing the equations and the basis) or adaptive mesh refinement (AMR, when passing the semi).\n\nSee also VolumeIntegralShockCapturingHG.\n\nReferences\n\nHennemann, Gassner (2020) \"A provably entropy stable subcell shock capturing approach for high order split form DG\" arXiv: 2008.12044\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IndicatorHennemannGassnerShallowWater","page":"Trixi.jl","title":"Trixi.IndicatorHennemannGassnerShallowWater","text":"IndicatorHennemannGassnerShallowWater(equations::AbstractEquations, basis;\n alpha_max=0.5,\n alpha_min=0.001,\n alpha_smooth=true,\n variable)\n\nModified version of the IndicatorHennemannGassner indicator used for shock-capturing for shallow water equations. After the element-wise values for the blending factors are computed an additional check is made to see if the element is partially wet. In this case, partially wet elements are set to use the pure finite volume scheme that is guaranteed to be well-balanced for this wet/dry transition state of the flow regime.\n\nSee also VolumeIntegralShockCapturingHG.\n\nReferences\n\nHennemann, Gassner (2020) \"A provably entropy stable subcell shock capturing approach for high order split form DG\" arXiv: 2008.12044\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IndicatorLöhner","page":"Trixi.jl","title":"Trixi.IndicatorLöhner","text":"IndicatorLöhner (equivalent to IndicatorLoehner)\n\nIndicatorLöhner(equations::AbstractEquations, basis;\n f_wave=0.2, variable)\nIndicatorLöhner(semi::AbstractSemidiscretization;\n f_wave=0.2, variable)\n\nAMR indicator adapted from a FEM indicator by Löhner (1987), also used in the FLASH code as standard AMR indicator. The indicator estimates a weighted second derivative of a specified variable locally.\n\nWhen constructed to be used for AMR, pass the semi. Pass the equations, and basis if this indicator should be used for shock capturing.\n\nReferences\n\nLöhner (1987) \"An adaptive finite element scheme for transient problems in CFD\" doi: 10.1016/0045-7825(87)90098-3\nhttps://flash.rochester.edu/site/flashcode/usersupport/flash4ug_4p62/node59.html#SECTION05163100000000000000\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IndicatorMax","page":"Trixi.jl","title":"Trixi.IndicatorMax","text":"IndicatorMax(equations::AbstractEquations, basis; variable)\nIndicatorMax(semi::AbstractSemidiscretization; variable)\n\nA simple indicator returning the maximum of variable in an element. When constructed to be used for AMR, pass the semi. Pass the equations, and basis if this indicator should be used for shock capturing.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.IndicatorNeuralNetwork","page":"Trixi.jl","title":"Trixi.IndicatorNeuralNetwork","text":"IndicatorNeuralNetwork\n\nArtificial neural network based indicator used for shock-capturing or AMR. Depending on the indicator_type, different input values and corresponding trained networks are used.\n\nindicator_type = NeuralNetworkPerssonPeraire()\n\nInput: The energies in lower modes as well as nnodes(dg).\n\nindicator_type = NeuralNetworkRayHesthaven()\n\n1d Input: Cell average of the cell and its neighboring cells as well as the interface values.\n2d Input: Linear modal values of the cell and its neighboring cells.\nRay, Hesthaven (2018) \"An artificial neural network as a troubled-cell indicator\" doi:10.1016/j.jcp.2018.04.029\nRay, Hesthaven (2019) \"Detecting troubled-cells on two-dimensional unstructured grids using a neural network\" doi:10.1016/j.jcp.2019.07.043\n\nindicator_type = CNN (Only in 2d)\n\nBased on convolutional neural network.\n2d Input: Interpolation of the nodal values of the indicator.variable to the 4x4 LGL nodes.\n\nIf alpha_continuous == true the continuous network output for troubled cells (alpha > 0.5) is considered. If the cells are good (alpha < 0.5), alpha is set to 0. If alpha_continuous == false, the blending factor is set to alpha = 0 for good cells and alpha = 1 for troubled cells.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.InviscidBurgersEquation1D","page":"Trixi.jl","title":"Trixi.InviscidBurgersEquation1D","text":"InviscidBurgersEquation1D\n\nThe inviscid Burgers' equation\n\npartial_t u + frac12 partial_1 u^2 = 0\n\nin one space dimension.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.Isothermal","page":"Trixi.jl","title":"Trixi.Isothermal","text":"struct Isothermal\n\nUsed to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_function should be a function with signature boundary_value_function(x, t, equations) and return a scalar value for the temperature at point x and time t.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LaplaceDiffusion1D","page":"Trixi.jl","title":"Trixi.LaplaceDiffusion1D","text":"LaplaceDiffusion1D(diffusivity, equations)\n\nLaplaceDiffusion1D represents a scalar diffusion term nabla cdot (kappanabla u)) with diffusivity kappa applied to each solution component defined by equations.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LaplaceDiffusion2D","page":"Trixi.jl","title":"Trixi.LaplaceDiffusion2D","text":"LaplaceDiffusion2D(diffusivity, equations)\n\nLaplaceDiffusion2D represents a scalar diffusion term nabla cdot (kappanabla u)) with diffusivity kappa applied to each solution component defined by equations.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LaplaceDiffusion3D","page":"Trixi.jl","title":"Trixi.LaplaceDiffusion3D","text":"LaplaceDiffusion3D(diffusivity, equations)\n\nLaplaceDiffusion3D represents a scalar diffusion term nabla cdot (kappanabla u)) with diffusivity kappa applied to each solution component defined by equations.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LatticeBoltzmannEquations2D","page":"Trixi.jl","title":"Trixi.LatticeBoltzmannEquations2D","text":"LatticeBoltzmannEquations2D(; Ma, Re, collision_op=collision_bgk,\n c=1, L=1, rho0=1, u0=nothing, nu=nothing)\n\nThe Lattice-Boltzmann equations\n\npartial_t u_alpha + v_alpha1 partial_1 u_alpha + v_alpha2 partial_2 u_alpha = 0\n\nin two space dimensions for the D2Q9 scheme.\n\nThe characteristic Mach number and Reynolds numbers are specified as Ma and Re. By the default, the collision operator collision_op is set to the BGK model. c, L, and rho0 specify the mean thermal molecular velocity, the characteristic length, and the reference density, respectively. They can usually be left to the default values. If desired, instead of the Mach number, one can set the macroscopic reference velocity u0 directly (Ma needs to be set to nothing in this case). Likewise, instead of the Reynolds number one can specify the kinematic viscosity nu directly (in this case, Re needs to be set to nothing).\n\nThe nine discrete velocity directions of the D2Q9 scheme are sorted as follows [4]:\n\n 6 2 5 y\n ┌───┼───┐ │\n │ │ │\n 3 ┼ 9 ┼ 1 ──── x\n │ │ ╱\n └───┼───┘ ╱\n 7 4 8 z\n\nNote that usually the velocities are numbered from 0 to 8, where 0 corresponds to the zero velocity. Due to Julia using 1-based indexing, here we use indices from 1 to 9, where 1 through 8 correspond to the velocity directions in [4] and 9 is the zero velocity.\n\nThe corresponding opposite directions are:\n\n1 ←→ 3\n2 ←→ 4\n3 ←→ 1\n4 ←→ 2\n5 ←→ 7\n6 ←→ 8\n7 ←→ 5\n8 ←→ 6\n9 ←→ 9\n\nThe main sources for the base implementation were\n\nMisun Min, Taehun Lee, A spectral-element discontinuous Galerkin lattice Boltzmann method for nearly incompressible flows, J Comput Phys 230(1), 2011 doi:10.1016/j.jcp.2010.09.024\nKarsten Golly, Anwendung der Lattice-Boltzmann Discontinuous Galerkin Spectral Element Method (LB-DGSEM) auf laminare und turbulente nahezu inkompressible Strömungen im dreidimensionalen Raum, Master Thesis, University of Cologne, 2018.\nDieter Hänel, Molekulare Gasdynamik, Springer-Verlag Berlin Heidelberg, 2004 doi:10.1007/3-540-35047-0\nDieter Krüger et al., The Lattice Boltzmann Method, Springer International Publishing, 2017 doi:10.1007/978-3-319-44649-3\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LatticeBoltzmannEquations3D","page":"Trixi.jl","title":"Trixi.LatticeBoltzmannEquations3D","text":"LatticeBoltzmannEquations3D(; Ma, Re, collision_op=collision_bgk,\n c=1, L=1, rho0=1, u0=nothing, nu=nothing)\n\nThe Lattice-Boltzmann equations\n\npartial_t u_alpha + v_alpha1 partial_1 u_alpha + v_alpha2 partial_2 u_alpha + v_alpha3 partial_3 u_alpha = 0\n\nin three space dimensions for the D3Q27 scheme.\n\nThe characteristic Mach number and Reynolds numbers are specified as Ma and Re. By the default, the collision operator collision_op is set to the BGK model. c, L, and rho0 specify the mean thermal molecular velocity, the characteristic length, and the reference density, respectively. They can usually be left to the default values. If desired, instead of the Mach number, one can set the macroscopic reference velocity u0 directly (Ma needs to be set to nothing in this case). Likewise, instead of the Reynolds number one can specify the kinematic viscosity nu directly (in this case, Re needs to be set to nothing).\n\nThe twenty-seven discrete velocity directions of the D3Q27 scheme are sorted as follows [4]:\n\nplane at z = -1:\n 24 17 21 y\n ┌───┼───┐ │\n │ │ │\n 10 ┼ 6 ┼ 15 ──── x\n │ │ ╱\n └───┼───┘ ╱\n 20 12 26 z\nplane at z = 0:\n 14 3 7 y\n ┌───┼───┐ │\n │ │ │\n 2 ┼ 27 ┼ 1 ──── x\n │ │ ╱\n └───┼───┘ ╱\n 8 4 13 z\nplane at z = +1:\n 25 11 19 y\n ┌───┼───┐ │\n │ │ │\n 16 ┼ 5 ┼ 9 ──── x\n │ │ ╱\n └───┼───┘ ╱\n 22 18 23 z\n\nNote that usually the velocities are numbered from 0 to 26, where 0 corresponds to the zero velocity. Due to Julia using 1-based indexing, here we use indices from 1 to 27, where 1 through 26 correspond to the velocity directions in [4] and 27 is the zero velocity.\n\nThe corresponding opposite directions are:\n\n1 ←→ 2\n2 ←→ 1\n3 ←→ 4\n4 ←→ 3\n5 ←→ 6\n6 ←→ 5\n7 ←→ 8\n8 ←→ 7\n9 ←→ 10\n10 ←→ 9\n11 ←→ 12\n12 ←→ 11\n13 ←→ 14\n14 ←→ 13\n15 ←→ 16\n16 ←→ 15\n17 ←→ 18\n18 ←→ 17\n19 ←→ 20\n20 ←→ 19\n21 ←→ 22\n22 ←→ 21\n23 ←→ 24\n24 ←→ 23\n25 ←→ 26\n26 ←→ 25\n27 ←→ 27\n\nThe main sources for the base implementation were\n\nMisun Min, Taehun Lee, A spectral-element discontinuous Galerkin lattice Boltzmann method for nearly incompressible flows, J Comput Phys 230(1), 2011 doi:10.1016/j.jcp.2010.09.024\nKarsten Golly, Anwendung der Lattice-Boltzmann Discontinuous Galerkin Spectral Element Method (LB-DGSEM) auf laminare und turbulente nahezu inkompressible Strömungen im dreidimensionalen Raum, Master Thesis, University of Cologne, 2018.\nDieter Hänel, Molekulare Gasdynamik, Springer-Verlag Berlin Heidelberg, 2004 doi:10.1007/3-540-35047-0\nDieter Krüger et al., The Lattice Boltzmann Method, Springer International Publishing, 2017 doi:10.1007/978-3-319-44649-3\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LinearScalarAdvectionEquation1D","page":"Trixi.jl","title":"Trixi.LinearScalarAdvectionEquation1D","text":"LinearScalarAdvectionEquation1D\n\nThe linear scalar advection equation\n\npartial_t u + a partial_1 u = 0\n\nin one space dimension with constant velocity a.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LinearScalarAdvectionEquation2D","page":"Trixi.jl","title":"Trixi.LinearScalarAdvectionEquation2D","text":"LinearScalarAdvectionEquation2D\n\nThe linear scalar advection equation\n\npartial_t u + a_1 partial_1 u + a_2 partial_2 u = 0\n\nin two space dimensions with constant velocity a.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LinearScalarAdvectionEquation3D","page":"Trixi.jl","title":"Trixi.LinearScalarAdvectionEquation3D","text":"LinearScalarAdvectionEquation3D\n\nThe linear scalar advection equation\n\npartial_t u + a_1 partial_1 u + a_2 partial_2 u + a_3 partial_3 u = 0\n\nin three space dimensions with constant velocity a.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LinearizedEulerEquations2D","page":"Trixi.jl","title":"Trixi.LinearizedEulerEquations2D","text":"LinearizedEulerEquations2D(v_mean_global, c_mean_global, rho_mean_global)\n\nLinearized euler equations in two space dimensions. The equations are given by\n\npartial_t\nbeginpmatrix\n rho v_1 v_2 p\nendpmatrix\n+\npartial_x\nbeginpmatrix\n barrho v_1 + barv_1 rho barv_1 v_1 + fracpbarrho barv_1 v_2 barv_1 p + c^2 barrho v_1\nendpmatrix\n+\npartial_y\nbeginpmatrix\n barrho v_2 + barv_2 rho barv_2 v_1 barv_2 v_2 + fracpbarrho barv_2 p + c^2 barrho v_2\nendpmatrix\n=\nbeginpmatrix\n 0 0 0 0\nendpmatrix\n\nThe bar bar(cdot) indicates uniform mean flow variables and c is the speed of sound. The unknowns are the acoustic velocities v = (v_1 v_2), the pressure p and the density rho.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.LobattoLegendreBasis","page":"Trixi.jl","title":"Trixi.LobattoLegendreBasis","text":"LobattoLegendreBasis([RealT=Float64,] polydeg::Integer)\n\nCreate a nodal Lobatto-Legendre basis for polynomials of degree polydeg.\n\nFor the special case polydeg=0 the DG method reduces to a finite volume method. Therefore, this function sets the center point of the cell as single node.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.NeuralNetworkCNN","page":"Trixi.jl","title":"Trixi.NeuralNetworkCNN","text":"NeuralNetworkCNN\n\nIndicator type for creating an IndicatorNeuralNetwork indicator.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nSee also: IndicatorNeuralNetwork\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.NeuralNetworkPerssonPeraire","page":"Trixi.jl","title":"Trixi.NeuralNetworkPerssonPeraire","text":"NeuralNetworkPerssonPeraire\n\nIndicator type for creating an IndicatorNeuralNetwork indicator.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nSee also: IndicatorNeuralNetwork\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.NeuralNetworkRayHesthaven","page":"Trixi.jl","title":"Trixi.NeuralNetworkRayHesthaven","text":"NeuralNetworkRayHesthaven\n\nIndicator type for creating an IndicatorNeuralNetwork indicator.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nSee also: IndicatorNeuralNetwork\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.NoSlip","page":"Trixi.jl","title":"Trixi.NoSlip","text":"struct NoSlip\n\nUse to create a no-slip boundary condition with BoundaryConditionNavierStokesWall. The field boundary_value_function should be a function with signature boundary_value_function(x, t, equations) and should return a SVector{NDIMS} whose entries are the velocity vector at a point x and time t.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.P4estMesh","page":"Trixi.jl","title":"Trixi.P4estMesh","text":"P4estMesh{NDIMS} <: AbstractMesh{NDIMS}\n\nAn unstructured curved mesh based on trees that uses the C library p4est to manage trees and mesh refinement.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.P4estMesh-Tuple{Any}","page":"Trixi.jl","title":"Trixi.P4estMesh","text":"P4estMesh(trees_per_dimension; polydeg,\n mapping=nothing, faces=nothing, coordinates_min=nothing, coordinates_max=nothing,\n RealT=Float64, initial_refinement_level=0, periodicity=true, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true)\n\nCreate a structured curved P4estMesh of the specified size.\n\nThere are three ways to map the mesh to the physical domain.\n\nDefine a mapping that maps the hypercube [-1, 1]^n.\nSpecify a Tuple faces of functions that parametrize each face.\nCreate a rectangular mesh by specifying coordinates_min and coordinates_max.\n\nNon-periodic boundaries will be called :x_neg, :x_pos, :y_neg, :y_pos, :z_neg, :z_pos.\n\nArguments\n\ntrees_per_dimension::NTupleE{NDIMS, Int}: the number of trees in each dimension.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nmapping: a function of NDIMS variables to describe the mapping that transforms the reference mesh ([-1, 1]^n) to the physical domain. Use only one of mapping, faces and coordinates_min/coordinates_max.\nfaces::NTuple{2*NDIMS}: a tuple of 2 * NDIMS functions that describe the faces of the domain. Each function must take NDIMS-1 arguments. faces[1] describes the face onto which the face in negative x-direction of the unit hypercube is mapped. The face in positive x-direction of the unit hypercube will be mapped onto the face described by faces[2]. faces[3:4] describe the faces in positive and negative y-direction respectively (in 2D and 3D). faces[5:6] describe the faces in positive and negative z-direction respectively (in 3D). Use only one of mapping, faces and coordinates_min/coordinates_max.\ncoordinates_min: vector or tuple of the coordinates of the corner in the negative direction of each dimension to create a rectangular mesh. Use only one of mapping, faces and coordinates_min/coordinates_max.\ncoordinates_max: vector or tuple of the coordinates of the corner in the positive direction of each dimension to create a rectangular mesh. Use only one of mapping, faces and coordinates_min/coordinates_max.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nperiodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.P4estMesh-Union{Tuple{String}, Tuple{NDIMS}} where NDIMS","page":"Trixi.jl","title":"Trixi.P4estMesh","text":"P4estMesh{NDIMS}(meshfile::String;\n mapping=nothing, polydeg=1, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true)\n\nMain mesh constructor for the P4estMesh that imports an unstructured, conforming mesh from an Abaqus mesh file (.inp). Each element of the conforming mesh parsed from the meshfile is created as a p4est tree datatype.\n\nTo create a curved unstructured mesh P4estMesh two strategies are available:\n\np4est_mesh_from_hohqmesh_abaqus: High-order, curved boundary information created by HOHQMesh.jl is available in the meshfile. The mesh polynomial degree polydeg of the boundaries is provided from the meshfile. The computation of the mapped tree coordinates is done with transfinite interpolation with linear blending similar to UnstructuredMesh2D. Boundary name information is also parsed from the meshfile such that different boundary conditions can be set at each named boundary on a given tree.\np4est_mesh_from_standard_abaqus: By default, with mapping=nothing and polydeg=1, this creates a straight-sided from the information parsed from the meshfile. If a mapping function is specified then it computes the mapped tree coordinates via polynomial interpolants with degree polydeg. The mesh created by this function will only have one boundary :all, as distinguishing different physical boundaries is non-trivial.\n\nNote that the mapping and polydeg keyword arguments are only used by the p4est_mesh_from_standard_abaqus function. The p4est_mesh_from_hohqmesh_abaqus function obtains the mesh polydeg directly from the meshfile and constructs the transfinite mapping internally.\n\nThe particular strategy is selected according to the header present in the meshfile where the constructor checks whether or not the meshfile was created with HOHQMesh.jl. If the Abaqus file header is not present in the meshfile then the P4estMesh is created with the function p4est_mesh_from_standard_abaqus.\n\nThe default keyword argument initial_refinement_level=0 corresponds to a forest where the number of trees is the same as the number of elements in the original meshfile. Increasing the initial_refinement_level allows one to uniformly refine the base mesh given in the meshfile to create a forest with more trees before the simulation begins. For example, if a two-dimensional base mesh contains 25 elements then setting initial_refinement_level=1 creates an initial forest of 2^2 * 25 = 100 trees.\n\nArguments\n\nmeshfile::String: an uncurved Abaqus mesh file that can be imported by p4est.\nmapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ParametersEulerGravity","page":"Trixi.jl","title":"Trixi.ParametersEulerGravity","text":"ParametersEulerGravity(; background_density=0.0,\n gravitational_constant=1.0,\n cfl=1.0,\n resid_tol=1.0e-4,\n n_iterations_max=10^4,\n timestep_gravity=timestep_gravity_erk52_3Sstar!)\n\nSet up parameters for the gravitational part of a SemidiscretizationEulerGravity.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ParsaniKetchesonDeconinck3Sstar32","page":"Trixi.jl","title":"Trixi.ParsaniKetchesonDeconinck3Sstar32","text":"ParsaniKetchesonDeconinck3Sstar32()\n\nParsani, Ketcheson, Deconinck (2013) Optimized explicit RK schemes for the spectral difference method applied to wave propagation problems DOI: 10.1137/120885899\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ParsaniKetchesonDeconinck3Sstar94","page":"Trixi.jl","title":"Trixi.ParsaniKetchesonDeconinck3Sstar94","text":"ParsaniKetchesonDeconinck3Sstar94()\n\nParsani, Ketcheson, Deconinck (2013) Optimized explicit RK schemes for the spectral difference method applied to wave propagation problems DOI: 10.1137/120885899\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PerformanceCounter","page":"Trixi.jl","title":"Trixi.PerformanceCounter","text":"PerformanceCounter()\n\nA PerformanceCounter can be used to track the runtime performance of some calls. Add a new runtime measurement via put!(counter, runtime) and get the averaged runtime of all measurements added so far via take!(counter), resetting the counter.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PerformanceCounterList","page":"Trixi.jl","title":"Trixi.PerformanceCounterList","text":"PerformanceCounterList{N}()\n\nA PerformanceCounterList{N} can be used to track the runtime performance of calls to multiple functions, adding them up. Add a new runtime measurement via put!(counter.counters[i], runtime) and get the averaged runtime of all measurements added so far via take!(counter), resetting the counter.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PlotData1D","page":"Trixi.jl","title":"Trixi.PlotData1D","text":"PlotData1D\n\nHolds all relevant data for creating 1D plots of multiple solution variables and to visualize the mesh.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PlotData1D-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.PlotData1D","text":"PlotData1D(u, semi [or mesh, equations, solver, cache];\n solution_variables=nothing, nvisnodes=nothing)\n\nCreate a new PlotData1D object that can be used for visualizing 1D DGSEM solution data array u with Plots.jl. All relevant geometrical information is extracted from the semidiscretization semi. By default, the primitive variables (if existent) or the conservative variables (otherwise) from the solution are used for plotting. This can be changed by passing an appropriate conversion function to solution_variables.\n\nnvisnodes specifies the number of visualization nodes to be used. If it is nothing, twice the number of solution DG nodes are used for visualization, and if set to 0, exactly the number of nodes in the DG elements are used.\n\nWhen visualizing data from a two-dimensional simulation, a 1D slice is extracted for plotting. slice specifies the axis along which the slice is extracted and may be :x, or :y. The slice position is specified by a point that lies on it, which defaults to (0.0, 0.0). Both of these values are ignored when visualizing 1D data. This applies analogously to three-dimensional simulations, where slice may be :xy, :xz, or :yz.\n\nAnother way to visualize 2D/3D data is by creating a plot along a given curve. This is done with the keyword argument curve. It can be set to a list of 2D/3D points which define the curve. When using curve any other input from slice or point will be ignored.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.PlotData1D-Tuple{Union{ODESolution{T, N, uType, uType2, DType, tType, rateType, P} where {T, N, uType, uType2, DType, tType, rateType, P<:(ODEProblem{uType_, tType_, isinplace, P_} where {uType_, tType_, isinplace, P_<:Trixi.AbstractSemidiscretization})}, Trixi.TimeIntegratorSolution}}","page":"Trixi.jl","title":"Trixi.PlotData1D","text":"PlotData1D(sol; kwargs...)\n\nCreate a PlotData1D object from a solution object created by either OrdinaryDiffEq.solve! (which returns a SciMLBase.ODESolution) or Trixi.jl's own solve! (which returns a TimeIntegratorSolution).\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.PlotData2DCartesian","page":"Trixi.jl","title":"Trixi.PlotData2DCartesian","text":"PlotData2D\n\nHolds all relevant data for creating 2D plots of multiple solution variables and to visualize the mesh.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PolytropicEulerEquations2D","page":"Trixi.jl","title":"Trixi.PolytropicEulerEquations2D","text":"PolytropicEulerEquations2D(gamma, kappa)\n\nThe polytropic Euler equations\n\nfracpartialpartial t\nbeginpmatrix\nrho rho v_1 rho v_2\nendpmatrix\n+\nfracpartialpartial x\nbeginpmatrix\n rho v_1 rho v_1^2 + kapparho^gamma rho v_1 v_2\nendpmatrix\n+\nfracpartialpartial y\nbeginpmatrix\nrho v_2 rho v_1 v_2 rho v_2^2 + kapparho^gamma\nendpmatrix\n=\nbeginpmatrix\n0 0 0\nendpmatrix\n\nfor an ideal gas with ratio of specific heats gamma in two space dimensions. Here, rho is the density and v_1 andv_2 the velocities and\n\np = kapparho^gamma\n\nthe pressure, which we replaced using this relation.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PositivityPreservingLimiterShallowWater","page":"Trixi.jl","title":"Trixi.PositivityPreservingLimiterShallowWater","text":"PositivityPreservingLimiterShallowWater(; variables)\n\nThe limiter is specifically designed for the shallow water equations. It is applied to all scalar variables in their given order using the defined threshold_limiter from the ShallowWaterEquations1D struct or the ShallowWaterEquations2D struct to determine the minimal acceptable values. The order of the variables is important and might have a strong influence on the robustness.\n\nAs opposed to the standard version of the PositivityPreservingLimiterZhangShu, nodes with a water height below the threshold_limiter are treated in a special way. To avoid numerical problems caused by velocities close to zero, the velocity is cut off, such that the node can be identified as \"dry\". The special feature of the ShallowWaterEquations used here is that the bottom topography is stored as an additional quantity in the solution vector u. However, the value of the bottom topography should not be changed. That is why, it is not limited.\n\nAfter the limiting process is applied to all degrees of freedom, for safety reasons, the threshold_limiter is applied again on all the DG nodes in order to avoid water height below. In the case where the cell mean value is below the threshold before applying the limiter, there could still be dry nodes afterwards due to the logic of the limiter.\n\nThis fully-discrete positivity-preserving limiter is based on the work of\n\nZhang, Shu (2011) Maximum-principle-satisfying and positivity-preserving high-order schemes for conservation laws: survey and new developments doi: 10.1098/rspa.2011.0153\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.PositivityPreservingLimiterZhangShu","page":"Trixi.jl","title":"Trixi.PositivityPreservingLimiterZhangShu","text":"PositivityPreservingLimiterZhangShu(; threshold, variables)\n\nThe fully-discrete positivity-preserving limiter of\n\nZhang, Shu (2011) Maximum-principle-satisfying and positivity-preserving high-order schemes for conservation laws: survey and new developments doi: 10.1098/rspa.2011.0153\n\nThe limiter is applied to all scalar variables in their given order using the associated thresholds to determine the minimal acceptable values. The order of the variables is important and might have a strong influence on the robustness.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SaveRestartCallback","page":"Trixi.jl","title":"Trixi.SaveRestartCallback","text":"SaveRestartCallback(; interval=0,\n save_final_restart=true,\n output_directory=\"out\")\n\nSave the current numerical solution in a restart file every interval time steps.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SaveSolutionCallback","page":"Trixi.jl","title":"Trixi.SaveSolutionCallback","text":"SaveSolutionCallback(; interval::Integer=0,\n dt=nothing,\n save_initial_solution=true,\n save_final_solution=true,\n output_directory=\"out\",\n solution_variables=cons2prim)\n\nSave the current numerical solution in regular intervals. Either pass interval to save every interval time steps or pass dt to save in intervals of dt in terms of integration time by adding additional (shortened) time steps where necessary (note that this may change the solution). solution_variables can be any callable that converts the conservative variables at a single point to a set of solution variables. The first parameter passed to solution_variables will be the set of conservative variables and the second parameter is the equation struct.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationCoupled","page":"Trixi.jl","title":"Trixi.SemidiscretizationCoupled","text":"SemidiscretizationCoupled\n\nA struct used to bundle multiple semidiscretizations. semidiscretize will return an ODEProblem that synchronizes time steps between the semidiscretizations. Each call of rhs! will call rhs! for each semidiscretization individually. The semidiscretizations can be coupled by gluing meshes together using BoundaryConditionCoupled.\n\nwarning: Experimental code\nThis is an experimental feature and can change any time.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationCoupled-Tuple","page":"Trixi.jl","title":"Trixi.SemidiscretizationCoupled","text":"SemidiscretizationCoupled(semis...)\n\nCreate a coupled semidiscretization that consists of the semidiscretizations passed as arguments.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.SemidiscretizationEulerAcoustics","page":"Trixi.jl","title":"Trixi.SemidiscretizationEulerAcoustics","text":"SemidiscretizationEulerAcoustics(semi_acoustics::SemiAcoustics, semi_euler::SemiEuler;\n source_region=x->true, weights=x->1.0)\n\nwarning: Experimental code\nThis semidiscretization is experimental and may change in any future release.\n\nConstruct a semidiscretization of the acoustic perturbation equations that is coupled with the compressible Euler equations via source terms for the perturbed velocity. Both semidiscretizations have to use the same mesh and solvers with a shared basis. The coupling region is described by a function source_region that maps the coordinates of a single node to true or false depending on whether the point lies within the coupling region or not. A weighting function weights that maps coordinates to weights is applied to the acoustic source terms. Note that this semidiscretization should be used in conjunction with EulerAcousticsCouplingCallback and only works in two dimensions.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationEulerGravity","page":"Trixi.jl","title":"Trixi.SemidiscretizationEulerGravity","text":"SemidiscretizationEulerGravity\n\nA struct containing everything needed to describe a spatial semidiscretization of a the compressible Euler equations with self-gravity, reformulating the Poisson equation for the gravitational potential as steady-state problem of the hyperblic diffusion equations.\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) \"A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics\" arXiv: 2008.10593\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationEulerGravity-Union{Tuple{SemiGravity}, Tuple{SemiEuler}, Tuple{Mesh}, Tuple{SemiEuler, SemiGravity, Any}} where {Mesh, SemiEuler<:(SemidiscretizationHyperbolic{Mesh, <:Trixi.AbstractCompressibleEulerEquations}), SemiGravity<:(SemidiscretizationHyperbolic{Mesh, <:Trixi.AbstractHyperbolicDiffusionEquations})}","page":"Trixi.jl","title":"Trixi.SemidiscretizationEulerGravity","text":"SemidiscretizationEulerGravity(semi_euler::SemiEuler, semi_gravity::SemiGravity, parameters)\n\nConstruct a semidiscretization of the compressible Euler equations with self-gravity. parameters should be given as ParametersEulerGravity.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.SemidiscretizationHyperbolic","page":"Trixi.jl","title":"Trixi.SemidiscretizationHyperbolic","text":"SemidiscretizationHyperbolic\n\nA struct containing everything needed to describe a spatial semidiscretization of a hyperbolic conservation law.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationHyperbolic-NTuple{4, Any}","page":"Trixi.jl","title":"Trixi.SemidiscretizationHyperbolic","text":"SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver;\n source_terms=nothing,\n boundary_conditions=boundary_condition_periodic,\n RealT=real(solver),\n uEltype=RealT,\n initial_cache=NamedTuple())\n\nConstruct a semidiscretization of a hyperbolic PDE.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.SemidiscretizationHyperbolicParabolic","page":"Trixi.jl","title":"Trixi.SemidiscretizationHyperbolicParabolic","text":"SemidiscretizationHyperbolicParabolic\n\nA struct containing everything needed to describe a spatial semidiscretization of a mixed hyperbolic-parabolic conservation law.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SemidiscretizationHyperbolicParabolic-Tuple{Any, Tuple, Any, Any}","page":"Trixi.jl","title":"Trixi.SemidiscretizationHyperbolicParabolic","text":"SemidiscretizationHyperbolicParabolic(mesh, both_equations, initial_condition, solver;\n solver_parabolic=default_parabolic_solver(),\n source_terms=nothing,\n both_boundary_conditions=(boundary_condition_periodic, boundary_condition_periodic),\n RealT=real(solver),\n uEltype=RealT,\n both_initial_caches=(NamedTuple(), NamedTuple()))\n\nConstruct a semidiscretization of a hyperbolic-parabolic PDE.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ShallowWaterEquations1D","page":"Trixi.jl","title":"Trixi.ShallowWaterEquations1D","text":"ShallowWaterEquations1D(; gravity, H0 = 0, threshold_limiter = nothing threshold_wet = nothing)\n\nShallow water equations (SWE) in one space dimension. The equations are given by\n\nbeginaligned\n fracpartial hpartial t + fracpartialpartial x(h v) = 0 \n fracpartialpartial t(h v) + fracpartialpartial xleft(h v^2 + fracg2h^2right)\n + g h fracpartial bpartial x = 0\nendaligned\n\nThe unknown quantities of the SWE are the water height h and the velocity v. The gravitational constant is denoted by g and the (possibly) variable bottom topography function b(x). Conservative variable water height h is measured from the bottom topography b, therefore one also defines the total water height as H = h + b.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nAlso, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is \"wet\" before calculating the numerical flux.\n\nThe bottom topography function b(x) is set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero.\n\nIn addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi.jl's visualization tools will visualize the bottom topography by default.\n\nReferences for the SWE are many but a good introduction is available in Chapter 13 of the book:\n\nRandall J. LeVeque (2002) Finite Volume Methods for Hyperbolic Problems DOI: 10.1017/CBO9780511791253\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ShallowWaterEquations2D","page":"Trixi.jl","title":"Trixi.ShallowWaterEquations2D","text":"ShallowWaterEquations2D(; gravity, H0 = 0, threshold_limiter = nothing, threshold_wet = nothing)\n\nShallow water equations (SWE) in two space dimensions. The equations are given by\n\nbeginaligned\n fracpartial hpartial t + fracpartialpartial x(h v_1)\n + fracpartialpartial y(h v_2) = 0 \n fracpartialpartial t(h v_1) + fracpartialpartial xleft(h v_1^2 + fracg2h^2right)\n + fracpartialpartial y(h v_1 v_2) + g h fracpartial bpartial x = 0 \n fracpartialpartial t(h v_2) + fracpartialpartial x(h v_1 v_2)\n + fracpartialpartial yleft(h v_2^2 + fracg2h^2right) + g h fracpartial bpartial y = 0\nendaligned\n\nThe unknown quantities of the SWE are the water height h and the velocities mathbfv = (v_1 v_2)^T. The gravitational constant is denoted by g and the (possibly) variable bottom topography function b(xy). Conservative variable water height h is measured from the bottom topography b, therefore one also defines the total water height as H = h + b.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nAlso, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is \"wet\" before calculating the numerical flux.\n\nThe bottom topography function b(xy) is set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero.\n\nIn addition to the unknowns, Trixi.jl currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi.jl's visualization tools will visualize the bottom topography by default.\n\nReferences for the SWE are many but a good introduction is available in Chapter 13 of the book:\n\nRandall J. LeVeque (2002) Finite Volume Methods for Hyperbolic Problems DOI: 10.1017/CBO9780511791253\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ShallowWaterEquationsQuasi1D","page":"Trixi.jl","title":"Trixi.ShallowWaterEquationsQuasi1D","text":"ShallowWaterEquationsQuasi1D(; gravity, H0 = 0, threshold_limiter = nothing threshold_wet = nothing)\n\nThe quasi-1D shallow water equations (SWE). The equations are given by\n\nbeginaligned\n fracpartialpartial t(a h) + fracpartialpartial x(a h v) = 0 \n fracpartialpartial t(a h v) + fracpartialpartial x(a h v^2)\n + g a h fracpartialpartial x(h + b) = 0\nendaligned\n\nThe unknown quantities of the Quasi-1D SWE are the water height h and the scaled velocity v. The gravitational constant is denoted by g, the (possibly) variable bottom topography function b(x), and (possibly) variable channel width a(x). The water height h is measured from the bottom topography b, therefore one also defines the total water height as H = h + b.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nAlso, there are two thresholds which prevent numerical problems as well as instabilities. Both of them do not have to be passed, as default values are defined within the struct. The first one, threshold_limiter, is used in PositivityPreservingLimiterShallowWater on the water height, as a (small) shift on the initial condition and cutoff before the next time step. The second one, threshold_wet, is applied on the water height to define when the flow is \"wet\" before calculating the numerical flux.\n\nThe bottom topography function b(x) and channel width a(x) are set inside the initial condition routine for a particular problem setup. To test the conservative form of the SWE one can set the bottom topography variable b to zero and a to one. \n\nIn addition to the unknowns, Trixi.jl currently stores the bottom topography and channel width values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography and channel width must be zero.\nThe bottom topography and channel width values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi.jl's visualization tools will visualize the bottom topography and channel width by default.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ShallowWaterTwoLayerEquations1D","page":"Trixi.jl","title":"Trixi.ShallowWaterTwoLayerEquations1D","text":"ShallowWaterTwoLayerEquations1D(gravity, H0, rho_upper, rho_lower)\n\nTwo-Layer Shallow Water equations (2LSWE) in one space dimension. The equations are given by\n\nbeginalignat*4\nfracpartialpartial th_upper\n+ fracpartialpartial xleft(h_upper v_1upperright)\n= 0 \nfracpartialpartial tleft(h_upperv_1upperright)\n+ fracpartialpartial xleft(h_upperv_1upper^2 + dfracgh_upper^22right)\n= -gh_upperfracpartialpartial xleft(b+h_lowerright)\nfracpartialpartial th_lower\n+ fracpartialpartial xleft(h_lowerv_1lowerright)\n= 0 \nfracpartialpartial tleft(h_lowerv_1lowerright)\n+ fracpartialpartial xleft(h_lowerv_1lower^2 + dfracgh_lower^22right)\n= -gh_lowerfracpartialpartial xleft(b+dfracrho_upperrho_lowerh_upperright)\nendalignat*\n\nThe unknown quantities of the 2LSWE are the water heights of the {lower} layer h_lower and the {upper} layer h_upper with respective velocities v_1upper and v_1lower. The gravitational constant is denoted by g, the layer densitites by rho_upperand rho_lower and the (possibly) variable bottom topography function b(x). The conservative variable water height h_lower is measured from the bottom topography b and h_upper relative to h_lower, therefore one also defines the total water heights as H_upper = h_upper + h_upper + b and H_lower = h_lower + b.\n\nThe densities must be chosen such that rho_upper rho_lower, to make sure that the heavier fluid rho_lower is in the bottom layer and the lighter fluid rho_upper in the {upper} layer.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nThe bottom topography function b(x) is set inside the initial condition routine for a particular problem setup.\n\nIn addition to the unknowns, Trixi currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi's visualization tools will visualize the bottom topography by default.\n\nA good introduction for the 2LSWE is available in Chapter 12 of the book:\n\nBenoit Cushman-Roisin (2011)\nIntroduction to geophyiscal fluid dynamics: physical and numerical aspects\nhttps://www.sciencedirect.com/bookseries/international-geophysics/vol/101/suppl/C\nISBN: 978-0-12-088759-0\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ShallowWaterTwoLayerEquations2D","page":"Trixi.jl","title":"Trixi.ShallowWaterTwoLayerEquations2D","text":"ShallowWaterTwoLayerEquations2D(gravity, H0, rho_upper, rho_lower)\n\nTwo-Layer Shallow water equations (2LSWE) in two space dimension. The equations are given by\n\nbeginalignat*8\nfracpartialpartial th_upper\n+ fracpartialpartial xleft(h_upper v_1upperright)\n+ fracpartialpartial yleft(h_upper v_2upperright) quad\n= quad 0 \nfracpartialpartial tleft(h_upper v_1upperright)\n+ fracpartialpartial xleft(h_upper v_1upper^2 + fracgh_upper^22right)\n+ fracpartialpartial yleft(h_upper v_1upper v_2upperright) quad\n= -gh_upperfracpartialpartial xleft(b+h_lowerright) \nfracpartialpartial tleft(h_upper v_2upperright)\n+ fracpartialpartial xleft(h_upper v_1upper v_2upperright)\n+ fracpartialpartial yleft(h_upper v_2upper^2 + fracgh_upper^22right)\n= -gh_upperfracpartialpartial yleft(b+h_lowerright)\nfracpartialpartial th_lower\n+ fracpartialpartial xleft(h_lower v_1lowerright)\n+ fracpartialpartial yleft(h_lower v_2lowerright)\n= quad 0 \nfracpartialpartial tleft(h_lower v_1lowerright)\n+ fracpartialpartial xleft(h_lower v_1lower^2 + fracgh_lower^22right)\n+ fracpartialpartial yleft(h_lower v_1lower v_2lowerright)\n= -gh_lowerfracpartialpartial xleft(b+fracrho_upperrho_lower h_upperright)\nfracpartialpartial tleft(h_lower v_2lowerright)\n+ fracpartialpartial xleft(h_lower v_1lower v_2lowerright)\n+ fracpartialpartial yleft(h_lower v_2lower^2 + fracgh_lower^22right)\n= -gh_lowerfracpartialpartial yleft(b+fracrho_upperrho_lower h_upperright)\nendalignat*\n\nThe unknown quantities of the 2LSWE are the water heights of the lower layer h_lower and the upper layer h_upper and the respective velocities in x-direction v_1lower and v_1upper and in y-direction v_2lower and v_2upper. The gravitational constant is denoted by g, the layer densitites by rho_upperand rho_lower and the (possibly) variable bottom topography function by b(x). Conservative variable water height h_lower is measured from the bottom topography b and h_upper relative to h_lower, therefore one also defines the total water heights as H_lower = h_lower + b and H_upper = h_upper + h_lower + b.\n\nThe densities must be chosen such that rho_upper rho_lower, to make sure that the heavier fluid rho_lower is in the bottom layer and the lighter fluid rho_upper in the upper layer.\n\nThe additional quantity H_0 is also available to store a reference value for the total water height that is useful to set initial conditions or test the \"lake-at-rest\" well-balancedness.\n\nThe bottom topography function b(x) is set inside the initial condition routine for a particular problem setup.\n\nIn addition to the unknowns, Trixi currently stores the bottom topography values at the approximation points despite being fixed in time. This is done for convenience of computing the bottom topography gradients on the fly during the approximation as well as computing auxiliary quantities like the total water height H or the entropy variables. This affects the implementation and use of these equations in various ways:\n\nThe flux values corresponding to the bottom topography must be zero.\nThe bottom topography values must be included when defining initial conditions, boundary conditions or source terms.\nAnalysisCallback analyzes this variable.\nTrixi's visualization tools will visualize the bottom topography by default.\n\nA good introduction for the 2LSWE is available in Chapter 12 of the book:\n\nBenoit Cushman-Roisin (2011)\nIntroduction to geophyiscal fluid dynamics: physical and numerical aspects\nhttps://www.sciencedirect.com/bookseries/international-geophysics/vol/101/suppl/C\nISBN: 978-0-12-088759-0\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SimpleSSPRK33","page":"Trixi.jl","title":"Trixi.SimpleSSPRK33","text":"SimpleSSPRK33(; stage_callbacks=())\n\nThe third-order SSP Runge-Kutta method of Shu and Osher.\n\nReferences\n\nShu, Osher (1988) \"Efficient Implementation of Essentially Non-oscillatory Shock-Capturing Schemes\" (Eq. 2.18) DOI: 10.1016/0021-9991(88)90177-5\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SteadyStateCallback","page":"Trixi.jl","title":"Trixi.SteadyStateCallback","text":"SteadyStateCallback(; abstol=1.0e-8, reltol=1.0e-6)\n\nTerminates the integration when the residual_steady_state(du, equations) falls below the threshold specified by abstol, reltol.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.StepsizeCallback","page":"Trixi.jl","title":"Trixi.StepsizeCallback","text":"StepsizeCallback(; cfl=1.0)\n\nSet the time step size according to a CFL condition with CFL number cfl if the time integration method isn't adaptive itself.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.StructuredMesh","page":"Trixi.jl","title":"Trixi.StructuredMesh","text":"StructuredMesh{NDIMS} <: AbstractMesh{NDIMS}\n\nA structured curved mesh.\n\nDifferent numbers of cells per dimension are possible and arbitrary functions can be used as domain faces.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.StructuredMesh-Tuple{Any, Any, Any}","page":"Trixi.jl","title":"Trixi.StructuredMesh","text":"StructuredMesh(cells_per_dimension, coordinates_min, coordinates_max; periodicity=true)\n\nCreate a StructuredMesh that represents a uncurved structured mesh with a rectangular domain.\n\nArguments\n\ncells_per_dimension::NTuple{NDIMS, Int}: the number of cells in each dimension.\ncoordinates_min::NTuple{NDIMS, RealT}: coordinate of the corner in the negative direction of each dimension.\ncoordinates_max::NTuple{NDIMS, RealT}: coordinate of the corner in the positive direction of each dimension.\nperiodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.StructuredMesh-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.StructuredMesh","text":"StructuredMesh(cells_per_dimension, mapping; RealT=Float64, unsaved_changes=true, mapping_as_string=mapping2string(mapping, length(cells_per_dimension)))\n\nCreate a StructuredMesh of the given size and shape that uses RealT as coordinate type.\n\nArguments\n\ncells_per_dimension::NTupleE{NDIMS, Int}: the number of cells in each dimension.\nmapping: a function of NDIMS variables to describe the mapping, which transforms the reference mesh to the physical domain. If no mapping_as_string is defined, this function must be defined with the name mapping to allow for restarts. This will be changed in the future, see https://github.com/trixi-framework/Trixi.jl/issues/541.\nRealT::Type: the type that should be used for coordinates.\nperiodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\nmapping_as_string::String: the code that defines the mapping. If CodeTracking can't find the function definition, it can be passed directly here. The code string must define the mapping function with the name mapping. This will be changed in the future, see https://github.com/trixi-framework/Trixi.jl/issues/541.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.StructuredMesh-Tuple{Any, Tuple}","page":"Trixi.jl","title":"Trixi.StructuredMesh","text":"StructuredMesh(cells_per_dimension, faces; RealT=Float64, unsaved_changes=true, faces_as_string=faces2string(faces))\n\nCreate a StructuredMesh of the given size and shape that uses RealT as coordinate type.\n\nArguments\n\ncells_per_dimension::NTupleE{NDIMS, Int}: the number of cells in each dimension.\nfaces::NTuple{2*NDIMS}: a tuple of 2 * NDIMS functions that describe the faces of the domain. Each function must take NDIMS-1 arguments. faces[1] describes the face onto which the face in negative x-direction of the unit hypercube is mapped. The face in positive x-direction of the unit hypercube will be mapped onto the face described by faces[2]. faces[3:4] describe the faces in positive and negative y-direction respectively (in 2D and 3D). faces[5:6] describe the faces in positive and negative z-direction respectively (in 3D).\nRealT::Type: the type that should be used for coordinates.\nperiodicity: either a Bool deciding if all of the boundaries are periodic or an NTuple{NDIMS, Bool} deciding for each dimension if the boundaries in this dimension are periodic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.SubcellLimiterIDP","page":"Trixi.jl","title":"Trixi.SubcellLimiterIDP","text":"SubcellLimiterIDP(equations::AbstractEquations, basis;\n positivity_variables_cons = [],\n positivity_correction_factor = 0.1)\n\nSubcell invariant domain preserving (IDP) limiting used with VolumeIntegralSubcellLimiting including:\n\npositivity limiting for conservative variables (positivity_variables_cons)\n\nThe bounds are calculated using the low-order FV solution. The positivity limiter uses positivity_correction_factor such that u^new >= positivity_correction_factor * u^FV.\n\nnote: Note\nThis limiter and the correction callback SubcellLimiterIDPCorrection only work together. Without the callback, no correction takes place, leading to a standard low-order FV scheme.\n\nReferences\n\nRueda-Ramírez, Pazner, Gassner (2022) Subcell Limiting Strategies for Discontinuous Galerkin Spectral Element Methods DOI: 10.1016/j.compfluid.2022.105627\nPazner (2020) Sparse invariant domain preserving discontinuous Galerkin methods with subcell convex limiting DOI: 10.1016/j.cma.2021.113876\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SubcellLimiterIDPCorrection","page":"Trixi.jl","title":"Trixi.SubcellLimiterIDPCorrection","text":"SubcellLimiterIDPCorrection()\n\nPerform antidiffusive correction stage for the a posteriori IDP limiter SubcellLimiterIDP called with VolumeIntegralSubcellLimiting.\n\nnote: Note\nThis callback and the actual limiter SubcellLimiterIDP only work together. This is not a replacement but a necessary addition.\n\nReferences\n\nRueda-Ramírez, Pazner, Gassner (2022) Subcell Limiting Strategies for Discontinuous Galerkin Spectral Element Methods DOI: 10.1016/j.compfluid.2022.105627\nPazner (2020) Sparse invariant domain preserving discontinuous Galerkin methods with subcell convex limiting DOI: 10.1016/j.cma.2021.113876\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SurfaceIntegralStrongForm","page":"Trixi.jl","title":"Trixi.SurfaceIntegralStrongForm","text":"SurfaceIntegralStrongForm(surface_flux=flux_central)\n\nThe classical strong form surface integral type for FD/DG methods.\n\nSee also VolumeIntegralStrongForm.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SurfaceIntegralUpwind","page":"Trixi.jl","title":"Trixi.SurfaceIntegralUpwind","text":"SurfaceIntegralUpwind(splitting)\n\nCouple elements with upwind simultaneous approximation terms (SATs) that use a particular flux splitting, e.g., splitting_steger_warming.\n\nSee also VolumeIntegralUpwind.\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.SurfaceIntegralWeakForm","page":"Trixi.jl","title":"Trixi.SurfaceIntegralWeakForm","text":"SurfaceIntegralWeakForm(surface_flux=flux_central)\n\nThe classical weak form surface integral type for DG methods as explained in standard textbooks.\n\nSee also VolumeIntegralWeakForm.\n\nReferences\n\nKopriva (2009) Implementing Spectral Methods for Partial Differential Equations: Algorithms for Scientists and Engineers doi: 10.1007/978-90-481-2261-5\nHesthaven, Warburton (2007) Nodal Discontinuous Galerkin Methods: Algorithms, Analysis, and Applications doi: 10.1007/978-0-387-72067-8\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.T8codeMesh","page":"Trixi.jl","title":"Trixi.T8codeMesh","text":"T8codeMesh{NDIMS} <: AbstractMesh{NDIMS}\n\nAn unstructured curved mesh based on trees that uses the C library 't8code' to manage trees and mesh refinement.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.T8codeMesh-Tuple{Any}","page":"Trixi.jl","title":"Trixi.T8codeMesh","text":"T8codeMesh(trees_per_dimension; polydeg, mapping=identity,\n RealT=Float64, initial_refinement_level=0, periodicity=true)\n\nCreate a structured potentially curved 'T8codeMesh' of the specified size.\n\nNon-periodic boundaries will be called ':xneg', ':xpos', ':yneg', ':ypos', ':zneg', ':zpos'.\n\nArguments\n\n'treesperdimension::NTupleE{NDIMS, Int}': the number of trees in each dimension.\n'polydeg::Integer': polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\n'mapping': a function of 'NDIMS' variables to describe the mapping that transforms the reference mesh ('[-1, 1]^n') to the physical domain.\n'RealT::Type': the type that should be used for coordinates.\n'initialrefinementlevel::Integer': refine the mesh uniformly to this level before the simulation starts.\n'periodicity': either a 'Bool' deciding if all of the boundaries are periodic or an 'NTuple{NDIMS, Bool}' deciding for each dimension if the boundaries in this dimension are periodic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.T8codeMesh-Union{Tuple{Ptr{P4est.LibP4est.p4est_connectivity}}, Tuple{NDIMS}} where NDIMS","page":"Trixi.jl","title":"Trixi.T8codeMesh","text":"T8codeMesh{NDIMS}(conn::Ptr{p4est_connectivity},\n mapping=nothing, polydeg=1, RealT=Float64,\n initial_refinement_level=0)\n\nMain mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a p4est_connectivity data structure.\n\nArguments\n\nconn::Ptr{p4est_connectivity}: Pointer to a P4est connectivity object.\nmapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.T8codeMesh-Union{Tuple{Ptr{T8code.Libt8.t8_cmesh}}, Tuple{NDIMS}} where NDIMS","page":"Trixi.jl","title":"Trixi.T8codeMesh","text":"T8codeMesh{NDIMS}(cmesh::Ptr{t8_cmesh},\n mapping=nothing, polydeg=1, RealT=Float64,\n initial_refinement_level=0)\n\nMain mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a t8_cmesh data structure.\n\nArguments\n\ncmesh::Ptr{t8_cmesh}: Pointer to a cmesh object.\nmapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.T8codeMesh-Union{Tuple{String}, Tuple{NDIMS}} where NDIMS","page":"Trixi.jl","title":"Trixi.T8codeMesh","text":"T8codeMesh{NDIMS}(meshfile::String;\n mapping=nothing, polydeg=1, RealT=Float64,\n initial_refinement_level=0)\n\nMain mesh constructor for the T8codeMesh that imports an unstructured, conforming mesh from a Gmsh mesh file (.msh).\n\nArguments\n\nmeshfile::String: path to a Gmsh mesh file.\nmapping: a function of NDIMS variables to describe the mapping that transforms the imported mesh to the physical domain. Use nothing for the identity map.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree. The default of 1 creates an uncurved geometry. Use a higher value if the mapping will curve the imported uncurved mesh.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.TimeSeriesCallback","page":"Trixi.jl","title":"Trixi.TimeSeriesCallback","text":"TimeSeriesCallback(semi, point_coordinates;\n interval=1, solution_variables=cons2cons,\n output_directory=\"out\", filename=\"time_series.h5\",\n RealT=real(solver), uEltype=eltype(cache.elements))\n\nCreate a callback that records point-wise data at points given in point_coordinates every interval time steps. The point coordinates are to be specified either as a vector of coordinate tuples or as a two-dimensional array where the first dimension is the point number and the second dimension is the coordinate dimension. By default, the conservative variables are recorded, but this can be controlled by passing a different conversion function to solution_variables.\n\nAfter the last time step, the results are stored in an HDF5 file filename in directory output_directory.\n\nThe real data type RealT and data type for solution variables uEltype default to the respective types used in the solver and the cache.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.TreeMesh","page":"Trixi.jl","title":"Trixi.TreeMesh","text":"TreeMesh{NDIMS} <: AbstractMesh{NDIMS}\n\nA Cartesian mesh based on trees of hypercubes to support adaptive mesh refinement.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.UnstructuredMesh2D","page":"Trixi.jl","title":"Trixi.UnstructuredMesh2D","text":"UnstructuredMesh2D <: AbstractMesh{2}\n\nAn unstructured (possibly curved) quadrilateral mesh.\n\nUnstructuredMesh2D(filename; RealT=Float64, periodicity=false)\n\nAll mesh information, neighbour coupling, and boundary curve information is read in from a mesh file filename.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.UnstructuredSortedBoundaryTypes","page":"Trixi.jl","title":"Trixi.UnstructuredSortedBoundaryTypes","text":"UnstructuredSortedBoundaryTypes\n\nGeneral container to sort the boundary conditions by type for some unstructured meshes/solvers. It stores a set of global indices for each boundary condition type to expedite computation during the call to calc_boundary_flux!. The original dictionary form of the boundary conditions set by the user in the elixir file is also stored for printing.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ViscousFormulationBassiRebay1","page":"Trixi.jl","title":"Trixi.ViscousFormulationBassiRebay1","text":"ViscousFormulationBassiRebay1()\n\nThe classical BR1 flux from\n\nF. Bassi, S. Rebay (1997) A High-Order Accurate Discontinuous Finite Element Method for the Numerical Solution of the Compressible Navier-Stokes Equations DOI: 10.1006/jcph.1996.5572\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.ViscousFormulationLocalDG","page":"Trixi.jl","title":"Trixi.ViscousFormulationLocalDG","text":"ViscousFormulationLocalDG(penalty_parameter)\n\nThe local DG (LDG) flux from \"The Local Discontinuous Galerkin Method for Time-Dependent Convection-Diffusion Systems\" by Cockburn and Shu (1998).\n\nNote that, since this implementation does not involve the parabolic \"upwinding\" vector, the LDG solver is equivalent to ViscousFormulationBassiRebay1 with an LDG-type penalization.\n\nCockburn and Shu (1998). The Local Discontinuous Galerkin Method for Time-Dependent Convection-Diffusion Systems DOI: 10.1137/S0036142997316712\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VisualizationCallback-Tuple{}","page":"Trixi.jl","title":"Trixi.VisualizationCallback","text":"VisualizationCallback(; interval=0,\n solution_variables=cons2prim,\n variable_names=[],\n show_mesh=false,\n plot_data_creator=PlotData2D,\n plot_creator=show_plot,\n plot_arguments...)\n\nCreate a callback that visualizes results during a simulation, also known as in-situ visualization.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in any future releases.\n\nThe interval specifies the number of time step iterations after which a new plot is generated. The available variables to plot are configured with the solution_variables parameter, which acts the same way as for the SaveSolutionCallback. The variables to be actually plotted can be selected by providing a single string or a list of strings to variable_names, and if show_mesh is true, an additional plot with the mesh will be generated.\n\nTo customize the generated figure, plot_data_creator allows to use different plot data types. With plot_creator you can further specify an own function to visualize results, which must support the same interface as the default implementation show_plot. All remaining keyword arguments are collected and passed as additional arguments to the plotting command.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.VolumeIntegralFluxDifferencing","page":"Trixi.jl","title":"Trixi.VolumeIntegralFluxDifferencing","text":"VolumeIntegralFluxDifferencing(volume_flux)\n\nVolume integral type for DG methods based on SBP operators and flux differencing using a symmetric two-point volume_flux. This volume_flux needs to satisfy the interface of numerical fluxes in Trixi.jl.\n\nReferences\n\nLeFloch, Mercier, Rohde (2002) Fully Discrete, Entropy Conservative Schemes of Arbitrary Order doi: 10.1137/S003614290240069X\nFisher, Carpenter (2013) High-order entropy stable finite difference schemes for nonlinear conservation laws: Finite domains doi: 10.1016/j.jcp.2013.06.014\nHendrik Ranocha (2017) Comparison of Some Entropy Conservative Numerical Fluxes for the Euler Equations arXiv: 1701.02264 doi: 10.1007/s10915-017-0618-1\nChen, Shu (2017) Entropy stable high order discontinuous Galerkin methods with suitable quadrature rules for hyperbolic conservation laws doi: 10.1016/j.jcp.2017.05.025\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralPureLGLFiniteVolume","page":"Trixi.jl","title":"Trixi.VolumeIntegralPureLGLFiniteVolume","text":"VolumeIntegralPureLGLFiniteVolume(volume_flux_fv)\n\nA volume integral that only uses the subcell finite volume schemes of the VolumeIntegralShockCapturingHG.\n\nThis gives a formally O(1)-accurate finite volume scheme on an LGL-type subcell mesh (LGL = Legendre-Gauss-Lobatto).\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nHennemann, Gassner (2020) \"A provably entropy stable subcell shock capturing approach for high order split form DG\" arXiv: 2008.12044\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralShockCapturingHG","page":"Trixi.jl","title":"Trixi.VolumeIntegralShockCapturingHG","text":"VolumeIntegralShockCapturingHG(indicator; volume_flux_dg=flux_central,\n volume_flux_fv=flux_lax_friedrichs)\n\nShock-capturing volume integral type for DG methods using a convex blending of the finite volume method with numerical flux volume_flux_fv and the VolumeIntegralFluxDifferencing with volume flux volume_flux_dg. The amount of blending is determined by the indicator, e.g., IndicatorHennemannGassner.\n\nReferences\n\nHennemann, Gassner (2020) \"A provably entropy stable subcell shock capturing approach for high order split form DG\" arXiv: 2008.12044\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralStrongForm","page":"Trixi.jl","title":"Trixi.VolumeIntegralStrongForm","text":"VolumeIntegralStrongForm()\n\nThe classical strong form volume integral type for FD/DG methods.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralSubcellLimiting","page":"Trixi.jl","title":"Trixi.VolumeIntegralSubcellLimiting","text":"VolumeIntegralSubcellLimiting(limiter;\n volume_flux_dg, volume_flux_fv)\n\nA subcell limiting volume integral type for DG methods based on subcell blending approaches with a low-order FV method. Used with limiter SubcellLimiterIDP.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralUpwind","page":"Trixi.jl","title":"Trixi.VolumeIntegralUpwind","text":"VolumeIntegralUpwind(splitting)\n\nSpecialized volume integral for finite difference summation-by-parts (FDSBP) solvers. Can be used together with the upwind SBP operators of Mattsson (2017) implemented in SummationByPartsOperators.jl. The splitting controls the discretization.\n\nSee also splitting_steger_warming, splitting_lax_friedrichs, splitting_vanleer_haenel.\n\nReferences\n\nMattsson (2017) Diagonal-norm upwind SBP operators doi: 10.1016/j.jcp.2017.01.042\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Trixi.VolumeIntegralWeakForm","page":"Trixi.jl","title":"Trixi.VolumeIntegralWeakForm","text":"VolumeIntegralWeakForm()\n\nThe classical weak form volume integral type for DG methods as explained in standard textbooks.\n\nReferences\n\nKopriva (2009) Implementing Spectral Methods for Partial Differential Equations: Algorithms for Scientists and Engineers doi: 10.1007/978-90-481-2261-5\nHesthaven, Warburton (2007) Nodal Discontinuous Galerkin Methods: Algorithms, Analysis, and Applications doi: 10.1007/978-0-387-72067-8\n\nVolumeIntegralWeakForm() is only implemented for conserved terms as non-conservative terms should always be discretized in conjunction with a flux-splitting scheme, see VolumeIntegralFluxDifferencing. This treatment is required to achieve, e.g., entropy-stability or well-balancedness.\n\n\n\n\n\n","category":"type"},{"location":"reference-trixi/#Base.getindex-Tuple{Trixi.AbstractPlotData, Any}","page":"Trixi.jl","title":"Base.getindex","text":"Base.getindex(pd::AbstractPlotData, variable_name)\n\nExtract a single variable variable_name from pd for plotting with Plots.plot.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Base.resize!-Tuple{Trixi.AbstractContainer, Any}","page":"Trixi.jl","title":"Base.resize!","text":"resize!(c::AbstractContainer, new_length) -> AbstractContainer\n\nResize c to contain new_length elements. If new_length is smaller than the current container length, the first new_length elements will be retained. If new_length is larger, the new elements are invalidated.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#PolynomialBases.compute_coefficients!-Tuple{Any, Any, Any, Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"PolynomialBases.compute_coefficients!","text":"compute_coefficients!(u_ode, func, t, semi::AbstractSemidiscretization)\n\nSame as compute_coefficients but stores the result in u_ode.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#PolynomialBases.compute_coefficients-Tuple{Any, Any, Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"PolynomialBases.compute_coefficients","text":"compute_coefficients(func, t, semi::AbstractSemidiscretization)\n\nCompute the discrete coefficients of the continuous function func at time t associated with the semidiscretization semi. For example, the discrete coefficients of func for a discontinuous Galerkin spectral element method (DGSEM) are the values of func at the Lobatto-Legendre nodes. Similarly, a classical finite difference method will use the values of func at the nodes of the grid assoociated with the semidiscretization semi.\n\nFor semidiscretizations semi associated with an initial condition, func can be omitted to use the given initial condition at time t.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#PolynomialBases.integrate-Tuple{Any, Any, LobattoLegendreBasis}","page":"Trixi.jl","title":"PolynomialBases.integrate","text":"integrate(f, u, basis::LobattoLegendreBasis)\n\nMap the function f to the coefficients u and integrate with respect to the quadrature rule given by basis.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#PolynomialBases.integrate-Union{Tuple{Func}, Tuple{Func, Any, Trixi.AbstractSemidiscretization}} where Func","page":"Trixi.jl","title":"PolynomialBases.integrate","text":"integrate([func=(u_node,equations)->u_node,] u_ode, semi::AbstractSemidiscretization; normalize=true)\n\nCall func(u_node, equations) for each vector of nodal variables u_node in u_ode and integrate the result using a quadrature associated with the semidiscretization semi.\n\nIf normalize is true, the result is divided by the total volume of the computational domain.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#SummationByPartsOperators.semidiscretize-Tuple{SemidiscretizationHyperbolicParabolic, Any}","page":"Trixi.jl","title":"SummationByPartsOperators.semidiscretize","text":"semidiscretize(semi::SemidiscretizationHyperbolicParabolic, tspan)\n\nWrap the semidiscretization semi as a split ODE problem in the time interval tspan that can be passed to solve from the SciML ecosystem. The parabolic right-hand side is the first function of the split ODE problem and will be used by default by the implicit part of IMEX methods from the SciML ecosystem.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#SummationByPartsOperators.semidiscretize-Tuple{Trixi.AbstractSemidiscretization, Any, AbstractString}","page":"Trixi.jl","title":"SummationByPartsOperators.semidiscretize","text":"semidiscretize(semi::AbstractSemidiscretization, tspan, restart_file::AbstractString)\n\nWrap the semidiscretization semi as an ODE problem in the time interval tspan that can be passed to solve from the SciML ecosystem. The initial condition etc. is taken from the restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#SummationByPartsOperators.semidiscretize-Tuple{Trixi.AbstractSemidiscretization, Any}","page":"Trixi.jl","title":"SummationByPartsOperators.semidiscretize","text":"semidiscretize(semi::AbstractSemidiscretization, tspan)\n\nWrap the semidiscretization semi as an ODE problem in the time interval tspan that can be passed to solve from the SciML ecosystem.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.DGMultiBasis-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.DGMultiBasis","text":"DGMultiBasis(element_type, polydeg; approximation_type = Polynomial(), kwargs...)\n\nConstructs a basis for DGMulti solvers. Returns a \"StartUpDG.RefElemData\" object. The kwargs arguments are additional keyword arguments for RefElemData, such as quad_rule_vol. These are the same as the RefElemData_kwargs used in DGMulti. For more info, see the StartUpDG.jl docs.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.LBMCollisionCallback-Tuple{}","page":"Trixi.jl","title":"Trixi.LBMCollisionCallback","text":"LBMCollisionCallback()\n\nApply the Lattice-Boltzmann method (LBM) collision operator before each time step. See LatticeBoltzmannEquations2D for further details.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.P4estMeshCubedSphere-NTuple{4, Any}","page":"Trixi.jl","title":"Trixi.P4estMeshCubedSphere","text":"P4estMeshCubedSphere(trees_per_face_dimension, layers, inner_radius, thickness;\n polydeg, RealT=Float64,\n initial_refinement_level=0, unsaved_changes=true,\n p4est_partition_allow_for_coarsening=true)\n\nBuild a \"Cubed Sphere\" mesh as P4estMesh with 6 * trees_per_face_dimension^2 * layers trees.\n\nThe mesh will have two boundaries, :inside and :outside.\n\nArguments\n\ntrees_per_face_dimension::Integer: the number of trees in the first two local dimensions of each face.\nlayers::Integer: the number of trees in the third local dimension of each face, i.e., the number of layers of the sphere.\ninner_radius::Integer: the inner radius of the sphere.\nthickness::Integer: the thickness of the sphere. The outer radius will be inner_radius + thickness.\npolydeg::Integer: polynomial degree used to store the geometry of the mesh. The mapping will be approximated by an interpolation polynomial of the specified degree for each tree.\nRealT::Type: the type that should be used for coordinates.\ninitial_refinement_level::Integer: refine the mesh uniformly to this level before the simulation starts.\nunsaved_changes::Bool: if set to true, the mesh will be saved to a mesh file.\np4est_partition_allow_for_coarsening::Bool: Must be true when using AMR to make mesh adaptivity independent of domain partitioning. Should be false for static meshes to permit more fine-grained partitioning.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.PlotData2D-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.PlotData2D","text":"PlotData2D(u, semi [or mesh, equations, solver, cache];\n solution_variables=nothing,\n grid_lines=true, max_supported_level=11, nvisnodes=nothing,\n slice=:xy, point=(0.0, 0.0, 0.0))\n\nCreate a new PlotData2D object that can be used for visualizing 2D/3D DGSEM solution data array u with Plots.jl. All relevant geometrical information is extracted from the semidiscretization semi. By default, the primitive variables (if existent) or the conservative variables (otherwise) from the solution are used for plotting. This can be changed by passing an appropriate conversion function to solution_variables.\n\nIf grid_lines is true, also extract grid vertices for visualizing the mesh. The output resolution is indirectly set via max_supported_level: all data is interpolated to 2^max_supported_level uniformly distributed points in each spatial direction, also setting the maximum allowed refinement level in the solution. nvisnodes specifies the number of visualization nodes to be used. If it is nothing, twice the number of solution DG nodes are used for visualization, and if set to 0, exactly the number of nodes in the DG elements are used.\n\nWhen visualizing data from a three-dimensional simulation, a 2D slice is extracted for plotting. slice specifies the plane that is being sliced and may be :xy, :xz, or :yz. The slice position is specified by a point that lies on it, which defaults to (0.0, 0.0, 0.0). Both of these values are ignored when visualizing 2D data.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nExamples\n\njulia> using Trixi, Plots\n\njulia> trixi_include(default_example())\n[...]\n\njulia> pd = PlotData2D(sol)\nPlotData2D(...)\n\njulia> plot(pd) # To plot all available variables\n\njulia> plot(pd[\"scalar\"]) # To plot only a single variable\n\njulia> plot!(getmesh(pd)) # To add grid lines to the plot\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.PlotData2D-Tuple{Union{ODESolution{T, N, uType, uType2, DType, tType, rateType, P} where {T, N, uType, uType2, DType, tType, rateType, P<:(ODEProblem{uType_, tType_, isinplace, P_} where {uType_, tType_, isinplace, P_<:Trixi.AbstractSemidiscretization})}, Trixi.TimeIntegratorSolution}}","page":"Trixi.jl","title":"Trixi.PlotData2D","text":"PlotData2D(sol; kwargs...)\n\nCreate a PlotData2D object from a solution object created by either OrdinaryDiffEq.solve! (which returns a SciMLBase.ODESolution) or Trixi.jl's own solve! (which returns a TimeIntegratorSolution).\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ScalarPlotData2D-Tuple{Any, Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"Trixi.ScalarPlotData2D","text":"ScalarPlotData2D(u, semi::AbstractSemidiscretization; kwargs...)\n\nReturns an PlotData2DTriangulated object which is used to visualize a single scalar field. u should be an array whose entries correspond to values of the scalar field at nodal points.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.SummaryCallback","page":"Trixi.jl","title":"Trixi.SummaryCallback","text":"SummaryCallback()\n\nCreate and return a callback that prints a human-readable summary of the simulation setup at the beginning of a simulation and then resets the timer. When the returned callback is executed directly, the current timer values are shown.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.TrivialCallback-Tuple{}","page":"Trixi.jl","title":"Trixi.TrivialCallback","text":"TrivialCallback()\n\nA callback that does nothing. This can be useful to disable some callbacks easily via trixi_include.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.adapt_to_mesh_level!-Tuple{Any, Any, Any}","page":"Trixi.jl","title":"Trixi.adapt_to_mesh_level!","text":"adapt_to_mesh_level!(u_ode, semi, level)\nadapt_to_mesh_level!(sol::Trixi.TrixiODESolution, level)\n\nLike adapt_to_mesh_level, but modifies the solution and parts of the semidiscretization (mesh and caches) in place.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.adapt_to_mesh_level-Tuple{Any, Any, Any}","page":"Trixi.jl","title":"Trixi.adapt_to_mesh_level","text":"adapt_to_mesh_level(u_ode, semi, level)\nadapt_to_mesh_level(sol::Trixi.TrixiODESolution, level)\n\nUse the regular adaptive mesh refinement routines to adaptively refine/coarsen the solution u_ode with semidiscretization semi towards a uniformly refined grid with refinement level level. The solution and semidiscretization are copied such that the original objects remain unaltered.\n\nA convenience method accepts an ODE solution object, from which solution and semidiscretization are extracted as needed.\n\nSee also: adapt_to_mesh_level!\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_linear_x-Tuple{Any, Any, Any, Any, Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.boundary_condition_linear_x","text":"boundary_condition_linear_x(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equation::LinearScalarAdvectionEquation1D)\n\nBoundary conditions for initial_condition_linear_x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_linear_x-Tuple{Any, Any, Any, Any, Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_linear_x","text":"boundary_condition_linear_x(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equation::LinearScalarAdvectionEquation2D)\n\nBoundary conditions for initial_condition_linear_x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_linear_x_y-Tuple{Any, Any, Any, Any, Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_linear_x_y","text":"boundary_condition_linear_x_y(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equation::LinearScalarAdvectionEquation2D)\n\nBoundary conditions for initial_condition_linear_x_y.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_linear_y-Tuple{Any, Any, Any, Any, Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_linear_y","text":"boundary_condition_linear_y(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equation::LinearScalarAdvectionEquation2D)\n\nBoundary conditions for initial_condition_linear_y.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_linear_z-Tuple{Any, Any, Any, Any, Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.boundary_condition_linear_z","text":"boundary_condition_linear_z(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equation::LinearScalarAdvectionEquation1D)\n\nBoundary conditions for boundary_condition_linear_z.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_noslip_wall-Tuple{Any, Any, Any, Any, Any, Any, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_noslip_wall","text":"boundary_condition_noslip_wall(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equations::LatticeBoltzmannEquations2D)\n\nNo-slip wall boundary condition using the bounce-back approach.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_poisson_nonperiodic-Tuple{Any, Any, Any, Any, Any, Any, HyperbolicDiffusionEquations1D}","page":"Trixi.jl","title":"Trixi.boundary_condition_poisson_nonperiodic","text":"boundary_condition_poisson_nonperiodic(u_inner, orientation, direction, x, t,\n surface_flux_function,\n equations::HyperbolicDiffusionEquations1D)\n\nBoundary conditions used for convergence tests in combination with initial_condition_poisson_nonperiodic and source_terms_poisson_nonperiodic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,\n equations::AcousticPerturbationEquations2D)\n\nUse an orthogonal projection of the perturbed velocities to zero out the normal velocity while retaining the possibility of a tangential velocity in the boundary state. Further details are available in the paper:\n\nMarcus Bauer, Jürgen Dierke and Roland Ewert (2011) Application of a discontinuous Galerkin method to discretize acoustic perturbation equations DOI: 10.2514/1.J050333\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, direction, x, t,\n surface_flux_function, equations::CompressibleEulerEquations2D)\n\nShould be used together with StructuredMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, direction, x, t,\n surface_flux_function, equations::CompressibleEulerEquations3D)\n\nShould be used together with StructuredMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,\n equations::CompressibleEulerEquations2D)\n\nDetermine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:\n\nJ. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF\n\nDetails about the 1D pressure Riemann solution can be found in Section 6.3.3 of the book\n\nEleuterio F. Toro (2009) Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction 3rd edition DOI: 10.1007/b79761\n\nShould be used together with UnstructuredMesh2D.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,\n equations::CompressibleEulerEquations3D)\n\nDetermine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:\n\nJ. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF\n\nDetails about the 1D pressure Riemann solution can be found in Section 6.3.3 of the book\n\nEleuterio F. Toro (2009) Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction 3rd edition DOI: 10.1007/b79761\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,\n equations::ShallowWaterEquations2D)\n\nCreate a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value. For details see Section 9.2.5 of the book:\n\nEleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, AbstractVector, Any, Any, Any, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, normal_direction, x, t, surface_flux_function,\n equations::ShallowWaterTwoLayerEquations2D)\n\nCreate a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.\n\nFor details see Section 9.2.5 of the book:\n\nEleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation, direction, x, t,\n surface_flux_function, equations::CompressibleEulerEquations1D)\n\nDetermine the boundary numerical surface flux for a slip wall condition. Imposes a zero normal velocity at the wall. Density is taken from the internal solution state and pressure is computed as an exact solution of a 1D Riemann problem. Further details about this boundary state are available in the paper:\n\nJ. J. W. van der Vegt and H. van der Ven (2002) Slip flow boundary conditions in discontinuous Galerkin discretizations of the Euler equations of gas dynamics PDF\nShould be used together with TreeMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation, direction, x, t,\n surface_flux_function, equations::CompressibleEulerEquations2D)\n\nShould be used together with TreeMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation, direction, x, t,\n surface_flux_function, equations::CompressibleEulerEquations3D)\n\nShould be used together with TreeMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation_or_normal, x, t, surface_flux_function,\n equations::ShallowWaterEquations1D)\n\nCreate a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.\n\nFor details see Section 9.2.5 of the book:\n\nEleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation, direction, x, t,\n surface_flux_function, equations::ShallowWaterEquations2D)\n\nShould be used together with TreeMesh.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_slip_wall-Tuple{Any, Any, Any, Any, Any, Any, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.boundary_condition_slip_wall","text":"boundary_condition_slip_wall(u_inner, orientation_or_normal, x, t, surface_flux_function,\n equations::ShallowWaterTwoLayerEquations1D)\n\nCreate a boundary state by reflecting the normal velocity component and keep the tangential velocity component unchanged. The boundary water height is taken from the internal value.\n\nFor details see Section 9.2.5 of the book:\n\nEleuterio F. Toro (2001) Shock-Capturing Methods for Free-Surface Shallow Flows 1st edition ISBN 0471987662\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_wall-Tuple{Any, Any, Any, Any, Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_wall","text":"boundary_condition_wall(u_inner, orientation, direction, x, t, surface_flux_function,\n equations::AcousticPerturbationEquations2D)\n\nBoundary conditions for a solid wall.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.boundary_condition_wall-Tuple{Any, Any, Any, Any, Any, Any, LinearizedEulerEquations2D}","page":"Trixi.jl","title":"Trixi.boundary_condition_wall","text":"boundary_condition_wall(u_inner, orientation, direction, x, t, surface_flux_function,\n equations::LinearizedEulerEquations2D)\n\nBoundary conditions for a solid wall.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_error_norms-Tuple{Any, Any, Any, Trixi.AbstractSemidiscretization, Any}","page":"Trixi.jl","title":"Trixi.calc_error_norms","text":"calc_error_norms([func=(u_node,equations)->u_node,] u_ode, t, analyzer, semi::AbstractSemidiscretization, cache_analysis)\n\nCalculate discrete L2 and L∞ error norms of func applied to each nodal variable u_node in u_ode. If no exact solution is available, \"errors\" are calculated using some reference state and can be useful for regression tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_fast_wavespeed_roe-Tuple{Any, Any, Any, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.calc_fast_wavespeed_roe","text":"calc_fast_wavespeed_roe(u_ll, u_rr, direction, equations::IdealGlmMhdEquations1D)\n\nCompute the fast magnetoacoustic wave speed using Roe averages as given by\n\nCargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_fast_wavespeed_roe-Tuple{Any, Any, Integer, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.calc_fast_wavespeed_roe","text":"calc_fast_wavespeed_roe(u_ll, u_rr, orientation_or_normal_direction, equations::IdealGlmMhdEquations2D)\n\nCompute the fast magnetoacoustic wave speed using Roe averages as given by\n\nCargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_fast_wavespeed_roe-Tuple{Any, Any, Integer, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.calc_fast_wavespeed_roe","text":"calc_fast_wavespeed_roe(u_ll, u_rr, orientation_or_normal_direction, equations::IdealGlmMhdEquations3D)\n\nCompute the fast magnetoacoustic wave speed using Roe averages as given by\n\nCargo and Gallice (1997) Roe Matrices for Ideal MHD and Systematic Construction of Roe Matrices for Systems of Conservation Laws DOI: 10.1006/jcph.1997.5773\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_wavespeed_roe-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.calc_wavespeed_roe","text":"calc_wavespeed_roe(u_ll, u_rr, direction::Integer,\n equations::ShallowWaterEquations1D)\n\nCalculate Roe-averaged velocity v_roe and wavespeed c_roe = sqrt{g * h_roe} See for instance equation (62) in \n\nPaul A. Ullrich, Christiane Jablonowski, and Bram van Leer (2010) High-order finite-volume methods for the shallow-water equations on the sphere DOI: 10.1016/j.jcp.2010.04.044\n\nOr equation (9.17) in this lecture notes.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.calc_wavespeed_roe-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.calc_wavespeed_roe","text":"calc_wavespeed_roe(u_ll, u_rr, direction::Integer,\n equations::ShallowWaterEquations2D)\n\nCalculate Roe-averaged velocity v_roe and wavespeed c_roe = sqrt{g * h_roe} depending on direction. See for instance equation (62) in \n\nPaul A. Ullrich, Christiane Jablonowski, and Bram van Leer (2010) High-order finite-volume methods for the shallow-water equations on the sphere DOI: 10.1016/j.jcp.2010.04.044\n\nOr this slides, slides 8 and 9.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.collision_bgk-Tuple{Any, Any, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.collision_bgk","text":"collision_bgk(u, dt, equations::LatticeBoltzmannEquations2D)\n\nCollision operator for the Bhatnagar, Gross, and Krook (BGK) model.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.collision_bgk-Tuple{Any, Any, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.collision_bgk","text":"collision_bgk(u, dt, equations::LatticeBoltzmannEquations3D)\n\nCollision operator for the Bhatnagar, Gross, and Krook (BGK) model.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.cons2cons-Tuple{Any, Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.cons2cons","text":"cons2cons(u, equations)\n\nReturn the conserved variables u. While this function is as trivial as identity, it is also as useful.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.cons2entropy","page":"Trixi.jl","title":"Trixi.cons2entropy","text":"cons2entropy(u, equations)\n\nConvert the conserved variables u to the entropy variables for a given set of equations with chosen standard entropy.\n\nu is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by entropy2cons.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.cons2prim","page":"Trixi.jl","title":"Trixi.cons2prim","text":"cons2prim(u, equations)\n\nConvert the conserved variables u to the primitive variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by prim2cons.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.convergence_test-Tuple{Module, AbstractString, Any}","page":"Trixi.jl","title":"Trixi.convergence_test","text":"convergence_test([mod::Module=Main,] elixir::AbstractString, iterations; kwargs...)\n\nRun iterations Trixi.jl simulations using the setup given in elixir and compute the experimental order of convergence (EOC) in the L^2 and L^infty norm. In each iteration, the resolution of the respective mesh will be doubled. Additional keyword arguments kwargs... and the optional module mod are passed directly to trixi_include.\n\nThis function assumes that the spatial resolution is set via the keywords initial_refinement_level (an integer) or cells_per_dimension (a tuple of integers, one per spatial dimension).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.default_analysis_integrals-Tuple{Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.default_analysis_integrals","text":"default_analysis_integrals(equations)\n\nDefault analysis integrals used by the AnalysisCallback.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.default_example-Tuple{}","page":"Trixi.jl","title":"Trixi.default_example","text":"default_example()\n\nReturn the path to an example elixir that can be used to quickly see Trixi.jl in action on a TreeMesh. See also examples_dir and get_examples.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.default_example_unstructured-Tuple{}","page":"Trixi.jl","title":"Trixi.default_example_unstructured","text":"default_example_unstructured()\n\nReturn the path to an example elixir that can be used to quickly see Trixi.jl in action on an UnstructuredMesh2D. This simulation is run on the example curved, unstructured mesh given in the Trixi.jl documentation regarding unstructured meshes.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.density-Tuple{Real, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.density","text":"density(p::Real, equations::LatticeBoltzmannEquations2D)\ndensity(u, equations::LatticeBoltzmannEquations2D)\n\nCalculate the macroscopic density from the pressure p or the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.density-Tuple{Real, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.density","text":"density(p::Real, equations::LatticeBoltzmannEquations3D)\ndensity(u, equations::LatticeBoltzmannEquations3D)\n\nCalculate the macroscopic density from the pressure p or the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.each_dof_global-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.each_dof_global","text":"each_dof_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the degrees of freedom (DOF) in dg. In particular, not the DOFs themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.each_face_node-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.each_face_node","text":"each_face_node(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the face nodes in dg. In particular, not the face_nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.each_face_node_global-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.each_face_node_global","text":"each_face_node_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the face nodes in mesh. In particular, not the face nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.each_quad_node-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.each_quad_node","text":"each_quad_node(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the quadrature nodes in dg. In particular, not the quadrature nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.each_quad_node_global-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.each_quad_node_global","text":"each_quad_node_global(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the global quadrature nodes in mesh. In particular, not the quadrature nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachboundary-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachboundary","text":"eachboundary(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the boundaries in cache. In particular, not the boundaries themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachcomponent-Tuple{Trixi.AbstractCompressibleEulerMulticomponentEquations}","page":"Trixi.jl","title":"Trixi.eachcomponent","text":"eachcomponent(equations::AbstractCompressibleEulerMulticomponentEquations)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the components in AbstractCompressibleEulerMulticomponentEquations. In particular, not the components themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachcomponent-Tuple{Trixi.AbstractIdealGlmMhdMulticomponentEquations}","page":"Trixi.jl","title":"Trixi.eachcomponent","text":"eachcomponent(equations::AbstractIdealGlmMhdMulticomponentEquations)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the components in AbstractIdealGlmMhdMulticomponentEquations. In particular, not the components themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachdim-Tuple{Any}","page":"Trixi.jl","title":"Trixi.eachdim","text":"eachdim(mesh)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the dimensions in AbstractTree. In particular, not the dimensions themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachdirection-Tuple{Trixi.AbstractTree}","page":"Trixi.jl","title":"Trixi.eachdirection","text":"eachdirection(tree::AbstractTree)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the directions in AbstractTree. In particular, not the directions themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in cache. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{DGMultiMesh, DGMulti{NDIMS, ElemType, ApproxType} where {NDIMS, ElemType, ApproxType}, Vararg{Any}}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(mesh::DGMultiMesh, dg::DGMulti, other_args...)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in mesh. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{Trixi.ElementContainer1D}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(elements::ElementContainer1D)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{Trixi.ElementContainer2D}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(elements::ElementContainer2D)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{Trixi.ElementContainer3D}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(elements::ElementContainer3D)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachelement-Tuple{Trixi.UnstructuredElementContainer2D}","page":"Trixi.jl","title":"Trixi.eachelement","text":"eachelement(elements::UnstructuredElementContainer2D)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the elements in elements. In particular, not the elements themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachinterface-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachinterface","text":"eachinterface(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the interfaces in cache. In particular, not the interfaces themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachmortar-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachmortar","text":"eachmortar(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the mortars in cache. In particular, not the mortars themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachmpiinterface-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachmpiinterface","text":"eachmpiinterface(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the MPI interfaces in cache. In particular, not the interfaces themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachmpimortar-Tuple{DG, Any}","page":"Trixi.jl","title":"Trixi.eachmpimortar","text":"eachmpimortar(dg::DG, cache)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the MPI mortars in cache. In particular, not the mortars themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachnode-Tuple{DG}","page":"Trixi.jl","title":"Trixi.eachnode","text":"eachnode(dg::DG)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the nodes in dg. In particular, not the nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachnode-Tuple{LobattoLegendreBasis}","page":"Trixi.jl","title":"Trixi.eachnode","text":"eachnode(basis::LobattoLegendreBasis)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the nodes in basis. In particular, not the nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachnode-Tuple{Trixi.LobattoLegendreAnalyzer}","page":"Trixi.jl","title":"Trixi.eachnode","text":"eachnode(analyzer::LobattoLegendreAnalyzer)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the nodes in analyzer. In particular, not the nodes themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.eachvariable-Tuple{Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.eachvariable","text":"eachvariable(equations::AbstractEquations)\n\nReturn an iterator over the indices that specify the location in relevant data structures for the variables in equations. In particular, not the variables themselves are returned.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.energy_internal","page":"Trixi.jl","title":"Trixi.energy_internal","text":"energy_internal(u, equations)\n\nReturn the internal energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.\n\nu is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.energy_kinetic","page":"Trixi.jl","title":"Trixi.energy_kinetic","text":"energy_kinetic(u, equations)\n\nReturn the kinetic energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.\n\nu is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.energy_total","page":"Trixi.jl","title":"Trixi.energy_total","text":"energy_total(u, equations)\n\nReturn the total energy of the conserved variables u for a given set of equations, e.g., the CompressibleEulerEquations2D.\n\nu is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.entropy","page":"Trixi.jl","title":"Trixi.entropy","text":"entropy(u, equations)\n\nReturn the chosen entropy of the conserved variables u for a given set of equations.\n\nu is a vector of the conserved variables at a single node, i.e., a vector of the correct length nvariables(equations).\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.entropy2cons","page":"Trixi.jl","title":"Trixi.entropy2cons","text":"entropy2cons(w, equations)\n\nConvert the entropy variables w based on a standard entropy to the conserved variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by cons2entropy.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.equilibrium_distribution-Tuple{Any, Any, Any, Any, Any, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.equilibrium_distribution","text":"equilibrium_distribution(alpha, rho, v1, v2, v3, equations::LatticeBoltzmannEquations3D)\n\nCalculate the local equilibrium distribution for the distribution function with index alpha and given the macroscopic state defined by rho, v1, v2, v3.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.equilibrium_distribution-Tuple{Any, Any, Any, Any, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.equilibrium_distribution","text":"equilibrium_distribution(alpha, rho, v1, v2, equations::LatticeBoltzmannEquations2D)\n\nCalculate the local equilibrium distribution for the distribution function with index alpha and given the macroscopic state defined by rho, v1, v2.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.examples_dir-Tuple{}","page":"Trixi.jl","title":"Trixi.examples_dir","text":"examples_dir()\n\nReturn the directory where the example files provided with Trixi.jl are located. If Trixi.jl is installed as a regular package (with ]add Trixi), these files are read-only and should not be modified. To find out which files are available, use, e.g., readdir:\n\nExamples\n\nreaddir(examples_dir())\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux","page":"Trixi.jl","title":"Trixi.flux","text":"flux(u, orientation_or_normal, equations)\n\nGiven the conservative variables u, calculate the (physical) flux in Cartesian direction orientation::Integer or in arbitrary direction normal::AbstractVector for the corresponding set of governing equations. orientation is 1, 2, and 3 for the x-, y-, and z-directions, respectively.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.flux-Tuple{Any, AbstractVector, Trixi.AbstractEquations{1}}","page":"Trixi.jl","title":"Trixi.flux","text":"flux(u, normal_direction::AbstractVector, equations::AbstractEquations{1})\n\nEnables calling flux with a non-integer argument normal_direction for one-dimensional equations. Returns the value of flux(u, 1, equations) scaled by normal_direction[1].\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_central-Tuple{Any, Any, Any, Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.flux_central","text":"flux_central(u_ll, u_rr, orientation_or_normal_direction, equations::AbstractEquations)\n\nThe classical central numerical flux f((u_ll) + f(u_rr)) / 2. When this flux is used as volume flux, the discretization is equivalent to the classical weak form DG method (except floating point errors).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chan_etal-Tuple{Any, Any, Integer, ShallowWaterEquationsQuasi1D}","page":"Trixi.jl","title":"Trixi.flux_chan_etal","text":"flux_chan_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterEquationsQuasi1D)\n\nTotal energy conservative (mathematical entropy for quasi 1D shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., FluxPlusDissipation(flux_chan_etal, DissipationLocalLaxFriedrichs()).\n\nFurther details are available in the paper:\n\nJesse Chan, Khemraj Shukla, Xinhui Wu, Ruofeng Liu, Prani Nalluri (2023) High order entropy stable schemes for the quasi-one-dimensional shallow water and compressible Euler equations DOI: 10.48550/arXiv.2307.12089\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chandrashekar-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_chandrashekar","text":"flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)\n\nEntropy conserving two-point flux by\n\nChandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chandrashekar-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_chandrashekar","text":"flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations2D)\n\nEntropy conserving two-point flux by\n\nChandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chandrashekar-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_chandrashekar","text":"flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerEquations3D)\n\nEntropy conserving two-point flux by\n\nChandrashekar (2013) Kinetic Energy Preserving and Entropy Stable Finite Volume Schemes for Compressible Euler and Navier-Stokes Equations DOI: 10.4208/cicp.170712.010313a\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chandrashekar-Tuple{Any, Any, Integer, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.flux_chandrashekar","text":"flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerMulticomponentEquations1D)\n\nEntropy conserving two-point flux by\n\nAyoub Gouasmi, Karthik Duraisamy (2020) \"Formulation of Entropy-Stable schemes for the multicomponent compressible Euler equations\" arXiv:1904.00972v3 [math.NA] 4 Feb 2020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_chandrashekar-Tuple{Any, Any, Integer, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.flux_chandrashekar","text":"flux_chandrashekar(u_ll, u_rr, orientation, equations::CompressibleEulerMulticomponentEquations2D)\n\nAdaption of the entropy conserving two-point flux by\n\nAyoub Gouasmi, Karthik Duraisamy (2020) \"Formulation of Entropy-Stable schemes for the multicomponent compressible Euler equations\" arXiv:1904.00972v3 [math.NA] 4 Feb 2020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_derigs_etal-Tuple{Any, Any, Integer, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.flux_derigs_etal","text":"flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations1D)\n\nEntropy conserving two-point flux by\n\nDerigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_derigs_etal-Tuple{Any, Any, Integer, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.flux_derigs_etal","text":"flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations2D)\n\nEntropy conserving two-point flux by\n\nDerigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_derigs_etal-Tuple{Any, Any, Integer, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.flux_derigs_etal","text":"flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations3D)\n\nEntropy conserving two-point flux by\n\nDerigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations DOI: 10.1016/j.jcp.2018.03.002\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_derigs_etal-Tuple{Any, Any, Integer, IdealGlmMhdMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.flux_derigs_etal","text":"flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdEquations1D)\n\nEntropy conserving two-point flux adapted by\n\nDerigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations for multicomponent DOI: 10.1016/j.jcp.2018.03.002\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_derigs_etal-Tuple{Any, Any, Integer, IdealGlmMhdMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.flux_derigs_etal","text":"flux_derigs_etal(u_ll, u_rr, orientation, equations::IdealGlmMhdMulticomponentEquations2D)\n\nEntropy conserving two-point flux adapted by\n\nDerigs et al. (2018) Ideal GLM-MHD: About the entropy consistent nine-wave magnetic field divergence diminishing ideal magnetohydrodynamics equations for multicomponent DOI: 10.1016/j.jcp.2018.03.002\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_es_fjordholm_etal-Tuple{Any, Any, Any, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_es_fjordholm_etal","text":"flux_es_fjordholm_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterTwoLayerEquations1D)\n\nEntropy stable surface flux for the two-layer shallow water equations. Uses the entropy conservative flux_fjordholm_etal and adds a Lax-Friedrichs type dissipation dependent on the jump of entropy variables.\n\nFurther details are available in the paper:\n\nUlrik Skre Fjordholm (2012)\n\nEnergy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039 It should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_es_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_es_fjordholm_etal","text":"flux_es_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterTwoLayerEquations1D)\n\nEntropy stable surface flux for the two-layer shallow water equations. Uses the entropy conservative flux_fjordholm_etal and adds a Lax-Friedrichs type dissipation dependent on the jump of entropy variables.\n\nFurther details are available in the paper:\n\nUlrik Skre Fjordholm (2012) Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039\n\nIt should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterEquations1D)\n\nTotal energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterEquations2D)\n\nTotal energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterTwoLayerEquations1D)\n\nTotal energy conservative (mathematical entropy for shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishra and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\nand the application to two layers is shown in the paper:\n\nUlrik Skre Fjordholm (2012) Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039\n\nIt should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_fjordholm_etal","text":"flux_fjordholm_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterTwoLayerEquations2D)\n\nTotal energy conservative (mathematical entropy for two-layer shallow water equations). When the bottom topography is nonzero this should only be used as a surface flux otherwise the scheme will not be well-balanced. For well-balancedness in the volume flux use flux_wintermeyer_etal.\n\nDetails are available in Eq. (4.1) in the paper:\n\nUlrik S. Fjordholm, Siddhartha Mishra and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\nand the application to two layers is shown in the paper:\n\nUlrik Skre Fjordholm (2012) Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039\n\nIt should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_godunov-Tuple{Any, Any, Integer, LinearizedEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_godunov","text":"flux_godunov(u_ll, u_rr, orientation_or_normal_direction,\n equations::LinearizedEulerEquations2D)\n\nAn upwind flux for the linearized Euler equations based on diagonalization of the physical flux matrix. Given the physical flux Au, A=T Lambda T^-1 with Lambda being a diagonal matrix that holds the eigenvalues of A, decompose Lambda = Lambda^+ + Lambda^- where Lambda^+ and Lambda^- are diagonal matrices holding the positive and negative eigenvalues of A, respectively. Then for left and right states u_L u_R, the numerical flux calculated by this function is given by A^+ u_L + A^- u_R where A^pm = T Lambda^pm T^-1.\n\nThe diagonalization of the flux matrix can be found in\n\nR. F. Warming, Richard M. Beam and B. J. Hyett (1975) Diagonalization and simultaneous symmetrization of the gas-dynamic matrices DOI: 10.1090/S0025-5718-1975-0388967-5\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hindenlang_gassner-Tuple{Any, Any, Integer, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.flux_hindenlang_gassner","text":"flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,\n equations::IdealGlmMhdEquations1D)\n\nEntropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.\n\nReferences\n\nFlorian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hindenlang_gassner-Tuple{Any, Any, Integer, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.flux_hindenlang_gassner","text":"flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,\n equations::IdealGlmMhdEquations2D)\n\nEntropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.\n\nReferences\n\nFlorian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hindenlang_gassner-Tuple{Any, Any, Integer, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.flux_hindenlang_gassner","text":"flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,\n equations::IdealGlmMhdEquations3D)\n\nEntropy conserving and kinetic energy preserving two-point flux of Hindenlang and Gassner (2019), extending flux_ranocha to the MHD equations.\n\nReferences\n\nFlorian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hindenlang_gassner-Tuple{Any, Any, Integer, IdealGlmMhdMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.flux_hindenlang_gassner","text":"flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,\n equations::IdealGlmMhdMulticomponentEquations1D)\n\nAdaption of the entropy conserving and kinetic energy preserving two-point flux of Hindenlang (2019), extending flux_ranocha to the MHD equations.\n\nReferences\n\nFlorian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hindenlang_gassner-Tuple{Any, Any, Integer, IdealGlmMhdMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.flux_hindenlang_gassner","text":"flux_hindenlang_gassner(u_ll, u_rr, orientation_or_normal_direction,\n equations::IdealGlmMhdMulticomponentEquations2D)\n\nAdaption of the entropy conserving and kinetic energy preserving two-point flux of Hindenlang (2019), extending flux_ranocha to the MHD equations.\n\nReferences\n\nFlorian Hindenlang, Gregor Gassner (2019) A new entropy conservative two-point flux for ideal MHD equations derived from first principles. Presented at HONOM 2019: European workshop on high order numerical methods for evolutionary PDEs, theory and applications\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hllc-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_hllc","text":"flux_hllc(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)\n\nComputes the HLLC flux (HLL with Contact) for compressible Euler equations developed by E.F. Toro Lecture slides Signal speeds: DOI: 10.1137/S1064827593260140\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hllc-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_hllc","text":"flux_hllc(u_ll, u_rr, orientation, equations::CompressibleEulerEquations2D)\n\nComputes the HLLC flux (HLL with Contact) for compressible Euler equations developed by E.F. Toro Lecture slides Signal speeds: DOI: 10.1137/S1064827593260140\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hllc-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_hllc","text":"flux_hllc(u_ll, u_rr, orientation, equations::CompressibleEulerEquations3D)\n\nComputes the HLLC flux (HLL with Contact) for compressible Euler equations developed by E.F. Toro Lecture slides Signal speeds: DOI: 10.1137/S1064827593260140\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hlle-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_hlle","text":"flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)\n\nComputes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.\n\nOriginal publication:\n\nBernd Einfeldt (1988) On Godunov-type methods for gas dynamics. DOI: 10.1137/0725021\n\nCompactly summarized:\n\nSiddhartha Mishra, Ulrik Skre Fjordholm and Rémi Abgrall Numerical methods for conservation laws and related equations. Link\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hlle-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_hlle","text":"flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations2D)\n\nComputes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.\n\nBernd Einfeldt (1988) On Godunov-type methods for gas dynamics. DOI: 10.1137/0725021\nBernd Einfeldt, Claus-Dieter Munz, Philip L. Roe and Björn Sjögreen (1991) On Godunov-type methods near low densities. DOI: 10.1016/0021-9991(91)90211-3\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_hlle-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_hlle","text":"flux_hlle(u_ll, u_rr, orientation, equations::CompressibleEulerEquations3D)\n\nComputes the HLLE (Harten-Lax-van Leer-Einfeldt) flux for the compressible Euler equations. Special estimates of the signal velocites and linearization of the Riemann problem developed by Einfeldt to ensure that the internal energy and density remain positive during the computation of the numerical flux.\n\nBernd Einfeldt (1988) On Godunov-type methods for gas dynamics. DOI: 10.1137/0725021\nBernd Einfeldt, Claus-Dieter Munz, Philip L. Roe and Björn Sjögreen (1991) On Godunov-type methods near low densities. DOI: 10.1016/0021-9991(91)90211-3\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_kennedy_gruber-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_kennedy_gruber","text":"flux_kennedy_gruber(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)\n\nKinetic energy preserving two-point flux by\n\nKennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_kennedy_gruber-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_kennedy_gruber","text":"flux_kennedy_gruber(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations2D)\n\nKinetic energy preserving two-point flux by\n\nKennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_kennedy_gruber-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_kennedy_gruber","text":"flux_kennedy_gruber(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations3D)\n\nKinetic energy preserving two-point flux by\n\nKennedy and Gruber (2008) Reduced aliasing formulations of the convective terms within the Navier-Stokes equations for a compressible fluid DOI: 10.1016/j.jcp.2007.09.020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_audusse_etal-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_audusse_etal","text":"flux_nonconservative_audusse_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nNon-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_audusse_etal on the conservative variables.\n\nThis hydrostatic reconstruction ensures that the finite volume numerical fluxes remain well-balanced for discontinuous bottom topographies ShallowWaterEquations1D. Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_audusse_etal in the surface flux to ensure consistency.\n\nFurther details on the hydrostatic reconstruction and its motivation can be found in\n\nEmmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_audusse_etal-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_audusse_etal","text":"flux_nonconservative_audusse_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations2D)\nflux_nonconservative_audusse_etal(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average::AbstractVector,\n equations::ShallowWaterEquations2D)\n\nNon-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_audusse_etal on the conservative variables.\n\nThis hydrostatic reconstruction ensures that the finite volume numerical fluxes remain well-balanced for discontinuous bottom topographies ShallowWaterEquations2D. Should be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_audusse_etal in the surface flux to ensure consistency.\n\nFurther details for the hydrostatic reconstruction and its motivation can be found in\n\nEmmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_chan_etal-Tuple{Any, Any, Integer, ShallowWaterEquationsQuasi1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_chan_etal","text":"flux_nonconservative_chan_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquationsQuasi1D)\n\nNon-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquationsQuasi1D and the channel width.\n\nFurther details are available in the paper:\n\nJesse Chan, Khemraj Shukla, Xinhui Wu, Ruofeng Liu, Prani Nalluri (2023) High order entropy stable schemes for the quasi-one-dimensional shallow water and compressible Euler equations DOI: 10.48550/arXiv.2307.12089\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_chen_noelle-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_chen_noelle","text":"flux_nonconservative_chen_noelle(u_ll, u_rr,\n orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nNon-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_chen_noelle on the conservative variables.\n\nShould be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_chen_noelle in the surface flux to ensure consistency.\n\nFurther details on the hydrostatic reconstruction and its motivation can be found in\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_chen_noelle-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_chen_noelle","text":"flux_nonconservative_chen_noelle(u_ll, u_rr,\n orientation::Integer,\n equations::ShallowWaterEquations2D)\nflux_nonconservative_chen_noelle(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average ::AbstractVector,\n equations::ShallowWaterEquations2D)\n\nNon-symmetric two-point surface flux that discretizes the nonconservative (source) term. The discretization uses the hydrostatic_reconstruction_chen_noelle on the conservative variables.\n\nShould be used together with FluxHydrostaticReconstruction and hydrostatic_reconstruction_chen_noelle in the surface flux to ensure consistency.\n\nFurther details on the hydrostatic reconstruction and its motivation can be found in\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_fjordholm_etal","text":"flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nNon-symmetric two-point surface flux discretizing the nonconservative (source) term of that contains the gradient of the bottom topography ShallowWaterEquations1D.\n\nThis contains additional terms compared to flux_nonconservative_wintermeyer_etal that account for possible discontinuities in the bottom topography function. Thus, this flux should be used in general at interfaces. For flux differencing volume terms, flux_nonconservative_wintermeyer_etal is analytically equivalent but slightly cheaper.\n\nFurther details for the original finite volume formulation are available in\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\nand for curvilinear 2D case in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_fjordholm_etal","text":"flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations2D)\nflux_nonconservative_fjordholm_etal(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average::AbstractVector,\n equations::ShallowWaterEquations2D)\n\nNon-symmetric two-point surface flux discretizing the nonconservative (source) term of that contains the gradient of the bottom topography ShallowWaterEquations2D.\n\nOn curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.\n\nThis contains additional terms compared to flux_nonconservative_wintermeyer_etal that account for possible discontinuities in the bottom topography function. Thus, this flux should be used in general at interfaces. For flux differencing volume terms, flux_nonconservative_wintermeyer_etal is analytically equivalent but slightly cheaper.\n\nFurther details for the original finite volume formulation are available in\n\nUlrik S. Fjordholm, Siddhartha Mishr and Eitan Tadmor (2011) Well-balanced and energy stable schemes for the shallow water equations with discontinuous topography DOI: 10.1016/j.jcp.2011.03.042\n\nand for curvilinear 2D case in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_fjordholm_etal","text":"flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterTwoLayerEquations1D)\n\nwarning: Experimental code\nThis numerical flux is experimental and may change in any future release.\n\nNon-symmetric two-point surface flux discretizing the nonconservative (source) term that contains the gradients of the bottom topography and an additional term that couples the momentum of both layers ShallowWaterTwoLayerEquations2D.\n\nFurther details are available in the paper:\n\nUlrik Skre Fjordholm (2012) Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039\n\nIt should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_fjordholm_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_fjordholm_etal","text":"flux_nonconservative_fjordholm_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterTwoLayerEquations2D)\n\nwarning: Experimental code\nThis numerical flux is experimental and may change in any future release.\n\nNon-symmetric two-point surface flux discretizing the nonconservative (source) term that contains the gradients of the bottom topography and an additional term that couples the momentum of both layers ShallowWaterTwoLayerEquations2D.\n\nFurther details are available in the paper:\n\nUlrik Skre Fjordholm (2012) Energy conservative and stable schemes for the two-layer shallow water equations. DOI: 10.1142/9789814417099_0039\n\nIt should be noted that the equations are ordered differently and the designation of the upper and lower layer has been changed which leads to a slightly different formulation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_powell-Tuple{Any, Any, Integer, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_powell","text":"flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,\n equations::IdealGlmMhdEquations2D)\nflux_nonconservative_powell(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average::AbstractVector,\n equations::IdealGlmMhdEquations2D)\n\nNon-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdEquations2D.\n\nOn curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.\n\nReferences\n\nMarvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_powell-Tuple{Any, Any, Integer, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_powell","text":"flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,\n equations::IdealGlmMhdEquations3D)\nflux_nonconservative_powell(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average::AbstractVector,\n equations::IdealGlmMhdEquations3D)\n\nNon-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdEquations3D.\n\nOn curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.\n\nReferences\n\nMarvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_powell-Tuple{Any, Any, Integer, IdealGlmMhdMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_powell","text":"flux_nonconservative_powell(u_ll, u_rr, orientation::Integer,\n equations::IdealGlmMhdMulticomponentEquations2D)\n\nNon-symmetric two-point flux discretizing the nonconservative (source) term of Powell and the Galilean nonconservative term associated with the GLM multiplier of the IdealGlmMhdMulticomponentEquations2D.\n\nReferences\n\nMarvin Bohm, Andrew R.Winters, Gregor J. Gassner, Dominik Derigs, Florian Hindenlang, Joachim Saur An entropy stable nodal discontinuous Galerkin method for the resistive MHD equations. Part I: Theory and numerical verification DOI: 10.1016/j.jcp.2018.06.027\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_wintermeyer_etal","text":"flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nNon-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquations1D.\n\nFurther details are available in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_wintermeyer_etal","text":"flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations2D)\nflux_nonconservative_wintermeyer_etal(u_ll, u_rr,\n normal_direction_ll ::AbstractVector,\n normal_direction_average::AbstractVector,\n equations::ShallowWaterEquations2D)\n\nNon-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterEquations2D.\n\nOn curvilinear meshes, this nonconservative flux depends on both the contravariant vector (normal direction) at the current node and the averaged one. This is different from numerical fluxes used to discretize conservative terms.\n\nFurther details are available in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_wintermeyer_etal","text":"flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterTwoLayerEquations1D)\n\nwarning: Experimental code\nThis numerical flux is experimental and may change in any future release.\n\nNon-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterTwoLayerEquations2D and an additional term that couples the momentum of both layers. This is a slightly modified version to account for the additional source term compared to the standard SWE described in the paper.\n\nFurther details are available in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_nonconservative_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_nonconservative_wintermeyer_etal","text":"flux_nonconservative_wintermeyer_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterTwoLayerEquations2D)\n\nwarning: Experimental code\nThis numerical flux is experimental and may change in any future release.\n\nNon-symmetric two-point volume flux discretizing the nonconservative (source) term that contains the gradient of the bottom topography ShallowWaterTwoLayerEquations2D and an additional term that couples the momentum of both layers. This is a slightly modified version to account for the additional source term compared to the standard SWE described in the paper.\n\nFurther details are available in the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_ranocha","text":"flux_ranocha(u_ll, u_rr, orientation_or_normal_direction, equations::CompressibleEulerEquations1D)\n\nEntropy conserving and kinetic energy preserving two-point flux by\n\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\n\nSee also\n\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_ranocha","text":"flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations2D)\n\nEntropy conserving and kinetic energy preserving two-point flux by\n\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\n\nSee also\n\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_ranocha","text":"flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations3D)\n\nEntropy conserving and kinetic energy preserving two-point flux by\n\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\n\nSee also\n\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha-Tuple{Any, Any, Integer, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.flux_ranocha","text":"flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerMulticomponentEquations1D)\n\nAdaption of the entropy conserving and kinetic energy preserving two-point flux by\n\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\n\nSee also\n\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha-Tuple{Any, Any, Integer, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.flux_ranocha","text":"flux_ranocha(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerMulticomponentEquations2D)\n\nAdaption of the entropy conserving and kinetic energy preserving two-point flux by\n\nHendrik Ranocha (2018) Generalised Summation-by-Parts Operators and Entropy Stability of Numerical Methods for Hyperbolic Balance Laws PhD thesis, TU Braunschweig\n\nSee also\n\nHendrik Ranocha (2020) Entropy Conserving and Kinetic Energy Preserving Numerical Methods for the Euler Equations Using Summation-by-Parts Operators Proceedings of ICOSAHOM 2018\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_ranocha_turbo-NTuple{4, Any}","page":"Trixi.jl","title":"Trixi.flux_ranocha_turbo","text":"flux_ranocha_turbo(u_ll, u_rr, orientation_or_normal_direction, equations)\n\nEquivalent to flux_ranocha except that it may use specialized methods, e.g., when used with VolumeIntegralFluxDifferencing. These specialized methods may enable better use of SIMD instructions to increase runtime efficiency on modern hardware.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_shima_etal-Tuple{Any, Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_shima_etal","text":"flux_shima_etal(u_ll, u_rr, orientation, equations::CompressibleEulerEquations1D)\n\nThis flux is is a modification of the original kinetic energy preserving two-point flux by\n\nYuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058\n\nThe modification is in the energy flux to guarantee pressure equilibrium and was developed by\n\nNao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_shima_etal-Tuple{Any, Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_shima_etal","text":"flux_shima_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations2D)\n\nThis flux is is a modification of the original kinetic energy preserving two-point flux by\n\nYuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058\n\nThe modification is in the energy flux to guarantee pressure equilibrium and was developed by\n\nNao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_shima_etal-Tuple{Any, Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.flux_shima_etal","text":"flux_shima_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::CompressibleEulerEquations3D)\n\nThis flux is is a modification of the original kinetic energy preserving two-point flux by\n\nYuichi Kuya, Kosuke Totani and Soshi Kawai (2018) Kinetic energy and entropy preserving schemes for compressible flows by split convective forms DOI: 10.1016/j.jcp.2018.08.058\n\nThe modification is in the energy flux to guarantee pressure equilibrium and was developed by\n\nNao Shima, Yuichi Kuya, Yoshiharu Tamaki, Soshi Kawai (JCP 2020) Preventing spurious pressure oscillations in split convective form discretizations for compressible flows DOI: 10.1016/j.jcp.2020.110060\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_shima_etal_turbo-NTuple{4, Any}","page":"Trixi.jl","title":"Trixi.flux_shima_etal_turbo","text":"flux_shima_etal_turbo(u_ll, u_rr, orientation_or_normal_direction, equations)\n\nEquivalent to flux_shima_etal except that it may use specialized methods, e.g., when used with VolumeIntegralFluxDifferencing. These specialized methods may enable better use of SIMD instructions to increase runtime efficiency on modern hardware.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterEquations1D)\n\nTotal energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterEquations2D)\n\nTotal energy conservative (mathematical entropy for shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterTwoLayerEquations1D)\n\nTotal energy conservative (mathematical entropy for two-layer shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal. To obtain the flux for the two-layer shallow water equations the flux that is described in the paper for the normal shallow water equations is used within each layer.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_wintermeyer_etal-Tuple{Any, Any, Integer, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_wintermeyer_etal","text":"flux_wintermeyer_etal(u_ll, u_rr, orientation,\n equations::ShallowWaterTwoLayerEquations2D)\n\nTotal energy conservative (mathematical entropy for two-layer shallow water equations) split form. When the bottom topography is nonzero this scheme will be well-balanced when used as a volume_flux. The surface_flux should still use, e.g., flux_fjordholm_etal. To obtain the flux for the two-layer shallow water equations the flux that is described in the paper for the normal shallow water equations is used within each layer.\n\nFurther details are available in Theorem 1 of the paper:\n\nNiklas Wintermeyer, Andrew R. Winters, Gregor J. Gassner and David A. Kopriva (2017) An entropy stable nodal discontinuous Galerkin method for the two dimensional shallow water equations on unstructured curvilinear meshes with discontinuous bathymetry DOI: 10.1016/j.jcp.2017.03.036\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.flux_winters_etal-Tuple{Any, Any, AbstractVector, PolytropicEulerEquations2D}","page":"Trixi.jl","title":"Trixi.flux_winters_etal","text":"flux_winters_etal(u_ll, u_rr, normal_direction,\n equations::PolytropicEulerEquations2D)\n\nEntropy conserving two-point flux for isothermal or polytropic gases. Requires a special weighted Stolarsky mean for the evaluation of the density denoted here as stolarsky_mean. Note, for isothermal gases where gamma = 1 this stolarsky_mean becomes the ln_mean.\n\nFor details see Section 3.2 of the following reference\n\nAndrew R. Winters, Christof Czernik, Moritz B. Schily & Gregor J. Gassner (2020) Entropy stable numerical approximations for the isothermal and polytropic Euler equations DOI: 10.1007/s10543-019-00789-w\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.get_examples-Tuple{}","page":"Trixi.jl","title":"Trixi.get_examples","text":"get_examples()\n\nReturn a list of all example elixirs that are provided by Trixi.jl. See also examples_dir and default_example.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.get_name-Tuple{Any}","page":"Trixi.jl","title":"Trixi.get_name","text":"get_name(x)\n\nReturns a name of x ready for pretty printing. By default, return string(y) if x isa Val{y} and return string(x) otherwise.\n\nExamples\n\njulia> Trixi.get_name(\"test\")\n\"test\"\n\njulia> Trixi.get_name(Val(:test))\n\"test\"\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.get_name-Tuple{Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.get_name","text":"get_name(equations::AbstractEquations)\n\nReturns the canonical, human-readable name for the given system of equations.\n\nExamples\n\njulia> Trixi.get_name(CompressibleEulerEquations1D(1.4))\n\"CompressibleEulerEquations1D\"\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.getmesh-Tuple{Trixi.AbstractPlotData}","page":"Trixi.jl","title":"Trixi.getmesh","text":"getmesh(pd::AbstractPlotData)\n\nExtract grid lines from pd for plotting with Plots.plot.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.global_mean_vars-Tuple{AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.global_mean_vars","text":"global_mean_vars(equations::AcousticPerturbationEquations2D)\n\nReturns the global mean variables stored in equations. This makes it easier to define flexible initial conditions for problems with constant mean flow.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.have_nonconservative_terms-Tuple{Trixi.AbstractEquations}","page":"Trixi.jl","title":"Trixi.have_nonconservative_terms","text":"have_nonconservative_terms(equations)\n\nTrait function determining whether equations represent a conservation law with or without nonconservative terms. Classical conservation laws such as the CompressibleEulerEquations2D do not have nonconservative terms. The ShallowWaterEquations2D with non-constant bottom topography are an example of equations with nonconservative terms. The return value will be True() or False() to allow dispatching on the return type.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.hydrostatic_reconstruction_audusse_etal-Tuple{Any, Any, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.hydrostatic_reconstruction_audusse_etal","text":"hydrostatic_reconstruction_audusse_etal(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nA particular type of hydrostatic reconstruction on the water height to guarantee well-balancedness for a general bottom topography ShallowWaterEquations1D. The reconstructed solution states u_ll_star and u_rr_star variables are then used to evaluate the surface numerical flux at the interface. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.\n\nFurther details on this hydrostatic reconstruction and its motivation can be found in\n\nEmmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.hydrostatic_reconstruction_audusse_etal-Tuple{Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.hydrostatic_reconstruction_audusse_etal","text":"hydrostatic_reconstruction_audusse_etal(u_ll, u_rr, orientation_or_normal_direction,\n equations::ShallowWaterEquations2D)\n\nA particular type of hydrostatic reconstruction on the water height to guarantee well-balancedness for a general bottom topography ShallowWaterEquations2D. The reconstructed solution states u_ll_star and u_rr_star variables are used to evaluate the surface numerical flux at the interface. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.\n\nFurther details for the hydrostatic reconstruction and its motivation can be found in\n\nEmmanuel Audusse, François Bouchut, Marie-Odile Bristeau, Rupert Klein, and Benoit Perthame (2004) A fast and stable well-balanced scheme with hydrostatic reconstruction for shallow water flows DOI: 10.1137/S1064827503431090\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.hydrostatic_reconstruction_chen_noelle-Tuple{Any, Any, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.hydrostatic_reconstruction_chen_noelle","text":"hydrostatic_reconstruction_chen_noelle(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nA particular type of hydrostatic reconstruction of the water height to guarantee well-balancedness for a general bottom topography of the ShallowWaterEquations1D. The reconstructed solution states u_ll_star and u_rr_star variables are used to evaluate the surface numerical flux at the interface. The key idea is a linear reconstruction of the bottom and water height at the interfaces using subcells. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.\n\nFurther details on this hydrostatic reconstruction and its motivation can be found in\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.hydrostatic_reconstruction_chen_noelle-Tuple{Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.hydrostatic_reconstruction_chen_noelle","text":"hydrostatic_reconstruction_chen_noelle(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations2D)\n\nA particular type of hydrostatic reconstruction of the water height to guarantee well-balancedness for a general bottom topography of the ShallowWaterEquations2D. The reconstructed solution states u_ll_star and u_rr_star variables are then used to evaluate the surface numerical flux at the interface. The key idea is a linear reconstruction of the bottom and water height at the interfaces using subcells. Use in combination with the generic numerical flux routine FluxHydrostaticReconstruction.\n\nFurther details on this hydrostatic reconstruction and its motivation can be found in\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.init_mpi-Tuple{}","page":"Trixi.jl","title":"Trixi.init_mpi","text":"init_mpi()\n\nInitialize MPI by calling MPI.Initialized(). The function will check if MPI is already initialized and if yes, do nothing, thus it is safe to call it multiple times.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.init_p4est-Tuple{}","page":"Trixi.jl","title":"Trixi.init_p4est","text":"init_p4est()\n\nInitialize p4est by calling p4est_init and setting the log level to SC_LP_ERROR. This function will check if p4est is already initialized and if yes, do nothing, thus it is safe to call it multiple times.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.init_t8code-Tuple{}","page":"Trixi.jl","title":"Trixi.init_t8code","text":"init_t8code()\n\nInitialize t8code by calling sc_init, p4est_init, and t8_init while setting the log level to SC_LP_ERROR. This function will check if t8code is already initialized and if yes, do nothing, thus it is safe to call it multiple times.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::AcousticPerturbationEquations2D)\n\nA constant initial condition where the state variables are zero and the mean flow is constant. Uses the global mean values from equations.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::CompressibleEulerEquations1D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::CompressibleEulerEquations2D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::CompressibleEulerEquations3D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::IdealGlmMhdEquations1D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::IdealGlmMhdEquations2D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::IdealGlmMhdEquations3D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, InviscidBurgersEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::InviscidBurgersEquation1D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::LatticeBoltzmannEquations2D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::LatticeBoltzmannEquations3D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_constant-Tuple{Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.initial_condition_constant","text":"initial_condition_constant(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA constant initial condition to test free-stream preservation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::AcousticPerturbationEquations2D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test. Uses the global mean values from equations.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::CompressibleEulerEquations1D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::CompressibleEulerEquations2D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::CompressibleEulerEquations3D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::CompressibleEulerMulticomponentEquations1D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::CompressibleEulerMulticomponentEquations2D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::IdealGlmMhdEquations1D)\n\nAn Alfvén wave as smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::IdealGlmMhdEquations2D)\n\nAn Alfvén wave as smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::IdealGlmMhdEquations3D)\n\nAn Alfvén wave as smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, IdealGlmMhdMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::IdealGlmMhdMulticomponentEquations1D)\n\nAn Alfvén wave as smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, IdealGlmMhdMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::IdealGlmMhdMulticomponentEquations2D)\n\nAn Alfvén wave as smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, InviscidBurgersEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::InviscidBurgersEquation1D)\n\nA smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA smooth initial condition used for convergence tests (in combination with BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, LinearizedEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::LinearizedEulerEquations2D)\n\nA smooth initial condition used for convergence tests.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, PolytropicEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::PolytropicEulerEquations2D)\n\nManufactured smooth initial condition used for convergence tests in combination with source_terms_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::ShallowWaterEquations2D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, ShallowWaterEquationsQuasi1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::ShallowWaterEquationsQuasi1D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::ShallowWaterTwoLayerEquations1D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_convergence_test-Tuple{Any, Any, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_convergence_test","text":"initial_condition_convergence_test(x, t, equations::ShallowWaterTwoLayerEquations2D)\n\nA smooth initial condition used for convergence tests in combination with source_terms_convergence_test. Constants must be set to rho_upper = 09, rho_lower = 10, g = 100.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_density_wave-Tuple{Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_density_wave","text":"initial_condition_density_wave(x, t, equations::CompressibleEulerEquations1D)\n\nA sine wave in the density with constant velocity and pressure; reduces the compressible Euler equations to the linear advection equations. This setup is the test case for stability of EC fluxes from paper\n\nGregor J. Gassner, Magnus Svärd, Florian J. Hindenlang (2020) Stability issues of entropy-stable and/or split-form high-order schemes arXiv: 2007.09026\n\nwith the following parameters\n\ndomain [-1, 1]\nmesh = 4x4\npolydeg = 5\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_density_wave-Tuple{Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_density_wave","text":"initial_condition_density_wave(x, t, equations::CompressibleEulerEquations2D)\n\nA sine wave in the density with constant velocity and pressure; reduces the compressible Euler equations to the linear advection equations. This setup is the test case for stability of EC fluxes from paper\n\nGregor J. Gassner, Magnus Svärd, Florian J. Hindenlang (2020) Stability issues of entropy-stable and/or split-form high-order schemes arXiv: 2007.09026\n\nwith the following parameters\n\ndomain [-1, 1]\nmesh = 4x4\npolydeg = 5\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations1D)\n\nOne dimensional variant of the setup used for convergence tests of the Euler equations with self-gravity from\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nnote: Note\nThere is no additional source term necessary for the manufactured solution in one spatial dimension. Thus, source_terms_eoc_test_coupled_euler_gravity is not present there.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations2D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with source_terms_eoc_test_coupled_euler_gravity or source_terms_eoc_test_euler.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::CompressibleEulerEquations3D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with source_terms_eoc_test_coupled_euler_gravity or source_terms_eoc_test_euler.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, HyperbolicDiffusionEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::HyperbolicDiffusionEquations1D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with source_terms_harmonic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, HyperbolicDiffusionEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::HyperbolicDiffusionEquations2D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with source_terms_harmonic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_eoc_test_coupled_euler_gravity-Tuple{Any, Any, HyperbolicDiffusionEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_eoc_test_coupled_euler_gravity","text":"initial_condition_eoc_test_coupled_euler_gravity(x, t, equations::HyperbolicDiffusionEquations3D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with source_terms_harmonic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_gauss-Tuple{Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_gauss","text":"initial_condition_gauss(x, t, equations::AcousticPerturbationEquations2D)\n\nA Gaussian pulse in a constant mean flow. Uses the global mean values from equations.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_gauss-Tuple{Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_gauss","text":"initial_condition_gauss(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA Gaussian pulse used together with BoundaryConditionDirichlet(initial_condition_gauss).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_gauss-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_gauss","text":"initial_condition_gauss(x, t, equation::LinearScalarAdvectionEquation2D)\n\nA Gaussian pulse used together with BoundaryConditionDirichlet(initial_condition_gauss).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_gauss-Tuple{Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.initial_condition_gauss","text":"initial_condition_gauss(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA Gaussian pulse.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_linear_x-Tuple{Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_linear_x","text":"initial_condition_linear_x(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA linear function of x[1] used together with boundary_condition_linear_x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_linear_x-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_linear_x","text":"initial_condition_linear_x(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA linear function of x[1] used together with boundary_condition_linear_x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_linear_x_y-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_linear_x_y","text":"initial_condition_linear_x_y(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA linear function of x[1] + x[2] used together with boundary_condition_linear_x_y.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_linear_y-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_linear_y","text":"initial_condition_linear_y(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA linear function of x[1] used together with boundary_condition_linear_y.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_linear_z-Tuple{Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.initial_condition_linear_z","text":"initial_condition_linear_z(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA linear function of x[3] used together with boundary_condition_linear_z.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_poisson_nonperiodic-Tuple{Any, Any, HyperbolicDiffusionEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_poisson_nonperiodic","text":"initial_condition_poisson_nonperiodic(x, t, equations::HyperbolicDiffusionEquations1D)\n\nA non-priodic smooth initial condition. Can be used for convergence tests in combination with source_terms_poisson_nonperiodic and boundary_condition_poisson_nonperiodic.\n\nnote: Note\nThe solution is periodic but the initial guess is not.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_sin-Tuple{Any, Any, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.initial_condition_sin","text":"initial_condition_sin(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA sine wave in the conserved variable.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_sin-Tuple{Any, Any, LinearScalarAdvectionEquation3D}","page":"Trixi.jl","title":"Trixi.initial_condition_sin","text":"initial_condition_sin(x, t, equations::LinearScalarAdvectionEquation1D)\n\nA sine wave in the conserved variable.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_sin_sin-Tuple{Any, Any, LinearScalarAdvectionEquation2D}","page":"Trixi.jl","title":"Trixi.initial_condition_sin_sin","text":"initial_condition_sin_sin(x, t, equations::LinearScalarAdvectionEquation2D)\n\nA sine wave in the conserved variable.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations1D)\n\nA weak blast wave taken from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations2D)\n\nA weak blast wave taken from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerEquations3D)\n\nA weak blast wave taken from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerMulticomponentEquations1D)\n\nA for multicomponent adapted weak blast wave adapted to multicomponent and taken from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::CompressibleEulerMulticomponentEquations2D)\n\nA for multicomponent adapted weak blast wave taken from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations1D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations2D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdEquations3D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, IdealGlmMhdMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdMulticomponentEquations1D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, IdealGlmMhdMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::IdealGlmMhdMulticomponentEquations2D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, PolytropicEulerEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::PolytropicEulerEquations2D)\n\nA weak blast wave adapted from\n\nSebastian Hennemann, Gregor J. Gassner (2020) A provably entropy stable subcell shock capturing approach for high order split form DG arXiv: 2008.12044\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::ShallowWaterEquations1D)\n\nA weak blast wave discontinuity useful for testing, e.g., total energy conservation. Note for the shallow water equations to the total energy acts as a mathematical entropy function.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.initial_condition_weak_blast_wave-Tuple{Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.initial_condition_weak_blast_wave","text":"initial_condition_weak_blast_wave(x, t, equations::ShallowWaterEquations2D)\n\nA weak blast wave discontinuity useful for testing, e.g., total energy conservation. Note for the shallow water equations to the total energy acts as a mathematical entropy function.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.integrate_via_indices-Union{Tuple{Func}, Tuple{Func, Any, Trixi.AbstractSemidiscretization, Vararg{Any}}} where Func","page":"Trixi.jl","title":"Trixi.integrate_via_indices","text":"integrate_via_indices(func, u_ode, semi::AbstractSemidiscretization, args...; normalize=true)\n\nCall func(u, i..., element, equations, solver, args...) for all nodal indices i..., element and integrate the result using a quadrature associated with the semidiscretization semi.\n\nIf normalize is true, the result is divided by the total volume of the computational domain.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.inv_ln_mean-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.inv_ln_mean","text":"inv_ln_mean(x, y)\n\nCompute the inverse 1 / ln_mean(x, y) of the logarithmic mean ln_mean.\n\nThis function may be used to increase performance where the inverse of the logarithmic mean is needed, by replacing a (slow) division by a (fast) multiplication.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.jacobian_ad_forward-Tuple{Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"Trixi.jacobian_ad_forward","text":"jacobian_ad_forward(semi::AbstractSemidiscretization;\n t0=zero(real(semi)),\n u0_ode=compute_coefficients(t0, semi))\n\nUses the right-hand side operator of the semidiscretization semi and forward mode automatic differentiation to compute the Jacobian J of the semidiscretization semi at state u0_ode.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.jacobian_fd-Tuple{Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"Trixi.jacobian_fd","text":"jacobian_fd(semi::AbstractSemidiscretization;\n t0=zero(real(semi)),\n u0_ode=compute_coefficients(t0, semi))\n\nUses the right-hand side operator of the semidiscretization semi and simple second order finite difference to compute the Jacobian J of the semidiscretization semi at state u0_ode.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.linear_structure-Tuple{Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"Trixi.linear_structure","text":"linear_structure(semi::AbstractSemidiscretization;\n t0=zero(real(semi)))\n\nWraps the right-hand side operator of the semidiscretization semi at time t0 as an affine-linear operator given by a linear operator A and a vector b.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ln_mean-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.ln_mean","text":"ln_mean(x, y)\n\nCompute the logarithmic mean\n\nln_mean(x, y) = (y - x) / (log(y) - log(x)) = (y - x) / log(y / x)\n\nProblem: The formula above has a removable singularity at x == y. Thus, some care must be taken to implement it correctly without problems or loss of accuracy when x ≈ y. Here, we use the approach proposed by Ismail and Roe (2009). Set ξ = y / x. Then, we have\n\n(y - x) / log(y / x) = (x + y) / log(ξ) * (ξ - 1) / (ξ + 1)\n\nSet f = (ξ - 1) / (ξ + 1) = (y - x) / (x + y). Then, we use the expansion\n\nlog(ξ) = 2 * f * (1 + f^2 / 3 + f^4 / 5 + f^6 / 7) + O(ξ^9)\n\nInserting the first few terms of this expansion yields\n\n(y - x) / log(ξ) ≈ (x + y) * f / (2 * f * (1 + f^2 / 3 + f^4 / 5 + f^6 / 7))\n = (x + y) / (2 + 2/3 * f^2 + 2/5 * f^4 + 2/7 * f^6)\n\nSince divisions are usually more expensive on modern hardware than multiplications (Agner Fog), we try to avoid computing two divisions. Thus, we use\n\nf^2 = (y - x)^2 / (x + y)^2\n = (x * (x - 2 * y) + y * y) / (x * (x + 2 * y) + y * y)\n\nGiven ε = 1.0e-4, we use the following algorithm.\n\nif f^2 < ε\n # use the expansion above\nelse\n # use the direct formula (y - x) / log(y / x)\nend\n\nReferences\n\nIsmail, Roe (2009). Affordable, entropy-consistent Euler flux functions II: Entropy production at shocks. DOI: 10.1016/j.jcp.2009.04.021\nAgner Fog. Lists of instruction latencies, throughputs and micro-operation breakdowns for Intel, AMD, and VIA CPUs. https://www.agner.org/optimize/instruction_tables.pdf\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_adaptive_time_integrator!-Tuple{Any, AbstractString}","page":"Trixi.jl","title":"Trixi.load_adaptive_time_integrator!","text":"load_adaptive_time_integrator!(integrator, restart_file::AbstractString)\n\nLoad the context information for time integrators with error-based step size control saved in a restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_dt-Tuple{AbstractString}","page":"Trixi.jl","title":"Trixi.load_dt","text":"load_dt(restart_file::AbstractString)\n\nLoad the time step size (dt in OrdinaryDiffEq.jl) saved in a restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_mesh-Tuple{AbstractString}","page":"Trixi.jl","title":"Trixi.load_mesh","text":"load_mesh(restart_file::AbstractString; n_cells_max)\n\nLoad the mesh from the restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_time-Tuple{AbstractString}","page":"Trixi.jl","title":"Trixi.load_time","text":"load_time(restart_file::AbstractString)\n\nLoad the time saved in a restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_timestep!-Tuple{Any, AbstractString}","page":"Trixi.jl","title":"Trixi.load_timestep!","text":"load_timestep!(integrator, restart_file::AbstractString)\n\nLoad the time step number saved in a restart_file and assign it to both the time step number and and the number of accepted steps (iter and stats.naccept in OrdinaryDiffEq.jl, respectively) in integrator.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.load_timestep-Tuple{AbstractString}","page":"Trixi.jl","title":"Trixi.load_timestep","text":"load_timestep(restart_file::AbstractString)\n\nLoad the time step number (iter in OrdinaryDiffEq.jl) saved in a restart_file.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.max-Tuple","page":"Trixi.jl","title":"Trixi.max","text":"max(x, y, ...)\n\nReturn the maximum of the arguments. See also the maximum function to take the maximum element from a collection.\n\nThis version in Trixi.jl is semantically equivalent to Base.max but may be implemented differently. In particular, it may avoid potentially expensive checks necessary in the presence of NaNs (or signed zeros).\n\nExamples\n\njulia> max(2, 5, 1)\n5\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.max_abs_speed_naive","page":"Trixi.jl","title":"Trixi.max_abs_speed_naive","text":"max_abs_speed_naive(u_ll, u_rr, orientation::Integer, equations)\nmax_abs_speed_naive(u_ll, u_rr, normal_direction::AbstractVector, equations)\n\nSimple and fast estimate of the maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, based only on the local wave speeds associated to u_ll and u_rr.\n\nFor non-integer arguments normal_direction in one dimension, max_abs_speed_naive returns abs(normal_direction[1]) * max_abs_speed_naive(u_ll, u_rr, 1, equations).\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.min-Tuple","page":"Trixi.jl","title":"Trixi.min","text":"min(x, y, ...)\n\nReturn the minimum of the arguments. See also the minimum function to take the minimum element from a collection.\n\nThis version in Trixi.jl is semantically equivalent to Base.min but may be implemented differently. In particular, it may avoid potentially expensive checks necessary in the presence of NaNs (or signed zeros).\n\nExamples\n\njulia> min(2, 5, 1)\n1\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.min_max_speed_chen_noelle-Tuple{Any, Any, Integer, ShallowWaterEquations1D}","page":"Trixi.jl","title":"Trixi.min_max_speed_chen_noelle","text":"min_max_speed_chen_noelle(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations1D)\n\nThe approximated speeds for the HLL type numerical flux used by Chen and Noelle for their hydrostatic reconstruction. As they state in the paper, these speeds are chosen for the numerical flux to ensure positivity and to satisfy an entropy inequality.\n\nFurther details on this hydrostatic reconstruction and its motivation can be found in\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.min_max_speed_chen_noelle-Tuple{Any, Any, Integer, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.min_max_speed_chen_noelle","text":"min_max_speed_chen_noelle(u_ll, u_rr, orientation::Integer,\n equations::ShallowWaterEquations2D)\nmin_max_speed_chen_noelle(u_ll, u_rr, normal_direction::AbstractVector,\n equations::ShallowWaterEquations2D)\n\nSpecial estimate of the minimal and maximal wave speed of the shallow water equations for the left and right states u_ll, u_rr. These approximate speeds are used for the HLL-type numerical flux flux_hll_chen_noelle. These wave speed estimates together with a particular hydrostatic reconstruction technique guarantee that the numerical flux is positive and satisfies an entropy inequality.\n\nFurther details on this hydrostatic reconstruction and its motivation can be found in the reference below. The definition of the wave speeds are given in Equation (2.20).\n\nGuoxian Chen and Sebastian Noelle (2017) A new hydrostatic reconstruction scheme based on subcell reconstructions DOI:10.1137/15M1053074\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.min_max_speed_davis","page":"Trixi.jl","title":"Trixi.min_max_speed_davis","text":"min_max_speed_davis(u_ll, u_rr, orientation::Integer, equations)\nmin_max_speed_davis(u_ll, u_rr, normal_direction::AbstractVector, equations)\n\nSimple and fast estimates of the minimal and maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, usually based only on the local wave speeds associated to u_ll and u_rr.\n\nS.F. Davis (1988) Simplified Second-Order Godunov-Type Methods DOI: 10.1137/0909030\n\nSee also FluxHLL, min_max_speed_naive, min_max_speed_einfeldt.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.min_max_speed_einfeldt","page":"Trixi.jl","title":"Trixi.min_max_speed_einfeldt","text":"min_max_speed_einfeldt(u_ll, u_rr, orientation::Integer, equations)\nmin_max_speed_einfeldt(u_ll, u_rr, normal_direction::AbstractVector, equations)\n\nMore advanced mininmal and maximal wave speed computation based on\n\nBernd Einfeldt (1988) On Godunov-type methods for gas dynamics. DOI: 10.1137/0725021\nBernd Einfeldt, Claus-Dieter Munz, Philip L. Roe and Björn Sjögreen (1991) On Godunov-type methods near low densities. DOI: 10.1016/0021-9991(91)90211-3\n\noriginally developed for the compressible Euler equations. A compact representation can be found in this lecture notes, eq. (9.28).\n\nSee also FluxHLL, min_max_speed_naive, min_max_speed_davis.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.min_max_speed_naive","page":"Trixi.jl","title":"Trixi.min_max_speed_naive","text":"min_max_speed_naive(u_ll, u_rr, orientation::Integer, equations)\nmin_max_speed_naive(u_ll, u_rr, normal_direction::AbstractVector, equations)\n\nSimple and fast estimate(!) of the minimal and maximal wave speed of the Riemann problem with left and right states u_ll, u_rr, usually based only on the local wave speeds associated to u_ll and u_rr.\n\nAmiram Harten, Peter D. Lax, Bram van Leer (1983) On Upstream Differencing and Godunov-Type Schemes for Hyperbolic Conservation Laws DOI: 10.1137/1025002\n\nSee also FluxHLL, min_max_speed_davis, min_max_speed_einfeldt.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.min_max_speed_naive-Tuple{Any, Any, Integer, IdealGlmMhdEquations1D}","page":"Trixi.jl","title":"Trixi.min_max_speed_naive","text":"min_max_speed_naive(u_ll, u_rr, orientation::Integer, equations::IdealGlmMhdEquations1D)\n\nCalculate minimum and maximum wave speeds for HLL-type fluxes as in\n\nLi (2005) An HLLC Riemann solver for magneto-hydrodynamics DOI: 10.1016/j.jcp.2004.08.020.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.min_max_speed_naive-Tuple{Any, Any, Integer, IdealGlmMhdEquations2D}","page":"Trixi.jl","title":"Trixi.min_max_speed_naive","text":"min_max_speed_naive(u_ll, u_rr, orientation::Integer, equations::IdealGlmMhdEquations2D)\n\nCalculate minimum and maximum wave speeds for HLL-type fluxes as in\n\nLi (2005) An HLLC Riemann solver for magneto-hydrodynamics DOI: 10.1016/j.jcp.2004.08.020.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.min_max_speed_naive-Tuple{Any, Any, Integer, IdealGlmMhdEquations3D}","page":"Trixi.jl","title":"Trixi.min_max_speed_naive","text":"min_max_speed_naive(u_ll, u_rr, orientation_or_normal_direction, equations::IdealGlmMhdEquations3D)\n\nCalculate minimum and maximum wave speeds for HLL-type fluxes as in\n\nLi (2005) An HLLC Riemann solver for magneto-hydrodynamics DOI: 10.1016/j.jcp.2004.08.020\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.multiply_dimensionwise-Tuple{AbstractMatrix, AbstractMatrix}","page":"Trixi.jl","title":"Trixi.multiply_dimensionwise","text":"multiply_dimensionwise(matrix::AbstractMatrix, data_in::AbstractArray{<:Any, NDIMS+1})\n\nMultiply the array data_in by matrix in each coordinate direction, where data_in is assumed to have the first coordinate for the number of variables and the remaining coordinates are multiplied by matrix.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ndofs-Tuple{Trixi.AbstractSemidiscretization}","page":"Trixi.jl","title":"Trixi.ndofs","text":"ndofs(semi::AbstractSemidiscretization)\n\nReturn the number of degrees of freedom associated with each scalar variable.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.negative_part-Tuple{Any}","page":"Trixi.jl","title":"Trixi.negative_part","text":"negative_part(x)\n\nReturn x if x is negative, else zero. In other words, return (x - abs(x)) / 2 for real numbers x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ode_default_options-Tuple{}","page":"Trixi.jl","title":"Trixi.ode_default_options","text":"ode_default_options()\n\nReturn the default options for OrdinaryDiffEq's solve. Pass ode_default_options()... to solve to only return the solution at the final time and enable MPI aware error-based step size control, whenever MPI is used. For example, use solve(ode, alg; ode_default_options()...).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ode_norm-Tuple{Number, Any}","page":"Trixi.jl","title":"Trixi.ode_norm","text":"ode_norm(u, t)\n\nImplementation of the weighted L2 norm of Hairer and Wanner used for error-based step size control in OrdinaryDiffEq.jl. This function is aware of MPI and uses global MPI communication when running in parallel.\n\nYou must pass this function as a keyword argument internalnorm=ode_norm to OrdinaryDiffEq.jl's solve when using error-based step size control with MPI parallel execution of Trixi.jl.\n\nSee the \"Advanced Adaptive Stepsize Control\" section of the documentation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.ode_unstable_check-NTuple{4, Any}","page":"Trixi.jl","title":"Trixi.ode_unstable_check","text":"ode_unstable_check(dt, u, semi, t)\n\nImplementation of the basic check for instability used in OrdinaryDiffEq.jl. Instead of checking something like any(isnan, u), this function just checks isnan(dt). This helps when using MPI parallelization, since no additional global communication is required and all ranks will return the same result.\n\nYou should pass this function as a keyword argument unstable_check=ode_unstable_check to OrdinaryDiffEq.jl's solve when using error-based step size control with MPI parallel execution of Trixi.jl.\n\nSee the \"Miscellaneous\" section of the documentation.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.partition!-Tuple{TreeMesh{NDIMS, <:Trixi.ParallelTree{NDIMS}} where NDIMS}","page":"Trixi.jl","title":"Trixi.partition!","text":"partition!(mesh::ParallelTreeMesh, allow_coarsening=true)\n\nPartition mesh using a static domain decomposition algorithm based on leaf cell count and tree structure. If allow_coarsening is true, the algorithm will keep leaf cells together on one rank when needed for local coarsening (i.e. when all children of a cell are leaves).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.positive_part-Tuple{Any}","page":"Trixi.jl","title":"Trixi.positive_part","text":"positive_part(x)\n\nReturn x if x is positive, else zero. In other words, return (x + abs(x)) / 2 for real numbers x.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.pressure-Tuple{Real, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.pressure","text":"pressure(rho::Real, equations::LatticeBoltzmannEquations2D)\npressure(u, equations::LatticeBoltzmannEquations2D)\n\nCalculate the macroscopic pressure from the density rho or the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.pressure-Tuple{Real, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.pressure","text":"pressure(rho::Real, equations::LatticeBoltzmannEquations3D)\npressure(u, equations::LatticeBoltzmannEquations3D)\n\nCalculate the macroscopic pressure from the density rho or the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.prim2cons","page":"Trixi.jl","title":"Trixi.prim2cons","text":"prim2cons(u, equations)\n\nConvert the primitive variables u to the conserved variables for a given set of equations. u is a vector type of the correct length nvariables(equations). Notice the function doesn't include any error checks for the purpose of efficiency, so please make sure your input is correct. The inverse conversion is performed by cons2prim.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.residual_steady_state-Tuple{Any, HyperbolicDiffusionEquations3D}","page":"Trixi.jl","title":"Trixi.residual_steady_state","text":"residual_steady_state(du, ::AbstractHyperbolicDiffusionEquations)\n\nUsed to determine the termination criterion of a SteadyStateCallback. For hyperbolic diffusion, this checks convergence of the potential phi.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.rotate_from_x","page":"Trixi.jl","title":"Trixi.rotate_from_x","text":"rotate_from_x(u, normal, equations)\n\nApply the rotation that maps the x-axis onto normal to the convservative variables u. This is used by FluxRotated to calculate the numerical flux of rotationally invariant equations in arbitrary normal directions.\n\nSee also: rotate_to_x\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.rotate_to_x","page":"Trixi.jl","title":"Trixi.rotate_to_x","text":"rotate_to_x(u, normal, equations)\n\nApply the rotation that maps normal onto the x-axis to the convservative variables u. This is used by FluxRotated to calculate the numerical flux of rotationally invariant equations in arbitrary normal directions.\n\nSee also: rotate_from_x\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.save_plot-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.save_plot","text":"save_plot(plot_data, variable_names;\n show_mesh=true, plot_arguments=Dict{Symbol,Any}(),\n time=nothing, timestep=nothing)\n\nVisualize the plot data object provided in plot_data and save result as a PNG file in the out directory, plotting only the variables in variable_names and, optionally, the mesh (if show_mesh is true). Additionally, plot_arguments will be unpacked and passed as keyword arguments to the Plots.plot command.\n\nThe timestep is used in the filename. time is currently unused by this function.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nSee also: VisualizationCallback, show_plot\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.show_plot-Tuple{Any, Any}","page":"Trixi.jl","title":"Trixi.show_plot","text":"show_plot(plot_data, variable_names;\n show_mesh=true, plot_arguments=Dict{Symbol,Any}(),\n time=nothing, timestep=nothing)\n\nVisualize the plot data object provided in plot_data and display result, plotting only the variables in variable_names and, optionally, the mesh (if show_mesh is true). Additionally, plot_arguments will be unpacked and passed as keyword arguments to the Plots.plot command.\n\nThis function is the default plot_creator argument for the VisualizationCallback. time and timestep are currently unused by this function.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\nSee also: VisualizationCallback, save_plot\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.solve","page":"Trixi.jl","title":"Trixi.solve","text":"solve(ode, alg; dt, callbacks, kwargs...)\n\nThe following structures and methods provide the infrastructure for SSP Runge-Kutta methods of type SimpleAlgorithmSSP.\n\nwarning: Experimental implementation\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, AcousticPerturbationEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::AcousticPerturbationEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::CompressibleEulerEquations1D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::CompressibleEulerEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::CompressibleEulerEquations3D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::CompressibleEulerMulticomponentEquations1D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::CompressibleEulerMulticomponentEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, InviscidBurgersEquation1D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::InviscidBurgersEquation1D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, PolytropicEulerEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::PolytropicEulerEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, ShallowWaterEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::ShallowWaterEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\nThis manufactured solution source term is specifically designed for the bottom topography function b(x,y) = 2 + 0.5 * sin(sqrt(2)*pi*x) + 0.5 * sin(sqrt(2)*pi*y) as defined in initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, ShallowWaterEquationsQuasi1D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::ShallowWaterEquationsQuasi1D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\nThis manufactured solution source term is specifically designed for the bottom topography function b(x) = 0.2 - 0.05 * sin(sqrt(2) * pi *x[1]) and channel width 'a(x)= 1 + 0.1 * cos(sqrt(2) * pi * x[1])' as defined in initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, ShallowWaterTwoLayerEquations1D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::ShallowWaterTwoLayerEquations1D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test (and BoundaryConditionDirichlet(initial_condition_convergence_test) in non-periodic domains).\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_convergence_test-Tuple{Any, Any, Any, ShallowWaterTwoLayerEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_convergence_test","text":"source_terms_convergence_test(u, x, t, equations::ShallowWaterTwoLayerEquations2D)\n\nSource terms used for convergence tests in combination with initial_condition_convergence_test.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_eoc_test_coupled_euler_gravity-Tuple{Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_eoc_test_coupled_euler_gravity","text":"source_terms_eoc_test_coupled_euler_gravity(u, x, t, equations::CompressibleEulerEquations2D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with initial_condition_eoc_test_coupled_euler_gravity.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_eoc_test_coupled_euler_gravity-Tuple{Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.source_terms_eoc_test_coupled_euler_gravity","text":"source_terms_eoc_test_coupled_euler_gravity(u, x, t, equations::CompressibleEulerEquations3D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with initial_condition_eoc_test_coupled_euler_gravity.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_eoc_test_euler-Tuple{Any, Any, Any, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_eoc_test_euler","text":"source_terms_eoc_test_euler(u, x, t, equations::CompressibleEulerEquations2D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with initial_condition_eoc_test_coupled_euler_gravity.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_eoc_test_euler-Tuple{Any, Any, Any, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.source_terms_eoc_test_euler","text":"source_terms_eoc_test_euler(u, x, t, equations::CompressibleEulerEquations3D)\n\nSetup used for convergence tests of the Euler equations with self-gravity used in\n\nMichael Schlottke-Lakemper, Andrew R. Winters, Hendrik Ranocha, Gregor J. Gassner (2020) A purely hyperbolic discontinuous Galerkin approach for self-gravitating gas dynamics arXiv: 2008.10593\n\nin combination with initial_condition_eoc_test_coupled_euler_gravity.\n\nnote: Note\nThis method is to be used for testing pure Euler simulations with analytic self-gravity. If you intend to do coupled Euler-gravity simulations, you need to use source_terms_eoc_test_coupled_euler_gravity instead.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_harmonic-Tuple{Any, Any, Any, HyperbolicDiffusionEquations1D}","page":"Trixi.jl","title":"Trixi.source_terms_harmonic","text":"source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations1D)\n\nSource term that only includes the forcing from the hyperbolic diffusion system.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_harmonic-Tuple{Any, Any, Any, HyperbolicDiffusionEquations2D}","page":"Trixi.jl","title":"Trixi.source_terms_harmonic","text":"source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations2D)\n\nSource term that only includes the forcing from the hyperbolic diffusion system.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_harmonic-Tuple{Any, Any, Any, HyperbolicDiffusionEquations3D}","page":"Trixi.jl","title":"Trixi.source_terms_harmonic","text":"source_terms_harmonic(u, x, t, equations::HyperbolicDiffusionEquations3D)\n\nSource term that only includes the forcing from the hyperbolic diffusion system.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.source_terms_poisson_nonperiodic-Tuple{Any, Any, Any, HyperbolicDiffusionEquations1D}","page":"Trixi.jl","title":"Trixi.source_terms_poisson_nonperiodic","text":"source_terms_poisson_nonperiodic(u, x, t,\n equations::HyperbolicDiffusionEquations1D)\n\nSource terms that include the forcing function f(x) and right hand side for the hyperbolic diffusion system that is used with initial_condition_poisson_nonperiodic and boundary_condition_poisson_nonperiodic.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_coirier_vanleer-Tuple{Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.splitting_coirier_vanleer","text":"splitting_coirier_vanleer(u, orientation::Integer,\n equations::CompressibleEulerEquations1D)\nsplitting_coirier_vanleer(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations1D)\n\nSplitting of the compressible Euler flux from Coirier and van Leer. The splitting has correction terms in the pressure splitting as well as the mass and energy flux components. The motivation for these corrections are to handle flows at the low Mach number limit.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nWilliam Coirier and Bram van Leer (1991) Numerical flux formulas for the Euler and Navier-Stokes equations. II - Progress in flux-vector splitting DOI: 10.2514/6.1991-1566\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_lax_friedrichs-Tuple{Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.splitting_lax_friedrichs","text":"splitting_lax_friedrichs(u, orientation::Integer,\n equations::CompressibleEulerEquations2D)\nsplitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations2D)\n\nNaive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) similar to a flux splitting one would apply, e.g., to Burgers' equation.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_lax_friedrichs-Tuple{Any, Integer, InviscidBurgersEquation1D}","page":"Trixi.jl","title":"Trixi.splitting_lax_friedrichs","text":"splitting_lax_friedrichs(u, orientation::Integer,\n equations::InviscidBurgersEquation1D)\nsplitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::InviscidBurgersEquation1D)\n\nNaive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) where λ = abs(u).\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_lax_friedrichs-Tuple{Any, Integer, LinearScalarAdvectionEquation1D}","page":"Trixi.jl","title":"Trixi.splitting_lax_friedrichs","text":"splitting_lax_friedrichs(u, orientation::Integer,\n equations::LinearScalarAdvectionEquation1D)\nsplitting_lax_friedrichs(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::LinearScalarAdvectionEquation1D)\n\nNaive local Lax-Friedrichs style flux splitting of the form f⁺ = 0.5 (f + λ u) and f⁻ = 0.5 (f - λ u) where λ is the absolute value of the advection velocity.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_steger_warming-Tuple{Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.splitting_steger_warming","text":"splitting_steger_warming(u, orientation::Integer,\n equations::CompressibleEulerEquations1D)\nsplitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations1D)\n\nSplitting of the compressible Euler flux of Steger and Warming.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nJoseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_steger_warming-Tuple{Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.splitting_steger_warming","text":"splitting_steger_warming(u, orientation::Integer,\n equations::CompressibleEulerEquations2D)\nsplitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations2D)\n\nSplitting of the compressible Euler flux of Steger and Warming.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nJoseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_steger_warming-Tuple{Any, Integer, CompressibleEulerEquations3D}","page":"Trixi.jl","title":"Trixi.splitting_steger_warming","text":"splitting_steger_warming(u, orientation::Integer,\n equations::CompressibleEulerEquations3D)\nsplitting_steger_warming(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations3D)\n\nSplitting of the compressible Euler flux of Steger and Warming.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nJoseph L. Steger and R. F. Warming (1979) Flux Vector Splitting of the Inviscid Gasdynamic Equations With Application to Finite Difference Methods NASA Technical Memorandum\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_vanleer_haenel-Tuple{Any, Integer, CompressibleEulerEquations1D}","page":"Trixi.jl","title":"Trixi.splitting_vanleer_haenel","text":"splitting_vanleer_haenel(u, orientation::Integer,\n equations::CompressibleEulerEquations1D)\nsplitting_vanleer_haenel(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations1D)\n\nSplitting of the compressible Euler flux from van Leer. This splitting further contains a reformulation due to Hänel et al. where the energy flux uses the enthalpy. The pressure splitting is independent from the splitting of the convective terms. As such there are many pressure splittings suggested across the literature. We implement the 'p4' variant suggested by Liou and Steffen as it proved the most robust in practice.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nBram van Leer (1982) Flux-Vector Splitting for the Euler Equation DOI: 10.1007/978-3-642-60543-7_5\nD. Hänel, R. Schwane and G. Seider (1987) On the accuracy of upwind schemes for the solution of the Navier-Stokes equations DOI: 10.2514/6.1987-1105\nMeng-Sing Liou and Chris J. Steffen, Jr. (1991) High-Order Polynomial Expansions (HOPE) for Flux-Vector Splitting NASA Technical Memorandum\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.splitting_vanleer_haenel-Tuple{Any, Integer, CompressibleEulerEquations2D}","page":"Trixi.jl","title":"Trixi.splitting_vanleer_haenel","text":"splitting_vanleer_haenel(u, orientation::Integer,\n equations::CompressibleEulerEquations2D)\nsplitting_vanleer_haenel(u, which::Union{Val{:minus}, Val{:plus}}\n orientation::Integer,\n equations::CompressibleEulerEquations2D)\n\nSplitting of the compressible Euler flux from van Leer. This splitting further contains a reformulation due to Hänel et al. where the energy flux uses the enthalpy. The pressure splitting is independent from the splitting of the convective terms. As such there are many pressure splittings suggested across the literature. We implement the 'p4' variant suggested by Liou and Steffen as it proved the most robust in practice.\n\nReturns a tuple of the fluxes \"minus\" (associated with waves going into the negative axis direction) and \"plus\" (associated with waves going into the positive axis direction). If only one of the fluxes is required, use the function signature with argument which set to Val{:minus}() or Val{:plus}().\n\nwarning: Experimental implementation (upwind SBP)\nThis is an experimental feature and may change in future releases.\n\nReferences\n\nBram van Leer (1982) Flux-Vector Splitting for the Euler Equation DOI: 10.1007/978-3-642-60543-7_5\nD. Hänel, R. Schwane and G. Seider (1987) On the accuracy of upwind schemes for the solution of the Navier-Stokes equations DOI: 10.2514/6.1987-1105\nMeng-Sing Liou and Chris J. Steffen, Jr. (1991) High-Order Polynomial Expansions (HOPE) for Flux-Vector Splitting NASA Technical Memorandum\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.stolarsky_mean-Tuple{Any, Any, Any}","page":"Trixi.jl","title":"Trixi.stolarsky_mean","text":"stolarsky_mean(x, y, gamma)\n\nCompute an instance of a weighted Stolarsky mean of the form\n\nstolarsky_mean(x, y, gamma) = (gamma - 1)/gamma * (y^gamma - x^gamma) / (y^(gamma-1) - x^(gamma-1))\n\nwhere gamma > 1.\n\nProblem: The formula above has a removable singularity at x == y. Thus, some care must be taken to implement it correctly without problems or loss of accuracy when x ≈ y. Here, we use the approach proposed by Winters et al. (2020). Set f = (y - x) / (y + x) and g = gamma (for compact notation). Then, we use the expansions\n\n((1+f)^g - (1-f)^g) / g = 2*f + (g-1)(g-2)/3 * f^3 + (g-1)(g-2)(g-3)(g-4)/60 * f^5 + O(f^7)\n\nand\n\n((1+f)^(g-1) - (1-f)^(g-1)) / (g-1) = 2*f + (g-2)(g-3)/3 * f^3 + (g-2)(g-3)(g-4)(g-5)/60 * f^5 + O(f^7)\n\nInserting the first few terms of these expansions and performing polynomial long division we find that\n\nstolarsky_mean(x, y, gamma) ≈ (y + x) / 2 * (1 + (g-2)/3 * f^2 - (g+1)(g-2)(g-3)/45 * f^4 + (g+1)(g-2)(g-3)(2g(g-2)-9)/945 * f^6)\n\nSince divisions are usually more expensive on modern hardware than multiplications (Agner Fog), we try to avoid computing two divisions. Thus, we use\n\nf^2 = (y - x)^2 / (x + y)^2\n = (x * (x - 2 * y) + y * y) / (x * (x + 2 * y) + y * y)\n\nGiven ε = 1.0e-4, we use the following algorithm.\n\nif f^2 < ε\n # use the expansion above\nelse\n # use the direct formula (gamma - 1)/gamma * (y^gamma - x^gamma) / (y^(gamma-1) - x^(gamma-1))\nend\n\nReferences\n\nAndrew R. Winters, Christof Czernik, Moritz B. Schily & Gregor J. Gassner (2020) Entropy stable numerical approximations for the isothermal and polytropic Euler equations DOI: 10.1007/s10543-019-00789-w\nAgner Fog. Lists of instruction latencies, throughputs and micro-operation breakdowns for Intel, AMD, and VIA CPUs. https://www.agner.org/optimize/instruction_tables.pdf\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.totalgamma-Tuple{Any, CompressibleEulerMulticomponentEquations1D}","page":"Trixi.jl","title":"Trixi.totalgamma","text":"totalgamma(u, equations::CompressibleEulerMulticomponentEquations1D)\n\nFunction that calculates the total gamma out of all partial gammas using the partial density fractions as well as the partial specific heats at constant volume.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.totalgamma-Tuple{Any, CompressibleEulerMulticomponentEquations2D}","page":"Trixi.jl","title":"Trixi.totalgamma","text":"totalgamma(u, equations::CompressibleEulerMulticomponentEquations2D)\n\nFunction that calculates the total gamma out of all partial gammas using the partial density fractions as well as the partial specific heats at constant volume.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.trixi_include-Tuple{Module, AbstractString}","page":"Trixi.jl","title":"Trixi.trixi_include","text":"trixi_include([mod::Module=Main,] elixir::AbstractString; kwargs...)\n\ninclude the file elixir and evaluate its content in the global scope of module mod. You can override specific assignments in elixir by supplying keyword arguments. It's basic purpose is to make it easier to modify some parameters while running Trixi.jl from the REPL. Additionally, this is used in tests to reduce the computational burden for CI while still providing examples with sensible default values for users.\n\nBefore replacing assignments in elixir, the keyword argument maxiters is inserted into calls to solve and Trixi.solve with it's default value used in the SciML ecosystem for ODEs, see the \"Miscellaneous\" section of the documentation.\n\nExamples\n\njulia> redirect_stdout(devnull) do\n trixi_include(@__MODULE__, joinpath(examples_dir(), \"tree_1d_dgsem\", \"elixir_advection_extended.jl\"),\n tspan=(0.0, 0.1))\n sol.t[end]\n end\n[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.\n0.1\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.uses_amr-Tuple{Any}","page":"Trixi.jl","title":"Trixi.uses_amr","text":"uses_amr(callback)\n\nChecks whether the provided callback or CallbackSet is an AMRCallback or contains one.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.varnames","page":"Trixi.jl","title":"Trixi.varnames","text":"varnames(conversion_function, equations)\n\nReturn the list of variable names when applying conversion_function to the conserved variables associated to equations. This function is mainly used internally to determine output to screen and for IO, e.g., for the AnalysisCallback and the SaveSolutionCallback. Common choices of the conversion_function are cons2cons and cons2prim.\n\n\n\n\n\n","category":"function"},{"location":"reference-trixi/#Trixi.velocity-Tuple{Any, Integer, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.velocity","text":"velocity(u, orientation, equations::LatticeBoltzmannEquations2D)\n\nCalculate the macroscopic velocity for the given orientation (1 -> x, 2 -> y) from the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.velocity-Tuple{Any, Integer, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.velocity","text":"velocity(u, orientation, equations::LatticeBoltzmannEquations3D)\n\nCalculate the macroscopic velocity for the given orientation (1 -> x, 2 -> y, 3 -> z) from the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.velocity-Tuple{Any, LatticeBoltzmannEquations2D}","page":"Trixi.jl","title":"Trixi.velocity","text":"velocity(u, equations::LatticeBoltzmannEquations2D)\n\nCalculate the macroscopic velocity vector from the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.velocity-Tuple{Any, LatticeBoltzmannEquations3D}","page":"Trixi.jl","title":"Trixi.velocity","text":"velocity(u, equations::LatticeBoltzmannEquations3D)\n\nCalculate the macroscopic velocity vector from the particle distribution functions u.\n\n\n\n\n\n","category":"method"},{"location":"reference-trixi/#Trixi.@autoinfiltrate","page":"Trixi.jl","title":"Trixi.@autoinfiltrate","text":"@autoinfiltrate\n@autoinfiltrate condition::Bool\n\nInvoke the @infiltrate macro of the package Infiltrator.jl to create a breakpoint for ad-hoc interactive debugging in the REPL. If the optional argument condition is given, the breakpoint is only enabled if condition evaluates to true.\n\nAs opposed to using Infiltrator.@infiltrate directly, this macro does not require Infiltrator.jl to be added as a dependency to Trixi.jl. As a bonus, the macro will also attempt to load the Infiltrator module if it has not yet been loaded manually.\n\nNote: For this macro to work, the Infiltrator.jl package needs to be installed in your current Julia environment stack.\n\nSee also: Infiltrator.jl\n\nwarning: Internal use only\nPlease note that this macro is intended for internal use only. It is not part of the public API of Trixi.jl, and it thus can altered (or be removed) at any time without it being considered a breaking change.\n\n\n\n\n\n","category":"macro"},{"location":"reference-trixi/#Trixi.@threaded-Tuple{Any}","page":"Trixi.jl","title":"Trixi.@threaded","text":"@threaded for ... end\n\nSemantically the same as Threads.@threads when iterating over a AbstractUnitRange but without guarantee that the underlying implementation uses Threads.@threads or works for more general for loops. In particular, there may be an additional check whether only one thread is used to reduce the overhead of serial execution or the underlying threading capabilities might be provided by other packages such as Polyester.jl.\n\nwarn: Warn\nThis macro does not necessarily work for general for loops. For example, it does not necessarily support general iterables such as eachline(filename).\n\nSome discussion can be found at https://discourse.julialang.org/t/overhead-of-threads-threads/53964 and https://discourse.julialang.org/t/threads-threads-with-one-thread-how-to-remove-the-overhead/58435.\n\n\n\n\n\n","category":"macro"},{"location":"styleguide/#Style-guide","page":"Style guide","title":"Style guide","text":"","category":"section"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"Coding style is an inherently personal - and thus hotly contested - issue. Since code is usually \"written once, read often\", it helps regular developers, new users, and reviewers if code is formatted consistently. We therefore believe in the merit of using a common coding style throughout Trixi.jl, even at the expense that not everyone can be happy with every detailed style decision. If you came here because you are furious about our code formatting rules, here is a happy little whale for you to calm you down: 🐳","category":"page"},{"location":"styleguide/#Conventions","page":"Style guide","title":"Conventions","text":"","category":"section"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"The following lists a few coding conventions for Trixi.jl. Note that in addition to these conventions, we apply and enforce automated source code formatting (see below for more details):","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"Modules, types, structs with CamelCase.\nFunctions, variables with lowercase snake_case.\nIndentation with 4 spaces (never tabs!)\nMaximum line length (strictly): 92.\nFunctions that mutate their input are named with a trailing !.\nFunctions order their parameters similar to Julia Base.\nThe main modified argument comes first. For example, if the right-hand side du is modified, it should come first. If only the cache is modified, e.g., in prolong2interfaces! and its siblings, put the cache first.\nOtherwise, use the order mesh, equations, solver, cache.\nIf something needs to be specified in more detail for dispatch, put the additional argument before the general one that is specified in more detail. For example, we use have_nonconservative_terms(equations), equations and dg.mortar, dg.\nPrefer for i in ... to for i = ... for better semantic clarity and greater flexibility.\nExecutable code should only use ASCII characters.\nDocstrings and comments can and should use Unicode characters where it helps understanding.\nMultiline expressions should be explicitly grouped by parentheses and not rely on Julia's implicit line continuation syntax.\nWhen naming multiple functions of a single or similar category, prefer to put the general classification first and the specialization second. Example: Use flux_central instead of central_flux. This helps when searching for available functions on the REPL (e.g., when trying to find all flux functions).","category":"page"},{"location":"styleguide/#automated-source-code-formatting","page":"Style guide","title":"Automated source code formatting","text":"","category":"section"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"We use JuliaFormatter.jl to format the source code of Trixi.jl, which will also enforce some of the Conventions listed above (e.g., line length or indentation with 4 spaces are automatically handled, while capitalization of names is not). Our format is mostly based on the SciML-style formatting rules. For more details you can have a look at the current .JuliaFormatter.toml file that holds the configuration options we use for JuliaFormatter.jl.","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"Note that we expect all contributions to Trixi.jl to be formatted with JuliaFormatter.jl before being merged to the main branch. We ensure this by running a automated check on all PRs that verify that running JuliaFormatter.jl again will not change the source code.","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"To format your contributions before created a PR (or, at least, before requesting a review of your PR), you need to install JuliaFormatter.jl first by running","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"julia -e 'using Pkg; Pkg.add(\"JuliaFormatter\")'","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"You can then recursively format the core Julia files in the Trixi.jl repo by executing","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"julia -e 'using JuliaFormatter; format([\"benchmark\", \"ext\", \"src\", \"utils\"])'","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"from inside the Trixi.jl repository. For convenience, there is also a script you can directly run from your terminal shell, which will automatically install JuliaFormatter in a temporary environment and then run it:","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"utils/trixi-format.jl","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"You can get more information about using the convenience script by running it with the --help/-h flag.","category":"page"},{"location":"styleguide/#Checking-formatting-before-committing","page":"Style guide","title":"Checking formatting before committing","text":"","category":"section"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"It can be convenient to check the formatting of source code automatically before each commit. We use git-hooks for it and provide a pre-commit script in the utils folder. The script uses JuliaFormatter.jl just like formatting script that runs over the whole Trixi.jl directory. You can copy the pre-commit-script into .git/hooks/pre-commit and it will check your formatting before each commit. If errors are found the commit is aborted and you can add the corrections via","category":"page"},{"location":"styleguide/","page":"Style guide","title":"Style guide","text":"git add -p","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"EditURL = \"../../literate/src/files/scalar_linear_advection_1d.jl\"","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#scalar_linear_advection_1d","page":"1 Introduction to DG methods","title":"1: Introduction to DG methods","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"(Image: ) (Image: ) (Image: )","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"This tutorial is about how to set up a simple way to approximate the solution of a hyperbolic partial differential equation. First, we will implement a basic and naive algorithm. Then, we will use predefined features from Trixi.jl to show how you can use Trixi.jl on your own.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We will implement the scalar linear advection equation in 1D with the advection velocity 1.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u_t + u_x = 0 textfor tin mathbbR^+ xinOmega=-11","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We define the domain Omega by setting the boundaries.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"coordinates_min = -1.0 # minimum coordinate\ncoordinates_max = 1.0 # maximum coordinate","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We assume periodic boundaries and the following initial condition.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"initial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#The-discontinuous-Galerkin-collocation-spectral-element-method-(DGSEM)","page":"1 Introduction to DG methods","title":"The discontinuous Galerkin collocation spectral element method (DGSEM)","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/#i.-Discretization-of-the-physical-domain","page":"1 Introduction to DG methods","title":"i. Discretization of the physical domain","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To improve precision we want to approximate the solution on small parts of the physical domain. So, we split the domain Omega=-1 1 into elements Q_l of length dx.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"n_elements = 16 # number of elements\n\ndx = (coordinates_max - coordinates_min) / n_elements # length of one element","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To make the calculation more efficient and storing less information, we transform each element Q_l with center point x_l to a reference element E=-1 1","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Q_l=Bigx_l-fracdx2 x_l+fracdx2Big undersetx(xi)oversetxi(x)rightleftarrows -1 1","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"So, for every element the transformation from the reference domain to the physical domain is defined by","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"x(xi) = x_l + fracdx2 xi xiin-1 1","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Therefore,","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"beginalign*\nu = u(x(xi) t) \nu_x = u_xi fracdxidx 3pt\nfracdxidx = (x_xi)^-1 = frac2dx = J^-1 \nendalign*","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Here, J is the Jacobian determinant of the transformation.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Using this transformation, we can transform our equation for each element Q_l.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"fracdx2 u_t^Q_l + u_xi^Q_l = 0 text for tinmathbbR^+ xiin-1 1","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Here, u_t^Q_l and u_xi^Q_l denote the time and spatial derivatives of the solution on the element Q_l.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#ii.-Polynomial-approach","page":"1 Introduction to DG methods","title":"ii. Polynomial approach","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Now, we want to approximate the solution in each element Q_l by a polynomial of degree N. Since we transformed the equation, we can use the same polynomial approach for the reference coordinate xiin-1 1 in every physical element Q_l. This saves a lot of resources by reducing the amount of calculations needed and storing less information.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"For DGSEM we choose Lagrange basis functions l_j_j=0^N as our polynomial basis of degree N in -1 1. The solution in element Q_l can be approximated by","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u(x(xi) t)big_Q_l approx u^Q_l(xi t) = sum_j=0^N u_j^Q_l(t) l_j(xi)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"with N+1 coefficients u_j^Q_l_j=0^N. By construction the Lagrange basis has some useful advantages. This basis is defined by N+1 nodes, which fulfill a Kronecker property at the exact same nodes. Let xi_i_i=0^N be these nodes.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"l_j(xi_i) = delta_ij =\nbegincases\n1 textif i=j \n0 textelse\nendcases","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Because of this property, the polynomial coefficients are exact the values of u^Q_l at the nodes","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u^Q_l(xi_i t) = sum_j=0^N u_j^Q_l(t) underbracel_j(xi_i)_=delta_ij = u_i^Q_l(t)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Next, we want to select the nodes xi_i_i=0^N, which we use for the construction of the Lagrange polynomials. We choose the N+1 Gauss-Lobatto nodes, which are used for the Gaussian-Lobatto quadrature. These always contain the boundary points at -1 and +1 and are well suited as interpolation nodes. The corresponding weights will be referred to as w_j_j=0^N. In Trixi.jl the basis with Lagrange polynomials on Gauss-Lobatto nodes is already defined.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using Trixi\npolydeg = 3 #= polynomial degree = N =#\nbasis = LobattoLegendreBasis(polydeg)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"The Gauss-Lobatto nodes are","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"nodes = basis.nodes","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"with the corresponding weights","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"weights = basis.weights","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To illustrate how you can integrate using numerical quadrature with this Legendre-Gauss-Lobatto nodes, we give an example for f(x)=x^3. Since f is of degree 3, a polynomial interpolation with N=3 is exact. Therefore, the integral on -1 1 can be calculated by","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"beginalign*\nint_-1^1 f(x) dx = int_-1^1 Big( sum_j=0^3 f(xi_j)l_j(x) Big) dx\n= sum_j=0^3 f(xi_j) int_-1^1 l_j(x)dx \n= sum_j=0^3 f(xi_j) w_j\n= sum_j=0^3 xi_j^3 w_j\nendalign*","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Let's use our nodes and weights for N=3 and plug in","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"integral = sum(nodes.^3 .* weights)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Using this polynomial approach leads to the equation","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"fracdx2 dotu^Q_l(xi t) + u^Q_l(xi t) = 0","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"with dotu=fracpartialpartial tu and u=fracpartialpartial xu. To approximate the solution, we need to get the polynomial coefficients u_j^Q_l_j=0^N for every element Q_l.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"After defining all nodes, we can implement the spatial coordinate x and its initial value u0 for every node.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"x = Matrix{Float64}(undef, length(nodes), n_elements)\nfor element in 1:n_elements\n x_l = coordinates_min + (element - 1) * dx + dx/2\n for i in 1:length(nodes)\n ξ = nodes[i] # nodes in [-1, 1]\n x[i, element] = x_l + dx/2 * ξ\n end\nend\n\nu0 = initial_condition_sine_wave.(x)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To have a look at the initial sinus curve, we plot it.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using Plots\nplot(vec(x), vec(u0), label=\"initial condition\", legend=:topleft)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#iii.-Variational-formulation","page":"1 Introduction to DG methods","title":"iii. Variational formulation","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"After defining the equation and initial condition, we want to implement an algorithm to approximate the solution.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"From now on, we only write u instead of u^Q_l for simplicity, but consider that all the following calculation only concern one element. Multiplying the new equation with the smooth Lagrange polynomials l_i_i=0^N (test functions) and integrating over the reference element E=-11, we get the variational formulation of our transformed partial differential equation for i=0N:","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"beginalign*\nint_-1^1 Big( fracdx2 dotu(xi t) + u(xi t) Big) l_i(xi)dxi\n = underbracefracdx2 int_-1^1 dotu(xi t) l_i(xi)dxi_textTerm I + underbraceint_-1^1 u(xi t) l_i(xi)dxi_textTerm II = 0\nendalign*","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We deal with the two terms separately. We write int_-1 N^1 cdot dxi for the approximation of the integral using numerical quadrature with N+1 basis points. We use the Gauss-Lobatto nodes again. The numerical scalar product langlecdot cdotrangle_N is defined by langle f grangle_N = int_-1 N^1 f(xi) g(xi) dxi.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Term-I:","page":"1 Introduction to DG methods","title":"Term I:","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"In the following calculation we approximate the integral numerically with quadrature on the Gauss-Lobatto nodes xi_i_i=0^N and then use the Kronecker property of the Lagrange polynomials. This approach of using the same nodes for the interpolation and quadrature is called collocation.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"beginalign*\nfracdx2 int_-1^1 dotu(xi t) l_i(xi)dxi\napprox fracdx2 int_-1 N^1 dotu(xi t) l_i(xi)dxi \n= fracdx2 sum_k=0^N underbracedotu(xi_k t)_=dotu_k(t) underbracel_i(xi_k)_=delta_kiw_k \n= fracdx2 dotu_i(t) w_i\nendalign*","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We define the Legendre-Gauss-Lobatto (LGL) mass matrix M and by the Kronecker property follows:","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"M_ij = langle l_j l_irangle_N = delta_ij w_j ij=0N","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using LinearAlgebra\nM = diagm(weights)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Now, we can write the integral with this new matrix.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"fracdx2 int_-1 N^1 dotu(xi t) underlinel(xi)dxi = fracdx2 M underlinedotu(t)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"where underlinedotu = (dotu_0 dotu_N)^T and underlinel respectively.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Note: Since the LGL quadrature with N+1 nodes is exact up to functions of degree 2N-1 and dotu(xi t) l_i(xi) is of degree 2N, in general the following holds","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"int_-1^1 dotu(xi t) l_i(xi) dxi neq int_-1 N^1 dotu(xi t) l_i(xi) dxi","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"With an exact integration the mass matrix would be dense. Choosing numerical integrating and quadrature with the exact same nodes (collocation) leads to the sparse and diagonal mass matrix M. This is called mass lumping and has the big advantage of an easy invertation of the matrix.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Term-II:","page":"1 Introduction to DG methods","title":"Term II:","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We use spatial partial integration for the second term:","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"int_-1^1 u(xi t) l_i(xi) dxi = u l_i_-1^1 - int_-1^1 u l_idxi","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"The resulting integral can be solved exactly with LGL quadrature since the polynomial is now of degree 2N-1.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Again, we split the calculation in two steps.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Surface-term","page":"1 Introduction to DG methods","title":"Surface term","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"As mentioned before, we approximate the solution with a polynomial in every element. Therefore, in general the value of this approximation at the interfaces between two elements is not unique. To solve this problem we introduce the idea of the numerical flux u^*, which will give an exact value at the interfaces. One of many different approaches and definitions for the calculation of the numerical flux we will deal with in 4. Numerical flux.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u l_i_-1^1 = u^*big^1 l_i(+1) - u^*big_-1 l_i(-1)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Since the Gauss-Lobatto nodes contain the element boundaries -1 and +1, we can use the Kronecker property of l_i for the calculation of l_i(-1) and l_i(+1).","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u underlinel_-1^1 = u^*big^1 left(beginarrayc 0 vdots 0 1 endarrayright)\n- u^*big_-1 left(beginarrayc 1 0 vdots 0endarrayright)\n= B underlineu^*(t)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"with the boundary matrix","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"B = beginpmatrix\n-1 0 cdots 0\n0 0 cdots 0\nvdots vdots 0 0\n0 cdots 0 1\nendpmatrix\nqquadtextandqquad\nunderlineu^*(t) = left(beginarrayc u^*big_-1 0 vdots 0 u^*big^1endarrayright)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"B = diagm([-1; zeros(polydeg - 1); 1])","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Volume-term","page":"1 Introduction to DG methods","title":"Volume term","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"As mentioned before, the new integral can be solved exact since the function inside is of degree 2N-1.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"- int_-1^1 u l_idxi = - int_-1 N^1 u l_i dxi\n= - sum_k=0^N u(xi_k t) l_i(xi_k) w_k\n= - sum_k=0^N u_k(t) D_ki w_k","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"where D is the derivative matrix defined by D_ki = l_i(xi_k) for ik=0N.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"D = basis.derivative_matrix","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To show why this matrix is called the derivative matrix, we go back to our example f(x)=x^3. We calculate the derivation of f at the Gauss-Lobatto nodes xi_k_k=0^N with N=8.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"f_x=xi_k = Big( sum_j=0^8 f(xi_j) l_j(x) Big)_x=xi_k = sum_j=0^8 f(xi_j) l_j(xi_k)\n= sum_j=0^8 f(xi_j) D_kj","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"for k=0N and therefore, underlinef = D underlinef.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"basis_N8 = LobattoLegendreBasis(8)\nplot(vec(x), x -> 3 * x^2, label=\"f'\", lw=2)\nscatter!(basis_N8.nodes, basis_N8.derivative_matrix * basis_N8.nodes.^3, label=\"Df\", lw=3)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Combining the volume term for every i=0N results in","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"int_-1^1 u underlinel dxi = - D^T M underlineu(t)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Putting all parts together we get the following equation for the element Q_l","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"fracdx2 M underlinedotu(t) = - B underlineu^*(t) + D^T M underlineu(t)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"or equivalent","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"underlinedotu^Q_l(t) = frac2dx Big - M^-1 B underlineu^Q_l^*(t) + M^-1 D^T M underlineu^Q_l(t)Big","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"This is called the weak form of the DGSEM.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Note: For every element Q_l we get a system of N+1 ordinary differential equations to calculate N+1 coefficients. Since the numerical flux u^* is depending on extern values at the interfaces, the equation systems of adjacent elements are weakly linked.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#numerical_flux","page":"1 Introduction to DG methods","title":"iv. Numerical flux","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"As mentioned above, we still have to handle the problem of different values at the same point at the interfaces. This happens with the ideas of the numerical flux f^*(u)=u^*. The role of f^* might seem minor in this simple example, but is important for more complicated problems. There are two values at the same spatial coordinate. Let's say we are looking at the interface between the elements Q_l and Q_l+1, while both elements got N+1 nodes as defined before. We call the first value of the right element u_R=u_0^Q_l+1 and the last one of the left element u_L=u_N^Q_l. So, for the value of the numerical flux on that interface the following holds","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u^* = u^*(u_L u_R)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"These values are interpreted as start values of a so-called Riemann problem. There are many different (approximate) Riemann solvers available and useful for different problems. We will use the local Lax-Friedrichs flux.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"surface_flux = flux_lax_friedrichs","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"The only missing ingredient is the flux calculation at the boundaries -1 and +1.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"u^Q_first^*big_-1 = u^Q_first^*big_-1(u^bound(-1) u_R)\nquadtextandquad\nu^Q_last^*big^1 = u^Q_last^*big^1(u_L u^bound(1))","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"The boundaries are periodic, which means that the last value of the last element u^Q_last_N is used as u_L at the first interface and accordingly for the other boundary.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Now, we implement a function, that calculates underlinedotu^Q_l for the given matrices, underlineu and underlineu^*.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"function rhs!(du, u, x, t)\n # Reset du and flux matrix\n du .= zero(eltype(du))\n flux_numerical = copy(du)\n\n # Calculate interface and boundary fluxes, $u^* = (u^*|_{-1}, 0, ..., 0, u^*|^1)^T$\n # Since we use the flux Lax-Friedrichs from Trixi.jl, we have to pass some extra arguments.\n # Trixi.jl needs the equation we are dealing with and an additional `1`, that indicates the\n # first coordinate direction.\n equations = LinearScalarAdvectionEquation1D(1.0)\n for element in 2:n_elements-1\n # left interface\n flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)\n flux_numerical[end, element-1] = flux_numerical[1, element]\n # right interface\n flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)\n flux_numerical[1, element+1] = flux_numerical[end, element]\n end\n # boundary flux\n flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)\n flux_numerical[end, end] = flux_numerical[1, 1]\n\n # Calculate surface integrals, $- M^{-1} * B * u^*$\n for element in 1:n_elements\n du[:, element] -= (M \\ B) * flux_numerical[:, element]\n end\n\n # Calculate volume integral, $+ M^{-1} * D^T * M * u$\n for element in 1:n_elements\n flux = u[:, element]\n du[:, element] += (M \\ transpose(D)) * M * flux\n end\n\n # Apply Jacobian from mapping to reference element\n for element in 1:n_elements\n du[:, element] *= 2 / dx\n end\n\n return nothing\nend","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Combining all definitions and the function that calculates the right-hand side, we define the ODE and solve it until t=2 with OrdinaryDiffEq's solve function and the Runge-Kutta method RDPK3SpFSAL49(), which is optimized for discontinuous Galerkin methods and hyperbolic PDEs. We set some common error tolerances abstol=1.0e-6, reltol=1.0e-6 and pass save_everystep=false to avoid saving intermediate solution vectors in memory.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using OrdinaryDiffEq\ntspan = (0.0, 2.0)\node = ODEProblem(rhs!, u0, tspan, x)\n\nsol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)\n\nplot(vec(x), vec(sol.u[end]), label=\"solution at t=$(tspan[2])\", legend=:topleft, lw=3)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Alternative-Implementation-based-on-Trixi.jl","page":"1 Introduction to DG methods","title":"Alternative Implementation based on Trixi.jl","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Now, we implement the same example. But this time, we directly use the functionality that Trixi.jl provides.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using Trixi, OrdinaryDiffEq, Plots","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"First, define the equation with a advection_velocity of 1.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"advection_velocity = 1.0\nequations = LinearScalarAdvectionEquation1D(advection_velocity)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Then, create a DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux. The implementation of the basis and the numerical flux is now already done.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We will now create a mesh with 16 elements for the physical domain [-1, 1] with periodic boundaries. We use Trixi.jl's standard mesh TreeMesh. Since it's limited to hypercube domains, we choose 2^4=16 elements. The mesh type supports AMR, that' why n_cells_max has to be set, even if we don't need AMR here.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"coordinates_min = -1.0 # minimum coordinate\ncoordinates_max = 1.0 # maximum coordinate\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4, # number of elements = 2^4\n n_cells_max=30_000) # set maximum capacity of tree data structure (only needed for AMR)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"A semidiscretization collects data structures and functions for the spatial discretization. In Trixi.jl, an initial condition has the following parameter structure and is of the type SVector.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"initial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"Again, combining all definitions and the function that calculates the right-hand side, we define the ODE and solve it until t=2 with OrdinaryDiffEq's solve function and the Runge-Kutta method RDPK3SpFSAL49().","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"tspan = (0.0, 2.0)\node_trixi = semidiscretize(semi, tspan)\n\nsol_trixi = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);\nnothing #hide","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"We add a plot of the new approximated solution to the one calculated before.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"plot!(sol_trixi, label=\"solution at t=$(tspan[2]) with Trixi.jl\", legend=:topleft, linestyle=:dash, lw=2)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Summary-of-the-code","page":"1 Introduction to DG methods","title":"Summary of the code","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"To sum up, here is the complete code that we used.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Raw-implementation","page":"1 Introduction to DG methods","title":"Raw implementation","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"# basis: Legendre-Gauss-Lobatto\nusing Trixi, LinearAlgebra, OrdinaryDiffEq, Plots\npolydeg = 3 #= polynomial degree =#\nbasis = LobattoLegendreBasis(polydeg)\nnodes = basis.nodes # Gauss-Lobatto nodes in [-1, 1]\nD = basis.derivative_matrix\nM = diagm(basis.weights) # mass matrix\nB = diagm([-1; zeros(polydeg - 1); 1])\n\n# mesh\ncoordinates_min = -1.0 # minimum coordinate\ncoordinates_max = 1.0 # maximum coordinate\nn_elements = 16 # number of elements\n\ndx = (coordinates_max - coordinates_min) / n_elements # length of one element\n\nx = Matrix{Float64}(undef, length(nodes), n_elements)\nfor element in 1:n_elements\n x_l = -1 + (element - 1) * dx + dx/2\n for i in 1:length(nodes) # basis points in [-1, 1]\n ξ = nodes[i]\n x[i, element] = x_l + dx/2 * ξ\n end\nend\n\n# initial condition\ninitial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)\nu0 = initial_condition_sine_wave.(x)\n\nplot(vec(x), vec(u0), label=\"initial condition\", legend=:topleft)\n\n# flux Lax-Friedrichs\nsurface_flux = flux_lax_friedrichs\n\n# rhs! method\nfunction rhs!(du, u, x, t)\n # reset du\n du .= zero(eltype(du))\n flux_numerical = copy(du)\n\n # calculate interface and boundary fluxes\n equations = LinearScalarAdvectionEquation1D(1.0)\n for element in 2:n_elements-1\n # left interface\n flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)\n flux_numerical[end, element-1] = flux_numerical[1, element]\n # right interface\n flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)\n flux_numerical[1, element+1] = flux_numerical[end, element]\n end\n # boundary flux\n flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)\n flux_numerical[end, end] = flux_numerical[1, 1]\n\n # calculate surface integrals\n for element in 1:n_elements\n du[:, element] -= (M \\ B) * flux_numerical[:, element]\n end\n\n # calculate volume integral\n for element in 1:n_elements\n flux = u[:, element]\n du[:, element] += (M \\ transpose(D)) * M * flux\n end\n\n # apply Jacobian from mapping to reference element\n for element in 1:n_elements\n du[:, element] *= 2 / dx\n end\n\n return nothing\nend\n\n# create ODE problem\ntspan = (0.0, 2.0)\node = ODEProblem(rhs!, u0, tspan, x)\n\n# solve\nsol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)\n\nplot(vec(x), vec(sol.u[end]), label=\"solution at t=$(tspan[2])\", legend=:topleft, lw=3)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Alternative-Implementation-based-on-Trixi.jl-2","page":"1 Introduction to DG methods","title":"Alternative Implementation based on Trixi.jl","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using Trixi, OrdinaryDiffEq, Plots\n\n# equation with a advection_velocity of `1`.\nadvection_velocity = 1.0\nequations = LinearScalarAdvectionEquation1D(advection_velocity)\n\n# create DG solver with flux lax friedrichs and LGL basis\nsolver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n\n# distretize domain with `TreeMesh`\ncoordinates_min = -1.0 # minimum coordinate\ncoordinates_max = 1.0 # maximum coordinate\nmesh = TreeMesh(coordinates_min, coordinates_max,\n initial_refinement_level=4, # number of elements = 2^4\n n_cells_max=30_000)\n\n# create initial condition and semidiscretization\ninitial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))\n\nsemi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)\n\n# solve\ntspan = (0.0, 2.0)\node_trixi = semidiscretize(semi, tspan)\nsol_trixi = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);\n\nplot!(sol_trixi, label=\"solution at t=$(tspan[2]) with Trixi.jl\", legend=:topleft, linestyle=:dash, lw=2)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/#Package-versions","page":"1 Introduction to DG methods","title":"Package versions","text":"","category":"section"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"These results were obtained using the following versions.","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"using InteractiveUtils\nversioninfo()\n\nusing Pkg\nPkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n mode=PKGMODE_MANIFEST)","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"","category":"page"},{"location":"tutorials/scalar_linear_advection_1d/","page":"1 Introduction to DG methods","title":"1 Introduction to DG methods","text":"This page was generated using Literate.jl.","category":"page"},{"location":"reference-trixi2vtk/#Trixi2Vtk.jl-API","page":"Trixi2Vtk.jl","title":"Trixi2Vtk.jl API","text":"","category":"section"},{"location":"reference-trixi2vtk/","page":"Trixi2Vtk.jl","title":"Trixi2Vtk.jl","text":"CurrentModule = Trixi2Vtk","category":"page"},{"location":"reference-trixi2vtk/","page":"Trixi2Vtk.jl","title":"Trixi2Vtk.jl","text":"Modules = [Trixi2Vtk]","category":"page"},{"location":"reference-trixi2vtk/#Trixi2Vtk.trixi2vtk-Tuple{Vararg{AbstractString}}","page":"Trixi2Vtk.jl","title":"Trixi2Vtk.trixi2vtk","text":"trixi2vtk(filename::AbstractString...;\n format=:vtu, verbose=false, hide_progress=false, pvd=nothing,\n output_directory=\".\", nvisnodes=nothing, save_celldata=true,\n reinterpolate=true, data_is_uniform=false)\n\nConvert Trixi-generated output files to VTK files (VTU or VTI).\n\nArguments\n\nfilename: One or more Trixi solution/restart/mesh files to convert to a VTK file. Filenames support file globbing, e.g., \"solution*\" to match all files starting with solution.\nformat: Output format for solution/restart files. Can be 'vtu' or 'vti'.\nverbose: Set to true to enable verbose output.\nhide_progress: Hide progress bar (will be hidden automatically if verbose is true).\npvd: Use this filename to store PVD file (instead of auto-detecting name). Note that only the name will be used (directory and file extension are ignored).\noutput_directory: Output directory where generated files are stored.\nnvisnodes: Number of visualization nodes per element. (default: number of DG nodes for StructuredMesh or UnstructuredMesh2D, twice the number of DG nodes for TreeMesh). A value of 0 (zero) uses the number of nodes in the DG elements.\nsave_celldata: Boolean value to determine if cell-based data should be saved. (default: true)\nreinterpolate: Boolean value to determine if data should be reinterpolated onto uniform points. When false the raw data at the compute nodes is copied into the appropriate format. (default: true)\ndata_is_uniform: Boolean to indicate if the data to be converted is from a finite difference method on a uniform grid of points. (default: false)\n\nExamples\n\njulia> trixi2vtk(\"out/solution_000*.h5\")\n[...]\n\n\n\n\n\n","category":"method"}] +} diff --git a/previews/PR1697/siteinfo.js b/previews/PR1697/siteinfo.js new file mode 100644 index 00000000000..3e575305989 --- /dev/null +++ b/previews/PR1697/siteinfo.js @@ -0,0 +1 @@ +var DOCUMENTER_CURRENT_VERSION = "previews/PR1697"; diff --git a/previews/PR1697/styleguide/index.html b/previews/PR1697/styleguide/index.html new file mode 100644 index 00000000000..e050be30df2 --- /dev/null +++ b/previews/PR1697/styleguide/index.html @@ -0,0 +1,2 @@ + +Style guide · Trixi.jl

Style guide

Coding style is an inherently personal - and thus hotly contested - issue. Since code is usually "written once, read often", it helps regular developers, new users, and reviewers if code is formatted consistently. We therefore believe in the merit of using a common coding style throughout Trixi.jl, even at the expense that not everyone can be happy with every detailed style decision. If you came here because you are furious about our code formatting rules, here is a happy little whale for you to calm you down: 🐳

Conventions

The following lists a few coding conventions for Trixi.jl. Note that in addition to these conventions, we apply and enforce automated source code formatting (see below for more details):

  • Modules, types, structs with CamelCase.
  • Functions, variables with lowercase snake_case.
  • Indentation with 4 spaces (never tabs!)
  • Maximum line length (strictly): 92.
  • Functions that mutate their input are named with a trailing !.
  • Functions order their parameters similar to Julia Base.
    • The main modified argument comes first. For example, if the right-hand side du is modified, it should come first. If only the cache is modified, e.g., in prolong2interfaces! and its siblings, put the cache first.
    • Otherwise, use the order mesh, equations, solver, cache.
    • If something needs to be specified in more detail for dispatch, put the additional argument before the general one that is specified in more detail. For example, we use have_nonconservative_terms(equations), equations and dg.mortar, dg.
  • Prefer for i in ... to for i = ... for better semantic clarity and greater flexibility.
  • Executable code should only use ASCII characters.
  • Docstrings and comments can and should use Unicode characters where it helps understanding.
  • Multiline expressions should be explicitly grouped by parentheses and not rely on Julia's implicit line continuation syntax.
  • When naming multiple functions of a single or similar category, prefer to put the general classification first and the specialization second. Example: Use flux_central instead of central_flux. This helps when searching for available functions on the REPL (e.g., when trying to find all flux functions).

Automated source code formatting

We use JuliaFormatter.jl to format the source code of Trixi.jl, which will also enforce some of the Conventions listed above (e.g., line length or indentation with 4 spaces are automatically handled, while capitalization of names is not). Our format is mostly based on the SciML-style formatting rules. For more details you can have a look at the current .JuliaFormatter.toml file that holds the configuration options we use for JuliaFormatter.jl.

Note that we expect all contributions to Trixi.jl to be formatted with JuliaFormatter.jl before being merged to the main branch. We ensure this by running a automated check on all PRs that verify that running JuliaFormatter.jl again will not change the source code.

To format your contributions before created a PR (or, at least, before requesting a review of your PR), you need to install JuliaFormatter.jl first by running

julia -e 'using Pkg; Pkg.add("JuliaFormatter")'

You can then recursively format the core Julia files in the Trixi.jl repo by executing

julia -e 'using JuliaFormatter; format(["benchmark", "ext", "src", "utils"])'

from inside the Trixi.jl repository. For convenience, there is also a script you can directly run from your terminal shell, which will automatically install JuliaFormatter in a temporary environment and then run it:

utils/trixi-format.jl

You can get more information about using the convenience script by running it with the --help/-h flag.

Checking formatting before committing

It can be convenient to check the formatting of source code automatically before each commit. We use git-hooks for it and provide a pre-commit script in the utils folder. The script uses JuliaFormatter.jl just like formatting script that runs over the whole Trixi.jl directory. You can copy the pre-commit-script into .git/hooks/pre-commit and it will check your formatting before each commit. If errors are found the commit is aborted and you can add the corrections via

git add -p
diff --git a/previews/PR1697/testing/index.html b/previews/PR1697/testing/index.html new file mode 100644 index 00000000000..9ca5ebcc658 --- /dev/null +++ b/previews/PR1697/testing/index.html @@ -0,0 +1,6 @@ + +Testing · Trixi.jl

Testing

During the development of Trixi.jl, we rely on continuous testing to ensure that modifications or new features do not break existing functionality or add other errors. In the main Trixi.jl repository (and the repositories for the visualization tool Trixi2Vtk), this is facilitated by GitHub Actions, which allows to run tests automatically upon certain events. When, how, and what is tested by GitHub Actions is controlled by the workflow file .github/workflows/ci.yml. In Trixi.jl and its related repositories, tests are triggered by

  • each git push to main and
  • each git push to any pull request.

Besides checking functionality, we also analyse the Test coverage to ensure that we do not miss important parts during testing.

Test and coverage requirements

Before merging a pull request (PR) to main, we require that

  • the code passes all functional tests
  • code coverage does not decrease.

Testing setup

The entry point for all testing is the file test/runtests.jl, which is run by the automated tests and which can be triggered manually by executing

julia> using Pkg; Pkg.test("Trixi")

in the REPL. Since there already exist many tests, we have split them up into multiple files in the test directory to allow for faster testing of individual parts of the code. Thus in addition to performing all tests, you can also just include one of the files named test_xxx.jl to run only a specific subset, e.g.,

julia> # Run all 2D tests on the P4estMesh
+       include(joinpath("test", "test_p4est_2d.jl"))
+
+julia> # Run all 1D tests for the Euler equations on the TreeMesh
+       include(joinpath("test", "test_tree_1d_euler.jl"))

For the automated tests with GitHub Actions, we run multiple jobs in parallel to reduce the waiting time until all tests are finished. You can see the different components that are run as jobs by looking at the TRIXI_TEST variable in test/runtests.jl.

Adding new tests

We use Julia's built-in unit testing capabilities to configure tests. In general, newly added code must be covered by at least one test, and all new elixirs added to the examples/ directory must be used at least once during testing. New tests should be added to the corresponding test/test_xxx.jl file, e.g., a test involving the 3D linear advection equation on the TreeMesh would go into test/test_tree_3d_advection.jl. Please study one of the existing tests and stay consistent to the current style when creating new tests.

Since we want to test as much as possible, we have a lot of tests and frequently create new ones. Naturally, this increases the time to wait for all tests to pass with each novel feature added to Trixi.jl. Therefore, new tests should be as short as reasonably possible, i.e., without being too insensitive to pick up changes or errors in the code.

When you add new tests, please check whether all CI jobs still take approximately the same time. If the job where you added new tests takes much longer than everything else, please consider moving some tests from one job to another (or report this incident and ask the main developers for help).

Test duration

As a general rule, tests should last no more than 10 seconds when run with a single thread and after compilation (i.e., excluding the first run).

Test coverage

In addition to ensuring that the code produces the expected results, the automated tests also record the code coverage. The resulting coverage reports, i.e., which lines of code were executed by at least one test and are thus considered "covered" by testing, are automatically uploaded to Coveralls for easy analysis. Typically, you see a number of Coveralls results at the bottom of each pull request: One for each parallel job (see Testing setup), which can usually be ignored since they only cover parts of the code by definition, and a cumulative coverage result named coverage/coveralls. The "Details" link takes you to a detailed report on which lines of code are covered by tests, which ones are missed, and especially which new lines the pull requests adds to Trixi.jl's code base that are not yet covered by testing.

Coverage requirements

In general, we require pull requests to not decrease the overall test coverage percentage in main, with a hard lower bound of 97%.

diff --git a/previews/PR1697/time_integration/index.html b/previews/PR1697/time_integration/index.html new file mode 100644 index 00000000000..30c495dd044 --- /dev/null +++ b/previews/PR1697/time_integration/index.html @@ -0,0 +1,2 @@ + +Time integration · Trixi.jl

Time integration methods

Trixi.jl is compatible with the SciML ecosystem for ordinary differential equations. In particular, explicit Runge-Kutta methods from OrdinaryDiffEq.jl are tested extensively. Interesting classes of time integration schemes are

Some common options for solve from OrdinaryDiffEq.jl are the following. Further documentation can be found in the SciML docs.

  • If you use a fixed time step method like CarpenterKennedy2N54, you need to pass a time step as dt=.... If you use a StepsizeCallback, the value passed as dt=... is irrelevant since it will be overwritten by the StepsizeCallback. If you want to use an adaptive time step method such as SSPRK43 or RDPK3SpFSAL49 and still want to use CFL-based step size control via the StepsizeCallback, you need to pass the keyword argument adaptive=false to solve.
  • You should usually set save_everystep=false. Otherwise, OrdinaryDiffEq.jl will (try to) save the numerical solution after every time step in RAM (until you run out of memory or start to swap).
  • You can set the maximal number of time steps via maxiters=....
  • SSP methods and many low-storage methods from OrdinaryDiffEq.jl support stage_limiter!s and step_limiter!s, e.g., PositivityPreservingLimiterZhangShu from Trixi.jl.
  • If you start Julia with multiple threads and want to use them also in the time integration method from OrdinaryDiffEq.jl, you need to pass the keyword argument thread=OrdinaryDiffEq.True() to the algorithm, e.g., RDPK3SpFSAL49(thread=OrdinaryDiffEq.True()) or CarpenterKennedy2N54(thread=OrdinaryDiffEq.True(), williamson_condition=false). For more information on using thread-based parallelism in Trixi.jl, please refer to Shared-memory parallelization with threads.
  • If you use error-based step size control (see also the section on error-based adaptive step sizes together with MPI, you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to OrdinaryDiffEq's solve, which are both included in ode_default_options.
Number of `rhs!` calls

If you use explicit Runge-Kutta methods from OrdinaryDiffEq.jl, the total number of rhs! calls can be (slightly) bigger than the number of steps times the number of stages, e.g. to allow for interpolation (dense output), root-finding for continuous callbacks, and error-based time step control. In general, you often should not need to worry about this if you use Trixi.jl.

diff --git a/previews/PR1697/troubleshooting/index.html b/previews/PR1697/troubleshooting/index.html new file mode 100644 index 00000000000..d69dd0b11e3 --- /dev/null +++ b/previews/PR1697/troubleshooting/index.html @@ -0,0 +1,47 @@ + +Troubleshooting and FAQ · Trixi.jl

Troubleshooting and FAQ

In general, Trixi.jl works best with the newest Julia release and up-to-date dependencies. If something does not work as expected, try updating your installed Julia packages via the package manager, e.g., by running

julia> import Pkg; Pkg.update()

If you do not use the latest stable release of Julia from the official website, consider updating your Julia installation.

Installing Trixi.jl as a package only provides an older release

Trixi.jl requires fairly recent versions of several of its dependencies, which sometimes causes issues when other installed packages have conflicting version requirements. In this case, Julia's package manager Pkg will try to handle this gracefully by going back in history until it finds a Trixi.jl release whose version requirements can be met, resulting in an older - and usually outdated - version of Trixi.jl being installed.

The following example illustrates this issue:

  • The current Trixi.jl release v0.3.6 requires package Foo with a minimum version of v0.2.
  • An older Trixi.jl release v0.2.1 requires package Foo only with a minimum version of v0.1.
  • A user has already installed package Bar, which itself requires Foo with a maximum version of v0.1.

In this case, installing Trixi.jl via Pkg will result in version v0.2.1 to be installed instead of the current release v0.3.6. That is, a specific release of Trixi.jl may not be installable if it has a dependency with a higher minimum version that at the same time is restricted to a lower maximum version by another installed package.

You can check whether an outdated version of Trixi.jl is installed by executing

julia> import Pkg; Pkg.update("Trixi"); Pkg.status("Trixi")

in the REPL and comparing the reported Trixi.jl version with the version of the latest release. If the versions differ, you can confirm that it is due to a version conflict by forcing Pkg to install the latest Trixi.jl release, where version is the current release:

julia> Pkg.add(name="Trixi", version="0.3.6")

In case of a conflict, the command above will produce an error that informs you about the offending packages, similar to the following:

   Updating registry at `~/.julia/registries/General`
+  Resolving package versions...
+ERROR: Unsatisfiable requirements detected for package DataStructures [864edb3b]:
+ DataStructures [864edb3b] log:
+ ├─possible versions are: [0.9.0, 0.10.0, 0.11.0-0.11.1, 0.12.0, 0.13.0, 0.14.0-0.14.1, 0.15.0, 0.16.1, 0.17.0-0.17.20, 0.18.0-0.18.8] or uninstalled
+ ├─restricted by compatibility requirements with DiffEqCallbacks [459566f4] to versions: 0.18.0-0.18.8
+ │ └─DiffEqCallbacks [459566f4] log:
+ │   ├─possible versions are: [2.0.0, 2.1.0, 2.2.0, 2.3.0, 2.4.0, 2.5.0-2.5.2, 2.6.0, 2.7.0, 2.8.0, 2.9.0, 2.10.0, 2.11.0, 2.12.0-2.12.1, 2.13.0-2.13.5, 2.14.0-2.14.1, 2.15.0] or uninstalled
+ │   ├─restricted by compatibility requirements with Trixi [a7f1ee26] to versions: [2.14.0-2.14.1, 2.15.0]
+ │   │ └─Trixi [a7f1ee26] log:
+ │   │   ├─possible versions are: [0.1.0-0.1.2, 0.2.0-0.2.6, 0.3.0-0.3.6] or uninstalled
+ │   │   └─restricted to versions 0.3.6 by an explicit requirement, leaving only versions 0.3.6
+ │   └─restricted by compatibility requirements with StaticArrays [90137ffa] to versions: 2.15.0 or uninstalled, leaving only versions: 2.15.0
+ │     └─StaticArrays [90137ffa] log:
+ │       ├─possible versions are: [0.8.0-0.8.3, 0.9.0-0.9.2, 0.10.0, 0.10.2-0.10.3, 0.11.0-0.11.1, 0.12.0-0.12.5, 1.0.0-1.0.1] or uninstalled
+ │       └─restricted by compatibility requirements with Trixi [a7f1ee26] to versions: 1.0.0-1.0.1
+ │         └─Trixi [a7f1ee26] log: see above
+ └─restricted by compatibility requirements with JLD2 [033835bb] to versions: [0.9.0, 0.10.0, 0.11.0-0.11.1, 0.12.0, 0.13.0, 0.14.0-0.14.1, 0.15.0, 0.16.1, 0.17.0-0.17.20] — no versions left
+   └─JLD2 [033835bb] log:
+     ├─possible versions are: [0.1.0-0.1.14, 0.2.0-0.2.4, 0.3.0-0.3.1] or uninstalled
+     └─restricted by compatibility requirements with BinaryBuilder [12aac903] to versions: 0.1.0-0.1.14
+       └─BinaryBuilder [12aac903] log:
+         ├─possible versions are: [0.1.0-0.1.2, 0.1.4, 0.2.0-0.2.6] or uninstalled
+         └─restricted to versions * by an explicit requirement, leaving only versions [0.1.0-0.1.2, 0.1.4, 0.2.0-0.2.6]

From the error message, we can see that ultimately BinaryBuilder is the problem here: It restricts the package DataStructures to version v0.17 (via its dependency JLD2), while Trixi.jl requires at least v0.18 (via its dependency DiffEqCallbacks). Following the official Pkg documentation, there are a number of things you can try to fix such errors:

  • Try updating all packages with julia -e 'using Pkg; Pkg.update()'. A newer version of the problematic package may exist that has updated version requirements.
  • Remove the offending package. Running
    julia> import Pkg; Pkg.rm("BinaryBuilder"); Pkg.update(); Pkg.status()
    in the REPL will remove BinaryBuilder and (hopefully) update Trixi.jl to the latest version.
  • Report the versioning issue to us and/or the development repository of the conflicting package. Maybe it is possible to lift the version restrictions such that both packages can live side by side.
  • Instead of installing Trixi.jl and conflicting packages in the same (default) environment, consider creating new environments/projects and install only packages required for the specific tasks, as explained in the official Pkg documentation. For example, if you use Trixi.jl for a research project (Bachelor/Master thesis or a paper), you should create a new Julia project/environment for that research and add Trixi.jl as a dependency. If you track all your code and the Project.toml, Manifest.toml files (generated by Pkg) in a version control system such as git, you can make your research easily reproducible (if you also record the version of Julia you are using and leave some comments for others who do not know what you are trying to do, including your future self 😉).

There are many questions marks and weird symbols in the output of Trixi.jl

This probably means that the default font used by your operating system does not support enough Unicode symbols. Try installing a modern font with decent unicode support, e.g. JuliaMono. Detailed installation instructions are available there.

This problems affects users of Mac OS particularly often. At the time of writing, installing JuliaMono is as simple as

$ brew tap homebrew/cask-fonts
+$ brew install --cask font-juliamono

There are no timing results of the initial mesh creation

By default, the SummaryCallback resets the timer used internally by Trixi.jl when it is initialized (when solve is called). If this step needs to be timed, e.g. to debug performance problems, explicit timings can be used as follows.

using Trixi
+
+begin
+  Trixi.reset_timer!(Trixi.timer())
+
+  equations = LinearScalarAdvectionEquation2D(0.2, -0.7)
+  mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), n_cells_max=10^5, initial_refinement_level=5)
+  solver = DGSEM(3)
+  semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test, solver)
+
+  Trixi.print_timer(Trixi.timer())
+end

MPI ranks are assigned zero cells in P4estMesh even though there are enough cells

The P4estMesh allows one to coarsen the mesh by default. When Trixi.jl is parallelized with multiple MPI ranks, this has the consequence that sibling cells (i.e., child cells with the same parent cell) are kept on the same MPI rank to be able to coarsen them easily. This might cause an unbalanced distribution of cells on different ranks. For 2D meshes, this also means that initially each rank will at least own 4 cells, and for 3D meshes, initially each rank will at least own 8 cells. See issue #1329.

Installing and updating everything takes a lot of time

Julia compiles code to get good (C/Fortran-like) performance. At the same time, Julia provides a dynamic environment and usually compiles code just before using it. Over time, Julia has improved its caching infrastructure, allowing to store and reuse more results from (pre-)compilation. This often results in an increased time to install/update packages, in particular when updating to Julia v1.8 or v1.9 from older versions.

Some packages used together with Trixi.jl provide options to configure the amount of precompilation. For example, OrdinaryDiffEq.jl precompiles many ODE solvers for a good runtime experience of average users. Currently, Trixi.jl does not use all of the available solvers. Thus, you can save some time at every update by setting their precompilation options.

At the time of writing, this could look as follows. First, you need to activate the environment where you have installed OrdinaryDiffEq.jl. Then, you need to execute the following Julia code.

using Preferences, UUIDs
+let uuid = UUID("1dea7af3-3e70-54e6-95c3-0bf5283fa5ed")
+  set_preferences!(uuid, "PrecompileAutoSpecialize" => false)
+  set_preferences!(uuid, "PrecompileAutoSwitch" => false)
+  set_preferences!(uuid, "PrecompileDefaultSpecialize" => true)
+  set_preferences!(uuid, "PrecompileFunctionWrapperSpecialize" => false)
+  set_preferences!(uuid, "PrecompileLowStorage" => true)
+  set_preferences!(uuid, "PrecompileNoSpecialize" => false)
+  set_preferences!(uuid, "PrecompileNonStiff" => true)
+  set_preferences!(uuid, "PrecompileStiff" => false)
+end

This disables precompilation of all implicit methods. This should usually not affect the runtime latency with Trixi.jl since most setups use explicit time integration methods.

diff --git a/previews/PR1697/tutorials/DGMulti_1/12ccb79d.svg b/previews/PR1697/tutorials/DGMulti_1/12ccb79d.svg new file mode 100644 index 00000000000..cdc10de5235 --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/12ccb79d.svg @@ -0,0 +1,8384 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/57a0c12e.svg b/previews/PR1697/tutorials/DGMulti_1/57a0c12e.svg new file mode 100644 index 00000000000..bf5328ff3d5 --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/57a0c12e.svg @@ -0,0 +1,6315 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/ce428824.svg b/previews/PR1697/tutorials/DGMulti_1/ce428824.svg new file mode 100644 index 00000000000..7855ea46b95 --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/ce428824.svg @@ -0,0 +1,4921 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/d6194a32.svg b/previews/PR1697/tutorials/DGMulti_1/d6194a32.svg new file mode 100644 index 00000000000..797f8d7420b --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/d6194a32.svg @@ -0,0 +1,5566 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/dc354ad7.svg b/previews/PR1697/tutorials/DGMulti_1/dc354ad7.svg new file mode 100644 index 00000000000..da0a19a36f8 --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/dc354ad7.svg @@ -0,0 +1,4816 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/eca33cfe.svg b/previews/PR1697/tutorials/DGMulti_1/eca33cfe.svg new file mode 100644 index 00000000000..6263d163e8e --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/eca33cfe.svg @@ -0,0 +1,6306 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGMulti_1/index.html b/previews/PR1697/tutorials/DGMulti_1/index.html new file mode 100644 index 00000000000..873bfb68ecb --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_1/index.html @@ -0,0 +1,308 @@ + +5 DG schemes via DGMulti solver · Trixi.jl

5: DG schemes via DGMulti solver

DGMulti is a DG solver that allows meshes with simplex elements. The basic idea and implementation of this solver is explained in section "Meshes". Here, we want to give some examples and a quick overview about the options with DGMulti.

We start with a simple example we already used in the tutorial about flux differencing. There, we implemented a simulation with initial_condition_weak_blast_wave for the 2D compressible Euler equations CompressibleEulerEquations2D and used the DG formulation with flux differencing using volume flux flux_ranocha and surface flux flux_lax_friedrichs.

Here, we want to implement the equivalent example, only now using the DGMulti solver instead of DGSEM.

using Trixi, OrdinaryDiffEq
+
+equations = CompressibleEulerEquations2D(1.4)
+
+initial_condition = initial_condition_weak_blast_wave
initial_condition_weak_blast_wave (generic function with 13 methods)

To use the Gauss-Lobatto nodes again, we choose approximation_type=SBP() in the solver. Since we want to start with a Cartesian domain discretized with squares, we use the element type Quad().

dg = DGMulti(polydeg = 3,
+             element_type = Quad(),
+             approximation_type = SBP(),
+             surface_flux = flux_lax_friedrichs,
+             volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))
+
+cells_per_dimension = (32, 32)
+mesh = DGMultiMesh(dg,
+                   cells_per_dimension, # initial_refinement_level = 5
+                   coordinates_min=(-2.0, -2.0),
+                   coordinates_max=( 2.0,  2.0),
+                   periodicity=true)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,
+                                    boundary_conditions=boundary_condition_periodic)
+tspan = (0.0, 0.4)
+ode = semidiscretize(semi, tspan)
+
+alive_callback = AliveCallback(alive_interval=10)
+analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))
+callbacks = CallbackSet(analysis_callback, alive_callback);

Run the simulation with the same time integration algorithm as before.

sol = solve(ode, RDPK3SpFSAL49(), abstol=1.0e-6, reltol=1.0e-6,
+            callback=callbacks, save_everystep=false);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       2.10000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:         16384                alloc'd memory:       2443.769 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       0.00000000e+00   0.00000000e+00   0.00000000e+00   0.00000000e+00
+ Linf error:     0.00000000e+00   0.00000000e+00   0.00000000e+00   0.00000000e+00
+ ∑∂S/∂U ⋅ Uₜ :  -2.41863883e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 8.2897e-03 │ sim. time: 5.6681e-02 (14.170%)  │ run time: 2.1028e-01 s
+#timesteps:     20 │ Δt: 1.2210e-02 │ sim. time: 1.6420e-01 (41.051%)  │ run time: 4.1395e-01 s
+#timesteps:     30 │ Δt: 1.3848e-02 │ sim. time: 2.9639e-01 (74.098%)  │ run time: 6.1852e-01 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 38                run time:       7.86099775e-01 s
+ Δt:             5.50651515e-03                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      4.00000000e-01 (100.000%)     time/DOF/rhs!:  1.25234219e-07 s
+                                               PID:            1.38326082e-07 s
+ #DOFs per field:         16384                alloc'd memory:       2448.630 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.13961930e-02   4.96492880e-02   4.96459232e-02   2.24580528e-01
+ Linf error:     2.63830830e-01   2.47653912e-01   2.47503933e-01   9.30036610e-01
+ ∑∂S/∂U ⋅ Uₜ :  -2.24450891e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 0.4  Time steps: 38 (accepted), 38 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
using Plots
+pd = PlotData2D(sol)
+plot(pd)
Example block output
plot(pd["rho"])
+plot!(getmesh(pd))
Example block output

This simulation is not as fast as the equivalent with TreeMesh since no special optimizations for quads (for instance tensor product structure) have been implemented. Figure 4 in "Efficient implementation of modern entropy stable and kinetic energy preserving discontinuous Galerkin methods for conservation laws" (2021) provides a nice runtime comparison between the different mesh types. On the other hand, the functions are more general and thus we have more option we can choose from.

Simulation with Gauss nodes

For instance, we can change the approximation type of our simulation.

using Trixi, OrdinaryDiffEq
+equations = CompressibleEulerEquations2D(1.4)
+initial_condition = initial_condition_weak_blast_wave
initial_condition_weak_blast_wave (generic function with 13 methods)

We now use Gauss nodes instead of Gauss-Lobatto nodes which can be done for the element types Quad() and Hex(). Therefore, we set approximation_type=GaussSBP(). Alternatively, we can use a modal approach using the approximation type Polynomial().

dg = DGMulti(polydeg = 3,
+             element_type = Quad(),
+             approximation_type = GaussSBP(),
+             surface_flux = flux_lax_friedrichs,
+             volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))
+
+cells_per_dimension = (32, 32)
+mesh = DGMultiMesh(dg,
+             cells_per_dimension, # initial_refinement_level = 5
+             coordinates_min=(-2.0, -2.0),
+             coordinates_max=( 2.0,  2.0),
+             periodicity=true)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,
+                              boundary_conditions=boundary_condition_periodic)
+tspan = (0.0, 0.4)
+ode = semidiscretize(semi, tspan)
+
+alive_callback = AliveCallback(alive_interval=10)
+analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))
+callbacks = CallbackSet(analysis_callback, alive_callback);
+
+sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,
+            ode_default_options()..., callback=callbacks);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       2.70000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:         16384                alloc'd memory:       2487.217 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       3.85192317e-16   1.11612674e-17   1.12132619e-17   9.02783286e-16
+ Linf error:     1.11022302e-15   1.94289029e-16   2.22044605e-16   3.10862447e-15
+ ∑∂S/∂U ⋅ Uₜ :  -1.01164379e-01
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 5.0548e-03 │ sim. time: 3.3436e-02 (8.359%)   │ run time: 6.8055e-01 s
+#timesteps:     20 │ Δt: 8.8313e-03 │ sim. time: 1.0601e-01 (26.503%)  │ run time: 1.3332e+00 s
+#timesteps:     30 │ Δt: 1.0521e-02 │ sim. time: 2.0438e-01 (51.094%)  │ run time: 1.9875e+00 s
+#timesteps:     40 │ Δt: 1.1006e-02 │ sim. time: 3.1245e-01 (78.113%)  │ run time: 2.6494e+00 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 48                run time:       3.18510476e+00 s
+ Δt:             1.00192333e-02                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      4.00000000e-01 (100.000%)     time/DOF/rhs!:  4.21890841e-07 s
+                                               PID:            4.45524821e-07 s
+ #DOFs per field:         16384                alloc'd memory:       2489.587 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.10354479e-02   4.94109888e-02   4.94109888e-02   2.23252171e-01
+ Linf error:     2.58968601e-01   2.43227118e-01   2.43227118e-01   9.39282114e-01
+ ∑∂S/∂U ⋅ Uₜ :  -2.32263587e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 0.4  Time steps: 48 (accepted), 48 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
using Plots
+pd = PlotData2D(sol)
+plot(pd)
Example block output

Simulation with triangular elements

Also, we can set another element type. We want to use triangles now.

using Trixi, OrdinaryDiffEq
+equations = CompressibleEulerEquations2D(1.4)
+initial_condition = initial_condition_weak_blast_wave
initial_condition_weak_blast_wave (generic function with 13 methods)

Since there is no direct equivalent to Gauss-Lobatto nodes on triangles, the approximation type SBP() now uses Gauss-Lobatto nodes on faces and special nodes in the interior of the triangular. More details can be found in the documentation of StartUpDG.jl.

dg = DGMulti(polydeg = 3,
+             element_type = Tri(),
+             approximation_type = SBP(),
+             surface_flux = flux_lax_friedrichs,
+             volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))
+
+cells_per_dimension = (32, 32)
+mesh = DGMultiMesh(dg,
+                   cells_per_dimension, # initial_refinement_level = 5
+                   coordinates_min=(-2.0, -2.0),
+                   coordinates_max=( 2.0,  2.0),
+                   periodicity=true)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,
+                                    boundary_conditions=boundary_condition_periodic)
+tspan = (0.0, 0.4)
+ode = semidiscretize(semi, tspan)
+
+alive_callback = AliveCallback(alive_interval=10)
+analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))
+callbacks = CallbackSet(analysis_callback, alive_callback);
+
+sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,
+            ode_default_options()..., callback=callbacks);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       2.20000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:         30720                alloc'd memory:       2511.186 MiB
+ #elements:                2048
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       0.00000000e+00   0.00000000e+00   0.00000000e+00   0.00000000e+00
+ Linf error:     0.00000000e+00   0.00000000e+00   0.00000000e+00   0.00000000e+00
+ ∑∂S/∂U ⋅ Uₜ :  -6.20288935e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 6.5307e-03 │ sim. time: 4.4324e-02 (11.081%)  │ run time: 1.1071e+00 s
+#timesteps:     20 │ Δt: 1.0419e-02 │ sim. time: 1.3413e-01 (33.533%)  │ run time: 2.1778e+00 s
+#timesteps:     30 │ Δt: 1.2042e-02 │ sim. time: 2.4861e-01 (62.152%)  │ run time: 3.2769e+00 s
+#timesteps:     40 │ Δt: 1.2624e-02 │ sim. time: 3.7245e-01 (93.113%)  │ run time: 4.3992e+00 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 43                run time:       4.74965666e+00 s
+ Δt:             2.19030700e-03                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      4.00000000e-01 (100.000%)     time/DOF/rhs!:  3.74788765e-07 s
+                                               PID:            3.95193421e-07 s
+ #DOFs per field:         30720                alloc'd memory:       2520.098 MiB
+ #elements:                2048
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.07364412e-02   4.91988609e-02   4.91963681e-02   2.22168460e-01
+ Linf error:     2.68903929e-01   2.45685699e-01   2.45819523e-01   9.33718963e-01
+ ∑∂S/∂U ⋅ Uₜ :  -1.96215242e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 0.4  Time steps: 43 (accepted), 43 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
using Plots
+pd = PlotData2D(sol)
+plot(pd)
Example block output
plot(pd["rho"])
+plot!(getmesh(pd))
Example block output

Triangular meshes on non-Cartesian domains

To use triangular meshes on a non-Cartesian domain, Trixi.jl uses the package StartUpDG.jl. The following example is based on elixir_euler_triangulate_pkg_mesh.jl and uses a pre-defined mesh from StartUpDG.jl.

using Trixi, OrdinaryDiffEq

We want to simulate the smooth initial condition initial_condition_convergence_test with source terms source_terms_convergence_test for the 2D compressible Euler equations.

equations = CompressibleEulerEquations2D(1.4)
+initial_condition = initial_condition_convergence_test
+source_terms = source_terms_convergence_test
source_terms_convergence_test (generic function with 13 methods)

We create the solver DGMulti with triangular elements (Tri()) as before.

dg = DGMulti(polydeg = 3, element_type = Tri(),
+             approximation_type=Polynomial(),
+             surface_flux = flux_lax_friedrichs,
+             volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… RefElemData{N=3, Polynomial, Tri}.                               │
+│ mortar: …………………………………………………………… nothing                                                          │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ volume integral: …………………………………… VolumeIntegralFluxDifferencing                                   │
+│ │ volume flux: ………………………………………… flux_ranocha                                                     │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

StartUpDG.jl provides for instance a pre-defined Triangulate geometry for a rectangular domain with hole RectangularDomainWithHole. Other pre-defined Triangulate geometries are e.g., SquareDomain, Scramjet, and CircularDomain.

meshIO = StartUpDG.triangulate_domain(StartUpDG.RectangularDomainWithHole());

The pre-defined Triangulate geometry in StartUpDG has integer boundary tags. With DGMultiMesh we assign boundary faces based on these integer boundary tags and create a mesh compatible with Trixi.jl.

mesh = DGMultiMesh(meshIO, dg, Dict(:outer_boundary=>1, :inner_boundary=>2))
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DGMultiMesh{2, Trixi.Affine},                                                                    │
+│ ══════════════════════════════                                                                   │
+│ number of elements: …………………………… 598                                                              │
+│ number of boundaries: ……………………… 2                                                                │
+│ │ nfaces on outer_boundary: ……… 52                                                               │
+│ │ nfaces on inner_boundary: ……… 4                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
boundary_condition_convergence_test = BoundaryConditionDirichlet(initial_condition)
+boundary_conditions = (; :outer_boundary => boundary_condition_convergence_test,
+                         :inner_boundary => boundary_condition_convergence_test)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,
+                                    source_terms = source_terms,
+                                    boundary_conditions = boundary_conditions)
+
+tspan = (0.0, 0.2)
+ode = semidiscretize(semi, tspan)
+
+alive_callback = AliveCallback(alive_interval=20)
+analysis_callback = AnalysisCallback(semi, interval=200, uEltype=real(dg))
+callbacks = CallbackSet(alive_callback, analysis_callback);
+
+sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),
+            dt = 0.5 * estimate_dt(mesh, dg), save_everystep=false, callback=callbacks);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.90100000e-06 s
+ Δt:             1.49245207e-03                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:          5980                alloc'd memory:       2549.221 MiB
+ #elements:                 598
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       3.93036845e-07   3.93036845e-07   3.93036845e-07   1.55064245e-06
+ Linf error:     4.47141181e-06   4.47141181e-06   4.47141181e-06   1.47933676e-05
+ ∑∂S/∂U ⋅ Uₜ :  -1.23444983e-02
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     20 │ Δt: 1.4925e-03 │ sim. time: 2.9849e-02 (14.925%)  │ run time: 7.1457e-01 s
+#timesteps:     40 │ Δt: 1.4925e-03 │ sim. time: 5.9698e-02 (29.849%)  │ run time: 1.4281e+00 s
+#timesteps:     60 │ Δt: 1.4925e-03 │ sim. time: 8.9547e-02 (44.774%)  │ run time: 2.1370e+00 s
+#timesteps:     80 │ Δt: 1.4925e-03 │ sim. time: 1.1940e-01 (59.698%)  │ run time: 2.8369e+00 s
+#timesteps:    100 │ Δt: 1.4925e-03 │ sim. time: 1.4925e-01 (74.623%)  │ run time: 3.5450e+00 s
+#timesteps:    120 │ Δt: 1.4925e-03 │ sim. time: 1.7909e-01 (89.547%)  │ run time: 4.2509e+00 s
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 0.2  Time steps: 135 (accepted), 135 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGMulti(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                135                run time:       4.78263487e+00 s
+ Δt:             1.14223386e-05                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      2.00000000e-01 (100.000%)     time/DOF/rhs!:  1.17005148e-06 s
+                                               PID:            1.18112699e-06 s
+ #DOFs per field:          5980                alloc'd memory:       2549.694 MiB
+ #elements:                 598
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       4.43758204e-06   3.71131543e-06   4.42671638e-06   9.85291883e-06
+ Linf error:     6.10809368e-05   4.53698746e-05   6.62331342e-05   1.25625347e-04
+ ∑∂S/∂U ⋅ Uₜ :  -1.03046341e-02
+────────────────────────────────────────────────────────────────────────────────────────────────────
using Plots
+pd = PlotData2D(sol)
+plot(pd["rho"])
+plot!(getmesh(pd))
Example block output

For more information, please have a look in the StartUpDG.jl documentation.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "StartUpDG", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [472ebc20] StartUpDG v0.17.7
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/DGMulti_2/index.html b/previews/PR1697/tutorials/DGMulti_2/index.html new file mode 100644 index 00000000000..2c75e4a3a85 --- /dev/null +++ b/previews/PR1697/tutorials/DGMulti_2/index.html @@ -0,0 +1,36 @@ + +6 Other SBP schemes (FD, CGSEM) via DGMulti solver · Trixi.jl

6: Other SBP schemes (FD, CGSEM) via DGMulti solver

For a tutorial about DG schemes via the DGMulti solver please visit the previous tutorial. The DGMulti solver also supports other methods than DG. The important property a method has to fulfill is the summation-by-parts (SBP) property. The package SummationByPartsOperators.jl provides such methods, like a finite difference SBP (FD SBP) scheme. To do this, you need to create an SBP derivative operator and pass that as approximation_type to the DGMulti constructor. For example, the classical second-order FD SBP operator can be created as

using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly
+D = derivative_operator(MattssonNordström2004(), derivative_order=1, accuracy_order=2,
+                        xmin=0.0, xmax=1.0, N=11)
SBP first-derivative operator of order 2 on a grid in [0.0, 1.0] using 11 nodes 
+and coefficients of Mattsson, Nordström (2004) 
+  Summation by parts operators for finite difference approximations of second 
+    derivatives. 
+  Journal of Computational Physics 199, pp. 503-540.

Here, the arguments xmin and xmax do not matter beyond setting the real type used for the operator - they just set a reference element and are rescaled on the physical elements. The parameter N determines the number of finite difference nodes. Then, D can be used as approximation_type like SBP() in a multi-block fashion. In multiple dimensions, such a 1D SBP operator will be used in a tensor product fashion, i.e., in each coordinate direction. In particular, you can use them only on 1D, 2D Quad(), and 3D Hex() elements.

You can also use fully periodic single-block FD methods by creating a periodic SBP operator. For example, a fully periodic FD operator can be constructed as

D = periodic_derivative_operator(derivative_order=1, accuracy_order=2,
+                                 xmin=0.0, xmax=1.0, N=11)
Periodic first-derivative operator of order 2 on a grid in [0.0, 1.0] using 11 nodes, 
+stencils with 1 nodes to the left, 1 nodes to the right, and coefficients of Fornberg (1998) 
+  Calculation of Weights in Finite Difference Formulas. 
+  SIAM Rev. 40.3, pp. 685-691.

An example using such an FD method is implemented in elixir_euler_fdsbp_periodic.jl. For all parameters and other calling options, please have a look in the documentation of SummationByPartsOperators.jl.

Another possible method is for instance a continuous Galerkin (CGSEM) method. You can use such a method with polynomial degree of 3 (N=4 Legendre Lobatto nodes on [0, 1]) coupled continuously on a uniform mesh with Nx=10 elements by setting approximation_type to

using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly
+D = couple_continuously(legendre_derivative_operator(xmin=0.0, xmax=1.0, N=4),
+                        UniformPeriodicMesh1D(xmin=-1.0, xmax=1.0, Nx=10))
First derivative operator {T=Float64} on 4 Lobatto Legendre nodes in [0.0, 1.0]
+coupled continuously on SummationByPartsOperators.UniformPeriodicMesh1D{Float64} with 10 cells in (-1.0, 1.0)

To choose a discontinuous coupling (DGSEM), use couple_discontinuously() instead of couple_continuously().

For more information and other SBP operators, see the documentations of StartUpDG.jl and SummationByPartsOperators.jl.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "StartUpDG", "SummationByPartsOperators"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [472ebc20] StartUpDG v0.17.7
+  [9f78cca6] SummationByPartsOperators v0.5.51
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/DGSEM_FluxDiff/606795d1.svg b/previews/PR1697/tutorials/DGSEM_FluxDiff/606795d1.svg new file mode 100644 index 00000000000..fa2ac8f8a2a --- /dev/null +++ b/previews/PR1697/tutorials/DGSEM_FluxDiff/606795d1.svg @@ -0,0 +1,4089 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGSEM_FluxDiff/869d34b2.svg b/previews/PR1697/tutorials/DGSEM_FluxDiff/869d34b2.svg new file mode 100644 index 00000000000..e79d1ee1a52 --- /dev/null +++ b/previews/PR1697/tutorials/DGSEM_FluxDiff/869d34b2.svg @@ -0,0 +1,2845 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/DGSEM_FluxDiff/index.html b/previews/PR1697/tutorials/DGSEM_FluxDiff/index.html new file mode 100644 index 00000000000..9850e2e7e35 --- /dev/null +++ b/previews/PR1697/tutorials/DGSEM_FluxDiff/index.html @@ -0,0 +1,166 @@ + +2 DGSEM with flux differencing · Trixi.jl

2: DGSEM with flux differencing

This tutorial starts with a presentation of the weak formulation of the discontinuous Galerkin spectral element method (DGSEM) in order to fix the notation of the used operators. Then, the DGSEM formulation with flux differencing (split form DGSEM) and its implementation in Trixi.jl is shown.

We start with the one-dimensional conservation law

\[u_t + f(u)_x = 0, \qquad t\in \mathbb{R}^+, x\in\Omega\]

with the physical flux $f$.

We split the domain $\Omega$ into elements $K$ with center $x_K$ and size $\Delta x$. With the transformation mapping $x(\xi)=x_K + \frac{\Delta x}{2} \xi$ we can transform the reference element $[-1,1]$ to every physical element. So, the equation can be restricted to the reference element using the determinant of the Jacobian matrix of the transformation mapping $J=\frac{\partial x}{\partial \xi}=\frac{\Delta x}{2}$.

\[J u_t + f(u)_{\xi} = 0, \qquad t\in \mathbb{R}^+, \xi\in [-1,1]\]

The weak form of the DGSEM

We consider the so-called discontinuous Galerkin spectral element method (DGSEM) with collocation. It results from choosing a nodal DG ansatz using $N+1$ Gauss-Lobatto nodes $\xi_i$ in $[-1,1]$ with matching interpolation weights $w_i$, which are used for numerical integration and interpolation with the Lagrange polynomial basis $l_i$ of degree $N$. The Lagrange functions are created with those nodes and hence fulfil a Kronecker property at the GL nodes. The weak formulation of the DGSEM for one element is

\[J \underline{\dot{u}}(t) = - M^{-1} B \underline{f}^* + M^{-1} D^T M \underline{f}\]

where $\underline{u}=(u_0, u_1, \dots, u_N)^T\in\mathbb{R}^{N+1}$ is the collected pointwise evaluation of $u$ at the discretization nodes and $\dot{u} = \partial u / \partial t = u_t$ is the temporal derivative. The nodal values of the flux function $f$ results with collocation in $\underline{f}$, since $\underline{f}_j=f(\underline{u}_j)$. Moreover, we got the numerical flux $f^*=f^*(u^-, u^+)$.

We will now have a short overview over the operators we used.

The derivative matrix $D\in\mathbb{R}^{(N+1)\times (N+1)}$ mimics a spatial derivation on a discrete level with $\underline{f}_x \approx D \underline{f}$. It is defined by $D_{ij} = l_j'(\xi_i)$.

The diagonal mass matrix $M$ is defined by $M_{ij}=\langle l_j, l_i\rangle_N$ with the numerical scalar product $\langle \cdot, \cdot\rangle_N$ defined for functions $f$ and $g$ by

\[\langle f, g\rangle_N := \int_{-1, N}^1 f(\xi) g(\xi) d\xi := \sum_{k=0}^N f(\xi_k) g(\xi_k) w_k.\]

The multiplication by $M$ matches a discrete integration

\[ \int_{-1}^1 f(\xi) \underline{l}(\xi) d\xi \approx M \underline{f},\]

The boundary matrix $B=\text{diag}([-1, 0,..., 0, 1])$ represents an evaluation of a function at the boundaries $\xi_0=-1$ and $\xi_N=1$.

For these operators the following property holds:

\[ M D + (M D)^T = B.\]

This is called the summation-by-parts (SBP) property since it mimics integration by parts on a discrete level (Gassner (2013)).

The explicit definitions of the operators and the construction of the 1D algorithm can be found for instance in the tutorial introduction to DG methods or in more detail in Kopriva (2009).

This property shows the equivalence between the weak form and the following strong formulation of the DGSEM.

\[\begin{align*} +J \underline{\dot{u}}(t) +&= - M^{-1} B \underline{f}^* + M^{-1} D^T M \underline{f}\\[5pt] +&= - M^{-1} B \underline{f}^* + M^{-1} (B - MD) \underline{f}\\[5pt] +&= - M^{-1} B (\underline{f}^* - \underline{f}) - D \underline{f} +\end{align*}\]

More information about the equivalence you can find in Kopriva, Gassner (2010).

DGSEM with flux differencing

When using the diagonal SBP property it is possible to rewrite the application of the derivative operator $D$ in the calculation of the volume integral into a subcell based finite volume type differencing formulation (Fisher, Carpenter (2013)). Generalizing

\[(D \underline{f})_i = \sum_j D_{i,j} \underline{f}_j += 2\sum_j \frac{1}{2} D_{i,j} (\underline{f}_j + \underline{f}_i) +\eqqcolon 2\sum_j D_{i,j} f_\text{central}(u_i, u_j),\]

we replace $D \underline{f}$ in the strong form by $2D \underline{f}_{vol}(u^-, u^+)$ with the consistent two-point volume flux $f_{vol}$ and receive the DGSEM formulation with flux differencing (split form DGSEM) (Gassner, Winters, Kopriva (2016)).

\[\begin{align*} +J \underline{\dot{u}}(t) &= - M^{-1} B (\underline{f}^* - \underline{f}) - 2D \underline{f}_{vol}(u^-, u^+)\\[5pt] +&= - M^{-1} B (\underline{f}^* - \underline{f}_{vol}(\underline{u}, \underline{u})) - 2D \underline{f}_{vol}(u^-, u^+)\\[5pt] +&= - M^{-1} B \underline{f}_{surface}^* - (2D - M^{-1} B) \underline{f}_{vol}\\[5pt] +&= - M^{-1} B \underline{f}_{surface}^* - D_{split} \underline{f}_{vol} +\end{align*}\]

This formulation is in a weak form type formulation and can be implemented by using the derivative split matrix $D_{split}=(2D-M^{-1}B)$ and two different fluxes. We divide between the surface flux $f=f_{surface}$ used for the numerical flux $f_{surface}^*$ and the already mentioned volume flux $f_{vol}$ especially for this formulation.

This formulation creates a more stable version of DGSEM, because it fulfils entropy stability. Moreover it allows the construction of entropy conserving discretizations without relying on exact integration. This is achieved when using a two-point entropy conserving flux function as volume flux in the volume flux differencing formulation. Then, the numerical surface flux can be used to control the dissipation of the discretization and to guarantee decreasing entropy, i.e. entropy stability.

Implementation in Trixi.jl

Now, we have a look at the implementation of DGSEM with flux differencing with Trixi.jl.

using OrdinaryDiffEq, Trixi

We implement a simulation for the compressible Euler equations in 2D

\[\partial_t \begin{pmatrix} \rho \\ \rho v_1 \\ \rho v_2 \\ \rho e \end{pmatrix} ++ \partial_x \begin{pmatrix} \rho v_1 \\ \rho v_1^2 + p \\ \rho v_1 v_2 \\ (\rho e +p) v_1 \end{pmatrix} ++ \partial_y \begin{pmatrix} \rho v_2 \\ \rho v_1 v_2 \\ \rho v_2^2 + p \\ (\rho e +p) v_2 \end{pmatrix} += \begin{pmatrix} 0 \\ 0 \\ 0 \\ 0 \end{pmatrix}\]

for an ideal gas with ratio of specific heats $\gamma=1.4$. Here, $\rho$ is the density, $v_1$, $v_2$ the velocities, $e$ the specific total energy and

\[p = (\gamma - 1) \left( \rho e - \frac{1}{2} \rho (v_1^2+v_2^2) \right)\]

the pressure.

gamma = 1.4
+equations = CompressibleEulerEquations2D(gamma)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ CompressibleEulerEquations2D                                                                     │
+│ ════════════════════════════                                                                     │
+│ #variables: ………………………………………………… 4                                                                │
+│ │ variable 1: …………………………………………… rho                                                              │
+│ │ variable 2: …………………………………………… rho_v1                                                           │
+│ │ variable 3: …………………………………………… rho_v2                                                           │
+│ │ variable 4: …………………………………………… rho_e                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

As our initial condition we will use a weak blast wave from Hennemann, Gassner (2020). The primitive variables are defined by

\[\begin{pmatrix} \rho \\ v_1 \\ v_2 \\ p \end{pmatrix} += \begin{pmatrix} 1.0 \\ 0.0 \\ 0.0 \\ 1.0 \end{pmatrix} \text{if } \|x\|_2 > 0.5,\; +\text{and } \begin{pmatrix} \rho \\ v_1 \\ v_2 \\ p \end{pmatrix} += \begin{pmatrix} 1.1691 \\ 0.1882 * \cos(\phi) \\ 0.1882 * \sin(\phi) \\ 1.245 \end{pmatrix} \text{else}\]

with $\phi = \tan^{-1}(\frac{x_2}{x_1})$.

This initial condition is implemented in Trixi.jl under the name initial_condition_weak_blast_wave.

initial_condition = initial_condition_weak_blast_wave
initial_condition_weak_blast_wave (generic function with 13 methods)

In Trixi.jl, flux differencing for the volume integral can be implemented with VolumeIntegralFluxDifferencing using symmetric two-point volume fluxes. First, we set up a simulation with the entropy conserving and kinetic energy preserving flux flux_ranocha by Hendrik Ranocha (2018) as surface and volume flux.

We will confirm the entropy conservation property numerically.

volume_flux = flux_ranocha # = f_vol
+solver = DGSEM(polydeg=3, surface_flux=volume_flux,
+               volume_integral=VolumeIntegralFluxDifferencing(volume_flux))
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_ranocha                                                     │
+│ volume integral: …………………………………… VolumeIntegralFluxDifferencing                                   │
+│ │ volume flux: ………………………………………… flux_ranocha                                                     │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Now, we implement Trixi.jl's mesh, semi and ode in a simple framework. For more information please have a look at the documentation, the basic tutorial introduction to DG methods or some basic elixirs.

coordinates_min = (-2.0, -2.0)
+coordinates_max = ( 2.0,  2.0)
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=5,
+                n_cells_max=10_000,
+                periodicity=true)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                    boundary_conditions=boundary_condition_periodic)
+
+# ODE solvers
+tspan = (0.0, 0.4)
+ode = semidiscretize(semi, tspan);

To analyse the entropy conservation of the approximation, we will use the analysis calllback implemented in Trixi. It provides some information about the approximation including the entropy change.

analysis_callback = AnalysisCallback(semi, interval=100);

We now run the simulation using flux_ranocha for both surface and volume flux.

sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,
+            ode_default_options()..., callback=analysis_callback);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.30000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:         16384                alloc'd memory:       2591.222 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.25621384e-03   5.88786362e-03   5.81457821e-03   2.34267393e-02
+ Linf error:     1.06470791e-01   2.46283676e-01   1.37585923e-01   3.98685775e-01
+ ∑∂S/∂U ⋅ Uₜ :   2.63255193e-19
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 61                run time:       1.12084717e+00 s
+ Δt:             2.65388338e-06                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      4.00000000e-01 (100.000%)     time/DOF/rhs!:  1.11129845e-07 s
+                                               PID:            1.23273245e-07 s
+ #DOFs per field:         16384                alloc'd memory:       2592.950 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.17814257e-02   5.02178088e-02   5.02253900e-02   2.25981851e-01
+ Linf error:     2.91149630e-01   3.21787795e-01   3.22040740e-01   1.04645370e+00
+ ∑∂S/∂U ⋅ Uₜ :  -2.34481695e-18
+────────────────────────────────────────────────────────────────────────────────────────────────────

A look at the change in entropy $\sum \partial S/\partial U \cdot U_t$ in the analysis callback confirms that the flux is entropy conserving since the change is about machine precision.

We can plot the approximated solution at the time t=0.4.

using Plots
+plot(sol)
Example block output

Now, we can use for instance the dissipative flux flux_lax_friedrichs as surface flux to get an entropy stable method.

using OrdinaryDiffEq, Trixi
+
+gamma = 1.4
+equations = CompressibleEulerEquations2D(gamma)
+
+initial_condition = initial_condition_weak_blast_wave
+
+volume_flux = flux_ranocha # = f_vol
+solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs,
+               volume_integral=VolumeIntegralFluxDifferencing(volume_flux))
+
+coordinates_min = (-2.0, -2.0)
+coordinates_max = ( 2.0,  2.0)
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=5,
+                n_cells_max=10_000,
+                periodicity=true)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                    boundary_conditions=boundary_condition_periodic)
+
+# ODE solvers
+tspan = (0.0, 0.4)
+ode = semidiscretize(semi, tspan);
+
+analysis_callback = AnalysisCallback(semi, interval=100);

We now run the simulation using the volume flux flux_ranocha and surface flux flux_lax_friedrichs.

sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,
+            ode_default_options()..., callback=analysis_callback);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.30000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:         16384                alloc'd memory:       2595.844 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.25621384e-03   5.88786362e-03   5.81457821e-03   2.34267393e-02
+ Linf error:     1.06470791e-01   2.46283676e-01   1.37585923e-01   3.98685775e-01
+ ∑∂S/∂U ⋅ Uₜ :   1.75163767e-19
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 37                run time:       6.50820750e-01 s
+ Δt:             9.70561500e-03                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      4.00000000e-01 (100.000%)     time/DOF/rhs!:  1.05017526e-07 s
+                                               PID:            1.17179011e-07 s
+ #DOFs per field:         16384                alloc'd memory:       2597.571 MiB
+ #elements:                1024
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       6.13073745e-02   4.96545958e-02   4.96554717e-02   2.24251907e-01
+ Linf error:     2.61815838e-01   2.48816692e-01   2.48316760e-01   9.30972696e-01
+ ∑∂S/∂U ⋅ Uₜ :  -1.40306972e-04
+────────────────────────────────────────────────────────────────────────────────────────────────────

The change in entropy confirms the expected entropy stability.

using Plots
+plot(sol)
Example block output

Of course, you can use more than these two fluxes in Trixi. Here, we will give a short list of possible fluxes for the compressible Euler equations. For the volume flux Trixi.jl provides for example flux_ranocha, flux_shima_etal, flux_chandrashekar, flux_kennedy_gruber. As surface flux you can use all volume fluxes and additionally for instance flux_lax_friedrichs, flux_hll, flux_hllc.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/adaptive_mesh_refinement/3e0d31e8.svg b/previews/PR1697/tutorials/adaptive_mesh_refinement/3e0d31e8.svg new file mode 100644 index 00000000000..b413294fce4 --- /dev/null +++ b/previews/PR1697/tutorials/adaptive_mesh_refinement/3e0d31e8.svg @@ -0,0 +1,1518 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adaptive_mesh_refinement/index.html b/previews/PR1697/tutorials/adaptive_mesh_refinement/index.html new file mode 100644 index 00000000000..5f05431c283 --- /dev/null +++ b/previews/PR1697/tutorials/adaptive_mesh_refinement/index.html @@ -0,0 +1,91 @@ + +12 Adaptive mesh refinement · Trixi.jl

12: Adaptive mesh refinement

Adaptive mesh refinement (AMR) is a method of adapting the resolution of the numerical method to the solution features such as turbulent regions or shocks. In those critical regions of the domain, we want the simulation to use elements with smaller mesh sizes compared to other regions. This should be automatically and dynamically adapted during the run of the simulation.

Implementation in Trixi.jl

In Trixi.jl, AMR is possible for the mesh types TreeMesh and P4estMesh. Both meshes are organized in a tree structure and therefore, each element can be refined independently. In Trixi.jl, AMR is restricted to a 2:1 refinement ratio between neighbor elements. This means that the maximum resolution difference of neighboring elements is a factor of two.

The implementation of AMR is divided into different steps. The basic refinement setting contains an indicator and a controller. These are added to the simulation by using an AMR callback.

Indicators

An indicator estimates the current accuracy of the numerical approximation. It indicates which regions of the domain need finer or coarser resolutions. In Trixi.jl, you can use for instance IndicatorLöhner and IndicatorHennemannGassner.

IndicatorLöhner (also callable with IndicatorLoehner) is an interpretation and adaptation of a FEM indicator by Löhner (1987) and estimates a weighted second derivative of a specified variable locally.

amr_indicator = IndicatorLöhner(semi, variable=variable)

All indicators have the parameter variable which is used to specify the variable for the indicator calculation. You can use for instance density, pressure or density_pressure for the compressible Euler equations. Moreover, you have the option to use simply the first conservation variable with first for any equations. This might be a good choice for a starting example.

IndicatorHennemannGassner, also used as a shock-capturing indicator, was developed by Hennemann et al. (2021) and is explained in detail in the tutorial about shock-capturing. It can be constructed as follows.

amr_indicator = IndicatorHennemannGassner(semi,
+                                          alpha_max=0.5,
+                                          alpha_min=0.001,
+                                          alpha_smooth=true,
+                                          variable=variable)

Another indicator is the very basic IndicatorMax. It indicates the maximal value of a variable and is therefore mostly used for verification and testing. But it might be useful for the basic understanding of the implementation of indicators and AMR in Trixi.jl.

amr_indicator = IndicatorMax(semi, variable=variable)

Controllers

The spatial discretization into elements is tree-based for both AMR supporting mesh types TreeMesh and P4estMesh. Thus, the higher the level in the tree the higher the level of refinement. For instance, a mesh element of level 3 has double resolution in each direction compared to another element with level 2.

To map specific indicator values to a desired level of refinement, Trixi.jl uses controllers. They are build in three levels: There is a base level of refinement base_level, which is the minimum allowed refinement level. Then, there is a medium level med_level, which corresponds to the initial level of refinement, for indicator values above the threshold med_threshold and equally, a maximal level max_level for values above max_threshold. This variant of controller is called ControllerThreeLevel in Trixi.jl.

amr_controller = ControllerThreeLevel(semi, amr_indicator;
+                                      base_level=4,
+                                      med_level=5, med_threshold=0.1,
+                                      max_level=6, max_threshold=0.6)

You can also set med_level=0 to use the current level as target, see the docstring of ControllerThreeLevel.

An extension is ControllerThreeLevelCombined, which uses two different indicators. The primary indicator works the same as the single indicator for ControllerThreeLevel. The second indicator with its own maximum threshold adds the property, that the target level is set to max_level additionally if this indicator's value is greater than max_threshold_secondary. This is for instance used to assure that a shock has always the maximum refinement level.

amr_controller = ControllerThreeLevelCombined(semi, indicator_primary, indicator_secondary;
+                                              base_level=2,
+                                              med_level=6, med_threshold=0.0003,
+                                              max_level=8, max_threshold=0.003,
+                                              max_threshold_secondary=0.3)

This controller is for instance used in elixir_euler_astro_jet_amr.jl.

Callback

The AMR indicator and controller are added to the simulation through the callback AMRCallback. It contains a semidiscretization semi, the controller amr_controller and the parameters interval, adapt_initial_condition, and adapt_initial_condition_only_refine.

Adaptive mesh refinement will be performed every interval time steps. adapt_initial_condition indicates whether the initial condition already should be adapted before the first time step. And with adapt_initial_condition_only_refine=true the mesh is only refined at the beginning but not coarsened.

amr_callback = AMRCallback(semi, amr_controller,
+                           interval=5,
+                           adapt_initial_condition=true,
+                           adapt_initial_condition_only_refine=true)

Exemplary simulation

Here, we want to implement a simple AMR simulation of the 2D linear advection equation for a Gaussian pulse.

using OrdinaryDiffEq
+using Trixi
+
+advection_velocity = (0.2, -0.7)
+equations = LinearScalarAdvectionEquation2D(advection_velocity)
+
+initial_condition = initial_condition_gauss
+solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
+
+coordinates_min = (-5.0, -5.0)
+coordinates_max = ( 5.0,  5.0)
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=4,
+                n_cells_max=30_000)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)
+
+
+tspan = (0.0, 10.0)
+ode = semidiscretize(semi, tspan);

For the best understanding about indicators and controllers, we use the simple AMR indicator IndicatorMax. As described before, it returns the maximal value of the specified variable (here the only conserved variable). Therefore, regions with a high maximum are refined. This is not really useful numerical application, but a nice demonstration example.

amr_indicator = IndicatorMax(semi, variable=first)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ IndicatorMax                                                                                     │
+│ ════════════                                                                                     │
+│ indicator variable: …………………………… first                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

These values are transferred to a refinement level with the ControllerThreeLevel, such that every element with maximal value greater than 0.1 is refined once and elements with maximum above 0.6 are refined twice.

amr_controller = ControllerThreeLevel(semi, amr_indicator,
+                                      base_level=4,
+                                      med_level=5, med_threshold=0.1,
+                                      max_level=6, max_threshold=0.6)
+
+amr_callback = AMRCallback(semi, amr_controller,
+                           interval=5,
+                           adapt_initial_condition=true,
+                           adapt_initial_condition_only_refine=true)
+
+stepsize_callback = StepsizeCallback(cfl=0.9)
+
+callbacks = CallbackSet(amr_callback, stepsize_callback);

Running 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);

We plot the solution and add the refined mesh at the end of the simulation.

using Plots
+pd = PlotData2D(sol)
+plot(pd)
+plot!(getmesh(pd))
Example block output

More examples

Trixi.jl provides many elixirs using AMR. We want to give some examples for different mesh types:

Animations of more interesting and complicated AMR simulations can be found below and on Trixi.jl's youtube channel "Trixi Framework".

First, we give a purely hyperbolic simulation of a Sedov blast wave with self-gravity. This simulation uses the mesh type TreeMesh as we did and the AMR indicator IndicatorHennemannGassner.

+

Source: Trixi.jl's YouTube channel Trixi Framework

The next example is a numerical simulation of an ideal MHD rotor on an unstructured AMR mesh. The used mesh type is a P4estMesh.

+

Source: Trixi.jl's YouTube channel Trixi Framework

For more information, please have a look at the respective links.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/adding_new_parabolic_terms/35a5f0a8.svg b/previews/PR1697/tutorials/adding_new_parabolic_terms/35a5f0a8.svg new file mode 100644 index 00000000000..89f5619c9c7 --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_parabolic_terms/35a5f0a8.svg @@ -0,0 +1,756 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_parabolic_terms/index.html b/previews/PR1697/tutorials/adding_new_parabolic_terms/index.html new file mode 100644 index 00000000000..fd1f6d61705 --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_parabolic_terms/index.html @@ -0,0 +1,94 @@ + +11 Adding new parabolic terms · Trixi.jl

11: Adding new parabolic terms

This demo illustrates the steps involved in adding new parabolic terms for the scalar advection equation. In particular, we will add an anisotropic diffusion. We begin by defining the hyperbolic (advection) part of the advection-diffusion equation.

using OrdinaryDiffEq
+using Trixi
+
+
+advection_velocity = (1.0, 1.0)
+equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);

Define a new parabolic equation type

Next, we define a 2D parabolic diffusion term type. This is similar to LaplaceDiffusion2D except that the diffusivity field refers to a spatially constant diffusivity matrix now. Note that ConstantAnisotropicDiffusion2D has a field for equations_hyperbolic. It is useful to have information about the hyperbolic system available to the parabolic part so that we can reuse functions defined for hyperbolic equations (such as varnames).

struct ConstantAnisotropicDiffusion2D{E, T} <: Trixi.AbstractEquationsParabolic{2, 1}
+  diffusivity::T
+  equations_hyperbolic::E
+end
+
+varnames(variable_mapping, equations_parabolic::ConstantAnisotropicDiffusion2D) =
+  varnames(variable_mapping, equations_parabolic.equations_hyperbolic)
varnames (generic function with 1 method)

Next, we define the viscous flux function. We assume that the mixed hyperbolic-parabolic system is of the form

\[\partial_t u(t,x) + \partial_x (f_1(u) - g_1(u, \nabla u)) + + \partial_y (f_2(u) - g_2(u, \nabla u)) = 0\]

where $f_1(u)$, $f_2(u)$ are the hyperbolic fluxes and $g_1(u, \nabla u)$, $g_2(u, \nabla u)$ denote the viscous fluxes. For anisotropic diffusion, the viscous fluxes are the first and second components of the matrix-vector product involving diffusivity and the gradient vector.

Here, we specialize the flux to our new parabolic equation type ConstantAnisotropicDiffusion2D.

function Trixi.flux(u, gradients, orientation::Integer, equations_parabolic::ConstantAnisotropicDiffusion2D)
+  @unpack diffusivity = equations_parabolic
+  dudx, dudy = gradients
+  if orientation == 1
+    return SVector(diffusivity[1, 1] * dudx + diffusivity[1, 2] * dudy)
+  else # if orientation == 2
+    return SVector(diffusivity[2, 1] * dudx + diffusivity[2, 2] * dudy)
+  end
+end

Defining boundary conditions

Trixi.jl's implementation of parabolic terms discretizes both the gradient and divergence using weak formulation. In other words, we discretize the system

\[\begin{aligned} +\bm{q} &= \nabla u \\ +\bm{\sigma} &= \begin{pmatrix} g_1(u, \bm{q}) \\ g_2(u, \bm{q}) \end{pmatrix} \\ +\text{viscous contribution } &= \nabla \cdot \bm{\sigma} +\end{aligned}\]

Boundary data must be specified for all spatial derivatives, e.g., for both the gradient equation $\bm{q} = \nabla u$ and the divergence of the viscous flux $\nabla \cdot \bm{\sigma}$. We account for this by introducing internal Gradient and Divergence types which are used to dispatch on each type of boundary condition.

As an example, let us introduce a Dirichlet boundary condition with constant boundary data.

struct BoundaryConditionConstantDirichlet{T <: Real}
+  boundary_value::T
+end

This boundary condition contains only the field boundary_value, which we assume to be some real-valued constant which we will impose as the Dirichlet data on the boundary.

Boundary conditions have generally been defined as "callable structs" (also known as "functors"). For each boundary condition, we need to specify the appropriate boundary data to return for both the Gradient and Divergence. Since the gradient is operating on the solution u, the boundary data should be the value of u, and we can directly impose Dirichlet data.

@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,
+                                                                          x, t, operator_type::Trixi.Gradient,
+                                                                          equations_parabolic::ConstantAnisotropicDiffusion2D)
+  return boundary_condition.boundary_value
+end

While the gradient acts on the solution u, the divergence acts on the viscous flux $\bm{\sigma}$. Thus, we have to supply boundary data for the Divergence operator that corresponds to $\bm{\sigma}$. However, we've already imposed boundary data on u for a Dirichlet boundary condition, and imposing boundary data for $\bm{\sigma}$ might overconstrain our problem.

Thus, for the Divergence boundary data under a Dirichlet boundary condition, we simply return flux_inner, which is boundary data for $\bm{\sigma}$ computed using the "inner" or interior solution. This way, we supply boundary data for the divergence operation without imposing any additional conditions.

@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,
+                                                                          x, t, operator_type::Trixi.Divergence,
+                                                                          equations_parabolic::ConstantAnisotropicDiffusion2D)
+  return flux_inner
+end

A note on the choice of gradient variables

It is often simpler to transform the solution variables (and solution gradients) to another set of variables prior to computing the viscous fluxes (see CompressibleNavierStokesDiffusion2D for an example of this). If this is done, then the boundary condition for the Gradient operator should be modified accordingly as well.

Putting things together

Finally, we can instantiate our new parabolic equation type, define boundary conditions, and run a simulation. The specific anisotropic diffusion matrix we use produces more dissipation in the direction $(1, -1)$ as an isotropic diffusion.

For boundary conditions, we impose that $u=1$ on the left wall, $u=2$ on the bottom wall, and $u = 0$ on the outflow walls. The initial condition is taken to be $u = 0$. Note that we use BoundaryConditionConstantDirichlet only for the parabolic boundary conditions, since we have not defined its behavior for the hyperbolic part.

using Trixi: SMatrix
+diffusivity = 5.0e-2 * SMatrix{2, 2}([2 -1; -1 2])
+equations_parabolic = ConstantAnisotropicDiffusion2D(diffusivity, equations_hyperbolic);
+
+boundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1.0)),
+                                    y_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(2.0)),
+                                    y_pos = boundary_condition_do_nothing,
+                                    x_pos = boundary_condition_do_nothing)
+
+boundary_conditions_parabolic = (; x_neg = BoundaryConditionConstantDirichlet(1.0),
+                                   y_neg = BoundaryConditionConstantDirichlet(2.0),
+                                   y_pos = BoundaryConditionConstantDirichlet(0.0),
+                                   x_pos = BoundaryConditionConstantDirichlet(0.0));
+
+solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
+coordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))
+coordinates_max = ( 1.0,  1.0) # maximum coordinates (max(x), max(y))
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=4,
+                periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure
+
+initial_condition = (x, t, equations) -> SVector(0.0)
+
+semi = SemidiscretizationHyperbolicParabolic(mesh,
+                                             (equations_hyperbolic, equations_parabolic),
+                                             initial_condition, solver;
+                                             boundary_conditions=(boundary_conditions_hyperbolic,
+                                                                  boundary_conditions_parabolic))
+
+tspan = (0.0, 2.0)
+ode = semidiscretize(semi, tspan)
+callbacks = CallbackSet(SummaryCallback())
+time_int_tol = 1.0e-6
+sol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,
+            ode_default_options()..., callback=callbacks);
+
+using Plots
+plot(sol)
Example block output

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/00857e32.svg b/previews/PR1697/tutorials/adding_new_scalar_equations/00857e32.svg new file mode 100644 index 00000000000..c747bfff0ab --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/00857e32.svg @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/49ba4521.svg b/previews/PR1697/tutorials/adding_new_scalar_equations/49ba4521.svg new file mode 100644 index 00000000000..e68d62a059d --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/49ba4521.svg @@ -0,0 +1,43 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/a4331a9e.svg b/previews/PR1697/tutorials/adding_new_scalar_equations/a4331a9e.svg new file mode 100644 index 00000000000..9c038da8eee --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/a4331a9e.svg @@ -0,0 +1,43 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/dfd5e74f.svg b/previews/PR1697/tutorials/adding_new_scalar_equations/dfd5e74f.svg new file mode 100644 index 00000000000..0a6f24db0d6 --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/dfd5e74f.svg @@ -0,0 +1,47 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/f7da1af1.svg b/previews/PR1697/tutorials/adding_new_scalar_equations/f7da1af1.svg new file mode 100644 index 00000000000..6699ec805b1 --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/f7da1af1.svg @@ -0,0 +1,43 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_new_scalar_equations/index.html b/previews/PR1697/tutorials/adding_new_scalar_equations/index.html new file mode 100644 index 00000000000..9a3f5288151 --- /dev/null +++ b/previews/PR1697/tutorials/adding_new_scalar_equations/index.html @@ -0,0 +1,205 @@ + +8 Adding a new scalar conservation law · Trixi.jl

8: Adding a new scalar conservation law

If you want to use Trixi.jl for your own research, you might be interested in a new physics model that's not already included in Trixi.jl. In this tutorial, we will implement the cubic conservation law

\[\partial_t u(t,x) + \partial_x u(t,x)^3 = 0\]

in a periodic domain in one space dimension. In Trixi.jl, such a mathematical model is encoded as a subtype of Trixi.AbstractEquations.

Basic setup

using Trixi
+
+struct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,
+                                                1 #= number of primary variables, i.e. scalar =#};
+end

We create CubicEquation as an empty struct since we do not use any parameters for this equation. Other models could bundle arbitrary parameters, e.g., the ideal gas constant for the compressible Euler equations.

Next, we define the physical flux f(u) = u^3 using the calling structure used in Trixi.jl.

Trixi.flux(u, orientation, equation::CubicEquation) = u.^3
+Trixi.varnames(_, ::CubicEquation) = ("scalar",)

In Trixi.jl, the conserved variables u are usually passed as SVectors of variables at a single physical location. Hence, we must use u.^3 instead of the scalar operation u^3.

That's already enough to run a simple simulation with a standard DGSEM discretization using the non-dissipative central flux at interfaces.

using OrdinaryDiffEq
+
+# Create a simulation setup
+equation = CubicEquation()
+
+initial_condition_sine(x, t, equation::CubicEquation) = SVector(sinpi(x[1]))
+
+mesh = TreeMesh(-1.0, 1.0, # min/max coordinates
+                initial_refinement_level=4,
+                n_cells_max=10^4)
+
+solver = DGSEM(3 #= polynomial degree =#, flux_central)
+
+semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… CubicEquation                                                    │
+│ initial condition: ……………………………… initial_condition_sine                                           │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… nothing                                                          │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We wrap the return value of the initial_condition_sine inside an SVector since that's the approach used in Trixi.jl also for systems of equations. We need to index the spatial coordinate x[1], since it is an SVector with one component. In multiple space dimensions, all spatial coordinates are passed together.

Next, we create an ODEProblem from the SciML/DifferentialEquations ecosystem. We can solve this ODE numerically using any time integration method, e.g., SSPRK43 from OrdinaryDiffEq.jl. Before, we set up a callback to summarize the simulation setup.

# Create ODE problem with given time span
+tspan = (0.0, 0.09)
+ode = semidiscretize(semi, tspan)
+
+summary_callback = SummaryCallback()
+callbacks = CallbackSet(summary_callback)
+
+# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks
+sol = solve(ode, SSPRK43();
+            ode_default_options()..., callback=callbacks);

+████████╗██████╗ ██╗██╗  ██╗██╗
+╚══██╔══╝██╔══██╗██║╚██╗██╔╝██║
+   ██║   ██████╔╝██║ ╚███╔╝ ██║
+   ██║   ██╔══██╗██║ ██╔██╗ ██║
+   ██║   ██║  ██║██║██╔╝ ██╗██║
+   ╚═╝   ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═╝
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… CubicEquation                                                    │
+│ initial condition: ……………………………… initial_condition_sine                                           │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… nothing                                                          │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 10000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ CubicEquation                                                                                    │
+│ ═════════════                                                                                    │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_central                                                     │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Time integration                                                                                 │
+│ ════════════════                                                                                 │
+│ Start time: ………………………………………………… 0.0                                                              │
+│ Final time: ………………………………………………… 0.09                                                             │
+│ time integrator: …………………………………… SSPRK43                                                          │
+│ adaptive: ……………………………………………………… true                                                             │
+│ abstol: …………………………………………………………… 1.0e-6                                                           │
+│ reltol: …………………………………………………………… 0.001                                                            │
+│ controller: ………………………………………………… PIController{Rational{Int64}}(7//30, 2//15)                      │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Environment information                                                                          │
+│ ═══════════════════════                                                                          │
+│ #threads: ……………………………………………………… 1                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

That's it, you ran your first simulation using your new equation with Trixi.jl! Now, we can plot the solution at the final time using Plots.jl.

using Plots
+plot(sol)
Example block output

You can already see that discontinuities will develop and oscillations start to occur around steep parts of the wave. That's expected from our central discretization. To avoid these issues, we need to use dissipative numerical fluxes (approximate Riemann solvers) at interfaces.

Advanced setup

Thus, we add a Godunov's flux for our cubic equation. That is easy for this equation since the wave speed f'(u) = 3u^2 is always non-negative.

@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)

Let's run the example again but with a dissipative numerical flux at interfaces. remake will recreate the semidiscretization we used before and only change selected parameters, in this case the solver.

# A new setup with dissipation
+semi = remake(semi, solver=DGSEM(3, flux_godunov))
+ode = semidiscretize(semi, tspan)
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot!(sol)
Example block output

You can see that there are fewer oscillations, in particular around steep edges. Now let's increase the final time (and also the spatial resolution).

# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)
+semi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))
+ode = semidiscretize(semi, (0.0, 0.5) #= tspan =#)
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot(sol)
Example block output

You can observe that nonclassical shocks develop and are stable under grid refinement, e.g. for initial_refinement_level=12. In this case, these nonclassical shocks can be avoided by using an entropy-dissipative semidiscretization. Thus, we need to define an entropy-conservative numerical flux

@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)
+  return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))
+end

and use a VolumeIntegralFluxDifferencing instead of the standard VolumeIntegralWeakForm in the DGSEM.

# Let's use a provably entropy-dissipative semidiscretization
+semi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))
+ode = semidiscretize(semi, (0.0, 0.5))
+sol = solve(ode, SSPRK43(); ode_default_options()...);
+plot(sol)
Example block output

Possible next steps could be

  • to define Trixi.max_abs_speeds(u, equations::CubicEquation) = 3 * u[1]^2 to use CFL-based time step control via a StepsizeCallback
  • to define quantities of interest like Trixi.entropy(u, equations::CubicEquation) = u[1]^2 and integrate them in a simulation using the AnalysisCallback
  • to experiment with shock-capturing volume integrals VolumeIntegralShockCapturingHG and adaptive mesh refinement AMRCallback

For further reading, Trixi.jl provides another example on adding a scalar equation. In the elixir about the KPP problem, the 2D scalar "KPP equation" from Kurganov, Petrova, Popov (2007) is implemented.

Summary of the code

To sum up, here is the complete code that we used (without the callbacks since these create a lot of unnecessary output in the doctests of this tutorial). In addition, we create the struct inside the new module CubicConservationLaw. That ensures that we can re-create structs defined therein without having to restart Julia.

# Define new physics
+module CubicConservationLaw
+
+using Trixi
+
+struct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,
+                                                1 #= number of primary variables, i.e. scalar =#}
+end
+
+@inline Trixi.flux(u, orientation, equation::CubicEquation) = u.^3
+Trixi.varnames(_, ::CubicEquation) = ("scalar",)
+
+@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)
+@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)
+  return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))
+end
+
+end # module
+
+
+# Create a simulation setup
+import .CubicConservationLaw
+using Trixi
+using OrdinaryDiffEq
+using Plots
+
+equation = CubicConservationLaw.CubicEquation()
+
+initial_condition_sine(x, t, equation::CubicConservationLaw.CubicEquation) = SVector(sinpi(x[1]))
+
+mesh = TreeMesh(-1.0, 1.0, # min/max coordinates
+                initial_refinement_level=4,
+                n_cells_max=10^4)
+
+solver = DGSEM(3 #= polynomial degree =#, flux_central)
+
+semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)
+
+# Create ODE problem with given time span
+tspan = (0.0, 0.1)
+ode = semidiscretize(semi, tspan)
+
+# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot(sol)
+
+
+# A new setup with dissipation
+semi = remake(semi, solver=DGSEM(3, flux_godunov))
+ode = semidiscretize(semi, tspan)
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot!(sol)
+
+
+# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)
+semi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))
+ode = semidiscretize(semi, (0.0, 0.5))
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot(sol)
+
+
+# Let's use a provably entropy-dissipative semidiscretization
+semi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))
+ode = semidiscretize(semi, (0.0, 0.5))
+sol = solve(ode, SSPRK43(); ode_default_options()...)
+plot(sol)
Example block output

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/adding_nonconservative_equation/53f78937.svg b/previews/PR1697/tutorials/adding_nonconservative_equation/53f78937.svg new file mode 100644 index 00000000000..485be153696 --- /dev/null +++ b/previews/PR1697/tutorials/adding_nonconservative_equation/53f78937.svg @@ -0,0 +1,80 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/adding_nonconservative_equation/index.html b/previews/PR1697/tutorials/adding_nonconservative_equation/index.html new file mode 100644 index 00000000000..905b765fcf1 --- /dev/null +++ b/previews/PR1697/tutorials/adding_nonconservative_equation/index.html @@ -0,0 +1,243 @@ + +9 Adding a non-conservative equation · Trixi.jl

9: Adding a non-conservative equation

If you want to use Trixi.jl for your own research, you might be interested in a new physics model that is not present in Trixi.jl. In this tutorial, we will implement the nonconservative linear advection equation in a periodic domain

\[\left\{ +\begin{aligned}&\partial_t u(t,x) + a(x) \partial_x u(t,x) = 0 \\ +&u(0,x)=\sin(x) \\ +&u(t,-\pi)=u(t,\pi) +\end{aligned} +\right.\]

where $a(x) = 2 + \cos(x)$. The analytic solution is

\[u(t,x)=-\sin \left(2 \tan ^{-1}\left(\sqrt{3} \tan \left(\frac{\sqrt{3} t}{2}-\tan ^{-1}\left(\frac{1}{\sqrt{3}}\tan \left(\frac{x}{2}\right)\right)\right)\right)\right)\]

In Trixi.jl, such a mathematical model is encoded as a subtype of Trixi.AbstractEquations.

Basic setup

Since there is no native support for variable coefficients, we need to transform the PDE to the following system:

\[\left\{ +\begin{aligned}&\partial_t \begin{pmatrix}u(t,x)\\a(t,x) \end{pmatrix} +\begin{pmatrix} a(t,x) \partial_x u(t,x) \\ 0 \end{pmatrix} = 0 \\ +&u(0,x)=\sin(x) \\ +&a(0,x)=2+\cos(x) \\ +&u(t,-\pi)=u(t,\pi) +\end{aligned} +\right.\]

# Define new physics
+using Trixi
+using Trixi: AbstractEquations, get_node_vars
+import Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,
+              have_nonconservative_terms
+
+# Since there is no native support for variable coefficients, we use two
+# variables: one for the basic unknown `u` and another one for the coefficient `a`
+struct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,
+                                                                   2 #= two variables (u,a) =#}
+end
+
+varnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = ("scalar", "advection_velocity")
+
+default_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()
+
+
+# The conservative part of the flux is zero
+flux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)
+
+# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation
+function max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)
+    _, advection_velocity_ll = u_ll
+    _, advection_velocity_rr = u_rr
+
+    return max(abs(advection_velocity_ll), abs(advection_velocity_rr))
+end
+
+
+# We use nonconservative terms
+have_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()
+
+# This "nonconservative numerical flux" implements the nonconservative terms.
+# In general, nonconservative terms can be written in the form
+#   g(u) ∂ₓ h(u)
+# Thus, a discrete difference approximation of this nonconservative term needs
+# - `u mine`:  the value of `u` at the current position (for g(u))
+# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))
+function flux_nonconservative(u_mine, u_other, orientation,
+                              equations::NonconservativeLinearAdvectionEquation)
+    _, advection_velocity = u_mine
+    scalar, _             = u_other
+
+    return SVector(advection_velocity * scalar, zero(scalar))
+end
flux_nonconservative (generic function with 1 method)

The implementation of nonconservative terms uses a single "nonconservative flux" function flux_nonconservative. It will basically be applied in a loop of the form

du_m(D, u) = sum(D[m, l] * flux_nonconservative(u[m], u[l], 1, equations)) # orientation 1: x

where D is the derivative matrix and u contains the nodal solution values.

Now, we can run a simple simulation using a DGSEM discretization.

# Create a simulation setup
+using Trixi
+using OrdinaryDiffEq
+
+equation = NonconservativeLinearAdvectionEquation()
+
+# You can derive the exact solution for this setup using the method of
+# characteristics
+function initial_condition_sine(x, t, equation::NonconservativeLinearAdvectionEquation)
+    x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))
+    scalar = sin(x0)
+    advection_velocity = 2 + cos(x[1])
+    SVector(scalar, advection_velocity)
+end
+
+# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries
+mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates
+                initial_refinement_level=4, n_cells_max=10^4)
+
+# Create a DGSEM solver with polynomials of degree `polydeg`
+# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`
+# as `surface_flux` and `volume_flux` when working with nonconservative terms
+volume_flux  = (flux_central, flux_nonconservative)
+surface_flux = (flux_lax_friedrichs, flux_nonconservative)
+solver = DGSEM(polydeg=3, surface_flux=surface_flux,
+               volume_integral=VolumeIntegralFluxDifferencing(volume_flux))
+
+# Setup the spatial semidiscretization containing all ingredients
+semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)
+
+# Create an ODE problem with given time span
+tspan = (0.0, 1.0)
+ode = semidiscretize(semi, tspan)
+
+# Set up some standard callbacks summarizing the simulation setup and computing
+# errors of the numerical solution
+summary_callback = SummaryCallback()
+analysis_callback = AnalysisCallback(semi, interval=50)
+callbacks = CallbackSet(summary_callback, analysis_callback)
+
+# OrdinaryDiffEq's `solve` method evolves the solution in time and executes
+# the passed callbacks
+sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,
+            save_everystep=false, callback=callbacks)
+
+# Print the timer summary
+summary_callback()
+
+# Plot the numerical solution at the final time
+using Plots: plot
+plot(sol)
Example block output

You see a plot of the final solution.

We can check whether everything fits together by refining the grid and comparing the numerical errors. First, we look at the error using the grid resolution above.

error_1 = analysis_callback(sol).l2 |> first
0.00029609575838969394

Next, we increase the grid resolution by one refinement level and run the simulation again.

mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates
+                initial_refinement_level=5, n_cells_max=10^4)
+
+semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)
+
+tspan = (0.0, 1.0)
+ode = semidiscretize(semi, tspan);
+
+summary_callback = SummaryCallback()
+analysis_callback = AnalysisCallback(semi, interval=50)
+callbacks = CallbackSet(summary_callback, analysis_callback);
+
+sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,
+            save_everystep=false, callback=callbacks);
+summary_callback()
+
+error_2 = analysis_callback(sol).l2 |> first
1.8602128505981686e-5
error_1 / error_2
15.917305285493626

As expected, the new error is roughly reduced by a factor of 16, corresponding to an experimental order of convergence of 4 (for polynomials of degree 3).

Summary of the code

Here is the complete code that we used (without the callbacks since these create a lot of unnecessary output in the doctests of this tutorial). In addition, we create the struct inside the new module NonconservativeLinearAdvection. That ensures that we can re-create structs defined therein without having to restart Julia.

Define new physics

module NonconservativeLinearAdvection
+
+using Trixi
+using Trixi: AbstractEquations, get_node_vars
+import Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,
+              have_nonconservative_terms
+
+# Since there is not yet native support for variable coefficients, we use two
+# variables: one for the basic unknown `u` and another one for the coefficient `a`
+struct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,
+                                                                   2 #= two variables (u,a) =#}
+end
+
+varnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = ("scalar", "advection_velocity")
+
+default_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()
+
+
+# The conservative part of the flux is zero
+flux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)
+
+# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation
+function max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)
+    _, advection_velocity_ll = u_ll
+    _, advection_velocity_rr = u_rr
+
+    return max(abs(advection_velocity_ll), abs(advection_velocity_rr))
+end
+
+
+# We use nonconservative terms
+have_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()
+
+# This "nonconservative numerical flux" implements the nonconservative terms.
+# In general, nonconservative terms can be written in the form
+#   g(u) ∂ₓ h(u)
+# Thus, a discrete difference approximation of this nonconservative term needs
+# - `u mine`:  the value of `u` at the current position (for g(u))
+# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))
+function flux_nonconservative(u_mine, u_other, orientation,
+                              equations::NonconservativeLinearAdvectionEquation)
+    _, advection_velocity = u_mine
+    scalar, _            = u_other
+
+    return SVector(advection_velocity * scalar, zero(scalar))
+end
+
+end # module
+
+
+
+# Create a simulation setup
+import .NonconservativeLinearAdvection
+using Trixi
+using OrdinaryDiffEq
+
+equation = NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation()
+
+# You can derive the exact solution for this setup using the method of
+# characteristics
+function initial_condition_sine(x, t, equation::NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation)
+    x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))
+    scalar = sin(x0)
+    advection_velocity = 2 + cos(x[1])
+    SVector(scalar, advection_velocity)
+end
+
+# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries
+mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates
+                initial_refinement_level=4, n_cells_max=10^4)
+
+# Create a DGSEM solver with polynomials of degree `polydeg`
+# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`
+# as `surface_flux` and `volume_flux` when working with nonconservative terms
+volume_flux  = (flux_central, NonconservativeLinearAdvection.flux_nonconservative)
+surface_flux = (flux_lax_friedrichs, NonconservativeLinearAdvection.flux_nonconservative)
+solver = DGSEM(polydeg=3, surface_flux=surface_flux,
+               volume_integral=VolumeIntegralFluxDifferencing(volume_flux))
+
+# Setup the spatial semidiscretization containing all ingredients
+semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)
+
+# Create an ODE problem with given time span
+tspan = (0.0, 1.0)
+ode = semidiscretize(semi, tspan);
+
+# Set up some standard callbacks summarizing the simulation setup and computing
+# errors of the numerical solution
+summary_callback = SummaryCallback()
+analysis_callback = AnalysisCallback(semi, interval=50)
+callbacks = CallbackSet(summary_callback, analysis_callback);
+
+# OrdinaryDiffEq's `solve` method evolves the solution in time and executes
+# the passed callbacks
+sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,
+            save_everystep=false);
+
+# Plot the numerical solution at the final time
+using Plots: plot
+plot(sol);

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/custom_semidiscretization/686132e6.svg b/previews/PR1697/tutorials/custom_semidiscretization/686132e6.svg new file mode 100644 index 00000000000..8e5b828ab28 --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/686132e6.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/custom_semidiscretization/bd8c446b.svg b/previews/PR1697/tutorials/custom_semidiscretization/bd8c446b.svg new file mode 100644 index 00000000000..6ca5a1b0cfe --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/bd8c446b.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/custom_semidiscretization/dfd5cf6d.svg b/previews/PR1697/tutorials/custom_semidiscretization/dfd5cf6d.svg new file mode 100644 index 00000000000..ff04b8910d3 --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/dfd5cf6d.svg @@ -0,0 +1,50 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/custom_semidiscretization/eb8e84c6.svg b/previews/PR1697/tutorials/custom_semidiscretization/eb8e84c6.svg new file mode 100644 index 00000000000..ccb70af915f --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/eb8e84c6.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/custom_semidiscretization/f31b1a9a.svg b/previews/PR1697/tutorials/custom_semidiscretization/f31b1a9a.svg new file mode 100644 index 00000000000..24db973162b --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/f31b1a9a.svg @@ -0,0 +1,48 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/custom_semidiscretization/index.html b/previews/PR1697/tutorials/custom_semidiscretization/index.html new file mode 100644 index 00000000000..31eabcadcc8 --- /dev/null +++ b/previews/PR1697/tutorials/custom_semidiscretization/index.html @@ -0,0 +1,597 @@ + +17 Custom semidiscretizations · Trixi.jl

17: Custom semidiscretizations

As described in the overview section, semidiscretizations are high-level descriptions of spatial discretizations in Trixi.jl. Trixi.jl's main focus is on hyperbolic conservation laws represented in a SemidiscretizationHyperbolic. Hyperbolic-parabolic problems based on the advection-diffusion equation or the compressible Navier-Stokes equations can be represented in a SemidiscretizationHyperbolicParabolic. This is described in the basic tutorial on parabolic terms and its extension to custom parabolic terms. In this tutorial, we will describe how these semidiscretizations work and how they can be used to create custom semidiscretizations involving also other tasks.

Overview of the right-hand side evaluation

The semidiscretizations provided by Trixi.jl are set up to create ODEProblems from the SciML ecosystem for ordinary differential equations. In particular, a spatial semidiscretization can be wrapped in an ODE problem using semidiscretize, which returns an ODEProblem. This ODEProblem bundles an initial condition, a right-hand side (RHS) function, the time span, and possible parameters. The ODEProblems created by Trixi.jl use the semidiscretization passed to semidiscretize as a parameter. For a SemidiscretizationHyperbolic, the ODEProblem wraps Trixi.rhs! as ODE RHS. For a SemidiscretizationHyperbolicParabolic, Trixi.jl uses a SplitODEProblem combining Trixi.rhs_parabolic! for the (potentially) stiff part and Trixi.rhs! for the other part.

Standard Trixi.jl setup

In this tutorial, we will consider the linear advection equation with source term

\[\partial_t u(t,x) + \partial_x u(t,x) = -\exp(-t) \sin\bigl(\pi (x - t) \bigr)\]

with periodic boundary conditions in the domain [-1, 1] as a model problem. The initial condition is

\[u(0,x) = \sin(\pi x).\]

The source term results in some damping and the analytical solution

\[u(t,x) = \exp(-t) \sin\bigl(\pi (x - t) \bigr).\]

First, we discretize this equation using the standard functionality of Trixi.jl.

using Trixi, OrdinaryDiffEq, Plots

The linear scalar advection equation is already implemented in Trixi.jl as LinearScalarAdvectionEquation1D. We construct it with an advection velocity 1.0.

equations = LinearScalarAdvectionEquation1D(1.0)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation1D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Next, we use a standard DGSEM solver.

solver = DGSEM(polydeg = 3)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_central                                                     │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We create a simple TreeMesh in 1D.

coordinates_min = (-1.0,)
+coordinates_max = (+1.0,)
+mesh = TreeMesh(coordinates_min, coordinates_max;
+                initial_refinement_level = 4,
+                n_cells_max = 10^4,
+                periodicity = true)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 10000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We wrap everything in in a semidiscretization and pass the source terms as a standard Julia function. Please note that Trixi.jl uses SVectors from StaticArrays.jl to store the conserved variables u. Thus, the return value of the source terms must be wrapped in an SVector - even if we consider just a scalar problem.

function initial_condition(x, t, equations)
+    return SVector(exp(-t) * sinpi(x[1] - t))
+end
+
+function source_terms_standard(u, x, t, equations)
+    return -initial_condition(x, t, equations)
+end
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition,
+                                    solver;
+                                    source_terms = source_terms_standard)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… LinearScalarAdvectionEquation1D                                  │
+│ initial condition: ……………………………… initial_condition                                                │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… source_terms_standard                                            │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Now, we can create the ODEProblem, solve the resulting ODE using a time integration method from OrdinaryDiffEq.jl, and visualize the numerical solution at the final time using Plots.jl.

tspan = (0.0, 3.0)
+ode = semidiscretize(semi, tspan)
+
+sol = solve(ode, RDPK3SpFSAL49(); ode_default_options()...)
+
+plot(sol; label = "numerical sol.", legend = :topright)
Example block output

We can also plot the analytical solution for comparison. Since Trixi.jl uses SVectors for the variables, we take their first (and only) component to get the scalar value for manual plotting.

let
+   x = range(-1.0, 1.0; length = 200)
+   plot!(x, first.(initial_condition.(x, sol.t[end], equations)),
+         label = "analytical sol.", linestyle = :dash, legend = :topright)
+end
Example block output

We can also add the initial condition to the plot.

plot!(sol.u[1], semi, label = "u0", linestyle = :dot, legend = :topleft)
Example block output

You can of course also use some callbacks provided by Trixi.jl as usual.

summary_callback = SummaryCallback()
+analysis_interval = 100
+analysis_callback = AnalysisCallback(semi; interval = analysis_interval)
+alive_callback = AliveCallback(; analysis_interval)
+callbacks = CallbackSet(summary_callback,
+                        analysis_callback,
+                        alive_callback)
+
+sol = solve(ode, RDPK3SpFSAL49();
+            ode_default_options()..., callback = callbacks)
+summary_callback()

+████████╗██████╗ ██╗██╗  ██╗██╗
+╚══██╔══╝██╔══██╗██║╚██╗██╔╝██║
+   ██║   ██████╔╝██║ ╚███╔╝ ██║
+   ██║   ██╔══██╗██║ ██╔██╗ ██║
+   ██║   ██║  ██║██║██╔╝ ██╗██║
+   ╚═╝   ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═╝
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… LinearScalarAdvectionEquation1D                                  │
+│ initial condition: ……………………………… initial_condition                                                │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… source_terms_standard                                            │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 10000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation1D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_central                                                     │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AnalysisCallback                                                                                 │
+│ ════════════════                                                                                 │
+│ interval: ……………………………………………………… 100                                                              │
+│ analyzer: ……………………………………………………… LobattoLegendreAnalyzer{Float64}(polydeg=6)                      │
+│ │ error 1: …………………………………………………… l2_error                                                         │
+│ │ error 2: …………………………………………………… linf_error                                                       │
+│ │ integral 1: …………………………………………… entropy_timederivative                                           │
+│ save analysis to file: …………………… no                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AliveCallback                                                                                    │
+│ ═════════════                                                                                    │
+│ interval: ……………………………………………………… 10                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Time integration                                                                                 │
+│ ════════════════                                                                                 │
+│ Start time: ………………………………………………… 0.0                                                              │
+│ Final time: ………………………………………………… 3.0                                                              │
+│ time integrator: …………………………………… RDPK3SpFSAL49                                                    │
+│ adaptive: ……………………………………………………… true                                                             │
+│ abstol: …………………………………………………………… 1.0e-6                                                           │
+│ reltol: …………………………………………………………… 0.001                                                            │
+│ controller: ………………………………………………… PIDController(beta=[0.38, -0.18,…iter=default_dt_factor_limiter) │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Environment information                                                                          │
+│ ═══════════════════════                                                                          │
+│ #threads: ……………………………………………………… 1                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.00000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:  4.71296224e-08 s
+                                               PID:                   Inf s
+ #DOFs per field:            64                alloc'd memory:       2744.475 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       5.57368408e-06
+ Linf error:     1.21294882e-05
+ ∑∂S/∂U ⋅ Uₜ :  -5.00000000e-01
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 9.9686e-02 │ sim. time: 3.4078e-01 (11.359%)  │ run time: 3.2721e-04 s
+#timesteps:     20 │ Δt: 8.5503e-02 │ sim. time: 1.2059e+00 (40.198%)  │ run time: 6.8801e-04 s
+#timesteps:     30 │ Δt: 6.9464e-02 │ sim. time: 1.9556e+00 (65.188%)  │ run time: 9.8622e-04 s
+#timesteps:     40 │ Δt: 8.5031e-02 │ sim. time: 2.7005e+00 (90.016%)  │ run time: 1.2823e-03 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 45                run time:       1.76342500e-03 s
+ Δt:             4.31148548e-02                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      3.00000000e+00 (100.000%)     time/DOF/rhs!:  4.81989758e-08 s
+                                               PID:            5.38377173e-08 s
+ #DOFs per field:            64                alloc'd memory:       2744.517 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       3.33421293e-05
+ Linf error:     1.31835569e-04
+ ∑∂S/∂U ⋅ Uₜ :  -1.23948350e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 3.0  Time steps: 45 (accepted), 46 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+ ────────────────────────────────────────────────────────────────────────────────
+            Trixi.jl                    Time                    Allocations
+                               ───────────────────────   ────────────────────────
+       Tot / % measured:           2.68ms /  66.9%           97.9KiB /  48.2%
+
+ Section               ncalls     time    %tot     avg     alloc    %tot      avg
+ ────────────────────────────────────────────────────────────────────────────────
+ rhs!                     417   1.24ms   68.9%  2.97μs   6.61KiB   14.0%    16.2B
+   source terms           417    547μs   30.5%  1.31μs     0.00B    0.0%    0.00B
+   ~rhs!~                 417    351μs   19.6%   843ns   6.61KiB   14.0%    16.2B
+   volume integral        417    157μs    8.8%   377ns     0.00B    0.0%    0.00B
+   interface flux         417   52.4μs    2.9%   126ns     0.00B    0.0%    0.00B
+   Jacobian               417   32.3μs    1.8%  77.5ns     0.00B    0.0%    0.00B
+   prolong2interfaces     417   29.3μs    1.6%  70.3ns     0.00B    0.0%    0.00B
+   surface integral       417   23.3μs    1.3%  55.9ns     0.00B    0.0%    0.00B
+   prolong2boundaries     417   16.8μs    0.9%  40.3ns     0.00B    0.0%    0.00B
+   reset ∂u/∂t            417   16.4μs    0.9%  39.3ns     0.00B    0.0%    0.00B
+   boundary flux          417   12.0μs    0.7%  28.8ns     0.00B    0.0%    0.00B
+ analyze solution           2    558μs   31.1%   279μs   40.6KiB   86.0%  20.3KiB
+ ────────────────────────────────────────────────────────────────────────────────

Using a custom ODE right-hand side function

Next, we will solve the same problem but use our own ODE RHS function. To demonstrate this, we will artificially create a global variable containing the current time of the simulation.

const GLOBAL_TIME = Ref(0.0)
+
+function source_terms_custom(u, x, t, equations)
+    t = GLOBAL_TIME[]
+    return -initial_condition(x, t, equations)
+end
source_terms_custom (generic function with 1 method)

Next, we create our own RHS function to update the global time of the simulation before calling the RHS function from Trixi.jl.

function rhs_source_custom!(du_ode, u_ode, semi, t)
+    GLOBAL_TIME[] = t
+    Trixi.rhs!(du_ode, u_ode, semi, t)
+end
rhs_source_custom! (generic function with 1 method)

Next, we create an ODEProblem manually copying over the data from the one we got from semidiscretize earlier.

ode_source_custom = ODEProblem(rhs_source_custom!,
+                               ode.u0,
+                               ode.tspan,
+                               ode.p #= semi =#)
+sol_source_custom = solve(ode_source_custom, RDPK3SpFSAL49();
+                          ode_default_options()...)
+
+plot(sol_source_custom; label = "numerical sol.")
+let
+    x = range(-1.0, 1.0; length = 200)
+    plot!(x, first.(initial_condition.(x, sol_source_custom.t[end], equations)),
+          label = "analytical sol.", linestyle = :dash, legend = :topleft)
+end
+plot!(sol_source_custom.u[1], semi, label = "u0", linestyle = :dot, legend = :topleft)
Example block output

This also works with callbacks as usual.

summary_callback = SummaryCallback()
+analysis_interval = 100
+analysis_callback = AnalysisCallback(semi; interval = analysis_interval)
+alive_callback = AliveCallback(; analysis_interval)
+callbacks = CallbackSet(summary_callback,
+                        analysis_callback,
+                        alive_callback)
+
+sol = solve(ode_source_custom, RDPK3SpFSAL49();
+            ode_default_options()..., callback = callbacks)
+summary_callback()

+████████╗██████╗ ██╗██╗  ██╗██╗
+╚══██╔══╝██╔══██╗██║╚██╗██╔╝██║
+   ██║   ██████╔╝██║ ╚███╔╝ ██║
+   ██║   ██╔══██╗██║ ██╔██╗ ██║
+   ██║   ██║  ██║██║██╔╝ ██╗██║
+   ╚═╝   ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═╝
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… LinearScalarAdvectionEquation1D                                  │
+│ initial condition: ……………………………… initial_condition                                                │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… source_terms_standard                                            │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 10000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation1D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_central                                                     │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AnalysisCallback                                                                                 │
+│ ════════════════                                                                                 │
+│ interval: ……………………………………………………… 100                                                              │
+│ analyzer: ……………………………………………………… LobattoLegendreAnalyzer{Float64}(polydeg=6)                      │
+│ │ error 1: …………………………………………………… l2_error                                                         │
+│ │ error 2: …………………………………………………… linf_error                                                       │
+│ │ integral 1: …………………………………………… entropy_timederivative                                           │
+│ save analysis to file: …………………… no                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AliveCallback                                                                                    │
+│ ═════════════                                                                                    │
+│ interval: ……………………………………………………… 10                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Time integration                                                                                 │
+│ ════════════════                                                                                 │
+│ Start time: ………………………………………………… 0.0                                                              │
+│ Final time: ………………………………………………… 3.0                                                              │
+│ time integrator: …………………………………… RDPK3SpFSAL49                                                    │
+│ adaptive: ……………………………………………………… true                                                             │
+│ abstol: …………………………………………………………… 1.0e-6                                                           │
+│ reltol: …………………………………………………………… 0.001                                                            │
+│ controller: ………………………………………………… PIDController(beta=[0.38, -0.18,…iter=default_dt_factor_limiter) │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Environment information                                                                          │
+│ ═══════════════════════                                                                          │
+│ #threads: ……………………………………………………… 1                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       7.00000000e-07 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:  4.73499870e-08 s
+                                               PID:                   Inf s
+ #DOFs per field:            64                alloc'd memory:       2736.210 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       5.57368408e-06
+ Linf error:     1.21294882e-05
+ ∑∂S/∂U ⋅ Uₜ :  -5.00000000e-01
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 9.9686e-02 │ sim. time: 3.4078e-01 (11.359%)  │ run time: 3.3141e-04 s
+#timesteps:     20 │ Δt: 8.5503e-02 │ sim. time: 1.2059e+00 (40.198%)  │ run time: 6.9701e-04 s
+#timesteps:     30 │ Δt: 6.9464e-02 │ sim. time: 1.9556e+00 (65.188%)  │ run time: 9.9682e-04 s
+#timesteps:     40 │ Δt: 8.5031e-02 │ sim. time: 2.7005e+00 (90.016%)  │ run time: 1.3108e-03 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 45                run time:       1.78182600e-03 s
+ Δt:             4.31148548e-02                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      3.00000000e+00 (100.000%)     time/DOF/rhs!:  4.86699312e-08 s
+                                               PID:            5.51829287e-08 s
+ #DOFs per field:            64                alloc'd memory:       2736.251 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       3.33421293e-05
+ Linf error:     1.31835569e-04
+ ∑∂S/∂U ⋅ Uₜ :  -1.23948350e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 3.0  Time steps: 45 (accepted), 46 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+ ────────────────────────────────────────────────────────────────────────────────
+            Trixi.jl                    Time                    Allocations
+                               ───────────────────────   ────────────────────────
+       Tot / % measured:           2.68ms /  67.0%           98.1KiB /  48.1%
+
+ Section               ncalls     time    %tot     avg     alloc    %tot      avg
+ ────────────────────────────────────────────────────────────────────────────────
+ rhs!                     417   1.25ms   69.7%  3.00μs   6.61KiB   14.0%    16.2B
+   source terms           417    538μs   30.0%  1.29μs     0.00B    0.0%    0.00B
+   ~rhs!~                 417    353μs   19.7%   846ns   6.61KiB   14.0%    16.2B
+   volume integral        417    154μs    8.6%   370ns     0.00B    0.0%    0.00B
+   interface flux         417   51.9μs    2.9%   124ns     0.00B    0.0%    0.00B
+   prolong2interfaces     417   46.5μs    2.6%   112ns     0.00B    0.0%    0.00B
+   surface integral       417   27.5μs    1.5%  65.9ns     0.00B    0.0%    0.00B
+   boundary flux          417   24.5μs    1.4%  58.8ns     0.00B    0.0%    0.00B
+   prolong2boundaries     417   19.1μs    1.1%  45.8ns     0.00B    0.0%    0.00B
+   reset ∂u/∂t            417   18.4μs    1.0%  44.1ns     0.00B    0.0%    0.00B
+   Jacobian               417   17.8μs    1.0%  42.7ns     0.00B    0.0%    0.00B
+ analyze solution           2    545μs   30.3%   272μs   40.6KiB   86.0%  20.3KiB
+ ────────────────────────────────────────────────────────────────────────────────

Setting up a custom semidiscretization

Using a global constant is of course not really nice from a software engineering point of view. Thus, it can often be useful to collect additional data in the parameters of the ODEProblem. Thus, it is time to create our own semidiscretization. Here, we create a small wrapper of a standard semidiscretization of Trixi.jl and the current global time of the simulation.

struct CustomSemidiscretization{Semi, T} <: Trixi.AbstractSemidiscretization
+    semi::Semi
+    t::T
+end
+
+semi_custom = CustomSemidiscretization(semi, Ref(0.0))
Main.CustomSemidiscretization{SemidiscretizationHyperbolic{TreeMesh{1, Trixi.SerialTree{1}}, LinearScalarAdvectionEquation1D{Float64}, typeof(Main.initial_condition), Trixi.BoundaryConditionPeriodic, typeof(Main.source_terms_standard), DGSEM{LobattoLegendreBasis{Float64, 4, SVector{4, Float64}, Matrix{Float64}, Matrix{Float64}, Matrix{Float64}}, Trixi.LobattoLegendreMortarL2{Float64, 4, Matrix{Float64}, Matrix{Float64}}, SurfaceIntegralWeakForm{typeof(flux_central)}, VolumeIntegralWeakForm}, NamedTuple{(:elements, :interfaces, :boundaries), Tuple{Trixi.ElementContainer1D{Float64, Float64}, Trixi.InterfaceContainer1D{Float64}, Trixi.BoundaryContainer1D{Float64, Float64}}}}, Base.RefValue{Float64}}(SemidiscretizationHyperbolic(TreeMesh{1, Trixi.SerialTree{1}} with length 31, LinearScalarAdvectionEquation1D with one variable, initial_condition, boundary_condition_periodic, source_terms_standard, DG{Float64}(LobattoLegendreBasis{Float64}(polydeg=3), LobattoLegendreMortarL2{Float64}(polydeg=3), SurfaceIntegralWeakForm{typeof(flux_central)}(Trixi.flux_central), VolumeIntegralWeakForm()), cache(elements interfaces boundaries)), Base.RefValue{Float64}(0.0))

To get pretty printing in the REPL, you can consider specializing

  • Base.show(io::IO, parameters::CustomSemidiscretization)
  • Base.show(io::IO, ::MIME"text/plain", parameters::CustomSemidiscretization)

for your custom semidiscretiation.

Next, we create our own source terms that use the global time stored in the custom semidiscretiation.

source_terms_custom_semi = let semi_custom = semi_custom
+    function source_terms_custom_semi(u, x, t, equations)
+        t = semi_custom.t[]
+        return -initial_condition(x, t, equations)
+    end
+end
source_terms_custom_semi (generic function with 1 method)

We also create a custom ODE RHS to update the current global time stored in the custom semidiscretization. We unpack the standard semidiscretization created by Trixi.jl and pass it to Trixi.rhs!.

function rhs_semi_custom!(du_ode, u_ode, semi_custom, t)
+    semi_custom.t[] = t
+    Trixi.rhs!(du_ode, u_ode, semi_custom.semi, t)
+end
rhs_semi_custom! (generic function with 1 method)

Finally, we set up an ODEProblem and solve it numerically.

ode_semi_custom = ODEProblem(rhs_semi_custom!,
+                             ode.u0,
+                             ode.tspan,
+                             semi_custom)
+sol_semi_custom = solve(ode_semi_custom, RDPK3SpFSAL49();
+                        ode_default_options()...)
retcode: Success
+Interpolation: 1st order linear
+t: 2-element Vector{Float64}:
+ 0.0
+ 3.0
+u: 2-element Vector{Vector{Float64}}:
+ [-3.487868498008632e-16, -0.1083263689449018, -0.2803509724255764, -0.38268343236508945, -0.3826834323650901, -0.48051200262449845, -0.6263474196321541, -0.7071067811865472, -0.7071067811865478, -0.7795440397566659  …  0.7795440397566659, 0.7071067811865478, 0.7071067811865472, 0.6263474196321541, 0.48051200262449845, 0.3826834323650901, 0.38268343236508945, 0.2803509724255764, 0.1083263689449018, 3.487868498008632e-16]
+ [0.00039320882668261985, 0.005593037571101643, 0.014211415234637079, 0.019097988726944525, 0.01932495108774102, 0.02399181705537257, 0.03128895202056526, 0.0351157802915657, 0.03531125107864154, 0.03873867502331451  …  -0.03840107811685022, -0.034871915240701996, -0.03475449432652092, -0.030829250470936792, -0.02350420904170509, -0.018777711432434757, -0.01859676365228886, -0.013658085806813441, -0.005028839697000977, 0.00017159954909493918]

If we want to make use of additional functionality provided by Trixi.jl, e.g., for plotting, we need to implement a few additional specializations. In this case, we forward everything to the standard semidiscretization provided by Trixi.jl wrapped in our custom semidiscretization.

Base.ndims(semi::CustomSemidiscretization) = ndims(semi.semi)
+function Trixi.mesh_equations_solver_cache(semi::CustomSemidiscretization)
+    Trixi.mesh_equations_solver_cache(semi.semi)
+end

Now, we can plot the numerical solution as usual.

plot(sol_semi_custom; label = "numerical sol.")
+let
+    x = range(-1.0, 1.0; length = 200)
+    plot!(x, first.(initial_condition.(x, sol_semi_custom.t[end], equations)),
+          label = "analytical sol.", linestyle = :dash, legend = :topleft)
+end
+plot!(sol_semi_custom.u[1], semi, label = "u0", linestyle = :dot, legend = :topleft)
Example block output

This also works with many callbacks as usual. However, the AnalysisCallback requires some special handling since it makes use of a performance counter contained in the standard semidiscretizations of Trixi.jl to report some performance metrics. Here, we forward all accesses to the performance counter to the wrapped semidiscretization.

function Base.getproperty(semi::CustomSemidiscretization, s::Symbol)
+    if s === :performance_counter
+        wrapped_semi = getfield(semi, :semi)
+        wrapped_semi.performance_counter
+    else
+        getfield(semi, s)
+    end
+end

Moreover, the AnalysisCallback also performs some error calculations. We also need to forward them to the wrapped semidiscretization.

function Trixi.calc_error_norms(func, u, t, analyzer,
+                                semi::CustomSemidiscretization,
+                                cache_analysis)
+    Trixi.calc_error_norms(func, u, t, analyzer,
+                           semi.semi,
+                           cache_analysis)
+end

Now, we can work with the callbacks used before as usual.

summary_callback = SummaryCallback()
+analysis_interval = 100
+analysis_callback = AnalysisCallback(semi_custom;
+                                     interval = analysis_interval)
+alive_callback = AliveCallback(; analysis_interval)
+callbacks = CallbackSet(summary_callback,
+                        analysis_callback,
+                        alive_callback)
+
+sol = solve(ode_semi_custom, RDPK3SpFSAL49();
+            ode_default_options()..., callback = callbacks)
+summary_callback()

+████████╗██████╗ ██╗██╗  ██╗██╗
+╚══██╔══╝██╔══██╗██║╚██╗██╔╝██║
+   ██║   ██████╔╝██║ ╚███╔╝ ██║
+   ██║   ██╔══██╗██║ ██╔██╗ ██║
+   ██║   ██║  ██║██║██╔╝ ██╗██║
+   ╚═╝   ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═╝
+
+Main.CustomSemidiscretization{SemidiscretizationHyperbolic{TreeMesh{1, Trixi.SerialTree{1}}, LinearScalarAdvectionEquation1D{Float64}, typeof(Main.initial_condition), Trixi.BoundaryConditionPeriodic, typeof(Main.source_terms_standard), DG{LobattoLegendreBasis{Float64, 4, StaticArraysCore.SArray{Tuple{4}, Float64, 1, 4}, Array{Float64, 2}, Array{Float64, 2}, Array{Float64, 2}}, Trixi.LobattoLegendreMortarL2{Float64, 4, Array{Float64, 2}, Array{Float64, 2}}, SurfaceIntegralWeakForm{typeof(flux_central)}, VolumeIntegralWeakForm}, NamedTuple{(:elements, :interfaces, :boundaries), Tuple{Trixi.ElementContainer1D{Float64, Float64}, Trixi.InterfaceContainer1D{Float64}, Trixi.BoundaryContainer1D{Float64, Float64}}}}, Base.RefValue{Float64}}(SemidiscretizationHyperbolic(TreeMesh{1, Trixi.SerialTree{1}} with length 31, LinearScalarAdvectionEquation1D with one variable, initial_condition, boundary_condition_periodic, source_terms_standard, DG{Float64}(LobattoLegendreBasis{Float64}(polydeg=3), LobattoLegendreMortarL2{Float64}(polydeg=3), SurfaceIntegralWeakForm{typeof(flux_central)}(Trixi.flux_central), VolumeIntegralWeakForm()), cache(elements interfaces boundaries)), Base.RefValue{Float64}(3.0))
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 10000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation1D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… flux_central                                                     │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AnalysisCallback                                                                                 │
+│ ════════════════                                                                                 │
+│ interval: ……………………………………………………… 100                                                              │
+│ analyzer: ……………………………………………………… LobattoLegendreAnalyzer{Float64}(polydeg=6)                      │
+│ │ error 1: …………………………………………………… l2_error                                                         │
+│ │ error 2: …………………………………………………… linf_error                                                       │
+│ │ integral 1: …………………………………………… entropy_timederivative                                           │
+│ save analysis to file: …………………… no                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ AliveCallback                                                                                    │
+│ ═════════════                                                                                    │
+│ interval: ……………………………………………………… 10                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Time integration                                                                                 │
+│ ════════════════                                                                                 │
+│ Start time: ………………………………………………… 0.0                                                              │
+│ Final time: ………………………………………………… 3.0                                                              │
+│ time integrator: …………………………………… RDPK3SpFSAL49                                                    │
+│ adaptive: ……………………………………………………… true                                                             │
+│ abstol: …………………………………………………………… 1.0e-6                                                           │
+│ reltol: …………………………………………………………… 0.001                                                            │
+│ controller: ………………………………………………… PIDController(beta=[0.38, -0.18,…iter=default_dt_factor_limiter) │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Environment information                                                                          │
+│ ═══════════════════════                                                                          │
+│ #threads: ……………………………………………………… 1                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.00000000e-06 s
+ Δt:             0.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:  4.73239020e-08 s
+                                               PID:                   Inf s
+ #DOFs per field:            64                alloc'd memory:       2713.274 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       5.57368408e-06
+ Linf error:     1.21294882e-05
+ ∑∂S/∂U ⋅ Uₜ :  -5.00000000e-01
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+#timesteps:     10 │ Δt: 9.9686e-02 │ sim. time: 3.4078e-01 (11.359%)  │ run time: 3.4711e-04 s
+#timesteps:     20 │ Δt: 8.5503e-02 │ sim. time: 1.2059e+00 (40.198%)  │ run time: 7.3011e-04 s
+#timesteps:     30 │ Δt: 6.9464e-02 │ sim. time: 1.9556e+00 (65.188%)  │ run time: 1.0452e-03 s
+#timesteps:     40 │ Δt: 8.5031e-02 │ sim. time: 2.7005e+00 (90.016%)  │ run time: 1.3603e-03 s
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'LinearScalarAdvectionEquation1D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                 45                run time:       9.04393200e-03 s
+ Δt:             4.31148548e-02                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      3.00000000e+00 (100.000%)     time/DOF/rhs!:  5.10809285e-08 s
+                                               PID:            5.71688399e-08 s
+ #DOFs per field:            64                alloc'd memory:       2713.603 MiB
+ #elements:                  16
+
+ Variable:       scalar
+ L2 error:       3.33421293e-05
+ Linf error:     1.31835569e-04
+ ∑∂S/∂U ⋅ Uₜ :  -1.23948350e-03
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+Trixi.jl simulation finished.  Final time: 3.0  Time steps: 45 (accepted), 46 (total)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+ ────────────────────────────────────────────────────────────────────────────────
+            Trixi.jl                    Time                    Allocations
+                               ───────────────────────   ────────────────────────
+       Tot / % measured:           9.95ms /  91.1%            391KiB /  87.3%
+
+ Section               ncalls     time    %tot     avg     alloc    %tot      avg
+ ────────────────────────────────────────────────────────────────────────────────
+ analyze solution           2   7.75ms   85.5%  3.88ms    335KiB   98.1%   167KiB
+ rhs!                     417   1.31ms   14.5%  3.14μs   6.61KiB    1.9%    16.2B
+   source terms           417    636μs    7.0%  1.52μs     0.00B    0.0%    0.00B
+   ~rhs!~                 417    349μs    3.8%   836ns   6.61KiB    1.9%    16.2B
+   volume integral        417    154μs    1.7%   371ns     0.00B    0.0%    0.00B
+   interface flux         417   54.7μs    0.6%   131ns     0.00B    0.0%    0.00B
+   prolong2interfaces     417   31.7μs    0.3%  76.0ns     0.00B    0.0%    0.00B
+   surface integral       417   24.5μs    0.3%  58.8ns     0.00B    0.0%    0.00B
+   Jacobian               417   19.3μs    0.2%  46.3ns     0.00B    0.0%    0.00B
+   reset ∂u/∂t            417   17.1μs    0.2%  41.0ns     0.00B    0.0%    0.00B
+   prolong2boundaries     417   14.2μs    0.2%  34.1ns     0.00B    0.0%    0.00B
+   boundary flux          417   10.8μs    0.1%  25.9ns     0.00B    0.0%    0.00B
+ ────────────────────────────────────────────────────────────────────────────────

For even more advanced usage of custom semidiscretizations, you may look at the source code of the ones contained in Trixi.jl, e.g.,

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/differentiable_programming/6726dae8.svg b/previews/PR1697/tutorials/differentiable_programming/6726dae8.svg new file mode 100644 index 00000000000..c0094c5c3f7 --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/6726dae8.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/69a549ba.svg b/previews/PR1697/tutorials/differentiable_programming/69a549ba.svg new file mode 100644 index 00000000000..a64fa15f94b --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/69a549ba.svg @@ -0,0 +1,809 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/71e1538b.svg b/previews/PR1697/tutorials/differentiable_programming/71e1538b.svg new file mode 100644 index 00000000000..be2c92fe76f --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/71e1538b.svg @@ -0,0 +1,2100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/73fec259.svg b/previews/PR1697/tutorials/differentiable_programming/73fec259.svg new file mode 100644 index 00000000000..962be03cbd9 --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/73fec259.svg @@ -0,0 +1,815 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/896ef882.svg b/previews/PR1697/tutorials/differentiable_programming/896ef882.svg new file mode 100644 index 00000000000..2718de68867 --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/896ef882.svg @@ -0,0 +1,1077 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/c6ac5c01.svg b/previews/PR1697/tutorials/differentiable_programming/c6ac5c01.svg new file mode 100644 index 00000000000..4a4dee7731d --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/c6ac5c01.svg @@ -0,0 +1,307 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/cc8281b6.svg b/previews/PR1697/tutorials/differentiable_programming/cc8281b6.svg new file mode 100644 index 00000000000..ecd81f1565d --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/cc8281b6.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/dac2545d.svg b/previews/PR1697/tutorials/differentiable_programming/dac2545d.svg new file mode 100644 index 00000000000..a5e18462aa9 --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/dac2545d.svg @@ -0,0 +1,1582 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/differentiable_programming/index.html b/previews/PR1697/tutorials/differentiable_programming/index.html new file mode 100644 index 00000000000..6ba098b13e2 --- /dev/null +++ b/previews/PR1697/tutorials/differentiable_programming/index.html @@ -0,0 +1,209 @@ + +16 Differentiable programming · Trixi.jl

16: Differentiable programming

Julia and its ecosystem provide some tools for differentiable programming. Trixi.jl is designed to be flexible, extendable, and composable with Julia's growing ecosystem for scientific computing and machine learning. Thus, the ultimate goal is to have fast implementations that allow automatic differentiation (AD) without too much hassle for users. If some parts do not meet these requirements, please feel free to open an issue or propose a fix in a PR.

In the following, we will walk through some examples demonstrating how to differentiate through Trixi.jl.

Forward mode automatic differentiation

Trixi.jl integrates well with ForwardDiff.jl for forward mode AD.

Computing the Jacobian

The high-level interface to compute the Jacobian this way is jacobian_ad_forward. First, we load the required packages and compute the Jacobian of a semidiscretization of the compressible Euler equations, a system of nonlinear conservation laws.

using Trixi, LinearAlgebra, Plots
+
+equations = CompressibleEulerEquations2D(1.4)
+
+solver = DGSEM(3, flux_central)
+mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)
+
+J = jacobian_ad_forward(semi);
+size(J)
(1024, 1024)

Next, we compute the eigenvalues of the Jacobian.

λ = eigvals(J)
+scatter(real.(λ), imag.(λ), label="central flux")
Example block output

As you can see here, the maximal real part is close to zero.

relative_maximum = maximum(real, λ) / maximum(abs, λ)
5.363931261250053e-10

Interestingly, if we add dissipation by switching to the flux_lax_friedrichs at the interfaces, the maximal real part of the eigenvalues increases.

solver = DGSEM(3, flux_lax_friedrichs)
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)
+
+J = jacobian_ad_forward(semi)
+λ = eigvals(J)
+
+scatter!(real.(λ), imag.(λ), label="Lax-Friedrichs flux")
Example block output

Although the maximal real part is still somewhat small, it's larger than for the purely central discretization.

relative_maximum = maximum(real, λ) / maximum(abs, λ)
2.078152025726539e-5

However, we should be careful when using this analysis, since the eigenvectors are not necessarily well-conditioned.

λ, V = eigen(J)
+condition_number = cond(V)
1.6378606512008032e6

In one space dimension, the situation is a bit different.

equations = CompressibleEulerEquations1D(1.4)
+
+solver = DGSEM(3, flux_central)
+mesh = TreeMesh((-1.0,), (1.0,), initial_refinement_level=6, n_cells_max=10^5)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)
+
+J = jacobian_ad_forward(semi)
+
+λ = eigvals(J)
+
+scatter(real.(λ), imag.(λ), label="central flux")
Example block output

Here, the maximal real part is basically zero to machine accuracy.

relative_maximum = maximum(real, λ) / maximum(abs, λ)
4.590384437371228e-16

Moreover, the eigenvectors are not as ill-conditioned as in 2D.

λ, V = eigen(J)
+condition_number = cond(V)
253.7112316032919

If we add dissipation, the maximal real part is still approximately zero.

solver = DGSEM(3, flux_lax_friedrichs)
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)
+
+J = jacobian_ad_forward(semi)
+λ = eigvals(J)
+
+scatter!(real.(λ), imag.(λ), label="Lax-Friedrichs flux")
Example block output

As you can see from the plot generated above, the maximal real part is still basically zero to machine precision.

relative_maximum = maximum(real, λ) / maximum(abs, λ)
5.183646920030433e-17

Let's check the condition number of the eigenvectors.

λ, V = eigen(J)
+
+condition_number = cond(V)
90353.75290021878

Note that the condition number of the eigenvector matrix increases but is still smaller than for the example in 2D.

Computing other derivatives

It is also possible to compute derivatives of other dependencies using AD in Trixi.jl. For example, you can compute the gradient of an entropy-dissipative semidiscretization with respect to the ideal gas constant of the compressible Euler equations as described in the following. This example is also available as the elixir examples/special_elixirs/elixir_euler_ad.jl

First, we create a semidiscretization of the compressible Euler equations.

using Trixi, LinearAlgebra, ForwardDiff
+
+equations = CompressibleEulerEquations2D(1.4)
+
+"""
+    initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)
+
+The classical isentropic vortex test case of
+- Chi-Wang Shu (1997)
+  Essentially Non-Oscillatory and Weighted Essentially Non-Oscillatory
+  Schemes for Hyperbolic Conservation Laws
+  [NASA/CR-97-206253](https://ntrs.nasa.gov/citations/19980007543)
+"""
+function initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)
+  inicenter = SVector(0.0, 0.0) # initial center of the vortex
+  iniamplitude = 5.0            # size and strength of the vortex
+
+  rho = 1.0  # base flow
+  v1 = 1.0
+  v2 = 1.0
+  vel = SVector(v1, v2)
+  p = 25.0
+
+  rt = p / rho                      # ideal gas equation
+  t_loc = 0.0
+
+  cent = inicenter + vel*t_loc      # shift advection of center to handle periodic BC, but only for v1 = v2 = 1.0
+  cent = x - cent                   # distance to center point
+  cent = SVector(-cent[2], cent[1])
+
+  r2 = cent[1]^2 + cent[2]^2
+  du = iniamplitude / (2*π) * exp(0.5 * (1 - r2)) # vel. perturbation
+  dtemp = -(equations.gamma - 1) / (2 * equations.gamma * rt) * du^2 # isentropic
+
+  rho = rho * (1 + dtemp)^(1 / (equations.gamma - 1))
+  vel = vel + du * cent
+  v1, v2 = vel
+  p = p * (1 + dtemp)^(equations.gamma / (equations.gamma - 1))
+
+  prim = SVector(rho, v1, v2, p)
+  return prim2cons(prim, equations)
+end
+
+mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)
+
+solver = DGSEM(3, flux_lax_friedrichs, VolumeIntegralFluxDifferencing(flux_ranocha))
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_isentropic_vortex, solver)
+
+u0_ode = Trixi.compute_coefficients(0.0, semi)
+size(u0_ode)
(1024,)

Next, we compute the Jacobian using ForwardDiff.jacobian.

J = ForwardDiff.jacobian((du_ode, γ) -> begin
+    equations_inner = CompressibleEulerEquations2D(first(γ))
+    semi_inner = Trixi.remake(semi, equations=equations_inner, uEltype=eltype(γ))
+    Trixi.rhs!(du_ode, u0_ode, semi_inner, 0.0)
+end, similar(u0_ode), [1.4]); # γ needs to be an `AbstractArray`
+
+round.(extrema(J), sigdigits=2)
(-220.0, 220.0)

Note that we create a semidiscretization semi at first to determine the state u0_ode around which we want to perform the linearization. Next, we wrap the RHS evaluation inside a closure and pass that to ForwardDiff.jacobian. There, we need to make sure that the internal caches are able to store dual numbers from ForwardDiff.jl by setting uEltype appropriately. A similar approach is used by jacobian_ad_forward.

Note that the ideal gas constant does not influence the semidiscrete rate of change of the density, as demonstrated by

norm(J[1:4:end])
0.0

Here, we used some knowledge about the internal memory layout of Trixi.jl, an array of structs with the conserved variables as fastest-varying index in memory.

Differentiating through a complete simulation

It is also possible to differentiate through a complete simulation. As an example, let's differentiate the total energy of a simulation using the linear scalar advection equation with respect to the wave number (frequency) of the initial data.

using Trixi, OrdinaryDiffEq, ForwardDiff, Plots
+
+function energy_at_final_time(k) # k is the wave number of the initial condition
+    equations = LinearScalarAdvectionEquation2D(1.0, -0.3)
+    mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)
+    solver = DGSEM(3, flux_lax_friedrichs)
+    initial_condition = (x, t, equation) -> begin
+            x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)
+            return SVector(sinpi(k * sum(x_trans)))
+    end
+    semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                               uEltype=typeof(k))
+    ode = semidiscretize(semi, (0.0, 1.0))
+    sol = solve(ode, BS3(), save_everystep=false)
+    Trixi.integrate(energy_total, sol.u[end], semi)
+end
+
+k_values = range(0.9, 1.1, length=101)
+
+plot(k_values, energy_at_final_time.(k_values), label="Energy")
Example block output

You see a plot of a curve that resembles a parabola with local maximum around k = 1.0. Why's that? Well, the domain is fixed but the wave number changes. Thus, if the wave number is not chosen as an integer, the initial condition will not be a smooth periodic function in the given domain. Hence, the dissipative surface flux (flux_lax_friedrichs in this example) will introduce more dissipation. In particular, it will introduce more dissipation for "less smooth" initial data, corresponding to wave numbers k further away from integers.

We can compute the discrete derivative of the energy at the final time with respect to the wave number k as follows.

round(ForwardDiff.derivative(energy_at_final_time, 1.0), sigdigits=2)
1.4e-5

This is rather small and we can treat it as zero in comparison to the value of this derivative at other wave numbers k.

dk_values = ForwardDiff.derivative.((energy_at_final_time,), k_values);
+
+plot(k_values, dk_values, label="Derivative")
Example block output

If you remember basic calculus, a sufficient condition for a local maximum is that the first derivative vanishes and the second derivative is negative. We can also check this discretely.

second_derivative = round(ForwardDiff.derivative(
+        k -> Trixi.ForwardDiff.derivative(energy_at_final_time, k), 1.0),
+      sigdigits=2)
-0.9

Having seen this application, let's break down what happens step by step.

function energy_at_final_time(k) # k is the wave number of the initial condition
+    equations = LinearScalarAdvectionEquation2D(1.0, -0.3)
+    mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)
+    solver = DGSEM(3, flux_lax_friedrichs)
+    initial_condition = (x, t, equation) -> begin
+        x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)
+        return SVector(sinpi(k * sum(x_trans)))
+    end
+    semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                               uEltype=typeof(k))
+    ode = semidiscretize(semi, (0.0, 1.0))
+    sol = solve(ode, BS3(), save_everystep=false)
+    Trixi.integrate(energy_total, sol.u[end], semi)
+end
+
+k = 1.0
+round(ForwardDiff.derivative(energy_at_final_time, k), sigdigits=2)
1.4e-5

When calling ForwardDiff.derivative(energy_at_final_time, k) with k=1.0, ForwardDiff.jl will basically use the chain rule and known derivatives of existing basic functions to calculate the derivative of the energy at the final time with respect to the wave number k at k0 = 1.0. To do this, ForwardDiff.jl uses dual numbers, which basically store the result and its derivative w.r.t. a specified parameter at the same time. Thus, we need to make sure that we can treat these ForwardDiff.Dual numbers everywhere during the computation. Fortunately, generic Julia code usually supports these operations. The most basic problem for a developer is to ensure that all types are generic enough, in particular the ones of internal caches.

The first step in this example creates some basic ingredients of our simulation.

equations = LinearScalarAdvectionEquation2D(1.0, -0.3)
+mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)
+solver = DGSEM(3, flux_lax_friedrichs);

These do not have internal caches storing intermediate values of the numerical solution, so we do not need to adapt them. In fact, we could also define them outside of energy_at_final_time (but would need to take care of globals or wrap everything in another function).

Next, we define the initial condition

initial_condition = (x, t, equation) -> begin
+    x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)
+    return SVector(sinpi(k * sum(x_trans)))
+end;

as a closure capturing the wave number k passed to energy_at_final_time. If you call energy_at_final_time(1.0), k will be a Float64. Thus, the return values of initial_condition will be SVectors of Float64s. When calculating the ForwardDiff.derivative, k will be a ForwardDiff.Dual number. Hence, the initial_condition will return SVectors of ForwardDiff.Dual numbers.

The semidiscretization semi uses some internal caches to avoid repeated allocations and speed up the computations, e.g. for numerical fluxes at interfaces. Thus, we need to tell Trixi.jl to allow ForwardDiff.Dual numbers in these caches. That's what the keyword argument uEltype=typeof(k) in

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                    uEltype=typeof(k));

does. This is basically the only part where you need to modify your standard Trixi.jl code to enable automatic differentiation. From there on, the remaining steps

ode = semidiscretize(semi, (0.0, 1.0))
+sol = solve(ode, BS3(), save_everystep=false)
+round(Trixi.integrate(energy_total, sol.u[end], semi), sigdigits=5)
0.24986

do not need any modifications since they are sufficiently generic (and enough effort has been spend to allow general types inside these calls).

Propagating errors using Measurements.jl

Error bars by Randall Munroe "Error bars" by Randall Munroe, linked from https://xkcd.com/2110

Similar to AD, Trixi.jl also allows propagating uncertainties using linear error propagation theory via Measurements.jl. As an example, let's create a system representing the linear advection equation in 1D with an uncertain velocity. Then, we create a semidiscretization using a sine wave as initial condition, solve the ODE, and plot the resulting uncertainties in the primitive variables.

using Trixi, OrdinaryDiffEq, Measurements, Plots, LaTeXStrings
+
+equations = LinearScalarAdvectionEquation1D(1.0 ± 0.1)
+
+mesh = TreeMesh((-1.0,), (1.0,), n_cells_max=10^5, initial_refinement_level=5)
+
+solver = DGSEM(3)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test,
+                                    solver, uEltype=Measurement{Float64})
+
+ode = semidiscretize(semi, (0.0, 1.5))
+
+sol = solve(ode, BS3(), save_everystep=false);
+
+plot(sol)
Example block output

You should see a plot where small error bars are shown around the extrema and larger error bars are shown in the remaining parts. This result is in accordance with expectations. Indeed, the uncertain propagation speed will affect the extrema less since the local variation of the solution is relatively small there. In contrast, the local variation of the solution is large around the turning points of the sine wave, so the uncertainties will be relatively large there.

All this is possible due to allowing generic types and having good abstractions in Julia that allow packages to work together seamlessly.

Finite difference approximations

Trixi.jl provides the convenience function jacobian_fd to approximate the Jacobian via central finite differences.

using Trixi, LinearAlgebra
+
+equations = CompressibleEulerEquations2D(1.4)
+
+solver = DGSEM(3, flux_central)
+
+mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)
+
+J_fd = jacobian_fd(semi)
+
+J_ad = jacobian_ad_forward(semi)
+
+relative_difference = norm(J_fd - J_ad) / size(J_fd, 1)
5.750018477545811e-7

This discrepancy is of the expected order of magnitude for central finite difference approximations.

Linear systems

When a linear PDE is discretized using a linear scheme such as a standard DG method, the resulting semidiscretization yields an affine ODE of the form

\[\partial_t u(t) = A u(t) + b,\]

where A is a linear operator ("matrix") and b is a vector. Trixi.jl allows you to obtain this linear structure in a matrix-free way by using linear_structure. The resulting operator A can be used in multiplication, e.g. mul! from LinearAlgebra, converted to a sparse matrix using sparse from SparseArrays, or converted to a dense matrix using Matrix for detailed eigenvalue analyses. For example,

using Trixi, LinearAlgebra, Plots
+
+equations = LinearScalarAdvectionEquation2D(1.0, -0.3)
+
+solver = DGSEM(3, flux_lax_friedrichs)
+
+mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test, solver)
+
+A, b = linear_structure(semi)
+
+size(A), size(b)
((256, 256), (256,))

Next, we compute the eigenvalues of the linear operator.

λ = eigvals(Matrix(A))
+
+scatter(real.(λ), imag.(λ))
Example block output

As you can see here, the maximal real part is close to machine precision.

λ = eigvals(Matrix(A))
+relative_maximum = maximum(real, λ) / maximum(abs, λ)
3.44417312410318e-17

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots", "ForwardDiff"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [f6369f11] ForwardDiff v0.10.36
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/hohqmesh_tutorial/index.html b/previews/PR1697/tutorials/hohqmesh_tutorial/index.html new file mode 100644 index 00000000000..a11b913b8cd --- /dev/null +++ b/previews/PR1697/tutorials/hohqmesh_tutorial/index.html @@ -0,0 +1,305 @@ + +14 Unstructured meshes with HOHQMesh.jl · Trixi.jl

14: Unstructured meshes with HOHQMesh.jl

Trixi.jl supports numerical approximations on unstructured quadrilateral meshes with the UnstructuredMesh2D mesh type.

The purpose of this tutorial is to demonstrate how to use the UnstructuredMesh2D functionality of Trixi.jl. This begins by running and visualizing an available unstructured quadrilateral mesh example. Then, the tutorial will demonstrate how to conceptualize a problem with curved boundaries, generate a curvilinear mesh using the available software in the Trixi.jl ecosystem, and then run a simulation using Trixi.jl on said mesh.

Unstructured quadrilateral meshes can be made with the High-Order Hex-Quad Mesh (HOHQMesh) generator created and developed by David Kopriva. HOHQMesh is a mesh generator specifically designed for spectral element methods. It provides high-order boundary curve information (needed to accurately set boundary conditions) and elements can be larger (due to the high accuracy of the spatial approximation) compared to traditional finite element mesh generators. For more information about the design and features of HOHQMesh one can refer to its official documentation.

HOHQMesh is incorporated into the Trixi.jl framework via the registered Julia package HOHQMesh.jl. This package provides a Julia wrapper for the HOHQMesh generator that allows users to easily create mesh files without the need to build HOHQMesh from source. To install the HOHQMesh package execute

import Pkg; Pkg.add("HOHQMesh")

Now we are ready to generate an unstructured quadrilateral mesh that can be used by Trixi.jl.

Running and visualizing an unstructured simulation

Trixi.jl supports solving hyperbolic problems on several mesh types. There is a default example for this mesh type that can be executed by

using Trixi
+trixi_include(default_example_unstructured())
[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.

This will compute a smooth, manufactured solution test case for the 2D compressible Euler equations on the curved quadrilateral mesh described in the Trixi.jl documentation.

Apart from the usual error and timing output provided by the Trixi.jl run, it is useful to visualize and inspect the solution. One option available in the Trixi.jl framework to visualize the solution on unstructured quadrilateral meshes is post-processing the Trixi.jl output file(s) with the Trixi2Vtk tool and plotting them with ParaView.

To convert the HDF5-formatted .h5 output file(s) from Trixi.jl into VTK format execute the following

using Trixi2Vtk
+trixi2vtk("out/solution_000180.h5", output_directory="out")

Note this step takes about 15-30 seconds as the package Trixi2Vtk must be precompiled and executed for the first time in your REPL session. The trixi2vtk command above will convert the solution file at the final time into a .vtu file which can be read in and visualized with ParaView. Optional arguments for trixi2vtk are: (1) Pointing to the output_directory where the new files will be saved; it defaults to the current directory. (2) Specifying a higher number of visualization nodes. For instance, if we want to use 12 uniformly spaced nodes for visualization we can execute

trixi2vtk("out/solution_000180.h5", output_directory="out", nvisnodes=12)

By default trixi2vtk sets nvisnodes to be the same as the number of nodes specified in the elixir file used to run the simulation.

Finally, if you want to convert all the solution files to VTK execute

trixi2vtk("out/solution_000*.h5", output_directory="out", nvisnodes=12)

then it is possible to open the .pvd file with ParaView and create a video of the simulation.

Creating a mesh using HOHQMesh

The creation of an unstructured quadrilateral mesh using HOHQMesh.jl is driven by a control file. In this file the user dictates the domain to be meshed, prescribes any desired boundary curvature, the polynomial order of said boundaries, etc. In this tutorial we cover several basic features of the possible control inputs. For a complete discussion on this topic see the HOHQMesh control file documentation.

To begin, we provide a complete control file in this tutorial. After this we give a breakdown of the control file components to explain the chosen parameters.

Suppose we want to create a mesh of a domain with straight sided outer boundaries and a curvilinear "ice cream cone" shaped object at its center.

mesh_boundary_cartoon

The associated ice_cream_straight_sides.control file is created below.

open("out/ice_cream_straight_sides.control", "w") do io
+  println(io, raw"""
+\begin{CONTROL_INPUT}
+    \begin{RUN_PARAMETERS}
+        mesh file name   = ice_cream_straight_sides.mesh
+        plot file name   = ice_cream_straight_sides.tec
+        stats file name  = none
+        mesh file format = ISM-v2
+        polynomial order = 4
+        plot file format = skeleton
+    \end{RUN_PARAMETERS}
+
+    \begin{BACKGROUND_GRID}
+        x0 = [-8.0, -8.0, 0.0]
+        dx = [1.0, 1.0, 0.0]
+        N  = [16,16,1]
+    \end{BACKGROUND_GRID}
+
+    \begin{SPRING_SMOOTHER}
+        smoothing            = ON
+        smoothing type       = LinearAndCrossBarSpring
+        number of iterations = 25
+    \end{SPRING_SMOOTHER}
+
+\end{CONTROL_INPUT}
+
+\begin{MODEL}
+
+    \begin{INNER_BOUNDARIES}
+
+        \begin{CHAIN}
+            name = IceCreamCone
+            \begin{END_POINTS_LINE}
+                name = LeftSlant
+                xStart = [-2.0, 1.0, 0.0]
+                xEnd   = [ 0.0, -3.0, 0.0]
+            \end{END_POINTS_LINE}
+
+            \begin{END_POINTS_LINE}
+                name = RightSlant
+                xStart = [ 0.0, -3.0, 0.0]
+                xEnd   = [ 2.0, 1.0, 0.0]
+            \end{END_POINTS_LINE}
+
+            \begin{CIRCULAR_ARC}
+                name        = IceCream
+                units       = degrees
+                center      = [ 0.0, 1.0, 0.0]
+                radius      = 2.0
+                start angle = 0.0
+                end angle   = 180.0
+            \end{CIRCULAR_ARC}
+        \end{CHAIN}
+
+    \end{INNER_BOUNDARIES}
+
+\end{MODEL}
+\end{FILE}
+""")
+end

The first three blocks of information are wrapped within a CONTROL_INPUT environment block as they define the core components of the quadrilateral mesh that will be generated.

The first block of information in RUN_PARAMETERS is

\begin{RUN_PARAMETERS}
+   mesh file name   = ice_cream_straight_sides.mesh
+   plot file name   = ice_cream_straight_sides.tec
+   stats file name  = none
+   mesh file format = ISM-v2
+   polynomial order = 4
+   plot file format = skeleton
+\end{RUN_PARAMETERS}

The mesh and plot file names will be the files created by HOHQMesh once successfully executed. The stats file name is available if you wish to also save a collection of mesh statistics. For this example it is deactivated. These file names given within RUN_PARAMETERS should match that of the control file, and although this is not required by HOHQMesh, it is a useful style convention. The mesh file format ISM-v2 in the format currently required by Trixi.jl. The polynomial order prescribes the order of an interpolant constructed on the Chebyshev-Gauss-Lobatto nodes that is used to represent any curved boundaries on a particular element. The plot file format of skeleton means that visualizing the plot file will only draw the element boundaries (and no internal nodes). Alternatively, the format can be set to sem to visualize the interior nodes of the approximation as well.

The second block of information in BACKGROUND_GRID is

\begin{BACKGROUND_GRID}
+  x0 = [-8.0, -8.0, 0.0]
+  dx = [1.0, 1.0, 0.0]
+  N  = [16,16,1]
+\end{BACKGROUND_GRID}

This lays a grid of Cartesian elements for the domain beginning at the point x0 as its bottom-left corner. The value of dx, which could differ in each direction if desired, controls the step size taken in each Cartesian direction. The values in N set how many Cartesian box elements are set in each coordinate direction. The above parameters define a $16\times 16$ element square mesh on $[-8,8]^2$. Further, this sets up four outer boundaries of the domain that are given the default names: Top, Left, Bottom, Right.

The third block of information in SPRING_SMOOTHER is

\begin{SPRING_SMOOTHER}
+   smoothing            = ON
+   smoothing type       = LinearAndCrossBarSpring
+   number of iterations = 25
+\end{SPRING_SMOOTHER}

Once HOHQMesh generates the mesh, a spring-mass-dashpot model is created to smooth the mesh and create "nicer" quadrilateral elements. The default parameters of Hooke's law for the spring-mass-dashpot model have been selected after a fair amount of experimentation across many meshes. If you wish to deactivate this feature you can set smoothing = OFF (or remove this block from the control file).

After the CONTROL_INPUT environment block comes the MODEL environment block. It is here where the user prescribes curved boundary information with either:

  • An OUTER_BOUNDARY (covered in the next section of this tutorial).
  • One or more INNER_BOUNDARIES.

There are several options to describe the boundary curve data to HOHQMesh like splines or parametric curves.

For the example ice_cream_straight_sides.control we define three internal boundaries; two straight-sided and one as a circular arc. Within the HOHQMesh control input each curve must be assigned to a CHAIN as shown below in the complete INNER_BOUNDARIES block.

\begin{INNER_BOUNDARIES}
+
+   \begin{CHAIN}
+   name = IceCreamCone
+   \begin{END_POINTS_LINE}
+      name = LeftSlant
+      xStart = [-2.0, 1.0, 0.0]
+      xEnd   = [ 0.0, -3.0, 0.0]
+   \end{END_POINTS_LINE}
+
+   \begin{END_POINTS_LINE}
+      name = RightSlant
+      xStart = [ 0.0, -3.0, 0.0]
+      xEnd   = [ 2.0, 1.0, 0.0]
+   \end{END_POINTS_LINE}
+
+   \begin{CIRCULAR_ARC}
+      name        = IceCream
+      units       = degrees
+      center      = [ 0.0, 1.0, 0.0]
+      radius      = 2.0
+      start angle = 0.0
+      end angle   = 180.0
+   \end{CIRCULAR_ARC}
+   \end{CHAIN}
+
+\end{INNER_BOUNDARIES}

It is important to note there are two name quantities one for the CHAIN and one for the PARAMETRIC_EQUATION_CURVE. The name for the CHAIN is used internally by HOHQMesh, so if you have multiple CHAINs they must be given a unique name. The name for the PARAMETRIC_EQUATION_CURVE will be printed to the appropriate boundaries within the .mesh file produced by HOHQMesh.

We create the mesh file ice_cream_straight_sides.mesh and its associated file for plotting ice_cream_straight_sides.tec by using HOHQMesh.jl's function generate_mesh.

using HOHQMesh
+control_file = joinpath("out", "ice_cream_straight_sides.control")
+output = generate_mesh(control_file);

The mesh file ice_cream_straight_sides.mesh and its associated file for plotting ice_cream_straight_sides.tec are placed in the out folder. The resulting mesh generated by HOHQMesh.jl is given in the following figure.

mesh_straight_sides

We note that Trixi.jl uses the boundary name information from the control file to assign boundary conditions in an elixir file. Therefore, the name should start with a letter and consist only of alphanumeric characters and underscores. Please note that the name will be treated as case sensitive.

Example simulation on ice_cream_straight_sides.mesh

With this newly generated mesh we are ready to run a Trixi.jl simulation on an unstructured quadrilateral mesh. For this we must create a new elixir file.

The elixir file given below creates an initial condition for a uniform background flow state with a free stream Mach number of 0.3. A focus for this part of the tutorial is to specify the boundary conditions and to construct the new mesh from the file that was generated in the previous exercise.

It is straightforward to set the different boundary condition types in an elixir by assigning a particular function to a boundary name inside a Julia dictionary, Dict, variable. Observe that the names of these boundaries match those provided by HOHQMesh either by default, e.g. Bottom, or user assigned, e.g. IceCream. For this problem setup use

  • Freestream boundary conditions on the four box edges.
  • Free slip wall boundary condition on the interior curved boundaries.

To construct the unstructured quadrilateral mesh from the HOHQMesh file we point to the appropriate location with the variable mesh_file and then feed this into the constructor for the UnstructuredMesh2D type in Trixi.jl

# create the unstructured mesh from your mesh file
+using Trixi
+mesh_file = joinpath("out", "ice_cream_straight_sides.mesh")
+mesh = UnstructuredMesh2D(mesh_file);

The complete elixir file for this simulation example is given below.

using OrdinaryDiffEq, Trixi
+
+equations = CompressibleEulerEquations2D(1.4) # set gas gamma = 1.4
+
+# freestream flow state with Ma_inf = 0.3
+@inline function uniform_flow_state(x, t, equations::CompressibleEulerEquations2D)
+
+  # set the freestream flow parameters
+  rho_freestream = 1.0
+  u_freestream = 0.3
+  p_freestream = inv(equations.gamma)
+
+  theta = 0.0 # zero angle of attack
+  si, co = sincos(theta)
+  v1 = u_freestream * co
+  v2 = u_freestream * si
+
+  prim = SVector(rho_freestream, v1, v2, p_freestream)
+  return prim2cons(prim, equations)
+end
+
+# initial condition
+initial_condition = uniform_flow_state
+
+# boundary condition types
+boundary_condition_uniform_flow = BoundaryConditionDirichlet(uniform_flow_state)
+
+# boundary condition dictionary
+boundary_conditions = Dict( :Bottom     => boundary_condition_uniform_flow,
+                            :Top        => boundary_condition_uniform_flow,
+                            :Right      => boundary_condition_uniform_flow,
+                            :Left       => boundary_condition_uniform_flow,
+                            :LeftSlant  => boundary_condition_slip_wall,
+                            :RightSlant => boundary_condition_slip_wall,
+                            :IceCream   => boundary_condition_slip_wall );
+
+# DGSEM solver.
+#    1) polydeg must be >= the polynomial order set in the HOHQMesh control file to guarantee
+#       freestream preservation. As a extra task try setting polydeg=3
+#    2) VolumeIntegralFluxDifferencing with central volume flux is activated
+#       for dealiasing
+volume_flux = flux_ranocha
+solver = DGSEM(polydeg=4, surface_flux=flux_hll,
+               volume_integral=VolumeIntegralFluxDifferencing(volume_flux))
+
+# create the unstructured mesh from your mesh file
+mesh_file = joinpath("out", "ice_cream_straight_sides.mesh")
+mesh = UnstructuredMesh2D(mesh_file)
+
+# Create semidiscretization with all spatial discretization-related components
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                    boundary_conditions=boundary_conditions)
+
+# Create ODE problem from semidiscretization with time span from 0.0 to 2.0
+tspan = (0.0, 2.0)
+ode = semidiscretize(semi, tspan)
+
+
+# Create the callbacks to output solution files and adapt the time step
+summary_callback = SummaryCallback()
+save_solution = SaveSolutionCallback(interval=10,
+                                     save_initial_solution=true,
+                                     save_final_solution=true)
+stepsize_callback = StepsizeCallback(cfl=1.0)
+
+callbacks = CallbackSet(summary_callback, save_solution, stepsize_callback)
+
+# Evolve ODE problem in time using `solve` from OrdinaryDiffEq
+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);
+# print the timer summary
+summary_callback()

Visualization of the solution is carried out in a similar way as above. That is, one converts the .h5 output files with trixi2vtk and then plot the solution in ParaView. An example plot of the pressure at the final time is shown below.

simulation_straight_sides

Making a mesh with a curved outer boundary

Let us modify the mesh from the previous task and place a circular outer boundary instead of straight-sided outer boundaries. Note, the "ice cream cone" shape is still placed at the center of the domain.

We create the new control file ice_cream_curved_sides.control file below and will then highlight the major differences compared to ice_cream_straight_sides.control.

open("out/ice_cream_curved_sides.control", "w") do io
+  println(io, raw"""
+\begin{CONTROL_INPUT}
+    \begin{RUN_PARAMETERS}
+        mesh file name   = ice_cream_curved_sides.mesh
+        plot file name   = ice_cream_curved_sides.tec
+        stats file name  = none
+        mesh file format = ISM-v2
+        polynomial order = 4
+        plot file format = skeleton
+    \end{RUN_PARAMETERS}
+
+    \begin{BACKGROUND_GRID}
+        background grid size = [1.0, 1.0, 0.0]
+    \end{BACKGROUND_GRID}
+
+    \begin{SPRING_SMOOTHER}
+        smoothing            = ON
+        smoothing type       = LinearAndCrossBarSpring
+        number of iterations = 25
+    \end{SPRING_SMOOTHER}
+
+\end{CONTROL_INPUT}
+
+\begin{MODEL}
+
+    \begin{OUTER_BOUNDARY}
+        \begin{PARAMETRIC_EQUATION_CURVE}
+            name = OuterCircle
+            xEqn = x(t) = 8.0*sin(2.0*pi*t)
+            yEqn = y(t) = 8.0*cos(2.0*pi*t)
+            zEqn = z(t) = 0.0
+        \end{PARAMETRIC_EQUATION_CURVE}
+
+    \end{OUTER_BOUNDARY}
+
+    \begin{INNER_BOUNDARIES}
+
+        \begin{CHAIN}
+            name = IceCreamCone
+            \begin{END_POINTS_LINE}
+                name = LeftSlant
+                xStart = [-2.0, 1.0, 0.0]
+                xEnd   = [ 0.0, -3.0, 0.0]
+            \end{END_POINTS_LINE}
+
+            \begin{END_POINTS_LINE}
+                name = RightSlant
+                xStart = [ 0.0, -3.0, 0.0]
+                xEnd   = [ 2.0, 1.0, 0.0]
+            \end{END_POINTS_LINE}
+
+            \begin{CIRCULAR_ARC}
+                name        = IceCream
+                units       = degrees
+                center      = [ 0.0, 1.0, 0.0]
+                radius      = 2.0
+                start angle = 0.0
+                end angle   = 180.0
+            \end{CIRCULAR_ARC}
+        \end{CHAIN}
+
+    \end{INNER_BOUNDARIES}
+
+\end{MODEL}
+\end{FILE}
+""")
+end

The first alteration is that we have altered the second block of information BACKGROUND_GRID within the CONTROL_INPUT to be

\begin{BACKGROUND_GRID}
+   background grid size = [1.0, 1.0, 0.0]
+\end{BACKGROUND_GRID}

This mesh control file has an outer boundary that determines the extent of the domain to be meshed. Therefore, we only need to supply the background grid size to the BACKGROUND_GRID control input.

The second alteration is that the MODEL now contains information for an OUTER_BOUNDARY. In this case it is a circle of radius 8 centered at [0.0, 0.0, 0.0] written as a set of PARAMETRIC_EQUATION_CURVEs.

   \begin{OUTER_BOUNDARY}
+
+      \begin{PARAMETRIC_EQUATION_CURVE}
+         name = OuterCircle
+         xEqn = x(t) = 8.0*sin(2.0*pi*t)
+         yEqn = y(t) = 8.0*cos(2.0*pi*t)
+         zEqn = z(t) = 0.0
+      \end{PARAMETRIC_EQUATION_CURVE}
+
+   \end{OUTER_BOUNDARY}

Just as with the inner boundary curves, we must assign a name to the OUTER_BOUNDARY. It will be included in the generated .mesh file and is used within the Trixi.jl elixir file to set boundary conditions.

Again, we create the .mesh and .tec files with HOHQMesh.jl's function generate_mesh

control_file = joinpath("out", "ice_cream_curved_sides.control")
+output = generate_mesh(control_file);

The files are placed in the out folder.

The resulting mesh generated by HOHQMesh.jl is given in the following figure.

mesh_curved_sides

Running Trixi.jl on ice_cream_curved_sides.mesh

We can reuse much of the elixir file to setup the uniform flow over an ice cream cone from the previous part of this tutorial. The only component of the elixir file that must be changed is the boundary condition dictionary because we now have a boundary named OuterCircle instead of four edges of a bounding box.

# boundary condition dictionary
+boundary_conditions = Dict( :OuterCircle => boundary_condition_uniform_flow,
+                            :LeftSlant   => boundary_condition_slip_wall,
+                            :RightSlant  => boundary_condition_slip_wall,
+                            :IceCream    => boundary_condition_slip_wall );

Also, we must update the construction of the mesh from our new mesh file ice_cream_curved_sides.mesh that is located in the out folder.

# create the unstructured mesh from your mesh file
+mesh_file = joinpath("out", "ice_cream_curved_sides.mesh")
+mesh = UnstructuredMesh2D(mesh_file);

We can then post-process the solution file at the final time on the new mesh with Trixi2Vtk and visualize with ParaView.

simulation_curved_sides

Setting up a simulation with AMR via P4estMesh

The above explained mesh file format of ISM-V2 only works with UnstructuredMesh2D and so does not support AMR. On the other hand, the mesh type P4estMesh allows AMR. The mesh constructor for the P4estMesh imports an unstructured, conforming mesh from an Abaqus mesh file (.inp).

As described above, the first block of the HOHQMesh control file contains the parameter mesh file format. If you set mesh file format = ABAQUS instead of ISM-V2, HOHQMesh.jl's function generate_mesh creates an Abaqus mesh file .inp.

using HOHQMesh
+control_file = joinpath("out", "ice_cream_straight_sides.control")
+output = generate_mesh(control_file);

Now, you can create a P4estMesh from your mesh file. It is described in detail in the P4est-based mesh part of the Trixi.jl docs.

using Trixi
+mesh_file = joinpath("out", "ice_cream_straight_sides.inp")
+mesh = P4estMesh{2}(mesh_file)

Since P4estMesh supports AMR, we just have to extend the setup from the first example by the standard AMR procedure. For more information about AMR in Trixi.jl, see the matching tutorial.

amr_indicator = IndicatorLöhner(semi, variable=density)
+
+amr_controller = ControllerThreeLevel(semi, amr_indicator,
+                                      base_level=0,
+                                      med_level =1, med_threshold=0.05,
+                                      max_level =3, max_threshold=0.1)
+
+amr_callback = AMRCallback(semi, amr_controller,
+                           interval=5,
+                           adapt_initial_condition=true,
+                           adapt_initial_condition_only_refine=true)
+
+callbacks = CallbackSet(..., amr_callback)

We can then post-process the solution file at the final time on the new mesh with Trixi2Vtk and visualize with ParaView, see the appropriate visualization section for details.

simulation_straight_sides_p4est_amr

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots", "Trixi2Vtk", "HOHQMesh"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [e4f4c7b8] HOHQMesh v0.2.1
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`
+  [bc1476a1] Trixi2Vtk v0.3.11

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/introduction/index.html b/previews/PR1697/tutorials/introduction/index.html new file mode 100644 index 00000000000..ae5f96d65b7 --- /dev/null +++ b/previews/PR1697/tutorials/introduction/index.html @@ -0,0 +1,2 @@ + +Introduction · Trixi.jl

Tutorials for Trixi.jl

The tutorial section for Trixi.jl also contains interactive step-by-step explanations via Binder.

Right now, you are using the classic documentation. The corresponding interactive notebooks can be opened in Binder and viewed in nbviewer via the icons and in the respective tutorial. You can download the raw notebooks from GitHub via .

Note: To improve responsiveness via caching, the notebooks are updated only once a week. They are only available for the latest stable release of Trixi.jl at the time of caching.

There are tutorials for the following topics:

1 Introduction to DG methods

This tutorial gives an introduction to discontinuous Galerkin (DG) methods with the example of the scalar linear advection equation in 1D. Starting with some theoretical explanations, we first implement a raw version of a discontinuous Galerkin spectral element method (DGSEM). Then, we will show how to use features of Trixi.jl to achieve the same result.

2 DGSEM with flux differencing

To improve stability often the flux differencing formulation of the DGSEM (split form) is used. We want to present the idea and formulation on a basic 1D level. Then, we show how this formulation can be implemented in Trixi.jl and analyse entropy conservation for two different flux combinations.

3 Shock capturing with flux differencing and stage limiter

Using the flux differencing formulation, a simple procedure to capture shocks is a hybrid blending of a high-order DG method and a low-order subcell finite volume (FV) method. We present the idea on a very basic level and show the implementation in Trixi.jl. Then, a positivity preserving limiter is explained and added to an exemplary simulation of the Sedov blast wave with the 2D compressible Euler equations.

4 Non-periodic boundary conditions

Thus far, all examples used periodic boundaries. In Trixi.jl, you can also set up a simulation with non-periodic boundaries. This tutorial presents the implementation of the classical Dirichlet boundary condition with a following example. Then, other non-periodic boundaries are mentioned.

5 DG schemes via DGMulti solver

This tutorial is about the more general DG solver DGMulti, introduced here. We are showing some examples for this solver, for instance with discretization nodes by Gauss or triangular elements. Moreover, we present a simple way to include pre-defined triangulate meshes for non-Cartesian domains using the package StartUpDG.jl.

6 Other SBP schemes (FD, CGSEM) via DGMulti solver

Supplementary to the previous tutorial about DG schemes via the DGMulti solver we now present the possibility for DGMulti to use other SBP schemes via the package SummationByPartsOperators.jl. For instance, we show how to set up a finite differences (FD) scheme and a continuous Galerkin (CGSEM) method.

7 Upwind FD SBP schemes

General SBP schemes can not only be used via the DGMulti solver but also with a general DG solver. In particular, upwind finite difference SBP methods can be used together with the TreeMesh. Similar to general SBP schemes in the DGMulti framework, the interface is based on the package SummationByPartsOperators.jl.

8 Adding a new scalar conservation law

This tutorial explains how to add a new physics model using the example of the cubic conservation law. First, we define the equation using a struct CubicEquation and the physical flux. Then, the corresponding standard setup in Trixi.jl (mesh, solver, semi and ode) is implemented and the ODE problem is solved by OrdinaryDiffEq's solve method.

9 Adding a non-conservative equation

In this part, another physics model is implemented, the nonconservative linear advection equation. We run two different simulations with different levels of refinement and compare the resulting errors.

10 Parabolic terms

This tutorial describes how parabolic terms are implemented in Trixi.jl, e.g., to solve the advection-diffusion equation.

11 Adding new parabolic terms

This tutorial describes how new parabolic terms can be implemented using Trixi.jl.

12 Adaptive mesh refinement

Adaptive mesh refinement (AMR) helps to increase the accuracy in sensitive or turbolent regions while not wasting resources for less interesting parts of the domain. This leads to much more efficient simulations. This tutorial presents the implementation strategy of AMR in Trixi.jl, including the use of different indicators and controllers.

13 Structured mesh with curvilinear mapping

In this tutorial, the use of Trixi.jl's structured curved mesh type StructuredMesh is explained. We present the two basic option to initialize such a mesh. First, the curved domain boundaries of a circular cylinder are set by explicit boundary functions. Then, a fully curved mesh is defined by passing the transformation mapping.

14 Unstructured meshes with HOHQMesh.jl

The purpose of this tutorial is to demonstrate how to use the UnstructuredMesh2D functionality of Trixi.jl. This begins by running and visualizing an available unstructured quadrilateral mesh example. Then, the tutorial will demonstrate how to conceptualize a problem with curved boundaries, generate a curvilinear mesh using the available HOHQMesh software in the Trixi.jl ecosystem, and then run a simulation using Trixi.jl on said mesh. In the end, the tutorial briefly explains how to simulate an example using AMR via P4estMesh.

15 Explicit time stepping

This tutorial is about time integration using OrdinaryDiffEq.jl. It explains how to use their algorithms and presents two types of time step choices - with error-based and CFL-based adaptive step size control.

16 Differentiable programming

This part deals with some basic differentiable programming topics. For example, a Jacobian, its eigenvalues and a curve of total energy (through the simulation) are calculated and plotted for a few semidiscretizations. Moreover, we calculate an example for propagating errors with Measurement.jl at the end.

17 Custom semidiscretization

This tutorial describes the semidiscretiations of Trixi.jl and explains how to extend them for custom tasks.

Examples in Trixi.jl

Trixi.jl already contains several more coding examples, the so-called elixirs. You can find them in the folder examples/. They are structured by the underlying mesh type and the respective number of spatial dimensions. The name of an elixir is composed of the underlying system of conservation equations (for instance advection or euler) and other special characteristics like the initial condition (e.g. gauss, astro_jet, blast_wave) or the included simulation features (e.g. amr, shockcapturing).


This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/non_periodic_boundaries/c37303c4.gif b/previews/PR1697/tutorials/non_periodic_boundaries/c37303c4.gif new file mode 100644 index 0000000000000000000000000000000000000000..6c121500fe81f66a540d4a5ea57b697f768fbb1d GIT binary patch literal 1128612 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

s7b{zN=s=@K)MYXjnw;cZ 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

~n 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

`fAL)QN3c2Nyt@fak&ChJ;0H+RIK4)st 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 x4-A4yQ6$5^#?k#q;i}dUOsam@=0Ia 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�!_N8fg(l0XQH5~Kx! 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%0D3A9jJ#~R`A2@Y#R|U0;QYpx3v4 z)wJ~f){&>{Bk%x*pytf?+&1^PJ5X546jeufS_G#PQ;n1Y$+`3{dAJcR}o zL>klR?Fap#_kz`}8Ryl18-0RN2M_xvSEQ%zpgaG>j15ZV4$O^jZ}7ONf2^eQbY|+f$y+}jGcok1 z>*=3-viJ)q&KIuS$o1Z`|&AI&o4c} zqzA!@ay9)DXS2d~G4oZ%hkLYV)RjNwm;dBGYU{RbP0Nl+9+{f8dO62=aRuH!J@v#t zRe05kA82w;y)iQKTmu|oTAN|dQ+=@jU&zSP5KNb=e)@2U=V79e*>IU)pPT@FODsqD z^z=g3u#VFtS4sLwmgU#TTM?YSab(C3j-?%M^nr%BX2Yqq- z8=Y+&mxbT{PAz(^ej{;|X`yeaW_s-%ra^Ng(&S~Lx%wy6L1Ft^%KO%Yr!f`ZG@_5q zev4O}{+yIqhm{+-Hni;S-{2f;D*s_$(6#Dt9nb30O;3U{ZEr`;+?h^XJ&Uu7+}0Gy zpZk+=2D5Wx<1;4vCF}eu8_ho~WN_O+V0>ji=ZgByt+wydSv#Dv=^dw{O>iSNFCcXIdQKAx0i%@O)@evK-zpIyJE2U;`;QA(XG(p`*JASR*MCb1}B^YkKu};mJ zcF3!_%0i-T=D@cx)^QPbp74vGegz#gt`~+yz1-s)9^O@2a@UNwEVJeEX8P7QbDO&% z)%ziVvSRmBzV7bNe2oqm5l2L^L|yF*v!q2eRzxKUY`aLVD@z|j;B)q7`VGI`?`Ltz zQr~wx_s+D0BUq1KMszDw1?r+>>|gm^h&^1~JW6;QZm)4OvF70`SpnYlRHvKc4mamG z;GFA?MSX9goc@Y-Z5~e1GzD8Nev>Mu8s2m-?EgmSbhFO;?sfaV>f4q0v$=k0xb9m} zG|%cGooDT9;%k4JIyVehkp9oO(h*4e%j$LwmZcfWDf54XUk}~%K^wXNArmVmWz+Ep zKXIsg4++19LM0KqPTK56oneR!kO;9F*~YN(H@B9ULOmYGMXFaw-P z=Ft|KS>)b-3M(d8?#Yyc>%*B&AKFY>e%&`BBWuP^!pfoU{Z;3e1ykJR^$cT&g1XXA zDp_@&PW6l?SnN0?Mxm4&W(rttk7St@8DE3V-N?w*^VQ9o%^41#)8Av-I$LpXHj6e@ zv~Zcb{Ea}&Jz9e^d*kMFub*(eSe}#3VDHkcB!~Q)kJrL#8cxz6}K#{h9et&8F1`%hn*&lzvNx?i7T$)X8Mv%1gpch1O3h>sWJf=9VG zpHxL&*$Hk%$)1qX-srM2iW4a6lYiH?J-&a_*^Bk7F5Qc614BQ+

=ZLdBF|13R!}f@ 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 +

Source: Video on Trixi.jl's YouTube channel Trixi Framework

A double Mach reflection problem for the 2D compressible Euler equations elixir_euler_double_mach_amr.jl exercises a special boundary conditions along the bottom of the domain that is a mixture of Dirichlet and slip wall.

+

Source: Video on Trixi.jl's YouTube channel Trixi Framework

A channel flow around a cylinder at Mach 3 elixir_euler_supersonic_cylinder.jl contains supersonic Mach 3 inflow at the left portion of the domain and supersonic outflow at the right portion of the domain. The top and bottom of the channel as well as the cylinder are treated as Euler slip wall boundaries.

+

Source: Video on Trixi.jl's YouTube channel Trixi Framework

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/notebooks/DGMulti_1.ipynb b/previews/PR1697/tutorials/notebooks/DGMulti_1.ipynb new file mode 100644 index 00000000000..8169567be87 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/DGMulti_1.ipynb @@ -0,0 +1,478 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 5: DG schemes via `DGMulti` solver" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "`DGMulti` is a DG solver that allows meshes with simplex elements. The basic idea and\n", + "implementation of this solver is explained in section \"Meshes\".\n", + "Here, we want to give some examples and a quick overview about the options with `DGMulti`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We start with a simple example we already used in the tutorial about flux differencing.\n", + "There, we implemented a simulation with `initial_condition_weak_blast_wave` for the\n", + "2D compressible Euler equations `CompressibleEulerEquations2D` and used the DG formulation\n", + "with flux differencing using volume flux `flux_ranocha` and surface flux `flux_lax_friedrichs`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Here, we want to implement the equivalent example, only now using the `DGMulti` solver\n", + "instead of `DGSEM`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "\n", + "initial_condition = initial_condition_weak_blast_wave" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To use the Gauss-Lobatto nodes again, we choose `approximation_type=SBP()` in the solver.\n", + "Since we want to start with a Cartesian domain discretized with squares, we use the element\n", + "type `Quad()`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "dg = DGMulti(polydeg = 3,\n", + " element_type = Quad(),\n", + " approximation_type = SBP(),\n", + " surface_flux = flux_lax_friedrichs,\n", + " volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n", + "\n", + "cells_per_dimension = (32, 32)\n", + "mesh = DGMultiMesh(dg,\n", + " cells_per_dimension, # initial_refinement_level = 5\n", + " coordinates_min=(-2.0, -2.0),\n", + " coordinates_max=( 2.0, 2.0),\n", + " periodicity=true)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n", + " boundary_conditions=boundary_condition_periodic)\n", + "tspan = (0.0, 0.4)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "alive_callback = AliveCallback(alive_interval=10)\n", + "analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\n", + "callbacks = CallbackSet(analysis_callback, alive_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Run the simulation with the same time integration algorithm as before." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, RDPK3SpFSAL49(), abstol=1.0e-6, reltol=1.0e-6,\n", + " callback=callbacks, save_everystep=false);" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "pd = PlotData2D(sol)\n", + "plot(pd)" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "plot(pd[\"rho\"])\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This simulation is not as fast as the equivalent with `TreeMesh` since no special optimizations for\n", + "quads (for instance tensor product structure) have been implemented. Figure 4 in [\"Efficient implementation of modern entropy stable\n", + "and kinetic energy preserving discontinuous Galerkin methods for conservation laws\"](https://arxiv.org/abs/2112.10517)\n", + "(2021) provides a nice runtime comparison between the different mesh types. On the other hand,\n", + "the functions are more general and thus we have more option we can choose from." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Simulation with Gauss nodes\n", + "For instance, we can change the approximation type of our simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "initial_condition = initial_condition_weak_blast_wave" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We now use Gauss nodes instead of Gauss-Lobatto nodes which can be done for the element types\n", + "`Quad()` and `Hex()`. Therefore, we set `approximation_type=GaussSBP()`. Alternatively, we\n", + "can use a modal approach using the approximation type `Polynomial()`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "dg = DGMulti(polydeg = 3,\n", + " element_type = Quad(),\n", + " approximation_type = GaussSBP(),\n", + " surface_flux = flux_lax_friedrichs,\n", + " volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n", + "\n", + "cells_per_dimension = (32, 32)\n", + "mesh = DGMultiMesh(dg,\n", + " cells_per_dimension, # initial_refinement_level = 5\n", + " coordinates_min=(-2.0, -2.0),\n", + " coordinates_max=( 2.0, 2.0),\n", + " periodicity=true)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n", + " boundary_conditions=boundary_condition_periodic)\n", + "tspan = (0.0, 0.4)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "alive_callback = AliveCallback(alive_interval=10)\n", + "analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\n", + "callbacks = CallbackSet(analysis_callback, alive_callback);\n", + "\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n", + " ode_default_options()..., callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "pd = PlotData2D(sol)\n", + "plot(pd)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Simulation with triangular elements\n", + "Also, we can set another element type. We want to use triangles now." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "initial_condition = initial_condition_weak_blast_wave" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Since there is no direct equivalent to Gauss-Lobatto nodes on triangles, the approximation type\n", + "`SBP()` now uses Gauss-Lobatto nodes on faces and special nodes in the interior of the triangular.\n", + "More details can be found in the documentation of\n", + "[StartUpDG.jl](https://jlchan.github.io/StartUpDG.jl/dev/RefElemData/#RefElemData-based-on-SBP-finite-differences)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "dg = DGMulti(polydeg = 3,\n", + " element_type = Tri(),\n", + " approximation_type = SBP(),\n", + " surface_flux = flux_lax_friedrichs,\n", + " volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))\n", + "\n", + "cells_per_dimension = (32, 32)\n", + "mesh = DGMultiMesh(dg,\n", + " cells_per_dimension, # initial_refinement_level = 5\n", + " coordinates_min=(-2.0, -2.0),\n", + " coordinates_max=( 2.0, 2.0),\n", + " periodicity=true)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n", + " boundary_conditions=boundary_condition_periodic)\n", + "tspan = (0.0, 0.4)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "alive_callback = AliveCallback(alive_interval=10)\n", + "analysis_callback = AnalysisCallback(semi, interval=100, uEltype=real(dg))\n", + "callbacks = CallbackSet(analysis_callback, alive_callback);\n", + "\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n", + " ode_default_options()..., callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "pd = PlotData2D(sol)\n", + "plot(pd)" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "plot(pd[\"rho\"])\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Triangular meshes on non-Cartesian domains\n", + "To use triangular meshes on a non-Cartesian domain, Trixi.jl uses the package [StartUpDG.jl](https://github.com/jlchan/StartUpDG.jl).\n", + "The following example is based on [`elixir_euler_triangulate_pkg_mesh.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/dgmulti_2d/elixir_euler_triangulate_pkg_mesh.jl)\n", + "and uses a pre-defined mesh from StartUpDG.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We want to simulate the smooth initial condition `initial_condition_convergence_test`\n", + "with source terms `source_terms_convergence_test` for the 2D compressible Euler equations." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "equations = CompressibleEulerEquations2D(1.4)\n", + "initial_condition = initial_condition_convergence_test\n", + "source_terms = source_terms_convergence_test" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We create the solver `DGMulti` with triangular elements (`Tri()`) as before." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "dg = DGMulti(polydeg = 3, element_type = Tri(),\n", + " approximation_type=Polynomial(),\n", + " surface_flux = flux_lax_friedrichs,\n", + " volume_integral = VolumeIntegralFluxDifferencing(flux_ranocha))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "StartUpDG.jl provides for instance a pre-defined Triangulate geometry for a rectangular domain with\n", + "hole `RectangularDomainWithHole`. Other pre-defined Triangulate geometries are e.g., `SquareDomain`,\n", + "`Scramjet`, and `CircularDomain`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "meshIO = StartUpDG.triangulate_domain(StartUpDG.RectangularDomainWithHole());" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The pre-defined Triangulate geometry in StartUpDG has integer boundary tags. With `DGMultiMesh`\n", + "we assign boundary faces based on these integer boundary tags and create a mesh compatible with Trixi.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "mesh = DGMultiMesh(meshIO, dg, Dict(:outer_boundary=>1, :inner_boundary=>2))" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "boundary_condition_convergence_test = BoundaryConditionDirichlet(initial_condition)\n", + "boundary_conditions = (; :outer_boundary => boundary_condition_convergence_test,\n", + " :inner_boundary => boundary_condition_convergence_test)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, dg,\n", + " source_terms = source_terms,\n", + " boundary_conditions = boundary_conditions)\n", + "\n", + "tspan = (0.0, 0.2)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "alive_callback = AliveCallback(alive_interval=20)\n", + "analysis_callback = AnalysisCallback(semi, interval=200, uEltype=real(dg))\n", + "callbacks = CallbackSet(alive_callback, analysis_callback);\n", + "\n", + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt = 0.5 * estimate_dt(mesh, dg), save_everystep=false, callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "pd = PlotData2D(sol)\n", + "plot(pd[\"rho\"])\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "For more information, please have a look in the [StartUpDG.jl documentation](https://jlchan.github.io/StartUpDG.jl/stable/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"StartUpDG\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/DGMulti_2.ipynb b/previews/PR1697/tutorials/notebooks/DGMulti_2.ipynb new file mode 100644 index 00000000000..452985ee64a --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/DGMulti_2.ipynb @@ -0,0 +1,157 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 6: Other SBP schemes (FD, CGSEM) via `DGMulti` solver" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For a tutorial about DG schemes via the `DGMulti` solver please visit the previous tutorial.\n", + "The `DGMulti` solver also supports other methods than DG. The important property a method has to\n", + "fulfill is the summation-by-parts (SBP) property. The package [SummationByPartsOperators.jl](https://github.com/ranocha/SummationByPartsOperators.jl)\n", + "provides such methods, like a finite difference SBP (FD SBP) scheme. To do this,\n", + "you need to create an SBP derivative operator and pass that as `approximation_type`\n", + "to the `DGMulti` constructor. For example, the classical second-order FD SBP operator\n", + "can be created as" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly\n", + "D = derivative_operator(MattssonNordström2004(), derivative_order=1, accuracy_order=2,\n", + " xmin=0.0, xmax=1.0, N=11)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Here, the arguments `xmin` and `xmax` do not matter beyond setting the real type\n", + "used for the operator - they just set a reference element and are rescaled on the\n", + "physical elements. The parameter `N` determines the number of finite difference nodes.\n", + "Then, `D` can be used as `approximation_type` like `SBP()` in a multi-block fashion.\n", + "In multiple dimensions, such a 1D SBP operator will be used in a tensor product fashion,\n", + "i.e., in each coordinate direction. In particular, you can use them only on 1D, 2D `Quad()`,\n", + "and 3D `Hex()` elements.\n", + "\n", + "You can also use fully periodic single-block FD methods by creating a periodic SBP\n", + "operator. For example, a fully periodic FD operator can be constructed as" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "D = periodic_derivative_operator(derivative_order=1, accuracy_order=2,\n", + " xmin=0.0, xmax=1.0, N=11)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "An example using such an FD method is implemented in\n", + "[`elixir_euler_fdsbp_periodic.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/dgmulti_2d/elixir_euler_fdsbp_periodic.jl).\n", + "For all parameters and other calling options, please have a look in the\n", + "[documentation of SummationByPartsOperators.jl](https://ranocha.de/SummationByPartsOperators.jl/stable/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Another possible method is for instance a continuous Galerkin (CGSEM) method. You can use such a\n", + "method with polynomial degree of `3` (`N=4` Legendre Lobatto nodes on `[0, 1]`) coupled continuously\n", + "on a uniform mesh with `Nx=10` elements by setting `approximation_type` to" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi.SummationByPartsOperators # or add SummationByPartsOperators to your project and use it directly\n", + "D = couple_continuously(legendre_derivative_operator(xmin=0.0, xmax=1.0, N=4),\n", + " UniformPeriodicMesh1D(xmin=-1.0, xmax=1.0, Nx=10))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To choose a discontinuous coupling (DGSEM), use `couple_discontinuously()` instead of `couple_continuously()`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For more information and other SBP operators, see the documentations of [StartUpDG.jl](https://jlchan.github.io/StartUpDG.jl/dev/)\n", + "and [SummationByPartsOperators.jl](https://ranocha.de/SummationByPartsOperators.jl/stable/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"StartUpDG\", \"SummationByPartsOperators\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/DGSEM_FluxDiff.ipynb b/previews/PR1697/tutorials/notebooks/DGSEM_FluxDiff.ipynb new file mode 100644 index 00000000000..2da43a6e4bf --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/DGSEM_FluxDiff.ipynb @@ -0,0 +1,525 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 2: DGSEM with flux differencing" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This tutorial starts with a presentation of the weak formulation of the discontinuous Galerkin\n", + "spectral element method (DGSEM) in order to fix the notation of the used operators.\n", + "Then, the DGSEM formulation with flux differencing (split form DGSEM) and its implementation in\n", + "[Trixi.jl](https://github.com/trixi-framework/Trixi.jl) is shown." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We start with the one-dimensional conservation law\n", + "$$\n", + "u_t + f(u)_x = 0, \\qquad t\\in \\mathbb{R}^+, x\\in\\Omega\n", + "$$\n", + "with the physical flux $f$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We split the domain $\\Omega$ into elements $K$ with center $x_K$ and size $\\Delta x$. With the\n", + "transformation mapping $x(\\xi)=x_K + \\frac{\\Delta x}{2} \\xi$ we can transform the reference element\n", + "$[-1,1]$ to every physical element. So, the equation can be restricted to the reference element using the\n", + "determinant of the Jacobian matrix of the transformation mapping\n", + "$J=\\frac{\\partial x}{\\partial \\xi}=\\frac{\\Delta x}{2}$.\n", + "$$\n", + "J u_t + f(u)_{\\xi} = 0, \\qquad t\\in \\mathbb{R}^+, \\xi\\in [-1,1]\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## The weak form of the DGSEM\n", + "We consider the so-called discontinuous Galerkin spectral element method (DGSEM) with collocation.\n", + "It results from choosing a nodal DG ansatz using $N+1$ Gauss-Lobatto nodes $\\xi_i$ in $[-1,1]$\n", + "with matching interpolation weights $w_i$, which are used for numerical integration and interpolation with\n", + "the Lagrange polynomial basis $l_i$ of degree $N$. The Lagrange functions are created with those nodes and\n", + "hence fulfil a Kronecker property at the GL nodes.\n", + "The weak formulation of the DGSEM for one element is\n", + "$$\n", + "J \\underline{\\dot{u}}(t) = - M^{-1} B \\underline{f}^* + M^{-1} D^T M \\underline{f}\n", + "$$\n", + "where $\\underline{u}=(u_0, u_1, \\dots, u_N)^T\\in\\mathbb{R}^{N+1}$ is the collected pointwise evaluation\n", + "of $u$ at the discretization nodes and $\\dot{u} = \\partial u / \\partial t = u_t$ is the temporal derivative.\n", + "The nodal values of the flux function $f$ results with collocation in $\\underline{f}$, since\n", + "$\\underline{f}_j=f(\\underline{u}_j)$. Moreover, we got the numerical flux $f^*=f^*(u^-, u^+)$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We will now have a short overview over the operators we used." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The **derivative matrix** $D\\in\\mathbb{R}^{(N+1)\\times (N+1)}$ mimics a spatial derivation on a\n", + "discrete level with $\\underline{f}_x \\approx D \\underline{f}$. It is defined by $D_{ij} = l_j'(\\xi_i)$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The diagonal **mass matrix** $M$ is defined by $M_{ij}=\\langle l_j, l_i\\rangle_N$ with the\n", + "numerical scalar product $\\langle \\cdot, \\cdot\\rangle_N$ defined for functions $f$ and $g$ by\n", + "$$\n", + "\\langle f, g\\rangle_N := \\int_{-1, N}^1 f(\\xi) g(\\xi) d\\xi := \\sum_{k=0}^N f(\\xi_k) g(\\xi_k) w_k.\n", + "$$\n", + "The multiplication by $M$ matches a discrete integration\n", + "$$\n", + " \\int_{-1}^1 f(\\xi) \\underline{l}(\\xi) d\\xi \\approx M \\underline{f},\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The **boundary matrix** $B=\\text{diag}([-1, 0,..., 0, 1])$ represents an evaluation of a\n", + "function at the boundaries $\\xi_0=-1$ and $\\xi_N=1$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For these operators the following property holds:\n", + "$$\n", + " M D + (M D)^T = B.\n", + "$$\n", + "This is called the summation-by-parts (SBP) property since it mimics integration by parts on a\n", + "discrete level ([Gassner (2013)](https://doi.org/10.1137/120890144))." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The explicit definitions of the operators and the construction of the 1D algorithm can be found\n", + "for instance in the tutorial introduction to DG methods\n", + "or in more detail in [Kopriva (2009)](https://link.springer.com/book/10.1007/978-90-481-2261-5)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This property shows the equivalence between the weak form and the following strong formulation\n", + "of the DGSEM.\n", + "$$\n", + "\\begin{align*}\n", + "J \\underline{\\dot{u}}(t)\n", + "&= - M^{-1} B \\underline{f}^* + M^{-1} D^T M \\underline{f}\\\\[5pt]\n", + "&= - M^{-1} B \\underline{f}^* + M^{-1} (B - MD) \\underline{f}\\\\[5pt]\n", + "&= - M^{-1} B (\\underline{f}^* - \\underline{f}) - D \\underline{f}\n", + "\\end{align*}\n", + "$$\n", + "More information about the equivalence you can find in [Kopriva, Gassner (2010)](https://doi.org/10.1007/s10915-010-9372-3)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## DGSEM with flux differencing\n", + "When using the diagonal SBP property it is possible to rewrite the application of the derivative\n", + "operator $D$ in the calculation of the volume integral into a subcell based finite volume type\n", + "differencing formulation ([Fisher, Carpenter (2013)](https://doi.org/10.1016/j.jcp.2013.06.014)).\n", + "Generalizing\n", + "$$\n", + "(D \\underline{f})_i = \\sum_j D_{i,j} \\underline{f}_j\n", + "= 2\\sum_j \\frac{1}{2} D_{i,j} (\\underline{f}_j + \\underline{f}_i)\n", + "\\eqqcolon 2\\sum_j D_{i,j} f_\\text{central}(u_i, u_j),\n", + "$$\n", + "we replace $D \\underline{f}$ in the strong form by $2D \\underline{f}_{vol}(u^-, u^+)$ with\n", + "the consistent two-point volume flux $f_{vol}$ and receive the DGSEM formulation with flux differencing\n", + "(split form DGSEM) ([Gassner, Winters, Kopriva (2016)](https://doi.org/10.1016/j.jcp.2016.09.013))." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "$$\n", + "\\begin{align*}\n", + "J \\underline{\\dot{u}}(t) &= - M^{-1} B (\\underline{f}^* - \\underline{f}) - 2D \\underline{f}_{vol}(u^-, u^+)\\\\[5pt]\n", + "&= - M^{-1} B (\\underline{f}^* - \\underline{f}_{vol}(\\underline{u}, \\underline{u})) - 2D \\underline{f}_{vol}(u^-, u^+)\\\\[5pt]\n", + "&= - M^{-1} B \\underline{f}_{surface}^* - (2D - M^{-1} B) \\underline{f}_{vol}\\\\[5pt]\n", + "&= - M^{-1} B \\underline{f}_{surface}^* - D_{split} \\underline{f}_{vol}\n", + "\\end{align*}\n", + "$$\n", + "This formulation is in a weak form type formulation and can be implemented by using the derivative\n", + "split matrix $D_{split}=(2D-M^{-1}B)$ and two different fluxes. We divide between the surface\n", + "flux $f=f_{surface}$ used for the numerical flux $f_{surface}^*$ and the already mentioned volume\n", + "flux $f_{vol}$ especially for this formulation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This formulation creates a more stable version of DGSEM, because it fulfils entropy stability.\n", + "Moreover it allows the construction of entropy conserving discretizations without relying on\n", + "exact integration. This is achieved when using a two-point entropy conserving flux function as\n", + "volume flux in the volume flux differencing formulation.\n", + "Then, the numerical surface flux can be used to control the dissipation of the discretization and to\n", + "guarantee decreasing entropy, i.e. entropy stability." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Implementation in Trixi.jl\n", + "Now, we have a look at the implementation of DGSEM with flux differencing with [Trixi.jl](https://github.com/trixi-framework/Trixi.jl)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq, Trixi" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We implement a simulation for the compressible Euler equations in 2D\n", + "$$\n", + "\\partial_t \\begin{pmatrix} \\rho \\\\ \\rho v_1 \\\\ \\rho v_2 \\\\ \\rho e \\end{pmatrix}\n", + "+ \\partial_x \\begin{pmatrix} \\rho v_1 \\\\ \\rho v_1^2 + p \\\\ \\rho v_1 v_2 \\\\ (\\rho e +p) v_1 \\end{pmatrix}\n", + "+ \\partial_y \\begin{pmatrix} \\rho v_2 \\\\ \\rho v_1 v_2 \\\\ \\rho v_2^2 + p \\\\ (\\rho e +p) v_2 \\end{pmatrix}\n", + "= \\begin{pmatrix} 0 \\\\ 0 \\\\ 0 \\\\ 0 \\end{pmatrix}\n", + "$$\n", + "for an ideal gas with ratio of specific heats $\\gamma=1.4$.\n", + "Here, $\\rho$ is the density, $v_1$, $v_2$ the velocities, $e$ the specific total energy and\n", + "$$\n", + "p = (\\gamma - 1) \\left( \\rho e - \\frac{1}{2} \\rho (v_1^2+v_2^2) \\right)\n", + "$$\n", + "the pressure." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "gamma = 1.4\n", + "equations = CompressibleEulerEquations2D(gamma)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As our initial condition we will use a weak blast wave from [Hennemann, Gassner (2020)](https://arxiv.org/abs/2008.12044).\n", + "The primitive variables are defined by\n", + "$$\n", + "\\begin{pmatrix} \\rho \\\\ v_1 \\\\ v_2 \\\\ p \\end{pmatrix}\n", + "= \\begin{pmatrix} 1.0 \\\\ 0.0 \\\\ 0.0 \\\\ 1.0 \\end{pmatrix} \\text{if } \\|x\\|_2 > 0.5,\\;\n", + "\\text{and } \\begin{pmatrix} \\rho \\\\ v_1 \\\\ v_2 \\\\ p \\end{pmatrix}\n", + "= \\begin{pmatrix} 1.1691 \\\\ 0.1882 * \\cos(\\phi) \\\\ 0.1882 * \\sin(\\phi) \\\\ 1.245 \\end{pmatrix} \\text{else}\n", + "$$\n", + "with $\\phi = \\tan^{-1}(\\frac{x_2}{x_1})$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This initial condition is implemented in Trixi.jl under the name `initial_condition_weak_blast_wave`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "initial_condition = initial_condition_weak_blast_wave" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "In Trixi.jl, flux differencing for the volume integral can be implemented with\n", + "`VolumeIntegralFluxDifferencing` using symmetric two-point volume fluxes.\n", + "First, we set up a simulation with the entropy conserving and kinetic energy preserving\n", + "flux `flux_ranocha` by [Hendrik Ranocha (2018)](https://cuvillier.de/en/shop/publications/7743)\n", + "as surface and volume flux." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We will confirm the entropy conservation property numerically." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "volume_flux = flux_ranocha # = f_vol\n", + "solver = DGSEM(polydeg=3, surface_flux=volume_flux,\n", + " volume_integral=VolumeIntegralFluxDifferencing(volume_flux))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we implement Trixi.jl's `mesh`, `semi` and `ode` in a simple framework. For more information please\n", + "have a look at the documentation, the basic tutorial introduction to DG methods\n", + "or some basic elixirs." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "coordinates_min = (-2.0, -2.0)\n", + "coordinates_max = ( 2.0, 2.0)\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=5,\n", + " n_cells_max=10_000,\n", + " periodicity=true)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " boundary_conditions=boundary_condition_periodic)\n", + "\n", + "# ODE solvers\n", + "tspan = (0.0, 0.4)\n", + "ode = semidiscretize(semi, tspan);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To analyse the entropy conservation of the approximation, we will use the analysis calllback\n", + "implemented in Trixi. It provides some information about the approximation including the entropy change." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "analysis_callback = AnalysisCallback(semi, interval=100);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We now run the simulation using `flux_ranocha` for both surface and volume flux." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n", + " ode_default_options()..., callback=analysis_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "A look at the change in entropy $\\sum \\partial S/\\partial U \\cdot U_t$ in the analysis callback\n", + "confirms that the flux is entropy conserving since the change is about machine precision." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We can plot the approximated solution at the time `t=0.4`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can use for instance the dissipative flux `flux_lax_friedrichs` as surface flux\n", + "to get an entropy stable method." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq, Trixi\n", + "\n", + "gamma = 1.4\n", + "equations = CompressibleEulerEquations2D(gamma)\n", + "\n", + "initial_condition = initial_condition_weak_blast_wave\n", + "\n", + "volume_flux = flux_ranocha # = f_vol\n", + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs,\n", + " volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n", + "\n", + "coordinates_min = (-2.0, -2.0)\n", + "coordinates_max = ( 2.0, 2.0)\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=5,\n", + " n_cells_max=10_000,\n", + " periodicity=true)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " boundary_conditions=boundary_condition_periodic)\n", + "\n", + "# ODE solvers\n", + "tspan = (0.0, 0.4)\n", + "ode = semidiscretize(semi, tspan);\n", + "\n", + "analysis_callback = AnalysisCallback(semi, interval=100);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We now run the simulation using the volume flux `flux_ranocha` and surface flux `flux_lax_friedrichs`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6,\n", + " ode_default_options()..., callback=analysis_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The change in entropy confirms the expected entropy stability." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Of course, you can use more than these two fluxes in Trixi. Here, we will give a short list\n", + "of possible fluxes for the compressible Euler equations.\n", + "For the volume flux Trixi.jl provides for example `flux_ranocha`, `flux_shima_etal`,\n", + "`flux_chandrashekar`, `flux_kennedy_gruber`.\n", + "As surface flux you can use all volume fluxes and additionally for instance `flux_lax_friedrichs`,\n", + "`flux_hll`, `flux_hllc`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/adaptive_mesh_refinement.ipynb b/previews/PR1697/tutorials/notebooks/adaptive_mesh_refinement.ipynb new file mode 100644 index 00000000000..ec3892f5dea --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/adaptive_mesh_refinement.ipynb @@ -0,0 +1,410 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 12: Adaptive mesh refinement" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Adaptive mesh refinement (AMR) is a method of adapting the resolution of the numerical method\n", + "to the solution features such as turbulent regions or shocks. In those critical regions\n", + "of the domain, we want the simulation to use elements with smaller mesh sizes compared to other\n", + "regions. This should be automatically and dynamically adapted during the run of the simulation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Implementation in Trixi.jl\n", + "In [Trixi.jl](https://github.com/trixi-framework/Trixi.jl), AMR is possible for the mesh types\n", + "`TreeMesh` and `P4estMesh`. Both meshes are organized in a tree structure\n", + "and therefore, each element can be refined independently. In Trixi.jl, AMR is restricted\n", + "to a 2:1 refinement ratio between neighbor elements. This means that the maximum resolution\n", + "difference of neighboring elements is a factor of two." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The implementation of AMR is divided into different steps. The basic refinement setting contains\n", + "an indicator and a controller. These are added to the simulation by using an AMR callback." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Indicators\n", + "An indicator estimates the current accuracy of the numerical approximation. It indicates which regions\n", + "of the domain need finer or coarser resolutions. In Trixi.jl, you can use for instance\n", + "`IndicatorLöhner` and `IndicatorHennemannGassner`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "`IndicatorLöhner` (also callable with `IndicatorLoehner`) is an interpretation and adaptation of\n", + "a FEM indicator by [Löhner (1987)](https://doi.org/10.1016/0045-7825(87)90098-3) and estimates a\n", + "weighted second derivative of a specified variable locally.\n", + "````julia\n", + "amr_indicator = IndicatorLöhner(semi, variable=variable)\n", + "````\n", + "All indicators have the parameter `variable` which is used to specify the variable for the\n", + "indicator calculation. You can use for instance `density`, `pressure` or `density_pressure`\n", + "for the compressible Euler equations. Moreover, you have the option to use simply the first\n", + "conservation variable with `first` for any equations. This might be a good choice for a starting\n", + "example." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "`IndicatorHennemannGassner`, also used as a shock-capturing indicator, was developed by\n", + "[Hennemann et al. (2021)](https://doi.org/10.1016/j.jcp.2020.109935) and is explained in detail\n", + "in the tutorial about shock-capturing. It can be constructed as follows.\n", + "````julia\n", + "amr_indicator = IndicatorHennemannGassner(semi,\n", + " alpha_max=0.5,\n", + " alpha_min=0.001,\n", + " alpha_smooth=true,\n", + " variable=variable)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Another indicator is the very basic `IndicatorMax`. It indicates the maximal value of a variable\n", + "and is therefore mostly used for verification and testing. But it might be useful for the basic\n", + "understanding of the implementation of indicators and AMR in Trixi.jl.\n", + "````julia\n", + "amr_indicator = IndicatorMax(semi, variable=variable)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Controllers\n", + "The spatial discretization into elements is tree-based for both AMR supporting mesh types `TreeMesh`\n", + "and `P4estMesh`. Thus, the higher the level in the tree the higher the level of refinement.\n", + "For instance, a mesh element of level `3` has double resolution in each direction compared to\n", + "another element with level `2`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To map specific indicator values to a desired level of refinement, Trixi.jl uses controllers.\n", + "They are build in three levels: There is a base level of refinement `base_level`, which is the\n", + "minimum allowed refinement level. Then, there is a medium level `med_level`, which corresponds\n", + "to the initial level of refinement, for indicator values above the threshold `med_threshold`\n", + "and equally, a maximal level `max_level` for values above `max_threshold`.\n", + "This variant of controller is called `ControllerThreeLevel` in Trixi.jl.\n", + "````julia\n", + "amr_controller = ControllerThreeLevel(semi, amr_indicator;\n", + " base_level=4,\n", + " med_level=5, med_threshold=0.1,\n", + " max_level=6, max_threshold=0.6)\n", + "````\n", + "You can also set `med_level=0` to use the current level as target, see the docstring of\n", + "`ControllerThreeLevel`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "An extension is `ControllerThreeLevelCombined`, which uses two different indicators.\n", + "The primary indicator works the same as the single indicator for `ControllerThreeLevel`.\n", + "The second indicator with its own maximum threshold adds the property, that the target level is set to\n", + "`max_level` additionally if this indicator's value is greater than `max_threshold_secondary`.\n", + "This is for instance used to assure that a shock has always the maximum refinement level.\n", + "````julia\n", + "amr_controller = ControllerThreeLevelCombined(semi, indicator_primary, indicator_secondary;\n", + " base_level=2,\n", + " med_level=6, med_threshold=0.0003,\n", + " max_level=8, max_threshold=0.003,\n", + " max_threshold_secondary=0.3)\n", + "````\n", + "This controller is for instance used in\n", + "[`elixir_euler_astro_jet_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_astro_jet_amr.jl)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Callback\n", + "The AMR indicator and controller are added to the simulation through the callback `AMRCallback`.\n", + "It contains a semidiscretization `semi`, the controller `amr_controller` and the parameters `interval`,\n", + "`adapt_initial_condition`, and `adapt_initial_condition_only_refine`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Adaptive mesh refinement will be performed every `interval` time steps. `adapt_initial_condition` indicates\n", + "whether the initial condition already should be adapted before the first time step. And with\n", + "`adapt_initial_condition_only_refine=true` the mesh is only refined at the beginning but not coarsened.\n", + "````julia\n", + "amr_callback = AMRCallback(semi, amr_controller,\n", + " interval=5,\n", + " adapt_initial_condition=true,\n", + " adapt_initial_condition_only_refine=true)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Exemplary simulation\n", + "Here, we want to implement a simple AMR simulation of the 2D linear advection equation for a Gaussian pulse." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "using Trixi\n", + "\n", + "advection_velocity = (0.2, -0.7)\n", + "equations = LinearScalarAdvectionEquation2D(advection_velocity)\n", + "\n", + "initial_condition = initial_condition_gauss\n", + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n", + "\n", + "coordinates_min = (-5.0, -5.0)\n", + "coordinates_max = ( 5.0, 5.0)\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4,\n", + " n_cells_max=30_000)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n", + "\n", + "\n", + "tspan = (0.0, 10.0)\n", + "ode = semidiscretize(semi, tspan);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "For the best understanding about indicators and controllers, we use the simple AMR indicator\n", + "`IndicatorMax`. As described before, it returns the maximal value of the specified variable\n", + "(here the only conserved variable). Therefore, regions with a high maximum are refined.\n", + "This is not really useful numerical application, but a nice demonstration example." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "amr_indicator = IndicatorMax(semi, variable=first)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "These values are transferred to a refinement level with the `ControllerThreeLevel`, such that\n", + "every element with maximal value greater than `0.1` is refined once and elements with maximum\n", + "above `0.6` are refined twice." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "amr_controller = ControllerThreeLevel(semi, amr_indicator,\n", + " base_level=4,\n", + " med_level=5, med_threshold=0.1,\n", + " max_level=6, max_threshold=0.6)\n", + "\n", + "amr_callback = AMRCallback(semi, amr_controller,\n", + " interval=5,\n", + " adapt_initial_condition=true,\n", + " adapt_initial_condition_only_refine=true)\n", + "\n", + "stepsize_callback = StepsizeCallback(cfl=0.9)\n", + "\n", + "callbacks = CallbackSet(amr_callback, stepsize_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Running the simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We plot the solution and add the refined mesh at the end of the simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "pd = PlotData2D(sol)\n", + "plot(pd)\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "# More examples\n", + "Trixi.jl provides many elixirs using AMR. We want to give some examples for different mesh types:\n", + "- `elixir_euler_blast_wave_amr.jl` for [`TreeMesh`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_blast_wave_amr.jl)\n", + " and [`P4estMesh`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/p4est_2d_dgsem/elixir_euler_blast_wave_amr.jl)\n", + "- [`elixir_euler_kelvin_helmholtz_instability_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_kelvin_helmholtz_instability_amr.jl) for `TreeMesh`\n", + "- [`elixir_euler_double_mach_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/p4est_2d_dgsem/elixir_euler_double_mach_amr.jl) for `P4estMesh`" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Animations of more interesting and complicated AMR simulations can be found below and on Trixi.jl's youtube channel\n", + "[\"Trixi Framework\"](https://www.youtube.com/channel/UCpd92vU2HjjTPup-AIN0pkg)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "First, we give a [purely hyperbolic simulation of a Sedov blast wave with self-gravity](https://www.youtube.com/watch?v=dxgzgteJdOA).\n", + "This simulation uses the mesh type `TreeMesh` as we did and the AMR indicator `IndicatorHennemannGassner`.\n", + "\n", + " \n", + "
\n", + "\n", + "Source: Trixi.jl's YouTube channel [`Trixi Framework`](https://www.youtube.com/channel/UCpd92vU2HjjTPup-AIN0pkg)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The next example is a numerical simulation of an [ideal MHD rotor on an unstructured AMR mesh](https://www.youtube.com/watch?v=Iei7e9oQ0hs).\n", + "The used mesh type is a `P4estMesh`.\n", + "\n", + " \n", + "
\n", + "\n", + "Source: Trixi.jl's YouTube channel [`Trixi Framework`](https://www.youtube.com/channel/UCpd92vU2HjjTPup-AIN0pkg)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For more information, please have a look at the respective links." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/adding_new_parabolic_terms.ipynb b/previews/PR1697/tutorials/notebooks/adding_new_parabolic_terms.ipynb new file mode 100644 index 00000000000..5d9b704f78b --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/adding_new_parabolic_terms.ipynb @@ -0,0 +1,309 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 11: Adding new parabolic terms" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This demo illustrates the steps involved in adding new parabolic terms for the scalar\n", + "advection equation. In particular, we will add an anisotropic diffusion. We begin by\n", + "defining the hyperbolic (advection) part of the advection-diffusion equation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "using Trixi\n", + "\n", + "\n", + "advection_velocity = (1.0, 1.0)\n", + "equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Define a new parabolic equation type\n", + "\n", + "Next, we define a 2D parabolic diffusion term type. This is similar to `LaplaceDiffusion2D`\n", + "except that the `diffusivity` field refers to a spatially constant diffusivity matrix now. Note that\n", + "`ConstantAnisotropicDiffusion2D` has a field for `equations_hyperbolic`. It is useful to have\n", + "information about the hyperbolic system available to the parabolic part so that we can reuse\n", + "functions defined for hyperbolic equations (such as `varnames`)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "struct ConstantAnisotropicDiffusion2D{E, T} <: Trixi.AbstractEquationsParabolic{2, 1}\n", + " diffusivity::T\n", + " equations_hyperbolic::E\n", + "end\n", + "\n", + "varnames(variable_mapping, equations_parabolic::ConstantAnisotropicDiffusion2D) =\n", + " varnames(variable_mapping, equations_parabolic.equations_hyperbolic)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we define the viscous flux function. We assume that the mixed hyperbolic-parabolic system\n", + "is of the form\n", + "$$\n", + "\\partial_t u(t,x) + \\partial_x (f_1(u) - g_1(u, \\nabla u))\n", + " + \\partial_y (f_2(u) - g_2(u, \\nabla u)) = 0\n", + "$$\n", + "where $f_1(u)$, $f_2(u)$ are the hyperbolic fluxes and $g_1(u, \\nabla u)$, $g_2(u, \\nabla u)$ denote\n", + "the viscous fluxes. For anisotropic diffusion, the viscous fluxes are the first and second components\n", + "of the matrix-vector product involving `diffusivity` and the gradient vector.\n", + "\n", + "Here, we specialize the flux to our new parabolic equation type `ConstantAnisotropicDiffusion2D`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function Trixi.flux(u, gradients, orientation::Integer, equations_parabolic::ConstantAnisotropicDiffusion2D)\n", + " @unpack diffusivity = equations_parabolic\n", + " dudx, dudy = gradients\n", + " if orientation == 1\n", + " return SVector(diffusivity[1, 1] * dudx + diffusivity[1, 2] * dudy)\n", + " else # if orientation == 2\n", + " return SVector(diffusivity[2, 1] * dudx + diffusivity[2, 2] * dudy)\n", + " end\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Defining boundary conditions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl's implementation of parabolic terms discretizes both the gradient and divergence\n", + "using weak formulation. In other words, we discretize the system\n", + "$$\n", + "\\begin{aligned}\n", + "\\bm{q} &= \\nabla u \\\\\n", + "\\bm{\\sigma} &= \\begin{pmatrix} g_1(u, \\bm{q}) \\\\ g_2(u, \\bm{q}) \\end{pmatrix} \\\\\n", + "\\text{viscous contribution } &= \\nabla \\cdot \\bm{\\sigma}\n", + "\\end{aligned}\n", + "$$\n", + "\n", + "Boundary data must be specified for all spatial derivatives, e.g., for both the gradient\n", + "equation $\\bm{q} = \\nabla u$ and the divergence of the viscous flux\n", + "$\\nabla \\cdot \\bm{\\sigma}$. We account for this by introducing internal `Gradient`\n", + "and `Divergence` types which are used to dispatch on each type of boundary condition.\n", + "\n", + "As an example, let us introduce a Dirichlet boundary condition with constant boundary data." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "struct BoundaryConditionConstantDirichlet{T <: Real}\n", + " boundary_value::T\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This boundary condition contains only the field `boundary_value`, which we assume to be some\n", + "real-valued constant which we will impose as the Dirichlet data on the boundary.\n", + "\n", + "Boundary conditions have generally been defined as \"callable structs\" (also known as \"functors\").\n", + "For each boundary condition, we need to specify the appropriate boundary data to return for both\n", + "the `Gradient` and `Divergence`. Since the gradient is operating on the solution `u`, the boundary\n", + "data should be the value of `u`, and we can directly impose Dirichlet data." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,\n", + " x, t, operator_type::Trixi.Gradient,\n", + " equations_parabolic::ConstantAnisotropicDiffusion2D)\n", + " return boundary_condition.boundary_value\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "While the gradient acts on the solution `u`, the divergence acts on the viscous flux $\\bm{\\sigma}$.\n", + "Thus, we have to supply boundary data for the `Divergence` operator that corresponds to $\\bm{\\sigma}$.\n", + "However, we've already imposed boundary data on `u` for a Dirichlet boundary condition, and imposing\n", + "boundary data for $\\bm{\\sigma}$ might overconstrain our problem.\n", + "\n", + "Thus, for the `Divergence` boundary data under a Dirichlet boundary condition, we simply return\n", + "`flux_inner`, which is boundary data for $\\bm{\\sigma}$ computed using the \"inner\" or interior solution.\n", + "This way, we supply boundary data for the divergence operation without imposing any additional conditions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "@inline function (boundary_condition::BoundaryConditionConstantDirichlet)(flux_inner, u_inner, normal::AbstractVector,\n", + " x, t, operator_type::Trixi.Divergence,\n", + " equations_parabolic::ConstantAnisotropicDiffusion2D)\n", + " return flux_inner\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "### A note on the choice of gradient variables\n", + "\n", + "It is often simpler to transform the solution variables (and solution gradients) to another set of\n", + "variables prior to computing the viscous fluxes (see `CompressibleNavierStokesDiffusion2D`\n", + "for an example of this). If this is done, then the boundary condition for the `Gradient` operator\n", + "should be modified accordingly as well.\n", + "\n", + "## Putting things together\n", + "\n", + "Finally, we can instantiate our new parabolic equation type, define boundary conditions,\n", + "and run a simulation. The specific anisotropic diffusion matrix we use produces more\n", + "dissipation in the direction $(1, -1)$ as an isotropic diffusion.\n", + "\n", + "For boundary conditions, we impose that $u=1$ on the left wall, $u=2$ on the bottom\n", + "wall, and $u = 0$ on the outflow walls. The initial condition is taken to be $u = 0$.\n", + "Note that we use `BoundaryConditionConstantDirichlet` only for the parabolic boundary\n", + "conditions, since we have not defined its behavior for the hyperbolic part." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi: SMatrix\n", + "diffusivity = 5.0e-2 * SMatrix{2, 2}([2 -1; -1 2])\n", + "equations_parabolic = ConstantAnisotropicDiffusion2D(diffusivity, equations_hyperbolic);\n", + "\n", + "boundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1.0)),\n", + " y_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(2.0)),\n", + " y_pos = boundary_condition_do_nothing,\n", + " x_pos = boundary_condition_do_nothing)\n", + "\n", + "boundary_conditions_parabolic = (; x_neg = BoundaryConditionConstantDirichlet(1.0),\n", + " y_neg = BoundaryConditionConstantDirichlet(2.0),\n", + " y_pos = BoundaryConditionConstantDirichlet(0.0),\n", + " x_pos = BoundaryConditionConstantDirichlet(0.0));\n", + "\n", + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n", + "coordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))\n", + "coordinates_max = ( 1.0, 1.0) # maximum coordinates (max(x), max(y))\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4,\n", + " periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure\n", + "\n", + "initial_condition = (x, t, equations) -> SVector(0.0)\n", + "\n", + "semi = SemidiscretizationHyperbolicParabolic(mesh,\n", + " (equations_hyperbolic, equations_parabolic),\n", + " initial_condition, solver;\n", + " boundary_conditions=(boundary_conditions_hyperbolic,\n", + " boundary_conditions_parabolic))\n", + "\n", + "tspan = (0.0, 2.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "callbacks = CallbackSet(SummaryCallback())\n", + "time_int_tol = 1.0e-6\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,\n", + " ode_default_options()..., callback=callbacks);\n", + "\n", + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/adding_new_scalar_equations.ipynb b/previews/PR1697/tutorials/notebooks/adding_new_scalar_equations.ipynb new file mode 100644 index 00000000000..69fa50f5d65 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/adding_new_scalar_equations.ipynb @@ -0,0 +1,451 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 8: Adding a new scalar conservation law" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "If you want to use Trixi.jl for your own research, you might be interested in\n", + "a new physics model that's not already included in Trixi.jl. In this tutorial,\n", + "we will implement the cubic conservation law\n", + "$$\n", + "\\partial_t u(t,x) + \\partial_x u(t,x)^3 = 0\n", + "$$\n", + "in a periodic domain in one space dimension. In Trixi.jl, such a mathematical model\n", + "is encoded as a subtype of `Trixi.AbstractEquations`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Basic setup" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi\n", + "\n", + "struct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,\n", + " 1 #= number of primary variables, i.e. scalar =#};\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We create `CubicEquation` as an empty `struct` since we do not use any parameters\n", + "for this equation. Other models could bundle arbitrary parameters, e.g., the\n", + "ideal gas constant for the compressible Euler equations." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we define the physical flux `f(u) = u^3` using the calling structure\n", + "used in Trixi.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "Trixi.flux(u, orientation, equation::CubicEquation) = u.^3\n", + "Trixi.varnames(_, ::CubicEquation) = (\"scalar\",)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "In Trixi.jl, the conserved variables `u` are usually passed as `SVector`s of variables\n", + "at a single physical location. Hence, we must use `u.^3` instead of the scalar\n", + "operation `u^3`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "That's already enough to run a simple simulation with a standard DGSEM discretization\n", + "using the non-dissipative central flux at interfaces." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "\n", + "# Create a simulation setup\n", + "equation = CubicEquation()\n", + "\n", + "initial_condition_sine(x, t, equation::CubicEquation) = SVector(sinpi(x[1]))\n", + "\n", + "mesh = TreeMesh(-1.0, 1.0, # min/max coordinates\n", + " initial_refinement_level=4,\n", + " n_cells_max=10^4)\n", + "\n", + "solver = DGSEM(3 #= polynomial degree =#, flux_central)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We wrap the return value of the `initial_condition_sine` inside an `SVector` since that's the approach\n", + "used in Trixi.jl also for systems of equations. We need to index the spatial coordinate `x[1]`,\n", + "since it is an `SVector` with one component. In multiple space dimensions, all spatial coordinates\n", + "are passed together." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we create an `ODEProblem` from the SciML/DifferentialEquations ecosystem.\n", + "We can solve this ODE numerically using any time integration method,\n", + "e.g., `SSPRK43` from [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl).\n", + "Before, we set up a callback to summarize the simulation setup." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# Create ODE problem with given time span\n", + "tspan = (0.0, 0.09)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "summary_callback = SummaryCallback()\n", + "callbacks = CallbackSet(summary_callback)\n", + "\n", + "# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks\n", + "sol = solve(ode, SSPRK43();\n", + " ode_default_options()..., callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "That's it, you ran your first simulation using your new equation with Trixi.jl! Now, we can plot\n", + "the solution at the final time using Plots.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You can already see that discontinuities will develop and oscillations start to\n", + "occur around steep parts of the wave. That's expected from our central discretization.\n", + "To avoid these issues, we need to use dissipative numerical fluxes (approximate\n", + "Riemann solvers) at interfaces." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Advanced setup" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Thus, we add a Godunov's flux for our cubic equation. That is easy for this equation\n", + "since the wave speed `f'(u) = 3u^2` is always non-negative." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Let's run the example again but with a dissipative numerical flux at interfaces.\n", + "`remake` will recreate the semidiscretization we used before and only change\n", + "selected parameters, in this case the `solver`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# A new setup with dissipation\n", + "semi = remake(semi, solver=DGSEM(3, flux_godunov))\n", + "ode = semidiscretize(semi, tspan)\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot!(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You can see that there are fewer oscillations, in particular around steep edges.\n", + "Now let's increase the final time (and also the spatial resolution)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)\n", + "semi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))\n", + "ode = semidiscretize(semi, (0.0, 0.5) #= tspan =#)\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You can observe that nonclassical shocks develop and are stable under grid refinement,\n", + "e.g. for `initial_refinement_level=12`. In this case, these nonclassical shocks\n", + "can be avoided by using an entropy-dissipative semidiscretization. Thus, we need\n", + "to define an entropy-conservative numerical flux" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)\n", + " return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "and use a `VolumeIntegralFluxDifferencing` instead of the standard\n", + "`VolumeIntegralWeakForm` in the DGSEM." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# Let's use a provably entropy-dissipative semidiscretization\n", + "semi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))\n", + "ode = semidiscretize(semi, (0.0, 0.5))\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...);\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Possible next steps could be\n", + "- to define `Trixi.max_abs_speeds(u, equations::CubicEquation) = 3 * u[1]^2`\n", + " to use CFL-based time step control via a `StepsizeCallback`\n", + "- to define quantities of interest like `Trixi.entropy(u, equations::CubicEquation) = u[1]^2`\n", + " and integrate them in a simulation using the `AnalysisCallback`\n", + "- to experiment with shock-capturing volume integrals `VolumeIntegralShockCapturingHG`\n", + " and adaptive mesh refinement `AMRCallback`" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For further reading, Trixi.jl provides another example on adding a scalar equation. In the\n", + "[elixir about the KPP problem](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_kpp.jl),\n", + "the 2D scalar \"KPP equation\" from [Kurganov, Petrova, Popov (2007)](https://doi.org/10.1137/040614189) is\n", + "implemented." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Summary of the code" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To sum up, here is the complete code that we used (without the callbacks since these create a\n", + "lot of unnecessary output in the doctests of this tutorial).\n", + "In addition, we create the `struct` inside the new module `CubicConservationLaw`. That\n", + "ensures that we can re-create `struct`s defined therein without having to restart Julia." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# Define new physics\n", + "module CubicConservationLaw\n", + "\n", + "using Trixi\n", + "\n", + "struct CubicEquation <: Trixi.AbstractEquations{1 #= number of spatial dimensions =#,\n", + " 1 #= number of primary variables, i.e. scalar =#}\n", + "end\n", + "\n", + "@inline Trixi.flux(u, orientation, equation::CubicEquation) = u.^3\n", + "Trixi.varnames(_, ::CubicEquation) = (\"scalar\",)\n", + "\n", + "@inline Trixi.flux_godunov(u_ll, u_rr, orientation, equation::CubicEquation) = flux(u_ll, orientation, equation)\n", + "@inline function Trixi.flux_ec(u_ll, u_rr, orientation, equation::CubicEquation)\n", + " return SVector(0.25 * (u_ll[1]^3 + u_ll[1]^2 * u_rr[1] + u_ll[1] * u_rr[1]^2 + u_rr[1]^3))\n", + "end\n", + "\n", + "end # module\n", + "\n", + "\n", + "# Create a simulation setup\n", + "import .CubicConservationLaw\n", + "using Trixi\n", + "using OrdinaryDiffEq\n", + "using Plots\n", + "\n", + "equation = CubicConservationLaw.CubicEquation()\n", + "\n", + "initial_condition_sine(x, t, equation::CubicConservationLaw.CubicEquation) = SVector(sinpi(x[1]))\n", + "\n", + "mesh = TreeMesh(-1.0, 1.0, # min/max coordinates\n", + " initial_refinement_level=4,\n", + " n_cells_max=10^4)\n", + "\n", + "solver = DGSEM(3 #= polynomial degree =#, flux_central)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n", + "\n", + "# Create ODE problem with given time span\n", + "tspan = (0.0, 0.1)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "# OrdinaryDiffEq's `solve` method evolves the solution in time and executes the passed callbacks\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot(sol)\n", + "\n", + "\n", + "# A new setup with dissipation\n", + "semi = remake(semi, solver=DGSEM(3, flux_godunov))\n", + "ode = semidiscretize(semi, tspan)\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot!(sol)\n", + "\n", + "\n", + "# A larger final time: Nonclassical shocks develop (you can even increase the refinement to 12)\n", + "semi = remake(semi, mesh=TreeMesh(-1.0, 1.0, initial_refinement_level=8, n_cells_max=10^5))\n", + "ode = semidiscretize(semi, (0.0, 0.5))\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot(sol)\n", + "\n", + "\n", + "# Let's use a provably entropy-dissipative semidiscretization\n", + "semi = remake(semi, solver=DGSEM(3, flux_godunov, VolumeIntegralFluxDifferencing(flux_ec)))\n", + "ode = semidiscretize(semi, (0.0, 0.5))\n", + "sol = solve(ode, SSPRK43(); ode_default_options()...)\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/adding_nonconservative_equation.ipynb b/previews/PR1697/tutorials/notebooks/adding_nonconservative_equation.ipynb new file mode 100644 index 00000000000..4079de43271 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/adding_nonconservative_equation.ipynb @@ -0,0 +1,455 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 9: Adding a non-conservative equation" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "If you want to use Trixi.jl for your own research, you might be interested in\n", + "a new physics model that is not present in Trixi.jl. In this tutorial,\n", + "we will implement the nonconservative linear advection equation in a periodic domain\n", + "$$\n", + "\\left\\{\n", + "\\begin{aligned}&\\partial_t u(t,x) + a(x) \\partial_x u(t,x) = 0 \\\\\n", + "&u(0,x)=\\sin(x) \\\\\n", + "&u(t,-\\pi)=u(t,\\pi)\n", + "\\end{aligned}\n", + "\\right.\n", + "$$\n", + "where $a(x) = 2 + \\cos(x)$. The analytic solution is\n", + "$$\n", + "u(t,x)=-\\sin \\left(2 \\tan ^{-1}\\left(\\sqrt{3} \\tan \\left(\\frac{\\sqrt{3} t}{2}-\\tan ^{-1}\\left(\\frac{1}{\\sqrt{3}}\\tan \\left(\\frac{x}{2}\\right)\\right)\\right)\\right)\\right)\n", + "$$\n", + "In Trixi.jl, such a mathematical model\n", + "is encoded as a subtype of `Trixi.AbstractEquations`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Basic setup" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Since there is no native support for variable coefficients, we need to transform the PDE to the following system:\n", + "$$\n", + "\\left\\{\n", + "\\begin{aligned}&\\partial_t \\begin{pmatrix}u(t,x)\\\\a(t,x) \\end{pmatrix} +\\begin{pmatrix} a(t,x) \\partial_x u(t,x) \\\\ 0 \\end{pmatrix} = 0 \\\\\n", + "&u(0,x)=\\sin(x) \\\\\n", + "&a(0,x)=2+\\cos(x) \\\\\n", + "&u(t,-\\pi)=u(t,\\pi)\n", + "\\end{aligned}\n", + "\\right.\n", + "$$" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# Define new physics\n", + "using Trixi\n", + "using Trixi: AbstractEquations, get_node_vars\n", + "import Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,\n", + " have_nonconservative_terms\n", + "\n", + "# Since there is no native support for variable coefficients, we use two\n", + "# variables: one for the basic unknown `u` and another one for the coefficient `a`\n", + "struct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,\n", + " 2 #= two variables (u,a) =#}\n", + "end\n", + "\n", + "varnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = (\"scalar\", \"advection_velocity\")\n", + "\n", + "default_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()\n", + "\n", + "\n", + "# The conservative part of the flux is zero\n", + "flux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)\n", + "\n", + "# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation\n", + "function max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)\n", + " _, advection_velocity_ll = u_ll\n", + " _, advection_velocity_rr = u_rr\n", + "\n", + " return max(abs(advection_velocity_ll), abs(advection_velocity_rr))\n", + "end\n", + "\n", + "\n", + "# We use nonconservative terms\n", + "have_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()\n", + "\n", + "# This \"nonconservative numerical flux\" implements the nonconservative terms.\n", + "# In general, nonconservative terms can be written in the form\n", + "# g(u) ∂ₓ h(u)\n", + "# Thus, a discrete difference approximation of this nonconservative term needs\n", + "# - `u mine`: the value of `u` at the current position (for g(u))\n", + "# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))\n", + "function flux_nonconservative(u_mine, u_other, orientation,\n", + " equations::NonconservativeLinearAdvectionEquation)\n", + " _, advection_velocity = u_mine\n", + " scalar, _ = u_other\n", + "\n", + " return SVector(advection_velocity * scalar, zero(scalar))\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The implementation of nonconservative terms uses a single \"nonconservative flux\"\n", + "function `flux_nonconservative`. It will basically be applied in a loop of the\n", + "form\n", + "```julia\n", + "du_m(D, u) = sum(D[m, l] * flux_nonconservative(u[m], u[l], 1, equations)) # orientation 1: x\n", + "```\n", + "where `D` is the derivative matrix and `u` contains the nodal solution values." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can run a simple simulation using a DGSEM discretization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# Create a simulation setup\n", + "using Trixi\n", + "using OrdinaryDiffEq\n", + "\n", + "equation = NonconservativeLinearAdvectionEquation()\n", + "\n", + "# You can derive the exact solution for this setup using the method of\n", + "# characteristics\n", + "function initial_condition_sine(x, t, equation::NonconservativeLinearAdvectionEquation)\n", + " x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))\n", + " scalar = sin(x0)\n", + " advection_velocity = 2 + cos(x[1])\n", + " SVector(scalar, advection_velocity)\n", + "end\n", + "\n", + "# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries\n", + "mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n", + " initial_refinement_level=4, n_cells_max=10^4)\n", + "\n", + "# Create a DGSEM solver with polynomials of degree `polydeg`\n", + "# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`\n", + "# as `surface_flux` and `volume_flux` when working with nonconservative terms\n", + "volume_flux = (flux_central, flux_nonconservative)\n", + "surface_flux = (flux_lax_friedrichs, flux_nonconservative)\n", + "solver = DGSEM(polydeg=3, surface_flux=surface_flux,\n", + " volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n", + "\n", + "# Setup the spatial semidiscretization containing all ingredients\n", + "semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n", + "\n", + "# Create an ODE problem with given time span\n", + "tspan = (0.0, 1.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "# Set up some standard callbacks summarizing the simulation setup and computing\n", + "# errors of the numerical solution\n", + "summary_callback = SummaryCallback()\n", + "analysis_callback = AnalysisCallback(semi, interval=50)\n", + "callbacks = CallbackSet(summary_callback, analysis_callback)\n", + "\n", + "# OrdinaryDiffEq's `solve` method evolves the solution in time and executes\n", + "# the passed callbacks\n", + "sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n", + " save_everystep=false, callback=callbacks)\n", + "\n", + "# Print the timer summary\n", + "summary_callback()\n", + "\n", + "# Plot the numerical solution at the final time\n", + "using Plots: plot\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You see a plot of the final solution." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We can check whether everything fits together by refining the grid and comparing\n", + "the numerical errors. First, we look at the error using the grid resolution\n", + "above." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "error_1 = analysis_callback(sol).l2 |> first" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we increase the grid resolution by one refinement level and run the\n", + "simulation again." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n", + " initial_refinement_level=5, n_cells_max=10^4)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n", + "\n", + "tspan = (0.0, 1.0)\n", + "ode = semidiscretize(semi, tspan);\n", + "\n", + "summary_callback = SummaryCallback()\n", + "analysis_callback = AnalysisCallback(semi, interval=50)\n", + "callbacks = CallbackSet(summary_callback, analysis_callback);\n", + "\n", + "sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n", + " save_everystep=false, callback=callbacks);\n", + "summary_callback()" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "error_2 = analysis_callback(sol).l2 |> first" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "error_1 / error_2" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As expected, the new error is roughly reduced by a factor of 16, corresponding\n", + "to an experimental order of convergence of 4 (for polynomials of degree 3)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Summary of the code" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Here is the complete code that we used (without the callbacks since these\n", + "create a lot of unnecessary output in the doctests of this tutorial).\n", + "In addition, we create the `struct` inside the new module `NonconservativeLinearAdvection`.\n", + "That ensures that we can re-create `struct`s defined therein without having to\n", + "restart Julia." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Define new physics" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "module NonconservativeLinearAdvection\n", + "\n", + "using Trixi\n", + "using Trixi: AbstractEquations, get_node_vars\n", + "import Trixi: varnames, default_analysis_integrals, flux, max_abs_speed_naive,\n", + " have_nonconservative_terms\n", + "\n", + "# Since there is not yet native support for variable coefficients, we use two\n", + "# variables: one for the basic unknown `u` and another one for the coefficient `a`\n", + "struct NonconservativeLinearAdvectionEquation <: AbstractEquations{1 #= spatial dimension =#,\n", + " 2 #= two variables (u,a) =#}\n", + "end\n", + "\n", + "varnames(::typeof(cons2cons), ::NonconservativeLinearAdvectionEquation) = (\"scalar\", \"advection_velocity\")\n", + "\n", + "default_analysis_integrals(::NonconservativeLinearAdvectionEquation) = ()\n", + "\n", + "\n", + "# The conservative part of the flux is zero\n", + "flux(u, orientation, equation::NonconservativeLinearAdvectionEquation) = zero(u)\n", + "\n", + "# Calculate maximum wave speed for local Lax-Friedrichs-type dissipation\n", + "function max_abs_speed_naive(u_ll, u_rr, orientation::Integer, ::NonconservativeLinearAdvectionEquation)\n", + " _, advection_velocity_ll = u_ll\n", + " _, advection_velocity_rr = u_rr\n", + "\n", + " return max(abs(advection_velocity_ll), abs(advection_velocity_rr))\n", + "end\n", + "\n", + "\n", + "# We use nonconservative terms\n", + "have_nonconservative_terms(::NonconservativeLinearAdvectionEquation) = Trixi.True()\n", + "\n", + "# This \"nonconservative numerical flux\" implements the nonconservative terms.\n", + "# In general, nonconservative terms can be written in the form\n", + "# g(u) ∂ₓ h(u)\n", + "# Thus, a discrete difference approximation of this nonconservative term needs\n", + "# - `u mine`: the value of `u` at the current position (for g(u))\n", + "# - `u_other`: the values of `u` in a neighborhood of the current position (for ∂ₓ h(u))\n", + "function flux_nonconservative(u_mine, u_other, orientation,\n", + " equations::NonconservativeLinearAdvectionEquation)\n", + " _, advection_velocity = u_mine\n", + " scalar, _ = u_other\n", + "\n", + " return SVector(advection_velocity * scalar, zero(scalar))\n", + "end\n", + "\n", + "end # module\n", + "\n", + "\n", + "\n", + "# Create a simulation setup\n", + "import .NonconservativeLinearAdvection\n", + "using Trixi\n", + "using OrdinaryDiffEq\n", + "\n", + "equation = NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation()\n", + "\n", + "# You can derive the exact solution for this setup using the method of\n", + "# characteristics\n", + "function initial_condition_sine(x, t, equation::NonconservativeLinearAdvection.NonconservativeLinearAdvectionEquation)\n", + " x0 = -2 * atan(sqrt(3) * tan(sqrt(3) / 2 * t - atan(tan(x[1] / 2) / sqrt(3))))\n", + " scalar = sin(x0)\n", + " advection_velocity = 2 + cos(x[1])\n", + " SVector(scalar, advection_velocity)\n", + "end\n", + "\n", + "# Create a uniform mesh in 1D in the interval [-π, π] with periodic boundaries\n", + "mesh = TreeMesh(-Float64(π), Float64(π), # min/max coordinates\n", + " initial_refinement_level=4, n_cells_max=10^4)\n", + "\n", + "# Create a DGSEM solver with polynomials of degree `polydeg`\n", + "# Remember to pass a tuple of the form `(conservative_flux, nonconservative_flux)`\n", + "# as `surface_flux` and `volume_flux` when working with nonconservative terms\n", + "volume_flux = (flux_central, NonconservativeLinearAdvection.flux_nonconservative)\n", + "surface_flux = (flux_lax_friedrichs, NonconservativeLinearAdvection.flux_nonconservative)\n", + "solver = DGSEM(polydeg=3, surface_flux=surface_flux,\n", + " volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n", + "\n", + "# Setup the spatial semidiscretization containing all ingredients\n", + "semi = SemidiscretizationHyperbolic(mesh, equation, initial_condition_sine, solver)\n", + "\n", + "# Create an ODE problem with given time span\n", + "tspan = (0.0, 1.0)\n", + "ode = semidiscretize(semi, tspan);\n", + "\n", + "# Set up some standard callbacks summarizing the simulation setup and computing\n", + "# errors of the numerical solution\n", + "summary_callback = SummaryCallback()\n", + "analysis_callback = AnalysisCallback(semi, interval=50)\n", + "callbacks = CallbackSet(summary_callback, analysis_callback);\n", + "\n", + "# OrdinaryDiffEq's `solve` method evolves the solution in time and executes\n", + "# the passed callbacks\n", + "sol = solve(ode, Tsit5(), abstol=1.0e-6, reltol=1.0e-6,\n", + " save_everystep=false);\n", + "\n", + "# Plot the numerical solution at the final time\n", + "using Plots: plot\n", + "plot(sol);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/custom_semidiscretization.ipynb b/previews/PR1697/tutorials/notebooks/custom_semidiscretization.ipynb new file mode 100644 index 00000000000..f2aa3de1411 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/custom_semidiscretization.ipynb @@ -0,0 +1,673 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 17: Custom semidiscretizations" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "As described in the overview section,\n", + "semidiscretizations are high-level descriptions of spatial discretizations\n", + "in Trixi.jl. Trixi.jl's main focus is on hyperbolic conservation\n", + "laws represented in a `SemidiscretizationHyperbolic`.\n", + "Hyperbolic-parabolic problems based on the advection-diffusion equation or\n", + "the compressible Navier-Stokes equations can be represented in a\n", + "`SemidiscretizationHyperbolicParabolic`. This is described in the\n", + "basic tutorial on parabolic terms and its extension to\n", + "custom parabolic terms.\n", + "In this tutorial, we will describe how these semidiscretizations work and how\n", + "they can be used to create custom semidiscretizations involving also other tasks." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Overview of the right-hand side evaluation" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The semidiscretizations provided by Trixi.jl are set up to create `ODEProblem`s from the\n", + "[SciML ecosystem for ordinary differential equations](https://diffeq.sciml.ai/latest/).\n", + "In particular, a spatial semidiscretization can be wrapped in an ODE problem\n", + "using `semidiscretize`, which returns an `ODEProblem`. This `ODEProblem`\n", + "bundles an initial condition, a right-hand side (RHS) function, the time span,\n", + "and possible parameters. The `ODEProblem`s created by Trixi.jl use the semidiscretization\n", + "passed to `semidiscretize` as a parameter.\n", + "For a `SemidiscretizationHyperbolic`, the `ODEProblem` wraps\n", + "`Trixi.rhs!` as ODE RHS.\n", + "For a `SemidiscretizationHyperbolicParabolic`, Trixi.jl\n", + "uses a `SplitODEProblem` combining `Trixi.rhs_parabolic!` for the\n", + "(potentially) stiff part and `Trixi.rhs!` for the other part." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Standard Trixi.jl setup" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "In this tutorial, we will consider the linear advection equation\n", + "with source term\n", + "$$\n", + "\\partial_t u(t,x) + \\partial_x u(t,x) = -\\exp(-t) \\sin\\bigl(\\pi (x - t) \\bigr)\n", + "$$\n", + "with periodic boundary conditions in the domain `[-1, 1]` as a\n", + "model problem.\n", + "The initial condition is\n", + "$$\n", + "u(0,x) = \\sin(\\pi x).\n", + "$$\n", + "The source term results in some damping and the analytical solution\n", + "$$\n", + "u(t,x) = \\exp(-t) \\sin\\bigl(\\pi (x - t) \\bigr).\n", + "$$\n", + "First, we discretize this equation using the standard functionality\n", + "of Trixi.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq, Plots" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The linear scalar advection equation is already implemented in\n", + "Trixi.jl as `LinearScalarAdvectionEquation1D`. We construct\n", + "it with an advection velocity `1.0`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "equations = LinearScalarAdvectionEquation1D(1.0)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we use a standard `DGSEM` solver." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(polydeg = 3)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We create a simple `TreeMesh` in 1D." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "coordinates_min = (-1.0,)\n", + "coordinates_max = (+1.0,)\n", + "mesh = TreeMesh(coordinates_min, coordinates_max;\n", + " initial_refinement_level = 4,\n", + " n_cells_max = 10^4,\n", + " periodicity = true)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We wrap everything in in a semidiscretization and pass the source\n", + "terms as a standard Julia function. Please note that Trixi.jl uses\n", + "`SVector`s from\n", + "[StaticArrays.jl](https://github.com/JuliaArrays/StaticArrays.jl)\n", + "to store the conserved variables `u`. Thus, the return value of the\n", + "source terms must be wrapped in an `SVector` - even if we consider\n", + "just a scalar problem." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function initial_condition(x, t, equations)\n", + " return SVector(exp(-t) * sinpi(x[1] - t))\n", + "end\n", + "\n", + "function source_terms_standard(u, x, t, equations)\n", + " return -initial_condition(x, t, equations)\n", + "end\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition,\n", + " solver;\n", + " source_terms = source_terms_standard)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can create the `ODEProblem`, solve the resulting ODE\n", + "using a time integration method from\n", + "[OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl),\n", + "and visualize the numerical solution at the final time using\n", + "[Plots.jl](https://github.com/JuliaPlots/Plots.jl)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "tspan = (0.0, 3.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "sol = solve(ode, RDPK3SpFSAL49(); ode_default_options()...)\n", + "\n", + "plot(sol; label = \"numerical sol.\", legend = :topright)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We can also plot the analytical solution for comparison.\n", + "Since Trixi.jl uses `SVector`s for the variables, we take their `first`\n", + "(and only) component to get the scalar value for manual plotting." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "let\n", + " x = range(-1.0, 1.0; length = 200)\n", + " plot!(x, first.(initial_condition.(x, sol.t[end], equations)),\n", + " label = \"analytical sol.\", linestyle = :dash, legend = :topright)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We can also add the initial condition to the plot." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "plot!(sol.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You can of course also use some\n", + "[callbacks](https://trixi-framework.github.io/Trixi.jl/stable/callbacks/)\n", + "provided by Trixi.jl as usual." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "summary_callback = SummaryCallback()\n", + "analysis_interval = 100\n", + "analysis_callback = AnalysisCallback(semi; interval = analysis_interval)\n", + "alive_callback = AliveCallback(; analysis_interval)\n", + "callbacks = CallbackSet(summary_callback,\n", + " analysis_callback,\n", + " alive_callback)\n", + "\n", + "sol = solve(ode, RDPK3SpFSAL49();\n", + " ode_default_options()..., callback = callbacks)\n", + "summary_callback()" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Using a custom ODE right-hand side function" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we will solve the same problem but use our own ODE RHS function.\n", + "To demonstrate this, we will artificially create a global variable\n", + "containing the current time of the simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "const GLOBAL_TIME = Ref(0.0)\n", + "\n", + "function source_terms_custom(u, x, t, equations)\n", + " t = GLOBAL_TIME[]\n", + " return -initial_condition(x, t, equations)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we create our own RHS function to update the global time of\n", + "the simulation before calling the RHS function from Trixi.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function rhs_source_custom!(du_ode, u_ode, semi, t)\n", + " GLOBAL_TIME[] = t\n", + " Trixi.rhs!(du_ode, u_ode, semi, t)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we create an `ODEProblem` manually copying over the data from\n", + "the one we got from `semidiscretize` earlier." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "ode_source_custom = ODEProblem(rhs_source_custom!,\n", + " ode.u0,\n", + " ode.tspan,\n", + " ode.p #= semi =#)\n", + "sol_source_custom = solve(ode_source_custom, RDPK3SpFSAL49();\n", + " ode_default_options()...)\n", + "\n", + "plot(sol_source_custom; label = \"numerical sol.\")\n", + "let\n", + " x = range(-1.0, 1.0; length = 200)\n", + " plot!(x, first.(initial_condition.(x, sol_source_custom.t[end], equations)),\n", + " label = \"analytical sol.\", linestyle = :dash, legend = :topleft)\n", + "end\n", + "plot!(sol_source_custom.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This also works with callbacks as usual." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "summary_callback = SummaryCallback()\n", + "analysis_interval = 100\n", + "analysis_callback = AnalysisCallback(semi; interval = analysis_interval)\n", + "alive_callback = AliveCallback(; analysis_interval)\n", + "callbacks = CallbackSet(summary_callback,\n", + " analysis_callback,\n", + " alive_callback)\n", + "\n", + "sol = solve(ode_source_custom, RDPK3SpFSAL49();\n", + " ode_default_options()..., callback = callbacks)\n", + "summary_callback()" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Setting up a custom semidiscretization" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Using a global constant is of course not really nice from a software\n", + "engineering point of view. Thus, it can often be useful to collect\n", + "additional data in the parameters of the `ODEProblem`. Thus, it is\n", + "time to create our own semidiscretization. Here, we create a small\n", + "wrapper of a standard semidiscretization of Trixi.jl and the current\n", + "global time of the simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "struct CustomSemidiscretization{Semi, T} <: Trixi.AbstractSemidiscretization\n", + " semi::Semi\n", + " t::T\n", + "end\n", + "\n", + "semi_custom = CustomSemidiscretization(semi, Ref(0.0))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To get pretty printing in the REPL, you can consider specializing\n", + "\n", + "- `Base.show(io::IO, parameters::CustomSemidiscretization)`\n", + "- `Base.show(io::IO, ::MIME\"text/plain\", parameters::CustomSemidiscretization)`\n", + "\n", + "for your custom semidiscretiation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we create our own source terms that use the global time stored\n", + "in the custom semidiscretiation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "source_terms_custom_semi = let semi_custom = semi_custom\n", + " function source_terms_custom_semi(u, x, t, equations)\n", + " t = semi_custom.t[]\n", + " return -initial_condition(x, t, equations)\n", + " end\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We also create a custom ODE RHS to update the current global time\n", + "stored in the custom semidiscretization. We unpack the standard\n", + "semidiscretization created by Trixi.jl and pass it to `Trixi.rhs!`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function rhs_semi_custom!(du_ode, u_ode, semi_custom, t)\n", + " semi_custom.t[] = t\n", + " Trixi.rhs!(du_ode, u_ode, semi_custom.semi, t)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Finally, we set up an `ODEProblem` and solve it numerically." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "ode_semi_custom = ODEProblem(rhs_semi_custom!,\n", + " ode.u0,\n", + " ode.tspan,\n", + " semi_custom)\n", + "sol_semi_custom = solve(ode_semi_custom, RDPK3SpFSAL49();\n", + " ode_default_options()...)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "If we want to make use of additional functionality provided by\n", + "Trixi.jl, e.g., for plotting, we need to implement a few additional\n", + "specializations. In this case, we forward everything to the standard\n", + "semidiscretization provided by Trixi.jl wrapped in our custom\n", + "semidiscretization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "Base.ndims(semi::CustomSemidiscretization) = ndims(semi.semi)\n", + "function Trixi.mesh_equations_solver_cache(semi::CustomSemidiscretization)\n", + " Trixi.mesh_equations_solver_cache(semi.semi)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can plot the numerical solution as usual." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "plot(sol_semi_custom; label = \"numerical sol.\")\n", + "let\n", + " x = range(-1.0, 1.0; length = 200)\n", + " plot!(x, first.(initial_condition.(x, sol_semi_custom.t[end], equations)),\n", + " label = \"analytical sol.\", linestyle = :dash, legend = :topleft)\n", + "end\n", + "plot!(sol_semi_custom.u[1], semi, label = \"u0\", linestyle = :dot, legend = :topleft)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This also works with many callbacks as usual. However, the\n", + "`AnalysisCallback` requires some special handling since it\n", + "makes use of a performance counter contained in the standard\n", + "semidiscretizations of Trixi.jl to report some\n", + "performance metrics.\n", + "Here, we forward all accesses to the performance counter to the\n", + "wrapped semidiscretization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function Base.getproperty(semi::CustomSemidiscretization, s::Symbol)\n", + " if s === :performance_counter\n", + " wrapped_semi = getfield(semi, :semi)\n", + " wrapped_semi.performance_counter\n", + " else\n", + " getfield(semi, s)\n", + " end\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Moreover, the `AnalysisCallback` also performs some error\n", + "calculations. We also need to forward them to the wrapped\n", + "semidiscretization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function Trixi.calc_error_norms(func, u, t, analyzer,\n", + " semi::CustomSemidiscretization,\n", + " cache_analysis)\n", + " Trixi.calc_error_norms(func, u, t, analyzer,\n", + " semi.semi,\n", + " cache_analysis)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can work with the callbacks used before as usual." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "summary_callback = SummaryCallback()\n", + "analysis_interval = 100\n", + "analysis_callback = AnalysisCallback(semi_custom;\n", + " interval = analysis_interval)\n", + "alive_callback = AliveCallback(; analysis_interval)\n", + "callbacks = CallbackSet(summary_callback,\n", + " analysis_callback,\n", + " alive_callback)\n", + "\n", + "sol = solve(ode_semi_custom, RDPK3SpFSAL49();\n", + " ode_default_options()..., callback = callbacks)\n", + "summary_callback()" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "For even more advanced usage of custom semidiscretizations, you\n", + "may look at the source code of the ones contained in Trixi.jl, e.g.,\n", + "- `SemidiscretizationHyperbolicParabolic`\n", + "- `SemidiscretizationEulerGravity`\n", + "- `SemidiscretizationEulerAcoustics`\n", + "- `SemidiscretizationCoupled`" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/differentiable_programming.ipynb b/previews/PR1697/tutorials/notebooks/differentiable_programming.ipynb new file mode 100644 index 00000000000..c94a1f3fd04 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/differentiable_programming.ipynb @@ -0,0 +1,956 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 16: Differentiable programming" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "[Julia and its ecosystem provide some tools for differentiable programming](https://sinews.siam.org/Details-Page/scientific-machine-learning-how-julia-employs-differentiable-programming-to-do-it-best).\n", + "Trixi.jl is designed to be flexible, extendable, and composable with Julia's growing ecosystem for\n", + "scientific computing and machine learning. Thus, the ultimate goal is to have fast implementations\n", + "that allow automatic differentiation (AD) without too much hassle for users. If some parts do not\n", + "meet these requirements, please feel free to open an issue or propose a fix in a PR." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "In the following, we will walk through some examples demonstrating how to differentiate through\n", + "Trixi.jl." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Forward mode automatic differentiation" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl integrates well with [ForwardDiff.jl](https://github.com/JuliaDiff/ForwardDiff.jl)\n", + "for forward mode AD." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Computing the Jacobian\n", + "The high-level interface to compute the Jacobian this way is `jacobian_ad_forward`.\n", + "First, we load the required packages and compute the Jacobian of a semidiscretization\n", + "of the compressible Euler equations, a system of nonlinear conservation laws." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, LinearAlgebra, Plots\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "\n", + "solver = DGSEM(3, flux_central)\n", + "mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n", + "\n", + "J = jacobian_ad_forward(semi);\n", + "size(J)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we compute the eigenvalues of the Jacobian." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ = eigvals(J)\n", + "scatter(real.(λ), imag.(λ), label=\"central flux\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As you can see here, the maximal real part is close to zero." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "relative_maximum = maximum(real, λ) / maximum(abs, λ)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Interestingly, if we add dissipation by switching to the `flux_lax_friedrichs`\n", + "at the interfaces, the maximal real part of the eigenvalues increases." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(3, flux_lax_friedrichs)\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n", + "\n", + "J = jacobian_ad_forward(semi)\n", + "λ = eigvals(J)\n", + "\n", + "scatter!(real.(λ), imag.(λ), label=\"Lax-Friedrichs flux\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Although the maximal real part is still somewhat small, it's larger than for\n", + "the purely central discretization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "relative_maximum = maximum(real, λ) / maximum(abs, λ)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "However, we should be careful when using this analysis, since the eigenvectors\n", + "are not necessarily well-conditioned." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ, V = eigen(J)\n", + "condition_number = cond(V)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "In one space dimension, the situation is a bit different." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "equations = CompressibleEulerEquations1D(1.4)\n", + "\n", + "solver = DGSEM(3, flux_central)\n", + "mesh = TreeMesh((-1.0,), (1.0,), initial_refinement_level=6, n_cells_max=10^5)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n", + "\n", + "J = jacobian_ad_forward(semi)\n", + "\n", + "λ = eigvals(J)\n", + "\n", + "scatter(real.(λ), imag.(λ), label=\"central flux\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Here, the maximal real part is basically zero to machine accuracy." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "relative_maximum = maximum(real, λ) / maximum(abs, λ)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Moreover, the eigenvectors are not as ill-conditioned as in 2D." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ, V = eigen(J)\n", + "condition_number = cond(V)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "If we add dissipation, the maximal real part is still approximately zero." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(3, flux_lax_friedrichs)\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n", + "\n", + "J = jacobian_ad_forward(semi)\n", + "λ = eigvals(J)\n", + "\n", + "scatter!(real.(λ), imag.(λ), label=\"Lax-Friedrichs flux\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As you can see from the plot generated above, the maximal real part is still\n", + "basically zero to machine precision." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "relative_maximum = maximum(real, λ) / maximum(abs, λ)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Let's check the condition number of the eigenvectors." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ, V = eigen(J)\n", + "\n", + "condition_number = cond(V)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Note that the condition number of the eigenvector matrix increases but is\n", + "still smaller than for the example in 2D." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Computing other derivatives" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It is also possible to compute derivatives of other dependencies using AD in Trixi.jl. For example,\n", + "you can compute the gradient of an entropy-dissipative semidiscretization with respect to the\n", + "ideal gas constant of the compressible Euler equations as described in the following. This example\n", + "is also available as the elixir\n", + "[`examples/special_elixirs/elixir_euler_ad.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/special_elixirs/elixir_euler_ad.jl)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "First, we create a semidiscretization of the compressible Euler equations." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, LinearAlgebra, ForwardDiff\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "\n", + "\"\"\"\n", + " initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)\n", + "\n", + "The classical isentropic vortex test case of\n", + "- Chi-Wang Shu (1997)\n", + " Essentially Non-Oscillatory and Weighted Essentially Non-Oscillatory\n", + " Schemes for Hyperbolic Conservation Laws\n", + " [NASA/CR-97-206253](https://ntrs.nasa.gov/citations/19980007543)\n", + "\"\"\"\n", + "function initial_condition_isentropic_vortex(x, t, equations::CompressibleEulerEquations2D)\n", + " inicenter = SVector(0.0, 0.0) # initial center of the vortex\n", + " iniamplitude = 5.0 # size and strength of the vortex\n", + "\n", + " rho = 1.0 # base flow\n", + " v1 = 1.0\n", + " v2 = 1.0\n", + " vel = SVector(v1, v2)\n", + " p = 25.0\n", + "\n", + " rt = p / rho # ideal gas equation\n", + " t_loc = 0.0\n", + "\n", + " cent = inicenter + vel*t_loc # shift advection of center to handle periodic BC, but only for v1 = v2 = 1.0\n", + " cent = x - cent # distance to center point\n", + " cent = SVector(-cent[2], cent[1])\n", + "\n", + " r2 = cent[1]^2 + cent[2]^2\n", + " du = iniamplitude / (2*π) * exp(0.5 * (1 - r2)) # vel. perturbation\n", + " dtemp = -(equations.gamma - 1) / (2 * equations.gamma * rt) * du^2 # isentropic\n", + "\n", + " rho = rho * (1 + dtemp)^(1 / (equations.gamma - 1))\n", + " vel = vel + du * cent\n", + " v1, v2 = vel\n", + " p = p * (1 + dtemp)^(equations.gamma / (equations.gamma - 1))\n", + "\n", + " prim = SVector(rho, v1, v2, p)\n", + " return prim2cons(prim, equations)\n", + "end\n", + "\n", + "mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n", + "\n", + "solver = DGSEM(3, flux_lax_friedrichs, VolumeIntegralFluxDifferencing(flux_ranocha))\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_isentropic_vortex, solver)\n", + "\n", + "u0_ode = Trixi.compute_coefficients(0.0, semi)\n", + "size(u0_ode)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we compute the Jacobian using `ForwardDiff.jacobian`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "J = ForwardDiff.jacobian((du_ode, γ) -> begin\n", + " equations_inner = CompressibleEulerEquations2D(first(γ))\n", + " semi_inner = Trixi.remake(semi, equations=equations_inner, uEltype=eltype(γ))\n", + " Trixi.rhs!(du_ode, u0_ode, semi_inner, 0.0)\n", + "end, similar(u0_ode), [1.4]); # γ needs to be an `AbstractArray`\n", + "\n", + "round.(extrema(J), sigdigits=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Note that we create a semidiscretization `semi` at first to determine the state `u0_ode` around\n", + "which we want to perform the linearization. Next, we wrap the RHS evaluation inside a closure\n", + "and pass that to `ForwardDiff.jacobian`. There, we need to make sure that the internal caches\n", + "are able to store dual numbers from ForwardDiff.jl by setting `uEltype` appropriately. A similar\n", + "approach is used by `jacobian_ad_forward`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Note that the ideal gas constant does not influence the semidiscrete rate of change of the\n", + "density, as demonstrated by" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "norm(J[1:4:end])" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Here, we used some knowledge about the internal memory layout of Trixi.jl, an array of structs\n", + "with the conserved variables as fastest-varying index in memory." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Differentiating through a complete simulation" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It is also possible to differentiate through a complete simulation. As an example, let's differentiate\n", + "the total energy of a simulation using the linear scalar advection equation with respect to the\n", + "wave number (frequency) of the initial data." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq, ForwardDiff, Plots\n", + "\n", + "function energy_at_final_time(k) # k is the wave number of the initial condition\n", + " equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n", + " mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\n", + " solver = DGSEM(3, flux_lax_friedrichs)\n", + " initial_condition = (x, t, equation) -> begin\n", + " x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n", + " return SVector(sinpi(k * sum(x_trans)))\n", + " end\n", + " semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " uEltype=typeof(k))\n", + " ode = semidiscretize(semi, (0.0, 1.0))\n", + " sol = solve(ode, BS3(), save_everystep=false)\n", + " Trixi.integrate(energy_total, sol.u[end], semi)\n", + "end\n", + "\n", + "k_values = range(0.9, 1.1, length=101)\n", + "\n", + "plot(k_values, energy_at_final_time.(k_values), label=\"Energy\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You see a plot of a curve that resembles a parabola with local maximum around `k = 1.0`.\n", + "Why's that? Well, the domain is fixed but the wave number changes. Thus, if the wave number is\n", + "not chosen as an integer, the initial condition will not be a smooth periodic function in the\n", + "given domain. Hence, the dissipative surface flux (`flux_lax_friedrichs` in this example)\n", + "will introduce more dissipation. In particular, it will introduce more dissipation for \"less smooth\"\n", + "initial data, corresponding to wave numbers `k` further away from integers." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We can compute the discrete derivative of the energy at the final time with respect to the wave\n", + "number `k` as follows." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "round(ForwardDiff.derivative(energy_at_final_time, 1.0), sigdigits=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This is rather small and we can treat it as zero in comparison to the value of this derivative at\n", + "other wave numbers `k`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "dk_values = ForwardDiff.derivative.((energy_at_final_time,), k_values);\n", + "\n", + "plot(k_values, dk_values, label=\"Derivative\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "If you remember basic calculus, a sufficient condition for a local maximum is that the first derivative\n", + "vanishes and the second derivative is negative. We can also check this discretely." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "second_derivative = round(ForwardDiff.derivative(\n", + " k -> Trixi.ForwardDiff.derivative(energy_at_final_time, k), 1.0),\n", + " sigdigits=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Having seen this application, let's break down what happens step by step." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function energy_at_final_time(k) # k is the wave number of the initial condition\n", + " equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n", + " mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\n", + " solver = DGSEM(3, flux_lax_friedrichs)\n", + " initial_condition = (x, t, equation) -> begin\n", + " x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n", + " return SVector(sinpi(k * sum(x_trans)))\n", + " end\n", + " semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " uEltype=typeof(k))\n", + " ode = semidiscretize(semi, (0.0, 1.0))\n", + " sol = solve(ode, BS3(), save_everystep=false)\n", + " Trixi.integrate(energy_total, sol.u[end], semi)\n", + "end\n", + "\n", + "k = 1.0\n", + "round(ForwardDiff.derivative(energy_at_final_time, k), sigdigits=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "When calling `ForwardDiff.derivative(energy_at_final_time, k)` with `k=1.0`, ForwardDiff.jl\n", + "will basically use the chain rule and known derivatives of existing basic functions\n", + "to calculate the derivative of the energy at the final time with respect to the\n", + "wave number `k` at `k0 = 1.0`. To do this, ForwardDiff.jl uses dual numbers, which\n", + "basically store the result and its derivative w.r.t. a specified parameter at the\n", + "same time. Thus, we need to make sure that we can treat these `ForwardDiff.Dual`\n", + "numbers everywhere during the computation. Fortunately, generic Julia code usually\n", + "supports these operations. The most basic problem for a developer is to ensure\n", + "that all types are generic enough, in particular the ones of internal caches." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The first step in this example creates some basic ingredients of our simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n", + "mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=3, n_cells_max=10^4)\n", + "solver = DGSEM(3, flux_lax_friedrichs);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "These do not have internal caches storing intermediate values of the numerical\n", + "solution, so we do not need to adapt them. In fact, we could also define them\n", + "outside of `energy_at_final_time` (but would need to take care of globals or\n", + "wrap everything in another function)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we define the initial condition" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "initial_condition = (x, t, equation) -> begin\n", + " x_trans = Trixi.x_trans_periodic_2d(x - equation.advection_velocity * t)\n", + " return SVector(sinpi(k * sum(x_trans)))\n", + "end;" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "as a closure capturing the wave number `k` passed to `energy_at_final_time`.\n", + "If you call `energy_at_final_time(1.0)`, `k` will be a `Float64`. Thus, the\n", + "return values of `initial_condition` will be `SVector`s of `Float64`s. When\n", + "calculating the `ForwardDiff.derivative`, `k` will be a `ForwardDiff.Dual` number.\n", + "Hence, the `initial_condition` will return `SVector`s of `ForwardDiff.Dual`\n", + "numbers." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The semidiscretization `semi` uses some internal caches to avoid repeated allocations\n", + "and speed up the computations, e.g. for numerical fluxes at interfaces. Thus, we\n", + "need to tell Trixi.jl to allow `ForwardDiff.Dual` numbers in these caches. That's what\n", + "the keyword argument `uEltype=typeof(k)` in" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " uEltype=typeof(k));" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "does. This is basically the only part where you need to modify your standard Trixi.jl\n", + "code to enable automatic differentiation. From there on, the remaining steps" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "ode = semidiscretize(semi, (0.0, 1.0))\n", + "sol = solve(ode, BS3(), save_everystep=false)\n", + "round(Trixi.integrate(energy_total, sol.u[end], semi), sigdigits=5)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "do not need any modifications since they are sufficiently generic (and enough effort\n", + "has been spend to allow general types inside these calls)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Propagating errors using Measurements.jl" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "[![Error bars by Randall Munroe](https://imgs.xkcd.com/comics/error_bars.png)](https://xkcd.com/2110/)\n", + "\"Error bars\" by Randall Munroe, linked from https://xkcd.com/2110" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Similar to AD, Trixi.jl also allows propagating uncertainties using linear error propagation\n", + "theory via [Measurements.jl](https://github.com/JuliaPhysics/Measurements.jl).\n", + "As an example, let's create a system representing the linear advection equation\n", + "in 1D with an uncertain velocity. Then, we create a semidiscretization using a\n", + "sine wave as initial condition, solve the ODE, and plot the resulting uncertainties\n", + "in the primitive variables." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq, Measurements, Plots, LaTeXStrings\n", + "\n", + "equations = LinearScalarAdvectionEquation1D(1.0 ± 0.1)\n", + "\n", + "mesh = TreeMesh((-1.0,), (1.0,), n_cells_max=10^5, initial_refinement_level=5)\n", + "\n", + "solver = DGSEM(3)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test,\n", + " solver, uEltype=Measurement{Float64})\n", + "\n", + "ode = semidiscretize(semi, (0.0, 1.5))\n", + "\n", + "sol = solve(ode, BS3(), save_everystep=false);\n", + "\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "You should see a plot where small error bars are shown around the extrema\n", + "and larger error bars are shown in the remaining parts.\n", + "This result is in accordance with expectations. Indeed, the uncertain propagation\n", + "speed will affect the extrema less since the local variation of the solution is\n", + "relatively small there. In contrast, the local variation of the solution is large\n", + "around the turning points of the sine wave, so the uncertainties will be relatively\n", + "large there." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "All this is possible due to allowing generic types and having good abstractions\n", + "in Julia that allow packages to work together seamlessly." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Finite difference approximations" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl provides the convenience function `jacobian_fd` to approximate the Jacobian\n", + "via central finite differences." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, LinearAlgebra\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)\n", + "\n", + "solver = DGSEM(3, flux_central)\n", + "\n", + "mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_density_wave, solver)\n", + "\n", + "J_fd = jacobian_fd(semi)\n", + "\n", + "J_ad = jacobian_ad_forward(semi)\n", + "\n", + "relative_difference = norm(J_fd - J_ad) / size(J_fd, 1)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This discrepancy is of the expected order of magnitude for central finite difference approximations." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Linear systems" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "When a linear PDE is discretized using a linear scheme such as a standard DG method,\n", + "the resulting semidiscretization yields an affine ODE of the form" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "$$\n", + "\\partial_t u(t) = A u(t) + b,\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "where `A` is a linear operator (\"matrix\") and `b` is a vector. Trixi.jl allows you\n", + "to obtain this linear structure in a matrix-free way by using `linear_structure`.\n", + "The resulting operator `A` can be used in multiplication, e.g. `mul!` from\n", + "LinearAlgebra, converted to a sparse matrix using `sparse` from SparseArrays,\n", + "or converted to a dense matrix using `Matrix` for detailed eigenvalue analyses.\n", + "For example," + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, LinearAlgebra, Plots\n", + "\n", + "equations = LinearScalarAdvectionEquation2D(1.0, -0.3)\n", + "\n", + "solver = DGSEM(3, flux_lax_friedrichs)\n", + "\n", + "mesh = TreeMesh((-1.0, -1.0), (1.0, 1.0), initial_refinement_level=2, n_cells_max=10^5)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_convergence_test, solver)\n", + "\n", + "A, b = linear_structure(semi)\n", + "\n", + "size(A), size(b)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we compute the eigenvalues of the linear operator." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ = eigvals(Matrix(A))\n", + "\n", + "scatter(real.(λ), imag.(λ))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As you can see here, the maximal real part is close to machine precision." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "λ = eigvals(Matrix(A))\n", + "relative_maximum = maximum(real, λ) / maximum(abs, λ)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\", \"ForwardDiff\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/hohqmesh_tutorial.ipynb b/previews/PR1697/tutorials/notebooks/hohqmesh_tutorial.ipynb new file mode 100644 index 00000000000..34e3ce63a0e --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/hohqmesh_tutorial.ipynb @@ -0,0 +1,1034 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 14: Unstructured meshes with HOHQMesh.jl" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl supports numerical approximations on unstructured quadrilateral meshes\n", + "with the `UnstructuredMesh2D` mesh type." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The purpose of this tutorial is to demonstrate how to use the `UnstructuredMesh2D`\n", + "functionality of Trixi.jl. This begins by running and visualizing an available unstructured\n", + "quadrilateral mesh example. Then, the tutorial will demonstrate how to\n", + "conceptualize a problem with curved boundaries, generate\n", + "a curvilinear mesh using the available software in the Trixi.jl ecosystem,\n", + "and then run a simulation using Trixi.jl on said mesh." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Unstructured quadrilateral meshes can be made\n", + "with the [High-Order Hex-Quad Mesh (HOHQMesh) generator](https://github.com/trixi-framework/HOHQMesh)\n", + "created and developed by David Kopriva.\n", + "HOHQMesh is a mesh generator specifically designed for spectral element methods.\n", + "It provides high-order boundary curve information (needed to accurately set boundary conditions)\n", + "and elements can be larger (due to the high accuracy of the spatial approximation)\n", + "compared to traditional finite element mesh generators.\n", + "For more information about the design and features of HOHQMesh one can refer to its\n", + "[official documentation](https://trixi-framework.github.io/HOHQMesh/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "HOHQMesh is incorporated into the Trixi.jl framework via the registered Julia package\n", + "[HOHQMesh.jl](https://github.com/trixi-framework/HOHQMesh.jl).\n", + "This package provides a Julia wrapper for the HOHQMesh generator that allows users to easily create mesh\n", + "files without the need to build HOHQMesh from source. To install the HOHQMesh package execute\n", + "```julia\n", + "import Pkg; Pkg.add(\"HOHQMesh\")\n", + "```\n", + "Now we are ready to generate an unstructured quadrilateral mesh that can be used by Trixi.jl." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Running and visualizing an unstructured simulation" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl supports solving hyperbolic problems on several mesh types.\n", + "There is a default example for this mesh type that can be executed by" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi\n", + "trixi_include(default_example_unstructured())" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "This will compute a smooth, manufactured solution test case for the 2D compressible Euler equations\n", + "on the curved quadrilateral mesh described in the\n", + "[Trixi.jl documentation](https://trixi-framework.github.io/Trixi.jl/stable/meshes/unstructured_quad_mesh/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Apart from the usual error and timing output provided by the Trixi.jl run, it is useful to visualize and inspect\n", + "the solution. One option available in the Trixi.jl framework to visualize the solution on\n", + "unstructured quadrilateral meshes is post-processing the\n", + "Trixi.jl output file(s) with the [`Trixi2Vtk`](https://github.com/trixi-framework/Trixi2Vtk.jl) tool\n", + "and plotting them with [ParaView](https://www.paraview.org/download/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To convert the HDF5-formatted `.h5` output file(s) from Trixi.jl into VTK format execute the following" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi2Vtk\n", + "trixi2vtk(\"out/solution_000180.h5\", output_directory=\"out\")" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Note this step takes about 15-30 seconds as the package `Trixi2Vtk` must be precompiled and executed for the first time\n", + "in your REPL session. The `trixi2vtk` command above will convert the solution file at the final time into a `.vtu` file\n", + "which can be read in and visualized with ParaView. Optional arguments for `trixi2vtk` are: (1) Pointing to the `output_directory`\n", + "where the new files will be saved; it defaults to the current directory. (2) Specifying a higher number of\n", + "visualization nodes. For instance, if we want to use 12 uniformly spaced nodes for visualization we can execute" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "trixi2vtk(\"out/solution_000180.h5\", output_directory=\"out\", nvisnodes=12)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "By default `trixi2vtk` sets `nvisnodes` to be the same as the number of nodes specified in\n", + "the `elixir` file used to run the simulation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Finally, if you want to convert all the solution files to VTK execute" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "trixi2vtk(\"out/solution_000*.h5\", output_directory=\"out\", nvisnodes=12)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "then it is possible to open the `.pvd` file with ParaView and create a video of the simulation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Creating a mesh using HOHQMesh" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The creation of an unstructured quadrilateral mesh using HOHQMesh.jl is driven by a **control file**. In this file the user dictates\n", + "the domain to be meshed, prescribes any desired boundary curvature, the polynomial order of said boundaries, etc.\n", + "In this tutorial we cover several basic features of the possible control inputs. For a complete discussion\n", + "on this topic see the [HOHQMesh control file documentation](https://trixi-framework.github.io/HOHQMesh/the-control-file/)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To begin, we provide a complete control file in this tutorial. After this we give a breakdown\n", + "of the control file components to explain the chosen parameters." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Suppose we want to create a mesh of a domain with straight sided\n", + "outer boundaries and a curvilinear \"ice cream cone\" shaped object at its center." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![mesh_boundary_cartoon](https://user-images.githubusercontent.com/25242486/129603954-9788500d-bba8-49be-8e6f-7555099dbf7c.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The associated `ice_cream_straight_sides.control` file is created below." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "open(\"out/ice_cream_straight_sides.control\", \"w\") do io\n", + " println(io, raw\"\"\"\n", + "\\begin{CONTROL_INPUT}\n", + " \\begin{RUN_PARAMETERS}\n", + " mesh file name = ice_cream_straight_sides.mesh\n", + " plot file name = ice_cream_straight_sides.tec\n", + " stats file name = none\n", + " mesh file format = ISM-v2\n", + " polynomial order = 4\n", + " plot file format = skeleton\n", + " \\end{RUN_PARAMETERS}\n", + "\n", + " \\begin{BACKGROUND_GRID}\n", + " x0 = [-8.0, -8.0, 0.0]\n", + " dx = [1.0, 1.0, 0.0]\n", + " N = [16,16,1]\n", + " \\end{BACKGROUND_GRID}\n", + "\n", + " \\begin{SPRING_SMOOTHER}\n", + " smoothing = ON\n", + " smoothing type = LinearAndCrossBarSpring\n", + " number of iterations = 25\n", + " \\end{SPRING_SMOOTHER}\n", + "\n", + "\\end{CONTROL_INPUT}\n", + "\n", + "\\begin{MODEL}\n", + "\n", + " \\begin{INNER_BOUNDARIES}\n", + "\n", + " \\begin{CHAIN}\n", + " name = IceCreamCone\n", + " \\begin{END_POINTS_LINE}\n", + " name = LeftSlant\n", + " xStart = [-2.0, 1.0, 0.0]\n", + " xEnd = [ 0.0, -3.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{END_POINTS_LINE}\n", + " name = RightSlant\n", + " xStart = [ 0.0, -3.0, 0.0]\n", + " xEnd = [ 2.0, 1.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{CIRCULAR_ARC}\n", + " name = IceCream\n", + " units = degrees\n", + " center = [ 0.0, 1.0, 0.0]\n", + " radius = 2.0\n", + " start angle = 0.0\n", + " end angle = 180.0\n", + " \\end{CIRCULAR_ARC}\n", + " \\end{CHAIN}\n", + "\n", + " \\end{INNER_BOUNDARIES}\n", + "\n", + "\\end{MODEL}\n", + "\\end{FILE}\n", + "\"\"\")\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The first three blocks of information are wrapped within a `CONTROL_INPUT` environment block as they define the\n", + "core components of the quadrilateral mesh that will be generated." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The first block of information in `RUN_PARAMETERS` is\n", + "```\n", + "\\begin{RUN_PARAMETERS}\n", + " mesh file name = ice_cream_straight_sides.mesh\n", + " plot file name = ice_cream_straight_sides.tec\n", + " stats file name = none\n", + " mesh file format = ISM-v2\n", + " polynomial order = 4\n", + " plot file format = skeleton\n", + "\\end{RUN_PARAMETERS}\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The mesh and plot file names will be the files created by HOHQMesh once successfully executed. The stats file name is\n", + "available if you wish to also save a collection of mesh statistics. For this example it is deactivated.\n", + "These file names given within `RUN_PARAMETERS` **should match** that of the control file, and although this is not required by\n", + "HOHQMesh, it is a useful style convention.\n", + "The mesh file format `ISM-v2` in the format currently required by Trixi.jl. The `polynomial order` prescribes the order\n", + "of an interpolant constructed on the Chebyshev-Gauss-Lobatto nodes that is used to represent any curved boundaries on a particular element.\n", + "The plot file format of `skeleton` means that visualizing the plot file will only draw the element boundaries (and no internal nodes).\n", + "Alternatively, the format can be set to `sem` to visualize the interior nodes of the approximation as well." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The second block of information in `BACKGROUND_GRID` is\n", + "```\n", + "\\begin{BACKGROUND_GRID}\n", + " x0 = [-8.0, -8.0, 0.0]\n", + " dx = [1.0, 1.0, 0.0]\n", + " N = [16,16,1]\n", + "\\end{BACKGROUND_GRID}\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This lays a grid of Cartesian elements for the domain beginning at the point `x0` as its bottom-left corner.\n", + "The value of `dx`, which could differ in each direction if desired, controls the step size taken in each Cartesian direction.\n", + "The values in `N` set how many Cartesian box elements are set in each coordinate direction.\n", + "The above parameters define a $16\\times 16$ element square mesh on $[-8,8]^2$.\n", + "Further, this sets up four outer boundaries of the domain that are given the default names: `Top, Left, Bottom, Right`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The third block of information in `SPRING_SMOOTHER` is\n", + "```\n", + "\\begin{SPRING_SMOOTHER}\n", + " smoothing = ON\n", + " smoothing type = LinearAndCrossBarSpring\n", + " number of iterations = 25\n", + "\\end{SPRING_SMOOTHER}\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Once HOHQMesh generates the mesh, a spring-mass-dashpot model is created to smooth the mesh and create \"nicer\" quadrilateral elements.\n", + "The [default parameters of Hooke's law](https://trixi-framework.github.io/HOHQMesh/the-control-input/#the-smoother)\n", + "for the spring-mass-dashpot model have been selected after a fair amount of experimentation across many meshes.\n", + "If you wish to deactivate this feature you can set `smoothing = OFF` (or remove this block from the control file)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "After the `CONTROL_INPUT` environment block comes the `MODEL` environment block. It is here where the user prescribes curved boundary information with either:\n", + "* An `OUTER_BOUNDARY` (covered in the next section of this tutorial).\n", + "* One or more `INNER_BOUNDARIES`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "There are several options to describe the boundary curve data to HOHQMesh like splines or parametric curves." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For the example `ice_cream_straight_sides.control` we define three internal boundaries; two straight-sided and\n", + "one as a circular arc.\n", + "Within the HOHQMesh control input each curve must be assigned to a `CHAIN` as shown below in the complete\n", + "`INNER_BOUNDARIES` block.\n", + "```\n", + "\\begin{INNER_BOUNDARIES}\n", + "\n", + " \\begin{CHAIN}\n", + " name = IceCreamCone\n", + " \\begin{END_POINTS_LINE}\n", + " name = LeftSlant\n", + " xStart = [-2.0, 1.0, 0.0]\n", + " xEnd = [ 0.0, -3.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{END_POINTS_LINE}\n", + " name = RightSlant\n", + " xStart = [ 0.0, -3.0, 0.0]\n", + " xEnd = [ 2.0, 1.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{CIRCULAR_ARC}\n", + " name = IceCream\n", + " units = degrees\n", + " center = [ 0.0, 1.0, 0.0]\n", + " radius = 2.0\n", + " start angle = 0.0\n", + " end angle = 180.0\n", + " \\end{CIRCULAR_ARC}\n", + " \\end{CHAIN}\n", + "\n", + "\\end{INNER_BOUNDARIES}\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It is important to note there are two `name` quantities one for the `CHAIN` and one for the `PARAMETRIC_EQUATION_CURVE`.\n", + "The name for the `CHAIN` is used internally by HOHQMesh, so if you have multiple `CHAIN`s they **must be given a unique name**.\n", + "The name for the `PARAMETRIC_EQUATION_CURVE` will be printed to the appropriate boundaries within the `.mesh` file produced by\n", + "HOHQMesh." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We create the mesh file `ice_cream_straight_sides.mesh` and its associated file for plotting\n", + "`ice_cream_straight_sides.tec` by using HOHQMesh.jl's function `generate_mesh`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using HOHQMesh\n", + "control_file = joinpath(\"out\", \"ice_cream_straight_sides.control\")\n", + "output = generate_mesh(control_file);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The mesh file `ice_cream_straight_sides.mesh` and its associated file for plotting\n", + "`ice_cream_straight_sides.tec` are placed in the `out` folder.\n", + "The resulting mesh generated by HOHQMesh.jl is given in the following figure." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![mesh_straight_sides](https://user-images.githubusercontent.com/25242486/129603958-08e4b874-53d5-4511-9a54-6daf4c21edca.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We note that Trixi.jl uses the boundary name information from the control file\n", + "to assign boundary conditions in an elixir file.\n", + "Therefore, the name should start with a letter and consist only of alphanumeric characters and underscores. Please note that the name will be treated as case sensitive." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Example simulation on `ice_cream_straight_sides.mesh`" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "With this newly generated mesh we are ready to run a Trixi.jl simulation on an unstructured quadrilateral mesh.\n", + "For this we must create a new elixir file." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The elixir file given below creates an initial condition for a\n", + "uniform background flow state with a free stream Mach number of 0.3.\n", + "A focus for this part of the tutorial is to specify the boundary conditions and to construct the new mesh from the\n", + "file that was generated in the previous exercise." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It is straightforward to set the different boundary\n", + "condition types in an elixir by assigning a particular function to a boundary name inside a\n", + "Julia dictionary, `Dict`, variable. Observe that the names of these boundaries match those provided by HOHQMesh\n", + "either by default, e.g. `Bottom`, or user assigned, e.g. `IceCream`. For this problem setup use\n", + "* Freestream boundary conditions on the four box edges.\n", + "* Free slip wall boundary condition on the interior curved boundaries." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To construct the unstructured quadrilateral mesh from the HOHQMesh file we point to the appropriate location\n", + "with the variable `mesh_file` and then feed this into the constructor for the `UnstructuredMesh2D` type in Trixi.jl" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "```julia\n", + "# create the unstructured mesh from your mesh file\n", + "using Trixi\n", + "mesh_file = joinpath(\"out\", \"ice_cream_straight_sides.mesh\")\n", + "mesh = UnstructuredMesh2D(mesh_file);\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The complete elixir file for this simulation example is given below." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq, Trixi\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4) # set gas gamma = 1.4\n", + "\n", + "# freestream flow state with Ma_inf = 0.3\n", + "@inline function uniform_flow_state(x, t, equations::CompressibleEulerEquations2D)\n", + "\n", + " # set the freestream flow parameters\n", + " rho_freestream = 1.0\n", + " u_freestream = 0.3\n", + " p_freestream = inv(equations.gamma)\n", + "\n", + " theta = 0.0 # zero angle of attack\n", + " si, co = sincos(theta)\n", + " v1 = u_freestream * co\n", + " v2 = u_freestream * si\n", + "\n", + " prim = SVector(rho_freestream, v1, v2, p_freestream)\n", + " return prim2cons(prim, equations)\n", + "end\n", + "\n", + "# initial condition\n", + "initial_condition = uniform_flow_state\n", + "\n", + "# boundary condition types\n", + "boundary_condition_uniform_flow = BoundaryConditionDirichlet(uniform_flow_state)\n", + "\n", + "# boundary condition dictionary\n", + "boundary_conditions = Dict( :Bottom => boundary_condition_uniform_flow,\n", + " :Top => boundary_condition_uniform_flow,\n", + " :Right => boundary_condition_uniform_flow,\n", + " :Left => boundary_condition_uniform_flow,\n", + " :LeftSlant => boundary_condition_slip_wall,\n", + " :RightSlant => boundary_condition_slip_wall,\n", + " :IceCream => boundary_condition_slip_wall );\n", + "\n", + "# DGSEM solver.\n", + "# 1) polydeg must be >= the polynomial order set in the HOHQMesh control file to guarantee\n", + "# freestream preservation. As a extra task try setting polydeg=3\n", + "# 2) VolumeIntegralFluxDifferencing with central volume flux is activated\n", + "# for dealiasing\n", + "volume_flux = flux_ranocha\n", + "solver = DGSEM(polydeg=4, surface_flux=flux_hll,\n", + " volume_integral=VolumeIntegralFluxDifferencing(volume_flux))\n", + "\n", + "# create the unstructured mesh from your mesh file\n", + "mesh_file = joinpath(\"out\", \"ice_cream_straight_sides.mesh\")\n", + "mesh = UnstructuredMesh2D(mesh_file)\n", + "\n", + "# Create semidiscretization with all spatial discretization-related components\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " boundary_conditions=boundary_conditions)\n", + "\n", + "# Create ODE problem from semidiscretization with time span from 0.0 to 2.0\n", + "tspan = (0.0, 2.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "\n", + "# Create the callbacks to output solution files and adapt the time step\n", + "summary_callback = SummaryCallback()\n", + "save_solution = SaveSolutionCallback(interval=10,\n", + " save_initial_solution=true,\n", + " save_final_solution=true)\n", + "stepsize_callback = StepsizeCallback(cfl=1.0)\n", + "\n", + "callbacks = CallbackSet(summary_callback, save_solution, stepsize_callback)\n", + "\n", + "# Evolve ODE problem in time using `solve` from OrdinaryDiffEq\n", + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, callback=callbacks);\n", + "# print the timer summary\n", + "summary_callback()" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Visualization of the solution is carried out in a similar way as above. That is, one converts the `.h5`\n", + "output files with `trixi2vtk` and then plot the solution in ParaView. An example plot of the pressure\n", + "at the final time is shown below." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![simulation_straight_sides](https://user-images.githubusercontent.com/25242486/129733926-6ef80676-779b-4f1e-9826-3ebf750cf382.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Making a mesh with a curved outer boundary" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Let us modify the mesh from the previous task and place a circular outer boundary instead\n", + "of straight-sided outer boundaries.\n", + "Note, the \"ice cream cone\" shape is still placed at the center of the domain." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We create the new control file `ice_cream_curved_sides.control` file below and will then highlight the\n", + "major differences compared to `ice_cream_straight_sides.control`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "open(\"out/ice_cream_curved_sides.control\", \"w\") do io\n", + " println(io, raw\"\"\"\n", + "\\begin{CONTROL_INPUT}\n", + " \\begin{RUN_PARAMETERS}\n", + " mesh file name = ice_cream_curved_sides.mesh\n", + " plot file name = ice_cream_curved_sides.tec\n", + " stats file name = none\n", + " mesh file format = ISM-v2\n", + " polynomial order = 4\n", + " plot file format = skeleton\n", + " \\end{RUN_PARAMETERS}\n", + "\n", + " \\begin{BACKGROUND_GRID}\n", + " background grid size = [1.0, 1.0, 0.0]\n", + " \\end{BACKGROUND_GRID}\n", + "\n", + " \\begin{SPRING_SMOOTHER}\n", + " smoothing = ON\n", + " smoothing type = LinearAndCrossBarSpring\n", + " number of iterations = 25\n", + " \\end{SPRING_SMOOTHER}\n", + "\n", + "\\end{CONTROL_INPUT}\n", + "\n", + "\\begin{MODEL}\n", + "\n", + " \\begin{OUTER_BOUNDARY}\n", + " \\begin{PARAMETRIC_EQUATION_CURVE}\n", + " name = OuterCircle\n", + " xEqn = x(t) = 8.0*sin(2.0*pi*t)\n", + " yEqn = y(t) = 8.0*cos(2.0*pi*t)\n", + " zEqn = z(t) = 0.0\n", + " \\end{PARAMETRIC_EQUATION_CURVE}\n", + "\n", + " \\end{OUTER_BOUNDARY}\n", + "\n", + " \\begin{INNER_BOUNDARIES}\n", + "\n", + " \\begin{CHAIN}\n", + " name = IceCreamCone\n", + " \\begin{END_POINTS_LINE}\n", + " name = LeftSlant\n", + " xStart = [-2.0, 1.0, 0.0]\n", + " xEnd = [ 0.0, -3.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{END_POINTS_LINE}\n", + " name = RightSlant\n", + " xStart = [ 0.0, -3.0, 0.0]\n", + " xEnd = [ 2.0, 1.0, 0.0]\n", + " \\end{END_POINTS_LINE}\n", + "\n", + " \\begin{CIRCULAR_ARC}\n", + " name = IceCream\n", + " units = degrees\n", + " center = [ 0.0, 1.0, 0.0]\n", + " radius = 2.0\n", + " start angle = 0.0\n", + " end angle = 180.0\n", + " \\end{CIRCULAR_ARC}\n", + " \\end{CHAIN}\n", + "\n", + " \\end{INNER_BOUNDARIES}\n", + "\n", + "\\end{MODEL}\n", + "\\end{FILE}\n", + "\"\"\")\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The first alteration is that we have altered the second block of information\n", + "`BACKGROUND_GRID` within the `CONTROL_INPUT` to be\n", + "```\n", + "\\begin{BACKGROUND_GRID}\n", + " background grid size = [1.0, 1.0, 0.0]\n", + "\\end{BACKGROUND_GRID}\n", + "```\n", + "This mesh control file has an outer boundary that determines the extent of the domain to be meshed.\n", + "Therefore, we only need to supply the `background grid size` to the `BACKGROUND_GRID` control input." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The second alteration is that the `MODEL` now contains information for an `OUTER_BOUNDARY`.\n", + "In this case it is a circle of radius `8` centered at `[0.0, 0.0, 0.0]` written as a set of\n", + "`PARAMETRIC_EQUATION_CURVE`s.\n", + "```\n", + " \\begin{OUTER_BOUNDARY}\n", + "\n", + " \\begin{PARAMETRIC_EQUATION_CURVE}\n", + " name = OuterCircle\n", + " xEqn = x(t) = 8.0*sin(2.0*pi*t)\n", + " yEqn = y(t) = 8.0*cos(2.0*pi*t)\n", + " zEqn = z(t) = 0.0\n", + " \\end{PARAMETRIC_EQUATION_CURVE}\n", + "\n", + " \\end{OUTER_BOUNDARY}\n", + "```\n", + "Just as with the inner boundary curves, we must assign a name to the `OUTER_BOUNDARY`. It will be included\n", + "in the generated `.mesh` file and is used within the Trixi.jl elixir file to set boundary conditions." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Again, we create the `.mesh` and `.tec` files with HOHQMesh.jl's function `generate_mesh`" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "control_file = joinpath(\"out\", \"ice_cream_curved_sides.control\")\n", + "output = generate_mesh(control_file);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The files are placed in the `out` folder." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The resulting mesh generated by HOHQMesh.jl is given in the following figure." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![mesh_curved_sides](https://user-images.githubusercontent.com/25242486/129603957-6a92618f-9ed8-4072-b6ab-05533bea746a.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Running Trixi.jl on `ice_cream_curved_sides.mesh`" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We can reuse much of the elixir file to setup the uniform flow over an ice cream cone from the\n", + "previous part of this tutorial. The only component of the elixir file that must be changed is the boundary condition\n", + "dictionary because we now have a boundary named `OuterCircle` instead of four edges of a bounding box." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# boundary condition dictionary\n", + "boundary_conditions = Dict( :OuterCircle => boundary_condition_uniform_flow,\n", + " :LeftSlant => boundary_condition_slip_wall,\n", + " :RightSlant => boundary_condition_slip_wall,\n", + " :IceCream => boundary_condition_slip_wall );" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Also, we must update the construction of the mesh from our new mesh file `ice_cream_curved_sides.mesh` that\n", + "is located in the `out` folder." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# create the unstructured mesh from your mesh file\n", + "mesh_file = joinpath(\"out\", \"ice_cream_curved_sides.mesh\")\n", + "mesh = UnstructuredMesh2D(mesh_file);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We can then post-process the solution file at the final time on the new mesh with `Trixi2Vtk` and visualize with ParaView." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![simulation_curved_sides](https://user-images.githubusercontent.com/25242486/129733924-778795c1-9119-419a-8b89-bcbe13e33cd7.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Setting up a simulation with AMR via `P4estMesh`\n", + "The above explained mesh file format of `ISM-V2` only works with `UnstructuredMesh2D` and so does\n", + "not support AMR. On the other hand, the mesh type `P4estMesh` allows AMR. The mesh\n", + "constructor for the `P4estMesh` imports an unstructured, conforming mesh from an Abaqus mesh file\n", + "(`.inp`)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "As described above, the first block of the HOHQMesh control file contains the parameter\n", + "`mesh file format`. If you set `mesh file format = ABAQUS` instead of `ISM-V2`,\n", + "HOHQMesh.jl's function `generate_mesh` creates an Abaqus mesh file `.inp`.\n", + "```julia\n", + "using HOHQMesh\n", + "control_file = joinpath(\"out\", \"ice_cream_straight_sides.control\")\n", + "output = generate_mesh(control_file);\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Now, you can create a `P4estMesh` from your mesh file. It is described in detail in the\n", + "[P4est-based mesh](https://trixi-framework.github.io/Trixi.jl/stable/meshes/p4est_mesh/#P4est-based-mesh)\n", + "part of the Trixi.jl docs.\n", + "```julia\n", + "using Trixi\n", + "mesh_file = joinpath(\"out\", \"ice_cream_straight_sides.inp\")\n", + "mesh = P4estMesh{2}(mesh_file)\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Since `P4estMesh` supports AMR, we just have to extend the setup from the first example by the\n", + "standard AMR procedure. For more information about AMR in Trixi.jl, see the matching tutorial." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "```julia\n", + "amr_indicator = IndicatorLöhner(semi, variable=density)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "amr_controller = ControllerThreeLevel(semi, amr_indicator,\n", + " base_level=0,\n", + " med_level =1, med_threshold=0.05,\n", + " max_level =3, max_threshold=0.1)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "amr_callback = AMRCallback(semi, amr_controller,\n", + " interval=5,\n", + " adapt_initial_condition=true,\n", + " adapt_initial_condition_only_refine=true)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "callbacks = CallbackSet(..., amr_callback)\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We can then post-process the solution file at the final time on the new mesh with `Trixi2Vtk` and visualize\n", + "with ParaView, see the appropriate [visualization section](https://trixi-framework.github.io/Trixi.jl/stable/visualization/#Trixi2Vtk)\n", + "for details." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![simulation_straight_sides_p4est_amr](https://user-images.githubusercontent.com/74359358/168049930-8abce6ac-cd47-4d04-b40b-0fa459bbd98d.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\", \"Trixi2Vtk\", \"HOHQMesh\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/non_periodic_boundaries.ipynb b/previews/PR1697/tutorials/notebooks/non_periodic_boundaries.ipynb new file mode 100644 index 00000000000..c03614e4c16 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/non_periodic_boundaries.ipynb @@ -0,0 +1,346 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 4: Non-periodic boundaries" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Dirichlet boundary condition\n", + "First, let's look at the Dirichlet boundary condition `BoundaryConditionDirichlet`.\n", + "```julia\n", + "BoundaryConditionDirichlet(boundary_value_function)\n", + "```\n", + "In Trixi.jl, this creates a Dirichlet boundary condition where the function `boundary_value_function`\n", + "is used to set the values at the boundary. It can be used to create a boundary condition that sets\n", + "exact boundary values by passing the exact solution of the equation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It is important to note that standard Dirichlet boundary conditions for hyperbolic PDEs do not\n", + "make sense in most cases. However, we are using a special weak form of the Dirichlet boundary\n", + "condition, based on the application of the numerical surface flux. The numerical surface flux\n", + "takes the solution value from inside the domain and the prescribed value of the outer boundary\n", + "state as arguments, and solves an approximate Riemann problem to introduce dissipation (and\n", + "hence stabilization) at the boundary. Hence, the performance of the Dirichlet BC depends on the\n", + "fidelity of the numerical surface flux." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The passed boundary value function is called with the same arguments as an initial condition\n", + "function, i.e.\n", + "```julia\n", + "boundary_value_function(x, t, equations)\n", + "```\n", + "where `x` specifies the spatial coordinates, `t` is the current time, and `equations` is the\n", + "corresponding system of equations." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We want to give a short example for a simulation with such a Dirichlet BC." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Consider the one-dimensional linear advection equation with domain $\\Omega=[0, 2]$ and a constant\n", + "zero initial condition." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq, Trixi\n", + "\n", + "advection_velocity = 1.0\n", + "equations = LinearScalarAdvectionEquation1D(advection_velocity)\n", + "\n", + "initial_condition_zero(x, t, equation::LinearScalarAdvectionEquation1D) = SVector(0.0)\n", + "initial_condition = initial_condition_zero\n", + "\n", + "using Plots\n", + "plot(x -> sum(initial_condition(x, 0.0, equations)), label=\"initial condition\", ylim=(-1.5, 1.5))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Using an advection velocity of `1.0` and the (local) Lax-Friedrichs/Rusanov flux\n", + "`FluxLaxFriedrichs` as a numerical surface flux, we are able to create an inflow boundary\n", + "on the left and an outflow boundary on the right, as the Lax-Friedrichs flux is in this case an\n", + "exact characteristics Riemann solver. We note that for more complex PDEs different strategies for\n", + "inflow/outflow boundaries are necessary. To define the inflow values, we initialize a `boundary_value_function`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function boundary_condition_sine_sector(x, t, equation::LinearScalarAdvectionEquation1D)\n", + " if 1 <= t <= 3\n", + " scalar = sin(2 * pi * sum(t - 1))\n", + " else\n", + " scalar = zero(t)\n", + " end\n", + " return SVector(scalar)\n", + "end\n", + "boundary_condition = boundary_condition_sine_sector" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We set the BC in negative and positive x-direction." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "boundary_conditions = (x_neg=BoundaryConditionDirichlet(boundary_condition),\n", + " x_pos=BoundaryConditionDirichlet(boundary_condition))" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n", + "\n", + "coordinates_min = (0.0,)\n", + "coordinates_max = (2.0,)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "For the mesh type `TreeMesh` the parameter `periodicity` must be set to `false` in the\n", + "corresponding direction." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4,\n", + " n_cells_max=10_000,\n", + " periodicity=false)\n", + "\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations,\n", + " initial_condition,\n", + " solver,\n", + " boundary_conditions=boundary_conditions)\n", + "\n", + "tspan = (0.0, 6.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "analysis_callback = AnalysisCallback(semi, interval=100,)\n", + "\n", + "stepsize_callback = StepsizeCallback(cfl=0.9)\n", + "\n", + "callbacks = CallbackSet(analysis_callback,\n", + " stepsize_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We define some equidistant nodes for the visualization" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "visnodes = range(tspan[1], tspan[2], length=300)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "and run the simulation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt=1, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, saveat=visnodes, callback=callbacks);\n", + "\n", + "using Plots\n", + "@gif for step in 1:length(sol.u)\n", + " plot(sol.u[step], semi, ylim=(-1.5, 1.5), legend=true, label=\"approximation\", title=\"time t=$(round(sol.t[step], digits=5))\")\n", + " scatter!([0.0], [sum(boundary_condition(SVector(0.0), sol.t[step], equations))], label=\"boundary condition\")\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "# Other available example elixirs with non-trivial BC\n", + "Moreover, there are other boundary conditions in Trixi.jl. For instance, you can use the slip wall\n", + "boundary condition `boundary_condition_slip_wall`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl provides some interesting examples with different combinations of boundary conditions, e.g.\n", + "using `boundary_condition_slip_wall` and other self-defined boundary conditions using\n", + "`BoundaryConditionDirichlet`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For instance, there is a 2D compressible Euler setup for a Mach 3 wind tunnel flow with a forward\n", + "facing step in the elixir [`elixir_euler_forward_step_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/p4est_2d_dgsem/elixir_euler_forward_step_amr.jl)\n", + "discretized with a `P4estMesh` using adaptive mesh refinement (AMR).\n", + "\n", + " \n", + "
\n", + "\n", + "Source: [`Video`](https://www.youtube.com/watch?v=glAug1aIxio) on Trixi.jl's YouTube channel [`Trixi Framework`](https://www.youtube.com/watch?v=WElqqdMhY4A)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "A double Mach reflection problem for the 2D compressible Euler equations\n", + "[`elixir_euler_double_mach_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/p4est_2d_dgsem/elixir_euler_double_mach_amr.jl)\n", + "exercises a special boundary conditions along the bottom of the domain that is a mixture of\n", + "Dirichlet and slip wall.\n", + "\n", + " \n", + "
\n", + "\n", + "Source: [`Video`](https://www.youtube.com/watch?v=WElqqdMhY4A) on Trixi.jl's YouTube channel [`Trixi Framework`](https://www.youtube.com/watch?v=WElqqdMhY4A)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "A channel flow around a cylinder at Mach 3\n", + "[`elixir_euler_supersonic_cylinder.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/p4est_2d_dgsem/elixir_euler_supersonic_cylinder.jl)\n", + "contains supersonic Mach 3 inflow at the left portion of the domain and supersonic outflow at the\n", + "right portion of the domain. The top and bottom of the channel as well as the cylinder are treated\n", + "as Euler slip wall boundaries.\n", + "\n", + " \n", + "
\n", + "\n", + "Source: [`Video`](https://www.youtube.com/watch?v=w0A9X38cSe4) on Trixi.jl's YouTube channel [`Trixi Framework`](https://www.youtube.com/watch?v=WElqqdMhY4A)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/parabolic_terms.ipynb b/previews/PR1697/tutorials/notebooks/parabolic_terms.ipynb new file mode 100644 index 00000000000..663610ad7ba --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/parabolic_terms.ipynb @@ -0,0 +1,264 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 10: Parabolic terms" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Experimental support for parabolic diffusion terms is available in Trixi.jl.\n", + "This demo illustrates parabolic terms for the advection-diffusion equation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "using Trixi" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Splitting a system into hyperbolic and parabolic parts." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For a mixed hyperbolic-parabolic system, we represent the hyperbolic and parabolic\n", + "parts of the system separately. We first define the hyperbolic (advection) part of\n", + "the advection-diffusion equation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "advection_velocity = (1.5, 1.0)\n", + "equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Next, we define the parabolic diffusion term. The constructor requires knowledge of\n", + "`equations_hyperbolic` to be passed in because the `LaplaceDiffusion2D` applies\n", + "diffusion to every variable of the hyperbolic system." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "diffusivity = 5.0e-2\n", + "equations_parabolic = LaplaceDiffusion2D(diffusivity, equations_hyperbolic);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Boundary conditions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "As with the equations, we define boundary conditions separately for the hyperbolic and\n", + "parabolic part of the system. For this example, we impose inflow BCs for the hyperbolic\n", + "system (no condition is imposed on the outflow), and we impose Dirichlet boundary conditions\n", + "for the parabolic equations. Both `BoundaryConditionDirichlet` and `BoundaryConditionNeumann`\n", + "are defined for `LaplaceDiffusion2D`.\n", + "\n", + "The hyperbolic and parabolic boundary conditions are assumed to be consistent with each other." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "boundary_condition_zero_dirichlet = BoundaryConditionDirichlet((x, t, equations) -> SVector(0.0))\n", + "\n", + "boundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),\n", + " y_neg = boundary_condition_zero_dirichlet,\n", + " y_pos = boundary_condition_do_nothing,\n", + " x_pos = boundary_condition_do_nothing)\n", + "\n", + "boundary_conditions_parabolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),\n", + " y_neg = boundary_condition_zero_dirichlet,\n", + " y_pos = boundary_condition_zero_dirichlet,\n", + " x_pos = boundary_condition_zero_dirichlet);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Defining the solver and mesh" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The process of creating the DG solver and mesh is the same as for a purely\n", + "hyperbolic system of equations." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n", + "coordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))\n", + "coordinates_max = ( 1.0, 1.0) # maximum coordinates (max(x), max(y))\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4,\n", + " periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure\n", + "\n", + "initial_condition = (x, t, equations) -> SVector(0.0);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Semidiscretizing and solving" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To semidiscretize a hyperbolic-parabolic system, we create a `SemidiscretizationHyperbolicParabolic`.\n", + "This differs from a `SemidiscretizationHyperbolic` in that we pass in a `Tuple` containing both the\n", + "hyperbolic and parabolic equation, as well as a `Tuple` containing the hyperbolic and parabolic\n", + "boundary conditions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "semi = SemidiscretizationHyperbolicParabolic(mesh,\n", + " (equations_hyperbolic, equations_parabolic),\n", + " initial_condition, solver;\n", + " boundary_conditions=(boundary_conditions_hyperbolic,\n", + " boundary_conditions_parabolic))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The rest of the code is identical to the hyperbolic case. We create a system of ODEs through\n", + "`semidiscretize`, defining callbacks, and then passing the system to OrdinaryDiffEq.jl." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "tspan = (0.0, 1.5)\n", + "ode = semidiscretize(semi, tspan)\n", + "callbacks = CallbackSet(SummaryCallback())\n", + "time_int_tol = 1.0e-6\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,\n", + " ode_default_options()..., callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We can now visualize the solution, which develops a boundary layer at the outflow boundaries." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/scalar_linear_advection_1d.ipynb b/previews/PR1697/tutorials/notebooks/scalar_linear_advection_1d.ipynb new file mode 100644 index 00000000000..5e821e90cc4 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/scalar_linear_advection_1d.ipynb @@ -0,0 +1,976 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 1: Introduction to DG methods" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This tutorial is about how to set up a simple way to approximate the solution of a hyperbolic partial\n", + "differential equation. First, we will implement a basic and naive algorithm. Then, we will use predefined\n", + "features from [Trixi.jl](https://github.com/trixi-framework/Trixi.jl) to show how you can use Trixi.jl on your own." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We will implement the scalar linear advection equation in 1D with the advection velocity $1$.\n", + "$$\n", + "u_t + u_x = 0,\\; \\text{for} \\;t\\in \\mathbb{R}^+, x\\in\\Omega=[-1,1]\n", + "$$\n", + "We define the domain $\\Omega$ by setting the boundaries." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "coordinates_min = -1.0 # minimum coordinate\n", + "coordinates_max = 1.0 # maximum coordinate" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We assume periodic boundaries and the following initial condition." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "initial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## The discontinuous Galerkin collocation spectral element method (DGSEM)\n", + "### i. Discretization of the physical domain\n", + "To improve precision we want to approximate the solution on small parts of the physical domain.\n", + "So, we split the domain $\\Omega=[-1, 1]$ into elements $Q_l$ of length $dx$." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "n_elements = 16 # number of elements\n", + "\n", + "dx = (coordinates_max - coordinates_min) / n_elements # length of one element" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To make the calculation more efficient and storing less information, we transform each element\n", + "$Q_l$ with center point $x_l$ to a reference element $E=[-1, 1]$\n", + "$$\n", + "Q_l=\\Big[x_l-\\frac{dx}{2}, x_l+\\frac{dx}{2}\\Big] \\underset{x(\\xi)}{\\overset{\\xi(x)}{\\rightleftarrows}} [-1, 1].\n", + "$$\n", + "So, for every element the transformation from the reference domain to the physical domain is defined by\n", + "$$\n", + "x(\\xi) = x_l + \\frac{dx}{2} \\xi,\\; \\xi\\in[-1, 1]\n", + "$$\n", + "Therefore,\n", + "$$\n", + "\\begin{align*}\n", + "u &= u(x(\\xi), t) \\\\\n", + "u_x &= u_\\xi \\frac{d\\xi}{dx} \\\\[3pt]\n", + "\\frac{d\\xi}{dx} &= (x_\\xi)^{-1} = \\frac{2}{dx} =: J^{-1}. \\\\\n", + "\\end{align*}\n", + "$$\n", + "Here, $J$ is the Jacobian determinant of the transformation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Using this transformation, we can transform our equation for each element $Q_l$.\n", + "$$\n", + "\\frac{dx}{2} u_t^{Q_l} + u_\\xi^{Q_l} = 0 \\text{, for }t\\in\\mathbb{R}^+,\\; \\xi\\in[-1, 1]\n", + "$$\n", + "Here, $u_t^{Q_l}$ and $u_\\xi^{Q_l}$ denote the time and spatial derivatives of the solution on the element $Q_l$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### ii. Polynomial approach\n", + "Now, we want to approximate the solution in each element $Q_l$ by a polynomial of degree $N$. Since we transformed\n", + "the equation, we can use the same polynomial approach for the reference coordinate $\\xi\\in[-1, 1]$ in every\n", + "physical element $Q_l$. This saves a lot of resources by reducing the amount of calculations needed\n", + "and storing less information." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For DGSEM we choose [Lagrange basis functions](https://en.wikipedia.org/wiki/Lagrange_polynomial)\n", + "$\\{l_j\\}_{j=0}^N$ as our polynomial basis of degree $N$ in $[-1, 1]$.\n", + "The solution in element $Q_l$ can be approximated by\n", + "$$\n", + "u(x(\\xi), t)\\big|_{Q_l} \\approx u^{Q_l}(\\xi, t) = \\sum_{j=0}^N u_j^{Q_l}(t) l_j(\\xi)\n", + "$$\n", + "with $N+1$ coefficients $\\{u_j^{Q_l}\\}_{j=0}^N$.\n", + "By construction the Lagrange basis has some useful advantages. This basis is defined by $N+1$ nodes, which\n", + "fulfill a Kronecker property at the exact same nodes. Let $\\{\\xi_i\\}_{i=0}^N$ be these nodes.\n", + "$$\n", + "l_j(\\xi_i) = \\delta_{i,j} =\n", + "\\begin{cases}\n", + "1, & \\text{if } i=j \\\\\n", + "0, & \\text{else.}\n", + "\\end{cases}\n", + "$$\n", + "Because of this property, the polynomial coefficients are exact the values of $u^{Q_l}$ at the nodes\n", + "$$\n", + "u^{Q_l}(\\xi_i, t) = \\sum_{j=0}^N u_j^{Q_l}(t) \\underbrace{l_j(\\xi_i)}_{=\\delta_{ij}} = u_i^{Q_l}(t).\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Next, we want to select the nodes $\\{\\xi_i\\}_{i=0}^N$, which we use for the construction of the Lagrange\n", + "polynomials. We choose the $N+1$ Gauss-Lobatto nodes, which are used for the\n", + "[Gaussian-Lobatto quadrature](https://mathworld.wolfram.com/LobattoQuadrature.html).\n", + "These always contain the boundary points at $-1$ and $+1$ and are well suited as interpolation nodes.\n", + "The corresponding weights will be referred to as $\\{w_j\\}_{j=0}^N$.\n", + "In Trixi.jl the basis with Lagrange polynomials on Gauss-Lobatto nodes is already defined." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi\n", + "polydeg = 3 #= polynomial degree = N =#\n", + "basis = LobattoLegendreBasis(polydeg)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The Gauss-Lobatto nodes are" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "nodes = basis.nodes" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "with the corresponding weights" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "weights = basis.weights" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To illustrate how you can integrate using numerical quadrature with this Legendre-Gauss-Lobatto nodes,\n", + "we give an example for $f(x)=x^3$. Since $f$ is of degree $3$, a polynomial interpolation with $N=3$ is exact.\n", + "Therefore, the integral on $[-1, 1]$ can be calculated by\n", + "$$\n", + "\\begin{align*}\n", + "\\int_{-1}^1 f(x) dx &= \\int_{-1}^1 \\Big( \\sum_{j=0}^3 f(\\xi_j)l_j(x) \\Big) dx\n", + "= \\sum_{j=0}^3 f(\\xi_j) \\int_{-1}^1 l_j(x)dx \\\\\n", + "&=: \\sum_{j=0}^3 f(\\xi_j) w_j\n", + "= \\sum_{j=0}^3 \\xi_j^3 w_j\n", + "\\end{align*}\n", + "$$\n", + "Let's use our nodes and weights for $N=3$ and plug in" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "integral = sum(nodes.^3 .* weights)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Using this polynomial approach leads to the equation\n", + "$$\n", + "\\frac{dx}{2} \\dot{u}^{Q_l}(\\xi, t) + u^{Q_l}(\\xi, t)' = 0\n", + "$$\n", + "with $\\dot{u}=\\frac{\\partial}{\\partial t}u$ and $u'=\\frac{\\partial}{\\partial x}u$.\n", + "To approximate the solution, we need to get the polynomial coefficients $\\{u_j^{Q_l}\\}_{j=0}^N$\n", + "for every element $Q_l$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "After defining all nodes, we can implement the spatial coordinate $x$ and its initial value $u0$\n", + "for every node." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "x = Matrix{Float64}(undef, length(nodes), n_elements)\n", + "for element in 1:n_elements\n", + " x_l = coordinates_min + (element - 1) * dx + dx/2\n", + " for i in 1:length(nodes)\n", + " ξ = nodes[i] # nodes in [-1, 1]\n", + " x[i, element] = x_l + dx/2 * ξ\n", + " end\n", + "end\n", + "\n", + "u0 = initial_condition_sine_wave.(x)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To have a look at the initial sinus curve, we plot it." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Plots\n", + "plot(vec(x), vec(u0), label=\"initial condition\", legend=:topleft)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "### iii. Variational formulation\n", + "After defining the equation and initial condition, we want to implement an algorithm to\n", + "approximate the solution." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "From now on, we only write $u$ instead of $u^{Q_l}$ for simplicity, but consider that all the following\n", + "calculation only concern one element.\n", + "Multiplying the new equation with the smooth Lagrange polynomials $\\{l_i\\}_{i=0}^N$ (test functions)\n", + "and integrating over the reference element $E=[-1,1]$, we get the variational formulation of our\n", + "transformed partial differential equation for $i=0,...,N$:\n", + "$$\n", + "\\begin{align*}\n", + "\\int_{-1}^1 \\Big( \\frac{dx}{2} \\dot{u}(\\xi, t) + u'(\\xi, t) \\Big) l_i(\\xi)d\\xi\n", + " &= \\underbrace{\\frac{dx}{2} \\int_{-1}^1 \\dot{u}(\\xi, t) l_i(\\xi)d\\xi}_{\\text{Term I}} + \\underbrace{\\int_{-1}^1 u'(\\xi, t) l_i(\\xi)d\\xi}_{\\text{Term II}} = 0\n", + "\\end{align*}\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We deal with the two terms separately. We write $\\int_{-1, N}^1 \\;\\cdot\\; d\\xi$ for the approximation\n", + "of the integral using numerical quadrature with $N+1$ basis points. We use the Gauss-Lobatto nodes\n", + "again. The numerical scalar product $\\langle\\cdot, \\cdot\\rangle_N$ is defined by\n", + "$\\langle f, g\\rangle_N := \\int_{-1, N}^1 f(\\xi) g(\\xi) d\\xi$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "#### Term I:\n", + "In the following calculation we approximate the integral numerically with quadrature on the Gauss-Lobatto\n", + "nodes $\\{\\xi_i\\}_{i=0}^N$ and then use the Kronecker property of the Lagrange polynomials. This approach\n", + "of using the same nodes for the interpolation and quadrature is called collocation.\n", + "$$\n", + "\\begin{align*}\n", + "\\frac{dx}{2} \\int_{-1}^1 \\dot{u}(\\xi, t) l_i(\\xi)d\\xi\n", + "&\\approx \\frac{dx}{2} \\int_{-1, N}^1 \\dot{u}(\\xi, t) l_i(\\xi)d\\xi \\\\\n", + "&= \\frac{dx}{2} \\sum_{k=0}^N \\underbrace{\\dot{u}(\\xi_k, t)}_{=\\dot{u}_k(t)} \\underbrace{l_i(\\xi_k)}_{=\\delta_{k,i}}w_k \\\\\n", + "&= \\frac{dx}{2} \\dot{u}_i(t) w_i\n", + "\\end{align*}\n", + "$$\n", + "We define the Legendre-Gauss-Lobatto (LGL) mass matrix $M$ and by the Kronecker property follows:\n", + "$$\n", + "M_{ij} = \\langle l_j, l_i\\rangle_N = \\delta_{ij} w_j,\\; i,j=0,...,N.\n", + "$$" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using LinearAlgebra\n", + "M = diagm(weights)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can write the integral with this new matrix.\n", + "$$\n", + "\\frac{dx}{2} \\int_{-1, N}^1 \\dot{u}(\\xi, t) \\underline{l}(\\xi)d\\xi = \\frac{dx}{2} M \\underline{\\dot{u}}(t),\n", + "$$\n", + "where $\\underline{\\dot{u}} = (\\dot{u}_0, ..., \\dot{u}_N)^T$ and $\\underline{l}$ respectively." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** Since the LGL quadrature with $N+1$ nodes is exact up to functions of degree $2N-1$ and\n", + "$\\dot{u}(\\xi, t) l_i(\\xi)$ is of degree $2N$, in general the following holds\n", + "$$\n", + "\\int_{-1}^1 \\dot{u}(\\xi, t) l_i(\\xi) d\\xi \\neq \\int_{-1, N}^1 \\dot{u}(\\xi, t) l_i(\\xi) d\\xi.\n", + "$$\n", + "With an exact integration the mass matrix would be dense. Choosing numerical integrating and quadrature\n", + "with the exact same nodes (collocation) leads to the sparse and diagonal mass matrix $M$. This\n", + "is called mass lumping and has the big advantage of an easy invertation of the matrix." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "#### Term II:\n", + "We use spatial partial integration for the second term:\n", + "$$\n", + "\\int_{-1}^1 u'(\\xi, t) l_i(\\xi) d\\xi = [u l_i]_{-1}^1 - \\int_{-1}^1 u l_i'd\\xi\n", + "$$\n", + "The resulting integral can be solved exactly with LGL quadrature since the polynomial is now\n", + "of degree $2N-1$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Again, we split the calculation in two steps." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "#### Surface term\n", + "As mentioned before, we approximate the solution with a polynomial in every element. Therefore, in\n", + "general the value of this approximation at the interfaces between two elements is not unique. To solve\n", + "this problem we introduce the idea of the numerical flux $u^*$, which will give an exact value at\n", + "the interfaces. One of many different approaches and definitions for the calculation of the\n", + "numerical flux we will deal with in 4. Numerical flux.\n", + "$$\n", + "[u l_i]_{-1}^1 = u^*\\big|^1 l_i(+1) - u^*\\big|_{-1} l_i(-1)\n", + "$$\n", + "Since the Gauss-Lobatto nodes contain the element boundaries $-1$ and $+1$, we can use the\n", + "Kronecker property of $l_i$ for the calculation of $l_i(-1)$ and $l_i(+1)$.\n", + "$$\n", + "[u \\underline{l}]_{-1}^1 = u^*\\big|^1 \\left(\\begin{array}{c} 0 \\\\ \\vdots \\\\ 0 \\\\ 1 \\end{array}\\right)\n", + "- u^*\\big|_{-1} \\left(\\begin{array}{c} 1 \\\\ 0 \\\\ \\vdots \\\\ 0\\end{array}\\right)\n", + "= B \\underline{u}^*(t)\n", + "$$\n", + "with the boundary matrix\n", + "$$\n", + "B = \\begin{pmatrix}\n", + "-1 & 0 & \\cdots & 0\\\\\n", + "0 & 0 & \\cdots & 0\\\\\n", + "\\vdots & \\vdots & 0 & 0\\\\\n", + "0 & \\cdots & 0 & 1\n", + "\\end{pmatrix}\n", + "\\qquad\\text{and}\\qquad\n", + "\\underline{u}^*(t) = \\left(\\begin{array}{c} u^*\\big|_{-1} \\\\ 0 \\\\ \\vdots \\\\ 0 \\\\ u^*\\big|^1\\end{array}\\right).\n", + "$$" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "B = diagm([-1; zeros(polydeg - 1); 1])" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "#### Volume term\n", + "As mentioned before, the new integral can be solved exact since the function inside is of degree $2N-1$.\n", + "$$\n", + "- \\int_{-1}^1 u l_i'd\\xi = - \\int_{-1, N}^1 u l_i' d\\xi\n", + "= - \\sum_{k=0}^N u(\\xi_k, t) l_i'(\\xi_k) w_k\n", + "= - \\sum_{k=0}^N u_k(t) D_{ki} w_k\n", + "$$\n", + "where $D$ is the derivative matrix defined by $D_{ki} = l_i'(\\xi_k)$ for $i,k=0,...,N$." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "D = basis.derivative_matrix" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "To show why this matrix is called the derivative matrix, we go back to our example $f(x)=x^3$.\n", + "We calculate the derivation of $f$ at the Gauss-Lobatto nodes $\\{\\xi_k\\}_{k=0}^N$ with $N=8$.\n", + "$$\n", + "f'|_{x=\\xi_k} = \\Big( \\sum_{j=0}^8 f(\\xi_j) l_j(x) \\Big)'|_{x=\\xi_k} = \\sum_{j=0}^8 f(\\xi_j) l_j'(\\xi_k)\n", + "= \\sum_{j=0}^8 f(\\xi_j) D_{kj}\n", + "$$\n", + "for $k=0,...,N$ and therefore, $\\underline{f}' = D \\underline{f}$." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "basis_N8 = LobattoLegendreBasis(8)\n", + "plot(vec(x), x -> 3 * x^2, label=\"f'\", lw=2)\n", + "scatter!(basis_N8.nodes, basis_N8.derivative_matrix * basis_N8.nodes.^3, label=\"Df\", lw=3)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Combining the volume term for every $i=0,...,N$ results in\n", + "$$\n", + "\\int_{-1}^1 u \\underline{l'} d\\xi = - D^T M \\underline{u}(t)\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Putting all parts together we get the following equation for the element $Q_l$\n", + "$$\n", + "\\frac{dx}{2} M \\underline{\\dot{u}}(t) = - B \\underline{u}^*(t) + D^T M \\underline{u}(t)\n", + "$$\n", + "or equivalent\n", + "$$\n", + "\\underline{\\dot{u}}^{Q_l}(t) = \\frac{2}{dx} \\Big[ - M^{-1} B \\underline{u}^{{Q_l}^*}(t) + M^{-1} D^T M \\underline{u}^{Q_l}(t)\\Big].\n", + "$$\n", + "This is called the weak form of the DGSEM." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** For every element $Q_l$ we get a system of $N+1$ ordinary differential equations to\n", + "calculate $N+1$ coefficients. Since the numerical flux $u^*$ is depending on extern values at\n", + "the interfaces, the equation systems of adjacent elements are weakly linked." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### iv. Numerical flux\n", + "As mentioned above, we still have to handle the problem of different values at the same point at\n", + "the interfaces. This happens with the ideas of the numerical flux $f^*(u)=u^*$. The role of $f^*$\n", + "might seem minor in this simple example, but is important for more complicated problems.\n", + "There are two values at the same spatial coordinate. Let's say we are looking at the interface between\n", + "the elements $Q_l$ and $Q_{l+1}$, while both elements got $N+1$ nodes as defined before. We call\n", + "the first value of the right element $u_R=u_0^{Q_{l+1}}$ and the last one of the left element\n", + "$u_L=u_N^{Q_l}$. So, for the value of the numerical flux on that interface the following holds\n", + "$$\n", + "u^* = u^*(u_L, u_R).\n", + "$$\n", + "These values are interpreted as start values of a so-called Riemann problem. There are many\n", + "different (approximate) Riemann solvers available and useful for different problems. We will\n", + "use the local Lax-Friedrichs flux." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "surface_flux = flux_lax_friedrichs" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The only missing ingredient is the flux calculation at the boundaries $-1$ and $+1$.\n", + "$$\n", + "u^{{Q_{first}}^*}\\big|_{-1} = u^{{Q_{first}}^*}\\big|_{-1}(u^{bound}(-1), u_R)\n", + "\\quad\\text{and}\\quad\n", + "u^{{Q_{last}}^*}\\big|^1 = u^{{Q_{last}}^*}\\big|^1(u_L, u^{bound}(1))\n", + "$$\n", + "The boundaries are periodic, which means that the last value of the last element $u^{Q_{last}}_N$\n", + "is used as $u_L$ at the first interface and accordingly for the other boundary." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Now, we implement a function, that calculates $\\underline{\\dot{u}}^{Q_l}$ for the given matrices,\n", + "$\\underline{u}$ and $\\underline{u}^*$." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function rhs!(du, u, x, t)\n", + " # Reset du and flux matrix\n", + " du .= zero(eltype(du))\n", + " flux_numerical = copy(du)\n", + "\n", + " # Calculate interface and boundary fluxes, $u^* = (u^*|_{-1}, 0, ..., 0, u^*|^1)^T$\n", + " # Since we use the flux Lax-Friedrichs from Trixi.jl, we have to pass some extra arguments.\n", + " # Trixi.jl needs the equation we are dealing with and an additional `1`, that indicates the\n", + " # first coordinate direction.\n", + " equations = LinearScalarAdvectionEquation1D(1.0)\n", + " for element in 2:n_elements-1\n", + " # left interface\n", + " flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)\n", + " flux_numerical[end, element-1] = flux_numerical[1, element]\n", + " # right interface\n", + " flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)\n", + " flux_numerical[1, element+1] = flux_numerical[end, element]\n", + " end\n", + " # boundary flux\n", + " flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)\n", + " flux_numerical[end, end] = flux_numerical[1, 1]\n", + "\n", + " # Calculate surface integrals, $- M^{-1} * B * u^*$\n", + " for element in 1:n_elements\n", + " du[:, element] -= (M \\ B) * flux_numerical[:, element]\n", + " end\n", + "\n", + " # Calculate volume integral, $+ M^{-1} * D^T * M * u$\n", + " for element in 1:n_elements\n", + " flux = u[:, element]\n", + " du[:, element] += (M \\ transpose(D)) * M * flux\n", + " end\n", + "\n", + " # Apply Jacobian from mapping to reference element\n", + " for element in 1:n_elements\n", + " du[:, element] *= 2 / dx\n", + " end\n", + "\n", + " return nothing\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Combining all definitions and the function that calculates the right-hand side, we define the ODE and\n", + "solve it until `t=2` with OrdinaryDiffEq's `solve` function and the Runge-Kutta method `RDPK3SpFSAL49()`,\n", + "which is optimized for discontinuous Galerkin methods and hyperbolic PDEs. We set some common\n", + "error tolerances `abstol=1.0e-6, reltol=1.0e-6` and pass `save_everystep=false` to avoid saving intermediate\n", + "solution vectors in memory." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "tspan = (0.0, 2.0)\n", + "ode = ODEProblem(rhs!, u0, tspan, x)\n", + "\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)\n", + "\n", + "plot(vec(x), vec(sol.u[end]), label=\"solution at t=$(tspan[2])\", legend=:topleft, lw=3)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Alternative Implementation based on Trixi.jl\n", + "Now, we implement the same example. But this time, we directly use the functionality that Trixi.jl\n", + "provides." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq, Plots" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "First, define the equation with a advection_velocity of `1`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "advection_velocity = 1.0\n", + "equations = LinearScalarAdvectionEquation1D(advection_velocity)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Then, create a DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux.\n", + "The implementation of the basis and the numerical flux is now already done." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We will now create a mesh with 16 elements for the physical domain `[-1, 1]` with periodic boundaries.\n", + "We use Trixi.jl's standard mesh `TreeMesh`. Since it's limited to hypercube domains, we\n", + "choose `2^4=16` elements. The mesh type supports AMR, that' why `n_cells_max` has to be set, even\n", + "if we don't need AMR here." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "coordinates_min = -1.0 # minimum coordinate\n", + "coordinates_max = 1.0 # maximum coordinate\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4, # number of elements = 2^4\n", + " n_cells_max=30_000) # set maximum capacity of tree data structure (only needed for AMR)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "A semidiscretization collects data structures and functions for the spatial discretization.\n", + "In Trixi.jl, an initial condition has the following parameter structure and is of the type `SVector`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "initial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Again, combining all definitions and the function that calculates the right-hand side, we define the ODE and\n", + "solve it until `t=2` with OrdinaryDiffEq's `solve` function and the Runge-Kutta method `RDPK3SpFSAL49()`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "tspan = (0.0, 2.0)\n", + "ode_trixi = semidiscretize(semi, tspan)\n", + "\n", + "sol_trixi = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We add a plot of the new approximated solution to the one calculated before." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "plot!(sol_trixi, label=\"solution at t=$(tspan[2]) with Trixi.jl\", legend=:topleft, linestyle=:dash, lw=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Summary of the code\n", + "To sum up, here is the complete code that we used." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "### Raw implementation" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "# basis: Legendre-Gauss-Lobatto\n", + "using Trixi, LinearAlgebra, OrdinaryDiffEq, Plots\n", + "polydeg = 3 #= polynomial degree =#\n", + "basis = LobattoLegendreBasis(polydeg)\n", + "nodes = basis.nodes # Gauss-Lobatto nodes in [-1, 1]\n", + "D = basis.derivative_matrix\n", + "M = diagm(basis.weights) # mass matrix\n", + "B = diagm([-1; zeros(polydeg - 1); 1])\n", + "\n", + "# mesh\n", + "coordinates_min = -1.0 # minimum coordinate\n", + "coordinates_max = 1.0 # maximum coordinate\n", + "n_elements = 16 # number of elements\n", + "\n", + "dx = (coordinates_max - coordinates_min) / n_elements # length of one element\n", + "\n", + "x = Matrix{Float64}(undef, length(nodes), n_elements)\n", + "for element in 1:n_elements\n", + " x_l = -1 + (element - 1) * dx + dx/2\n", + " for i in 1:length(nodes) # basis points in [-1, 1]\n", + " ξ = nodes[i]\n", + " x[i, element] = x_l + dx/2 * ξ\n", + " end\n", + "end\n", + "\n", + "# initial condition\n", + "initial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)\n", + "u0 = initial_condition_sine_wave.(x)\n", + "\n", + "plot(vec(x), vec(u0), label=\"initial condition\", legend=:topleft)\n", + "\n", + "# flux Lax-Friedrichs\n", + "surface_flux = flux_lax_friedrichs\n", + "\n", + "# rhs! method\n", + "function rhs!(du, u, x, t)\n", + " # reset du\n", + " du .= zero(eltype(du))\n", + " flux_numerical = copy(du)\n", + "\n", + " # calculate interface and boundary fluxes\n", + " equations = LinearScalarAdvectionEquation1D(1.0)\n", + " for element in 2:n_elements-1\n", + " # left interface\n", + " flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)\n", + " flux_numerical[end, element-1] = flux_numerical[1, element]\n", + " # right interface\n", + " flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)\n", + " flux_numerical[1, element+1] = flux_numerical[end, element]\n", + " end\n", + " # boundary flux\n", + " flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)\n", + " flux_numerical[end, end] = flux_numerical[1, 1]\n", + "\n", + " # calculate surface integrals\n", + " for element in 1:n_elements\n", + " du[:, element] -= (M \\ B) * flux_numerical[:, element]\n", + " end\n", + "\n", + " # calculate volume integral\n", + " for element in 1:n_elements\n", + " flux = u[:, element]\n", + " du[:, element] += (M \\ transpose(D)) * M * flux\n", + " end\n", + "\n", + " # apply Jacobian from mapping to reference element\n", + " for element in 1:n_elements\n", + " du[:, element] *= 2 / dx\n", + " end\n", + "\n", + " return nothing\n", + "end\n", + "\n", + "# create ODE problem\n", + "tspan = (0.0, 2.0)\n", + "ode = ODEProblem(rhs!, u0, tspan, x)\n", + "\n", + "# solve\n", + "sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)\n", + "\n", + "plot(vec(x), vec(sol.u[end]), label=\"solution at t=$(tspan[2])\", legend=:topleft, lw=3)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "### Alternative Implementation based on Trixi.jl" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi, OrdinaryDiffEq, Plots\n", + "\n", + "# equation with a advection_velocity of `1`.\n", + "advection_velocity = 1.0\n", + "equations = LinearScalarAdvectionEquation1D(advection_velocity)\n", + "\n", + "# create DG solver with flux lax friedrichs and LGL basis\n", + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)\n", + "\n", + "# distretize domain with `TreeMesh`\n", + "coordinates_min = -1.0 # minimum coordinate\n", + "coordinates_max = 1.0 # maximum coordinate\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=4, # number of elements = 2^4\n", + " n_cells_max=30_000)\n", + "\n", + "# create initial condition and semidiscretization\n", + "initial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)\n", + "\n", + "# solve\n", + "tspan = (0.0, 2.0)\n", + "ode_trixi = semidiscretize(semi, tspan)\n", + "sol_trixi = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);\n", + "\n", + "plot!(sol_trixi, label=\"solution at t=$(tspan[2]) with Trixi.jl\", legend=:topleft, linestyle=:dash, lw=2)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/shock_capturing.ipynb b/previews/PR1697/tutorials/notebooks/shock_capturing.ipynb new file mode 100644 index 00000000000..2453dfff1da --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/shock_capturing.ipynb @@ -0,0 +1,503 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 3: Shock capturing with flux differencing and stage limiter" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This tutorial contains a short summary of the idea of shock capturing for DGSEM with flux differencing\n", + "and its implementation in [Trixi.jl](https://github.com/trixi-framework/Trixi.jl).\n", + "In the second part, an implementation of a positivity preserving limiter is added to the simulation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Shock capturing with flux differencing" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The following rough explanation is on a very basic level. More information about an entropy stable\n", + "shock-capturing strategy for DGSEM discretizations of advection dominated problems, such as the\n", + "compressible Euler equations or the compressible Navier-Stokes equations, can be found in\n", + "[Hennemann et al. (2021)](https://doi.org/10.1016/j.jcp.2020.109935). In\n", + "[Rueda-Ramírez et al. (2021)](https://doi.org/10.1016/j.jcp.2021.110580) you find the extension to\n", + "the systems with non-conservative terms, such as the compressible magnetohydrodynamics (MHD) equations." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The strategy for a shock-capturing method presented by Hennemann et al. is based on a hybrid blending\n", + "of a high-order DG method with a low-order variant. The low-order subcell finite volume (FV) method is created\n", + "directly with the Legendre-Gauss-Lobatto (LGL) nodes already used for the high-order DGSEM.\n", + "Then, the final method is a convex combination with regulating indicator $\\alpha$ of these two methods." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Since the surface integral is equal for both the DG and the subcell FV method, only the volume integral divides\n", + "between the two methods." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This strategy for the volume integral is implemented in Trixi.jl under the name of\n", + "`VolumeIntegralShockCapturingHG` with the three parameters of the indicator and the volume fluxes for\n", + "the DG and the subcell FV method." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Note, that the DG method is based on the flux differencing formulation. Hence, you have to use a\n", + "two-point flux, such as `flux_ranocha`, `flux_shima_etal`, `flux_chandrashekar` or `flux_kennedy_gruber`,\n", + "for the DG volume flux. We would recommend to use the entropy conserving flux `flux_ranocha` by\n", + "[Ranocha (2018)](https://cuvillier.de/en/shop/publications/7743) for the compressible Euler equations.\n", + "````julia\n", + "volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;\n", + " volume_flux_dg=volume_flux_dg,\n", + " volume_flux_fv=volume_flux_fv)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We now focus on a choice of the shock capturing indicator `indicator_sc`.\n", + "A possible indicator is $\\alpha_{HG}$ presented by Hennemann et al. (p.10), which depends on the\n", + "current approximation with modal coefficients $\\{m_j\\}_{j=0}^N$ of a given `variable`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The indicator is calculated for every DG element by itself. First, we calculate a smooth $\\alpha$ by\n", + "$$\n", + "\\alpha = \\frac{1}{1+\\exp(-\\frac{-s}{\\mathbb{T}}(\\mathbb{E}-\\mathbb{T}))}\n", + "$$\n", + "with the total energy $\\mathbb{E}=\\max\\big(\\frac{m_N^2}{\\sum_{j=0}^N m_j^2}, \\frac{m_{N-1}^2}{\\sum_{j=0}^{N-1} m_j^2}\\big)$,\n", + "threshold $\\mathbb{T}= 0.5 * 10^{-1.8*(N+1)^{1/4}}$ and parameter $s=ln\\big(\\frac{1-0.0001}{0.0001}\\big)\\approx 9.21024$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For computational efficiency, $\\alpha_{min}$ is introduced and used for\n", + "$$\n", + "\\tilde{\\alpha} = \\begin{cases}\n", + "0, & \\text{if } \\alpha<\\alpha_{min}\\\\\n", + "\\alpha, & \\text{if } \\alpha_{min}\\leq \\alpha \\leq 1- \\alpha_{min}\\\\\n", + "1, & \\text{if } 1-\\alpha_{min}<\\alpha.\n", + "\\end{cases}\n", + "$$" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Moreover, the parameter $\\alpha_{max}$ sets a maximal value for $\\alpha$ by\n", + "$$\n", + "\\alpha = \\min\\{\\tilde{\\alpha}, \\alpha_{max}\\}.\n", + "$$\n", + "This allows to control the maximal dissipation." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "To remove numerical artifact the final indicator is smoothed with all the neighboring elements'\n", + "indicators. This is activated with `alpha_smooth=true`.\n", + "$$\n", + "\\alpha_{HG} = \\max_E \\{ \\alpha, 0.5 * \\alpha_E\\},\n", + "$$\n", + "where $E$ are all elements sharing a face with the current element." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Furthermore, you can specify the variable used for the calculation. For instance you can choose\n", + "`density`, `pressure` or both with `density_pressure` for the compressible Euler equations.\n", + "For every equation there is also the option to use the first conservation variable with `first`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "This indicator is implemented in Trixi.jl and called `IndicatorHennemannGassner` with the parameters\n", + "`equations`, `basis`, `alpha_max`, `alpha_min`, `alpha_smooth` and `variable`.\n", + "````julia\n", + "indicator_sc = IndicatorHennemannGassner(equations, basis,\n", + " alpha_max=0.5,\n", + " alpha_min=0.001,\n", + " alpha_smooth=true,\n", + " variable=variable)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Positivity preserving limiter" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Some numerical solutions are physically meaningless, for instance negative values of pressure\n", + "or density for the compressible Euler equations. This often results in crashed simulations since\n", + "the calculation of numerical fluxes or stable time steps uses mathematical operations like roots or\n", + "logarithms. One option to avoid these cases are a-posteriori positivity preserving limiters.\n", + "Trixi.jl provides the fully-discrete positivity-preserving limiter of\n", + "[Zhang, Shu (2011)](https://doi.org/10.1098/rspa.2011.0153)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "It works the following way. For every passed (scalar) variable and for every DG element we calculate\n", + "the minimal value $value_{min}$. If this value falls below the given threshold $\\varepsilon$,\n", + "the approximation is slightly adapted such that the minimal value of the relevant variable lies\n", + "now above the threshold.\n", + "$$\n", + "\\underline{u}^{new} = \\theta * \\underline{u} + (1-\\theta) * u_{mean}\n", + "$$\n", + "where $\\underline{u}$ are the collected pointwise evaluation coefficients in element $e$ and\n", + "$u_{mean}$ the integral mean of the quantity in $e$. The new coefficients are a convex combination\n", + "of these two values with factor\n", + "$$\n", + "\\theta = \\frac{value_{mean} - \\varepsilon}{value_{mean} - value_{min}},\n", + "$$\n", + "where $value_{mean}$ is the relevant variable evaluated for the mean value $u_{mean}$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The adapted approximation keeps the exact same mean value, but the relevant variable is now greater\n", + "or equal the threshold $\\varepsilon$ at every node in every element." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We specify the variables the way we did before for the shock capturing variables. For the\n", + "compressible Euler equations `density`, `pressure` or the combined variable `density_pressure`\n", + "are a reasonable choice." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "You can implement the limiter in Trixi.jl using `PositivityPreservingLimiterZhangShu` with parameters\n", + "`threshold` and `variables`.\n", + "````julia\n", + "stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=thresholds,\n", + " variables=variables)\n", + "````\n", + "Then, the limiter is added to the time integration method in the `solve` function. For instance, like\n", + "````julia\n", + "CarpenterKennedy2N54(stage_limiter!, williamson_condition=false)\n", + "````\n", + "or\n", + "````julia\n", + "SSPRK43(stage_limiter!).\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Simulation with shock capturing and positivity preserving" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can run a simulation using the described methods of shock capturing and positivity\n", + "preserving limiters. We want to give an example for the 2D compressible Euler equations." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq, Trixi\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As our initial condition we use the Sedov blast wave setup." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function initial_condition_sedov_blast_wave(x, t, equations::CompressibleEulerEquations2D)\n", + " # Set up polar coordinates\n", + " inicenter = SVector(0.0, 0.0)\n", + " x_norm = x[1] - inicenter[1]\n", + " y_norm = x[2] - inicenter[2]\n", + " r = sqrt(x_norm^2 + y_norm^2)\n", + "\n", + " r0 = 0.21875 # = 3.5 * smallest dx (for domain length=4 and max-ref=6)\n", + " # r0 = 0.5 # = more reasonable setup\n", + " E = 1.0\n", + " p0_inner = 3 * (equations.gamma - 1) * E / (3 * pi * r0^2)\n", + " p0_outer = 1.0e-5 # = true Sedov setup\n", + " # p0_outer = 1.0e-3 # = more reasonable setup\n", + "\n", + " # Calculate primitive variables\n", + " rho = 1.0\n", + " v1 = 0.0\n", + " v2 = 0.0\n", + " p = r > r0 ? p0_outer : p0_inner\n", + "\n", + " return prim2cons(SVector(rho, v1, v2, p), equations)\n", + "end\n", + "initial_condition = initial_condition_sedov_blast_wave" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "basis = LobattoLegendreBasis(3)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We set the numerical fluxes and divide between the surface flux and the two volume fluxes for the DG\n", + "and FV method. Here, we are using `flux_lax_friedrichs` and `flux_ranocha`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "surface_flux = flux_lax_friedrichs\n", + "volume_flux = flux_ranocha" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we specify the shock capturing indicator $\\alpha$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "We implement the described indicator of Hennemann, Gassner as explained above with parameters\n", + "`equations`, `basis`, `alpha_max`, `alpha_min`, `alpha_smooth` and `variable`.\n", + "Since density and pressure are the critical variables in this example, we use\n", + "`density_pressure = density * pressure = rho * p` as indicator variable." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "indicator_sc = IndicatorHennemannGassner(equations, basis,\n", + " alpha_max=0.5,\n", + " alpha_min=0.001,\n", + " alpha_smooth=true,\n", + " variable=density_pressure)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we can use the defined fluxes and the indicator to implement the volume integral using shock\n", + "capturing." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;\n", + " volume_flux_dg=volume_flux,\n", + " volume_flux_fv=surface_flux)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We finalize the discretization by implementing Trixi.jl's `solver`, `mesh`, `semi` and `ode`,\n", + "while `solver` now has the extra parameter `volume_integral`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(basis, surface_flux, volume_integral)\n", + "\n", + "coordinates_min = (-2.0, -2.0)\n", + "coordinates_max = ( 2.0, 2.0)\n", + "mesh = TreeMesh(coordinates_min, coordinates_max,\n", + " initial_refinement_level=6,\n", + " n_cells_max=10_000)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n", + "\n", + "tspan = (0.0, 1.0)\n", + "ode = semidiscretize(semi, tspan);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We add some callbacks to get an solution analysis and use a CFL-based time step size calculation." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "analysis_callback = AnalysisCallback(semi, interval=100)\n", + "\n", + "stepsize_callback = StepsizeCallback(cfl=0.8)\n", + "\n", + "callbacks = CallbackSet(analysis_callback, stepsize_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We now run the simulation using the positivity preserving limiter of Zhang and Shu for the variables\n", + "density and pressure." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=(5.0e-6, 5.0e-6),\n", + " variables=(Trixi.density, pressure))\n", + "\n", + "sol = solve(ode, CarpenterKennedy2N54(stage_limiter!, williamson_condition=false),\n", + " dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, callback=callbacks);\n", + "\n", + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/structured_mesh_mapping.ipynb b/previews/PR1697/tutorials/notebooks/structured_mesh_mapping.ipynb new file mode 100644 index 00000000000..c56e5a26da2 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/structured_mesh_mapping.ipynb @@ -0,0 +1,451 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 13: Structured mesh with curvilinear mapping" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Here, we want to introduce another mesh type of [Trixi.jl](https://github.com/trixi-framework/Trixi.jl).\n", + "More precisely, this tutorial is about the curved mesh type `StructuredMesh` supporting\n", + "curved meshes." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Creating a curved mesh\n", + "There are two basic options to define a curved `StructuredMesh` in Trixi.jl. You can\n", + "implement curves for the domain boundaries, or alternatively, set up directly the complete\n", + "transformation mapping. We now present one short example each." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Mesh defined by domain boundary curves\n", + "Both examples are based on a semdiscretization of the 2D compressible Euler equations." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "using Trixi\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We start with a pressure perturbation at `(xs, 0.0)` as initial condition." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function initial_condition_pressure_perturbation(x, t, equations::CompressibleEulerEquations2D)\n", + " xs = 1.5 # location of the initial disturbance on the x axis\n", + " w = 1/8 # half width\n", + " p = exp(-log(2) * ((x[1]-xs)^2 + x[2]^2)/w^2) + 1.0\n", + " v1 = 0.0\n", + " v2 = 0.0\n", + " rho = 1.0\n", + "\n", + " return prim2cons(SVector(rho, v1, v2, p), equations)\n", + "end\n", + "initial_condition = initial_condition_pressure_perturbation" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Initialize every boundary as a `boundary_condition_slip_wall`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "boundary_conditions = boundary_condition_slip_wall" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "The approximation setup is an entropy-stable split-form DG method with `polydeg=4`. We are using\n", + "the two fluxes `flux_ranocha` and `flux_lax_friedrichs`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "solver = DGSEM(polydeg=4, surface_flux=flux_lax_friedrichs,\n", + " volume_integral=VolumeIntegralFluxDifferencing(flux_ranocha))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We want to define a circular cylinder as physical domain. It contains an inner semicircle with\n", + "radius `r0` and an outer semicircle of radius `r1`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "![](https://user-images.githubusercontent.com/74359358/159492083-1709510f-8ba4-4416-9fb1-e2ed2a11c62c.png)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The domain boundary curves with curve parameter in $[-1,1]$ are sorted as shown in the sketch.\n", + "They always are orientated from negative to positive coordinate, such that the corners have to\n", + "fit like this $f_1(+1) = f_4(-1)$, $f_3(+1) = f_2(-1)$, etc." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "In our case we can define the domain boundary curves as follows:" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "r0 = 0.5 # inner radius\n", + "r1 = 5.0 # outer radius\n", + "f1(xi) = SVector( r0 + 0.5 * (r1 - r0) * (xi + 1), 0.0) # right line\n", + "f2(xi) = SVector(-r0 - 0.5 * (r1 - r0) * (xi + 1), 0.0) # left line\n", + "f3(eta) = SVector(r0 * cos(0.5 * pi * (eta + 1)), r0 * sin(0.5 * pi * (eta + 1))) # inner circle\n", + "f4(eta) = SVector(r1 * cos(0.5 * pi * (eta + 1)), r1 * sin(0.5 * pi * (eta + 1))) # outer circle" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We create a curved mesh with 16 x 16 elements. The defined domain boundary curves are passed as a tuple." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "cells_per_dimension = (16, 16)\n", + "mesh = StructuredMesh(cells_per_dimension, (f1, f2, f3, f4), periodicity=false)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Then, we define the simulation with endtime `T=3` with `semi`, `ode` and `callbacks`." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,\n", + " boundary_conditions=boundary_conditions)\n", + "\n", + "tspan = (0.0, 3.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "analysis_interval = 100\n", + "analysis_callback = AnalysisCallback(semi, interval=analysis_interval)\n", + "\n", + "alive_callback = AliveCallback(analysis_interval=analysis_interval)\n", + "\n", + "stepsize_callback = StepsizeCallback(cfl=0.9)\n", + "\n", + "callbacks = CallbackSet(analysis_callback,\n", + " alive_callback,\n", + " stepsize_callback);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Running the simulation" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, callback=callbacks);\n", + "\n", + "using Plots\n", + "plot(sol)" + ], + "metadata": {}, + "execution_count": null + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "pd = PlotData2D(sol)\n", + "plot(pd[\"p\"])\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "## Mesh directly defined by the transformation mapping\n", + "As mentioned before, you can also define the domain for a `StructuredMesh` by directly setting up\n", + "a transformation mapping. Here, we want to present a nice mapping, which is often used to test\n", + "free-stream preservation. Exact free-stream preservation is a crucial property of any numerical\n", + "method on curvilinear grids. The mapping is a reduced 2D version of the mapping described in\n", + "[Rueda-Ramírez et al. (2021), p.18](https://arxiv.org/abs/2012.12040)." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using OrdinaryDiffEq\n", + "using Trixi\n", + "\n", + "equations = CompressibleEulerEquations2D(1.4)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "As mentioned, this mapping is used for testing free-stream preservation. So, we use a constant\n", + "initial condition." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "initial_condition = initial_condition_constant\n", + "\n", + "solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We define the transformation mapping with variables in $[-1, 1]$ as described in\n", + "Rueda-Ramírez et al. (2021), p.18 (reduced to 2D):" + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "function mapping(xi_, eta_)\n", + " # Transform input variables between -1 and 1 onto [0,3]\n", + " xi = 1.5 * xi_ + 1.5\n", + " eta = 1.5 * eta_ + 1.5\n", + "\n", + " y = eta + 3/8 * (cos(1.5 * pi * (2 * xi - 3)/3) *\n", + " cos(0.5 * pi * (2 * eta - 3)/3))\n", + "\n", + " x = xi + 3/8 * (cos(0.5 * pi * (2 * xi - 3)/3) *\n", + " cos(2 * pi * (2 * y - 3)/3))\n", + "\n", + " return SVector(x, y)\n", + "end" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Instead of a tuple of boundary functions, the `mesh` now has the mapping as its parameter." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "cells_per_dimension = (16, 16)\n", + "mesh = StructuredMesh(cells_per_dimension, mapping)\n", + "\n", + "semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)\n", + "\n", + "tspan = (0.0, 1.0)\n", + "ode = semidiscretize(semi, tspan)\n", + "\n", + "analysis_callback = AnalysisCallback(semi, interval=250)\n", + "\n", + "stepsize_callback = StepsizeCallback(cfl=0.8)\n", + "\n", + "callbacks = CallbackSet(analysis_callback,\n", + " stepsize_callback)\n", + "\n", + "sol = solve(ode, CarpenterKennedy2N54(williamson_condition=false),\n", + " dt=1.0, # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " save_everystep=false, callback=callbacks);" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Now, we want to verify the free-stream preservation property and plot the mesh. For the verification,\n", + "we calculate the absolute difference of the first conservation variable density `u[1]` and `1.0`.\n", + "To plot this error and the mesh, we are using the visualization feature `ScalarPlotData2D`,\n", + "explained in visualization." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "error_density = let u = Trixi.wrap_array(sol.u[end], semi)\n", + " abs.(u[1, :, :, :] .- 1.0) # density, x, y, elements\n", + "end\n", + "pd = ScalarPlotData2D(error_density, semi)\n", + "\n", + "using Plots\n", + "plot(pd, title=\"Error in density\")\n", + "plot!(getmesh(pd))" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "We observe that the errors in the variable `density` are at the level of machine accuracy.\n", + "Moreover, the plot shows the mesh structure resulting from our transformation mapping." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Of course, you can also use other mappings as for instance shifts by $(x, y)$\n", + "```julia\n", + "mapping(xi, eta) = SVector(xi + x, eta + y)\n", + "```\n", + "or rotations with a rotation matrix $T$\n", + "```julia\n", + "mapping(xi, eta) = T * SVector(xi, eta).\n", + "```" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For more curved mesh mappings, please have a look at some\n", + "[elixirs for `StructuredMesh`](https://github.com/trixi-framework/Trixi.jl/tree/main/examples).\n", + "For another curved mesh type, there is a tutorial about Trixi.jl's\n", + "unstructured mesh type [`UnstructuredMesh2D`] and its use of the\n", + "[High-Order Hex-Quad Mesh (HOHQMesh) generator](https://github.com/trixi-framework/HOHQMesh),\n", + "created and developed by David Kopriva." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\", \"Plots\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/time_stepping.ipynb b/previews/PR1697/tutorials/notebooks/time_stepping.ipynb new file mode 100644 index 00000000000..e695e83f618 --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/time_stepping.ipynb @@ -0,0 +1,195 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 15: Explicit time stepping" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For the time integration, [Trixi.jl](https://github.com/trixi-framework/Trixi.jl) uses the package\n", + "[OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl) from the SciML ecosystem.\n", + "The interface to this package is the `solve(...)` function. It always requires an ODE problem and\n", + "a time integration algorithm as input parameters.\n", + "````julia\n", + "solve(ode, alg; kwargs...)\n", + "````\n", + "In Trixi.jl, the ODE problem is created by `semidiscretize(semi, tspan)` for a semidiscretization\n", + "`semi` and the time span `tspan`. In particular, `semidiscretize` returns an `ODEProblem`\n", + "used by OrdinaryDiffEq.jl." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "OrdinaryDiffEq.jl provides many integration algorithms, which are summarized in\n", + "the [documentation](https://diffeq.sciml.ai/stable/solvers/ode_solve/#Full-List-of-Methods).\n", + "Particularly interesting for Trixi.jl are their\n", + "[strong stability preserving (SSP) methods](https://diffeq.sciml.ai/stable/solvers/ode_solve/#Explicit-Strong-Stability-Preserving-Runge-Kutta-Methods-for-Hyperbolic-PDEs-(Conservation-Laws))\n", + "and [low-storage methods](https://diffeq.sciml.ai/stable/solvers/ode_solve/#Low-Storage-Methods).\n", + "There are some differences regarding the choice of the used time step." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# Error-based adaptive step sizes\n", + "First, we treat time integration algorithms with adaptive step sizes, such as `SSPRK43`. It is used in\n", + "some elixirs, like [`elixir_euler_colliding_flow.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_colliding_flow.jl)\n", + "or [`elixir_euler_astro_jet_amr.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_astro_jet_amr.jl)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Other error-based adaptive integration algorithms are for instance `RDPK3SpFSAL35`, `RDPK3Sp35`,\n", + "`RDPK3SpFSAL49`, `RDPK3Sp49`, `RDPK3SpFSAL510`, `RDPK3Sp510`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "They already contain an error-based adaptive step size control and heuristics to guess\n", + "a starting step size. If this heuristic fails in your case, you can specify an appropriately\n", + "small initial step size as keyword argument `dt=...` of `solve`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "If you run Trixi in parallel with MPI you need to pass `internalnorm=ode_norm` and you should pass `unstable_check=ode_unstable_check`\n", + "to enable MPI aware error-based adaptive step size control. These keyword arguments are also included in `ode_default_options`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "# CFL-based step size control\n", + "The SciML ecosystem also provides time integration algorithms without adaptive time stepping on\n", + "their own, such as `CarpenterKennedy2N54`. Moreover, you also can deactivate the automatic adaptivity\n", + "of adaptive integration algorithms by passing `adaptive=false` in the `solve` function." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These algorithms require another way of setting the step size. You have to pass `dt=...`\n", + "in the `solve` function. Without other settings, the simulation uses this fixed time step." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "For hyperbolic PDEs, it is natural to use an adaptive CFL-based step size control. Here, the time\n", + "step is proportional to a ratio of the local measure of mesh spacing $\\Delta x_i$ for an element `i`\n", + "and the maximum (local) wave speed $\\lambda_{\\max}$ related to the largest-magnitude eigenvalue of\n", + "the flux Jacobian of the hyperbolic system.\n", + "$$\n", + "\\Delta t_n = \\text{CFL} * \\min_i \\frac{\\Delta x_i}{\\lambda_{\\max}(u_i^n)}\n", + "$$\n", + "We compute $\\Delta x_i$ by scaling the element size by a factor of $1/(N+1)$, cf.\n", + "[Gassner and Kopriva (2011)](https://doi.org/10.1137/100807211), Section 5." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl provides such a CFL-based step size control. It is implemented as the callback\n", + "`StepsizeCallback`.\n", + "````julia\n", + "stepsize_callback = StepsizeCallback(; cfl=1.0)\n", + "````\n", + "A suitable CFL number depends on many parameters such as the chosen grid, the integration\n", + "algorithm and the polynomial degree of the spatial DG discretization. So, the optimal number\n", + "for an example is mostly determined experimentally." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "You can add this CFL-based step size control to your simulation like any other callback.\n", + "````julia\n", + "callbacks = CallbackSet(stepsize_callback)\n", + "alg = CarpenterKennedy2N54(williamson_condition=false)\n", + "solve(ode, alg;\n", + " dt=1.0 # solve needs some value here but it will be overwritten by the stepsize_callback\n", + " callback=callbacks)\n", + "````" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "You can find simple examples with a CFL-based step size control for instance in the elixirs\n", + "[`elixir_advection_basic.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_advection_basic.jl)\n", + "or [`elixir_euler_source_terms.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_dgsem/elixir_euler_source_terms.jl)." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"OrdinaryDiffEq\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/notebooks/upwind_fdsbp.ipynb b/previews/PR1697/tutorials/notebooks/upwind_fdsbp.ipynb new file mode 100644 index 00000000000..11a54d9c26e --- /dev/null +++ b/previews/PR1697/tutorials/notebooks/upwind_fdsbp.ipynb @@ -0,0 +1,219 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "source": [ + "# 7: Upwind FD SBP schemes" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "**Note:** To improve responsiveness via caching, the notebooks are updated only once a week. They are only\n", + "available for the latest stable release of Trixi.jl at the time of caching." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "General tensor product SBP methods are supported via the `DGMulti` solver\n", + "in a reasonably complete way, see the previous tutorial.\n", + "Nevertheless, there is also experimental support for SBP methods with\n", + "other solver and mesh types." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The first step is to set up an SBP operator. A classical (central) SBP\n", + "operator can be created as follows." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using Trixi\n", + "D_SBP = derivative_operator(SummationByPartsOperators.MattssonNordström2004(),\n", + " derivative_order=1, accuracy_order=2,\n", + " xmin=0.0, xmax=1.0, N=11)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Instead of prefixing the source of coefficients `MattssonNordström2004()`,\n", + "you can also load the package SummationByPartsOperators.jl. Either way,\n", + "this yields an object representing the operator efficiently. If you want to\n", + "compare it to coefficients presented in the literature, you can convert it\n", + "to a matrix." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "Matrix(D_SBP)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Upwind SBP operators are a concept introduced in 2017 by Ken Mattsson. You can\n", + "create them as follows." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "D_upw = upwind_operators(SummationByPartsOperators.Mattsson2017,\n", + " derivative_order=1, accuracy_order=2,\n", + " xmin=0.0, xmax=1.0, N=11)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Upwind operators are derivative operators biased towards one direction.\n", + "The \"minus\" variants has a bias towards the left side, i.e., it uses values\n", + "from more nodes to the left than from the right to compute the discrete\n", + "derivative approximation at a given node (in the interior of the domain).\n", + "In matrix form, this means more non-zero entries are left from the diagonal." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "Matrix(D_upw.minus)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "Analogously, the \"plus\" variant has a bias towards the right side." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "Matrix(D_upw.plus)" + ], + "metadata": {}, + "execution_count": null + }, + { + "cell_type": "markdown", + "source": [ + "For more information on upwind SBP operators, please refer to the documentation\n", + "of [SummationByPartsOperators.jl](https://github.com/ranocha/SummationByPartsOperators.jl)\n", + "and references cited there." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "The basic idea of upwind SBP schemes is to apply a flux vector splitting and\n", + "use appropriate upwind operators for both parts of the flux. In 1D, this means\n", + "to split the flux\n", + "$$\n", + "f(u) = f^-(u) + f^+(u)\n", + "$$\n", + "such that $f^-(u)$ is associated with left-going waves and $f^+(u)$ with\n", + "right-going waves. Then, we apply upwind SBP operators $D^-, D^+$ with an\n", + "appropriate upwind bias, resulting in\n", + "$$\n", + "\\partial_x f(u) \\approx D^+ f^-(u) + D^- f^+(u)\n", + "$$\n", + "Note that the established notations of upwind operators $D^\\pm$ and flux\n", + "splittings $f^\\pm$ clash. The right-going waves from $f^+$ need an operator\n", + "biased towards their upwind side, i.e., the left side. This upwind bias is\n", + "provided by the operator $D^-$." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Many classical flux vector splittings have been developed for finite volume\n", + "methods and are described in the book \"Riemann Solvers and Numerical Methods\n", + "for Fluid Dynamics: A Practical Introduction\" of Eleuterio F. Toro (2009),\n", + "[DOI: 10.1007/b79761](https://doi.org/10.1007/b79761). One such a well-known\n", + "splitting provided by Trixi.jl is `splitting_steger_warming`." + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "Trixi.jl comes with several example setups using upwind SBP methods with\n", + "flux vector splitting, e.g.,\n", + "- [`elixir_euler_vortex.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_2d_fdsbp/elixir_euler_vortex.jl)\n", + "- [`elixir_euler_taylor_green_vortex.jl`](https://github.com/trixi-framework/Trixi.jl/blob/main/examples/tree_3d_fdsbp/elixir_euler_taylor_green_vortex.jl)" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "## Package versions" + ], + "metadata": {} + }, + { + "cell_type": "markdown", + "source": [ + "These results were obtained using the following versions." + ], + "metadata": {} + }, + { + "outputs": [], + "cell_type": "code", + "source": [ + "using InteractiveUtils\n", + "versioninfo()\n", + "\n", + "using Pkg\n", + "Pkg.status([\"Trixi\", \"SummationByPartsOperators\"],\n", + " mode=PKGMODE_MANIFEST)" + ], + "metadata": {}, + "execution_count": null + } + ], + "nbformat_minor": 3, + "metadata": { + "language_info": { + "file_extension": ".jl", + "mimetype": "application/julia", + "name": "julia", + "version": "1.9.3" + }, + "kernelspec": { + "name": "julia-1.9", + "display_name": "Julia 1.9.3", + "language": "julia" + } + }, + "nbformat": 4 +} diff --git a/previews/PR1697/tutorials/out/ice_cream_curved_sides.control b/previews/PR1697/tutorials/out/ice_cream_curved_sides.control new file mode 100644 index 00000000000..2ba8e1dc5bd --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_curved_sides.control @@ -0,0 +1,65 @@ +\begin{CONTROL_INPUT} + \begin{RUN_PARAMETERS} + mesh file name = ice_cream_curved_sides.mesh + plot file name = ice_cream_curved_sides.tec + stats file name = none + mesh file format = ISM-v2 + polynomial order = 4 + plot file format = skeleton + \end{RUN_PARAMETERS} + + \begin{BACKGROUND_GRID} + background grid size = [1.0, 1.0, 0.0] + \end{BACKGROUND_GRID} + + \begin{SPRING_SMOOTHER} + smoothing = ON + smoothing type = LinearAndCrossBarSpring + number of iterations = 25 + \end{SPRING_SMOOTHER} + +\end{CONTROL_INPUT} + +\begin{MODEL} + + \begin{OUTER_BOUNDARY} + \begin{PARAMETRIC_EQUATION_CURVE} + name = OuterCircle + xEqn = x(t) = 8.0*sin(2.0*pi*t) + yEqn = y(t) = 8.0*cos(2.0*pi*t) + zEqn = z(t) = 0.0 + \end{PARAMETRIC_EQUATION_CURVE} + + \end{OUTER_BOUNDARY} + + \begin{INNER_BOUNDARIES} + + \begin{CHAIN} + name = IceCreamCone + \begin{END_POINTS_LINE} + name = LeftSlant + xStart = [-2.0, 1.0, 0.0] + xEnd = [ 0.0, -3.0, 0.0] + \end{END_POINTS_LINE} + + \begin{END_POINTS_LINE} + name = RightSlant + xStart = [ 0.0, -3.0, 0.0] + xEnd = [ 2.0, 1.0, 0.0] + \end{END_POINTS_LINE} + + \begin{CIRCULAR_ARC} + name = IceCream + units = degrees + center = [ 0.0, 1.0, 0.0] + radius = 2.0 + start angle = 0.0 + end angle = 180.0 + \end{CIRCULAR_ARC} + \end{CHAIN} + + \end{INNER_BOUNDARIES} + +\end{MODEL} +\end{FILE} + diff --git a/previews/PR1697/tutorials/out/ice_cream_curved_sides.mesh b/previews/PR1697/tutorials/out/ice_cream_curved_sides.mesh new file mode 100644 index 00000000000..5cdee3e4898 --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_curved_sides.mesh @@ -0,0 +1,1778 @@ + ISM-V2 + 256 472 216 4 + -2.6873977405837541 -6.8533127622695584 0.0000000000000000 + -2.0107216208337615 -6.8653592763871760 0.0000000000000000 + -1.0410418717253931 -6.9216393501901949 0.0000000000000000 + 2.9912702576840707E-007 -6.9498898853362308 0.0000000000000000 + 1.0410424460724244 -6.9216392767031785 0.0000000000000000 + 2.0107220324553001 -6.8653591831123713 0.0000000000000000 + 2.6873981284579389 -6.8533125932786199 0.0000000000000000 + -4.7376904454980995 -5.7175213451225044 0.0000000000000000 + -4.1206720130528520 -5.8675490522077896 0.0000000000000000 + -3.1043042956445648 -6.1731350923322887 0.0000000000000000 + -2.0036785626447200 -5.9851228109660299 0.0000000000000000 + -1.0098066418509064 -5.9615428122665204 0.0000000000000000 + 1.4706799468291222E-007 -5.9621383436589896 0.0000000000000000 + 1.0098069252998503 -5.9615427750810719 0.0000000000000000 + 2.0036788470530045 -5.9851227251882229 0.0000000000000000 + 3.1043047227986076 -6.1731348858195423 0.0000000000000000 + 4.1206723395676512 -5.8675488550488604 0.0000000000000000 + 4.7376907442183054 -5.7175210852012199 0.0000000000000000 + -5.7175290854607779 -4.7380091301910010 0.0000000000000000 + -5.0338745166877699 -5.0343954062500895 0.0000000000000000 + -4.0192675410949015 -4.9833531598216387 0.0000000000000000 + -3.0341474170277136 -5.0182548701078833 0.0000000000000000 + -2.0156881211264164 -5.0103777714865521 0.0000000000000000 + -1.0040300753799325 -4.9870767872107384 0.0000000000000000 + 6.0815912483782476E-008 -4.9814748373723354 0.0000000000000000 + 1.0040302008008126 -4.9870767661818354 0.0000000000000000 + 2.0156882686372239 -5.0103777190234284 0.0000000000000000 + 3.0341475955502211 -5.0182547800320005 0.0000000000000000 + 4.0192677419725520 -4.9833530285321146 0.0000000000000000 + 5.0338748213315210 -5.0343951447304720 0.0000000000000000 + 5.7175292975176388 -4.7380089561448235 0.0000000000000000 + -5.8675188863064056 -4.1212636296863909 0.0000000000000000 + -4.9817761240538099 -4.0207066396640707 0.0000000000000000 + -4.0043466716132494 -4.0091310423573763 0.0000000000000000 + -2.9990315694177996 -4.0029589564990600 0.0000000000000000 + -1.9980410613753681 -4.0034989440708078 0.0000000000000000 + -1.0025886914582574 -4.0005457543668728 0.0000000000000000 + 2.0716010322157786E-008 -3.9975159229364250 0.0000000000000000 + 1.0025887371619329 -4.0005457439384919 0.0000000000000000 + 1.9980411183580911 -4.0034989210294167 0.0000000000000000 + 2.9990316405720265 -4.0029589207724925 0.0000000000000000 + 4.0043467561697534 -4.0091310005645440 0.0000000000000000 + 4.9817761918620427 -4.0207066409172585 0.0000000000000000 + 5.8675188518455164 -4.1212637904706897 0.0000000000000000 + -6.8541002111688183 -2.6879947245913107 0.0000000000000000 + -6.1729085409881828 -3.1048888913844155 0.0000000000000000 + -5.0136659075640297 -3.0350713738960646 0.0000000000000000 + -3.9875424262402634 -3.0037083370185043 0.0000000000000000 + -2.9583450770060664 -2.9862077152150777 0.0000000000000000 + -1.9564448711240272 -3.0074316257274023 0.0000000000000000 + -1.0288837123639378 -3.0335503938670736 0.0000000000000000 + 1.0288837261293409 -3.0335503875679914 0.0000000000000000 + 1.9564448907221292 -3.0074316143886093 0.0000000000000000 + 2.9583450995996925 -2.9862077071259527 0.0000000000000000 + 3.9875424417605054 -3.0037083567292124 0.0000000000000000 + 5.0136658835814423 -3.0350714872829925 0.0000000000000000 + 6.1729083819393678 -3.1048892701218342 0.0000000000000000 + 6.8541000555287406 -2.6879951006708396 0.0000000000000000 + -6.8662753709801922 -2.0111701987867616 0.0000000000000000 + -5.9840270273315026 -2.0036316982582778 0.0000000000000000 + -4.9988021360598456 -2.0128444316642962 0.0000000000000000 + -3.9673460790320734 -1.9910456416213265 0.0000000000000000 + -2.9250676751279636 -1.9602609213766236 0.0000000000000000 + -1.7488220331260820 -1.8941799125227698 0.0000000000000000 + -1.0549997787868850 -2.3236466700725056 0.0000000000000000 + 1.0549997837346989 -2.3236466644045155 0.0000000000000000 + 1.7488220456724668 -1.8941798935970877 0.0000000000000000 + 2.9250676820651060 -1.9602609194579510 0.0000000000000000 + 3.9673460732862944 -1.9910456785028996 0.0000000000000000 + 4.9988021003931316 -2.0128445626745215 0.0000000000000000 + 5.9840269527385770 -2.0036319863591987 0.0000000000000000 + 6.8662752831181848 -2.0111706214718250 0.0000000000000000 + -6.9224179711968894 -1.0409114847469898 0.0000000000000000 + -5.9580972668346384 -1.0079369394830269 0.0000000000000000 + -4.9644031999205085 -0.99567599301028353 0.0000000000000000 + -3.9291101003161621 -0.97695020835669544 0.0000000000000000 + -2.9054997225222792 -0.96230280748999231 0.0000000000000000 + -1.9926400784257630 -0.87289673502189002 0.0000000000000000 + 1.9926400966711493 -0.87289669885085341 0.0000000000000000 + 2.9054997267781739 -0.96230280151691017 0.0000000000000000 + 3.9291100927795046 -0.97695023859068741 0.0000000000000000 + 4.9644031747190178 -0.99567610299695042 0.0000000000000000 + 5.9580972159582188 -1.0079372294112183 0.0000000000000000 + 6.9224178848348696 -1.0409122106557087 0.0000000000000000 + -6.9501005397333646 9.2742624259376633E-004 0.0000000000000000 + -5.9557814357875589 3.5672791828285848E-003 0.0000000000000000 + -4.9483036165862142 1.0995072712916637E-002 0.0000000000000000 + -3.8953761385874000 2.9859225313277699E-002 0.0000000000000000 + -2.7044268180022062 9.0239571225917664E-002 0.0000000000000000 + -2.0577134077941768 -0.24596023237843018 0.0000000000000000 + 2.0577134210781893 -0.24596020432330881 0.0000000000000000 + 2.7044268189529750 9.0239580439220993E-002 0.0000000000000000 + 3.8953761307951136 2.9859213141896310E-002 0.0000000000000000 + 4.9483035951629128 1.0995006083563994E-002 0.0000000000000000 + 5.9557813901342689 3.5670820551844027E-003 0.0000000000000000 + 6.9501004563400075 9.2689433946285945E-004 0.0000000000000000 + -6.9211366160086696 1.0424222176432969 0.0000000000000000 + -5.9532838484776942 1.0137526163989738 0.0000000000000000 + -4.9500311685113738 1.0133010960715971 0.0000000000000000 + -3.8931011037157370 1.0206864672017701 0.0000000000000000 + -2.8597405927114097 1.0355541279811451 0.0000000000000000 + 2.8597405855121849 1.0355541561971500 0.0000000000000000 + 3.8931010938629025 1.0206864792386088 0.0000000000000000 + 4.9500311437661138 1.0133010952219772 0.0000000000000000 + 5.9532837990717420 1.0137526003884889 0.0000000000000000 + 6.9211365315572104 1.0424222862574206 0.0000000000000000 + -6.8644255432723220 2.0119396442671040 0.0000000000000000 + -5.9770878564770857 2.0066264662415398 0.0000000000000000 + -4.9783437062948490 2.0217143918982812 0.0000000000000000 + -3.9140404518912146 2.0099176101976779 0.0000000000000000 + -2.7410761635755314 1.9789206013273941 0.0000000000000000 + -2.1286743374522938 2.2972195370402191 0.0000000000000000 + 2.1286743610257428 2.2972195426678863 0.0000000000000000 + 2.7410761638388315 1.9789206359776161 0.0000000000000000 + 3.9140404460755791 2.0099176374807124 0.0000000000000000 + 4.9783436737400066 2.0217144567818068 0.0000000000000000 + 5.9770877867144092 2.0066266051878681 0.0000000000000000 + 6.8644254594391168 2.0119399050256175 0.0000000000000000 + -6.8525413060636966 2.6881963732921865 0.0000000000000000 + -6.1678363756747823 3.1055140586749621 0.0000000000000000 + -4.9973810792864457 3.0371864629703023 0.0000000000000000 + -3.9532479064607431 3.0086876509391756 0.0000000000000000 + -2.9421500723748752 3.0044506681060703 0.0000000000000000 + -1.9325861810773708 2.9330503835958242 0.0000000000000000 + -1.2961124323034472 3.1292858466381226 0.0000000000000000 + 1.2961125095535806 3.1292858073071472 0.0000000000000000 + 1.9325862367186470 2.9330503517007265 0.0000000000000000 + 2.9421501048823253 3.0044506615488382 0.0000000000000000 + 3.9532479276365025 3.0086876615716163 0.0000000000000000 + 4.9973810641359471 3.0371865415826074 0.0000000000000000 + 6.1678362306961185 3.1055143771001839 0.0000000000000000 + 6.8525411601091664 2.6881966863964721 0.0000000000000000 + -5.8641463558607985 4.1208556574546105 0.0000000000000000 + -4.9733093718925314 4.0196757173264421 0.0000000000000000 + -3.9922265881412802 4.0059453056237606 0.0000000000000000 + -2.9890091422252363 3.9843170145084694 0.0000000000000000 + -2.0054941764375291 3.9431793687522627 0.0000000000000000 + -0.97208389168591847 3.7420513075922179 0.0000000000000000 + 4.9676272106708220E-008 3.8718978722738666 0.0000000000000000 + 0.97208398546357100 3.7420512824509329 0.0000000000000000 + 2.0054942543469472 3.9431793364082628 0.0000000000000000 + 2.9890092219353601 3.9843169730044226 0.0000000000000000 + 3.9922266832879605 4.0059452501162065 0.0000000000000000 + 4.9733094595143239 4.0196756893634520 0.0000000000000000 + 5.8641463429630729 4.1208557832656991 0.0000000000000000 + -5.7158908831846356 4.7374654742093689 0.0000000000000000 + -5.0310753814344409 5.0329859200420142 0.0000000000000000 + -4.0146693983288904 4.9778067867170375 0.0000000000000000 + -3.0301613062086163 5.0005146435834220 0.0000000000000000 + -2.0111150485345335 4.9601592448796588 0.0000000000000000 + -0.99816482806907292 4.9040223934159526 0.0000000000000000 + 6.5559167275215029E-008 4.8889229740908711 0.0000000000000000 + 0.99816495902914193 4.9040223703928012 0.0000000000000000 + 2.0111151922869741 4.9601591923650652 0.0000000000000000 + 3.0301614770132304 5.0005145532717288 0.0000000000000000 + 4.0146696060123634 4.9778066411423163 0.0000000000000000 + 5.0310757370402959 5.0329856029402960 0.0000000000000000 + 5.7158911418430645 4.7374652500277525 0.0000000000000000 + -4.7366408724331448 5.7163969255377962 0.0000000000000000 + -4.1192062592906806 5.8644052326761127 0.0000000000000000 + -3.1027380900121511 6.1648179887777212 0.0000000000000000 + -2.0015559213129070 5.9647195940348077 0.0000000000000000 + -1.0080842121091849 5.9307120578964962 0.0000000000000000 + 1.2809144579091231E-007 5.9271981412979953 0.0000000000000000 + 1.0080844592290032 5.9307120244791536 0.0000000000000000 + 2.0015561708518548 5.9647195166171958 0.0000000000000000 + 3.1027384683617534 6.1648178022211253 0.0000000000000000 + 4.1192065691366757 5.8644050357600435 0.0000000000000000 + 4.7366412086031051 5.7163966234799082 0.0000000000000000 + -2.6868851371343672 6.8498717712581927 0.0000000000000000 + -2.0100960238839289 6.8591082624958490 0.0000000000000000 + -1.0405857107919183 6.9126053965829257 0.0000000000000000 + 2.5020681072890381E-007 6.9397443383701223 0.0000000000000000 + 1.0405861922485977 6.9126053343110048 0.0000000000000000 + 2.0100963728176224 6.8591081816647161 0.0000000000000000 + 2.6868854733549496 6.8498716232438612 0.0000000000000000 + -3.6705104009983383 -7.1082595194719094 0.0000000000000000 + -3.0442865551243687 -7.3981294507658495 0.0000000000000000 + -2.1863978152204240 -7.6954314104928097 0.0000000000000000 + -1.1313695802431920 -7.9195961306685545 0.0000000000000000 + 3.6410209097182056E-009 -8.0000000000000000 0.0000000000000000 + 1.1313715929171260 -7.9195958431437754 0.0000000000000000 + 2.1863978152204160 -7.6954314104928123 0.0000000000000000 + 3.0442865551243607 -7.3981294507658522 0.0000000000000000 + 3.6705121720218252 -7.1082586049636394 0.0000000000000000 + 4.4376011313588206 -6.6564026469980702 0.0000000000000000 + 5.1002019105058052 -6.1634357684714240 0.0000000000000000 + 5.6568541807137214 -5.6568543182710380 0.0000000000000000 + 6.1634357684714249 -5.1002019105058043 0.0000000000000000 + 6.6564026469980728 -4.4376011313588162 0.0000000000000000 + 7.1082586387364719 -3.6705121066178656 0.0000000000000000 + 7.3981294507658539 -3.0442865551243559 0.0000000000000000 + 7.6954314104928132 -2.1863978152204129 0.0000000000000000 + 7.9195958648410292 -1.1313714410364422 0.0000000000000000 + 7.9999999999999973 -1.9089446951922548E-007 0.0000000000000000 + 7.9195958696254367 1.1313714075456063 0.0000000000000000 + 7.6954314104928123 2.1863978152204151 0.0000000000000000 + 7.3981294507658530 3.0442865551243603 0.0000000000000000 + 7.1082586908781771 3.6705120056410205 0.0000000000000000 + 6.6564026469980719 4.4376011313588171 0.0000000000000000 + 6.1634357684714232 5.1002019105058070 0.0000000000000000 + 5.6568544506792646 5.6568540483054894 0.0000000000000000 + 5.1002019105058061 6.1634357684714240 0.0000000000000000 + 4.4376011313588162 6.6564026469980728 0.0000000000000000 + 3.6705119402370614 7.1082587246510069 0.0000000000000000 + 3.0442865551243585 7.3981294507658530 0.0000000000000000 + 2.1863978152204191 7.6954314104928114 0.0000000000000000 + 1.1313712556649234 7.9195958913226860 0.0000000000000000 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + -1.1313695802431916 7.9195961306685545 0.0000000000000000 + -2.1863978152204133 7.6954314104928132 0.0000000000000000 + -3.0442865551243616 7.3981294507658522 0.0000000000000000 + -3.6705104009983285 7.1082595194719147 0.0000000000000000 + -4.4376011313588100 6.6564026469980773 0.0000000000000000 + -5.1002019105058114 6.1634357684714187 0.0000000000000000 + -5.6568527973323857 5.6568557016520025 0.0000000000000000 + -6.1634357684714214 5.1002019105058087 0.0000000000000000 + -6.6564026469980755 4.4376011313588126 0.0000000000000000 + -7.1082595194719094 3.6705104009983378 0.0000000000000000 + -7.3981294507658477 3.0442865551243714 0.0000000000000000 + -7.6954314104928097 2.1863978152204235 0.0000000000000000 + -7.9195961306685545 1.1313695802431951 0.0000000000000000 + -7.9999999999997362 2.0536640888705361E-006 0.0000000000000000 + -7.9195961306685545 -1.1313695802431909 0.0000000000000000 + -7.6954314104928114 -2.1863978152204195 0.0000000000000000 + -7.3981294507658522 -3.0442865551243612 0.0000000000000000 + -7.1082595194719147 -3.6705104009983280 0.0000000000000000 + -6.6564026469980782 -4.4376011313588091 0.0000000000000000 + -6.1634357684714196 -5.1002019105058105 0.0000000000000000 + -5.6568527973323830 -5.6568557016520042 0.0000000000000000 + -5.1002019105058114 -6.1634357684714187 0.0000000000000000 + -4.4376011313588135 -6.6564026469980755 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 0.84062499397195267 -1.3187500120560947 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.5593750060280469 0.11875001205609381 0.0000000000000000 + 1.8406249939719526 0.68124998794390512 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9234528539428934 1.5480229180052039 0.0000000000000000 + 1.7577069153495042 1.9541836299856183 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 0.95418362998561834 2.7577069153495040 0.0000000000000000 + 0.54802294711610822 2.9234528456487245 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -0.54802270862631064 2.9234529135983243 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.7577069153495022 1.9541836299856215 0.0000000000000000 + -1.9234529135983240 1.5480227086263110 0.0000000000000000 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.5593750060280471 0.11875001205609437 0.0000000000000000 + -1.2000000031251037 -0.59999999374979263 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 1 2 1 136 1 4 + 2 11 1 2 2 4 + 10 11 1 9 3 1 + 1 10 1 135 4 -4 + 2 3 2 137 1 4 + 3 12 2 3 2 4 + 11 12 2 10 3 1 + 3 4 3 138 1 4 + 4 13 3 4 2 4 + 12 13 3 11 3 1 + 4 5 4 139 1 4 + 5 14 4 5 2 4 + 13 14 4 12 3 1 + 5 6 5 140 1 4 + 6 15 5 6 2 4 + 14 15 5 13 3 1 + 6 7 6 141 1 4 + 7 16 6 142 2 4 + 15 16 6 14 3 1 + 8 9 7 189 1 4 + 9 21 7 8 2 4 + 20 21 7 18 3 1 + 8 20 7 188 4 -4 + 9 10 8 190 1 4 + 10 22 8 9 2 4 + 21 22 8 19 3 1 + 11 23 9 10 2 4 + 22 23 9 20 3 1 + 12 24 10 11 2 4 + 23 24 10 21 3 1 + 13 25 11 12 2 4 + 24 25 11 22 3 1 + 14 26 12 13 2 4 + 25 26 12 23 3 1 + 15 27 13 14 2 4 + 26 27 13 24 3 1 + 16 28 14 15 2 4 + 27 28 14 25 3 1 + 16 17 15 143 1 4 + 17 29 15 16 2 4 + 28 29 15 26 3 1 + 17 18 16 144 1 4 + 18 30 16 145 2 4 + 29 30 16 27 3 1 + 19 20 17 187 1 4 + 20 33 17 18 2 4 + 32 33 17 29 3 1 + 19 32 17 186 4 -4 + 21 34 18 19 2 4 + 33 34 18 30 3 1 + 22 35 19 20 2 4 + 34 35 19 31 3 1 + 23 36 20 21 2 4 + 35 36 20 32 3 1 + 24 37 21 22 2 4 + 36 37 21 33 3 1 + 25 38 22 23 2 4 + 37 38 22 191 3 2 + 26 39 23 24 2 4 + 38 39 23 192 3 2 + 27 40 24 25 2 4 + 39 40 24 34 3 1 + 28 41 25 26 2 4 + 40 41 25 35 3 1 + 29 42 26 27 2 4 + 41 42 26 36 3 1 + 30 43 27 28 2 4 + 42 43 27 37 3 1 + 30 31 28 146 1 4 + 31 44 28 147 2 4 + 43 44 28 38 3 1 + 33 47 29 30 2 4 + 46 47 29 40 3 1 + 32 46 29 185 4 -4 + 34 48 30 31 2 4 + 47 48 30 41 3 1 + 35 49 31 32 2 4 + 48 49 31 42 3 1 + 36 50 32 33 2 4 + 49 50 32 43 3 1 + 37 51 33 191 2 -1 + 50 51 33 44 3 1 + 40 53 34 35 2 4 + 52 53 34 45 3 1 + 39 52 34 192 4 -3 + 41 54 35 36 2 4 + 53 54 35 46 3 1 + 42 55 36 37 2 4 + 54 55 36 47 3 1 + 43 56 37 38 2 4 + 55 56 37 48 3 1 + 44 57 38 148 2 4 + 56 57 38 49 3 1 + 45 46 39 184 1 4 + 46 60 39 40 2 4 + 59 60 39 51 3 1 + 45 59 39 183 4 -4 + 47 61 40 41 2 4 + 60 61 40 52 3 1 + 48 62 41 42 2 4 + 61 62 41 53 3 1 + 49 63 42 43 2 4 + 62 63 42 54 3 1 + 50 64 43 44 2 4 + 63 64 43 55 3 1 + 51 65 44 216 2 -1 + 64 65 44 215 3 1 + 53 67 45 46 2 4 + 66 67 45 194 3 1 + 52 66 45 193 4 1 + 54 68 46 47 2 4 + 67 68 46 56 3 1 + 55 69 47 48 2 4 + 68 69 47 57 3 1 + 56 70 48 49 2 4 + 69 70 48 58 3 1 + 57 71 49 50 2 4 + 70 71 49 59 3 1 + 57 58 50 149 1 4 + 58 72 50 150 2 4 + 71 72 50 60 3 1 + 60 74 51 52 2 4 + 73 74 51 61 3 1 + 59 73 51 182 4 -4 + 61 75 52 53 2 4 + 74 75 52 62 3 1 + 62 76 53 54 2 4 + 75 76 53 63 3 1 + 63 77 54 55 2 4 + 76 77 54 64 3 1 + 64 78 55 214 2 -1 + 77 78 55 65 3 1 + 68 80 56 57 2 4 + 79 80 56 66 3 1 + 67 79 56 195 4 1 + 69 81 57 58 2 4 + 80 81 57 67 3 1 + 70 82 58 59 2 4 + 81 82 58 68 3 1 + 71 83 59 60 2 4 + 82 83 59 69 3 1 + 72 84 60 151 2 4 + 83 84 60 70 3 1 + 74 86 61 62 2 4 + 85 86 61 71 3 1 + 73 85 61 181 4 -4 + 75 87 62 63 2 4 + 86 87 62 72 3 1 + 76 88 63 64 2 4 + 87 88 63 73 3 1 + 77 89 64 65 2 4 + 88 89 64 74 3 1 + 78 90 65 213 2 -1 + 89 90 65 212 3 1 + 80 92 66 67 2 4 + 91 92 66 197 3 1 + 79 91 66 196 4 1 + 81 93 67 68 2 4 + 92 93 67 75 3 1 + 82 94 68 69 2 4 + 93 94 68 76 3 1 + 83 95 69 70 2 4 + 94 95 69 77 3 1 + 84 96 70 152 2 4 + 95 96 70 78 3 1 + 86 98 71 72 2 4 + 97 98 71 79 3 1 + 85 97 71 180 4 -4 + 87 99 72 73 2 4 + 98 99 72 80 3 1 + 88 100 73 74 2 4 + 99 100 73 81 3 1 + 89 101 74 211 2 -1 + 100 101 74 82 3 1 + 93 103 75 76 2 4 + 102 103 75 83 3 1 + 92 102 75 198 4 1 + 94 104 76 77 2 4 + 103 104 76 84 3 1 + 95 105 77 78 2 4 + 104 105 77 85 3 1 + 96 106 78 153 2 4 + 105 106 78 86 3 1 + 98 108 79 80 2 4 + 107 108 79 87 3 1 + 97 107 79 179 4 -4 + 99 109 80 81 2 4 + 108 109 80 88 3 1 + 100 110 81 82 2 4 + 109 110 81 89 3 1 + 101 111 82 210 2 -1 + 110 111 82 90 3 1 + 103 115 83 84 2 4 + 114 115 83 93 3 1 + 102 114 83 199 4 1 + 104 116 84 85 2 4 + 115 116 84 94 3 1 + 105 117 85 86 2 4 + 116 117 85 95 3 1 + 106 118 86 154 2 4 + 117 118 86 96 3 1 + 108 120 87 88 2 4 + 119 120 87 177 3 -4 + 107 119 87 178 4 -4 + 109 121 88 89 2 4 + 120 121 88 97 3 1 + 110 122 89 90 2 4 + 121 122 89 98 3 1 + 111 123 90 91 2 4 + 122 123 90 99 3 1 + 111 112 91 209 1 -1 + 112 124 91 208 2 -1 + 123 124 91 100 3 1 + 113 114 92 200 1 -1 + 114 128 92 93 2 4 + 127 128 92 103 3 1 + 113 127 92 201 4 1 + 115 129 93 94 2 4 + 128 129 93 104 3 1 + 116 130 94 95 2 4 + 129 130 94 105 3 1 + 117 131 95 96 2 4 + 130 131 95 106 3 1 + 118 132 96 155 2 4 + 131 132 96 156 3 -4 + 121 134 97 98 2 4 + 133 134 97 107 3 1 + 120 133 97 176 4 -4 + 122 135 98 99 2 4 + 134 135 98 108 3 1 + 123 136 99 100 2 4 + 135 136 99 109 3 1 + 124 137 100 101 2 4 + 136 137 100 110 3 1 + 124 125 101 207 1 -1 + 125 138 101 206 2 -1 + 137 138 101 111 3 1 + 126 127 102 202 1 -1 + 127 141 102 103 2 4 + 140 141 102 114 3 1 + 126 140 102 203 4 1 + 128 142 103 104 2 4 + 141 142 103 115 3 1 + 129 143 104 105 2 4 + 142 143 104 116 3 1 + 130 144 105 106 2 4 + 143 144 105 117 3 1 + 131 145 106 157 2 4 + 144 145 106 118 3 1 + 134 147 107 108 2 4 + 146 147 107 174 3 -4 + 133 146 107 175 4 -4 + 135 148 108 109 2 4 + 147 148 108 119 3 1 + 136 149 109 110 2 4 + 148 149 109 120 3 1 + 137 150 110 111 2 4 + 149 150 110 121 3 1 + 138 151 111 112 2 4 + 150 151 111 122 3 1 + 138 139 112 205 1 -1 + 139 152 112 113 2 4 + 151 152 112 123 3 1 + 139 140 113 204 1 -1 + 140 153 113 114 2 4 + 152 153 113 124 3 1 + 141 154 114 115 2 4 + 153 154 114 125 3 1 + 142 155 115 116 2 4 + 154 155 115 126 3 1 + 143 156 116 117 2 4 + 155 156 116 127 3 1 + 144 157 117 118 2 4 + 156 157 117 128 3 1 + 145 158 118 158 2 4 + 157 158 118 159 3 -4 + 148 160 119 120 2 4 + 159 160 119 172 3 -4 + 147 159 119 173 4 -4 + 149 161 120 121 2 4 + 160 161 120 171 3 -4 + 150 162 121 122 2 4 + 161 162 121 129 3 1 + 151 163 122 123 2 4 + 162 163 122 130 3 1 + 152 164 123 124 2 4 + 163 164 123 131 3 1 + 153 165 124 125 2 4 + 164 165 124 132 3 1 + 154 166 125 126 2 4 + 165 166 125 133 3 1 + 155 167 126 127 2 4 + 166 167 126 134 3 1 + 156 168 127 128 2 4 + 167 168 127 162 3 -4 + 157 169 128 160 2 4 + 168 169 128 161 3 -4 + 162 171 129 130 2 4 + 170 171 129 169 3 -4 + 161 170 129 170 4 -4 + 163 172 130 131 2 4 + 171 172 130 168 3 -4 + 164 173 131 132 2 4 + 172 173 131 167 3 -4 + 165 174 132 133 2 4 + 173 174 132 166 3 -4 + 166 175 133 134 2 4 + 174 175 133 165 3 -4 + 167 176 134 163 2 4 + 175 176 134 164 3 -4 + 10 177 135 190 1 3 + 177 178 135 0 2 0 + 1 178 135 136 3 1 + 178 179 136 0 2 0 + 2 179 136 137 3 1 + 179 180 137 0 2 0 + 3 180 137 138 3 1 + 180 181 138 0 2 0 + 4 181 138 139 3 1 + 181 182 139 0 2 0 + 5 182 139 140 3 1 + 182 183 140 0 2 0 + 6 183 140 141 3 1 + 183 184 141 0 2 0 + 7 184 141 142 3 1 + 184 185 142 0 2 0 + 16 185 142 143 3 1 + 185 186 143 0 2 0 + 17 186 143 144 3 1 + 186 187 144 0 2 0 + 18 187 144 145 3 1 + 187 188 145 0 2 0 + 30 188 145 146 3 1 + 188 189 146 0 2 0 + 31 189 146 147 3 1 + 189 190 147 0 2 0 + 44 190 147 148 3 1 + 190 191 148 0 2 0 + 57 191 148 149 3 1 + 191 192 149 0 2 0 + 58 192 149 150 3 1 + 192 193 150 0 2 0 + 72 193 150 151 3 1 + 193 194 151 0 2 0 + 84 194 151 152 3 1 + 194 195 152 0 2 0 + 96 195 152 153 3 1 + 195 196 153 0 2 0 + 106 196 153 154 3 1 + 196 197 154 0 2 0 + 118 197 154 155 3 1 + 197 198 155 0 2 0 + 132 198 155 156 3 1 + 198 199 156 0 2 0 + 131 199 156 157 3 1 + 199 200 157 0 2 0 + 145 200 157 158 3 1 + 200 201 158 0 2 0 + 158 201 158 159 3 1 + 201 202 159 0 2 0 + 157 202 159 160 3 1 + 202 203 160 0 2 0 + 169 203 160 161 3 1 + 203 204 161 0 2 0 + 168 204 161 162 3 1 + 204 205 162 0 2 0 + 167 205 162 163 3 1 + 205 206 163 0 2 0 + 176 206 163 164 3 1 + 206 207 164 0 2 0 + 175 207 164 165 3 1 + 207 208 165 0 2 0 + 174 208 165 166 3 1 + 208 209 166 0 2 0 + 173 209 166 167 3 1 + 209 210 167 0 2 0 + 172 210 167 168 3 1 + 210 211 168 0 2 0 + 171 211 168 169 3 1 + 211 212 169 0 2 0 + 170 212 169 170 3 1 + 212 213 170 0 2 0 + 161 213 170 171 3 1 + 213 214 171 0 2 0 + 160 214 171 172 3 1 + 214 215 172 0 2 0 + 159 215 172 173 3 1 + 215 216 173 0 2 0 + 147 216 173 174 3 1 + 216 217 174 0 2 0 + 146 217 174 175 3 1 + 217 218 175 0 2 0 + 133 218 175 176 3 1 + 218 219 176 0 2 0 + 120 219 176 177 3 1 + 219 220 177 0 2 0 + 119 220 177 178 3 1 + 220 221 178 0 2 0 + 107 221 178 179 3 1 + 221 222 179 0 2 0 + 97 222 179 180 3 1 + 222 223 180 0 2 0 + 85 223 180 181 3 1 + 223 224 181 0 2 0 + 73 224 181 182 3 1 + 224 225 182 0 2 0 + 59 225 182 183 3 1 + 225 226 183 0 2 0 + 45 226 183 184 3 1 + 226 227 184 0 2 0 + 46 227 184 185 3 1 + 227 228 185 0 2 0 + 32 228 185 186 3 1 + 228 229 186 0 2 0 + 19 229 186 187 3 1 + 229 230 187 0 2 0 + 20 230 187 188 3 1 + 230 231 188 0 2 0 + 8 231 188 189 3 1 + 231 232 189 0 2 0 + 9 232 189 190 3 1 + 232 177 190 0 2 0 + 233 38 191 192 3 1 + 51 233 191 216 4 2 + 233 52 192 193 4 -4 + 66 234 193 194 2 4 + 233 234 193 0 3 0 + 67 235 194 195 2 4 + 234 235 194 0 3 0 + 79 236 195 196 2 4 + 235 236 195 0 3 0 + 91 237 196 197 2 4 + 236 237 196 0 3 0 + 92 238 197 198 2 4 + 237 238 197 0 3 0 + 102 239 198 199 2 4 + 238 239 198 0 3 0 + 114 240 199 200 2 4 + 239 240 199 0 3 0 + 113 241 200 201 2 4 + 240 241 200 0 3 0 + 127 242 201 202 2 4 + 241 242 201 0 3 0 + 126 243 202 203 2 4 + 242 243 202 0 3 0 + 140 244 203 204 2 4 + 243 244 203 0 3 0 + 139 245 204 205 2 4 + 244 245 204 0 3 0 + 138 246 205 206 2 4 + 245 246 205 0 3 0 + 125 247 206 207 2 4 + 246 247 206 0 3 0 + 124 248 207 208 2 4 + 247 248 207 0 3 0 + 112 249 208 209 2 4 + 248 249 208 0 3 0 + 111 250 209 210 2 4 + 249 250 209 0 3 0 + 101 251 210 211 2 4 + 250 251 210 0 3 0 + 89 252 211 212 2 4 + 251 252 211 0 3 0 + 90 253 212 213 2 4 + 252 253 212 0 3 0 + 78 254 213 214 2 4 + 253 254 213 0 3 0 + 64 255 214 215 2 4 + 254 255 214 0 3 0 + 65 256 215 216 2 4 + 255 256 215 0 3 0 + 256 233 216 0 3 0 + 1 2 11 10 + 0 0 0 0 + --- --- --- --- + 2 3 12 11 + 0 0 0 0 + --- --- --- --- + 3 4 13 12 + 0 0 0 0 + --- --- --- --- + 4 5 14 13 + 0 0 0 0 + --- --- --- --- + 5 6 15 14 + 0 0 0 0 + --- --- --- --- + 6 7 16 15 + 0 0 0 0 + --- --- --- --- + 8 9 21 20 + 0 0 0 0 + --- --- --- --- + 9 10 22 21 + 0 0 0 0 + --- --- --- --- + 10 11 23 22 + 0 0 0 0 + --- --- --- --- + 11 12 24 23 + 0 0 0 0 + --- --- --- --- + 12 13 25 24 + 0 0 0 0 + --- --- --- --- + 13 14 26 25 + 0 0 0 0 + --- --- --- --- + 14 15 27 26 + 0 0 0 0 + --- --- --- --- + 15 16 28 27 + 0 0 0 0 + --- --- --- --- + 16 17 29 28 + 0 0 0 0 + --- --- --- --- + 17 18 30 29 + 0 0 0 0 + --- --- --- --- + 19 20 33 32 + 0 0 0 0 + --- --- --- --- + 20 21 34 33 + 0 0 0 0 + --- --- --- --- + 21 22 35 34 + 0 0 0 0 + --- --- --- --- + 22 23 36 35 + 0 0 0 0 + --- --- --- --- + 23 24 37 36 + 0 0 0 0 + --- --- --- --- + 24 25 38 37 + 0 0 0 0 + --- --- --- --- + 25 26 39 38 + 0 0 0 0 + --- --- --- --- + 26 27 40 39 + 0 0 0 0 + --- --- --- --- + 27 28 41 40 + 0 0 0 0 + --- --- --- --- + 28 29 42 41 + 0 0 0 0 + --- --- --- --- + 29 30 43 42 + 0 0 0 0 + --- --- --- --- + 30 31 44 43 + 0 0 0 0 + --- --- --- --- + 32 33 47 46 + 0 0 0 0 + --- --- --- --- + 33 34 48 47 + 0 0 0 0 + --- --- --- --- + 34 35 49 48 + 0 0 0 0 + --- --- --- --- + 35 36 50 49 + 0 0 0 0 + --- --- --- --- + 36 37 51 50 + 0 0 0 0 + --- --- --- --- + 39 40 53 52 + 0 0 0 0 + --- --- --- --- + 40 41 54 53 + 0 0 0 0 + --- --- --- --- + 41 42 55 54 + 0 0 0 0 + --- --- --- --- + 42 43 56 55 + 0 0 0 0 + --- --- --- --- + 43 44 57 56 + 0 0 0 0 + --- --- --- --- + 45 46 60 59 + 0 0 0 0 + --- --- --- --- + 46 47 61 60 + 0 0 0 0 + --- --- --- --- + 47 48 62 61 + 0 0 0 0 + --- --- --- --- + 48 49 63 62 + 0 0 0 0 + --- --- --- --- + 49 50 64 63 + 0 0 0 0 + --- --- --- --- + 50 51 65 64 + 0 0 0 0 + --- --- --- --- + 52 53 67 66 + 0 0 0 0 + --- --- --- --- + 53 54 68 67 + 0 0 0 0 + --- --- --- --- + 54 55 69 68 + 0 0 0 0 + --- --- --- --- + 55 56 70 69 + 0 0 0 0 + --- --- --- --- + 56 57 71 70 + 0 0 0 0 + --- --- --- --- + 57 58 72 71 + 0 0 0 0 + --- --- --- --- + 59 60 74 73 + 0 0 0 0 + --- --- --- --- + 60 61 75 74 + 0 0 0 0 + --- --- --- --- + 61 62 76 75 + 0 0 0 0 + --- --- --- --- + 62 63 77 76 + 0 0 0 0 + --- --- --- --- + 63 64 78 77 + 0 0 0 0 + --- --- --- --- + 67 68 80 79 + 0 0 0 0 + --- --- --- --- + 68 69 81 80 + 0 0 0 0 + --- --- --- --- + 69 70 82 81 + 0 0 0 0 + --- --- --- --- + 70 71 83 82 + 0 0 0 0 + --- --- --- --- + 71 72 84 83 + 0 0 0 0 + --- --- --- --- + 73 74 86 85 + 0 0 0 0 + --- --- --- --- + 74 75 87 86 + 0 0 0 0 + --- --- --- --- + 75 76 88 87 + 0 0 0 0 + --- --- --- --- + 76 77 89 88 + 0 0 0 0 + --- --- --- --- + 77 78 90 89 + 0 0 0 0 + --- --- --- --- + 79 80 92 91 + 0 0 0 0 + --- --- --- --- + 80 81 93 92 + 0 0 0 0 + --- --- --- --- + 81 82 94 93 + 0 0 0 0 + --- --- --- --- + 82 83 95 94 + 0 0 0 0 + --- --- --- --- + 83 84 96 95 + 0 0 0 0 + --- --- --- --- + 85 86 98 97 + 0 0 0 0 + --- --- --- --- + 86 87 99 98 + 0 0 0 0 + --- --- --- --- + 87 88 100 99 + 0 0 0 0 + --- --- --- --- + 88 89 101 100 + 0 0 0 0 + --- --- --- --- + 92 93 103 102 + 0 0 0 0 + --- --- --- --- + 93 94 104 103 + 0 0 0 0 + --- --- --- --- + 94 95 105 104 + 0 0 0 0 + --- --- --- --- + 95 96 106 105 + 0 0 0 0 + --- --- --- --- + 97 98 108 107 + 0 0 0 0 + --- --- --- --- + 98 99 109 108 + 0 0 0 0 + --- --- --- --- + 99 100 110 109 + 0 0 0 0 + --- --- --- --- + 100 101 111 110 + 0 0 0 0 + --- --- --- --- + 102 103 115 114 + 0 0 0 0 + --- --- --- --- + 103 104 116 115 + 0 0 0 0 + --- --- --- --- + 104 105 117 116 + 0 0 0 0 + --- --- --- --- + 105 106 118 117 + 0 0 0 0 + --- --- --- --- + 107 108 120 119 + 0 0 0 0 + --- --- --- --- + 108 109 121 120 + 0 0 0 0 + --- --- --- --- + 109 110 122 121 + 0 0 0 0 + --- --- --- --- + 110 111 123 122 + 0 0 0 0 + --- --- --- --- + 111 112 124 123 + 0 0 0 0 + --- --- --- --- + 113 114 128 127 + 0 0 0 0 + --- --- --- --- + 114 115 129 128 + 0 0 0 0 + --- --- --- --- + 115 116 130 129 + 0 0 0 0 + --- --- --- --- + 116 117 131 130 + 0 0 0 0 + --- --- --- --- + 117 118 132 131 + 0 0 0 0 + --- --- --- --- + 120 121 134 133 + 0 0 0 0 + --- --- --- --- + 121 122 135 134 + 0 0 0 0 + --- --- --- --- + 122 123 136 135 + 0 0 0 0 + --- --- --- --- + 123 124 137 136 + 0 0 0 0 + --- --- --- --- + 124 125 138 137 + 0 0 0 0 + --- --- --- --- + 126 127 141 140 + 0 0 0 0 + --- --- --- --- + 127 128 142 141 + 0 0 0 0 + --- --- --- --- + 128 129 143 142 + 0 0 0 0 + --- --- --- --- + 129 130 144 143 + 0 0 0 0 + --- --- --- --- + 130 131 145 144 + 0 0 0 0 + --- --- --- --- + 133 134 147 146 + 0 0 0 0 + --- --- --- --- + 134 135 148 147 + 0 0 0 0 + --- --- --- --- + 135 136 149 148 + 0 0 0 0 + --- --- --- --- + 136 137 150 149 + 0 0 0 0 + --- --- --- --- + 137 138 151 150 + 0 0 0 0 + --- --- --- --- + 138 139 152 151 + 0 0 0 0 + --- --- --- --- + 139 140 153 152 + 0 0 0 0 + --- --- --- --- + 140 141 154 153 + 0 0 0 0 + --- --- --- --- + 141 142 155 154 + 0 0 0 0 + --- --- --- --- + 142 143 156 155 + 0 0 0 0 + --- --- --- --- + 143 144 157 156 + 0 0 0 0 + --- --- --- --- + 144 145 158 157 + 0 0 0 0 + --- --- --- --- + 147 148 160 159 + 0 0 0 0 + --- --- --- --- + 148 149 161 160 + 0 0 0 0 + --- --- --- --- + 149 150 162 161 + 0 0 0 0 + --- --- --- --- + 150 151 163 162 + 0 0 0 0 + --- --- --- --- + 151 152 164 163 + 0 0 0 0 + --- --- --- --- + 152 153 165 164 + 0 0 0 0 + --- --- --- --- + 153 154 166 165 + 0 0 0 0 + --- --- --- --- + 154 155 167 166 + 0 0 0 0 + --- --- --- --- + 155 156 168 167 + 0 0 0 0 + --- --- --- --- + 156 157 169 168 + 0 0 0 0 + --- --- --- --- + 161 162 171 170 + 0 0 0 0 + --- --- --- --- + 162 163 172 171 + 0 0 0 0 + --- --- --- --- + 163 164 173 172 + 0 0 0 0 + --- --- --- --- + 164 165 174 173 + 0 0 0 0 + --- --- --- --- + 165 166 175 174 + 0 0 0 0 + --- --- --- --- + 166 167 176 175 + 0 0 0 0 + --- --- --- --- + 10 177 178 1 + 0 1 0 0 + -3.6705104009983383 -7.1082595194719094 0.0000000000000000 + -3.5803997071952218 -7.1540714237919358 0.0000000000000000 + -3.3605253584455799 -7.2599496771840100 0.0000000000000000 + -3.1375238868024042 -7.3590722146031649 0.0000000000000000 + -3.0442865551243754 -7.3981294507658468 0.0000000000000000 + --- OuterCircle --- --- + 1 178 179 2 + 0 1 0 0 + -3.0442865551243754 -7.3981294507658468 0.0000000000000000 + -2.9208434333314410 -7.4477294283536244 0.0000000000000000 + -2.6195632955431121 -7.5589607844361328 0.0000000000000000 + -2.3140614803533142 -7.6580101504989546 0.0000000000000000 + -2.1863978152204173 -7.6954314104928114 0.0000000000000000 + --- OuterCircle --- --- + 2 179 180 3 + 0 1 0 0 + -2.1863978152204173 -7.6954314104928114 0.0000000000000000 + -2.0339247302763477 -7.7371280325176395 0.0000000000000000 + -1.6626658046773015 -7.8253142059572776 0.0000000000000000 + -1.2876240548142968 -7.8956965679706554 0.0000000000000000 + -1.1313695802431920 -7.9195961306685545 0.0000000000000000 + --- OuterCircle --- --- + 3 180 181 4 + 0 1 0 0 + -1.1313695802431920 -7.9195961306685545 0.0000000000000000 + -0.96656542320610084 -7.9413947945346735 0.0000000000000000 + -0.56711151925005809 -7.9798737160893651 0.0000000000000000 + -0.16623058505690086 -7.9982727755804657 0.0000000000000000 + 3.6410244624318844E-009 -8.0000000000000000 0.0000000000000000 + --- OuterCircle --- --- + 4 181 182 5 + 0 1 0 0 + 3.6410244624318844E-009 -8.0000000000000000 0.0000000000000000 + 0.16623088894862023 -7.9982727692645836 0.0000000000000000 + 0.56711253687833307 -7.9798736437687676 0.0000000000000000 + 0.96656714691797452 -7.9413945847375480 0.0000000000000000 + 1.1313715929171329 -7.9195958431437745 0.0000000000000000 + --- OuterCircle --- --- + 5 182 183 6 + 0 1 0 0 + 1.1313715929171329 -7.9195958431437745 0.0000000000000000 + 1.2876257675546530 -7.8956962886581001 0.0000000000000000 + 1.6626667990339425 -7.8253139946835502 0.0000000000000000 + 2.0339250182345823 -7.7371279568196014 0.0000000000000000 + 2.1863978152204191 -7.6954314104928114 0.0000000000000000 + --- OuterCircle --- --- + 6 183 184 7 + 0 1 0 0 + 2.1863978152204191 -7.6954314104928114 0.0000000000000000 + 2.3140614803533164 -7.6580101504989546 0.0000000000000000 + 2.6195632955431036 -7.5589607844361355 0.0000000000000000 + 2.9208434333314228 -7.4477294283536315 0.0000000000000000 + 3.0442865551243541 -7.3981294507658548 0.0000000000000000 + --- OuterCircle --- --- + 7 184 185 16 + 0 1 0 0 + 3.0442865551243541 -7.3981294507658548 0.0000000000000000 + 3.1375241553142388 -7.3590721001237425 0.0000000000000000 + 3.3605262628541577 -7.2599492585463343 0.0000000000000000 + 3.5804012286008309 -7.1540706623735320 0.0000000000000000 + 3.6705121720218283 -7.1082586049636376 0.0000000000000000 + --- OuterCircle --- --- + 16 185 186 17 + 0 1 0 0 + 3.6705121720218283 -7.1082586049636376 0.0000000000000000 + 3.7859245146957798 -7.0474658969749919 0.0000000000000000 + 4.0603471263922497 -6.8930095903892514 0.0000000000000000 + 4.3284784509689231 -6.7278729402016557 0.0000000000000000 + 4.4376011313588206 -6.6564026469980702 0.0000000000000000 + --- OuterCircle --- --- + 17 186 187 18 + 0 1 0 0 + 4.4376011313588206 -6.6564026469980702 0.0000000000000000 + 4.5377671295720710 -6.5885255921014112 0.0000000000000000 + 4.7752670922349045 -6.4184752237442186 0.0000000000000000 + 5.0064007762506497 -6.2398678886300862 0.0000000000000000 + 5.1002019105058052 -6.1634357684714240 0.0000000000000000 + --- OuterCircle --- --- + 18 187 188 30 + 0 1 0 0 + 5.1002019105058052 -6.1634357684714240 0.0000000000000000 + 5.1846655472125462 -6.0925563734402353 0.0000000000000000 + 5.3844888456410187 -5.9166950125190203 0.0000000000000000 + 5.5783507939965791 -5.7342830780419041 0.0000000000000000 + 5.6568541807137214 -5.6568543182710380 0.0000000000000000 + --- OuterCircle --- --- + 30 188 189 31 + 0 1 0 0 + 5.6568541807137214 -5.6568543182710380 0.0000000000000000 + 5.7342829622587921 -5.5783509130161875 0.0000000000000000 + 5.9166949470519077 -5.3844889175789401 0.0000000000000000 + 6.0925563549769590 -5.1846655689089411 0.0000000000000000 + 6.1634357684714249 -5.1002019105058043 0.0000000000000000 + --- OuterCircle --- --- + 31 189 190 44 + 0 1 0 0 + 6.1634357684714249 -5.1002019105058043 0.0000000000000000 + 6.2398678886300871 -5.0064007762506488 0.0000000000000000 + 6.4184752237442195 -4.7752670922349036 0.0000000000000000 + 6.5885255921014121 -4.5377671295720701 0.0000000000000000 + 6.6564026469980710 -4.4376011313588197 0.0000000000000000 + --- OuterCircle --- --- + 44 190 191 57 + 0 1 0 0 + 6.6564026469980710 -4.4376011313588197 0.0000000000000000 + 6.7278729460341653 -4.3284784419032931 0.0000000000000000 + 6.8930096090691286 -4.0603470946805356 0.0000000000000000 + 7.0474659267083171 -3.7859244593474495 0.0000000000000000 + 7.1082586387364701 -3.6705121066178688 0.0000000000000000 + --- OuterCircle --- --- + 57 191 192 58 + 0 1 0 0 + 7.1082586387364701 -3.6705121066178688 0.0000000000000000 + 7.1540706904927474 -3.5804011724152676 0.0000000000000000 + 7.2599492740066429 -3.3605262294543121 0.0000000000000000 + 7.3590721043514726 -3.1375241453980860 0.0000000000000000 + 7.3981294507658548 -3.0442865551243545 0.0000000000000000 + --- OuterCircle --- --- + 58 192 193 72 + 0 1 0 0 + 7.3981294507658548 -3.0442865551243545 0.0000000000000000 + 7.4477294283536315 -2.9208434333314215 0.0000000000000000 + 7.5589607844361355 -2.6195632955431023 0.0000000000000000 + 7.6580101504989546 -2.3140614803533150 0.0000000000000000 + 7.6954314104928114 -2.1863978152204178 0.0000000000000000 + --- OuterCircle --- --- + 72 193 194 84 + 0 1 0 0 + 7.6954314104928114 -2.1863978152204178 0.0000000000000000 + 7.7371279625319387 -2.0339249965046329 0.0000000000000000 + 7.8253140106267232 -1.6626667239976600 0.0000000000000000 + 7.8956963097356363 -1.2876256383075975 0.0000000000000000 + 7.9195958648410283 -1.1313714410364439 0.0000000000000000 + --- OuterCircle --- --- + 84 194 195 96 + 0 1 0 0 + 7.9195958648410283 -1.1313714410364439 0.0000000000000000 + 7.9413945972463518 -0.96656704414461170 0.0000000000000000 + 7.9798736425696513 -0.56711255375116587 0.0000000000000000 + 7.9982727664103441 -0.16623102628154870 0.0000000000000000 + 7.9999999999999973 -1.9089446951922548E-007 0.0000000000000000 + --- OuterCircle --- --- + 96 195 196 106 + 0 1 0 0 + 7.9999999999999973 -1.9089446951922548E-007 0.0000000000000000 + 7.9982727732846479 0.16623069552132208 0.0000000000000000 + 7.9798736573010984 0.56711234646407993 0.0000000000000000 + 7.9413946074905288 0.96656695997760744 0.0000000000000000 + 7.9195958696254358 1.1313714075456114 0.0000000000000000 + --- OuterCircle --- --- + 106 196 197 118 + 0 1 0 0 + 7.9195958696254358 1.1313714075456114 0.0000000000000000 + 7.8956963143833914 1.2876256098076511 0.0000000000000000 + 7.8253140141423119 1.6626667074515964 0.0000000000000000 + 7.7371279637915515 2.0339249917130173 0.0000000000000000 + 7.6954314104928114 2.1863978152204187 0.0000000000000000 + --- OuterCircle --- --- + 118 197 198 132 + 0 1 0 0 + 7.6954314104928114 2.1863978152204187 0.0000000000000000 + 7.6580101504989546 2.3140614803533159 0.0000000000000000 + 7.5589607844361355 2.6195632955431032 0.0000000000000000 + 7.4477294283536315 2.9208434333314224 0.0000000000000000 + 7.3981294507658548 3.0442865551243554 0.0000000000000000 + --- OuterCircle --- --- + 132 198 199 131 + 0 1 0 0 + 7.3981294507658548 3.0442865551243554 0.0000000000000000 + 7.3590721108786434 3.1375241300885865 0.0000000000000000 + 7.2599492978757336 3.3605261778884632 0.0000000000000000 + 7.1540707339058658 3.5804010856706525 0.0000000000000000 + 7.1082586908781789 3.6705120056410174 0.0000000000000000 + --- OuterCircle --- --- + 131 199 200 145 + 0 1 0 0 + 7.1082586908781789 3.6705120056410174 0.0000000000000000 + 7.0474659726134474 3.7859243738954413 0.0000000000000000 + 6.8930096379088956 4.0603470457209783 0.0000000000000000 + 6.7278729550389462 4.3284784279069148 0.0000000000000000 + 6.6564026469980710 4.4376011313588197 0.0000000000000000 + --- OuterCircle --- --- + 145 200 201 158 + 0 1 0 0 + 6.6564026469980710 4.4376011313588197 0.0000000000000000 + 6.5885255921014068 4.5377671295720763 0.0000000000000000 + 6.4184752237442195 4.7752670922349036 0.0000000000000000 + 6.2398678886300898 5.0064007762506453 0.0000000000000000 + 6.1634357684714249 5.1002019105058043 0.0000000000000000 + --- OuterCircle --- --- + 158 201 202 157 + 0 1 0 0 + 6.1634357684714249 5.1002019105058043 0.0000000000000000 + 6.0925563912123897 5.1846655263282955 0.0000000000000000 + 5.9166950755355483 5.3844887763958980 0.0000000000000000 + 5.7342831894909869 5.5783506794321447 0.0000000000000000 + 5.6568544506792646 5.6568540483054885 0.0000000000000000 + --- OuterCircle --- --- + 157 202 203 169 + 0 1 0 0 + 5.6568544506792646 5.6568540483054885 0.0000000000000000 + 5.5783510275806201 5.7342828508097012 0.0000000000000000 + 5.3844889868240617 5.9166948840353761 0.0000000000000000 + 5.1846655897931875 6.0925563372048082 0.0000000000000000 + 5.1002019105058034 6.1634357684714258 0.0000000000000000 + --- OuterCircle --- --- + 169 203 204 168 + 0 1 0 0 + 5.1002019105058034 6.1634357684714258 0.0000000000000000 + 5.0064007762506453 6.2398678886300907 0.0000000000000000 + 4.7752670922349036 6.4184752237442195 0.0000000000000000 + 4.5377671295720763 6.5885255921014076 0.0000000000000000 + 4.4376011313588188 6.6564026469980710 0.0000000000000000 + --- OuterCircle --- --- + 168 204 205 167 + 0 1 0 0 + 4.4376011313588188 6.6564026469980710 0.0000000000000000 + 4.3284784188412866 6.7278729608714549 0.0000000000000000 + 4.0603470140092695 6.8930096565887684 0.0000000000000000 + 3.7859243185471225 7.0474660023467655 0.0000000000000000 + 3.6705119402370658 7.1082587246510052 0.0000000000000000 + --- OuterCircle --- --- + 167 205 206 176 + 0 1 0 0 + 3.6705119402370658 7.1082587246510052 0.0000000000000000 + 3.5804010294850976 7.1540707620250759 0.0000000000000000 + 3.3605261444886256 7.2599493133360387 0.0000000000000000 + 3.1375241201724351 7.3590721151063727 0.0000000000000000 + 3.0442865551243541 7.3981294507658548 0.0000000000000000 + --- OuterCircle --- --- + 176 206 207 175 + 0 1 0 0 + 3.0442865551243541 7.3981294507658548 0.0000000000000000 + 2.9208434333314224 7.4477294283536315 0.0000000000000000 + 2.6195632955431032 7.5589607844361355 0.0000000000000000 + 2.3140614803533159 7.6580101504989546 0.0000000000000000 + 2.1863978152204182 7.6954314104928114 0.0000000000000000 + --- OuterCircle --- --- + 175 207 208 174 + 0 1 0 0 + 2.1863978152204182 7.6954314104928114 0.0000000000000000 + 2.0339249699830715 7.7371279695038888 0.0000000000000000 + 1.6626666324153139 7.8253140300854840 0.0000000000000000 + 1.2876254805605953 7.8956963354609258 0.0000000000000000 + 1.1313712556649251 7.9195958913226860 0.0000000000000000 + --- OuterCircle --- --- + 174 208 209 173 + 0 1 0 0 + 1.1313712556649251 7.9195958913226860 0.0000000000000000 + 0.96656685773355411 7.9413946199349068 0.0000000000000000 + 0.56711236515284669 7.9798736559729280 0.0000000000000000 + 0.16623083596138777 7.9982727703658352 0.0000000000000000 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + --- OuterCircle --- --- + 173 209 210 172 + 0 1 0 0 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + -0.16623058816404371 7.9982727755158889 0.0000000000000000 + -0.56711152106598395 7.9798737159603110 0.0000000000000000 + -0.96656542373539966 7.9413947944702512 0.0000000000000000 + -1.1313695802431845 7.9195961306685554 0.0000000000000000 + --- OuterCircle --- --- + 172 210 211 171 + 0 1 0 0 + -1.1313695802431845 7.9195961306685554 0.0000000000000000 + -1.2876240548142890 7.8956965679706572 0.0000000000000000 + -1.6626658046772940 7.8253142059572793 0.0000000000000000 + -2.0339247302763508 7.7371280325176395 0.0000000000000000 + -2.1863978152204200 7.6954314104928105 0.0000000000000000 + --- OuterCircle --- --- + 171 211 212 170 + 0 1 0 0 + -2.1863978152204200 7.6954314104928105 0.0000000000000000 + -2.3140614803533204 7.6580101504989528 0.0000000000000000 + -2.6195632955431045 7.5589607844361346 0.0000000000000000 + -2.9208434333314273 7.4477294283536297 0.0000000000000000 + -3.0442865551243550 7.3981294507658548 0.0000000000000000 + --- OuterCircle --- --- + 170 212 213 161 + 0 1 0 0 + -3.0442865551243550 7.3981294507658548 0.0000000000000000 + -3.1375238868023905 7.3590722146031711 0.0000000000000000 + -3.3605253584455697 7.2599496771840144 0.0000000000000000 + -3.5803997071952116 7.1540714237919403 0.0000000000000000 + -3.6705104009983285 7.1082595194719147 0.0000000000000000 + --- OuterCircle --- --- + 161 213 214 160 + 0 1 0 0 + -3.6705104009983285 7.1082595194719147 0.0000000000000000 + -3.7859230159610333 7.0474667021005866 0.0000000000000000 + -4.0603462676951780 6.8930100962071599 0.0000000000000000 + -4.3284782054877473 6.7278730981356629 0.0000000000000000 + -4.4376011313588100 6.6564026469980773 0.0000000000000000 + --- OuterCircle --- --- + 160 214 215 159 + 0 1 0 0 + -4.4376011313588100 6.6564026469980773 0.0000000000000000 + -4.5377671295720692 6.5885255921014121 0.0000000000000000 + -4.7752670922349054 6.4184752237442178 0.0000000000000000 + -5.0064007762506559 6.2398678886300809 0.0000000000000000 + -5.1002019105058114 6.1634357684714187 0.0000000000000000 + --- OuterCircle --- --- + 159 215 216 147 + 0 1 0 0 + -5.1002019105058114 6.1634357684714187 0.0000000000000000 + -5.1846653290170721 6.0925565591209976 0.0000000000000000 + -5.3844881221784417 5.9166956709061242 0.0000000000000000 + -5.5783495970446006 5.7342842424449403 0.0000000000000000 + -5.6568527973323901 5.6568557016519971 0.0000000000000000 + --- OuterCircle --- --- + 147 216 217 146 + 0 1 0 0 + -5.6568527973323901 5.6568557016519971 0.0000000000000000 + -5.7342817978554761 5.5783521099679048 0.0000000000000000 + -5.9166942886646945 5.3844896410414416 0.0000000000000000 + -6.0925561692961825 5.1846657871044126 0.0000000000000000 + -6.1634357684714214 5.1002019105058087 0.0000000000000000 + --- OuterCircle --- --- + 146 217 218 133 + 0 1 0 0 + -6.1634357684714214 5.1002019105058087 0.0000000000000000 + -6.2398678886300836 5.0064007762506533 0.0000000000000000 + -6.4184752237442160 4.7752670922349090 0.0000000000000000 + -6.5885255921014103 4.5377671295720718 0.0000000000000000 + -6.6564026469980710 4.4376011313588188 0.0000000000000000 + --- OuterCircle --- --- + 133 218 219 120 + 0 1 0 0 + -6.6564026469980710 4.4376011313588188 0.0000000000000000 + -6.7278730981356611 4.3284782054877509 0.0000000000000000 + -6.8930100962071545 4.0603462676951878 0.0000000000000000 + -7.0474667021005848 3.7859230159610364 0.0000000000000000 + -7.1082595194719094 3.6705104009983378 0.0000000000000000 + --- OuterCircle --- --- + 120 219 220 119 + 0 1 0 0 + -7.1082595194719094 3.6705104009983378 0.0000000000000000 + -7.1540714237919358 3.5803997071952214 0.0000000000000000 + -7.2599496771840100 3.3605253584455794 0.0000000000000000 + -7.3590722146031666 3.1375238868024007 0.0000000000000000 + -7.3981294507658477 3.0442865551243714 0.0000000000000000 + --- OuterCircle --- --- + 119 220 221 107 + 0 1 0 0 + -7.3981294507658477 3.0442865551243714 0.0000000000000000 + -7.4477294283536226 2.9208434333314437 0.0000000000000000 + -7.5589607844361311 2.6195632955431147 0.0000000000000000 + -7.6580101504989537 2.3140614803533173 0.0000000000000000 + -7.6954314104928114 2.1863978152204169 0.0000000000000000 + --- OuterCircle --- --- + 107 221 222 97 + 0 1 0 0 + -7.6954314104928114 2.1863978152204169 0.0000000000000000 + -7.7371280325176404 2.0339247302763472 0.0000000000000000 + -7.8253142059572784 1.6626658046772975 0.0000000000000000 + -7.8956965679706554 1.2876240548142996 0.0000000000000000 + -7.9195961306685545 1.1313695802431951 0.0000000000000000 + --- OuterCircle --- --- + 97 222 223 85 + 0 1 0 0 + -7.9195961306685545 1.1313695802431951 0.0000000000000000 + -7.9413947581331668 0.96656572228434601 0.0000000000000000 + -7.9798736431692099 0.56711254531473887 0.0000000000000000 + -7.9982727390922488 0.16623234069752618 0.0000000000000000 + -7.9999999999997362 2.0536640888705361E-006 0.0000000000000000 + --- OuterCircle --- --- + 85 223 224 73 + 0 1 0 0 + -7.9999999999997362 2.0536640888705361E-006 0.0000000000000000 + -7.9982728119391444 -0.16622883563054935 0.0000000000000000 + -7.9798737887512807 -0.56711049681722270 0.0000000000000000 + -7.9413948308073232 -0.96656512518646220 0.0000000000000000 + -7.9195961306685563 -1.1313695802431840 0.0000000000000000 + --- OuterCircle --- --- + 73 224 225 59 + 0 1 0 0 + -7.9195961306685563 -1.1313695802431840 0.0000000000000000 + -7.8956965679706572 -1.2876240548142885 0.0000000000000000 + -7.8253142059572793 -1.6626658046772935 0.0000000000000000 + -7.7371280325176395 -2.0339247302763503 0.0000000000000000 + -7.6954314104928114 -2.1863978152204195 0.0000000000000000 + --- OuterCircle --- --- + 59 225 226 45 + 0 1 0 0 + -7.6954314104928114 -2.1863978152204195 0.0000000000000000 + -7.6580101504989528 -2.3140614803533199 0.0000000000000000 + -7.5589607844361355 -2.6195632955431041 0.0000000000000000 + -7.4477294283536297 -2.9208434333314268 0.0000000000000000 + -7.3981294507658548 -3.0442865551243545 0.0000000000000000 + --- OuterCircle --- --- + 45 226 227 46 + 0 1 0 0 + -7.3981294507658548 -3.0442865551243545 0.0000000000000000 + -7.3590722146031711 -3.1375238868023900 0.0000000000000000 + -7.2599496771840144 -3.3605253584455692 0.0000000000000000 + -7.1540714237919403 -3.5803997071952112 0.0000000000000000 + -7.1082595194719147 -3.6705104009983280 0.0000000000000000 + --- OuterCircle --- --- + 46 227 228 32 + 0 1 0 0 + -7.1082595194719147 -3.6705104009983280 0.0000000000000000 + -7.0474667021005866 -3.7859230159610329 0.0000000000000000 + -6.8930100962071599 -4.0603462676951780 0.0000000000000000 + -6.7278730981356638 -4.3284782054877473 0.0000000000000000 + -6.6564026469980782 -4.4376011313588091 0.0000000000000000 + --- OuterCircle --- --- + 32 228 229 19 + 0 1 0 0 + -6.6564026469980782 -4.4376011313588091 0.0000000000000000 + -6.5885255921014130 -4.5377671295720683 0.0000000000000000 + -6.4184752237442186 -4.7752670922349054 0.0000000000000000 + -6.2398678886300818 -5.0064007762506559 0.0000000000000000 + -6.1634357684714196 -5.1002019105058105 0.0000000000000000 + --- OuterCircle --- --- + 19 229 230 20 + 0 1 0 0 + -6.1634357684714196 -5.1002019105058105 0.0000000000000000 + -6.0925561692961807 -5.1846657871044153 0.0000000000000000 + -5.9166942886646918 -5.3844896410414433 0.0000000000000000 + -5.7342817978554717 -5.5783521099679092 0.0000000000000000 + -5.6568527973323857 -5.6568557016520016 0.0000000000000000 + --- OuterCircle --- --- + 20 230 231 8 + 0 1 0 0 + -5.6568527973323857 -5.6568557016520016 0.0000000000000000 + -5.5783495970445989 -5.7342842424449421 0.0000000000000000 + -5.3844881221784373 -5.9166956709061287 0.0000000000000000 + -5.1846653290170703 -6.0925565591209994 0.0000000000000000 + -5.1002019105058114 -6.1634357684714187 0.0000000000000000 + --- OuterCircle --- --- + 8 231 232 9 + 0 1 0 0 + -5.1002019105058114 -6.1634357684714187 0.0000000000000000 + -5.0064007762506542 -6.2398678886300827 0.0000000000000000 + -4.7752670922349063 -6.4184752237442178 0.0000000000000000 + -4.5377671295720754 -6.5885255921014076 0.0000000000000000 + -4.4376011313588188 -6.6564026469980710 0.0000000000000000 + --- OuterCircle --- --- + 9 232 177 10 + 0 1 0 0 + -4.4376011313588188 -6.6564026469980710 0.0000000000000000 + -4.3284782054877544 -6.7278730981356594 0.0000000000000000 + -4.0603462676951878 -6.8930100962071537 0.0000000000000000 + -3.7859230159610400 -7.0474667021005830 0.0000000000000000 + -3.6705104009983383 -7.1082595194719094 0.0000000000000000 + --- OuterCircle --- --- + 51 37 38 233 + 0 0 0 0 + --- --- --- --- + 233 38 39 52 + 0 0 0 0 + --- --- --- --- + 52 66 234 233 + 0 0 1 0 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 8.1918573019674312E-002 -2.8361628539606514 0.0000000000000000 + 0.27968750301402334 -2.4406249939719533 0.0000000000000000 + 0.47745643300837237 -2.0450871339832553 0.0000000000000000 + 0.55937500602804668 -1.8812499879439066 0.0000000000000000 + --- --- RightSlant --- + 66 67 235 234 + 0 0 1 0 + 0.55937500602804668 -1.8812499879439066 0.0000000000000000 + 0.60056311315811417 -1.7988737736837717 0.0000000000000000 + 0.69999999999999973 -1.6000000000000005 0.0000000000000000 + 0.79943688684188530 -1.4011262263162294 0.0000000000000000 + 0.84062499397195278 -1.3187500120560944 0.0000000000000000 + --- --- RightSlant --- + 67 79 236 235 + 0 0 1 0 + 0.84062499397195278 -1.3187500120560944 0.0000000000000000 + 0.89325425707682937 -1.2134914858463413 0.0000000000000000 + 1.0203125378423255 -0.95937492431534910 0.0000000000000000 + 1.1473708186078211 -0.70525836278435783 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + --- --- RightSlant --- + 79 91 237 236 + 0 0 1 0 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.2526293208844796 -0.49474135823104071 0.0000000000000000 + 1.3796875438703724 -0.24062491225925520 0.0000000000000000 + 1.5067457668562652 1.3491533712530313E-002 0.0000000000000000 + 1.5593750060280467 0.11875001205609337 0.0000000000000000 + --- --- RightSlant --- + 91 92 238 237 + 0 0 1 0 + 1.5593750060280467 0.11875001205609337 0.0000000000000000 + 1.6005631131581151 0.20112622631623012 0.0000000000000000 + 1.6999999999999993 0.39999999999999858 0.0000000000000000 + 1.7994368868418849 0.59887377368376971 0.0000000000000000 + 1.8406249939719528 0.68124998794390557 0.0000000000000000 + --- --- RightSlant --- + 92 102 239 238 + 0 0 1 0 + 1.8406249939719528 0.68124998794390557 0.0000000000000000 + 1.8639649232289370 0.72792984645787406 0.0000000000000000 + 1.9203124969859759 0.84062499397195189 0.0000000000000000 + 1.9766600707430158 0.95332014148603150 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + --- --- RightSlant --- + 102 114 240 239 + 0 0 1 0 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9983479703871072 1.0812735458173770 0.0000000000000000 + 1.9807707726899886 1.2766715490561058 0.0000000000000000 + 1.9441339362737691 1.4694073261344140 0.0000000000000000 + 1.9234528539428932 1.5480229180052043 0.0000000000000000 + --- --- IceCream --- + 114 113 241 240 + 0 0 1 0 + 1.9234528539428932 1.5480229180052043 0.0000000000000000 + 1.9048209196670516 1.6096369936271651 0.0000000000000000 + 1.8517494276368289 1.7556613376683212 0.0000000000000000 + 1.7875027702478623 1.8971253236623173 0.0000000000000000 + 1.7577069153495042 1.9541836299856179 0.0000000000000000 + --- --- IceCream --- + 113 127 242 241 + 0 0 1 0 + 1.7577069153495042 1.9541836299856179 0.0000000000000000 + 1.7159031169606289 2.0274611881744238 0.0000000000000000 + 1.6025531944504807 2.1965881743342441 0.0000000000000000 + 1.4725959561431350 2.3533148746507173 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + --- --- IceCream --- + 127 126 243 242 + 0 0 1 0 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 1.3533148446578711 2.4725959837065434 0.0000000000000000 + 1.1965881552143354 2.6025532087268597 0.0000000000000000 + 1.0274611821782322 2.7159031205510731 0.0000000000000000 + 0.95418362998561790 2.7577069153495044 0.0000000000000000 + --- --- IceCream --- + 126 140 244 243 + 0 0 1 0 + 0.95418362998561790 2.7577069153495044 0.0000000000000000 + 0.89712532762418773 2.7875027682594489 0.0000000000000000 + 0.75566135168116888 2.8517494219184703 0.0000000000000000 + 0.60963701823418193 2.9048209117915880 0.0000000000000000 + 0.54802294711610733 2.9234528456487245 0.0000000000000000 + --- --- IceCream --- + 140 139 245 244 + 0 0 1 0 + 0.54802294711610733 2.9234528456487245 0.0000000000000000 + 0.46940735118449745 2.9441339302254752 0.0000000000000000 + 0.27667156381993480 2.9807707706277959 0.0000000000000000 + 8.1273549858423472E-002 2.9983479702227562 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + --- --- IceCream --- + 139 138 246 245 + 0 0 1 0 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -8.1273514348751255E-002 2.9983479716669477 0.0000000000000000 + -0.27667144147234074 2.9807707877171499 0.0000000000000000 + -0.46940714556157248 2.9441339798727189 0.0000000000000000 + -0.54802270862630975 2.9234529135983243 0.0000000000000000 + --- --- IceCream --- + 138 125 247 246 + 0 0 1 0 + -0.54802270862630975 2.9234529135983243 0.0000000000000000 + -0.60963681664226710 2.9048209763109716 0.0000000000000000 + -0.75566123688154063 2.8517494687658642 0.0000000000000000 + -0.89712529516674266 2.7875027845494351 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + --- --- IceCream --- + 125 124 248 247 + 0 0 1 0 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.0274611529224809 2.7159031380690477 0.0000000000000000 + -1.1965880619272244 2.6025532783821101 0.0000000000000000 + -1.3533146983210931 2.4725961181899434 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + --- --- IceCream --- + 124 112 249 248 + 0 0 1 0 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.4725958216597181 2.3533150209874787 0.0000000000000000 + -1.6025531247952236 2.1965882676213502 0.0000000000000000 + -1.7159030994426530 2.0274612174301749 0.0000000000000000 + -1.7577069153495026 1.9541836299856208 0.0000000000000000 + --- --- IceCream --- + 112 111 250 249 + 0 0 1 0 + -1.7577069153495026 1.9541836299856208 0.0000000000000000 + -1.7875027845494327 1.8971252951667479 0.0000000000000000 + -1.8517494687658640 1.7556612368815410 0.0000000000000000 + -1.9048209763109714 1.6096368166422679 0.0000000000000000 + -1.9234529135983243 1.5480227086263101 0.0000000000000000 + --- --- IceCream --- + 111 101 251 250 + 0 0 1 0 + -1.9234529135983243 1.5480227086263101 0.0000000000000000 + -1.9441339798883621 1.4694071454967825 0.0000000000000000 + -1.9807707877486287 1.2766714412469717 0.0000000000000000 + -1.9983479716827337 1.0812735139606025 0.0000000000000000 + -2.0000000000000000 1.0000000000000002 0.0000000000000000 + --- --- IceCream --- + 101 89 252 251 + 0 0 1 0 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.9766600707430160 0.95332014148603195 0.0000000000000000 + -1.9203124969859764 0.84062499397195278 0.0000000000000000 + -1.8639649232289368 0.72792984645787362 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + --- --- LeftSlant --- + 89 90 253 252 + 0 0 1 0 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.7994368868418851 0.59887377368377015 0.0000000000000000 + -1.7000000000000000 0.39999999999999991 0.0000000000000000 + -1.6005631131581148 0.20112622631622967 0.0000000000000000 + -1.5593750060280471 0.11875001205609426 0.0000000000000000 + --- --- LeftSlant --- + 90 78 254 253 + 0 0 1 0 + -1.5593750060280471 0.11875001205609426 0.0000000000000000 + -1.5067457553473789 1.3491510694757736E-002 0.0000000000000000 + -1.3796875045765755 -0.24062499084684896 0.0000000000000000 + -1.2526292538057724 -0.49474149238845522 0.0000000000000000 + -1.2000000031251039 -0.59999999374979218 0.0000000000000000 + --- --- LeftSlant --- + 78 64 255 254 + 0 0 1 0 + -1.2000000031251039 -0.59999999374979218 0.0000000000000000 + -1.1473707515291136 -0.70525849694177278 0.0000000000000000 + -1.0203124985485283 -0.95937500290294331 0.0000000000000000 + -0.89325424556794286 -1.2134915088641143 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + --- --- LeftSlant --- + 64 65 256 255 + 0 0 1 0 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.79943688684188507 -1.4011262263162299 0.0000000000000000 + -0.69999999999999996 -1.6000000000000001 0.0000000000000000 + -0.60056311315811484 -1.7988737736837703 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + --- --- LeftSlant --- + 65 51 233 256 + 0 0 1 0 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + -0.47745643300837282 -2.0450871339832544 0.0000000000000000 + -0.27968750301402356 -2.4406249939719529 0.0000000000000000 + -8.1918573019674756E-002 -2.8361628539606505 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + --- --- LeftSlant --- diff --git a/previews/PR1697/tutorials/out/ice_cream_curved_sides.tec b/previews/PR1697/tutorials/out/ice_cream_curved_sides.tec new file mode 100644 index 00000000000..535e295d57c --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_curved_sides.tec @@ -0,0 +1,474 @@ + VARIABLES = "X", "Y", "Z" + ZONE F=FEPOINT, ET=QUADRILATERAL, N= 256 E= 216 + -2.6873977405837541 -6.8533127622695584 0.0000000000000000 + -2.0107216208337615 -6.8653592763871760 0.0000000000000000 + -1.0410418717253931 -6.9216393501901949 0.0000000000000000 + 2.9912702576840707E-007 -6.9498898853362308 0.0000000000000000 + 1.0410424460724244 -6.9216392767031785 0.0000000000000000 + 2.0107220324553001 -6.8653591831123713 0.0000000000000000 + 2.6873981284579389 -6.8533125932786199 0.0000000000000000 + -4.7376904454980995 -5.7175213451225044 0.0000000000000000 + -4.1206720130528520 -5.8675490522077896 0.0000000000000000 + -3.1043042956445648 -6.1731350923322887 0.0000000000000000 + -2.0036785626447200 -5.9851228109660299 0.0000000000000000 + -1.0098066418509064 -5.9615428122665204 0.0000000000000000 + 1.4706799468291222E-007 -5.9621383436589896 0.0000000000000000 + 1.0098069252998503 -5.9615427750810719 0.0000000000000000 + 2.0036788470530045 -5.9851227251882229 0.0000000000000000 + 3.1043047227986076 -6.1731348858195423 0.0000000000000000 + 4.1206723395676512 -5.8675488550488604 0.0000000000000000 + 4.7376907442183054 -5.7175210852012199 0.0000000000000000 + -5.7175290854607779 -4.7380091301910010 0.0000000000000000 + -5.0338745166877699 -5.0343954062500895 0.0000000000000000 + -4.0192675410949015 -4.9833531598216387 0.0000000000000000 + -3.0341474170277136 -5.0182548701078833 0.0000000000000000 + -2.0156881211264164 -5.0103777714865521 0.0000000000000000 + -1.0040300753799325 -4.9870767872107384 0.0000000000000000 + 6.0815912483782476E-008 -4.9814748373723354 0.0000000000000000 + 1.0040302008008126 -4.9870767661818354 0.0000000000000000 + 2.0156882686372239 -5.0103777190234284 0.0000000000000000 + 3.0341475955502211 -5.0182547800320005 0.0000000000000000 + 4.0192677419725520 -4.9833530285321146 0.0000000000000000 + 5.0338748213315210 -5.0343951447304720 0.0000000000000000 + 5.7175292975176388 -4.7380089561448235 0.0000000000000000 + -5.8675188863064056 -4.1212636296863909 0.0000000000000000 + -4.9817761240538099 -4.0207066396640707 0.0000000000000000 + -4.0043466716132494 -4.0091310423573763 0.0000000000000000 + -2.9990315694177996 -4.0029589564990600 0.0000000000000000 + -1.9980410613753681 -4.0034989440708078 0.0000000000000000 + -1.0025886914582574 -4.0005457543668728 0.0000000000000000 + 2.0716010322157786E-008 -3.9975159229364250 0.0000000000000000 + 1.0025887371619329 -4.0005457439384919 0.0000000000000000 + 1.9980411183580911 -4.0034989210294167 0.0000000000000000 + 2.9990316405720265 -4.0029589207724925 0.0000000000000000 + 4.0043467561697534 -4.0091310005645440 0.0000000000000000 + 4.9817761918620427 -4.0207066409172585 0.0000000000000000 + 5.8675188518455164 -4.1212637904706897 0.0000000000000000 + -6.8541002111688183 -2.6879947245913107 0.0000000000000000 + -6.1729085409881828 -3.1048888913844155 0.0000000000000000 + -5.0136659075640297 -3.0350713738960646 0.0000000000000000 + -3.9875424262402634 -3.0037083370185043 0.0000000000000000 + -2.9583450770060664 -2.9862077152150777 0.0000000000000000 + -1.9564448711240272 -3.0074316257274023 0.0000000000000000 + -1.0288837123639378 -3.0335503938670736 0.0000000000000000 + 1.0288837261293409 -3.0335503875679914 0.0000000000000000 + 1.9564448907221292 -3.0074316143886093 0.0000000000000000 + 2.9583450995996925 -2.9862077071259527 0.0000000000000000 + 3.9875424417605054 -3.0037083567292124 0.0000000000000000 + 5.0136658835814423 -3.0350714872829925 0.0000000000000000 + 6.1729083819393678 -3.1048892701218342 0.0000000000000000 + 6.8541000555287406 -2.6879951006708396 0.0000000000000000 + -6.8662753709801922 -2.0111701987867616 0.0000000000000000 + -5.9840270273315026 -2.0036316982582778 0.0000000000000000 + -4.9988021360598456 -2.0128444316642962 0.0000000000000000 + -3.9673460790320734 -1.9910456416213265 0.0000000000000000 + -2.9250676751279636 -1.9602609213766236 0.0000000000000000 + -1.7488220331260820 -1.8941799125227698 0.0000000000000000 + -1.0549997787868850 -2.3236466700725056 0.0000000000000000 + 1.0549997837346989 -2.3236466644045155 0.0000000000000000 + 1.7488220456724668 -1.8941798935970877 0.0000000000000000 + 2.9250676820651060 -1.9602609194579510 0.0000000000000000 + 3.9673460732862944 -1.9910456785028996 0.0000000000000000 + 4.9988021003931316 -2.0128445626745215 0.0000000000000000 + 5.9840269527385770 -2.0036319863591987 0.0000000000000000 + 6.8662752831181848 -2.0111706214718250 0.0000000000000000 + -6.9224179711968894 -1.0409114847469898 0.0000000000000000 + -5.9580972668346384 -1.0079369394830269 0.0000000000000000 + -4.9644031999205085 -0.99567599301028353 0.0000000000000000 + -3.9291101003161621 -0.97695020835669544 0.0000000000000000 + -2.9054997225222792 -0.96230280748999231 0.0000000000000000 + -1.9926400784257630 -0.87289673502189002 0.0000000000000000 + 1.9926400966711493 -0.87289669885085341 0.0000000000000000 + 2.9054997267781739 -0.96230280151691017 0.0000000000000000 + 3.9291100927795046 -0.97695023859068741 0.0000000000000000 + 4.9644031747190178 -0.99567610299695042 0.0000000000000000 + 5.9580972159582188 -1.0079372294112183 0.0000000000000000 + 6.9224178848348696 -1.0409122106557087 0.0000000000000000 + -6.9501005397333646 9.2742624259376633E-004 0.0000000000000000 + -5.9557814357875589 3.5672791828285848E-003 0.0000000000000000 + -4.9483036165862142 1.0995072712916637E-002 0.0000000000000000 + -3.8953761385874000 2.9859225313277699E-002 0.0000000000000000 + -2.7044268180022062 9.0239571225917664E-002 0.0000000000000000 + -2.0577134077941768 -0.24596023237843018 0.0000000000000000 + 2.0577134210781893 -0.24596020432330881 0.0000000000000000 + 2.7044268189529750 9.0239580439220993E-002 0.0000000000000000 + 3.8953761307951136 2.9859213141896310E-002 0.0000000000000000 + 4.9483035951629128 1.0995006083563994E-002 0.0000000000000000 + 5.9557813901342689 3.5670820551844027E-003 0.0000000000000000 + 6.9501004563400075 9.2689433946285945E-004 0.0000000000000000 + -6.9211366160086696 1.0424222176432969 0.0000000000000000 + -5.9532838484776942 1.0137526163989738 0.0000000000000000 + -4.9500311685113738 1.0133010960715971 0.0000000000000000 + -3.8931011037157370 1.0206864672017701 0.0000000000000000 + -2.8597405927114097 1.0355541279811451 0.0000000000000000 + 2.8597405855121849 1.0355541561971500 0.0000000000000000 + 3.8931010938629025 1.0206864792386088 0.0000000000000000 + 4.9500311437661138 1.0133010952219772 0.0000000000000000 + 5.9532837990717420 1.0137526003884889 0.0000000000000000 + 6.9211365315572104 1.0424222862574206 0.0000000000000000 + -6.8644255432723220 2.0119396442671040 0.0000000000000000 + -5.9770878564770857 2.0066264662415398 0.0000000000000000 + -4.9783437062948490 2.0217143918982812 0.0000000000000000 + -3.9140404518912146 2.0099176101976779 0.0000000000000000 + -2.7410761635755314 1.9789206013273941 0.0000000000000000 + -2.1286743374522938 2.2972195370402191 0.0000000000000000 + 2.1286743610257428 2.2972195426678863 0.0000000000000000 + 2.7410761638388315 1.9789206359776161 0.0000000000000000 + 3.9140404460755791 2.0099176374807124 0.0000000000000000 + 4.9783436737400066 2.0217144567818068 0.0000000000000000 + 5.9770877867144092 2.0066266051878681 0.0000000000000000 + 6.8644254594391168 2.0119399050256175 0.0000000000000000 + -6.8525413060636966 2.6881963732921865 0.0000000000000000 + -6.1678363756747823 3.1055140586749621 0.0000000000000000 + -4.9973810792864457 3.0371864629703023 0.0000000000000000 + -3.9532479064607431 3.0086876509391756 0.0000000000000000 + -2.9421500723748752 3.0044506681060703 0.0000000000000000 + -1.9325861810773708 2.9330503835958242 0.0000000000000000 + -1.2961124323034472 3.1292858466381226 0.0000000000000000 + 1.2961125095535806 3.1292858073071472 0.0000000000000000 + 1.9325862367186470 2.9330503517007265 0.0000000000000000 + 2.9421501048823253 3.0044506615488382 0.0000000000000000 + 3.9532479276365025 3.0086876615716163 0.0000000000000000 + 4.9973810641359471 3.0371865415826074 0.0000000000000000 + 6.1678362306961185 3.1055143771001839 0.0000000000000000 + 6.8525411601091664 2.6881966863964721 0.0000000000000000 + -5.8641463558607985 4.1208556574546105 0.0000000000000000 + -4.9733093718925314 4.0196757173264421 0.0000000000000000 + -3.9922265881412802 4.0059453056237606 0.0000000000000000 + -2.9890091422252363 3.9843170145084694 0.0000000000000000 + -2.0054941764375291 3.9431793687522627 0.0000000000000000 + -0.97208389168591847 3.7420513075922179 0.0000000000000000 + 4.9676272106708220E-008 3.8718978722738666 0.0000000000000000 + 0.97208398546357100 3.7420512824509329 0.0000000000000000 + 2.0054942543469472 3.9431793364082628 0.0000000000000000 + 2.9890092219353601 3.9843169730044226 0.0000000000000000 + 3.9922266832879605 4.0059452501162065 0.0000000000000000 + 4.9733094595143239 4.0196756893634520 0.0000000000000000 + 5.8641463429630729 4.1208557832656991 0.0000000000000000 + -5.7158908831846356 4.7374654742093689 0.0000000000000000 + -5.0310753814344409 5.0329859200420142 0.0000000000000000 + -4.0146693983288904 4.9778067867170375 0.0000000000000000 + -3.0301613062086163 5.0005146435834220 0.0000000000000000 + -2.0111150485345335 4.9601592448796588 0.0000000000000000 + -0.99816482806907292 4.9040223934159526 0.0000000000000000 + 6.5559167275215029E-008 4.8889229740908711 0.0000000000000000 + 0.99816495902914193 4.9040223703928012 0.0000000000000000 + 2.0111151922869741 4.9601591923650652 0.0000000000000000 + 3.0301614770132304 5.0005145532717288 0.0000000000000000 + 4.0146696060123634 4.9778066411423163 0.0000000000000000 + 5.0310757370402959 5.0329856029402960 0.0000000000000000 + 5.7158911418430645 4.7374652500277525 0.0000000000000000 + -4.7366408724331448 5.7163969255377962 0.0000000000000000 + -4.1192062592906806 5.8644052326761127 0.0000000000000000 + -3.1027380900121511 6.1648179887777212 0.0000000000000000 + -2.0015559213129070 5.9647195940348077 0.0000000000000000 + -1.0080842121091849 5.9307120578964962 0.0000000000000000 + 1.2809144579091231E-007 5.9271981412979953 0.0000000000000000 + 1.0080844592290032 5.9307120244791536 0.0000000000000000 + 2.0015561708518548 5.9647195166171958 0.0000000000000000 + 3.1027384683617534 6.1648178022211253 0.0000000000000000 + 4.1192065691366757 5.8644050357600435 0.0000000000000000 + 4.7366412086031051 5.7163966234799082 0.0000000000000000 + -2.6868851371343672 6.8498717712581927 0.0000000000000000 + -2.0100960238839289 6.8591082624958490 0.0000000000000000 + -1.0405857107919183 6.9126053965829257 0.0000000000000000 + 2.5020681072890381E-007 6.9397443383701223 0.0000000000000000 + 1.0405861922485977 6.9126053343110048 0.0000000000000000 + 2.0100963728176224 6.8591081816647161 0.0000000000000000 + 2.6868854733549496 6.8498716232438612 0.0000000000000000 + -3.6705104009983383 -7.1082595194719094 0.0000000000000000 + -3.0442865551243687 -7.3981294507658495 0.0000000000000000 + -2.1863978152204240 -7.6954314104928097 0.0000000000000000 + -1.1313695802431920 -7.9195961306685545 0.0000000000000000 + 3.6410209097182056E-009 -8.0000000000000000 0.0000000000000000 + 1.1313715929171260 -7.9195958431437754 0.0000000000000000 + 2.1863978152204160 -7.6954314104928123 0.0000000000000000 + 3.0442865551243607 -7.3981294507658522 0.0000000000000000 + 3.6705121720218252 -7.1082586049636394 0.0000000000000000 + 4.4376011313588206 -6.6564026469980702 0.0000000000000000 + 5.1002019105058052 -6.1634357684714240 0.0000000000000000 + 5.6568541807137214 -5.6568543182710380 0.0000000000000000 + 6.1634357684714249 -5.1002019105058043 0.0000000000000000 + 6.6564026469980728 -4.4376011313588162 0.0000000000000000 + 7.1082586387364719 -3.6705121066178656 0.0000000000000000 + 7.3981294507658539 -3.0442865551243559 0.0000000000000000 + 7.6954314104928132 -2.1863978152204129 0.0000000000000000 + 7.9195958648410292 -1.1313714410364422 0.0000000000000000 + 7.9999999999999973 -1.9089446951922548E-007 0.0000000000000000 + 7.9195958696254367 1.1313714075456063 0.0000000000000000 + 7.6954314104928123 2.1863978152204151 0.0000000000000000 + 7.3981294507658530 3.0442865551243603 0.0000000000000000 + 7.1082586908781771 3.6705120056410205 0.0000000000000000 + 6.6564026469980719 4.4376011313588171 0.0000000000000000 + 6.1634357684714232 5.1002019105058070 0.0000000000000000 + 5.6568544506792646 5.6568540483054894 0.0000000000000000 + 5.1002019105058061 6.1634357684714240 0.0000000000000000 + 4.4376011313588162 6.6564026469980728 0.0000000000000000 + 3.6705119402370614 7.1082587246510069 0.0000000000000000 + 3.0442865551243585 7.3981294507658530 0.0000000000000000 + 2.1863978152204191 7.6954314104928114 0.0000000000000000 + 1.1313712556649234 7.9195958913226860 0.0000000000000000 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + -1.1313695802431916 7.9195961306685545 0.0000000000000000 + -2.1863978152204133 7.6954314104928132 0.0000000000000000 + -3.0442865551243616 7.3981294507658522 0.0000000000000000 + -3.6705104009983285 7.1082595194719147 0.0000000000000000 + -4.4376011313588100 6.6564026469980773 0.0000000000000000 + -5.1002019105058114 6.1634357684714187 0.0000000000000000 + -5.6568527973323857 5.6568557016520025 0.0000000000000000 + -6.1634357684714214 5.1002019105058087 0.0000000000000000 + -6.6564026469980755 4.4376011313588126 0.0000000000000000 + -7.1082595194719094 3.6705104009983378 0.0000000000000000 + -7.3981294507658477 3.0442865551243714 0.0000000000000000 + -7.6954314104928097 2.1863978152204235 0.0000000000000000 + -7.9195961306685545 1.1313695802431951 0.0000000000000000 + -7.9999999999997362 2.0536640888705361E-006 0.0000000000000000 + -7.9195961306685545 -1.1313695802431909 0.0000000000000000 + -7.6954314104928114 -2.1863978152204195 0.0000000000000000 + -7.3981294507658522 -3.0442865551243612 0.0000000000000000 + -7.1082595194719147 -3.6705104009983280 0.0000000000000000 + -6.6564026469980782 -4.4376011313588091 0.0000000000000000 + -6.1634357684714196 -5.1002019105058105 0.0000000000000000 + -5.6568527973323830 -5.6568557016520042 0.0000000000000000 + -5.1002019105058114 -6.1634357684714187 0.0000000000000000 + -4.4376011313588135 -6.6564026469980755 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 0.84062499397195267 -1.3187500120560947 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.5593750060280469 0.11875001205609381 0.0000000000000000 + 1.8406249939719526 0.68124998794390512 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9234528539428934 1.5480229180052039 0.0000000000000000 + 1.7577069153495042 1.9541836299856183 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 0.95418362998561834 2.7577069153495040 0.0000000000000000 + 0.54802294711610822 2.9234528456487245 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -0.54802270862631064 2.9234529135983243 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.7577069153495022 1.9541836299856215 0.0000000000000000 + -1.9234529135983240 1.5480227086263110 0.0000000000000000 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.5593750060280471 0.11875001205609437 0.0000000000000000 + -1.2000000031251037 -0.59999999374979263 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 1 2 11 10 + 2 3 12 11 + 3 4 13 12 + 4 5 14 13 + 5 6 15 14 + 6 7 16 15 + 8 9 21 20 + 9 10 22 21 + 10 11 23 22 + 11 12 24 23 + 12 13 25 24 + 13 14 26 25 + 14 15 27 26 + 15 16 28 27 + 16 17 29 28 + 17 18 30 29 + 19 20 33 32 + 20 21 34 33 + 21 22 35 34 + 22 23 36 35 + 23 24 37 36 + 24 25 38 37 + 25 26 39 38 + 26 27 40 39 + 27 28 41 40 + 28 29 42 41 + 29 30 43 42 + 30 31 44 43 + 32 33 47 46 + 33 34 48 47 + 34 35 49 48 + 35 36 50 49 + 36 37 51 50 + 39 40 53 52 + 40 41 54 53 + 41 42 55 54 + 42 43 56 55 + 43 44 57 56 + 45 46 60 59 + 46 47 61 60 + 47 48 62 61 + 48 49 63 62 + 49 50 64 63 + 50 51 65 64 + 52 53 67 66 + 53 54 68 67 + 54 55 69 68 + 55 56 70 69 + 56 57 71 70 + 57 58 72 71 + 59 60 74 73 + 60 61 75 74 + 61 62 76 75 + 62 63 77 76 + 63 64 78 77 + 67 68 80 79 + 68 69 81 80 + 69 70 82 81 + 70 71 83 82 + 71 72 84 83 + 73 74 86 85 + 74 75 87 86 + 75 76 88 87 + 76 77 89 88 + 77 78 90 89 + 79 80 92 91 + 80 81 93 92 + 81 82 94 93 + 82 83 95 94 + 83 84 96 95 + 85 86 98 97 + 86 87 99 98 + 87 88 100 99 + 88 89 101 100 + 92 93 103 102 + 93 94 104 103 + 94 95 105 104 + 95 96 106 105 + 97 98 108 107 + 98 99 109 108 + 99 100 110 109 + 100 101 111 110 + 102 103 115 114 + 103 104 116 115 + 104 105 117 116 + 105 106 118 117 + 107 108 120 119 + 108 109 121 120 + 109 110 122 121 + 110 111 123 122 + 111 112 124 123 + 113 114 128 127 + 114 115 129 128 + 115 116 130 129 + 116 117 131 130 + 117 118 132 131 + 120 121 134 133 + 121 122 135 134 + 122 123 136 135 + 123 124 137 136 + 124 125 138 137 + 126 127 141 140 + 127 128 142 141 + 128 129 143 142 + 129 130 144 143 + 130 131 145 144 + 133 134 147 146 + 134 135 148 147 + 135 136 149 148 + 136 137 150 149 + 137 138 151 150 + 138 139 152 151 + 139 140 153 152 + 140 141 154 153 + 141 142 155 154 + 142 143 156 155 + 143 144 157 156 + 144 145 158 157 + 147 148 160 159 + 148 149 161 160 + 149 150 162 161 + 150 151 163 162 + 151 152 164 163 + 152 153 165 164 + 153 154 166 165 + 154 155 167 166 + 155 156 168 167 + 156 157 169 168 + 161 162 171 170 + 162 163 172 171 + 163 164 173 172 + 164 165 174 173 + 165 166 175 174 + 166 167 176 175 + 10 177 178 1 + 1 178 179 2 + 2 179 180 3 + 3 180 181 4 + 4 181 182 5 + 5 182 183 6 + 6 183 184 7 + 7 184 185 16 + 16 185 186 17 + 17 186 187 18 + 18 187 188 30 + 30 188 189 31 + 31 189 190 44 + 44 190 191 57 + 57 191 192 58 + 58 192 193 72 + 72 193 194 84 + 84 194 195 96 + 96 195 196 106 + 106 196 197 118 + 118 197 198 132 + 132 198 199 131 + 131 199 200 145 + 145 200 201 158 + 158 201 202 157 + 157 202 203 169 + 169 203 204 168 + 168 204 205 167 + 167 205 206 176 + 176 206 207 175 + 175 207 208 174 + 174 208 209 173 + 173 209 210 172 + 172 210 211 171 + 171 211 212 170 + 170 212 213 161 + 161 213 214 160 + 160 214 215 159 + 159 215 216 147 + 147 216 217 146 + 146 217 218 133 + 133 218 219 120 + 120 219 220 119 + 119 220 221 107 + 107 221 222 97 + 97 222 223 85 + 85 223 224 73 + 73 224 225 59 + 59 225 226 45 + 45 226 227 46 + 46 227 228 32 + 32 228 229 19 + 19 229 230 20 + 20 230 231 8 + 8 231 232 9 + 9 232 177 10 + 51 37 38 233 + 233 38 39 52 + 52 66 234 233 + 66 67 235 234 + 67 79 236 235 + 79 91 237 236 + 91 92 238 237 + 92 102 239 238 + 102 114 240 239 + 114 113 241 240 + 113 127 242 241 + 127 126 243 242 + 126 140 244 243 + 140 139 245 244 + 139 138 246 245 + 138 125 247 246 + 125 124 248 247 + 124 112 249 248 + 112 111 250 249 + 111 101 251 250 + 101 89 252 251 + 89 90 253 252 + 90 78 254 253 + 78 64 255 254 + 64 65 256 255 + 65 51 233 256 diff --git a/previews/PR1697/tutorials/out/ice_cream_curved_sides.txt b/previews/PR1697/tutorials/out/ice_cream_curved_sides.txt new file mode 100644 index 00000000000..a16c98dc3de --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_curved_sides.txt @@ -0,0 +1,222 @@ + + ------------------------ + 2D Mesh Quality Measures + ------------------------ + +Signed Area Aspect Ratio Condition Edge Ratio Jacobian Minimum Angle Maximum Angle Area Sign + 7.1136E-01 1.3622E+00 1.2021E+00 1.6498E+00 4.5524E-01 6.8188E+01 1.2253E+02 1.0000E+00 + 9.0371E-01 1.0468E+00 1.0079E+00 1.1294E+00 8.5394E-01 8.6778E+01 9.2863E+01 1.0000E+00 + 9.9891E-01 1.0425E+00 1.0033E+00 1.0841E+00 9.6953E-01 8.8446E+01 9.1830E+01 1.0000E+00 + 9.9891E-01 1.0425E+00 1.0033E+00 1.0841E+00 9.6953E-01 8.8446E+01 9.1830E+01 1.0000E+00 + 9.0371E-01 1.0468E+00 1.0079E+00 1.1294E+00 8.5394E-01 8.6778E+01 9.2863E+01 1.0000E+00 + 7.1136E-01 1.3622E+00 1.2021E+00 1.6498E+00 4.5524E-01 6.8188E+01 1.2253E+02 1.0000E+00 + 6.3450E-01 1.3151E+00 1.2698E+00 1.5998E+00 3.7707E-01 6.9440E+01 1.2711E+02 1.0000E+00 + 1.0349E+00 1.1443E+00 1.0318E+00 1.3000E+00 8.7458E-01 7.6742E+01 1.0019E+02 1.0000E+00 + 1.1254E+00 1.0967E+00 1.0277E+00 1.1869E+00 9.9283E-01 7.6830E+01 9.8988E+01 1.0000E+00 + 9.7737E-01 1.0238E+00 1.0011E+00 1.0384E+00 9.6836E-01 8.8341E+01 9.1699E+01 1.0000E+00 + 9.8432E-01 1.0179E+00 1.0006E+00 1.0362E+00 9.7836E-01 8.9680E+01 9.0659E+01 1.0000E+00 + 9.8432E-01 1.0179E+00 1.0006E+00 1.0362E+00 9.7836E-01 8.9680E+01 9.0659E+01 1.0000E+00 + 9.7737E-01 1.0238E+00 1.0011E+00 1.0384E+00 9.6836E-01 8.8341E+01 9.1699E+01 1.0000E+00 + 1.1254E+00 1.0967E+00 1.0277E+00 1.1869E+00 9.9283E-01 7.6830E+01 9.8988E+01 1.0000E+00 + 1.0349E+00 1.1443E+00 1.0318E+00 1.3000E+00 8.7458E-01 7.6742E+01 1.0019E+02 1.0000E+00 + 6.3450E-01 1.3151E+00 1.2698E+00 1.5998E+00 3.7707E-01 6.9440E+01 1.2711E+02 1.0000E+00 + 6.3491E-01 1.3135E+00 1.2701E+00 1.5992E+00 3.7719E-01 6.9504E+01 1.2711E+02 1.0000E+00 + 9.8895E-01 1.0228E+00 1.0052E+00 1.0426E+00 9.5206E-01 8.4178E+01 9.3757E+01 1.0000E+00 + 9.9036E-01 1.0210E+00 1.0009E+00 1.0427E+00 9.6025E-01 8.7667E+01 9.1229E+01 1.0000E+00 + 1.0208E+00 1.0083E+00 1.0009E+00 1.0175E+00 1.0079E+00 8.7576E+01 9.1950E+01 1.0000E+00 + 1.0001E+00 1.0120E+00 1.0008E+00 1.0257E+00 9.8204E-01 8.7676E+01 9.1403E+01 1.0000E+00 + 9.8850E-01 1.0099E+00 1.0002E+00 1.0204E+00 9.8651E-01 8.9597E+01 9.0320E+01 1.0000E+00 + 9.8850E-01 1.0099E+00 1.0002E+00 1.0204E+00 9.8651E-01 8.9597E+01 9.0320E+01 1.0000E+00 + 1.0001E+00 1.0120E+00 1.0008E+00 1.0257E+00 9.8204E-01 8.7676E+01 9.1403E+01 1.0000E+00 + 1.0208E+00 1.0083E+00 1.0009E+00 1.0175E+00 1.0079E+00 8.7576E+01 9.1950E+01 1.0000E+00 + 9.9036E-01 1.0210E+00 1.0009E+00 1.0427E+00 9.6025E-01 8.7667E+01 9.1229E+01 1.0000E+00 + 9.8895E-01 1.0228E+00 1.0052E+00 1.0426E+00 9.5206E-01 8.4178E+01 9.3757E+01 1.0000E+00 + 6.3491E-01 1.3135E+00 1.2701E+00 1.5992E+00 3.7719E-01 6.9504E+01 1.2711E+02 1.0000E+00 + 1.0379E+00 1.1470E+00 1.0317E+00 1.3028E+00 8.7623E-01 7.6723E+01 1.0025E+02 1.0000E+00 + 9.9746E-01 1.0281E+00 1.0013E+00 1.0502E+00 9.6376E-01 8.7292E+01 9.1636E+01 1.0000E+00 + 1.0282E+00 1.0156E+00 1.0017E+00 1.0239E+00 1.0107E+00 8.6734E+01 9.2643E+01 1.0000E+00 + 1.0083E+00 1.0136E+00 1.0009E+00 1.0207E+00 9.9708E-01 8.7739E+01 9.2360E+01 1.0000E+00 + 9.4384E-01 1.0266E+00 1.0027E+00 1.0744E+00 8.9626E-01 8.7439E+01 9.3171E+01 1.0000E+00 + 9.4384E-01 1.0266E+00 1.0027E+00 1.0744E+00 8.9626E-01 8.7439E+01 9.3171E+01 1.0000E+00 + 1.0083E+00 1.0136E+00 1.0009E+00 1.0207E+00 9.9708E-01 8.7739E+01 9.2360E+01 1.0000E+00 + 1.0282E+00 1.0156E+00 1.0017E+00 1.0239E+00 1.0107E+00 8.6734E+01 9.2643E+01 1.0000E+00 + 9.9746E-01 1.0281E+00 1.0013E+00 1.0502E+00 9.6376E-01 8.7292E+01 9.1636E+01 1.0000E+00 + 1.0379E+00 1.1470E+00 1.0317E+00 1.3028E+00 8.7623E-01 7.6723E+01 1.0025E+02 1.0000E+00 + 7.1306E-01 1.3614E+00 1.2019E+00 1.6506E+00 4.5597E-01 6.8265E+01 1.2250E+02 1.0000E+00 + 1.1353E+00 1.0961E+00 1.0278E+00 1.1787E+00 1.0073E+00 7.6821E+01 9.9197E+01 1.0000E+00 + 1.0463E+00 1.0091E+00 1.0014E+00 1.0186E+00 1.0385E+00 8.7416E+01 9.2893E+01 1.0000E+00 + 1.0551E+00 1.0158E+00 1.0020E+00 1.0295E+00 1.0419E+00 8.6450E+01 9.2834E+01 1.0000E+00 + 1.1622E+00 1.0997E+00 1.0304E+00 1.1756E+00 1.0286E+00 7.6220E+01 9.9351E+01 1.0000E+00 + 7.5968E-01 1.3367E+00 1.2159E+00 1.5941E+00 4.8133E-01 6.8807E+01 1.2386E+02 1.0000E+00 + 7.5968E-01 1.3367E+00 1.2159E+00 1.5941E+00 4.8133E-01 6.8807E+01 1.2386E+02 1.0000E+00 + 1.1622E+00 1.0997E+00 1.0304E+00 1.1756E+00 1.0286E+00 7.6220E+01 9.9351E+01 1.0000E+00 + 1.0551E+00 1.0158E+00 1.0020E+00 1.0295E+00 1.0419E+00 8.6450E+01 9.2834E+01 1.0000E+00 + 1.0463E+00 1.0091E+00 1.0014E+00 1.0186E+00 1.0385E+00 8.7416E+01 9.2893E+01 1.0000E+00 + 1.1353E+00 1.0961E+00 1.0278E+00 1.1787E+00 1.0073E+00 7.6821E+01 9.9197E+01 1.0000E+00 + 7.1306E-01 1.3614E+00 1.2019E+00 1.6506E+00 4.5597E-01 6.8265E+01 1.2250E+02 1.0000E+00 + 9.0787E-01 1.0464E+00 1.0080E+00 1.1289E+00 8.5643E-01 8.6550E+01 9.2822E+01 1.0000E+00 + 9.9578E-01 1.0202E+00 1.0014E+00 1.0330E+00 9.8122E-01 8.7356E+01 9.2199E+01 1.0000E+00 + 1.0488E+00 1.0119E+00 1.0019E+00 1.0203E+00 1.0452E+00 8.6804E+01 9.3370E+01 1.0000E+00 + 1.0385E+00 1.0240E+00 1.0026E+00 1.0447E+00 1.0212E+00 8.6149E+01 9.2979E+01 1.0000E+00 + 1.0633E+00 1.1477E+00 1.0228E+00 1.2844E+00 9.0925E-01 7.9788E+01 9.7834E+01 1.0000E+00 + 1.0633E+00 1.1477E+00 1.0228E+00 1.2844E+00 9.0925E-01 7.9788E+01 9.7834E+01 1.0000E+00 + 1.0385E+00 1.0240E+00 1.0026E+00 1.0447E+00 1.0212E+00 8.6149E+01 9.2979E+01 1.0000E+00 + 1.0488E+00 1.0119E+00 1.0019E+00 1.0203E+00 1.0452E+00 8.6804E+01 9.3370E+01 1.0000E+00 + 9.9578E-01 1.0202E+00 1.0014E+00 1.0330E+00 9.8122E-01 8.7356E+01 9.2199E+01 1.0000E+00 + 9.0787E-01 1.0464E+00 1.0080E+00 1.1289E+00 8.5643E-01 8.6550E+01 9.2822E+01 1.0000E+00 + 1.0057E+00 1.0397E+00 1.0030E+00 1.0801E+00 9.7534E-01 8.8630E+01 9.2090E+01 1.0000E+00 + 1.0096E+00 1.0068E+00 1.0005E+00 1.0178E+00 1.0001E+00 8.8661E+01 9.1623E+01 1.0000E+00 + 1.0507E+00 1.0280E+00 1.0023E+00 1.0460E+00 1.0417E+00 8.7055E+01 9.2955E+01 1.0000E+00 + 1.1357E+00 1.1274E+00 1.0352E+00 1.1837E+00 1.0301E+00 7.6282E+01 1.0164E+02 1.0000E+00 + 6.6321E-01 1.3524E+00 1.2104E+00 1.7001E+00 3.8357E-01 7.3347E+01 1.2339E+02 1.0000E+00 + 6.6321E-01 1.3524E+00 1.2104E+00 1.7001E+00 3.8357E-01 7.3347E+01 1.2339E+02 1.0000E+00 + 1.1357E+00 1.1274E+00 1.0352E+00 1.1837E+00 1.0301E+00 7.6282E+01 1.0164E+02 1.0000E+00 + 1.0507E+00 1.0280E+00 1.0023E+00 1.0460E+00 1.0417E+00 8.7055E+01 9.2955E+01 1.0000E+00 + 1.0096E+00 1.0068E+00 1.0005E+00 1.0178E+00 1.0001E+00 8.8661E+01 9.1623E+01 1.0000E+00 + 1.0057E+00 1.0397E+00 1.0030E+00 1.0801E+00 9.7534E-01 8.8630E+01 9.2090E+01 1.0000E+00 + 1.0066E+00 1.0388E+00 1.0027E+00 1.0760E+00 9.7778E-01 8.8255E+01 9.1555E+01 1.0000E+00 + 1.0116E+00 1.0044E+00 1.0001E+00 1.0079E+00 1.0056E+00 8.9436E+01 9.0324E+01 1.0000E+00 + 1.0513E+00 1.0313E+00 1.0021E+00 1.0667E+00 1.0432E+00 8.9072E+01 9.1158E+01 1.0000E+00 + 1.0795E+00 1.1529E+00 1.0305E+00 1.2448E+00 9.7916E-01 8.3572E+01 9.8506E+01 1.0000E+00 + 1.0795E+00 1.1529E+00 1.0305E+00 1.2448E+00 9.7916E-01 8.3572E+01 9.8506E+01 1.0000E+00 + 1.0513E+00 1.0313E+00 1.0021E+00 1.0667E+00 1.0432E+00 8.9072E+01 9.1158E+01 1.0000E+00 + 1.0116E+00 1.0044E+00 1.0001E+00 1.0079E+00 1.0056E+00 8.9436E+01 9.0324E+01 1.0000E+00 + 1.0066E+00 1.0388E+00 1.0027E+00 1.0760E+00 9.7778E-01 8.8255E+01 9.1555E+01 1.0000E+00 + 9.1043E-01 1.0418E+00 1.0068E+00 1.1192E+00 8.6059E-01 8.6930E+01 9.3005E+01 1.0000E+00 + 1.0018E+00 1.0080E+00 1.0004E+00 1.0158E+00 9.9199E-01 8.8366E+01 9.1399E+01 1.0000E+00 + 1.0593E+00 1.0348E+00 1.0032E+00 1.0757E+00 1.0457E+00 8.7757E+01 9.1848E+01 1.0000E+00 + 1.0664E+00 1.1408E+00 1.0272E+00 1.2341E+00 9.7307E-01 8.4344E+01 9.7994E+01 1.0000E+00 + 1.0664E+00 1.1408E+00 1.0272E+00 1.2341E+00 9.7307E-01 8.4344E+01 9.7994E+01 1.0000E+00 + 1.0593E+00 1.0348E+00 1.0032E+00 1.0757E+00 1.0457E+00 8.7757E+01 9.1848E+01 1.0000E+00 + 1.0018E+00 1.0080E+00 1.0004E+00 1.0158E+00 9.9199E-01 8.8366E+01 9.1399E+01 1.0000E+00 + 9.1043E-01 1.0418E+00 1.0068E+00 1.1192E+00 8.6059E-01 8.6930E+01 9.3005E+01 1.0000E+00 + 7.1607E-01 1.3554E+00 1.2012E+00 1.6490E+00 4.5808E-01 6.8486E+01 1.2237E+02 1.0000E+00 + 1.1438E+00 1.1025E+00 1.0284E+00 1.1738E+00 1.0145E+00 7.6812E+01 9.8982E+01 1.0000E+00 + 1.0611E+00 1.0342E+00 1.0032E+00 1.0649E+00 1.0417E+00 8.7117E+01 9.3811E+01 1.0000E+00 + 1.1032E+00 1.1245E+00 1.0316E+00 1.1739E+00 1.0097E+00 7.7393E+01 1.0133E+02 1.0000E+00 + 6.7398E-01 1.3229E+00 1.4055E+00 1.5706E+00 3.2697E-01 7.3630E+01 1.3460E+02 1.0000E+00 + 6.7398E-01 1.3229E+00 1.4055E+00 1.5706E+00 3.2697E-01 7.3630E+01 1.3460E+02 1.0000E+00 + 1.1032E+00 1.1245E+00 1.0316E+00 1.1739E+00 1.0097E+00 7.7393E+01 1.0133E+02 1.0000E+00 + 1.0611E+00 1.0342E+00 1.0032E+00 1.0649E+00 1.0417E+00 8.7117E+01 9.3811E+01 1.0000E+00 + 1.1438E+00 1.1025E+00 1.0284E+00 1.1738E+00 1.0145E+00 7.6812E+01 9.8982E+01 1.0000E+00 + 7.1607E-01 1.3554E+00 1.2012E+00 1.6490E+00 4.5808E-01 6.8486E+01 1.2237E+02 1.0000E+00 + 1.0434E+00 1.1550E+00 1.0329E+00 1.3077E+00 8.7767E-01 7.6689E+01 1.0017E+02 1.0000E+00 + 1.0022E+00 1.0439E+00 1.0032E+00 1.0646E+00 9.6423E-01 8.6198E+01 9.3040E+01 1.0000E+00 + 9.9508E-01 1.0145E+00 1.0027E+00 1.0307E+00 9.8201E-01 8.6527E+01 9.3973E+01 1.0000E+00 + 9.8818E-01 1.0224E+00 1.0103E+00 1.0324E+00 9.6179E-01 8.1826E+01 9.6783E+01 1.0000E+00 + 6.7782E-01 1.3299E+00 1.4155E+00 1.5807E+00 3.2642E-01 7.3144E+01 1.3501E+02 1.0000E+00 + 6.7782E-01 1.3299E+00 1.4155E+00 1.5807E+00 3.2642E-01 7.3144E+01 1.3501E+02 1.0000E+00 + 9.8818E-01 1.0224E+00 1.0103E+00 1.0324E+00 9.6179E-01 8.1826E+01 9.6783E+01 1.0000E+00 + 9.9508E-01 1.0145E+00 1.0027E+00 1.0307E+00 9.8201E-01 8.6527E+01 9.3973E+01 1.0000E+00 + 1.0022E+00 1.0439E+00 1.0032E+00 1.0646E+00 9.6423E-01 8.6198E+01 9.3040E+01 1.0000E+00 + 1.0434E+00 1.1550E+00 1.0329E+00 1.3077E+00 8.7767E-01 7.6689E+01 1.0017E+02 1.0000E+00 + 6.3765E-01 1.3098E+00 1.2663E+00 1.6004E+00 3.7845E-01 6.9921E+01 1.2686E+02 1.0000E+00 + 9.8996E-01 1.0247E+00 1.0062E+00 1.0471E+00 9.5317E-01 8.3630E+01 9.4430E+01 1.0000E+00 + 9.8795E-01 1.0236E+00 1.0020E+00 1.0462E+00 9.5732E-01 8.6446E+01 9.2558E+01 1.0000E+00 + 1.0169E+00 1.0124E+00 1.0039E+00 1.0360E+00 9.9775E-01 8.5413E+01 9.4714E+01 1.0000E+00 + 1.1127E+00 1.1089E+00 1.0285E+00 1.1456E+00 1.0298E+00 7.7701E+01 1.0133E+02 1.0000E+00 + 1.0740E+00 1.1250E+00 1.0207E+00 1.1851E+00 9.8863E-01 8.3678E+01 9.7608E+01 1.0000E+00 + 1.0740E+00 1.1250E+00 1.0207E+00 1.1851E+00 9.8863E-01 8.3678E+01 9.7608E+01 1.0000E+00 + 1.1127E+00 1.1089E+00 1.0285E+00 1.1456E+00 1.0298E+00 7.7701E+01 1.0133E+02 1.0000E+00 + 1.0169E+00 1.0124E+00 1.0039E+00 1.0360E+00 9.9775E-01 8.5413E+01 9.4714E+01 1.0000E+00 + 9.8795E-01 1.0236E+00 1.0020E+00 1.0462E+00 9.5732E-01 8.6446E+01 9.2558E+01 1.0000E+00 + 9.8996E-01 1.0247E+00 1.0062E+00 1.0471E+00 9.5317E-01 8.3630E+01 9.4430E+01 1.0000E+00 + 6.3765E-01 1.3098E+00 1.2663E+00 1.6004E+00 3.7845E-01 6.9921E+01 1.2686E+02 1.0000E+00 + 6.3688E-01 1.3145E+00 1.2644E+00 1.6032E+00 3.7838E-01 6.9800E+01 1.2679E+02 1.0000E+00 + 1.0403E+00 1.1506E+00 1.0306E+00 1.3067E+00 8.7524E-01 7.7102E+01 9.9740E+01 1.0000E+00 + 1.1458E+00 1.0971E+00 1.0309E+00 1.1612E+00 1.0241E+00 7.6134E+01 9.9754E+01 1.0000E+00 + 1.0189E+00 1.0178E+00 1.0022E+00 1.0329E+00 9.9833E-01 8.6274E+01 9.2627E+01 1.0000E+00 + 1.0357E+00 1.0204E+00 1.0009E+00 1.0401E+00 1.0247E+00 8.9133E+01 9.1420E+01 1.0000E+00 + 1.0357E+00 1.0204E+00 1.0009E+00 1.0401E+00 1.0247E+00 8.9133E+01 9.1420E+01 1.0000E+00 + 1.0189E+00 1.0178E+00 1.0022E+00 1.0329E+00 9.9833E-01 8.6274E+01 9.2627E+01 1.0000E+00 + 1.1458E+00 1.0971E+00 1.0309E+00 1.1612E+00 1.0241E+00 7.6134E+01 9.9754E+01 1.0000E+00 + 1.0403E+00 1.1506E+00 1.0306E+00 1.3067E+00 8.7524E-01 7.7102E+01 9.9740E+01 1.0000E+00 + 6.3688E-01 1.3145E+00 1.2644E+00 1.6032E+00 3.7838E-01 6.9800E+01 1.2679E+02 1.0000E+00 + 7.2149E-01 1.3542E+00 1.1966E+00 1.6536E+00 4.5980E-01 6.9040E+01 1.2204E+02 1.0000E+00 + 9.2098E-01 1.0367E+00 1.0065E+00 1.1114E+00 8.6758E-01 8.6144E+01 9.2611E+01 1.0000E+00 + 1.0217E+00 1.0301E+00 1.0017E+00 1.0596E+00 9.8972E-01 8.8506E+01 9.2096E+01 1.0000E+00 + 1.0217E+00 1.0301E+00 1.0017E+00 1.0596E+00 9.8972E-01 8.8506E+01 9.2096E+01 1.0000E+00 + 9.2098E-01 1.0367E+00 1.0065E+00 1.1114E+00 8.6758E-01 8.6144E+01 9.2611E+01 1.0000E+00 + 7.2149E-01 1.3542E+00 1.1966E+00 1.6536E+00 4.5980E-01 6.9040E+01 1.2204E+02 1.0000E+00 + 6.0980E-01 1.4486E+00 1.1816E+00 1.6785E+00 4.4463E-01 6.2700E+01 1.1527E+02 1.0000E+00 + 5.6865E-01 1.2312E+00 1.1827E+00 1.3940E+00 3.7296E-01 7.5887E+01 1.2221E+02 1.0000E+00 + 9.4396E-01 1.1142E+00 1.0289E+00 1.2712E+00 8.1479E-01 8.3176E+01 9.8628E+01 1.0000E+00 + 1.1148E+00 1.0754E+00 1.0079E+00 1.1319E+00 1.0415E+00 8.5935E+01 9.3617E+01 1.0000E+00 + 1.1148E+00 1.0754E+00 1.0079E+00 1.1319E+00 1.0415E+00 8.5935E+01 9.3618E+01 1.0000E+00 + 9.4396E-01 1.1142E+00 1.0289E+00 1.2712E+00 8.1479E-01 8.3177E+01 9.8628E+01 1.0000E+00 + 5.6865E-01 1.2312E+00 1.1827E+00 1.3940E+00 3.7296E-01 7.5887E+01 1.2221E+02 1.0000E+00 + 6.0981E-01 1.4486E+00 1.1816E+00 1.6785E+00 4.4463E-01 6.2700E+01 1.1527E+02 1.0000E+00 + 9.3589E-01 1.1374E+00 1.0332E+00 1.2859E+00 7.4833E-01 7.5540E+01 9.8612E+01 1.0000E+00 + 5.0423E-01 1.2163E+00 1.1129E+00 1.4793E+00 3.2952E-01 7.5239E+01 1.1544E+02 1.0000E+00 + 5.2090E-01 1.2479E+00 1.1649E+00 1.5324E+00 3.7971E-01 6.8464E+01 1.1745E+02 1.0000E+00 + 5.2094E-01 1.2480E+00 1.1655E+00 1.5330E+00 3.7978E-01 6.8414E+01 1.1748E+02 1.0000E+00 + 5.0400E-01 1.2163E+00 1.1127E+00 1.4795E+00 3.2934E-01 7.5202E+01 1.1542E+02 1.0000E+00 + 9.3574E-01 1.1373E+00 1.0331E+00 1.2861E+00 7.4808E-01 7.5562E+01 9.8650E+01 1.0000E+00 + 6.0960E-01 1.4489E+00 1.1820E+00 1.6808E+00 4.4396E-01 6.2629E+01 1.1531E+02 1.0000E+00 + 5.6798E-01 1.2319E+00 1.1826E+00 1.3962E+00 3.7255E-01 7.5893E+01 1.2219E+02 1.0000E+00 + 9.4333E-01 1.1146E+00 1.0292E+00 1.2727E+00 8.1433E-01 8.3188E+01 9.8621E+01 1.0000E+00 + 1.1147E+00 1.0755E+00 1.0080E+00 1.1328E+00 1.0414E+00 8.5986E+01 9.3661E+01 1.0000E+00 + 1.1151E+00 1.0752E+00 1.0078E+00 1.1315E+00 1.0425E+00 8.5884E+01 9.3498E+01 1.0000E+00 + 9.4445E-01 1.1138E+00 1.0287E+00 1.2702E+00 8.1557E-01 8.3095E+01 9.8509E+01 1.0000E+00 + 5.6898E-01 1.2307E+00 1.1816E+00 1.3936E+00 3.7319E-01 7.5982E+01 1.2212E+02 1.0000E+00 + 6.1210E-01 1.4520E+00 1.1848E+00 1.6839E+00 4.4488E-01 6.2359E+01 1.1551E+02 1.0000E+00 + 9.3864E-01 1.1397E+00 1.0328E+00 1.2858E+00 7.5085E-01 7.5655E+01 9.8709E+01 1.0000E+00 + 5.0542E-01 1.2194E+00 1.1131E+00 1.4811E+00 3.2974E-01 7.5143E+01 1.1551E+02 1.0000E+00 + 5.2252E-01 1.2507E+00 1.1666E+00 1.5339E+00 3.8067E-01 6.8254E+01 1.1763E+02 1.0000E+00 + 5.2219E-01 1.2508E+00 1.1652E+00 1.5335E+00 3.8009E-01 6.8395E+01 1.1757E+02 1.0000E+00 + 5.0578E-01 1.2196E+00 1.1144E+00 1.4814E+00 3.2983E-01 7.5252E+01 1.1564E+02 1.0000E+00 + 9.4047E-01 1.1430E+00 1.0340E+00 1.2900E+00 7.5140E-01 7.5425E+01 9.8599E+01 1.0000E+00 + 6.1411E-01 1.4555E+00 1.1869E+00 1.6825E+00 4.4693E-01 6.2299E+01 1.1564E+02 1.0000E+00 + 5.7212E-01 1.2275E+00 1.1840E+00 1.3873E+00 3.7436E-01 7.6014E+01 1.2232E+02 1.0000E+00 + 9.5150E-01 1.1096E+00 1.0272E+00 1.2619E+00 8.2026E-01 8.3156E+01 9.8746E+01 1.0000E+00 + 1.1249E+00 1.0704E+00 1.0068E+00 1.1218E+00 1.0503E+00 8.5935E+01 9.3658E+01 1.0000E+00 + 1.1249E+00 1.0704E+00 1.0068E+00 1.1218E+00 1.0503E+00 8.5935E+01 9.3658E+01 1.0000E+00 + 9.5150E-01 1.1096E+00 1.0272E+00 1.2619E+00 8.2026E-01 8.3156E+01 9.8746E+01 1.0000E+00 + 5.7212E-01 1.2275E+00 1.1840E+00 1.3873E+00 3.7436E-01 7.6014E+01 1.2232E+02 1.0000E+00 + 6.1411E-01 1.4555E+00 1.1869E+00 1.6825E+00 4.4693E-01 6.2299E+01 1.1564E+02 1.0000E+00 + 9.4047E-01 1.1430E+00 1.0340E+00 1.2900E+00 7.5140E-01 7.5425E+01 9.8599E+01 1.0000E+00 + 5.0578E-01 1.2196E+00 1.1145E+00 1.4814E+00 3.2983E-01 7.5252E+01 1.1564E+02 1.0000E+00 + 5.2218E-01 1.2508E+00 1.1652E+00 1.5335E+00 3.8009E-01 6.8395E+01 1.1757E+02 1.0000E+00 + 5.2252E-01 1.2507E+00 1.1666E+00 1.5339E+00 3.8067E-01 6.8254E+01 1.1763E+02 1.0000E+00 + 5.0542E-01 1.2194E+00 1.1131E+00 1.4811E+00 3.2974E-01 7.5143E+01 1.1551E+02 1.0000E+00 + 9.3865E-01 1.1397E+00 1.0328E+00 1.2858E+00 7.5086E-01 7.5655E+01 9.8709E+01 1.0000E+00 + 6.1210E-01 1.4520E+00 1.1848E+00 1.6839E+00 4.4488E-01 6.2359E+01 1.1551E+02 1.0000E+00 + 5.6898E-01 1.2307E+00 1.1816E+00 1.3936E+00 3.7319E-01 7.5982E+01 1.2212E+02 1.0000E+00 + 9.4446E-01 1.1138E+00 1.0287E+00 1.2702E+00 8.1557E-01 8.3095E+01 9.8509E+01 1.0000E+00 + 1.1151E+00 1.0752E+00 1.0078E+00 1.1315E+00 1.0425E+00 8.5884E+01 9.3498E+01 1.0000E+00 + 1.1147E+00 1.0755E+00 1.0080E+00 1.1328E+00 1.0414E+00 8.5985E+01 9.3661E+01 1.0000E+00 + 9.4333E-01 1.1146E+00 1.0292E+00 1.2727E+00 8.1433E-01 8.3188E+01 9.8621E+01 1.0000E+00 + 5.6798E-01 1.2319E+00 1.1826E+00 1.3962E+00 3.7255E-01 7.5892E+01 1.2219E+02 1.0000E+00 + 6.0960E-01 1.4489E+00 1.1820E+00 1.6808E+00 4.4396E-01 6.2629E+01 1.1531E+02 1.0000E+00 + 9.3574E-01 1.1373E+00 1.0331E+00 1.2861E+00 7.4808E-01 7.5562E+01 9.8650E+01 1.0000E+00 + 5.0400E-01 1.2163E+00 1.1127E+00 1.4795E+00 3.2934E-01 7.5202E+01 1.1542E+02 1.0000E+00 + 5.2094E-01 1.2480E+00 1.1655E+00 1.5330E+00 3.7978E-01 6.8414E+01 1.1748E+02 1.0000E+00 + 5.2090E-01 1.2479E+00 1.1649E+00 1.5324E+00 3.7971E-01 6.8464E+01 1.1745E+02 1.0000E+00 + 5.0423E-01 1.2163E+00 1.1129E+00 1.4793E+00 3.2952E-01 7.5239E+01 1.1544E+02 1.0000E+00 + 9.3589E-01 1.1374E+00 1.0332E+00 1.2859E+00 7.4833E-01 7.5540E+01 9.8612E+01 1.0000E+00 + 9.9795E-01 1.0307E+00 1.0019E+00 1.0642E+00 9.6958E-01 8.8132E+01 9.1384E+01 1.0000E+00 + 9.9795E-01 1.0307E+00 1.0019E+00 1.0642E+00 9.6958E-01 8.8132E+01 9.1384E+01 1.0000E+00 + 7.6662E-01 1.4908E+00 1.3016E+00 1.8827E+00 3.6340E-01 6.5303E+01 1.2965E+02 1.0000E+00 + 5.9625E-01 1.4355E+00 1.1541E+00 1.7096E+00 4.0321E-01 6.4115E+01 1.0649E+02 1.0000E+00 + 8.6780E-01 1.1668E+00 1.0575E+00 1.3379E+00 6.6778E-01 7.1069E+01 9.7567E+01 1.0000E+00 + 5.0197E-01 1.2065E+00 1.1581E+00 1.3575E+00 3.3616E-01 7.6928E+01 1.2027E+02 1.0000E+00 + 5.2776E-01 1.4983E+00 1.2092E+00 1.6948E+00 3.8289E-01 6.1848E+01 1.1633E+02 1.0000E+00 + 5.8837E-01 1.4327E+00 1.6541E+00 2.9369E+00 2.6838E-01 6.4950E+01 1.1893E+02 1.0000E+00 + 6.4816E-01 1.2061E+00 1.2061E+00 1.7183E+00 4.7388E-01 6.9380E+01 1.0984E+02 1.0000E+00 + 3.6583E-01 1.6158E+00 1.2969E+00 2.1068E+00 2.0753E-01 5.5253E+01 1.1056E+02 1.0000E+00 + 3.5991E-01 1.2625E+00 1.1513E+00 1.4516E+00 2.8849E-01 6.2114E+01 1.1562E+02 1.0000E+00 + 3.6017E-01 1.2618E+00 1.1505E+00 1.4524E+00 2.8839E-01 6.2161E+01 1.1549E+02 1.0000E+00 + 3.6635E-01 1.6098E+00 1.2940E+00 2.1016E+00 2.0759E-01 5.5255E+01 1.1042E+02 1.0000E+00 + 6.6431E-01 1.2282E+00 1.2016E+00 1.7724E+00 4.7782E-01 7.0223E+01 1.0943E+02 1.0000E+00 + 6.6431E-01 1.2282E+00 1.2016E+00 1.7724E+00 4.7782E-01 7.0223E+01 1.0943E+02 1.0000E+00 + 3.6635E-01 1.6098E+00 1.2940E+00 2.1016E+00 2.0759E-01 5.5255E+01 1.1042E+02 1.0000E+00 + 3.6017E-01 1.2618E+00 1.1505E+00 1.4524E+00 2.8839E-01 6.2161E+01 1.1549E+02 1.0000E+00 + 3.5991E-01 1.2625E+00 1.1513E+00 1.4516E+00 2.8849E-01 6.2114E+01 1.1562E+02 1.0000E+00 + 3.6583E-01 1.6158E+00 1.2969E+00 2.1068E+00 2.0753E-01 5.5253E+01 1.1056E+02 1.0000E+00 + 6.4816E-01 1.2061E+00 1.2061E+00 1.7183E+00 4.7388E-01 6.9380E+01 1.0984E+02 1.0000E+00 + 5.8837E-01 1.4327E+00 1.6541E+00 2.9369E+00 2.6838E-01 6.4950E+01 1.1893E+02 1.0000E+00 + 5.2776E-01 1.4983E+00 1.2092E+00 1.6948E+00 3.8289E-01 6.1848E+01 1.1633E+02 1.0000E+00 + 5.0197E-01 1.2065E+00 1.1581E+00 1.3575E+00 3.3616E-01 7.6928E+01 1.2027E+02 1.0000E+00 + 8.6780E-01 1.1668E+00 1.0575E+00 1.3379E+00 6.6778E-01 7.1069E+01 9.7567E+01 1.0000E+00 + 5.9625E-01 1.4355E+00 1.1541E+00 1.7096E+00 4.0321E-01 6.4115E+01 1.0649E+02 1.0000E+00 + 7.6662E-01 1.4908E+00 1.3016E+00 1.8827E+00 3.6340E-01 6.5303E+01 1.2965E+02 1.0000E+00 diff --git a/previews/PR1697/tutorials/out/ice_cream_straight_sides.control b/previews/PR1697/tutorials/out/ice_cream_straight_sides.control new file mode 100644 index 00000000000..ca732872568 --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_straight_sides.control @@ -0,0 +1,57 @@ +\begin{CONTROL_INPUT} + \begin{RUN_PARAMETERS} + mesh file name = ice_cream_straight_sides.mesh + plot file name = ice_cream_straight_sides.tec + stats file name = none + mesh file format = ISM-v2 + polynomial order = 4 + plot file format = skeleton + \end{RUN_PARAMETERS} + + \begin{BACKGROUND_GRID} + x0 = [-8.0, -8.0, 0.0] + dx = [1.0, 1.0, 0.0] + N = [16,16,1] + \end{BACKGROUND_GRID} + + \begin{SPRING_SMOOTHER} + smoothing = ON + smoothing type = LinearAndCrossBarSpring + number of iterations = 25 + \end{SPRING_SMOOTHER} + +\end{CONTROL_INPUT} + +\begin{MODEL} + + \begin{INNER_BOUNDARIES} + + \begin{CHAIN} + name = IceCreamCone + \begin{END_POINTS_LINE} + name = LeftSlant + xStart = [-2.0, 1.0, 0.0] + xEnd = [ 0.0, -3.0, 0.0] + \end{END_POINTS_LINE} + + \begin{END_POINTS_LINE} + name = RightSlant + xStart = [ 0.0, -3.0, 0.0] + xEnd = [ 2.0, 1.0, 0.0] + \end{END_POINTS_LINE} + + \begin{CIRCULAR_ARC} + name = IceCream + units = degrees + center = [ 0.0, 1.0, 0.0] + radius = 2.0 + start angle = 0.0 + end angle = 180.0 + \end{CIRCULAR_ARC} + \end{CHAIN} + + \end{INNER_BOUNDARIES} + +\end{MODEL} +\end{FILE} + diff --git a/previews/PR1697/tutorials/out/ice_cream_straight_sides.mesh b/previews/PR1697/tutorials/out/ice_cream_straight_sides.mesh new file mode 100644 index 00000000000..2650c3fae30 --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_straight_sides.mesh @@ -0,0 +1,1722 @@ + ISM-V2 + 296 548 252 4 + -8.0000000000000000 -8.0000000000000000 0.0000000000000000 + -7.0000000000000000 -8.0000000000000000 0.0000000000000000 + -6.0000000000000000 -8.0000000000000000 0.0000000000000000 + -5.0000000000000000 -8.0000000000000000 0.0000000000000000 + -4.0000000000000000 -8.0000000000000000 0.0000000000000000 + -3.0000000000000000 -8.0000000000000000 0.0000000000000000 + -2.0000000000000000 -8.0000000000000000 0.0000000000000000 + -1.0000000000000000 -8.0000000000000000 0.0000000000000000 + 0.0000000000000000 -8.0000000000000000 0.0000000000000000 + 1.0000000000000000 -8.0000000000000000 0.0000000000000000 + 2.0000000000000000 -8.0000000000000000 0.0000000000000000 + 3.0000000000000000 -8.0000000000000000 0.0000000000000000 + 4.0000000000000000 -8.0000000000000000 0.0000000000000000 + 5.0000000000000000 -8.0000000000000000 0.0000000000000000 + 6.0000000000000000 -8.0000000000000000 0.0000000000000000 + 7.0000000000000000 -8.0000000000000000 0.0000000000000000 + 8.0000000000000000 -8.0000000000000000 0.0000000000000000 + -8.0000000000000000 -7.0000000000000000 0.0000000000000000 + -6.9999650574820480 -6.9999679261182877 0.0000000000000000 + -5.9998665632941011 -6.9998724565097961 0.0000000000000000 + -4.9996213184978222 -6.9996097515900049 0.0000000000000000 + -3.9991854607018733 -6.9990475318617795 0.0000000000000000 + -2.9986952242321481 -6.9981269410719644 0.0000000000000000 + -1.9985140781988169 -6.9969986109118514 0.0000000000000000 + -0.99897849037601483 -6.9960383675970457 0.0000000000000000 + 4.7989409883115671E-012 -6.9956585147354131 0.0000000000000000 + 0.99897849038591502 -6.9960383675859896 0.0000000000000000 + 1.9985140782087694 -6.9969986108947824 0.0000000000000000 + 2.9986952242406435 -6.9981269410555944 0.0000000000000000 + 3.9991854607075754 -6.9990475318504446 0.0000000000000000 + 4.9996213185007372 -6.9996097515841544 0.0000000000000000 + 5.9998665632952193 -6.9998724565075419 0.0000000000000000 + 6.9999650574823553 -6.9999679261176624 0.0000000000000000 + 8.0000000000000000 -7.0000000000000000 0.0000000000000000 + -8.0000000000000000 -6.0000000000000000 0.0000000000000000 + -6.9998976699211699 -5.9999122764402735 0.0000000000000000 + -5.9996135291753685 -5.9996633062377125 0.0000000000000000 + -4.9989226436212064 -5.9990208119514659 0.0000000000000000 + -3.9977653337150905 -5.9977581248894900 0.0000000000000000 + -2.9966204896079378 -5.9958717654755365 0.0000000000000000 + -1.9964039837778744 -5.9937267870813304 0.0000000000000000 + -0.99766406647423933 -5.9919797466297764 0.0000000000000000 + 2.4090097191669961E-011 -5.9913000293311889 0.0000000000000000 + 0.99766406652596806 -5.9919797465642901 0.0000000000000000 + 1.9964039838329390 -5.9937267869811102 0.0000000000000000 + 2.9966204896556343 -5.9958717653815992 0.0000000000000000 + 3.9977653337461323 -5.9977581248272331 0.0000000000000000 + 4.9989226436360692 -5.9990208119214286 0.0000000000000000 + 5.9996135291805706 -5.9996633062271050 0.0000000000000000 + 6.9998976699224684 -5.9999122764375885 0.0000000000000000 + 8.0000000000000000 -6.0000000000000000 0.0000000000000000 + -8.0000000000000000 -5.0000000000000000 0.0000000000000000 + -6.9997501274902012 -4.9998034408089786 0.0000000000000000 + -5.9990675728612679 -4.9992697388441112 0.0000000000000000 + -4.9973858232938344 -4.9979740837677751 0.0000000000000000 + -3.9945964688979139 -4.9957899032377453 0.0000000000000000 + -2.9923152259971646 -4.9934053345787692 0.0000000000000000 + -1.9929564366212700 -4.9916256720553269 0.0000000000000000 + -0.99625966749685468 -4.9904887766265009 0.0000000000000000 + 8.7516607876472420E-011 -4.9900352567664603 0.0000000000000000 + 0.99625966770123564 -4.9904887763239962 0.0000000000000000 + 1.9929564368609574 -4.9916256715941776 0.0000000000000000 + 2.9923152262075878 -4.9934053341572957 0.0000000000000000 + 3.9945964690280817 -4.9957899029737884 0.0000000000000000 + 4.9973858233507853 -4.9979740836508393 0.0000000000000000 + 5.9990675728791238 -4.9992697388066452 0.0000000000000000 + 6.9997501274942060 -4.9998034408002647 0.0000000000000000 + 8.0000000000000000 -5.0000000000000000 0.0000000000000000 + -8.0000000000000000 -4.0000000000000000 0.0000000000000000 + -6.9994442810297537 -3.9996092645441159 0.0000000000000000 + -5.9979747892447062 -3.9985815423292643 0.0000000000000000 + -4.9942895414925133 -3.9961147104828689 0.0000000000000000 + -3.9872884982575028 -3.9920749153444808 0.0000000000000000 + -2.9807287305762533 -3.9900738967481790 0.0000000000000000 + -1.9852784719276839 -3.9938575615448597 0.0000000000000000 + -0.99708909504304877 -3.9973734973237129 0.0000000000000000 + 2.1033866962410606E-010 -3.9974440103039064 0.0000000000000000 + 0.99708909566634052 -3.9973734962049221 0.0000000000000000 + 1.9852784727951609 -3.9938575598154191 0.0000000000000000 + 2.9807287313302866 -3.9900738952156258 0.0000000000000000 + 3.9872884986834030 -3.9920749144641170 0.0000000000000000 + 4.9942895416564230 -3.9961147101336323 0.0000000000000000 + 5.9979747892902688 -3.9985815422265709 0.0000000000000000 + 6.9994442810389081 -3.9996092645214816 0.0000000000000000 + 8.0000000000000000 -4.0000000000000000 0.0000000000000000 + -8.0000000000000000 -3.0000000000000000 0.0000000000000000 + -6.9988707545318789 -2.9993214807930388 0.0000000000000000 + -5.9959723250282675 -2.9975703581842250 0.0000000000000000 + -4.9889296386581075 -2.9933466877064818 0.0000000000000000 + -3.9746774455653884 -2.9854293504387881 0.0000000000000000 + -2.9486314200342503 -2.9764998162463585 0.0000000000000000 + -1.9503942149316469 -3.0021256138813035 0.0000000000000000 + -1.0261614729009205 -3.0312104940798901 0.0000000000000000 + 1.0261614745493584 -3.0312104908158548 0.0000000000000000 + 1.9503942176787044 -3.0021256083069598 0.0000000000000000 + 2.9486314222736021 -2.9764998116137829 0.0000000000000000 + 3.9746774466049950 -2.9854293481972203 0.0000000000000000 + 4.9889296390019764 -2.9933466869030068 0.0000000000000000 + 5.9959723251123087 -2.9975703579581028 0.0000000000000000 + 6.9988707545467523 -2.9993214807434820 0.0000000000000000 + 8.0000000000000000 -3.0000000000000000 0.0000000000000000 + -8.0000000000000000 -2.0000000000000000 0.0000000000000000 + -6.9979591237819632 -1.9990110686940572 0.0000000000000000 + -5.9927227618739725 -1.9964483151530883 0.0000000000000000 + -4.9801080557894242 -1.9901770532049168 0.0000000000000000 + -3.9576959349815479 -1.9783015452963999 0.0000000000000000 + -2.9197320667969913 -1.9542226531228222 0.0000000000000000 + -1.7464656898511224 -1.8918471048105712 0.0000000000000000 + -1.0538136609635054 -2.3225159630485046 0.0000000000000000 + 1.0538136634211011 -2.3225159580901482 0.0000000000000000 + 1.7464656992760117 -1.8918470856151424 0.0000000000000000 + 2.9197320715976618 -1.9542226428284530 0.0000000000000000 + 3.9576959367463562 -1.9783015410469320 0.0000000000000000 + 4.9801080562838553 -1.9901770517309758 0.0000000000000000 + 5.9927227619766033 -1.9964483147281369 0.0000000000000000 + 6.9979591237966705 -1.9990110685977320 0.0000000000000000 + 8.0000000000000000 -2.0000000000000000 0.0000000000000000 + -8.0000000000000000 -1.0000000000000000 0.0000000000000000 + -6.9968317675017770 -0.99886259715705294 0.0000000000000000 + -5.9885538594769985 -0.99581599636441842 0.0000000000000000 + -4.9678071326527107 -0.98792038864408005 0.0000000000000000 + -3.9258196694477046 -0.97144892599683563 0.0000000000000000 + -2.9029530084938924 -0.95956909177122207 0.0000000000000000 + -1.9915356039925562 -0.87186063981735284 0.0000000000000000 + 1.9915356222472387 -0.87186060209166283 0.0000000000000000 + 2.9029530147562950 -0.95956907678113346 0.0000000000000000 + 3.9258196712523956 -0.97144891979974901 0.0000000000000000 + 4.9678071330492370 -0.98792038628267198 0.0000000000000000 + 5.9885538595330425 -0.99581599564497181 0.0000000000000000 + 6.9968317675030942 -0.99886259698874036 0.0000000000000000 + 8.0000000000000000 -1.0000000000000000 0.0000000000000000 + -8.0000000000000000 0.0000000000000000 0.0000000000000000 + -6.9958722740070352 9.2605842887460131E-004 0.0000000000000000 + -5.9849442010567895 3.5673767964436867E-003 0.0000000000000000 + -4.9568386769387480 1.1004836478173498E-002 0.0000000000000000 + -3.8951308919991683 2.9902496021364251E-002 0.0000000000000000 + -2.7032673839116930 9.0361097440859073E-002 0.0000000000000000 + -2.0571891363329842 -0.24562578581377828 0.0000000000000000 + 2.0571891499716477 -0.24562575669779302 0.0000000000000000 + 2.7032673869204902 9.0361111129516711E-002 0.0000000000000000 + 3.8951308924034209 2.9902504788020891E-002 0.0000000000000000 + 4.9568386769148196 1.1004839991627878E-002 0.0000000000000000 + 5.9849442010018254 3.5673778782903827E-003 0.0000000000000000 + 6.9958722739839931 9.2605868315656019E-004 0.0000000000000000 + 8.0000000000000000 0.0000000000000000 0.0000000000000000 + -8.0000000000000000 1.0000000000000000 0.0000000000000000 + -6.9955326960520150 1.0003662482577591 0.0000000000000000 + -5.9837177157599681 1.0016260315303323 0.0000000000000000 + -4.9534382883740049 1.0055660842008067 0.0000000000000000 + -3.8899281210667138 1.0153264300994280 0.0000000000000000 + -2.8576269259239067 1.0332611206083833 0.0000000000000000 + 2.8576269206180700 1.0332611487718453 0.0000000000000000 + 3.8899281199071547 1.0153264422760757 0.0000000000000000 + 4.9534382879928192 1.0055660886453257 0.0000000000000000 + 5.9837177156175274 1.0016260328696145 0.0000000000000000 + 6.9955326960100548 1.0003662485715008 0.0000000000000000 + 8.0000000000000000 1.0000000000000000 0.0000000000000000 + -8.0000000000000000 2.0000000000000000 0.0000000000000000 + -6.9960066511840280 1.9997507013087121 0.0000000000000000 + -5.9856229332322686 1.9994091100965983 0.0000000000000000 + -4.9595830937353638 1.9990558628265500 0.0000000000000000 + -3.9045581869999268 1.9973598907135701 0.0000000000000000 + -2.7368541689106971 1.9740722869324492 0.0000000000000000 + -2.1263404894339657 2.2948900365574501 0.0000000000000000 + 2.1263405099846904 2.2948900432082628 0.0000000000000000 + 2.7368541668551467 1.9740723203179147 0.0000000000000000 + 3.9045581868167778 1.9973599020749815 0.0000000000000000 + 4.9595830935518537 1.9990558669341754 0.0000000000000000 + 5.9856229331196342 1.9994091113584684 0.0000000000000000 + 6.9960066511449766 1.9997507016103995 0.0000000000000000 + 8.0000000000000000 2.0000000000000000 0.0000000000000000 + -8.0000000000000000 3.0000000000000000 0.0000000000000000 + -6.9970741145254109 2.9994054140824691 0.0000000000000000 + -5.9897519210034096 2.9981360157242580 0.0000000000000000 + -4.9724862257635190 2.9954390224920608 0.0000000000000000 + -3.9404681650821662 2.9905143469756337 0.0000000000000000 + -2.9327419944795010 2.9950483993160772 0.0000000000000000 + -1.9277593203701284 2.9288827058393201 0.0000000000000000 + -1.2934382299147573 3.1270574946750189 0.0000000000000000 + 1.2934382981899317 3.1270574584627195 0.0000000000000000 + 1.9277593629377268 2.9288826795836580 0.0000000000000000 + 2.9327420063368876 2.9950484011603677 0.0000000000000000 + 3.9404681675772051 2.9905143520853521 0.0000000000000000 + 4.9724862261650982 2.9954390249429101 0.0000000000000000 + 5.9897519210122363 2.9981360165754762 0.0000000000000000 + 6.9970741145083171 2.9994054143006470 0.0000000000000000 + 8.0000000000000000 3.0000000000000000 0.0000000000000000 + -8.0000000000000000 4.0000000000000000 0.0000000000000000 + -6.9982592393987968 3.9994059470511574 0.0000000000000000 + -5.9941718412117382 3.9980597406816538 0.0000000000000000 + -4.9856339697631320 3.9950007774720344 0.0000000000000000 + -3.9751323492146069 3.9888639093805867 0.0000000000000000 + -2.9708305521947196 3.9715346676422256 0.0000000000000000 + -1.9930387640582898 3.9338224795098449 0.0000000000000000 + -0.96763685658155807 3.7397274668414906 0.0000000000000000 + 3.3429034151622827E-008 3.8724227990342959 0.0000000000000000 + 0.96763691762346205 3.7397274489896106 0.0000000000000000 + 1.9930387926022926 3.9338224677871469 0.0000000000000000 + 2.9708305639402397 3.9715346636992050 0.0000000000000000 + 3.9751323526676017 3.9888639097163923 0.0000000000000000 + 4.9856339705045638 3.9950007782744765 0.0000000000000000 + 5.9941718413174092 3.9980597410666165 0.0000000000000000 + 6.9982592394038319 3.9994059471655752 0.0000000000000000 + 8.0000000000000000 4.0000000000000000 0.0000000000000000 + -8.0000000000000000 5.0000000000000000 0.0000000000000000 + -6.9991633741456480 4.9995936517804571 0.0000000000000000 + -5.9973416427807713 4.9986235063327511 0.0000000000000000 + -4.9939474927689487 4.9961691895174090 0.0000000000000000 + -3.9898774621657993 4.9900396721612950 0.0000000000000000 + -2.9882983865581152 4.9754672684598420 0.0000000000000000 + -1.9884726792358567 4.9414046357118258 0.0000000000000000 + -0.99054764142862672 4.9076265219014017 0.0000000000000000 + 1.5044633229432108E-008 4.8977197323029209 0.0000000000000000 + 0.99054766715027320 4.9076265171995406 0.0000000000000000 + 1.9884726950216143 4.9414046308491191 0.0000000000000000 + 2.9882983935721197 4.9754672660048422 0.0000000000000000 + 3.9898774645940622 4.9900396715407211 0.0000000000000000 + 4.9939474933945487 4.9961691895653884 0.0000000000000000 + 5.9973416428964281 4.9986235064339004 0.0000000000000000 + 6.9991633741594397 4.9995936518214812 0.0000000000000000 + 8.0000000000000000 5.0000000000000000 0.0000000000000000 + -8.0000000000000000 6.0000000000000000 0.0000000000000000 + -6.9996739984196390 5.9997893596429419 0.0000000000000000 + -5.9989986118848257 5.9992529007592390 0.0000000000000000 + -4.9977434317195026 5.9977709675596005 0.0000000000000000 + -3.9960992156787842 5.9940404411235333 0.0000000000000000 + -2.9946713951079547 5.9858782583382260 0.0000000000000000 + -1.9942453640855442 5.9731438824671530 0.0000000000000000 + -0.99595680588594671 5.9611672784475598 0.0000000000000000 + 5.4895336706131739E-009 5.9564095944048683 0.0000000000000000 + 0.99595681544617021 5.9611672771802988 0.0000000000000000 + 1.9942453703764043 5.9731438809327670 0.0000000000000000 + 2.9946713982270148 5.9858782573487614 0.0000000000000000 + 3.9960992168542182 5.9940404407363950 0.0000000000000000 + 4.9977434320589262 5.9977709674807409 0.0000000000000000 + 5.9989986119578065 5.9992529007644064 0.0000000000000000 + 6.9996739984307244 5.9997893596515759 0.0000000000000000 + 8.0000000000000000 6.0000000000000000 0.0000000000000000 + -8.0000000000000000 7.0000000000000000 0.0000000000000000 + -6.9999004989624796 6.9999196928494865 0.0000000000000000 + -5.9996945336645995 6.9997036786799463 0.0000000000000000 + -4.9992926804199769 6.9990875647356665 0.0000000000000000 + -3.9986895202660464 6.9975750738144677 0.0000000000000000 + -2.9980654465831940 6.9946658241746293 0.0000000000000000 + -1.9978514474788915 6.9906409012147579 0.0000000000000000 + -0.99851861799346908 6.9869919193812402 0.0000000000000000 + 1.5699479313662187E-009 6.9855176655399553 0.0000000000000000 + 0.99851862076110953 6.9869919190879317 0.0000000000000000 + 1.9978514493699755 6.9906409008314814 0.0000000000000000 + 2.9980654475797910 6.9946658238941168 0.0000000000000000 + 3.9986895206695174 6.9975750736809648 0.0000000000000000 + 4.9992926805452846 6.9990875646946797 0.0000000000000000 + 5.9996945336942300 6.9997036786734528 0.0000000000000000 + 6.9999004989676070 6.9999196928498879 0.0000000000000000 + 8.0000000000000000 7.0000000000000000 0.0000000000000000 + -8.0000000000000000 8.0000000000000000 0.0000000000000000 + -7.0000000000000000 8.0000000000000000 0.0000000000000000 + -6.0000000000000000 8.0000000000000000 0.0000000000000000 + -5.0000000000000000 8.0000000000000000 0.0000000000000000 + -4.0000000000000000 8.0000000000000000 0.0000000000000000 + -3.0000000000000000 8.0000000000000000 0.0000000000000000 + -2.0000000000000000 8.0000000000000000 0.0000000000000000 + -1.0000000000000000 8.0000000000000000 0.0000000000000000 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + 1.0000000000000000 8.0000000000000000 0.0000000000000000 + 2.0000000000000000 8.0000000000000000 0.0000000000000000 + 3.0000000000000000 8.0000000000000000 0.0000000000000000 + 4.0000000000000000 8.0000000000000000 0.0000000000000000 + 5.0000000000000000 8.0000000000000000 0.0000000000000000 + 6.0000000000000000 8.0000000000000000 0.0000000000000000 + 7.0000000000000000 8.0000000000000000 0.0000000000000000 + 8.0000000000000000 8.0000000000000000 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 0.84062499397195267 -1.3187500120560947 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.5593750060280469 0.11875001205609381 0.0000000000000000 + 1.8406249939719526 0.68124998794390512 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9234528539428934 1.5480229180052039 0.0000000000000000 + 1.7577069153495042 1.9541836299856183 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 0.95418362998561834 2.7577069153495040 0.0000000000000000 + 0.54802294711610822 2.9234528456487245 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -0.54802270862631064 2.9234529135983243 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.7577069153495022 1.9541836299856215 0.0000000000000000 + -1.9234529135983240 1.5480227086263110 0.0000000000000000 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.5593750060280471 0.11875001205609437 0.0000000000000000 + -1.2000000031251037 -0.59999999374979263 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 1 2 1 0 1 0 + 2 19 1 2 2 4 + 18 19 1 17 3 1 + 1 18 1 0 4 0 + 2 3 2 0 1 0 + 3 20 2 3 2 4 + 19 20 2 18 3 1 + 3 4 3 0 1 0 + 4 21 3 4 2 4 + 20 21 3 19 3 1 + 4 5 4 0 1 0 + 5 22 4 5 2 4 + 21 22 4 20 3 1 + 5 6 5 0 1 0 + 6 23 5 6 2 4 + 22 23 5 21 3 1 + 6 7 6 0 1 0 + 7 24 6 7 2 4 + 23 24 6 22 3 1 + 7 8 7 0 1 0 + 8 25 7 8 2 4 + 24 25 7 23 3 1 + 8 9 8 0 1 0 + 9 26 8 9 2 4 + 25 26 8 24 3 1 + 9 10 9 0 1 0 + 10 27 9 10 2 4 + 26 27 9 25 3 1 + 10 11 10 0 1 0 + 11 28 10 11 2 4 + 27 28 10 26 3 1 + 11 12 11 0 1 0 + 12 29 11 12 2 4 + 28 29 11 27 3 1 + 12 13 12 0 1 0 + 13 30 12 13 2 4 + 29 30 12 28 3 1 + 13 14 13 0 1 0 + 14 31 13 14 2 4 + 30 31 13 29 3 1 + 14 15 14 0 1 0 + 15 32 14 15 2 4 + 31 32 14 30 3 1 + 15 16 15 0 1 0 + 16 33 15 16 2 4 + 32 33 15 31 3 1 + 16 17 16 0 1 0 + 17 34 16 0 2 0 + 33 34 16 32 3 1 + 19 36 17 18 2 4 + 35 36 17 33 3 1 + 18 35 17 0 4 0 + 20 37 18 19 2 4 + 36 37 18 34 3 1 + 21 38 19 20 2 4 + 37 38 19 35 3 1 + 22 39 20 21 2 4 + 38 39 20 36 3 1 + 23 40 21 22 2 4 + 39 40 21 37 3 1 + 24 41 22 23 2 4 + 40 41 22 38 3 1 + 25 42 23 24 2 4 + 41 42 23 39 3 1 + 26 43 24 25 2 4 + 42 43 24 40 3 1 + 27 44 25 26 2 4 + 43 44 25 41 3 1 + 28 45 26 27 2 4 + 44 45 26 42 3 1 + 29 46 27 28 2 4 + 45 46 27 43 3 1 + 30 47 28 29 2 4 + 46 47 28 44 3 1 + 31 48 29 30 2 4 + 47 48 29 45 3 1 + 32 49 30 31 2 4 + 48 49 30 46 3 1 + 33 50 31 32 2 4 + 49 50 31 47 3 1 + 34 51 32 0 2 0 + 50 51 32 48 3 1 + 36 53 33 34 2 4 + 52 53 33 49 3 1 + 35 52 33 0 4 0 + 37 54 34 35 2 4 + 53 54 34 50 3 1 + 38 55 35 36 2 4 + 54 55 35 51 3 1 + 39 56 36 37 2 4 + 55 56 36 52 3 1 + 40 57 37 38 2 4 + 56 57 37 53 3 1 + 41 58 38 39 2 4 + 57 58 38 54 3 1 + 42 59 39 40 2 4 + 58 59 39 55 3 1 + 43 60 40 41 2 4 + 59 60 40 56 3 1 + 44 61 41 42 2 4 + 60 61 41 57 3 1 + 45 62 42 43 2 4 + 61 62 42 58 3 1 + 46 63 43 44 2 4 + 62 63 43 59 3 1 + 47 64 44 45 2 4 + 63 64 44 60 3 1 + 48 65 45 46 2 4 + 64 65 45 61 3 1 + 49 66 46 47 2 4 + 65 66 46 62 3 1 + 50 67 47 48 2 4 + 66 67 47 63 3 1 + 51 68 48 0 2 0 + 67 68 48 64 3 1 + 53 70 49 50 2 4 + 69 70 49 65 3 1 + 52 69 49 0 4 0 + 54 71 50 51 2 4 + 70 71 50 66 3 1 + 55 72 51 52 2 4 + 71 72 51 67 3 1 + 56 73 52 53 2 4 + 72 73 52 68 3 1 + 57 74 53 54 2 4 + 73 74 53 69 3 1 + 58 75 54 55 2 4 + 74 75 54 70 3 1 + 59 76 55 56 2 4 + 75 76 55 71 3 1 + 60 77 56 57 2 4 + 76 77 56 227 3 2 + 61 78 57 58 2 4 + 77 78 57 228 3 2 + 62 79 58 59 2 4 + 78 79 58 72 3 1 + 63 80 59 60 2 4 + 79 80 59 73 3 1 + 64 81 60 61 2 4 + 80 81 60 74 3 1 + 65 82 61 62 2 4 + 81 82 61 75 3 1 + 66 83 62 63 2 4 + 82 83 62 76 3 1 + 67 84 63 64 2 4 + 83 84 63 77 3 1 + 68 85 64 0 2 0 + 84 85 64 78 3 1 + 70 87 65 66 2 4 + 86 87 65 79 3 1 + 69 86 65 0 4 0 + 71 88 66 67 2 4 + 87 88 66 80 3 1 + 72 89 67 68 2 4 + 88 89 67 81 3 1 + 73 90 68 69 2 4 + 89 90 68 82 3 1 + 74 91 69 70 2 4 + 90 91 69 83 3 1 + 75 92 70 71 2 4 + 91 92 70 84 3 1 + 76 93 71 227 2 -1 + 92 93 71 85 3 1 + 79 95 72 73 2 4 + 94 95 72 86 3 1 + 78 94 72 228 4 -3 + 80 96 73 74 2 4 + 95 96 73 87 3 1 + 81 97 74 75 2 4 + 96 97 74 88 3 1 + 82 98 75 76 2 4 + 97 98 75 89 3 1 + 83 99 76 77 2 4 + 98 99 76 90 3 1 + 84 100 77 78 2 4 + 99 100 77 91 3 1 + 85 101 78 0 2 0 + 100 101 78 92 3 1 + 87 103 79 80 2 4 + 102 103 79 93 3 1 + 86 102 79 0 4 0 + 88 104 80 81 2 4 + 103 104 80 94 3 1 + 89 105 81 82 2 4 + 104 105 81 95 3 1 + 90 106 82 83 2 4 + 105 106 82 96 3 1 + 91 107 83 84 2 4 + 106 107 83 97 3 1 + 92 108 84 85 2 4 + 107 108 84 98 3 1 + 93 109 85 252 2 -1 + 108 109 85 251 3 1 + 95 111 86 87 2 4 + 110 111 86 230 3 1 + 94 110 86 229 4 1 + 96 112 87 88 2 4 + 111 112 87 99 3 1 + 97 113 88 89 2 4 + 112 113 88 100 3 1 + 98 114 89 90 2 4 + 113 114 89 101 3 1 + 99 115 90 91 2 4 + 114 115 90 102 3 1 + 100 116 91 92 2 4 + 115 116 91 103 3 1 + 101 117 92 0 2 0 + 116 117 92 104 3 1 + 103 119 93 94 2 4 + 118 119 93 105 3 1 + 102 118 93 0 4 0 + 104 120 94 95 2 4 + 119 120 94 106 3 1 + 105 121 95 96 2 4 + 120 121 95 107 3 1 + 106 122 96 97 2 4 + 121 122 96 108 3 1 + 107 123 97 98 2 4 + 122 123 97 109 3 1 + 108 124 98 250 2 -1 + 123 124 98 110 3 1 + 112 126 99 100 2 4 + 125 126 99 111 3 1 + 111 125 99 231 4 1 + 113 127 100 101 2 4 + 126 127 100 112 3 1 + 114 128 101 102 2 4 + 127 128 101 113 3 1 + 115 129 102 103 2 4 + 128 129 102 114 3 1 + 116 130 103 104 2 4 + 129 130 103 115 3 1 + 117 131 104 0 2 0 + 130 131 104 116 3 1 + 119 133 105 106 2 4 + 132 133 105 117 3 1 + 118 132 105 0 4 0 + 120 134 106 107 2 4 + 133 134 106 118 3 1 + 121 135 107 108 2 4 + 134 135 107 119 3 1 + 122 136 108 109 2 4 + 135 136 108 120 3 1 + 123 137 109 110 2 4 + 136 137 109 121 3 1 + 124 138 110 249 2 -1 + 137 138 110 248 3 1 + 126 140 111 112 2 4 + 139 140 111 233 3 1 + 125 139 111 232 4 1 + 127 141 112 113 2 4 + 140 141 112 122 3 1 + 128 142 113 114 2 4 + 141 142 113 123 3 1 + 129 143 114 115 2 4 + 142 143 114 124 3 1 + 130 144 115 116 2 4 + 143 144 115 125 3 1 + 131 145 116 0 2 0 + 144 145 116 126 3 1 + 133 147 117 118 2 4 + 146 147 117 127 3 1 + 132 146 117 0 4 0 + 134 148 118 119 2 4 + 147 148 118 128 3 1 + 135 149 119 120 2 4 + 148 149 119 129 3 1 + 136 150 120 121 2 4 + 149 150 120 130 3 1 + 137 151 121 247 2 -1 + 150 151 121 131 3 1 + 141 153 122 123 2 4 + 152 153 122 132 3 1 + 140 152 122 234 4 1 + 142 154 123 124 2 4 + 153 154 123 133 3 1 + 143 155 124 125 2 4 + 154 155 124 134 3 1 + 144 156 125 126 2 4 + 155 156 125 135 3 1 + 145 157 126 0 2 0 + 156 157 126 136 3 1 + 147 159 127 128 2 4 + 158 159 127 137 3 1 + 146 158 127 0 4 0 + 148 160 128 129 2 4 + 159 160 128 138 3 1 + 149 161 129 130 2 4 + 160 161 129 139 3 1 + 150 162 130 131 2 4 + 161 162 130 140 3 1 + 151 163 131 246 2 -1 + 162 163 131 141 3 1 + 153 167 132 133 2 4 + 166 167 132 144 3 1 + 152 166 132 235 4 1 + 154 168 133 134 2 4 + 167 168 133 145 3 1 + 155 169 134 135 2 4 + 168 169 134 146 3 1 + 156 170 135 136 2 4 + 169 170 135 147 3 1 + 157 171 136 0 2 0 + 170 171 136 148 3 1 + 159 173 137 138 2 4 + 172 173 137 149 3 1 + 158 172 137 0 4 0 + 160 174 138 139 2 4 + 173 174 138 150 3 1 + 161 175 139 140 2 4 + 174 175 139 151 3 1 + 162 176 140 141 2 4 + 175 176 140 152 3 1 + 163 177 141 142 2 4 + 176 177 141 153 3 1 + 163 164 142 245 1 -1 + 164 178 142 244 2 -1 + 177 178 142 154 3 1 + 165 166 143 236 1 -1 + 166 182 143 144 2 4 + 181 182 143 157 3 1 + 165 181 143 237 4 1 + 167 183 144 145 2 4 + 182 183 144 158 3 1 + 168 184 145 146 2 4 + 183 184 145 159 3 1 + 169 185 146 147 2 4 + 184 185 146 160 3 1 + 170 186 147 148 2 4 + 185 186 147 161 3 1 + 171 187 148 0 2 0 + 186 187 148 162 3 1 + 173 189 149 150 2 4 + 188 189 149 163 3 1 + 172 188 149 0 4 0 + 174 190 150 151 2 4 + 189 190 150 164 3 1 + 175 191 151 152 2 4 + 190 191 151 165 3 1 + 176 192 152 153 2 4 + 191 192 152 166 3 1 + 177 193 153 154 2 4 + 192 193 153 167 3 1 + 178 194 154 155 2 4 + 193 194 154 168 3 1 + 178 179 155 243 1 -1 + 179 195 155 242 2 -1 + 194 195 155 169 3 1 + 180 181 156 238 1 -1 + 181 198 156 157 2 4 + 197 198 156 172 3 1 + 180 197 156 239 4 1 + 182 199 157 158 2 4 + 198 199 157 173 3 1 + 183 200 158 159 2 4 + 199 200 158 174 3 1 + 184 201 159 160 2 4 + 200 201 159 175 3 1 + 185 202 160 161 2 4 + 201 202 160 176 3 1 + 186 203 161 162 2 4 + 202 203 161 177 3 1 + 187 204 162 0 2 0 + 203 204 162 178 3 1 + 189 206 163 164 2 4 + 205 206 163 179 3 1 + 188 205 163 0 4 0 + 190 207 164 165 2 4 + 206 207 164 180 3 1 + 191 208 165 166 2 4 + 207 208 165 181 3 1 + 192 209 166 167 2 4 + 208 209 166 182 3 1 + 193 210 167 168 2 4 + 209 210 167 183 3 1 + 194 211 168 169 2 4 + 210 211 168 184 3 1 + 195 212 169 170 2 4 + 211 212 169 185 3 1 + 195 196 170 241 1 -1 + 196 213 170 171 2 4 + 212 213 170 186 3 1 + 196 197 171 240 1 -1 + 197 214 171 172 2 4 + 213 214 171 187 3 1 + 198 215 172 173 2 4 + 214 215 172 188 3 1 + 199 216 173 174 2 4 + 215 216 173 189 3 1 + 200 217 174 175 2 4 + 216 217 174 190 3 1 + 201 218 175 176 2 4 + 217 218 175 191 3 1 + 202 219 176 177 2 4 + 218 219 176 192 3 1 + 203 220 177 178 2 4 + 219 220 177 193 3 1 + 204 221 178 0 2 0 + 220 221 178 194 3 1 + 206 223 179 180 2 4 + 222 223 179 195 3 1 + 205 222 179 0 4 0 + 207 224 180 181 2 4 + 223 224 180 196 3 1 + 208 225 181 182 2 4 + 224 225 181 197 3 1 + 209 226 182 183 2 4 + 225 226 182 198 3 1 + 210 227 183 184 2 4 + 226 227 183 199 3 1 + 211 228 184 185 2 4 + 227 228 184 200 3 1 + 212 229 185 186 2 4 + 228 229 185 201 3 1 + 213 230 186 187 2 4 + 229 230 186 202 3 1 + 214 231 187 188 2 4 + 230 231 187 203 3 1 + 215 232 188 189 2 4 + 231 232 188 204 3 1 + 216 233 189 190 2 4 + 232 233 189 205 3 1 + 217 234 190 191 2 4 + 233 234 190 206 3 1 + 218 235 191 192 2 4 + 234 235 191 207 3 1 + 219 236 192 193 2 4 + 235 236 192 208 3 1 + 220 237 193 194 2 4 + 236 237 193 209 3 1 + 221 238 194 0 2 0 + 237 238 194 210 3 1 + 223 240 195 196 2 4 + 239 240 195 211 3 1 + 222 239 195 0 4 0 + 224 241 196 197 2 4 + 240 241 196 212 3 1 + 225 242 197 198 2 4 + 241 242 197 213 3 1 + 226 243 198 199 2 4 + 242 243 198 214 3 1 + 227 244 199 200 2 4 + 243 244 199 215 3 1 + 228 245 200 201 2 4 + 244 245 200 216 3 1 + 229 246 201 202 2 4 + 245 246 201 217 3 1 + 230 247 202 203 2 4 + 246 247 202 218 3 1 + 231 248 203 204 2 4 + 247 248 203 219 3 1 + 232 249 204 205 2 4 + 248 249 204 220 3 1 + 233 250 205 206 2 4 + 249 250 205 221 3 1 + 234 251 206 207 2 4 + 250 251 206 222 3 1 + 235 252 207 208 2 4 + 251 252 207 223 3 1 + 236 253 208 209 2 4 + 252 253 208 224 3 1 + 237 254 209 210 2 4 + 253 254 209 225 3 1 + 238 255 210 0 2 0 + 254 255 210 226 3 1 + 240 257 211 212 2 4 + 256 257 211 0 3 0 + 239 256 211 0 4 0 + 241 258 212 213 2 4 + 257 258 212 0 3 0 + 242 259 213 214 2 4 + 258 259 213 0 3 0 + 243 260 214 215 2 4 + 259 260 214 0 3 0 + 244 261 215 216 2 4 + 260 261 215 0 3 0 + 245 262 216 217 2 4 + 261 262 216 0 3 0 + 246 263 217 218 2 4 + 262 263 217 0 3 0 + 247 264 218 219 2 4 + 263 264 218 0 3 0 + 248 265 219 220 2 4 + 264 265 219 0 3 0 + 249 266 220 221 2 4 + 265 266 220 0 3 0 + 250 267 221 222 2 4 + 266 267 221 0 3 0 + 251 268 222 223 2 4 + 267 268 222 0 3 0 + 252 269 223 224 2 4 + 268 269 223 0 3 0 + 253 270 224 225 2 4 + 269 270 224 0 3 0 + 254 271 225 226 2 4 + 270 271 225 0 3 0 + 255 272 226 0 2 0 + 271 272 226 0 3 0 + 273 77 227 228 3 1 + 93 273 227 252 4 2 + 273 94 228 229 4 -4 + 110 274 229 230 2 4 + 273 274 229 0 3 0 + 111 275 230 231 2 4 + 274 275 230 0 3 0 + 125 276 231 232 2 4 + 275 276 231 0 3 0 + 139 277 232 233 2 4 + 276 277 232 0 3 0 + 140 278 233 234 2 4 + 277 278 233 0 3 0 + 152 279 234 235 2 4 + 278 279 234 0 3 0 + 166 280 235 236 2 4 + 279 280 235 0 3 0 + 165 281 236 237 2 4 + 280 281 236 0 3 0 + 181 282 237 238 2 4 + 281 282 237 0 3 0 + 180 283 238 239 2 4 + 282 283 238 0 3 0 + 197 284 239 240 2 4 + 283 284 239 0 3 0 + 196 285 240 241 2 4 + 284 285 240 0 3 0 + 195 286 241 242 2 4 + 285 286 241 0 3 0 + 179 287 242 243 2 4 + 286 287 242 0 3 0 + 178 288 243 244 2 4 + 287 288 243 0 3 0 + 164 289 244 245 2 4 + 288 289 244 0 3 0 + 163 290 245 246 2 4 + 289 290 245 0 3 0 + 151 291 246 247 2 4 + 290 291 246 0 3 0 + 137 292 247 248 2 4 + 291 292 247 0 3 0 + 138 293 248 249 2 4 + 292 293 248 0 3 0 + 124 294 249 250 2 4 + 293 294 249 0 3 0 + 108 295 250 251 2 4 + 294 295 250 0 3 0 + 109 296 251 252 2 4 + 295 296 251 0 3 0 + 296 273 252 0 3 0 + 1 2 19 18 + 0 0 0 0 + Bottom --- --- Left + 2 3 20 19 + 0 0 0 0 + Bottom --- --- --- + 3 4 21 20 + 0 0 0 0 + Bottom --- --- --- + 4 5 22 21 + 0 0 0 0 + Bottom --- --- --- + 5 6 23 22 + 0 0 0 0 + Bottom --- --- --- + 6 7 24 23 + 0 0 0 0 + Bottom --- --- --- + 7 8 25 24 + 0 0 0 0 + Bottom --- --- --- + 8 9 26 25 + 0 0 0 0 + Bottom --- --- --- + 9 10 27 26 + 0 0 0 0 + Bottom --- --- --- + 10 11 28 27 + 0 0 0 0 + Bottom --- --- --- + 11 12 29 28 + 0 0 0 0 + Bottom --- --- --- + 12 13 30 29 + 0 0 0 0 + Bottom --- --- --- + 13 14 31 30 + 0 0 0 0 + Bottom --- --- --- + 14 15 32 31 + 0 0 0 0 + Bottom --- --- --- + 15 16 33 32 + 0 0 0 0 + Bottom --- --- --- + 16 17 34 33 + 0 0 0 0 + Bottom Right --- --- + 18 19 36 35 + 0 0 0 0 + --- --- --- Left + 19 20 37 36 + 0 0 0 0 + --- --- --- --- + 20 21 38 37 + 0 0 0 0 + --- --- --- --- + 21 22 39 38 + 0 0 0 0 + --- --- --- --- + 22 23 40 39 + 0 0 0 0 + --- --- --- --- + 23 24 41 40 + 0 0 0 0 + --- --- --- --- + 24 25 42 41 + 0 0 0 0 + --- --- --- --- + 25 26 43 42 + 0 0 0 0 + --- --- --- --- + 26 27 44 43 + 0 0 0 0 + --- --- --- --- + 27 28 45 44 + 0 0 0 0 + --- --- --- --- + 28 29 46 45 + 0 0 0 0 + --- --- --- --- + 29 30 47 46 + 0 0 0 0 + --- --- --- --- + 30 31 48 47 + 0 0 0 0 + --- --- --- --- + 31 32 49 48 + 0 0 0 0 + --- --- --- --- + 32 33 50 49 + 0 0 0 0 + --- --- --- --- + 33 34 51 50 + 0 0 0 0 + --- Right --- --- + 35 36 53 52 + 0 0 0 0 + --- --- --- Left + 36 37 54 53 + 0 0 0 0 + --- --- --- --- + 37 38 55 54 + 0 0 0 0 + --- --- --- --- + 38 39 56 55 + 0 0 0 0 + --- --- --- --- + 39 40 57 56 + 0 0 0 0 + --- --- --- --- + 40 41 58 57 + 0 0 0 0 + --- --- --- --- + 41 42 59 58 + 0 0 0 0 + --- --- --- --- + 42 43 60 59 + 0 0 0 0 + --- --- --- --- + 43 44 61 60 + 0 0 0 0 + --- --- --- --- + 44 45 62 61 + 0 0 0 0 + --- --- --- --- + 45 46 63 62 + 0 0 0 0 + --- --- --- --- + 46 47 64 63 + 0 0 0 0 + --- --- --- --- + 47 48 65 64 + 0 0 0 0 + --- --- --- --- + 48 49 66 65 + 0 0 0 0 + --- --- --- --- + 49 50 67 66 + 0 0 0 0 + --- --- --- --- + 50 51 68 67 + 0 0 0 0 + --- Right --- --- + 52 53 70 69 + 0 0 0 0 + --- --- --- Left + 53 54 71 70 + 0 0 0 0 + --- --- --- --- + 54 55 72 71 + 0 0 0 0 + --- --- --- --- + 55 56 73 72 + 0 0 0 0 + --- --- --- --- + 56 57 74 73 + 0 0 0 0 + --- --- --- --- + 57 58 75 74 + 0 0 0 0 + --- --- --- --- + 58 59 76 75 + 0 0 0 0 + --- --- --- --- + 59 60 77 76 + 0 0 0 0 + --- --- --- --- + 60 61 78 77 + 0 0 0 0 + --- --- --- --- + 61 62 79 78 + 0 0 0 0 + --- --- --- --- + 62 63 80 79 + 0 0 0 0 + --- --- --- --- + 63 64 81 80 + 0 0 0 0 + --- --- --- --- + 64 65 82 81 + 0 0 0 0 + --- --- --- --- + 65 66 83 82 + 0 0 0 0 + --- --- --- --- + 66 67 84 83 + 0 0 0 0 + --- --- --- --- + 67 68 85 84 + 0 0 0 0 + --- Right --- --- + 69 70 87 86 + 0 0 0 0 + --- --- --- Left + 70 71 88 87 + 0 0 0 0 + --- --- --- --- + 71 72 89 88 + 0 0 0 0 + --- --- --- --- + 72 73 90 89 + 0 0 0 0 + --- --- --- --- + 73 74 91 90 + 0 0 0 0 + --- --- --- --- + 74 75 92 91 + 0 0 0 0 + --- --- --- --- + 75 76 93 92 + 0 0 0 0 + --- --- --- --- + 78 79 95 94 + 0 0 0 0 + --- --- --- --- + 79 80 96 95 + 0 0 0 0 + --- --- --- --- + 80 81 97 96 + 0 0 0 0 + --- --- --- --- + 81 82 98 97 + 0 0 0 0 + --- --- --- --- + 82 83 99 98 + 0 0 0 0 + --- --- --- --- + 83 84 100 99 + 0 0 0 0 + --- --- --- --- + 84 85 101 100 + 0 0 0 0 + --- Right --- --- + 86 87 103 102 + 0 0 0 0 + --- --- --- Left + 87 88 104 103 + 0 0 0 0 + --- --- --- --- + 88 89 105 104 + 0 0 0 0 + --- --- --- --- + 89 90 106 105 + 0 0 0 0 + --- --- --- --- + 90 91 107 106 + 0 0 0 0 + --- --- --- --- + 91 92 108 107 + 0 0 0 0 + --- --- --- --- + 92 93 109 108 + 0 0 0 0 + --- --- --- --- + 94 95 111 110 + 0 0 0 0 + --- --- --- --- + 95 96 112 111 + 0 0 0 0 + --- --- --- --- + 96 97 113 112 + 0 0 0 0 + --- --- --- --- + 97 98 114 113 + 0 0 0 0 + --- --- --- --- + 98 99 115 114 + 0 0 0 0 + --- --- --- --- + 99 100 116 115 + 0 0 0 0 + --- --- --- --- + 100 101 117 116 + 0 0 0 0 + --- Right --- --- + 102 103 119 118 + 0 0 0 0 + --- --- --- Left + 103 104 120 119 + 0 0 0 0 + --- --- --- --- + 104 105 121 120 + 0 0 0 0 + --- --- --- --- + 105 106 122 121 + 0 0 0 0 + --- --- --- --- + 106 107 123 122 + 0 0 0 0 + --- --- --- --- + 107 108 124 123 + 0 0 0 0 + --- --- --- --- + 111 112 126 125 + 0 0 0 0 + --- --- --- --- + 112 113 127 126 + 0 0 0 0 + --- --- --- --- + 113 114 128 127 + 0 0 0 0 + --- --- --- --- + 114 115 129 128 + 0 0 0 0 + --- --- --- --- + 115 116 130 129 + 0 0 0 0 + --- --- --- --- + 116 117 131 130 + 0 0 0 0 + --- Right --- --- + 118 119 133 132 + 0 0 0 0 + --- --- --- Left + 119 120 134 133 + 0 0 0 0 + --- --- --- --- + 120 121 135 134 + 0 0 0 0 + --- --- --- --- + 121 122 136 135 + 0 0 0 0 + --- --- --- --- + 122 123 137 136 + 0 0 0 0 + --- --- --- --- + 123 124 138 137 + 0 0 0 0 + --- --- --- --- + 125 126 140 139 + 0 0 0 0 + --- --- --- --- + 126 127 141 140 + 0 0 0 0 + --- --- --- --- + 127 128 142 141 + 0 0 0 0 + --- --- --- --- + 128 129 143 142 + 0 0 0 0 + --- --- --- --- + 129 130 144 143 + 0 0 0 0 + --- --- --- --- + 130 131 145 144 + 0 0 0 0 + --- Right --- --- + 132 133 147 146 + 0 0 0 0 + --- --- --- Left + 133 134 148 147 + 0 0 0 0 + --- --- --- --- + 134 135 149 148 + 0 0 0 0 + --- --- --- --- + 135 136 150 149 + 0 0 0 0 + --- --- --- --- + 136 137 151 150 + 0 0 0 0 + --- --- --- --- + 140 141 153 152 + 0 0 0 0 + --- --- --- --- + 141 142 154 153 + 0 0 0 0 + --- --- --- --- + 142 143 155 154 + 0 0 0 0 + --- --- --- --- + 143 144 156 155 + 0 0 0 0 + --- --- --- --- + 144 145 157 156 + 0 0 0 0 + --- Right --- --- + 146 147 159 158 + 0 0 0 0 + --- --- --- Left + 147 148 160 159 + 0 0 0 0 + --- --- --- --- + 148 149 161 160 + 0 0 0 0 + --- --- --- --- + 149 150 162 161 + 0 0 0 0 + --- --- --- --- + 150 151 163 162 + 0 0 0 0 + --- --- --- --- + 152 153 167 166 + 0 0 0 0 + --- --- --- --- + 153 154 168 167 + 0 0 0 0 + --- --- --- --- + 154 155 169 168 + 0 0 0 0 + --- --- --- --- + 155 156 170 169 + 0 0 0 0 + --- --- --- --- + 156 157 171 170 + 0 0 0 0 + --- Right --- --- + 158 159 173 172 + 0 0 0 0 + --- --- --- Left + 159 160 174 173 + 0 0 0 0 + --- --- --- --- + 160 161 175 174 + 0 0 0 0 + --- --- --- --- + 161 162 176 175 + 0 0 0 0 + --- --- --- --- + 162 163 177 176 + 0 0 0 0 + --- --- --- --- + 163 164 178 177 + 0 0 0 0 + --- --- --- --- + 165 166 182 181 + 0 0 0 0 + --- --- --- --- + 166 167 183 182 + 0 0 0 0 + --- --- --- --- + 167 168 184 183 + 0 0 0 0 + --- --- --- --- + 168 169 185 184 + 0 0 0 0 + --- --- --- --- + 169 170 186 185 + 0 0 0 0 + --- --- --- --- + 170 171 187 186 + 0 0 0 0 + --- Right --- --- + 172 173 189 188 + 0 0 0 0 + --- --- --- Left + 173 174 190 189 + 0 0 0 0 + --- --- --- --- + 174 175 191 190 + 0 0 0 0 + --- --- --- --- + 175 176 192 191 + 0 0 0 0 + --- --- --- --- + 176 177 193 192 + 0 0 0 0 + --- --- --- --- + 177 178 194 193 + 0 0 0 0 + --- --- --- --- + 178 179 195 194 + 0 0 0 0 + --- --- --- --- + 180 181 198 197 + 0 0 0 0 + --- --- --- --- + 181 182 199 198 + 0 0 0 0 + --- --- --- --- + 182 183 200 199 + 0 0 0 0 + --- --- --- --- + 183 184 201 200 + 0 0 0 0 + --- --- --- --- + 184 185 202 201 + 0 0 0 0 + --- --- --- --- + 185 186 203 202 + 0 0 0 0 + --- --- --- --- + 186 187 204 203 + 0 0 0 0 + --- Right --- --- + 188 189 206 205 + 0 0 0 0 + --- --- --- Left + 189 190 207 206 + 0 0 0 0 + --- --- --- --- + 190 191 208 207 + 0 0 0 0 + --- --- --- --- + 191 192 209 208 + 0 0 0 0 + --- --- --- --- + 192 193 210 209 + 0 0 0 0 + --- --- --- --- + 193 194 211 210 + 0 0 0 0 + --- --- --- --- + 194 195 212 211 + 0 0 0 0 + --- --- --- --- + 195 196 213 212 + 0 0 0 0 + --- --- --- --- + 196 197 214 213 + 0 0 0 0 + --- --- --- --- + 197 198 215 214 + 0 0 0 0 + --- --- --- --- + 198 199 216 215 + 0 0 0 0 + --- --- --- --- + 199 200 217 216 + 0 0 0 0 + --- --- --- --- + 200 201 218 217 + 0 0 0 0 + --- --- --- --- + 201 202 219 218 + 0 0 0 0 + --- --- --- --- + 202 203 220 219 + 0 0 0 0 + --- --- --- --- + 203 204 221 220 + 0 0 0 0 + --- Right --- --- + 205 206 223 222 + 0 0 0 0 + --- --- --- Left + 206 207 224 223 + 0 0 0 0 + --- --- --- --- + 207 208 225 224 + 0 0 0 0 + --- --- --- --- + 208 209 226 225 + 0 0 0 0 + --- --- --- --- + 209 210 227 226 + 0 0 0 0 + --- --- --- --- + 210 211 228 227 + 0 0 0 0 + --- --- --- --- + 211 212 229 228 + 0 0 0 0 + --- --- --- --- + 212 213 230 229 + 0 0 0 0 + --- --- --- --- + 213 214 231 230 + 0 0 0 0 + --- --- --- --- + 214 215 232 231 + 0 0 0 0 + --- --- --- --- + 215 216 233 232 + 0 0 0 0 + --- --- --- --- + 216 217 234 233 + 0 0 0 0 + --- --- --- --- + 217 218 235 234 + 0 0 0 0 + --- --- --- --- + 218 219 236 235 + 0 0 0 0 + --- --- --- --- + 219 220 237 236 + 0 0 0 0 + --- --- --- --- + 220 221 238 237 + 0 0 0 0 + --- Right --- --- + 222 223 240 239 + 0 0 0 0 + --- --- --- Left + 223 224 241 240 + 0 0 0 0 + --- --- --- --- + 224 225 242 241 + 0 0 0 0 + --- --- --- --- + 225 226 243 242 + 0 0 0 0 + --- --- --- --- + 226 227 244 243 + 0 0 0 0 + --- --- --- --- + 227 228 245 244 + 0 0 0 0 + --- --- --- --- + 228 229 246 245 + 0 0 0 0 + --- --- --- --- + 229 230 247 246 + 0 0 0 0 + --- --- --- --- + 230 231 248 247 + 0 0 0 0 + --- --- --- --- + 231 232 249 248 + 0 0 0 0 + --- --- --- --- + 232 233 250 249 + 0 0 0 0 + --- --- --- --- + 233 234 251 250 + 0 0 0 0 + --- --- --- --- + 234 235 252 251 + 0 0 0 0 + --- --- --- --- + 235 236 253 252 + 0 0 0 0 + --- --- --- --- + 236 237 254 253 + 0 0 0 0 + --- --- --- --- + 237 238 255 254 + 0 0 0 0 + --- Right --- --- + 239 240 257 256 + 0 0 0 0 + --- --- Top Left + 240 241 258 257 + 0 0 0 0 + --- --- Top --- + 241 242 259 258 + 0 0 0 0 + --- --- Top --- + 242 243 260 259 + 0 0 0 0 + --- --- Top --- + 243 244 261 260 + 0 0 0 0 + --- --- Top --- + 244 245 262 261 + 0 0 0 0 + --- --- Top --- + 245 246 263 262 + 0 0 0 0 + --- --- Top --- + 246 247 264 263 + 0 0 0 0 + --- --- Top --- + 247 248 265 264 + 0 0 0 0 + --- --- Top --- + 248 249 266 265 + 0 0 0 0 + --- --- Top --- + 249 250 267 266 + 0 0 0 0 + --- --- Top --- + 250 251 268 267 + 0 0 0 0 + --- --- Top --- + 251 252 269 268 + 0 0 0 0 + --- --- Top --- + 252 253 270 269 + 0 0 0 0 + --- --- Top --- + 253 254 271 270 + 0 0 0 0 + --- --- Top --- + 254 255 272 271 + 0 0 0 0 + --- Right Top --- + 93 76 77 273 + 0 0 0 0 + --- --- --- --- + 273 77 78 94 + 0 0 0 0 + --- --- --- --- + 94 110 274 273 + 0 0 1 0 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 8.1918573019674312E-002 -2.8361628539606514 0.0000000000000000 + 0.27968750301402334 -2.4406249939719533 0.0000000000000000 + 0.47745643300837237 -2.0450871339832553 0.0000000000000000 + 0.55937500602804668 -1.8812499879439066 0.0000000000000000 + --- --- RightSlant --- + 110 111 275 274 + 0 0 1 0 + 0.55937500602804668 -1.8812499879439066 0.0000000000000000 + 0.60056311315811417 -1.7988737736837717 0.0000000000000000 + 0.69999999999999973 -1.6000000000000005 0.0000000000000000 + 0.79943688684188530 -1.4011262263162294 0.0000000000000000 + 0.84062499397195278 -1.3187500120560944 0.0000000000000000 + --- --- RightSlant --- + 111 125 276 275 + 0 0 1 0 + 0.84062499397195278 -1.3187500120560944 0.0000000000000000 + 0.89325425707682937 -1.2134914858463413 0.0000000000000000 + 1.0203125378423255 -0.95937492431534910 0.0000000000000000 + 1.1473708186078211 -0.70525836278435783 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + --- --- RightSlant --- + 125 139 277 276 + 0 0 1 0 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.2526293208844796 -0.49474135823104071 0.0000000000000000 + 1.3796875438703724 -0.24062491225925520 0.0000000000000000 + 1.5067457668562652 1.3491533712530313E-002 0.0000000000000000 + 1.5593750060280467 0.11875001205609337 0.0000000000000000 + --- --- RightSlant --- + 139 140 278 277 + 0 0 1 0 + 1.5593750060280467 0.11875001205609337 0.0000000000000000 + 1.6005631131581151 0.20112622631623012 0.0000000000000000 + 1.6999999999999993 0.39999999999999858 0.0000000000000000 + 1.7994368868418849 0.59887377368376971 0.0000000000000000 + 1.8406249939719528 0.68124998794390557 0.0000000000000000 + --- --- RightSlant --- + 140 152 279 278 + 0 0 1 0 + 1.8406249939719528 0.68124998794390557 0.0000000000000000 + 1.8639649232289370 0.72792984645787406 0.0000000000000000 + 1.9203124969859759 0.84062499397195189 0.0000000000000000 + 1.9766600707430158 0.95332014148603150 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + --- --- RightSlant --- + 152 166 280 279 + 0 0 1 0 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9983479703871072 1.0812735458173770 0.0000000000000000 + 1.9807707726899886 1.2766715490561058 0.0000000000000000 + 1.9441339362737691 1.4694073261344140 0.0000000000000000 + 1.9234528539428932 1.5480229180052043 0.0000000000000000 + --- --- IceCream --- + 166 165 281 280 + 0 0 1 0 + 1.9234528539428932 1.5480229180052043 0.0000000000000000 + 1.9048209196670516 1.6096369936271651 0.0000000000000000 + 1.8517494276368289 1.7556613376683212 0.0000000000000000 + 1.7875027702478623 1.8971253236623173 0.0000000000000000 + 1.7577069153495042 1.9541836299856179 0.0000000000000000 + --- --- IceCream --- + 165 181 282 281 + 0 0 1 0 + 1.7577069153495042 1.9541836299856179 0.0000000000000000 + 1.7159031169606289 2.0274611881744238 0.0000000000000000 + 1.6025531944504807 2.1965881743342441 0.0000000000000000 + 1.4725959561431350 2.3533148746507173 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + --- --- IceCream --- + 181 180 283 282 + 0 0 1 0 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 1.3533148446578711 2.4725959837065434 0.0000000000000000 + 1.1965881552143354 2.6025532087268597 0.0000000000000000 + 1.0274611821782322 2.7159031205510731 0.0000000000000000 + 0.95418362998561790 2.7577069153495044 0.0000000000000000 + --- --- IceCream --- + 180 197 284 283 + 0 0 1 0 + 0.95418362998561790 2.7577069153495044 0.0000000000000000 + 0.89712532762418773 2.7875027682594489 0.0000000000000000 + 0.75566135168116888 2.8517494219184703 0.0000000000000000 + 0.60963701823418193 2.9048209117915880 0.0000000000000000 + 0.54802294711610733 2.9234528456487245 0.0000000000000000 + --- --- IceCream --- + 197 196 285 284 + 0 0 1 0 + 0.54802294711610733 2.9234528456487245 0.0000000000000000 + 0.46940735118449745 2.9441339302254752 0.0000000000000000 + 0.27667156381993480 2.9807707706277959 0.0000000000000000 + 8.1273549858423472E-002 2.9983479702227562 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + --- --- IceCream --- + 196 195 286 285 + 0 0 1 0 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -8.1273514348751255E-002 2.9983479716669477 0.0000000000000000 + -0.27667144147234074 2.9807707877171499 0.0000000000000000 + -0.46940714556157248 2.9441339798727189 0.0000000000000000 + -0.54802270862630975 2.9234529135983243 0.0000000000000000 + --- --- IceCream --- + 195 179 287 286 + 0 0 1 0 + -0.54802270862630975 2.9234529135983243 0.0000000000000000 + -0.60963681664226710 2.9048209763109716 0.0000000000000000 + -0.75566123688154063 2.8517494687658642 0.0000000000000000 + -0.89712529516674266 2.7875027845494351 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + --- --- IceCream --- + 179 178 288 287 + 0 0 1 0 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.0274611529224809 2.7159031380690477 0.0000000000000000 + -1.1965880619272244 2.6025532783821101 0.0000000000000000 + -1.3533146983210931 2.4725961181899434 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + --- --- IceCream --- + 178 164 289 288 + 0 0 1 0 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.4725958216597181 2.3533150209874787 0.0000000000000000 + -1.6025531247952236 2.1965882676213502 0.0000000000000000 + -1.7159030994426530 2.0274612174301749 0.0000000000000000 + -1.7577069153495026 1.9541836299856208 0.0000000000000000 + --- --- IceCream --- + 164 163 290 289 + 0 0 1 0 + -1.7577069153495026 1.9541836299856208 0.0000000000000000 + -1.7875027845494327 1.8971252951667479 0.0000000000000000 + -1.8517494687658640 1.7556612368815410 0.0000000000000000 + -1.9048209763109714 1.6096368166422679 0.0000000000000000 + -1.9234529135983243 1.5480227086263101 0.0000000000000000 + --- --- IceCream --- + 163 151 291 290 + 0 0 1 0 + -1.9234529135983243 1.5480227086263101 0.0000000000000000 + -1.9441339798883621 1.4694071454967825 0.0000000000000000 + -1.9807707877486287 1.2766714412469717 0.0000000000000000 + -1.9983479716827337 1.0812735139606025 0.0000000000000000 + -2.0000000000000000 1.0000000000000002 0.0000000000000000 + --- --- IceCream --- + 151 137 292 291 + 0 0 1 0 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.9766600707430160 0.95332014148603195 0.0000000000000000 + -1.9203124969859764 0.84062499397195278 0.0000000000000000 + -1.8639649232289368 0.72792984645787362 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + --- --- LeftSlant --- + 137 138 293 292 + 0 0 1 0 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.7994368868418851 0.59887377368377015 0.0000000000000000 + -1.7000000000000000 0.39999999999999991 0.0000000000000000 + -1.6005631131581148 0.20112622631622967 0.0000000000000000 + -1.5593750060280471 0.11875001205609426 0.0000000000000000 + --- --- LeftSlant --- + 138 124 294 293 + 0 0 1 0 + -1.5593750060280471 0.11875001205609426 0.0000000000000000 + -1.5067457553473789 1.3491510694757736E-002 0.0000000000000000 + -1.3796875045765755 -0.24062499084684896 0.0000000000000000 + -1.2526292538057724 -0.49474149238845522 0.0000000000000000 + -1.2000000031251039 -0.59999999374979218 0.0000000000000000 + --- --- LeftSlant --- + 124 108 295 294 + 0 0 1 0 + -1.2000000031251039 -0.59999999374979218 0.0000000000000000 + -1.1473707515291136 -0.70525849694177278 0.0000000000000000 + -1.0203124985485283 -0.95937500290294331 0.0000000000000000 + -0.89325424556794286 -1.2134915088641143 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + --- --- LeftSlant --- + 108 109 296 295 + 0 0 1 0 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.79943688684188507 -1.4011262263162299 0.0000000000000000 + -0.69999999999999996 -1.6000000000000001 0.0000000000000000 + -0.60056311315811484 -1.7988737736837703 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + --- --- LeftSlant --- + 109 93 273 296 + 0 0 1 0 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + -0.47745643300837282 -2.0450871339832544 0.0000000000000000 + -0.27968750301402356 -2.4406249939719529 0.0000000000000000 + -8.1918573019674756E-002 -2.8361628539606505 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + --- --- LeftSlant --- diff --git a/previews/PR1697/tutorials/out/ice_cream_straight_sides.tec b/previews/PR1697/tutorials/out/ice_cream_straight_sides.tec new file mode 100644 index 00000000000..d897fe73036 --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_straight_sides.tec @@ -0,0 +1,550 @@ + VARIABLES = "X", "Y", "Z" + ZONE F=FEPOINT, ET=QUADRILATERAL, N= 296 E= 252 + -8.0000000000000000 -8.0000000000000000 0.0000000000000000 + -7.0000000000000000 -8.0000000000000000 0.0000000000000000 + -6.0000000000000000 -8.0000000000000000 0.0000000000000000 + -5.0000000000000000 -8.0000000000000000 0.0000000000000000 + -4.0000000000000000 -8.0000000000000000 0.0000000000000000 + -3.0000000000000000 -8.0000000000000000 0.0000000000000000 + -2.0000000000000000 -8.0000000000000000 0.0000000000000000 + -1.0000000000000000 -8.0000000000000000 0.0000000000000000 + 0.0000000000000000 -8.0000000000000000 0.0000000000000000 + 1.0000000000000000 -8.0000000000000000 0.0000000000000000 + 2.0000000000000000 -8.0000000000000000 0.0000000000000000 + 3.0000000000000000 -8.0000000000000000 0.0000000000000000 + 4.0000000000000000 -8.0000000000000000 0.0000000000000000 + 5.0000000000000000 -8.0000000000000000 0.0000000000000000 + 6.0000000000000000 -8.0000000000000000 0.0000000000000000 + 7.0000000000000000 -8.0000000000000000 0.0000000000000000 + 8.0000000000000000 -8.0000000000000000 0.0000000000000000 + -8.0000000000000000 -7.0000000000000000 0.0000000000000000 + -6.9999650574820480 -6.9999679261182877 0.0000000000000000 + -5.9998665632941011 -6.9998724565097961 0.0000000000000000 + -4.9996213184978222 -6.9996097515900049 0.0000000000000000 + -3.9991854607018733 -6.9990475318617795 0.0000000000000000 + -2.9986952242321481 -6.9981269410719644 0.0000000000000000 + -1.9985140781988169 -6.9969986109118514 0.0000000000000000 + -0.99897849037601483 -6.9960383675970457 0.0000000000000000 + 4.7989409883115671E-012 -6.9956585147354131 0.0000000000000000 + 0.99897849038591502 -6.9960383675859896 0.0000000000000000 + 1.9985140782087694 -6.9969986108947824 0.0000000000000000 + 2.9986952242406435 -6.9981269410555944 0.0000000000000000 + 3.9991854607075754 -6.9990475318504446 0.0000000000000000 + 4.9996213185007372 -6.9996097515841544 0.0000000000000000 + 5.9998665632952193 -6.9998724565075419 0.0000000000000000 + 6.9999650574823553 -6.9999679261176624 0.0000000000000000 + 8.0000000000000000 -7.0000000000000000 0.0000000000000000 + -8.0000000000000000 -6.0000000000000000 0.0000000000000000 + -6.9998976699211699 -5.9999122764402735 0.0000000000000000 + -5.9996135291753685 -5.9996633062377125 0.0000000000000000 + -4.9989226436212064 -5.9990208119514659 0.0000000000000000 + -3.9977653337150905 -5.9977581248894900 0.0000000000000000 + -2.9966204896079378 -5.9958717654755365 0.0000000000000000 + -1.9964039837778744 -5.9937267870813304 0.0000000000000000 + -0.99766406647423933 -5.9919797466297764 0.0000000000000000 + 2.4090097191669961E-011 -5.9913000293311889 0.0000000000000000 + 0.99766406652596806 -5.9919797465642901 0.0000000000000000 + 1.9964039838329390 -5.9937267869811102 0.0000000000000000 + 2.9966204896556343 -5.9958717653815992 0.0000000000000000 + 3.9977653337461323 -5.9977581248272331 0.0000000000000000 + 4.9989226436360692 -5.9990208119214286 0.0000000000000000 + 5.9996135291805706 -5.9996633062271050 0.0000000000000000 + 6.9998976699224684 -5.9999122764375885 0.0000000000000000 + 8.0000000000000000 -6.0000000000000000 0.0000000000000000 + -8.0000000000000000 -5.0000000000000000 0.0000000000000000 + -6.9997501274902012 -4.9998034408089786 0.0000000000000000 + -5.9990675728612679 -4.9992697388441112 0.0000000000000000 + -4.9973858232938344 -4.9979740837677751 0.0000000000000000 + -3.9945964688979139 -4.9957899032377453 0.0000000000000000 + -2.9923152259971646 -4.9934053345787692 0.0000000000000000 + -1.9929564366212700 -4.9916256720553269 0.0000000000000000 + -0.99625966749685468 -4.9904887766265009 0.0000000000000000 + 8.7516607876472420E-011 -4.9900352567664603 0.0000000000000000 + 0.99625966770123564 -4.9904887763239962 0.0000000000000000 + 1.9929564368609574 -4.9916256715941776 0.0000000000000000 + 2.9923152262075878 -4.9934053341572957 0.0000000000000000 + 3.9945964690280817 -4.9957899029737884 0.0000000000000000 + 4.9973858233507853 -4.9979740836508393 0.0000000000000000 + 5.9990675728791238 -4.9992697388066452 0.0000000000000000 + 6.9997501274942060 -4.9998034408002647 0.0000000000000000 + 8.0000000000000000 -5.0000000000000000 0.0000000000000000 + -8.0000000000000000 -4.0000000000000000 0.0000000000000000 + -6.9994442810297537 -3.9996092645441159 0.0000000000000000 + -5.9979747892447062 -3.9985815423292643 0.0000000000000000 + -4.9942895414925133 -3.9961147104828689 0.0000000000000000 + -3.9872884982575028 -3.9920749153444808 0.0000000000000000 + -2.9807287305762533 -3.9900738967481790 0.0000000000000000 + -1.9852784719276839 -3.9938575615448597 0.0000000000000000 + -0.99708909504304877 -3.9973734973237129 0.0000000000000000 + 2.1033866962410606E-010 -3.9974440103039064 0.0000000000000000 + 0.99708909566634052 -3.9973734962049221 0.0000000000000000 + 1.9852784727951609 -3.9938575598154191 0.0000000000000000 + 2.9807287313302866 -3.9900738952156258 0.0000000000000000 + 3.9872884986834030 -3.9920749144641170 0.0000000000000000 + 4.9942895416564230 -3.9961147101336323 0.0000000000000000 + 5.9979747892902688 -3.9985815422265709 0.0000000000000000 + 6.9994442810389081 -3.9996092645214816 0.0000000000000000 + 8.0000000000000000 -4.0000000000000000 0.0000000000000000 + -8.0000000000000000 -3.0000000000000000 0.0000000000000000 + -6.9988707545318789 -2.9993214807930388 0.0000000000000000 + -5.9959723250282675 -2.9975703581842250 0.0000000000000000 + -4.9889296386581075 -2.9933466877064818 0.0000000000000000 + -3.9746774455653884 -2.9854293504387881 0.0000000000000000 + -2.9486314200342503 -2.9764998162463585 0.0000000000000000 + -1.9503942149316469 -3.0021256138813035 0.0000000000000000 + -1.0261614729009205 -3.0312104940798901 0.0000000000000000 + 1.0261614745493584 -3.0312104908158548 0.0000000000000000 + 1.9503942176787044 -3.0021256083069598 0.0000000000000000 + 2.9486314222736021 -2.9764998116137829 0.0000000000000000 + 3.9746774466049950 -2.9854293481972203 0.0000000000000000 + 4.9889296390019764 -2.9933466869030068 0.0000000000000000 + 5.9959723251123087 -2.9975703579581028 0.0000000000000000 + 6.9988707545467523 -2.9993214807434820 0.0000000000000000 + 8.0000000000000000 -3.0000000000000000 0.0000000000000000 + -8.0000000000000000 -2.0000000000000000 0.0000000000000000 + -6.9979591237819632 -1.9990110686940572 0.0000000000000000 + -5.9927227618739725 -1.9964483151530883 0.0000000000000000 + -4.9801080557894242 -1.9901770532049168 0.0000000000000000 + -3.9576959349815479 -1.9783015452963999 0.0000000000000000 + -2.9197320667969913 -1.9542226531228222 0.0000000000000000 + -1.7464656898511224 -1.8918471048105712 0.0000000000000000 + -1.0538136609635054 -2.3225159630485046 0.0000000000000000 + 1.0538136634211011 -2.3225159580901482 0.0000000000000000 + 1.7464656992760117 -1.8918470856151424 0.0000000000000000 + 2.9197320715976618 -1.9542226428284530 0.0000000000000000 + 3.9576959367463562 -1.9783015410469320 0.0000000000000000 + 4.9801080562838553 -1.9901770517309758 0.0000000000000000 + 5.9927227619766033 -1.9964483147281369 0.0000000000000000 + 6.9979591237966705 -1.9990110685977320 0.0000000000000000 + 8.0000000000000000 -2.0000000000000000 0.0000000000000000 + -8.0000000000000000 -1.0000000000000000 0.0000000000000000 + -6.9968317675017770 -0.99886259715705294 0.0000000000000000 + -5.9885538594769985 -0.99581599636441842 0.0000000000000000 + -4.9678071326527107 -0.98792038864408005 0.0000000000000000 + -3.9258196694477046 -0.97144892599683563 0.0000000000000000 + -2.9029530084938924 -0.95956909177122207 0.0000000000000000 + -1.9915356039925562 -0.87186063981735284 0.0000000000000000 + 1.9915356222472387 -0.87186060209166283 0.0000000000000000 + 2.9029530147562950 -0.95956907678113346 0.0000000000000000 + 3.9258196712523956 -0.97144891979974901 0.0000000000000000 + 4.9678071330492370 -0.98792038628267198 0.0000000000000000 + 5.9885538595330425 -0.99581599564497181 0.0000000000000000 + 6.9968317675030942 -0.99886259698874036 0.0000000000000000 + 8.0000000000000000 -1.0000000000000000 0.0000000000000000 + -8.0000000000000000 0.0000000000000000 0.0000000000000000 + -6.9958722740070352 9.2605842887460131E-004 0.0000000000000000 + -5.9849442010567895 3.5673767964436867E-003 0.0000000000000000 + -4.9568386769387480 1.1004836478173498E-002 0.0000000000000000 + -3.8951308919991683 2.9902496021364251E-002 0.0000000000000000 + -2.7032673839116930 9.0361097440859073E-002 0.0000000000000000 + -2.0571891363329842 -0.24562578581377828 0.0000000000000000 + 2.0571891499716477 -0.24562575669779302 0.0000000000000000 + 2.7032673869204902 9.0361111129516711E-002 0.0000000000000000 + 3.8951308924034209 2.9902504788020891E-002 0.0000000000000000 + 4.9568386769148196 1.1004839991627878E-002 0.0000000000000000 + 5.9849442010018254 3.5673778782903827E-003 0.0000000000000000 + 6.9958722739839931 9.2605868315656019E-004 0.0000000000000000 + 8.0000000000000000 0.0000000000000000 0.0000000000000000 + -8.0000000000000000 1.0000000000000000 0.0000000000000000 + -6.9955326960520150 1.0003662482577591 0.0000000000000000 + -5.9837177157599681 1.0016260315303323 0.0000000000000000 + -4.9534382883740049 1.0055660842008067 0.0000000000000000 + -3.8899281210667138 1.0153264300994280 0.0000000000000000 + -2.8576269259239067 1.0332611206083833 0.0000000000000000 + 2.8576269206180700 1.0332611487718453 0.0000000000000000 + 3.8899281199071547 1.0153264422760757 0.0000000000000000 + 4.9534382879928192 1.0055660886453257 0.0000000000000000 + 5.9837177156175274 1.0016260328696145 0.0000000000000000 + 6.9955326960100548 1.0003662485715008 0.0000000000000000 + 8.0000000000000000 1.0000000000000000 0.0000000000000000 + -8.0000000000000000 2.0000000000000000 0.0000000000000000 + -6.9960066511840280 1.9997507013087121 0.0000000000000000 + -5.9856229332322686 1.9994091100965983 0.0000000000000000 + -4.9595830937353638 1.9990558628265500 0.0000000000000000 + -3.9045581869999268 1.9973598907135701 0.0000000000000000 + -2.7368541689106971 1.9740722869324492 0.0000000000000000 + -2.1263404894339657 2.2948900365574501 0.0000000000000000 + 2.1263405099846904 2.2948900432082628 0.0000000000000000 + 2.7368541668551467 1.9740723203179147 0.0000000000000000 + 3.9045581868167778 1.9973599020749815 0.0000000000000000 + 4.9595830935518537 1.9990558669341754 0.0000000000000000 + 5.9856229331196342 1.9994091113584684 0.0000000000000000 + 6.9960066511449766 1.9997507016103995 0.0000000000000000 + 8.0000000000000000 2.0000000000000000 0.0000000000000000 + -8.0000000000000000 3.0000000000000000 0.0000000000000000 + -6.9970741145254109 2.9994054140824691 0.0000000000000000 + -5.9897519210034096 2.9981360157242580 0.0000000000000000 + -4.9724862257635190 2.9954390224920608 0.0000000000000000 + -3.9404681650821662 2.9905143469756337 0.0000000000000000 + -2.9327419944795010 2.9950483993160772 0.0000000000000000 + -1.9277593203701284 2.9288827058393201 0.0000000000000000 + -1.2934382299147573 3.1270574946750189 0.0000000000000000 + 1.2934382981899317 3.1270574584627195 0.0000000000000000 + 1.9277593629377268 2.9288826795836580 0.0000000000000000 + 2.9327420063368876 2.9950484011603677 0.0000000000000000 + 3.9404681675772051 2.9905143520853521 0.0000000000000000 + 4.9724862261650982 2.9954390249429101 0.0000000000000000 + 5.9897519210122363 2.9981360165754762 0.0000000000000000 + 6.9970741145083171 2.9994054143006470 0.0000000000000000 + 8.0000000000000000 3.0000000000000000 0.0000000000000000 + -8.0000000000000000 4.0000000000000000 0.0000000000000000 + -6.9982592393987968 3.9994059470511574 0.0000000000000000 + -5.9941718412117382 3.9980597406816538 0.0000000000000000 + -4.9856339697631320 3.9950007774720344 0.0000000000000000 + -3.9751323492146069 3.9888639093805867 0.0000000000000000 + -2.9708305521947196 3.9715346676422256 0.0000000000000000 + -1.9930387640582898 3.9338224795098449 0.0000000000000000 + -0.96763685658155807 3.7397274668414906 0.0000000000000000 + 3.3429034151622827E-008 3.8724227990342959 0.0000000000000000 + 0.96763691762346205 3.7397274489896106 0.0000000000000000 + 1.9930387926022926 3.9338224677871469 0.0000000000000000 + 2.9708305639402397 3.9715346636992050 0.0000000000000000 + 3.9751323526676017 3.9888639097163923 0.0000000000000000 + 4.9856339705045638 3.9950007782744765 0.0000000000000000 + 5.9941718413174092 3.9980597410666165 0.0000000000000000 + 6.9982592394038319 3.9994059471655752 0.0000000000000000 + 8.0000000000000000 4.0000000000000000 0.0000000000000000 + -8.0000000000000000 5.0000000000000000 0.0000000000000000 + -6.9991633741456480 4.9995936517804571 0.0000000000000000 + -5.9973416427807713 4.9986235063327511 0.0000000000000000 + -4.9939474927689487 4.9961691895174090 0.0000000000000000 + -3.9898774621657993 4.9900396721612950 0.0000000000000000 + -2.9882983865581152 4.9754672684598420 0.0000000000000000 + -1.9884726792358567 4.9414046357118258 0.0000000000000000 + -0.99054764142862672 4.9076265219014017 0.0000000000000000 + 1.5044633229432108E-008 4.8977197323029209 0.0000000000000000 + 0.99054766715027320 4.9076265171995406 0.0000000000000000 + 1.9884726950216143 4.9414046308491191 0.0000000000000000 + 2.9882983935721197 4.9754672660048422 0.0000000000000000 + 3.9898774645940622 4.9900396715407211 0.0000000000000000 + 4.9939474933945487 4.9961691895653884 0.0000000000000000 + 5.9973416428964281 4.9986235064339004 0.0000000000000000 + 6.9991633741594397 4.9995936518214812 0.0000000000000000 + 8.0000000000000000 5.0000000000000000 0.0000000000000000 + -8.0000000000000000 6.0000000000000000 0.0000000000000000 + -6.9996739984196390 5.9997893596429419 0.0000000000000000 + -5.9989986118848257 5.9992529007592390 0.0000000000000000 + -4.9977434317195026 5.9977709675596005 0.0000000000000000 + -3.9960992156787842 5.9940404411235333 0.0000000000000000 + -2.9946713951079547 5.9858782583382260 0.0000000000000000 + -1.9942453640855442 5.9731438824671530 0.0000000000000000 + -0.99595680588594671 5.9611672784475598 0.0000000000000000 + 5.4895336706131739E-009 5.9564095944048683 0.0000000000000000 + 0.99595681544617021 5.9611672771802988 0.0000000000000000 + 1.9942453703764043 5.9731438809327670 0.0000000000000000 + 2.9946713982270148 5.9858782573487614 0.0000000000000000 + 3.9960992168542182 5.9940404407363950 0.0000000000000000 + 4.9977434320589262 5.9977709674807409 0.0000000000000000 + 5.9989986119578065 5.9992529007644064 0.0000000000000000 + 6.9996739984307244 5.9997893596515759 0.0000000000000000 + 8.0000000000000000 6.0000000000000000 0.0000000000000000 + -8.0000000000000000 7.0000000000000000 0.0000000000000000 + -6.9999004989624796 6.9999196928494865 0.0000000000000000 + -5.9996945336645995 6.9997036786799463 0.0000000000000000 + -4.9992926804199769 6.9990875647356665 0.0000000000000000 + -3.9986895202660464 6.9975750738144677 0.0000000000000000 + -2.9980654465831940 6.9946658241746293 0.0000000000000000 + -1.9978514474788915 6.9906409012147579 0.0000000000000000 + -0.99851861799346908 6.9869919193812402 0.0000000000000000 + 1.5699479313662187E-009 6.9855176655399553 0.0000000000000000 + 0.99851862076110953 6.9869919190879317 0.0000000000000000 + 1.9978514493699755 6.9906409008314814 0.0000000000000000 + 2.9980654475797910 6.9946658238941168 0.0000000000000000 + 3.9986895206695174 6.9975750736809648 0.0000000000000000 + 4.9992926805452846 6.9990875646946797 0.0000000000000000 + 5.9996945336942300 6.9997036786734528 0.0000000000000000 + 6.9999004989676070 6.9999196928498879 0.0000000000000000 + 8.0000000000000000 7.0000000000000000 0.0000000000000000 + -8.0000000000000000 8.0000000000000000 0.0000000000000000 + -7.0000000000000000 8.0000000000000000 0.0000000000000000 + -6.0000000000000000 8.0000000000000000 0.0000000000000000 + -5.0000000000000000 8.0000000000000000 0.0000000000000000 + -4.0000000000000000 8.0000000000000000 0.0000000000000000 + -3.0000000000000000 8.0000000000000000 0.0000000000000000 + -2.0000000000000000 8.0000000000000000 0.0000000000000000 + -1.0000000000000000 8.0000000000000000 0.0000000000000000 + 0.0000000000000000 8.0000000000000000 0.0000000000000000 + 1.0000000000000000 8.0000000000000000 0.0000000000000000 + 2.0000000000000000 8.0000000000000000 0.0000000000000000 + 3.0000000000000000 8.0000000000000000 0.0000000000000000 + 4.0000000000000000 8.0000000000000000 0.0000000000000000 + 5.0000000000000000 8.0000000000000000 0.0000000000000000 + 6.0000000000000000 8.0000000000000000 0.0000000000000000 + 7.0000000000000000 8.0000000000000000 0.0000000000000000 + 8.0000000000000000 8.0000000000000000 0.0000000000000000 + 0.0000000000000000 -3.0000000000000000 0.0000000000000000 + 0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 0.84062499397195267 -1.3187500120560947 0.0000000000000000 + 1.2000000817126981 -0.59999983657460376 0.0000000000000000 + 1.5593750060280469 0.11875001205609381 0.0000000000000000 + 1.8406249939719526 0.68124998794390512 0.0000000000000000 + 2.0000000000000000 1.0000000000000000 0.0000000000000000 + 1.9234528539428934 1.5480229180052039 0.0000000000000000 + 1.7577069153495042 1.9541836299856183 0.0000000000000000 + 1.4142135455002482 2.4142135792459416 0.0000000000000000 + 0.95418362998561834 2.7577069153495040 0.0000000000000000 + 0.54802294711610822 2.9234528456487245 0.0000000000000000 + -4.5511671064437944E-010 3.0000000000000000 0.0000000000000000 + -0.54802270862631064 2.9234529135983243 0.0000000000000000 + -0.95418362998561812 2.7577069153495044 0.0000000000000000 + -1.4142133808531077 2.4142137438930593 0.0000000000000000 + -1.7577069153495022 1.9541836299856215 0.0000000000000000 + -1.9234529135983240 1.5480227086263110 0.0000000000000000 + -2.0000000000000000 1.0000000000000000 0.0000000000000000 + -1.8406249939719528 0.68124998794390557 0.0000000000000000 + -1.5593750060280471 0.11875001205609437 0.0000000000000000 + -1.2000000031251037 -0.59999999374979263 0.0000000000000000 + -0.84062499397195278 -1.3187500120560944 0.0000000000000000 + -0.55937500602804713 -1.8812499879439057 0.0000000000000000 + 1 2 19 18 + 2 3 20 19 + 3 4 21 20 + 4 5 22 21 + 5 6 23 22 + 6 7 24 23 + 7 8 25 24 + 8 9 26 25 + 9 10 27 26 + 10 11 28 27 + 11 12 29 28 + 12 13 30 29 + 13 14 31 30 + 14 15 32 31 + 15 16 33 32 + 16 17 34 33 + 18 19 36 35 + 19 20 37 36 + 20 21 38 37 + 21 22 39 38 + 22 23 40 39 + 23 24 41 40 + 24 25 42 41 + 25 26 43 42 + 26 27 44 43 + 27 28 45 44 + 28 29 46 45 + 29 30 47 46 + 30 31 48 47 + 31 32 49 48 + 32 33 50 49 + 33 34 51 50 + 35 36 53 52 + 36 37 54 53 + 37 38 55 54 + 38 39 56 55 + 39 40 57 56 + 40 41 58 57 + 41 42 59 58 + 42 43 60 59 + 43 44 61 60 + 44 45 62 61 + 45 46 63 62 + 46 47 64 63 + 47 48 65 64 + 48 49 66 65 + 49 50 67 66 + 50 51 68 67 + 52 53 70 69 + 53 54 71 70 + 54 55 72 71 + 55 56 73 72 + 56 57 74 73 + 57 58 75 74 + 58 59 76 75 + 59 60 77 76 + 60 61 78 77 + 61 62 79 78 + 62 63 80 79 + 63 64 81 80 + 64 65 82 81 + 65 66 83 82 + 66 67 84 83 + 67 68 85 84 + 69 70 87 86 + 70 71 88 87 + 71 72 89 88 + 72 73 90 89 + 73 74 91 90 + 74 75 92 91 + 75 76 93 92 + 78 79 95 94 + 79 80 96 95 + 80 81 97 96 + 81 82 98 97 + 82 83 99 98 + 83 84 100 99 + 84 85 101 100 + 86 87 103 102 + 87 88 104 103 + 88 89 105 104 + 89 90 106 105 + 90 91 107 106 + 91 92 108 107 + 92 93 109 108 + 94 95 111 110 + 95 96 112 111 + 96 97 113 112 + 97 98 114 113 + 98 99 115 114 + 99 100 116 115 + 100 101 117 116 + 102 103 119 118 + 103 104 120 119 + 104 105 121 120 + 105 106 122 121 + 106 107 123 122 + 107 108 124 123 + 111 112 126 125 + 112 113 127 126 + 113 114 128 127 + 114 115 129 128 + 115 116 130 129 + 116 117 131 130 + 118 119 133 132 + 119 120 134 133 + 120 121 135 134 + 121 122 136 135 + 122 123 137 136 + 123 124 138 137 + 125 126 140 139 + 126 127 141 140 + 127 128 142 141 + 128 129 143 142 + 129 130 144 143 + 130 131 145 144 + 132 133 147 146 + 133 134 148 147 + 134 135 149 148 + 135 136 150 149 + 136 137 151 150 + 140 141 153 152 + 141 142 154 153 + 142 143 155 154 + 143 144 156 155 + 144 145 157 156 + 146 147 159 158 + 147 148 160 159 + 148 149 161 160 + 149 150 162 161 + 150 151 163 162 + 152 153 167 166 + 153 154 168 167 + 154 155 169 168 + 155 156 170 169 + 156 157 171 170 + 158 159 173 172 + 159 160 174 173 + 160 161 175 174 + 161 162 176 175 + 162 163 177 176 + 163 164 178 177 + 165 166 182 181 + 166 167 183 182 + 167 168 184 183 + 168 169 185 184 + 169 170 186 185 + 170 171 187 186 + 172 173 189 188 + 173 174 190 189 + 174 175 191 190 + 175 176 192 191 + 176 177 193 192 + 177 178 194 193 + 178 179 195 194 + 180 181 198 197 + 181 182 199 198 + 182 183 200 199 + 183 184 201 200 + 184 185 202 201 + 185 186 203 202 + 186 187 204 203 + 188 189 206 205 + 189 190 207 206 + 190 191 208 207 + 191 192 209 208 + 192 193 210 209 + 193 194 211 210 + 194 195 212 211 + 195 196 213 212 + 196 197 214 213 + 197 198 215 214 + 198 199 216 215 + 199 200 217 216 + 200 201 218 217 + 201 202 219 218 + 202 203 220 219 + 203 204 221 220 + 205 206 223 222 + 206 207 224 223 + 207 208 225 224 + 208 209 226 225 + 209 210 227 226 + 210 211 228 227 + 211 212 229 228 + 212 213 230 229 + 213 214 231 230 + 214 215 232 231 + 215 216 233 232 + 216 217 234 233 + 217 218 235 234 + 218 219 236 235 + 219 220 237 236 + 220 221 238 237 + 222 223 240 239 + 223 224 241 240 + 224 225 242 241 + 225 226 243 242 + 226 227 244 243 + 227 228 245 244 + 228 229 246 245 + 229 230 247 246 + 230 231 248 247 + 231 232 249 248 + 232 233 250 249 + 233 234 251 250 + 234 235 252 251 + 235 236 253 252 + 236 237 254 253 + 237 238 255 254 + 239 240 257 256 + 240 241 258 257 + 241 242 259 258 + 242 243 260 259 + 243 244 261 260 + 244 245 262 261 + 245 246 263 262 + 246 247 264 263 + 247 248 265 264 + 248 249 266 265 + 249 250 267 266 + 250 251 268 267 + 251 252 269 268 + 252 253 270 269 + 253 254 271 270 + 254 255 272 271 + 93 76 77 273 + 273 77 78 94 + 94 110 274 273 + 110 111 275 274 + 111 125 276 275 + 125 139 277 276 + 139 140 278 277 + 140 152 279 278 + 152 166 280 279 + 166 165 281 280 + 165 181 282 281 + 181 180 283 282 + 180 197 284 283 + 197 196 285 284 + 196 195 286 285 + 195 179 287 286 + 179 178 288 287 + 178 164 289 288 + 164 163 290 289 + 163 151 291 290 + 151 137 292 291 + 137 138 293 292 + 138 124 294 293 + 124 108 295 294 + 108 109 296 295 + 109 93 273 296 diff --git a/previews/PR1697/tutorials/out/ice_cream_straight_sides.txt b/previews/PR1697/tutorials/out/ice_cream_straight_sides.txt new file mode 100644 index 00000000000..e41813ce3c2 --- /dev/null +++ b/previews/PR1697/tutorials/out/ice_cream_straight_sides.txt @@ -0,0 +1,258 @@ + + ------------------------ + 2D Mesh Quality Measures + ------------------------ + +Signed Area Aspect Ratio Condition Edge Ratio Jacobian Minimum Angle Maximum Angle Area Sign + 1.0000E+00 1.0000E+00 1.0000E+00 1.0000E+00 1.0000E+00 8.9996E+01 9.0002E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9987E+01 9.0008E+01 1.0000E+00 + 1.0004E+00 1.0002E+00 1.0000E+00 1.0004E+00 1.0001E+00 8.9963E+01 9.0023E+01 1.0000E+00 + 1.0009E+00 1.0005E+00 1.0000E+00 1.0010E+00 1.0004E+00 8.9921E+01 9.0054E+01 1.0000E+00 + 1.0017E+00 1.0010E+00 1.0000E+00 1.0019E+00 1.0010E+00 8.9873E+01 9.0099E+01 1.0000E+00 + 1.0025E+00 1.0017E+00 1.0000E+00 1.0030E+00 1.0019E+00 8.9850E+01 9.0139E+01 1.0000E+00 + 1.0032E+00 1.0023E+00 1.0000E+00 1.0044E+00 1.0025E+00 8.9887E+01 9.0140E+01 1.0000E+00 + 1.0036E+00 1.0025E+00 1.0000E+00 1.0054E+00 1.0029E+00 8.9942E+01 9.0080E+01 1.0000E+00 + 1.0036E+00 1.0025E+00 1.0000E+00 1.0054E+00 1.0029E+00 8.9942E+01 9.0080E+01 1.0000E+00 + 1.0032E+00 1.0023E+00 1.0000E+00 1.0044E+00 1.0025E+00 8.9887E+01 9.0140E+01 1.0000E+00 + 1.0025E+00 1.0017E+00 1.0000E+00 1.0030E+00 1.0019E+00 8.9850E+01 9.0139E+01 1.0000E+00 + 1.0017E+00 1.0010E+00 1.0000E+00 1.0019E+00 1.0010E+00 8.9873E+01 9.0099E+01 1.0000E+00 + 1.0009E+00 1.0005E+00 1.0000E+00 1.0010E+00 1.0004E+00 8.9921E+01 9.0054E+01 1.0000E+00 + 1.0004E+00 1.0002E+00 1.0000E+00 1.0004E+00 1.0001E+00 8.9963E+01 9.0023E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9987E+01 9.0008E+01 1.0000E+00 + 1.0000E+00 1.0000E+00 1.0000E+00 1.0000E+00 1.0000E+00 8.9996E+01 9.0002E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9991E+01 9.0006E+01 1.0000E+00 + 1.0003E+00 1.0001E+00 1.0000E+00 1.0002E+00 1.0002E+00 8.9971E+01 9.0020E+01 1.0000E+00 + 1.0009E+00 1.0003E+00 1.0000E+00 1.0005E+00 1.0005E+00 8.9923E+01 9.0055E+01 1.0000E+00 + 1.0017E+00 1.0004E+00 1.0000E+00 1.0009E+00 1.0010E+00 8.9846E+01 9.0113E+01 1.0000E+00 + 1.0026E+00 1.0010E+00 1.0000E+00 1.0018E+00 1.0018E+00 8.9773E+01 9.0189E+01 1.0000E+00 + 1.0030E+00 1.0018E+00 1.0000E+00 1.0031E+00 1.0024E+00 8.9757E+01 9.0241E+01 1.0000E+00 + 1.0028E+00 1.0027E+00 1.0000E+00 1.0053E+00 1.0020E+00 8.9824E+01 9.0221E+01 1.0000E+00 + 1.0025E+00 1.0031E+00 1.0000E+00 1.0067E+00 1.0017E+00 8.9903E+01 9.0114E+01 1.0000E+00 + 1.0025E+00 1.0031E+00 1.0000E+00 1.0067E+00 1.0017E+00 8.9903E+01 9.0114E+01 1.0000E+00 + 1.0028E+00 1.0027E+00 1.0000E+00 1.0053E+00 1.0020E+00 8.9824E+01 9.0221E+01 1.0000E+00 + 1.0030E+00 1.0018E+00 1.0000E+00 1.0031E+00 1.0024E+00 8.9757E+01 9.0241E+01 1.0000E+00 + 1.0026E+00 1.0010E+00 1.0000E+00 1.0018E+00 1.0018E+00 8.9773E+01 9.0189E+01 1.0000E+00 + 1.0017E+00 1.0004E+00 1.0000E+00 1.0009E+00 1.0010E+00 8.9846E+01 9.0113E+01 1.0000E+00 + 1.0009E+00 1.0003E+00 1.0000E+00 1.0005E+00 1.0005E+00 8.9923E+01 9.0055E+01 1.0000E+00 + 1.0003E+00 1.0001E+00 1.0000E+00 1.0002E+00 1.0002E+00 8.9971E+01 9.0020E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9991E+01 9.0006E+01 1.0000E+00 + 1.0002E+00 1.0001E+00 1.0000E+00 1.0002E+00 1.0001E+00 8.9980E+01 9.0013E+01 1.0000E+00 + 1.0007E+00 1.0003E+00 1.0000E+00 1.0006E+00 1.0004E+00 8.9938E+01 9.0046E+01 1.0000E+00 + 1.0019E+00 1.0007E+00 1.0000E+00 1.0013E+00 1.0011E+00 8.9838E+01 9.0125E+01 1.0000E+00 + 1.0035E+00 1.0011E+00 1.0000E+00 1.0017E+00 1.0022E+00 8.9694E+01 9.0253E+01 1.0000E+00 + 1.0039E+00 1.0005E+00 1.0000E+00 1.0013E+00 1.0031E+00 8.9618E+01 9.0354E+01 1.0000E+00 + 1.0021E+00 1.0015E+00 1.0000E+00 1.0031E+00 1.0015E+00 8.9631E+01 9.0348E+01 1.0000E+00 + 9.9951E-01 1.0024E+00 1.0000E+00 1.0054E+00 9.9818E-01 8.9703E+01 9.0262E+01 1.0000E+00 + 9.9834E-01 1.0023E+00 1.0000E+00 1.0053E+00 9.9752E-01 8.9881E+01 9.0106E+01 1.0000E+00 + 9.9834E-01 1.0023E+00 1.0000E+00 1.0053E+00 9.9752E-01 8.9881E+01 9.0106E+01 1.0000E+00 + 9.9951E-01 1.0024E+00 1.0000E+00 1.0054E+00 9.9818E-01 8.9703E+01 9.0262E+01 1.0000E+00 + 1.0021E+00 1.0015E+00 1.0000E+00 1.0031E+00 1.0015E+00 8.9631E+01 9.0348E+01 1.0000E+00 + 1.0039E+00 1.0005E+00 1.0000E+00 1.0013E+00 1.0031E+00 8.9618E+01 9.0354E+01 1.0000E+00 + 1.0035E+00 1.0011E+00 1.0000E+00 1.0017E+00 1.0022E+00 8.9694E+01 9.0253E+01 1.0000E+00 + 1.0019E+00 1.0007E+00 1.0000E+00 1.0013E+00 1.0011E+00 8.9838E+01 9.0125E+01 1.0000E+00 + 1.0007E+00 1.0003E+00 1.0000E+00 1.0006E+00 1.0004E+00 8.9938E+01 9.0046E+01 1.0000E+00 + 1.0002E+00 1.0001E+00 1.0000E+00 1.0002E+00 1.0001E+00 8.9980E+01 9.0013E+01 1.0000E+00 + 1.0005E+00 1.0003E+00 1.0000E+00 1.0006E+00 1.0002E+00 8.9960E+01 9.0029E+01 1.0000E+00 + 1.0015E+00 1.0007E+00 1.0000E+00 1.0013E+00 1.0009E+00 8.9879E+01 9.0093E+01 1.0000E+00 + 1.0040E+00 1.0017E+00 1.0000E+00 1.0030E+00 1.0024E+00 8.9682E+01 9.0251E+01 1.0000E+00 + 1.0077E+00 1.0032E+00 1.0001E+00 1.0051E+00 1.0046E+00 8.9353E+01 9.0542E+01 1.0000E+00 + 1.0079E+00 1.0026E+00 1.0001E+00 1.0043E+00 1.0056E+00 8.9224E+01 9.0798E+01 1.0000E+00 + 9.9796E-01 1.0044E+00 1.0001E+00 1.0080E+00 9.9326E-01 8.9236E+01 9.0543E+01 1.0000E+00 + 9.8792E-01 1.0039E+00 1.0001E+00 1.0097E+00 9.8138E-01 8.9494E+01 9.0252E+01 1.0000E+00 + 9.8955E-01 1.0023E+00 1.0000E+00 1.0045E+00 9.8888E-01 8.9948E+01 9.0026E+01 1.0000E+00 + 9.8955E-01 1.0023E+00 1.0000E+00 1.0045E+00 9.8888E-01 8.9948E+01 9.0026E+01 1.0000E+00 + 9.8792E-01 1.0039E+00 1.0001E+00 1.0097E+00 9.8138E-01 8.9494E+01 9.0252E+01 1.0000E+00 + 9.9796E-01 1.0044E+00 1.0001E+00 1.0080E+00 9.9326E-01 8.9236E+01 9.0543E+01 1.0000E+00 + 1.0079E+00 1.0026E+00 1.0001E+00 1.0043E+00 1.0056E+00 8.9224E+01 9.0798E+01 1.0000E+00 + 1.0077E+00 1.0032E+00 1.0001E+00 1.0051E+00 1.0046E+00 8.9353E+01 9.0542E+01 1.0000E+00 + 1.0040E+00 1.0017E+00 1.0000E+00 1.0030E+00 1.0024E+00 8.9682E+01 9.0251E+01 1.0000E+00 + 1.0015E+00 1.0007E+00 1.0000E+00 1.0013E+00 1.0009E+00 8.9879E+01 9.0093E+01 1.0000E+00 + 1.0005E+00 1.0003E+00 1.0000E+00 1.0006E+00 1.0002E+00 8.9960E+01 9.0029E+01 1.0000E+00 + 1.0010E+00 1.0006E+00 1.0000E+00 1.0011E+00 1.0006E+00 8.9928E+01 9.0055E+01 1.0000E+00 + 1.0028E+00 1.0015E+00 1.0000E+00 1.0026E+00 1.0018E+00 8.9785E+01 9.0173E+01 1.0000E+00 + 1.0073E+00 1.0034E+00 1.0001E+00 1.0060E+00 1.0047E+00 8.9453E+01 9.0447E+01 1.0000E+00 + 1.0153E+00 1.0067E+00 1.0002E+00 1.0115E+00 1.0098E+00 8.8835E+01 9.0948E+01 1.0000E+00 + 1.0265E+00 1.0130E+00 1.0009E+00 1.0194E+00 1.0132E+00 8.7688E+01 9.1928E+01 1.0000E+00 + 9.9998E-01 1.0142E+00 1.0006E+00 1.0219E+00 9.8735E-01 8.8404E+01 9.1797E+01 1.0000E+00 + 9.3613E-01 1.0261E+00 1.0029E+00 1.0732E+00 8.9211E-01 8.8073E+01 9.3526E+01 1.0000E+00 + 9.3613E-01 1.0261E+00 1.0029E+00 1.0732E+00 8.9211E-01 8.8073E+01 9.3526E+01 1.0000E+00 + 9.9998E-01 1.0142E+00 1.0006E+00 1.0219E+00 9.8735E-01 8.8404E+01 9.1797E+01 1.0000E+00 + 1.0265E+00 1.0130E+00 1.0009E+00 1.0194E+00 1.0132E+00 8.7688E+01 9.1928E+01 1.0000E+00 + 1.0153E+00 1.0067E+00 1.0002E+00 1.0115E+00 1.0098E+00 8.8835E+01 9.0948E+01 1.0000E+00 + 1.0073E+00 1.0034E+00 1.0001E+00 1.0060E+00 1.0047E+00 8.9453E+01 9.0447E+01 1.0000E+00 + 1.0028E+00 1.0015E+00 1.0000E+00 1.0026E+00 1.0018E+00 8.9785E+01 9.0173E+01 1.0000E+00 + 1.0010E+00 1.0006E+00 1.0000E+00 1.0011E+00 1.0006E+00 8.9928E+01 9.0055E+01 1.0000E+00 + 1.0017E+00 1.0012E+00 1.0000E+00 1.0020E+00 1.0011E+00 8.9891E+01 9.0091E+01 1.0000E+00 + 1.0048E+00 1.0029E+00 1.0000E+00 1.0049E+00 1.0032E+00 8.9668E+01 9.0286E+01 1.0000E+00 + 1.0120E+00 1.0067E+00 1.0002E+00 1.0115E+00 1.0082E+00 8.9141E+01 9.0744E+01 1.0000E+00 + 1.0234E+00 1.0109E+00 1.0005E+00 1.0192E+00 1.0174E+00 8.8369E+01 9.1413E+01 1.0000E+00 + 1.0468E+00 1.0152E+00 1.0014E+00 1.0307E+00 1.0332E+00 8.7052E+01 9.2295E+01 1.0000E+00 + 1.1556E+00 1.0994E+00 1.0290E+00 1.1766E+00 1.0212E+00 7.6549E+01 9.8937E+01 1.0000E+00 + 7.5553E-01 1.3366E+00 1.2195E+00 1.5916E+00 4.7897E-01 6.8536E+01 1.2411E+02 1.0000E+00 + 7.5553E-01 1.3366E+00 1.2195E+00 1.5916E+00 4.7897E-01 6.8536E+01 1.2411E+02 1.0000E+00 + 1.1556E+00 1.0994E+00 1.0290E+00 1.1766E+00 1.0212E+00 7.6549E+01 9.8937E+01 1.0000E+00 + 1.0468E+00 1.0152E+00 1.0014E+00 1.0307E+00 1.0332E+00 8.7052E+01 9.2295E+01 1.0000E+00 + 1.0234E+00 1.0109E+00 1.0005E+00 1.0192E+00 1.0174E+00 8.8369E+01 9.1413E+01 1.0000E+00 + 1.0120E+00 1.0067E+00 1.0002E+00 1.0115E+00 1.0082E+00 8.9141E+01 9.0744E+01 1.0000E+00 + 1.0048E+00 1.0029E+00 1.0000E+00 1.0049E+00 1.0032E+00 8.9668E+01 9.0286E+01 1.0000E+00 + 1.0017E+00 1.0012E+00 1.0000E+00 1.0020E+00 1.0011E+00 8.9891E+01 9.0091E+01 1.0000E+00 + 1.0027E+00 1.0018E+00 1.0000E+00 1.0032E+00 1.0020E+00 8.9870E+01 9.0121E+01 1.0000E+00 + 1.0071E+00 1.0047E+00 1.0001E+00 1.0081E+00 1.0054E+00 8.9588E+01 9.0385E+01 1.0000E+00 + 1.0181E+00 1.0118E+00 1.0004E+00 1.0201E+00 1.0132E+00 8.8854E+01 9.1058E+01 1.0000E+00 + 1.0366E+00 1.0240E+00 1.0017E+00 1.0397E+00 1.0246E+00 8.7281E+01 9.2479E+01 1.0000E+00 + 1.0308E+00 1.0232E+00 1.0020E+00 1.0437E+00 1.0172E+00 8.6858E+01 9.2479E+01 1.0000E+00 + 1.0585E+00 1.1472E+00 1.0235E+00 1.2832E+00 9.0507E-01 7.9533E+01 9.8013E+01 1.0000E+00 + 1.0585E+00 1.1472E+00 1.0235E+00 1.2832E+00 9.0507E-01 7.9533E+01 9.8013E+01 1.0000E+00 + 1.0308E+00 1.0232E+00 1.0020E+00 1.0437E+00 1.0172E+00 8.6858E+01 9.2479E+01 1.0000E+00 + 1.0366E+00 1.0240E+00 1.0017E+00 1.0397E+00 1.0246E+00 8.7281E+01 9.2479E+01 1.0000E+00 + 1.0181E+00 1.0118E+00 1.0004E+00 1.0201E+00 1.0132E+00 8.8854E+01 9.1058E+01 1.0000E+00 + 1.0071E+00 1.0047E+00 1.0001E+00 1.0081E+00 1.0054E+00 8.9588E+01 9.0385E+01 1.0000E+00 + 1.0027E+00 1.0018E+00 1.0000E+00 1.0032E+00 1.0020E+00 8.9870E+01 9.0121E+01 1.0000E+00 + 1.0035E+00 1.0024E+00 1.0000E+00 1.0043E+00 1.0030E+00 8.9892E+01 9.0120E+01 1.0000E+00 + 1.0092E+00 1.0063E+00 1.0001E+00 1.0115E+00 1.0076E+00 8.9643E+01 9.0380E+01 1.0000E+00 + 1.0235E+00 1.0164E+00 1.0006E+00 1.0292E+00 1.0196E+00 8.8956E+01 9.1072E+01 1.0000E+00 + 1.0516E+00 1.0362E+00 1.0029E+00 1.0630E+00 1.0407E+00 8.7225E+01 9.2661E+01 1.0000E+00 + 1.1316E+00 1.1303E+00 1.0354E+00 1.1912E+00 1.0239E+00 7.6328E+01 1.0143E+02 1.0000E+00 + 6.6097E-01 1.3511E+00 1.2114E+00 1.6973E+00 3.8254E-01 7.3292E+01 1.2346E+02 1.0000E+00 + 6.6097E-01 1.3511E+00 1.2114E+00 1.6973E+00 3.8254E-01 7.3292E+01 1.2346E+02 1.0000E+00 + 1.1316E+00 1.1303E+00 1.0354E+00 1.1912E+00 1.0239E+00 7.6328E+01 1.0143E+02 1.0000E+00 + 1.0516E+00 1.0362E+00 1.0029E+00 1.0630E+00 1.0407E+00 8.7225E+01 9.2661E+01 1.0000E+00 + 1.0235E+00 1.0164E+00 1.0006E+00 1.0292E+00 1.0196E+00 8.8956E+01 9.1072E+01 1.0000E+00 + 1.0092E+00 1.0063E+00 1.0001E+00 1.0115E+00 1.0076E+00 8.9643E+01 9.0380E+01 1.0000E+00 + 1.0035E+00 1.0024E+00 1.0000E+00 1.0043E+00 1.0030E+00 8.9892E+01 9.0120E+01 1.0000E+00 + 1.0040E+00 1.0025E+00 1.0000E+00 1.0050E+00 1.0036E+00 8.9947E+01 9.0072E+01 1.0000E+00 + 1.0101E+00 1.0068E+00 1.0001E+00 1.0138E+00 1.0090E+00 8.9831E+01 9.0220E+01 1.0000E+00 + 1.0254E+00 1.0176E+00 1.0006E+00 1.0359E+00 1.0225E+00 8.9515E+01 9.0610E+01 1.0000E+00 + 1.0519E+00 1.0377E+00 1.0031E+00 1.0793E+00 1.0461E+00 8.8784E+01 9.1322E+01 1.0000E+00 + 1.0752E+00 1.1563E+00 1.0312E+00 1.2490E+00 9.7613E-01 8.3607E+01 9.8302E+01 1.0000E+00 + 1.0752E+00 1.1563E+00 1.0312E+00 1.2490E+00 9.7613E-01 8.3607E+01 9.8302E+01 1.0000E+00 + 1.0519E+00 1.0377E+00 1.0031E+00 1.0793E+00 1.0461E+00 8.8784E+01 9.1322E+01 1.0000E+00 + 1.0254E+00 1.0176E+00 1.0006E+00 1.0359E+00 1.0225E+00 8.9515E+01 9.0610E+01 1.0000E+00 + 1.0101E+00 1.0068E+00 1.0001E+00 1.0138E+00 1.0090E+00 8.9831E+01 9.0220E+01 1.0000E+00 + 1.0040E+00 1.0025E+00 1.0000E+00 1.0050E+00 1.0036E+00 8.9947E+01 9.0072E+01 1.0000E+00 + 1.0039E+00 1.0025E+00 1.0000E+00 1.0051E+00 1.0034E+00 8.9979E+01 9.0041E+01 1.0000E+00 + 1.0097E+00 1.0070E+00 1.0001E+00 1.0141E+00 1.0081E+00 8.9953E+01 9.0129E+01 1.0000E+00 + 1.0237E+00 1.0184E+00 1.0007E+00 1.0370E+00 1.0194E+00 8.9865E+01 9.0374E+01 1.0000E+00 + 1.0463E+00 1.0404E+00 1.0032E+00 1.0829E+00 1.0360E+00 8.9554E+01 9.0946E+01 1.0000E+00 + 1.0577E+00 1.1404E+00 1.0277E+00 1.2313E+00 9.6903E-01 8.3827E+01 9.8310E+01 1.0000E+00 + 1.0577E+00 1.1404E+00 1.0277E+00 1.2313E+00 9.6903E-01 8.3827E+01 9.8310E+01 1.0000E+00 + 1.0463E+00 1.0404E+00 1.0032E+00 1.0829E+00 1.0360E+00 8.9554E+01 9.0946E+01 1.0000E+00 + 1.0237E+00 1.0184E+00 1.0007E+00 1.0370E+00 1.0194E+00 8.9865E+01 9.0374E+01 1.0000E+00 + 1.0097E+00 1.0070E+00 1.0001E+00 1.0141E+00 1.0081E+00 8.9953E+01 9.0129E+01 1.0000E+00 + 1.0039E+00 1.0025E+00 1.0000E+00 1.0051E+00 1.0034E+00 8.9979E+01 9.0041E+01 1.0000E+00 + 1.0033E+00 1.0023E+00 1.0000E+00 1.0043E+00 1.0026E+00 8.9925E+01 9.0095E+01 1.0000E+00 + 1.0080E+00 1.0064E+00 1.0001E+00 1.0117E+00 1.0060E+00 8.9744E+01 9.0309E+01 1.0000E+00 + 1.0191E+00 1.0165E+00 1.0005E+00 1.0297E+00 1.0136E+00 8.9238E+01 9.0894E+01 1.0000E+00 + 1.0380E+00 1.0361E+00 1.0025E+00 1.0616E+00 1.0248E+00 8.7837E+01 9.2344E+01 1.0000E+00 + 1.0943E+00 1.1231E+00 1.0293E+00 1.1752E+00 1.0010E+00 7.7997E+01 1.0060E+02 1.0000E+00 + 6.6823E-01 1.3227E+00 1.4180E+00 1.5648E+00 3.2335E-01 7.3140E+01 1.3511E+02 1.0000E+00 + 6.6823E-01 1.3227E+00 1.4180E+00 1.5648E+00 3.2335E-01 7.3140E+01 1.3511E+02 1.0000E+00 + 1.0943E+00 1.1231E+00 1.0293E+00 1.1752E+00 1.0010E+00 7.7997E+01 1.0060E+02 1.0000E+00 + 1.0380E+00 1.0361E+00 1.0025E+00 1.0616E+00 1.0248E+00 8.7837E+01 9.2344E+01 1.0000E+00 + 1.0191E+00 1.0165E+00 1.0005E+00 1.0297E+00 1.0136E+00 8.9238E+01 9.0894E+01 1.0000E+00 + 1.0080E+00 1.0064E+00 1.0001E+00 1.0117E+00 1.0060E+00 8.9744E+01 9.0309E+01 1.0000E+00 + 1.0033E+00 1.0023E+00 1.0000E+00 1.0043E+00 1.0026E+00 8.9925E+01 9.0095E+01 1.0000E+00 + 1.0023E+00 1.0018E+00 1.0000E+00 1.0029E+00 1.0017E+00 8.9898E+01 9.0102E+01 1.0000E+00 + 1.0057E+00 1.0045E+00 1.0000E+00 1.0074E+00 1.0040E+00 8.9675E+01 9.0330E+01 1.0000E+00 + 1.0126E+00 1.0110E+00 1.0003E+00 1.0176E+00 1.0081E+00 8.9094E+01 9.0927E+01 1.0000E+00 + 1.0201E+00 1.0221E+00 1.0013E+00 1.0331E+00 1.0086E+00 8.7738E+01 9.2337E+01 1.0000E+00 + 9.9312E-01 1.0118E+00 1.0020E+00 1.0312E+00 9.8003E-01 8.7023E+01 9.3222E+01 1.0000E+00 + 9.7950E-01 1.0205E+00 1.0086E+00 1.0306E+00 9.5336E-01 8.2517E+01 9.6001E+01 1.0000E+00 + 6.7093E-01 1.3257E+00 1.4243E+00 1.5704E+00 3.2406E-01 7.2716E+01 1.3535E+02 1.0000E+00 + 6.7093E-01 1.3257E+00 1.4243E+00 1.5704E+00 3.2406E-01 7.2716E+01 1.3535E+02 1.0000E+00 + 9.7950E-01 1.0205E+00 1.0086E+00 1.0306E+00 9.5336E-01 8.2517E+01 9.6001E+01 1.0000E+00 + 9.9312E-01 1.0118E+00 1.0020E+00 1.0312E+00 9.8003E-01 8.7023E+01 9.3222E+01 1.0000E+00 + 1.0201E+00 1.0221E+00 1.0013E+00 1.0331E+00 1.0086E+00 8.7738E+01 9.2337E+01 1.0000E+00 + 1.0126E+00 1.0110E+00 1.0003E+00 1.0176E+00 1.0081E+00 8.9094E+01 9.0927E+01 1.0000E+00 + 1.0057E+00 1.0045E+00 1.0000E+00 1.0074E+00 1.0040E+00 8.9675E+01 9.0330E+01 1.0000E+00 + 1.0023E+00 1.0018E+00 1.0000E+00 1.0029E+00 1.0017E+00 8.9898E+01 9.0102E+01 1.0000E+00 + 1.0014E+00 1.0010E+00 1.0000E+00 1.0017E+00 1.0008E+00 8.9914E+01 9.0075E+01 1.0000E+00 + 1.0033E+00 1.0024E+00 1.0000E+00 1.0039E+00 1.0020E+00 8.9742E+01 9.0237E+01 1.0000E+00 + 1.0068E+00 1.0051E+00 1.0001E+00 1.0080E+00 1.0040E+00 8.9350E+01 9.0616E+01 1.0000E+00 + 1.0084E+00 1.0064E+00 1.0003E+00 1.0093E+00 1.0052E+00 8.8808E+01 9.1194E+01 1.0000E+00 + 1.0052E+00 1.0021E+00 1.0006E+00 1.0032E+00 1.0025E+00 8.8015E+01 9.1832E+01 1.0000E+00 + 9.9427E-01 1.0110E+00 1.0019E+00 1.0297E+00 9.8098E-01 8.7052E+01 9.3206E+01 1.0000E+00 + 1.0994E+00 1.1204E+00 1.0282E+00 1.1699E+00 1.0056E+00 7.8158E+01 1.0046E+02 1.0000E+00 + 1.0744E+00 1.1309E+00 1.0230E+00 1.1960E+00 9.9212E-01 8.3315E+01 9.7808E+01 1.0000E+00 + 1.0744E+00 1.1309E+00 1.0230E+00 1.1960E+00 9.9212E-01 8.3315E+01 9.7808E+01 1.0000E+00 + 1.0994E+00 1.1204E+00 1.0282E+00 1.1699E+00 1.0056E+00 7.8158E+01 1.0046E+02 1.0000E+00 + 9.9427E-01 1.0110E+00 1.0019E+00 1.0297E+00 9.8098E-01 8.7052E+01 9.3206E+01 1.0000E+00 + 1.0052E+00 1.0021E+00 1.0006E+00 1.0032E+00 1.0025E+00 8.8015E+01 9.1832E+01 1.0000E+00 + 1.0084E+00 1.0064E+00 1.0003E+00 1.0093E+00 1.0052E+00 8.8808E+01 9.1194E+01 1.0000E+00 + 1.0068E+00 1.0051E+00 1.0001E+00 1.0080E+00 1.0040E+00 8.9350E+01 9.0616E+01 1.0000E+00 + 1.0033E+00 1.0024E+00 1.0000E+00 1.0039E+00 1.0020E+00 8.9742E+01 9.0237E+01 1.0000E+00 + 1.0014E+00 1.0010E+00 1.0000E+00 1.0017E+00 1.0008E+00 8.9914E+01 9.0075E+01 1.0000E+00 + 1.0007E+00 1.0005E+00 1.0000E+00 1.0008E+00 1.0003E+00 8.9947E+01 9.0041E+01 1.0000E+00 + 1.0017E+00 1.0010E+00 1.0000E+00 1.0016E+00 1.0009E+00 8.9850E+01 9.0126E+01 1.0000E+00 + 1.0034E+00 1.0017E+00 1.0000E+00 1.0028E+00 1.0019E+00 8.9643E+01 9.0302E+01 1.0000E+00 + 1.0056E+00 1.0013E+00 1.0001E+00 1.0025E+00 1.0032E+00 8.9295E+01 9.0568E+01 1.0000E+00 + 1.0086E+00 1.0062E+00 1.0003E+00 1.0090E+00 1.0054E+00 8.8805E+01 9.1189E+01 1.0000E+00 + 1.0211E+00 1.0214E+00 1.0013E+00 1.0313E+00 1.0100E+00 8.7728E+01 9.2313E+01 1.0000E+00 + 1.0405E+00 1.0333E+00 1.0022E+00 1.0553E+00 1.0294E+00 8.7767E+01 9.2259E+01 1.0000E+00 + 1.0490E+00 1.0342E+00 1.0023E+00 1.0687E+00 1.0435E+00 8.9427E+01 9.0867E+01 1.0000E+00 + 1.0490E+00 1.0342E+00 1.0023E+00 1.0687E+00 1.0435E+00 8.9427E+01 9.0867E+01 1.0000E+00 + 1.0405E+00 1.0333E+00 1.0022E+00 1.0553E+00 1.0294E+00 8.7767E+01 9.2259E+01 1.0000E+00 + 1.0211E+00 1.0214E+00 1.0013E+00 1.0313E+00 1.0100E+00 8.7728E+01 9.2313E+01 1.0000E+00 + 1.0086E+00 1.0062E+00 1.0003E+00 1.0090E+00 1.0054E+00 8.8805E+01 9.1189E+01 1.0000E+00 + 1.0056E+00 1.0013E+00 1.0001E+00 1.0025E+00 1.0032E+00 8.9295E+01 9.0568E+01 1.0000E+00 + 1.0034E+00 1.0017E+00 1.0000E+00 1.0028E+00 1.0019E+00 8.9643E+01 9.0302E+01 1.0000E+00 + 1.0017E+00 1.0010E+00 1.0000E+00 1.0016E+00 1.0009E+00 8.9850E+01 9.0126E+01 1.0000E+00 + 1.0007E+00 1.0005E+00 1.0000E+00 1.0008E+00 1.0003E+00 8.9947E+01 9.0041E+01 1.0000E+00 + 1.0003E+00 1.0002E+00 1.0000E+00 1.0003E+00 1.0001E+00 8.9975E+01 9.0018E+01 1.0000E+00 + 1.0007E+00 1.0003E+00 1.0000E+00 1.0005E+00 1.0003E+00 8.9929E+01 9.0052E+01 1.0000E+00 + 1.0017E+00 1.0005E+00 1.0000E+00 1.0009E+00 1.0009E+00 8.9827E+01 9.0125E+01 1.0000E+00 + 1.0035E+00 1.0018E+00 1.0000E+00 1.0029E+00 1.0019E+00 8.9639E+01 9.0302E+01 1.0000E+00 + 1.0072E+00 1.0052E+00 1.0001E+00 1.0082E+00 1.0042E+00 8.9340E+01 9.0615E+01 1.0000E+00 + 1.0134E+00 1.0108E+00 1.0003E+00 1.0173E+00 1.0090E+00 8.9068E+01 9.0922E+01 1.0000E+00 + 1.0204E+00 1.0156E+00 1.0005E+00 1.0275E+00 1.0157E+00 8.9170E+01 9.0890E+01 1.0000E+00 + 1.0246E+00 1.0168E+00 1.0005E+00 1.0333E+00 1.0217E+00 8.9726E+01 9.0417E+01 1.0000E+00 + 1.0246E+00 1.0168E+00 1.0005E+00 1.0333E+00 1.0217E+00 8.9726E+01 9.0417E+01 1.0000E+00 + 1.0204E+00 1.0156E+00 1.0005E+00 1.0275E+00 1.0157E+00 8.9170E+01 9.0890E+01 1.0000E+00 + 1.0134E+00 1.0108E+00 1.0003E+00 1.0173E+00 1.0090E+00 8.9068E+01 9.0922E+01 1.0000E+00 + 1.0072E+00 1.0052E+00 1.0001E+00 1.0082E+00 1.0042E+00 8.9340E+01 9.0615E+01 1.0000E+00 + 1.0035E+00 1.0018E+00 1.0000E+00 1.0029E+00 1.0019E+00 8.9639E+01 9.0302E+01 1.0000E+00 + 1.0017E+00 1.0005E+00 1.0000E+00 1.0009E+00 1.0009E+00 8.9827E+01 9.0125E+01 1.0000E+00 + 1.0007E+00 1.0003E+00 1.0000E+00 1.0005E+00 1.0003E+00 8.9929E+01 9.0052E+01 1.0000E+00 + 1.0003E+00 1.0002E+00 1.0000E+00 1.0003E+00 1.0001E+00 8.9975E+01 9.0018E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9990E+01 9.0006E+01 1.0000E+00 + 1.0003E+00 1.0002E+00 1.0000E+00 1.0003E+00 1.0001E+00 8.9970E+01 9.0018E+01 1.0000E+00 + 1.0008E+00 1.0005E+00 1.0000E+00 1.0009E+00 1.0003E+00 8.9924E+01 9.0053E+01 1.0000E+00 + 1.0020E+00 1.0014E+00 1.0000E+00 1.0024E+00 1.0009E+00 8.9838E+01 9.0127E+01 1.0000E+00 + 1.0042E+00 1.0032E+00 1.0000E+00 1.0053E+00 1.0024E+00 8.9723E+01 9.0241E+01 1.0000E+00 + 1.0075E+00 1.0056E+00 1.0001E+00 1.0094E+00 1.0053E+00 8.9647E+01 9.0341E+01 1.0000E+00 + 1.0108E+00 1.0076E+00 1.0001E+00 1.0137E+00 1.0087E+00 8.9707E+01 9.0331E+01 1.0000E+00 + 1.0130E+00 1.0080E+00 1.0001E+00 1.0160E+00 1.0115E+00 8.9915E+01 9.0168E+01 1.0000E+00 + 1.0130E+00 1.0080E+00 1.0001E+00 1.0160E+00 1.0115E+00 8.9915E+01 9.0168E+01 1.0000E+00 + 1.0108E+00 1.0076E+00 1.0001E+00 1.0137E+00 1.0087E+00 8.9707E+01 9.0331E+01 1.0000E+00 + 1.0075E+00 1.0056E+00 1.0001E+00 1.0094E+00 1.0053E+00 8.9647E+01 9.0341E+01 1.0000E+00 + 1.0042E+00 1.0032E+00 1.0000E+00 1.0053E+00 1.0024E+00 8.9723E+01 9.0241E+01 1.0000E+00 + 1.0020E+00 1.0014E+00 1.0000E+00 1.0024E+00 1.0009E+00 8.9838E+01 9.0127E+01 1.0000E+00 + 1.0008E+00 1.0005E+00 1.0000E+00 1.0009E+00 1.0003E+00 8.9924E+01 9.0053E+01 1.0000E+00 + 1.0003E+00 1.0002E+00 1.0000E+00 1.0003E+00 1.0001E+00 8.9970E+01 9.0018E+01 1.0000E+00 + 1.0001E+00 1.0001E+00 1.0000E+00 1.0001E+00 1.0000E+00 8.9990E+01 9.0006E+01 1.0000E+00 + 9.9344E-01 1.0303E+00 1.0018E+00 1.0621E+00 9.6335E-01 8.8258E+01 9.1728E+01 1.0000E+00 + 9.9344E-01 1.0303E+00 1.0018E+00 1.0621E+00 9.6335E-01 8.8258E+01 9.1728E+01 1.0000E+00 + 7.6404E-01 1.4936E+00 1.2992E+00 1.8874E+00 3.6261E-01 6.5177E+01 1.2951E+02 1.0000E+00 + 5.9465E-01 1.4327E+00 1.1525E+00 1.7044E+00 4.0223E-01 6.4192E+01 1.0638E+02 1.0000E+00 + 8.6551E-01 1.1646E+00 1.0567E+00 1.3339E+00 6.6662E-01 7.1190E+01 9.7610E+01 1.0000E+00 + 5.0114E-01 1.2054E+00 1.1575E+00 1.3566E+00 3.3567E-01 7.7029E+01 1.2022E+02 1.0000E+00 + 5.2705E-01 1.4977E+00 1.2088E+00 1.6949E+00 3.8250E-01 6.1886E+01 1.1632E+02 1.0000E+00 + 5.8633E-01 1.4337E+00 1.6529E+00 2.9340E+00 2.6807E-01 6.4887E+01 1.1879E+02 1.0000E+00 + 6.4463E-01 1.2060E+00 1.2013E+00 1.7142E+00 4.7255E-01 6.9670E+01 1.0969E+02 1.0000E+00 + 3.6363E-01 1.6089E+00 1.2913E+00 2.0932E+00 2.0620E-01 5.5366E+01 1.1055E+02 1.0000E+00 + 3.5720E-01 1.2556E+00 1.1503E+00 1.4484E+00 2.8661E-01 6.2329E+01 1.1535E+02 1.0000E+00 + 3.5734E-01 1.2550E+00 1.1494E+00 1.4497E+00 2.8644E-01 6.2412E+01 1.1522E+02 1.0000E+00 + 3.6464E-01 1.6058E+00 1.2900E+00 2.0922E+00 2.0625E-01 5.5209E+01 1.1037E+02 1.0000E+00 + 6.6182E-01 1.2250E+00 1.1978E+00 1.7651E+00 4.7811E-01 7.0603E+01 1.0925E+02 1.0000E+00 + 6.6182E-01 1.2250E+00 1.1978E+00 1.7651E+00 4.7811E-01 7.0603E+01 1.0925E+02 1.0000E+00 + 3.6464E-01 1.6058E+00 1.2900E+00 2.0922E+00 2.0625E-01 5.5209E+01 1.1037E+02 1.0000E+00 + 3.5734E-01 1.2550E+00 1.1494E+00 1.4497E+00 2.8644E-01 6.2412E+01 1.1522E+02 1.0000E+00 + 3.5720E-01 1.2556E+00 1.1503E+00 1.4484E+00 2.8661E-01 6.2329E+01 1.1535E+02 1.0000E+00 + 3.6363E-01 1.6089E+00 1.2913E+00 2.0932E+00 2.0620E-01 5.5366E+01 1.1055E+02 1.0000E+00 + 6.4463E-01 1.2060E+00 1.2013E+00 1.7142E+00 4.7255E-01 6.9670E+01 1.0969E+02 1.0000E+00 + 5.8633E-01 1.4337E+00 1.6529E+00 2.9340E+00 2.6807E-01 6.4887E+01 1.1879E+02 1.0000E+00 + 5.2705E-01 1.4977E+00 1.2088E+00 1.6949E+00 3.8250E-01 6.1886E+01 1.1632E+02 1.0000E+00 + 5.0114E-01 1.2054E+00 1.1575E+00 1.3566E+00 3.3567E-01 7.7029E+01 1.2022E+02 1.0000E+00 + 8.6551E-01 1.1646E+00 1.0567E+00 1.3339E+00 6.6662E-01 7.1190E+01 9.7610E+01 1.0000E+00 + 5.9465E-01 1.4327E+00 1.1525E+00 1.7044E+00 4.0223E-01 6.4192E+01 1.0638E+02 1.0000E+00 + 7.6404E-01 1.4936E+00 1.2992E+00 1.8874E+00 3.6261E-01 6.5177E+01 1.2951E+02 1.0000E+00 diff --git a/previews/PR1697/tutorials/out/mesh.h5 b/previews/PR1697/tutorials/out/mesh.h5 new file mode 100644 index 0000000000000000000000000000000000000000..ae8c51df1eb7204b89b5bda915697dfdfc2488bb GIT binary patch literal 1136 zcmeD5aB<`1lHy_j0S*oZ76t(@6Gr@pf&vzZ2#gPtPk=HQp>zk7Ucm%mFfy<+faD~g z;sQ|f6__Cc0Z@%0L9VVK5t#Wf8meuS8sQ<};p!Lw3W5k|IB-De6VP-9<$}{1hz(W@ z6QqC^gr-;Ybj`zH0XCJHfs26y2pMxzi!gn>Co2q+255}|p;B}JvlC8b5F zDZW5eMlL`}9tH!bel{Q*s6Q_yGq;#Q0O&7>*Bs#bQGAHd#|qI`oLQBMRofr1`7nZq z!2@a^ACi01GILV%5_2JLRs<@5xjDbIL_ae*H9om0H8D3H=>Eja^o)}D;>?uPVm**o f5$@oDxT7GoC^J7LGdZ)Ql0gJ+63}BX7eHtLJ=as7 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/restart_000050.h5 b/previews/PR1697/tutorials/out/restart_000050.h5 new file mode 100644 index 0000000000000000000000000000000000000000..d97dc7bc0830a1c30ce49816e294cb0eeb520aa1 GIT binary patch literal 11976 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 Tj9eX+>cGI>%ZepipdS7g?HLNY literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/restart_000100.h5 b/previews/PR1697/tutorials/out/restart_000100.h5 new file mode 100644 index 0000000000000000000000000000000000000000..8d913bf49ba44db47eb3db3d807160d63dc37480 GIT binary patch literal 11976 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 I82stK07&dlF8}}l literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/restart_000150.h5 b/previews/PR1697/tutorials/out/restart_000150.h5 new file mode 100644 index 0000000000000000000000000000000000000000..6b928beff87745da5fc9cd20dd8a04a7c86ea9cc GIT binary patch literal 11976 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 Rl%OZXQ%8@)_bS{h{9jmmxz_*y literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000.pvd b/previews/PR1697/tutorials/out/solution_000.pvd new file mode 100644 index 00000000000..5a8e7dcf8d2 --- /dev/null +++ b/previews/PR1697/tutorials/out/solution_000.pvd @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/out/solution_000000.h5 b/previews/PR1697/tutorials/out/solution_000000.h5 new file mode 100644 index 0000000000000000000000000000000000000000..8136e9b53713927d858462fd0b46a2461fc7722d GIT binary patch literal 205696 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

g-QR4}zy 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 z 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 F{10_ZhdclP literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000010.vtu b/previews/PR1697/tutorials/out/solution_000010.vtu new file mode 100644 index 0000000000000000000000000000000000000000..c093326c6effaabd4f24c1affeb4877db3565f0a GIT binary patch literal 18966 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
qk?{%@SC|;XC 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

S%w4;V=Ko$FoS z6ADKUDkXb0XJ5=1;#X?J%kNWpdo3NA|4A)Y7o`3#*snWZ065Uo^&j!JxcxJQC|!zo z9bYQI{=VO-O6^Iib=W!`?Ti%_c}8}$E^6c_;%^n#ERSdbt!!47(m3i!Uht;+_bdy6 z!$+L*oHOHBA0Iwp{%7asJm#O4p6Fal`KOyMsS*AWqH8$G z8~iRy5Z=CYobjO*ibq&^k0X@FQTk)+FY~CMqm!pelAQ3GhZ{?*x3v*AgnLeOuyo0O zajU06UcAg`B=xiD^6q;yE*6{90nS^zzd(d0(S+iVB;3@02!cm8e)(;Jj&%j#c0*mW%B2Y*ZsCbUzuT}66gD)(av z9lbOH3FkSl`a$ckF>8++od=KZQ0}37gG6Q3jkN#PX1Vr|o>I_BFVYKCN}omhS}HHt zna+o&GurRz0gnXL#!x-EVf2#_c;6w)p_9t9-xT;Z1o&?LnEj;Z=lZUd@+Z8#i<^4b z9mnZ9WG6-LhvbI?jY2nikzV-cU!O=%Yy;R5?6&yrymVngB z@y@^-^Gl!7du36kx3({b{S54RQMC>Bw*Ttu-xHCqfBw%bYEP9{*+)rW#*>*hZJ{?h zFZN3i_{H^04Iz0*zwOCKu!@{A#)w&46pkAM`;Y~YQOgWvu$vY*x&th9lHE(6@nHR^Pr){|J^Gx_(kI_Xw*Af4k=D$`;;cq3c^{|tm@4af? zIi-w(JE*rI+^;nNe&lholwKOj`xdcanDX~Z-nmQFW3EM3^9&1{hsGLI^KS3TTd$pj za%W^Ow3dSZc)BjM*yF0U`RisOKJ=yJ^%T^T^>mkpHQKXJK>gTX%wNd`4bi8VKUcvOsuFKA7K{K~3IMpl5u+*u{7r{AQ%k>LXZh4Ie|RiYZQ{ z{A${J=!r}e-%arkL9rhv#G#j&e$;0kc<;-f%{gJv6Z;i+^ab=n?N_?e`X2cAP+Gbx z{9?|{^S7bb-S3?0V(6XT)1CeidQZA-M$qpa*rX;tummn1_i81bU#2u%mnMHHZum`} z_R$CH)a~Ri`vq+OO!vt?f~zaVAtzYAOSb|>`x=T-9N7Crl?k0Urs?~9%YvRndWkgM zn>jr{@XHSA3oN60=)9vAlTuH7;Fe;`VnO6*=4}bRWj@gm0K{0z0UN0=OC<)^Z`{8y`=Z{Mry$UbMLH&$j^FRjyJgBwimSjHJPKX*TGWaYhEpuCaFvo>`bLgSm+ z$;Dx$U4vM?#qXQgdbm;5xSI6Lj^}M7Ju$5_EWaU*dmsPP@(Q*tZ8uwk7{RXu?yx2F zFxwSK{_;b(L<7miU81stU6p71(>~wOTQP+ErTOM}DP#xCi^i^}eblOY*@5aQGd;eY z{IB7gUd=rK87psxQ&| z4<-h2j`3@zlV0P?3nmdjt?S+wXne}wDi5N3**`WqRPNhb+l5H)Z@|nN8{h!heKifh z`(;y`8ek7q2YTHLJAadXjiw;zmRFupXq33*NW=G4u+rduyJCEER0A z_YJT^OJ-Fm{F>MKO?$-foaWL4OX&N^#+O4Ql96A%N8p+Q(zj1<(cK3>VxT&2!CR!e z4etI+{@g=9!EgoSr>`1H}iu+OoRAK&$W|GiKozcDd2bwE+4aZ|#WmA>F5}$@_$II%vi`%%(N&AEZltb_w}f6;w5ruOlt1))!sc9m z#6#4!E|uJj^|G_K;VaJnMuXBfJ(9=x3gj0iKrcdDcfMUhB~P!v;tOT)joffuV?D%~ zrk^=CJVz7$s;c7W$l0*Z+0`{G;4iOzo+5k^{<1X7#U9h;LrK-yeFbliuF#k8!#zHqS{K^L;$MAS?#=Ge$mvYdaBN;B7jY zS`MDD_ww``Q=oUj^n4H98|tYqPd@;EKKI+e1+y`}cdUxvUqE@?b9$?DHCX=4F7969mi!N<=bti} z`QKm9kd1l=dvoZ4TRM{G)9?UAo8=g`J97CVXceWGs&Ux+h{LZhN3rz7KRH>Uoh!$A z2PfYH`=jT4o{VI8E-sV#OP5dfC=utVyGxkAblTFioa8q5OZJ2VRpVIyGkX>@{xv31 znECU!C1zHXKSkO%iRs0jVf`vxxQdlutkc5ea#1lRFRJK8U;}1{}JQy9r#-YJh5Df>vpIA{u{{G>l1~wkM1+OzcGPP$kCLG^k_&;UqJUU2&`<_m> z4GRqMlQ~~T6DG~S%*O4St@(54 z{ki0RdpV7p$fd)%@bBZJ+}FLJ^wIj&OQEOsJ1ss4BSYL@{iQ;nkCz+9vrUZbrzgHX7~6JZ_b%7e-uAv^K5eB8di#8Joby6XoTMt z4;}b-&!=kMKGRaa3)4$^Ij*C_M_j+lo4IQD0p)GrwI%-92dXN0dRHYu!=wT~o(cfqeNS}@#ULJd!=NW04X`vac&P@&|r(GPiT z_nw3|XFlfDWCVq)+n4d=r2k8&Sy%yLiaa8}B)vbRB%U7`&l9 z=&9*5y<*;hInGg<5f!}kj7SJY(C+<{_a=Jd{gI{1eP^G^E8|Ido?1FG ztCHuIpWD*23jEFEOz|`5^%lOjI*9SeoAJq^D5#RR^~w6wEoZP#q?12*>q5_O`jzpx zzxY1tv$_p)J9V|vw`b0l6d?T1Gm?R(RXa$C|9 z>;E&O1MS{$=N=9!Sl147j#vThhBe}sZ~*&-`5~kVJT0 zKXNA7ox3T)#w54=`EE=0X;ad<(`1+T)`+n4(I4j{?4CsFR&o*9%eJ2jT**$a-1M8h zhxb=>)?~S7T8)-M;fbku&*z0Z7PJyM<*N`kMS;%;b?blWFNH*PY zO^UEIO!pk&vS&l#p>clH>(BgEb-gk3w>$C+*g03Ax#R%lCulY^UNIxUjPZeSS06F? zf=(LqyKCE5?IJy?%RS6L$BqBW^o}LIV0u~?BF9s{_?DjtOn~RwdaIKhUu?nr`n#T2 ztejy>#hCux%%jYY^>07U(yaszv2@$3rp&({2$5#;{rX~7u30`244lV05k?0Z42HX- z@;5GExKXE!wI^TDlF1e)@i_9kSD|=dSsRY|K)1C^nVzGjCzH3za{Q)U9m9eAuYT*yt!0Kg~o85D3yI9LC~2rjPil^#R-1!_L9 zhLVBXggJcT#69Osfb?*_{tWb<`T%5>m zniG>J>>b8%V}K09GNU()=lIOz#^?NI&;vY|lWNPb(ttj=!@3)Ll#ScGYOdUmFSwVX}7;KngwJb-bs$wq~+|JzI0`dKq! z9@Ag8SIdmjcbA@G{h4{IfR&%HH;(l)TD5|q@-_Pzq?fbl4$IHd66Mg=g`s9Owm0(C znpU!MiWhS8oZ`uipXmq(mfvMm&dMv^EW_H96!9#Y>`k$*V;b2p#pu)c%PF{DaGjGt z`~S(*m+Cb@1xukC+DE^36ypUU#O+-=-%))%Tdpi6UX-?5xP{`J&rjsB^U2SD&5Vbx zwk|*e(7%z&R|zMTJK`@kU_2(ZU*g$qX>DraeVek{Fk)r9Eu&XPcy$!qyS?H8_KT+6Y z#XF_Rm*v23BzLXb0sYWBYoCt<8aPccBm1UO@gzkB`V}KAOzHQo%%zPs%OO4a%pMn0 zVDtq&7M~XM8-C6la!!!PPgm$)9X$+zIK&MK?|r3lRJH4TUY}J+^JYbaixAU(mhKN$JlUNE7l430_GXlmDftZ zUmblTWVZwMLho%z!1@|q#lYISNAT||B0l@e;J-qB8^(vhuWnjc=#+=}Po<{7hu^Eg z>#B8+8iP;TzdrVreut~PdeRDC=$GGl={6DiF;<3dL%{>YVm9}0M}D1#@Y6MDN0zN! z(>t_VKkTFUWc0I0Rp_@1;uP-fb$@BR?-Yfqk$?Nx(cnS-n!0C(urr?jrnG#nf;PT~ zdVXWnp~uy{Gm&zhvkUOvak$G{;o+scb0#zWmd+{Wtv_LXsm{8TH)Z>;NtL09!%2#3 z^rqv!r$}T;2l!95xbNvNapkxNy*}ftUMa8pp?Smsv{%{wpmCQ1_Gwq)p=|J&L-9JX zZSmNL-_|CLT3X4ox!!dDJ>pg(L1sF6h`-DjzS&As8ob_EYN;9GGWJ?A!Rw`~dD
^Z4sNpD62; zpdASfkLTBd?>^V}`APLobA0x23^0Fvr}AISt6hPpD%qR&DR*S_@%*OspAYpymObR8 zTMD@+=Y}+;Um1Bv{0T5OKPtix`QNuMUQG5OLs{CFP~__p!SBHP3MB{V+^i%R8b*BY zUzTpGF|cd(L>}#HFYhzOttcnKu}Nnz zZ_YjFt0Yf+VF7uqiclKuFFk{4$Ee<;HdnXoME<2upAJbw)(rEy%L6(E@A|F-%-=GN z*{??dKaHNP=$7Q6FsLb_dj8qnb*22P zUQQ;2Y9qff9%z!Ql*sI~mKFjvh|^wc+{Vh$xXAAD1-|4hBH7el@FlgQXo6=e_3wI# zjVz^a5Q>x_R4x-MB=q=v$d-7oqN%JOwWEI7*yq%a$6iC1Q2v!q-20ZL<_|8Aynog& z#&6FzCNuxJ+^?4Tt7TnR;i$p;-WLxc+_&Ng^8@=;Tv-0;1?U#iCrrD@o)dIV^dw4Q3d4TWdA*hZTpCzz}c_Nuys{K>Y_fK6gjZg6TOC-f5A(B5{g*TSj4^ub`6D;s=Ah>@9&{D>`dJ{um0BNI ze%DA;i}chEPVew7Ob6sUcB%~Rg_~LVM;~zUo||!Sm&jlBMw4NtDuw}a=%!0dFX|1Z z3$g?I!7TW>gJ=%qo%H9LfUixYS-tZDy_g)?z}4&NjqoM%Kb+w7hvr%^xos@Rlj91>Br$) z%o62KCIJ56BYxzO$#ZEKk={fA#7kxjb*Wg$0n~h;;cyNat%K}LB2bc#ANgp5Qvs!e zWH6-BBpD=)A!{aN{OCTDX_P1*HNp(?`!7JiZuxLJZu0FN2ck6 zzJ@c0lPozzkdURf(qqW4AOObba+t)QNBP`K(7?L6ifsaXw-?(NSRP-=WErPo#@prJ zgZ?3Xy(JAO_BX5$p=mhx`wk9t+=Sfw)0p9w1{zSrw_>o3fZy=fC03O zT*r+=K?5}y?d1O*!~Ol8nLMZyfb>yxy$sYj&&gZobF!Gq2$sH1_9;96X_z^){oB~7 z!T9%@fA@crJsS1sP%zoi?v&kl5dJiR4sNiIzx|or81Z=!mIT@vvsjc+?INu#><3w{ zeYf4XbIY}Z`e-Ql$2K3PzlXoxTUELCOws1r_t&AGJ+Cw82MWS?Ev5y4_{%cR9<&|j z#-rx(SC)Qc(kpC8wCA?yC*s|SQJ`Hivk7h~WjGG;9$d~)nHyZ3k2IqpT} zU&~r8KcSM2)#*l0}y!;Ne=g~%S7%0rcPE9Ou?7Qiua|weJ6xhAA z<)~RZi68$ox_mVb_<3a8uA=AH?SUM&^3~5q@IBMU#?e9GvlGm+9d;ny*Xu=w zGEh}kVLZisHm^?_M|^wN${|LY;33aP&oL&yxoDrvb@GE7rv%~y0mKKJHM?AZ((&@L zEx^;EhlMF$K6dvt8i#;44LwxOe8C0Vm4NrNUR0H!J$W)xyQn`lc5-YTGz$t&Apa#~ zDf-zG_{sm?n}tB{p{_H_M}QZ7@q4O?dsywWE>F9`&nmJCe!fP#th!&M?a6?jXf9H- zK)C;gE$}YEagBS3 z*I3GwG(1KA_jiE_q<{b7p}of;hZp6j4?}r12_nD5@8i3K*de`2K8SZ6z4R~~>As@` z{S6Q&PJPy;<&S&gFuf%)NAZ05)m@*nz+a!PGPL@F^TAEUw8SN-uj#nr?EPqeapbgj zMd`KIqS}x5p|GvHVvp=fc)i= z=MtAe|4!ncxFtYwokd0)F`l2^&fG%j_C5v%)X&uHfYG$xWm>a-W&(fgJl;k3?VJ2s zbfi>J?(lue`M6IPiAmh{8GLl+z%93mzz@B)9nEz?eTvPE!*-!O6UV2ibU$h4H*xd~ z@KE837cxfZSG{f5TN&v2cWo|S1-xH>Dcl+ubN*kRJn9=UV_Sy=o;#YHs_hA!X1IH+ z9dPp8yGvI9i=Hg+PwxX7M}Brng1(01%7L$dQZM%x6#>WlTf8{{?6!&ubO&C1`R)wu zx73*0jict`{%$dE&_Be*ji!n()x>zF$LQrafcGYg@059s^Ueq51)C<|UVrZLzX_+& zuHFf!R3DE+TxjgWr~r)XuzSA_bRm7%@UredcrI?&lP9tmM}uEQ7fq3VH-5hX#WPo@ z`pTY0J3W7XnbLvu%$nHf3&4lEi;jFidfMwjPbHvt&9!YqvykzBrUpa91AVDL+=MMF;hdUVQs$F7iKnsEbqm zwMVzO%|?62M%K7Fqnr{MO%M7$P|Ne@A}UXH>9?REz+Mf}wKhm!@BM5v*@G7n!Le?@ z>o=7y(f#xczvfJ`H!GIhXTOJi_=V6#C&)YNj|$Lw(H(!%m-y%ak89$zpBKAjU7&pv zlJ>T>KgnL{?0xZr^=3aQ-}vhRXR;GDb??`;L+^3mmABu4drqy|WP@r`FF@?~ zF^aFwo@y9K=aujAbMQ-?7@viI50kywJR`MmJaCbh%4TYx!meoccYb<)k9H#aGx}xK zV6x9;^JeU%{Dqh0&JykrKKP63FOC|97o)J=3ie;6^x4JS-zj}~^c8!LYfgISRLZ}% zq+6NVGr`Ewob(3Owg?lpiTH&OHvZmljMkUh%**X0pAI>q%dnR z5X^JKCvn2#vFE^CP;SaD=GU6tGnu~}zabtD5BE1mmjn?G8GM(OBkRunUPWEUF(yxa zWX|-pOA1i{;v}1dnP0!~&Ip77cJZbXE62#(j`{7!?mf)k|K2$T%m%!@PKmWE#``7n z^Bxw&@Nf=^GiCZ_7P+il+jnqrH1mHdOrBY{nBlY2^H@7B(PyA|ZjI$AhT=LLU(S%1 zXY%yj@~oYa8!0f0bBBgKOK)!<$*{hVUdK6-~@%%|I z2ZsM_;eH`II-xtjX3P?y;1UikwQZTKMX%=}U9=X}1Ldy*fI)bRj8L~9*Y3y&F1IL6=Oa@`I*2X2%4i-{+sB zexKp=LfC`wd#nS9H}K_9{ya1(a(cw#soa$Wz*fHO!`D~mk0-5G${)_hg?x$mgA zyRTof`1!ON>A3@ZWUp&L-hGM+Mtxi9LBx;UXr$o3TWDfo=VS4D0WjhOM4$s$C*emn z5#TY6ob0lY8jACxG$$XX?G0I-zaErmTSC@b#bMb@4o&&vFpW(#{0%z*Vto1cEg$Ll zi{~!Tu?IMjKkm5fWAf&89BQY~M#1={Ze;1(M&&bEY19rh3_LG>CThfb8^!f6!IvtA zf4RWfiE*u5{N9i+(_eR{{1X`*o)JTFkatVchJige%GsT3Y$1bR;%y#EAC|-EPrW&o z$=~02Gu$u1<$u4(3d-L50=Pf)gMfiB76bvKc#zHom$$yBf z(Z`>#!ujLrGK?7FG>xs8IK<6IUSQ?q6-L5PfCm{zGJlgJc7WyA?t9Jh1$}~8J%cWn zF!}YPJ9A0@Zn^~^lDmK zY^a}W9rZ@g^C7-lZ4LC7I4odv@*8Bi^#s@6%;!$Kz990>z`$ zZE1WaYB$7DeowlX8_7-rwVRZHTOU3eO6`3AQ8k3h+xXiek7RF`wZ+7H^4E64!yyiE z@WjcNI46uN`BpcA`r+A}wgc(nVFRBG1`l1GJ|v_+@L96U@iyddey=%!zDurD7I;bR z_!8msp3c7yPgp6@{KZ84Nv3w@ZGB!v<*&b6T21{rmEXRXc;ZVF--}~_YAPplRe-%d ze%I){xW8Cz4)MeEK`T$t{Z7W_9|DA1^&Mu=y_i(X=!evgBirPAb%6~j3nK}$Z>;Me zY`Pe7a46dO-78rCH{?yF(rqQcszEBnn}N1dc{_&zCttpH${JYg`^C!+_|to5@?78u zKOR0zho2}Jo=kjI>$=b`djD~+=h=Kh-{M&<)NU=~ACc6b$In(zpmDrxoQ((`{OIfv z0|~>TCh8Gx|Mjkn#^-9|vwt)%4_yK_)4adRbRJB+a*c5~UTDKSl#RPeC~vjWk>*GL zh?lh>aESTSgs$kI42?pkt( z`nmu01{SZ*eK0kU_FLe?l=GyoR{NoA9B^7>6Mpy;{T$hlLG$uWv+xh)uZp>Tl*%_3 zHh5lv_Wk@Wu#tFv@BZ5lX&$G_snk$@o!GNl8jnoFsQb!5UGZJDR8RjCACFLbMo!CO zzw^A^Zz&8n*3Y(w1BlN@&WV9R!u@0VM>`rXm)oBMDZkPw11=5w-uJ{CDtC=xiWTL% zPdy0B3VXOA6dnrazRB2b!2Q9;#Hiis`=5AHdFdC;Whi~d+IeFLO>)k`pkx2&>q%3; z)|>UrBt6@$>ROaOJ;p?Y@JhSrcEZEc6GbRr+5L-C^R`7hNH^PtETSq%VW?!8ye`j`C z>{ce@^_pYU*>j7nPO|5sn@w4M^KeZj2hTRzK;>NcQq7)M3E2)uj&o&|8ne&cJpt_b z=J!o3Ju#B|ovKUyvzh+f7IB6SD~Q-)eOmuy?a3{M`Go9PkLrL%8_+%Ath3Gx_Z%?c z+Oc9Flj{$W60eSE*J|8Nl?jfH}afF6o z1%%_HIovUcLlMk6rC;aE5Bd6Dcq@R?ZTLJ(n_q4oU%!gFhx}K$oL)S31<9d&y(xUX z2!1W(j-Red(*>Co3*-ns>=Qp9n~mlF z<+pPUUsmBGqp5ffMgjl+_c?$y7x}EYK&B4td%jO*)gYbN-G8>rlrJ;*kLUa3zVg|y zA-_-l@A~@k+4MuNFTYQpO)t{fumE8U@eg*CkHi8=X2(Nd-?;USYv1_=B#r6Ot|tAy z`uec1pDY{sFk(!vuRVR(m*3YukZh*MrWeok%}-x@`;gIo8yCjR(!dyes;Y?dUaGV?Bxi05Pm0vlV`C5HR5#rXrqBQu!RYKGM5U%eOV`` zAIlan{3N?DLtLK?D0n>^DC|GB5V6lGtb*qf26NBrk_cIozn`4>`ulyk^g}Wn{^ggK z%^$Db{QX<1$mM78?U8U4!el7#gG&o5clh85OkR277;3=xqi3et5Kf*)BLY8DN(CbB zoJA`K_dG7#dsX|-%3uHxpPtUy^E?lldGMJkZd{ai&;*0u^Z%aN@iuBW;*$TkeD{f* z{-w{H++cl#FJBaVPwF!&z8eN;yjxr^o8`_UOa;aVSeIcSv_|K zc(8g(gz1ex%#*`%EDi9g;&&`Ru~UTM-pmsW$MV$J^I^qha4ly&FE zFH3U)E3Yiz8Edc9=ip-Ec{}{>`VxMJq0FiFo_r2kiOIqH#~Cyy`(G z|I#@wvcy1?_+3K((Zh&`J}H?VITkojIG6q2`K^3|tJF`8F?-niu`W*?pV9OG(yGQ0 zKKZ=Noba~vZ1%m8%hwM$u!1jK%4jjM)qe*4h*P@esw9M?IAXtcVxe=(PSKoaekZ znEJ6>+dPZ-XyKSs-lXTWrPiLxE!nbdCgJ#~L8A!+$4Z|dTsLb)Jn7~AC}q6zt+-Yg z$;#%6O!mLO8#@^1kh*A9Lc`UCLQFrD*Prm8W*)<=h%#A{BO@hSWt7TK{{8F3hEKjAU}abmHUV3%+Ym`)($zyhr+r z)(PWJH6U)~Fhq^8_fsWn&sE=JaH)usE32*|T)r<55fH?OR&EEg!a07)Y&lB*w0syW z7rrO3+|Aa<;jRSMt}Dr7LMh#~w~no+Ljm$^zfQTp{hnR0`VJ?`k9$8ziBMr-4Xbx{ z+zi%!U*#mWe>y+w2U5ER@zR#l`i>L+*hcmLdQ=0GjyQzU3%Cr}+wC6@5)KbN4c84l z^DD5#^n1W|Z2c|@d&9~Lf3+SK5q$Z_E7qR+Pw(0OsNaieM0!mSwg=G9r;?3lrG^;G z|JZ(>*^giAx3Y5HeJNsSnP8_w`b{p|VBj!*u|HUPxA7^4^A(7Q;yuVxOH0Cr(fB+D zs5}YNO(?Yl1`zN0G_Pa(@5TNMR?oS7WA@yhd6$`<|H^?3OZb21Yc~IPd>`uhv-G3{ za(ZRRbB`)x~y2`mK=|4q&1?h8Y+dh-m|Q9?xd=-Ah4tAzRSv-oPpR zIM;yj+;eTxS6Mp+r@+i1|8YI08)yfy*M1#gJwf-WDF-ej^oO!z0Jw3 ze7;??nUiC1D^L2_sa(5UPI3OHG=xjHyv6DH<#4j^T~2=go-gzH_hotv<;)tz;VOEq z1F||*4?IrY1F~xbApIH*$+fFE^d@!4e=*yH?Dzom<;$<>SOobKRu`e~WDZBtFhRb< zum5-nrI zec0EYzH#p>k3ELx`tZN?{#SW@_4Pg1S5KeZhyPt(pI#sK>Gfe>eSOH5CEC|F4t?X? zSAX9;^*!H*eb4ueGmIeq{a-)(^!mo55BtWYZyx&e{u}%B|Cioc_5gn0hmU>dh2?yi zqALH{9*VkO0pwHsd>g+0Vz!a-KHD%Ze*|A|F&}^P^wuJxbl<8jUqph-~VvF{arYhOP@{GD9BHVYGmy^lNMDqeiw5Gp zVQ24j!t&SLIiX_@?G*5wWois3xpDq1)Lb70q8;;Trg6SmLOTrn6~DSp7;QuohkHl+ zx2$|CL+U7aGP7tnkG$r_QG6>muD%s3SpI}9Tz^DjAVS}l1!@pi-a;KhJXx1k0OGWU zu~^FB`F7nH8q7;uE=&J%t3j6Jo`>JB6W_X4NCz?8M@N%|20v}R#&G4xREDwVuQ2|% zCCQStv)?n07wi|6V)-)%-el+;j9;OH9g>Bs5iy9}~#qyW!@RF{&(A9#o@i_Nj2y={K@tej7N`%yn+RR{T{Q4wX^2rafUxGPhsunJ-W^2X>~fT zk)S8~DuSVhZVW@e8{rIH5^xMae#x0LtX(nU#;l#bZh55-S5(W$%$=YXES!5^@>~~M{EU?E> zWWe$L;3`ZbFm)o=o{xe!wnEl@%e5nWDH$-_*L=fr18V4U_;jWXlSRa>8HOgI8OV1= zRDm%41ePywec3HmUakxNt74C?^l3xv%rO$GOivANT!yJ|EBjb{io)^}l@i|0{?3fBFB@TmLD? z^NlKiiIwEy@2Kb(O4@A{mg zWH{j-5~Ft4ry%UNqJ!_E)d=@V%bN0_xfZz4a60RfwF5Ef0I{R$9^gVHr@Bk9BTSY* zTM@q91Hy|JoV>;x!Q&}gz?#(wbd887NhNzg>)Y*T&4l-AK0gd0A?Tx@?6C@<9vlT# z+4IVB=p=A0lWsF9 z10Ht5VmBxW_m;j7YA-z@=!2w~SYOcS0Y|c(H+1&KKmqS_rycJ;@L@xG$$-F{EpxeI z@$Nf%7ZPD3lTr_w&NpVh z$*%zesV6&61hj)6Td&Af2AaT)d&M#Jl(isB=IfizxC&qxGx2JWv;>^bY|GqHX#taE zLq}u3YCx-0Gd*mc3rcd`e{VCV0ZddYBj8mgpuJh=_4s%@5XzlZk*=)*iY-f1Row+3 zU~zeDks%NKs_ac9V78BW-+CStry&XpB|FU^tRDjj7Y@$T!39|=6IUx_${ z^$7iCBd=$12=#zBm%{_K2D*UfgS$#-YA0YgwnSX=y$g_^|6%X4)Cp8Slrgh~w}JJs z$LAd?n}C|hmrZl~2H?CZZF5>21sm13pKREcgEQp*c}X=z;O)b&6`!u=fx*O!0b*e} zz=CyP-)G|s5TbZ|DM&j7jNGwLq!~#E&LLkTHwL}}8ab)f-=A{;_X9^4qWk5bU(jXq zj!hY;X6k(bWQqZY7E8OBNCCJwUmVvpln0X9qcR^Cbb|Sdb8DNL?La2P%guqb31k)B zXBNzf%q2k{OL!PVBUUfqFtc`h(23cFbOXN zA{#r{nfE!MJg9ggW-AMf&Dv+2^2h)eubmJb(#-%}l`)Iki|JrBhOtF4GY6PbP4<~o ze*@5mQ^QmdxuCOVw$&*=7ueIvb}sGYf;hjw&##l^gF%Z(rHsW~V06vRvqkqSP-<@a zwpW`07I~LYf1wPZB;|1-b*2)8h1HCEG}MDjm$tU`5<9_6tn$8MOAip%t$2aN6ZAf4 zIf~jV3PH+MEpqjuasr>Aci5ea4PfUN8KWj&2M|6pW;yKE1=?R^CKR$|0GF*RMzlKV z;4ZZ#6qb+$lKl}|QgLw~6yL@W=~8!=0>KFkF#{=96a zdYJ`oHEo6x`=$c%pC(n)qZy#F)VY1?Y8t2sgbQ92FiO)s#%K-V~725pi5|FH~<918B5d17!nH=TG z2emT1q}!c&fb?W|+IV&r`UZU0~wGYC*U+Rng8><3!Fv>atlsZ)) zsFHEq@Y?ZflWwuN*M3G;+p~VTAMV+XFZ( zm%v*$Rgj&Y4Y)oI{;7z}12Qy6Za14s!JN|i2=8G9C^r}{FF#5LAr|%9m_RNN8a93P zDzgxfwp&mpR+fO06`BvF0p;M%z<56?T>_~2#KY1*{}GUp(;V=rrhq<4v(lQd0>D*J zFovj>fZh0v@q%NOfMj7&9_p6 zTw1`(;+nPAcO@X)aMOBktOD?}D_=_?t^vQG^S4wC8i1@iSGZ7Q6F9mjOnR2!-@?|) zy0nd}6Qre3X;z)+0PAh`e1l4zAlfaF{g_f02s;(bIbYNYzMTy*S#xd$?~vUeCEjh| zZO&mv$+J!{cRR?egfNc`0!Xa>MmK_6rwdfydNhO4<=anVD%-&ynR2E5pIx947WZ^$ z=>~@~zAH@5EkKi~``tie8)$)&Hw%@!z~}q=VFrY8To%yFZO%kEk378DMpDoOp2zz6 zKD*co{#skiJS5boz3(#3KEbcW?~rTV;0Hl|la|l>>s}Z5={ateI@JXNnd-Qd#S%Ag8@KQ+eevJ;^M zd;*q>0#yn1{JQEow=CWRv?T|%k_rBTg*V!txe@G>7{}xeUDOHpWOZEpXV?knx^pqR zZIuLho&=X-U`8M4`m$>|YTgezB04LyYx;o^aV8bR3_&l-DapDcxexTTcu3g(?FU_< zW?!pL3<9!hp5Ni>gCO4R{>>(W{h9wnlYA{dL9co$#%z>e=M^yO6EH(~-v6%sC7rOZ ze`viWm`3nd!j%%fN<_d*)f$UzTm(L<7`@h#c7nZLbiiDiEJ44~Qzo?dEP+qqqNqY) zUo}CFZPa1qVciE3VNcz;us#rSVNWaPSs(Dyd8V66;7c`({=i=LZ~)LyygRx@JP2Ge z&t7yE83bITg|e3z27%4mtk7B2LC~E-8S*@35VR+LJ87mg1ZE06ZY=u`fqnPmVW#dw zAg*BchVQWCpr=W5RhXne-%Ye6x4+-_`RQp;w zK(KGy4LvQlN=49zr{_2KA^52ojKe&P3I3wLA*AVoj(r6Cafh37I(H+*Z4c>uXJwRNU$MhM~AV_n_w0Lqj04m2GK(6K=0Wkc2Usb65-OzY0mdP*EEEL4d!{EZ ztjlzD0JpM7XCnx>Z__BtKlfn|XpDVGHAqNT+k9K8oU0qOQ2X5!bm{`Zde21buM+0L zPx3cL5Bq?-iKoL2;y$1_og z02hfYN{6fTAk&Itw~y?r5V;I*2x_3xt&(4%qe zJR5<>!}R8cTr}PX=#{cIRVCU9{u}SeTzb_Cf@XFvDBfuSTC6$mL%y~G;q7f>ZQpjF zpTB(bs#q5&Ys&iRPQc~5oZ42p@0tO*=9l2Z&Uzrq8q>!mRtMH?XWn=aaQ4XMe6pmP zE-;TL!EGcR;LNhQ1I21HVB5;Q>o7v#sU!C#pz9t$^@uXqVzdiLm(tAbO0)r&-DHTL zqzROc7v*GTHUNv-bbOmIZeQF_oF5_Zjc`?$$#lB4fSF)t0|KKlAP*LE;C+PwWF0!+ z)7K6bSe~vl8MFXu`lH+Q2Q?rlzHMtNvm9ug|GjUI7J~|M^Zj(nI-oe4W%Kb`4RGIB z-BjhS1a>c8Nr$pkfP;8Za<|!1KqrwSxwX;=3`Ceq?;X~I!5}EK|7;ETQTQ^f?idOZ zbBN{-OkR$P#8+9Pcd7i}WE)E!CfB2K@7XuT~n{qWQ1z;`r;M%D_ z6#$+7P~8$;4lc26A!XnuU!DQJwQM5@K7hE z5Y(}d51*Jz2dpl12Q%Jrz(q#qdv$dxFsy3r*~rNNYkW@H%l!SomTvvp2-XkYKX(ju zRT}_z7~gM|6cPBB6Sf_!ul0lUdH9OhZGs)eXT&|~Q4i?2>%pX**bU+eHAKtq^Z;`4 zDxSZDbwZi_)$u^?av;xV{K0s-7_(JY$Q5} zf?`9n!k6bzaMhic;p7Gemam;wiY_IL)9IhDJy>di>z~?!97$J#{SH+fr@%XKp((qd z#Uc!F(8hnLb@c~amJYWf-@XOM@i7`IGz)CxqDR_k`QZAsH2J%wg+O1jnb>Hf7+_n4 zUZa%7;9*(x_lRPG9N`>$>H}ZGeSUE6V2x-$_`}#g=ug-u_*Vs_b;FwhqqM2!IAI^s zaMCQVH|zryYv}iD3P|(_ z31o{&1&JE@BT_1UvkC9c&#LQo^pMY9%^e%v8*WlsgNDax~F zN)kaPLy&w?_eU`Jm8&FqE*dzFd1XH{j|AhvDJ7X1`C#++?!(B1LJ+m_^Ksv=Qi7h1 zOtw!X3QQ%+S!I$@z#rTE;w8aeKF{%|-?9PX&0u6PxQTRSOKhj#u*H zl|c6UG1@ha0zj&`7jYo<1r)4t_J7Dv183=^`CL{afyWOHdE%}QKrkw2bksN%RG2Ba zdUWQ4;m65sQE&5r&;;pQW@Qu@sXb_p7%K;FHsB@m#sYBU#A&DUT?$)Z~D z#QfUbWW{#CxF=EY=qZ zgB@Aha)@sI&g|%ZEkrbSl0{Ir1CnLqR5)mSj#?*r`@4K@g=E=nWq?&X9OO@#NJx8eP~0G^Hk8{1C7+Q^CDH1El4j2sOonwq zjz6Zzo$Q(*D?8sZ9+osn`@T^;)thwaf@#9NZ(B7`v6{o~iH-~?qh!2vTt60?J$Cif zbM+>O{8Yzq4nqfIfB5*}<;EI_squC|VPYrbqOtBA+SUolc6a?raLs~**5m11auQL4 zXl6DT%SUq^iwjC7Y@j@WBR288dM-DL5iMC zhGHV#YE8b5Km+$gcjwegASDj_72fe~NFk%(^RizvG&rt&`IJsKH1Qz#3b)-?^p5d8 zj6ydR`g0?jG`1}dYB%{NCMsP5F=@`p3sA;EU(~{dt{L^65o2l0 zGY9YDD+%~VZ2ea5p8meI@d>`hQ(dy-1N0=M_rj0{X3uZK)5V@i=VxT zZKv(a-m9U*b~A7u5|<;W*ed>Ir`I;>dF>{}=TGOc!5WXV!i(qN2{q_si_<>(gxm1~ z^!hktBFe_0hzG|JERhO7Ah$kGMe$WLX0Zk z{!|$#hr8bR`*E_>!Ta$?pFPGpvHo{Ml;cOl_%j{mQ!k!(z-h_8?BA^VFh#@GheoV( znC#@`QFrqen5%P!h@*!Y;pr5_4X*!&``EK19_|t2LM2rzO3Kvu-GHLI>dEJk7^zcP2zA1OS@E`MDbf0xk!~jY9qmew5ZL*h`wON%V#6$oS7`Lmpq>T3tH#XOq9l_Z_wW(UUVes`{ z%N!#KXY7r(xKVg?6HJobo!{-8gtgXo0Qct`Smf!xvo=-ruo*Fw`1p1nCYYc!woFlo z)fby~zgMn+-(63>?y|WH^Y*ToTD0|JN9<;h*0UeT0<@N09}GEKb;2~Q*Zh+Veiw(~Fez}QpVFkBh866mW8^k+qC zz3HfZ8mRGUB1QhsSD5gK%DUM~e&|(@dC_pLy*#bEfy=~uXpIq*M}owud1Z5 zKEj@SHXc~FcnH5{VAxcCS_S)oj;2Mw&v1v00(U!)9>yhoozXbj1hzONULrO&#%wRr z{C(}-hIQL<6FI-g#FToQ_=kfY!P*H!Eqz~XF=4%rQqAxaSo1pNh{Ek<*v5xM_jG&% z+|I1F`1*o7){!YhXI=anrn=Hk!XX`kT~*ad{LFj|@n z&Cs+Kvk7)t?fcwl6gAdd_#i%qo)UhNU3uw|4>fj|vyeB}X%95@gqdJB6l6o6G3vpw<*u%r0}rr4lkDcNJ-RS# z&&hP|CJQD8+GT%d4Wc%&uhYd1d!hBFGZd^AX-xOl+fD9*I*IwimhkeQJyrgwMj&T|V77aVMLMcC-E=GekNH45?m3*5 zYi@x4N)t5X*Q%j5T4|P#P&MSN-mj{)*a~f>Uat-mj75i&gEgtOTOiw~QcHWU8liJG z?~W?8nxW(ztvmyd2I%OAo|~Fn7o_&c3+%7uqnrU}=Gp!pn-2>UpLi% zLsedtJvPiH7^=w*IR2Q6c76mxn&GhdqzjeguK%3NT;9FD*K z{hqfPja7pO7w`8#-_X5s>wr2);purYZ{lufjpQjw22B(6axA27mcAVN;relViVp-;|O7Un?Yj1s5B4eFq-mdlh>O>Gc^cYfITL>+YX%)(cH0`7dZc%t!X zcOBHyR1=iu8IM}fZT9^>%0s2@s@2^*VTuNG7-{>^L_>_dTuuWoNi6w2>-jeOmsPdSKBzYYq=-kJx!rTm5d3^4Ufl=tFckR&{%_m5# zC8*%fnM$;SAv#gdu^QdMq%TeE)}o*MDVl^f^3jL~Qv*@W`A~yJD4(BAJc_VzzaC)8 zgiM%TrHF;Iq3>#w;+{@eL6jcGI-a%t(ETe~y>B1mkh8!gh8NFGAyTr@k7piMK-V(J z5=!mAK$4SwTZwv~q1AhLyADdaq20m83g(h#$iuB+JNRxB#JQ3q_QN?5%1@=>cg>1K zXX!2&I5{^%-*I6hdi@S4npW^YsJIC_G9XSU&8~o|Znc+5_<5lDlj0f0+Fwu)2fCqO zu~jI4Xvd#hL4|14rj1MYMHDr;e=7=h@IooD?oA`>izr=#RJh2{SM=-o=RS8dtG zyk#wPLZ{{(LCyssg=AIdof@IE=`-9OYK71Xe;xc_wiW6>r~9D%Y6DbCIwsC#+6kEp zYEVRUR70;F=lSEzV$t5J;FKfzCRBw$uKZc83bmN)A^9d&k^tkj~vANw)7$^(R^> zRh>?hLd?DShU6Y}i*%;ouz>}>Q|%*Wz%dBDbnd2Ws?JAc>pFiY1aw2}i%`tWxh05V zJI1SY?FQ!l>YiTX)h=idF&cEdUW1-g;^GLRorXR*UvFLWC&%*b_**#TWnh-gzATmU#@Xxh9l>Tv;(M=u$P9fB#32)wmMTpMWK9u+t6np~iLe;-KFJey7&*-Nof4+iAq$h)QgFO`tb`@`H}f+*e+2L6pPWXI7r+_Ku!T{L z9K7}M^t<|1DGbUOqd%&I;iZ@CXTdfl_Qh%`*!EsJ=BssU`GuzjX6VLdBf&2Z_a?GM zAI2$S8>8&8TZ;hGS+Cv~?*9fSx%b^B`T7D*zr$lOa_up8n!^9*$}w~J%NB3?xl&Jf zfdJZ+!V0loR~tRE5MNlHVj8b*cfhJdWag9d-C!d3J%hwPZ|q^9#ye})J&d}YtRT## z3Vt7P`H+kn!&u1g?mTptzzyf>egu^F|-)^9J#kg@r>#1qF^kguBu3s%Gu z_`8L8-*ELixGjTB+)Ic8;bD@9m@{F(yNT^qJbv-x^r4gnj%^Ua@|#WB@{tZgx*L@3 z-@}2=`^hvVG6^H2GASF|2DcEq%`S_e165qPby)Fb%u}3T!L?&%tRJp1FP0X4oy$e}~$f`6So{?T}K`quRTq-*6xYe-iFV#0&e zP9>TkU+$;sCOg>R=C*OwlqX%0M^}zUAd?WB?_4g|U?^_~XgA?owQ2!?=*_Ryh*r_r|&Sc0HcB5RedR zG=cED-vJ6Wb4XH4e3;@@JG@K1(yhAu8RGRfZ1tPmBcwt$s>$SrI?^I2vM0)8j9Zen zRTrF&LMDSndQ7GZfEN2%5r}iYf<9a&hF4f%z5a{42izr9}D+_UaCLC zQ%>igZ%V8X=3Y9=ND6>wU6GC5-!sC8ROnpPld6!nmXV82t6vb^WO4L*J-~egn@?6R zIU&9N?ra=HHb^+jo7@M#<`KWH0RAZ?2{&%`seY1FinFR-_z%%k&k|lZeNe&L^w^dNc^Jd@Q29{JWbf|<5x=O$f=)6Aa{|~A?1EvydO5a zcJ=`;Zr^sr8*k%9WZ#_3NU7ICbYNY*ea{DYRUdi$ z*tvUpqg#oHy3uV?McwE4<@Eb;cZtjpiSB11-O~<;$YXD|<09t}rg5jsN{{Q|tT1!2 z3#7xaZkUQvYkeLJB3}g1l10NQ_3`VkhP^O4v)S(}%M5s9wxyrV`%Ns>zWJ_~Ks;ut z*sHpK^bLFSeE5zx!RKqBYR+Cd6CXm9Wx1|?h6Ewm$mdYGodW+2FK~E1QVy?-c9oF}`%*zi$aK}Dn^lj@2%o_6-QJ2remP?=tjLr@dc+FfD@ZAE| z`(4hFZES)mZKi~An+s!IJtqPwOp0JG_V3guU5&7<2wPjLHZAPp;nUPM*ciU4>Qb_E z#{~1Ax#e9vR*m`Pz6hW(a){C;{V`mO`g;LY4NJ4~r8v5n)cLlKQ-`7h>=sDqq<>f2R z>Psl;^6QMR7p*apl8|aYzuzbbyByuM!w#E~2Lzi}Fkw^8YrLnt7~pB4NjC1F=deVV z;#lo10c@l$TI;MAH^!`7_U%RpH~jL8U#7k^FE-K0DZ`1s#ag`u3XX+X!2Twi6)%#7 zFw5}Lg)uF5Z2E=aT~TEKUwzm59zBO)hB+$B0oT2;%t#(VH8&^t(ef+sP4+3qIVkpd zEzTUS&wn5spUH{I{G4jw&Rs=AM_H!@U-mg|1D*>Xoxy0%Xcb5dWI`$Lwior! zv_eoIV0mxeh4!ni^lY$}Hn z^A{_$&v0o&Cs_0g1QObzKDrboN#aP9UbWy#AaN@sBEoOP7}E}QiW=k;hqOUi7yT2F zmO5ymwW2$efYAE6#4(;pnAf$gv<0((T2eaD;MGSXqgNF!La5) z)puTN(0}`cYTnel9cfyC(kcHtova|gCTz5^fNtv~&c;(elA zf*uUSu64;Q=w=_JbjS1NKvpT_ZZDRcH6D+CSqw_zGpvJLH`nVN?KHe-B!#LWNFvP0dI&qSmB5XZ8?grE_a|by z+@0w4-;_(~mD7+@TA#4x@=uiH#k#B0ASK*?DOhPlR19OrpSMPe)kEqPr)Wx#*`gz% zYW%@{Gf+4F{y}XA{pJR5XBMMYbX2O@R z6g)hq?0_{NF?JqHdW=UB#srgloI=b%o&5lxtz3Z=MA;s_S#rc>UXc>?iPqb^*kSj7_kFEagQv74x$YB-Wv5C z-{W*h#5yYW6=B1}bcIR>5phJ2+I#rpx+&6TOwM=s={&BTO(gR76(=GVk@jfrIuHJ= zS?9olSOTGwiViev_QL~m)LNq=^$>wz@ox%|y11aKW&Xn*6Xfw1h1o`bZ(MHd8n3ll zGTtFHx^!k(2QltxOUMN>xP8r;%k9yMh#`0Ig{a3dcz3W=see--(q_9iMs-^jFErV` zTKz)}XY+ej?8@MPGo{9RmG(s-r6YzOnO{F4RFg6q9Q1MsI}c}_=vyP?j(|mlagsM8 z{%cZDiYgwbp-$76&C9?SB29D(3>|Qj#T#R^gU|8XNz9vGys7x5PBPk?M0vepA5At2sMCChr8QQ+Llt7_M zNTS^AL}kZ4y*A%J?0~*PvPYvwxRUgO61o5M^-5t4|Gal57(#Je`YxG715Q`B=aI}- zg$sqbmHv?p!%6NfDJG)DNZN<{%@@;`a6xJET?M=dCp-Ex-nmnR*p%{7L>j)wi;r#S zjz;9+K+8H@tY8<>I4I>SvF}Bm$;>e@2Iu2E1O-JY{;$ZKrE^zHe=)L}_?kqpil$N+ z{~lj8c7SV>#pN)8Q9P7}Og(gQ5T`t%ueno^g|n?qxeE}(mE`7Td@X}(xU}rA$eUAt zk*e8AyK@u6IO*qTUxUwE_&t^UnJE5Dq&M>$rGb0^zFE3V#$juQP$}r}-N<)D=JGf9 z<>9A@0H59KO~qvV{sWV(7$g)KRZ0$gaNY&aW}UFiv44U$MgQn@9Fs+?$_nh3$-W@J zWm4z9y!?a@{16?YB6@>Fxef8W&V7o|uzY0heP)h(o9?s9rs&krGi4#aLWzDMBikJcjl7V)wNvNThn-N;Eg{hwwp%kc1&OK_)kGj3UG zo%Fmb2alM~y)5czhxq5m7{J&q#B*(4#4Yd&ekY@wzr>giY4;0~r&;F4N$n5A1L>rZ zbglf$OA}&9<3YO5*}4nJb=c@O(-1vAPVIR=lkO1C9#Gv%4>ZALeKn)|i*DiNg{kFi zv*P&A;Uej|(`*RYw;RH%;lHqthp*KC)V@W`i7t_M-nT&-uF<||8oh_qn004d5rpwj zm1@(3fo05}B0n(fath9$5Y*4eX%<_Y~=fX_J{1xPik@TsHHDC6T;p8hgyeA@&O}X3+Z`Zk13K`DBri(?_ zn0d>wB=!B)jdQLTvp`9EpYkVIOJl1G9{CQ3vF#`7T&X}3(?zHNgO=-Nfa*DW#Q z&r6!pd!?9)X`W=5COb00^^-S%mlrwglfB}x^A~IOKBNw`nt|Q4``gUqN8zAxFfMjV z1Fy+(-q&R&L(aLVvn#7JAqSMtGC6{oaRCX5602}}!go zzaZB%`u#E1AeyB5>Ut9-pR{JW38B$=xcv5pIG?yMA0kCRZC3LfYv}xJrav>&#-HE;X-m(W_q}r24R0r zhr216y_kZ!#E&lNcKFh-2|lCuO_;N3^N-a&TNukxRQ|mw4`+R*$!6BQi1E5lyx)Az z2d~Vuy6%QhW9OvW`Q0U-VWS@{S|-(bF`hlh(@*3KJa8m<`jOBn%<;pkZmJ?~_{8*3 zi<_Vq9ICDS!MKhW^Xq%`QaSh>#wz*QruNoZ*ykoTm|`f1l}vx+Xoo|w7nM{)tNHeD z*vG!}=3EjO%z7uXK%5d&b>ThJqjM8>RS^~Y<<)^jF|8KYFulbNKK4E}SMY)zI4|vb z*}lL$$QCDE>73vv6+-hii@aF0hS^5a#u|Fp`Ibg+%TsoHrjYK%0Xpkm=t-n0?!%v;Ng4 zh`)Y=hHbbF;`uWSuHEfMD_T^DnjBjp=XH5e?iNWnTI8)4T`>!`K>gUnaA^`+it4Xu z;|Pa7sVU0#6V0J_gC(p6;rZ-NG=lctKLf93Qs6@4Zs2%LQL*m6t41;lZrx z#z>|3+99J;Azn(^Eszu4C_J)W1{wRNjLIccK@MxZf6lIw^ibKy6%byUlX zhddXx5*~0^`4Emu)~FNDIJcpZ7b0|DY!^er3jSSbQW5B^ab^+o_lMBY)$*FfKxfp{ z&a}qKh!cC3lrBR9WkGvEC);jc8iux>+*0^3)d0o6WgZ&LY=rtfc?$;*lAz=n`6trc zWoQwLmB()=7h)aK`4(_K5p~+Oyxy}_0@1r~zD#ZRf~FIRVy>C^({d!D~TvBFP$k4t&lI^Dqkyr8f*fbb1s)c$43_KWzytAQ(bznq;na1 ztIBH8=)eOq(){e?#*_f%jxcVVsqlwx@x8ycLsSV7>6CNWY_CFQH<`ZO6OMxnB=2rs zvgn4oPFel>6Q2i7e{mR>mY9L0KR@vL#6k=|p*uCLUt9)pGJUWn-tLDqle5FKXG_r6 znx9>NRBuBaL@a;Y1x2tRTgmO@i7v=j?BNS1UOn`2jlafq_X#MDs%Ob%=@6YV-9;1+IRS%KAjtP>P&yt(5z#&pK4s|lDn8Ij)7X-foO_SK>Y+;axkw?*k}1ib z%zh#fT7#PlDJRrh`q3+j=nR>iMje>{nR1o^vKOIE{4& z-62oYz7SpBbI+pujN~N54;+uJ#|>RiOqAL zgdHUL5rL{9Jr{v#*vvR6Me$WHw)Q=^N%l=YoFaPWvWxf{_JJ#K$I<#WV%MIR6*j*J zv!AUOV|~30AJAVIW)t~~$(`Ms`sojbGWfo0 zP9Q;^IWJIM_G7^#-_M>n$DoBz9gnNZ6kx=Yi4$vmg zYDk5|^m+DgD)=Lq2}KA`1h2hgwPX7IQ2%@w^TVboKZ06LfV!N(m|K1mi5ULFAxoSkyz-9 zylp(Udi_QLa>P7HBWipPf4wjDW8VK7?%^zA|CdY)QB*gg+Ew$y=N->kej=*D-JEX= z)gc7D&)KWxWF3IBtQDk1cZDK;#%`!-Y#RQKThdTbb_Bu3CRsKZ-H~#=`|~><5y;G2 zow@b26ukY7;Sl%bMnqCA@}#}<0pj%Q*44j46}ZVK1<9wuDG1$)FR0v##I2ny<1|@x-kt7k==nP$xjJMFzmi6J#h+zdLX5oCo(FGWcEJ;RKqz%QnfcdR1B zC_LKvO6gQ(a#KS#)$J)9+n8-`o|USEbVTPrc}jpz>)=c1B`#Q+P^X5uH3eZ{Mf16hi5+Z zS@hM~MRe&p&h~e7kAL)RG&WEX~sgiy5R8I{OLR`%X| zQ#O@R=9dcDqmuW$N)amABeJq7dymi0^YdKSxz2Sz_j+vGPqhSpgQ{Lqo!@PzAoJm0 zkA1^U$Y(uz&UR@8_&VQ|v7Rmi8b5-vKUh_O$N-Ao$6tuit;Fk}iZ=*Q^Tgk&u_h-@ z#ZT-bi)WsKv!~rG7M8OhyCKZ(wwA*Gj=ZoF>1DtlMr$ef8=XauGaO_NCRdtsb(>znG-+om@OH~qDD8eibjr-=+GG-@rOLCB&Z4Bb#G(?huZ_p ztr<-P@KJdQdHbX%P}{jt$~4RZ?-;zkR2?D)^|L30v4lgKtZ2qVWb|V^Xc8nun z7g}UyTVn~v<^|n{1!ZB2$e>}rfGzA7WO)4Jb~KO-4wiWIIR(6!Yww>W@q&vAeoCJo zNPw~UhgD?MHIQ1%-l$@)9)23^Nh#rc1Eo2q5RG$f7ojfqr?={qm%)JhQ`zB?mI%ss1VstF``i4F7{E&b1A@^ z&19hdTo~rv*>|VWy96|zHoUN~Hv(M)1)^o-N>J?XnGi_{GDt#HzV<5kA_%y!%bkF* z!Sg|5BL%$1aJT3>S}~yyLfSgKQ_HE~z2f3Xt{QqMmq&Cf`RZk$X#KCrZZIMwo$ zllZ_z!_UkKHFrR5zn(vrwlXZV2%z}!MG9^gaETkLmV&kT%g^(g6X9*fi@Vlm6d>uX z;N#&XOCT`ID85DO2GM{JC)v9~V0qJH`fbt?!lKg7H`Kd;nY#xCyk(d`;t29qJnY=zca!PNa&<1C7vuf&4I?{r3T1M5^8^Xf*-YI?O9$j& z1jOUJYqFexEO_3NxU)I!R%k4WR<4&*b?)Me3|MAVaA>apgMWjP5w83@l~4(@uJ87^8!3V4RcZ%^SBPM2X_a<5$q^WG?Xg=?x&SsBQmUdZBZRCB zCb(&5@L&PZ$19&)5K$z*vcYNf2yxqsToCXUz#63jJ43GsW7v+8vtY0QQu*uc?+4ma znDpBW9SOdN82*w;)!D!c$%v0&ED=<}5)H-zgL=7;8ri9rAN`b(`+OBESO2wRWovpt zy)|0MrMiRdnKU;fj1+!pz3GH;gc%u(8F?XZzscp&Ulzj%c~8$Nr~hsI^{sBR>D`nP zXGSH3l=}BZUhHkLol~!p6|?&8&Qo3_tdxVmEvr(=kk^Lg_Eu%1@ImaxmEvBd)8-gH zwR+-j4_FYAsusq2shfJs3#XO7`pX3P1vM!tEcWGo*8bY)^&(fXL9Jg&qnqT3Z806v zx0UH6qsoM}tFvz0d9$L#!WNoy-(aNi5>c2q4fRB$!IRfrmwjE3(A~ZV#aGy{VQ0#9 zDeg0v!uU&%L}C)eQmX&hREiGk8s$iLaVu3)(mq*5;@zzj#bPDXG>SEj3;kuO-(6LD z)#n!|eB~T=xL*6SnJ-6aa7lWN|6{dM?o{N8d&>`{cj0q4cUqSk-)5J-wss@Mv|-6! z&-o0c7cupA>rBl`mR_bDddHoO`97WQwCDGgjxRfi%FSFv#s;@}DAaJJc_W#K4&}K< z5VZLrLSRkFDP(BZ?=3ZUZ{MDv%G>~pu36eI%Ggob^?gmw5k!V%4kSDHP&tmL*&L$p&X}+7uNUMM11BcJ7QKaJ*L(q zjJ@9@eEnWd5g~RJS21{Oh23Zw!wKdCkt?S;13Y3>up2aQ<>?%6BHjj$j=Rwo*v@-r z-|YL52?~I9O~riqcmpdd%0J+%a>2L^iJM<8@j()Y6x(87S7JdMUR6d(qloz%r}eOfC`75GPrf|R4EcEH{kJa@k(kSG z!|U@tI5HY^UA!V^7<(apZFC+!`TiTin_+ZW<J2FXRzgA(TAxlhWx(6E{DS?w1+kn7|hCY$I6GToE4B;utYbQ7Y9 z_$CQV3teA0b^}<1G@Kegumpyy!OhXDDR3$His|?RCD8hd?#afnKCA%wI&6Gq;9J$F z-98&n$nWXK{mZ2qDo>wPQl&S8h6|qQOVWlw@Zwp!hALC2`{nH^(f>@qRqE{#YcEX_l{N;Ar6`uRab4(4}n<; z*FvjO4fM@$#qHQKL8r~-JhwZKp^E?Ok{32#!N-DYJBJ%*@Ndzf;e$uL;LYlxW6#nT zILIs*qpi{o2>$CcQ8J%_Hcyb|k3o#6qwrduOLYxscKmy5xuqL~O50LK+RVZHMS?e! zNwlaz$?4qC_w;CT`dM?4%q^(F9Y|>Az6g|B8VoR(9auVkebCjK6IJh&Hc~xS$D36c zMsK#iqi1l|4Hb+CCt^ue>n;o73Y!QG)JFY-LeVr z!QJ|+Ri7F08@;V~Ri7|g9WxsrqBzJt;zn=ZeVj*m z6$7Elcx>rid7B;+e0uw5ywJ~zpLk!G0UfAN0uYq?5gV(UizqI4e0}Pf z{5<%Zd3!ZVmkgiGU6mwy5P*M|j!N_}(#HFpt48#j)KH_cLSKpk0o>jw*UiT5Eb6#I zn))-)9yP5v6Y+QIJ|6Ss*WPx$0J?Pi@8ITJA@mWS0^Q98S^Tap#klbt*ZDRz$|t7`IDNTFyCx5 z{4{M9a92)h2u41D%ti5+6OV}TF@N8S)YYGWd>_VP~pyF^jX*xua@HYkt!^N{)i3Eu@vD%O-J9x z8gnq=d|@6c*auQH61lcI>G%$OcxI^L{NNd^ul)=z7u?**_c!h~=6ft)Ao2QiKRK}YILIC17J z9F_^Y`z1dWkZQ_r2o*TN_cLB^OCCp`fH1apk1+z2>1=$Ftj0$`cWhy+(T%~g-+!0& zOVt2>XFbdRgoWg;l`Yb$N82W&pM?5$5x9Y^S66z@__JEW&&?;1uVWF*iCF12@M_B6=g0ufuFyX(oQBo)2Bw5cpI8iuRynNdG>|nTJ7tghNEDioa{5+cC#^r2?9tPO zsU#!7RCa5?ctH#-Kk`4U521wt$QLa|0#e{e?O<|LxP>V(u#B<^8i4cDQB$kxnxIdE zBf?FJ3nrugWMvGfz+Or-rZ&8Ryf71$*tQ(R+Si;9UxgcE|D{O^vxtWyO5soOe~Cd@ z$4j>dOkO!9;z`W<0~3pUW0$i`VQekqX5IO6Yp{ zB>OPc^n~QAH>!~v)1;2rIWO$~L3?iPs3vweRIp)G5{s}VZjrDlor2$QP*$X{_G8YD zl+5gsC;2wcKkR7@6_|R8^1{l8Ld4DIR@mo|eXQ)T>!g)q1@p(m5*{YDA&1ASTA2KM zEYf=3c{|S+OY*Jv@{tclW`a>YoUd((F817E~^^1{A>su>n{fB8uG zi2<^otsudwppL1}1ue8#zCq6PSg~F@myR6yea$4#bHfh!2Yfm?ED@SYLPyhiIxNU( zmo@1(<;mP2Q)N2Mj7@jYbXT`D#rFa}dDU=kw%{k49W?eO9hu+gVc9?~ZOEcGt*W{q8J5 z49Vv%bZKc}UiI}WuJ4VIs#Ap7-d`=T8FQCb{@qaIfHw(?xcL#88`ie4@d(6}2a<2; zP)8s%BW;3HW{H@}WC+bQ`wArNqZ4O;ZU^F7@4*oH$Q3E0a6KRA?}OdkQcP^%ibUq~ zNUmGbzQUg9#oU>EQjLj65>O?2xM5N|q|KQI5r~N^{FL`F1v8SIs;D}wL*!1S5zGhh!PK5an-33O!v%BXDPN?XwlM-Jhl20xKVv2Ci!%zxO;*DPIs|FJ`dRj=iVm2O1Y@q5cc#Tb_Gn(>mH*&?E1 z>AIL%LkW54U!*J2t|I4JIpn^HHe&fVt`HHxE~HZ46h5mS$Ckca1Jo9zpe~mGy38g8 z(7HCinp!=JL|S}JaMfJKzWYBnVzt^u?yn|(kd%m!eZQc!9cF*P7Xy1RUR& zc&nFm3rvrXk7zQ7fRDd^itfD-g2^cn7mkHw!Pz%4cRn4cLXngDhMpW}a8z$E!Rzo8 z#;Y2Q>^!;xbhd)eoj=J#rc+fEQVME;gRxcy5?5E4{GCuRF+3GqXwE5Fw^9KO%)SF` ztOQ_IKV3^APaZBD&PKl5_6D!1+bI4!;c4q4)g!}RdIIx(3g{|w zd(mYT!nS6;r=&CxYBh4yXi`N1>8hjP*oJuc&*AaE|DrQMk^H!Dg~xk1{JfZ0RH6ok z8Y^d1{df%ji%_@ZXZ8g~BICDWcxd%V68eUgFEw9N-gk|8tUU z2%IlDG@8r41zC2Zi8u?I!7HifF_`}h=rCWqnfjm+>@J*y8>QdDVJcUP&v%=FAysGQ z#P?ZPP7QzGLk>VgY@p*PRSBT=53Ze6`V5o$}>7C$3H^JhAMk@3=Cp`th zkvLw#^FEJbQx0ujx@tCi{}bTVwPMyNI|97gIYDc@^tf+xbMozYWi)LQr*_NHM;8ny zpSH!)qCY*(*o$WJ;IdKuy|v0x=vNZG3nYUYc+|fjZQVJ4+%YO(oU~mLeR|QUwXWd` zF0mnD%VVLBS_edY`18jdUyW73Wn#kc!Ic=f$A1vqCq}4eW7`7%y{r1?wwe)|Cr%$d zGp~hTRalSAH4I1f4ZI?TI@M7_(Uuj?bB5@DVQdL|Uu;qRYb!&IVjg&wQkv`2r9iZk zR;wbfP8S^)=k)p+V1YOI=+|AE@WqFmCql(r?x7#B?*_h=DQKs6JiS$TFrNIZ>dC1p zH~iUY&G*mldZTM{qEu&Qv(Rn3jizahduRYCZ{2qa#Lv3!3;eN2NAm>Klq0l@(ML>E z&$a@epc>@;NE}@WzO*6bZ+<2Xjmbli*h}vCXoAEmE)5m5{o?G=Mw|iO?fuciY1bN` zW{j2{-$+3@Vjj;3R=VKdi1t2FoW6?AhlG{bJiT|a&$@j(1=qx=IGu(;=)7ieZ1y^KGihg$6g zh!Lnp;1KN?3|jKTL#L}Zf7sQcb}}@2-WSSIPmcHeA48v`&w|wl?(rz$haMKMNP6S( z_CnXQIm*^JD^Y{(8yN=lobT;Tzc~){rM*ao`XLiu{qjT6cX$q!Allzrt5Cz|TYGN4 zl2FBI_aqfAT_HzhJ`)9t+}r_$sYD}Dh1B?j&r_M;H5;_G>{eRfh924xk=0;)T?$X# zBYqHj{sL<48zZ#h#DG!|rG`8W2*kw)i~a!-c~quDc)*TW9i_Egs{Eye;OaL&+>E`> zhQ_?LD|K*8!>>Hh2&8}Hjh9K>P$iU*~-Bzfpb;=Q>@RObXOx-u_k zGp+j%^u?RJH|rgMm!s~KJUwU!DqinMy>zOfXNWvG%^7OEO_oDayQUpvNMc3btlELv zsb}9b`#wS)nv(y_&wT*;w-(-(1yQ06b`K&e%s1fczhBR;>-~hVpWS&lv=g{1o~Px= zX@j;0M=Hw7!l>IU?bXD;Oel*ludb)SK2+GIi$4d)K+9^l(W6#n1uFe*Q7}>v|7}Q)aHe zG5!U5n7S3#{s{$SgpwNtN)dqRl-$W|`W%iaP3D9+9s^OTS-wYlHIUdY}!^&5y;GXb1ue75FfL`dXSuC{W+kbEgG{8pguY@~T z{P^#NV-pj&s?@1M+Mx`cYT?8Cx7opTUH&}p-g!7)QI$eCSBH)M`*XM+;0JbpW((G8 z-T@Aaoi$c8itq~j0fy3q0Fih#(-ad494=A3-<6(uq8EmWT>Web3O|kcc37am()o?) zgVd|g@xjmg#zWV^>@V-S-}*IBqiavj~9C>x;QTBI+Jw)$l^jwzp zJi_nlQq`dL1(U}mUqR+tM5QoYSHV3Nk^kBTNo_e`$*rT|FWf}%Du1@#1+ghaD-&qi zNB3fXAJY;&j;}(lvDrmmc%ljF+;)Ux<99H1*PD{NA6K!5kGf63y%i*>B%m(^Y-9eh z)S6_D_W@V>-EvC?Zcv^7P1<3D7RG1a;iwup2h{g<8q9x@LNh9F{*<&PgwRU(w|`L< z@=4A1>HhaXY-2at`)86HqVvPbc9Pr(n-G3h<#YZdR5V1uF-?|=-S_)=X7!vi60D^B z?@6H<7Dy8{)P1Ok@rp#Kt&n#h8+Tv${>NI3Y~*B}pW%LpEnj`j*?kRODIDlx z9>m8%*rjz$IJaPup)?zzI`dnaZ|Mp0z<9Cvfa5Wy_v!gJN3L9?!QirHa|Ai;FHXKi z&Deq2INKAxn{Pl!h%%4$2CFgogOWyLw+f_G)==HSTLt4iPHb+xbPK8aG9jd5XO8ty z@Dt6R_D2v)@3PT`Muf&CBRKgSFGjKaJTLm|RpeBd-inj&34Z;u>?hpnjJW<)9pMjo zf$Y@ZsI9(Dj976g1u~suL6*;ZJ)f`S#^i1e>a~7WMtH87u>C%Kh?u>U{BKc39O?Az ziEvF6i^^A+aGK4*P(~fH9K0-BDTQN=E}|hFr`r%6*Am?Z?m6tX`BGDr zHxsl!ecnfYI1AA%$ROvGevLh~pv!JzsYQspcJ4Kh3}DHBN=^;FIl#~^hqaugxRbd; z9<4u@h)p5Hcr(RQL@RiBYGA4cTQ2zCMcpG2n00nv$0KYpWIV9&=vG3fCN>O5AQYo@QYA`3`u1_?_> zg<-(?5Z(M@Zn*gOh(IKn2D}v)TO^95he~9vr{oiqL1VU((Vf^N2;_E-CHFnR_mULF zire9kPtcSmB_Rpi`B!2X&Q}HdRj!1_g@=G*rx3ShDrcY-IcGln$PFUJu4ZvmL4eWp ztNkLH51nZ#L`-v#6Vg>ZcVj| zF`&%xvS1i@3iRG?<}c8A4(1X|tLmnD01e%F+N!d4aN6j@#82$RS0Jfn!E5&mnk(&z z^iB|?3unGcaQZW&cNH_vhDr_q{wsOMEP9`zslzdsZF>{=Wfr(ep!EkhdzRI@aT1}l zJ@SprVT)kBf`c=Eatc-z0P?L%i$H+Y%g6ReX_Z$T-J{SW_*A>xQOXIMo*R}I8 z#}RN;AQJywCW&{M3CW$#5kxD#&2)a+62~VK;`>?%QS@Q_Bq2-g100qzEB{cm!AatO z{JeKSkDmL?!#v?|8E+6b-Q*~iMim6-e{u0!5(kCQNJl3h|W|0XQ6S@x2{dt)M14N#nSgA`=p>7 z-JDEqAyN3|SOn`K=7gU(N?yK_yon}qU*UM8B8}HvYUaB@$ctY~XSGVna>eiV@Ni}w zxZ*nAqi&NEYUtj>unDG0cHHNspBh7sJf5I75N^2dgwM+Rsx*s~L9}pHJ3eaap{BU;fw3&uFTJ604AVlKIQx zS+$*X@!Z)cd-#x+N}mdPC}j0CTGJe-sHTmOXS{{`%}9~z)!oK@jEeY5I_U5VKSc+; z->{=w8uB|a76Xvm>NcHQ=oGy3E9TNt_9i%>eYJW?LK5G~>(}hPK!FBrd-^)qu7L1n zk;`mz%dmg@SvL#C61bmwPx-660xr9u5^~;{4o~4aq~ZmeK$Sb;9zod@e9skeeu4i3 zVAK4_h$ac(=BkAuM)`zjYA&Cj>Ed5Nf1>yH(ak|VvE9Qq%RXS`d`3!&T^~1JcDh^J z!G)S%NgHx|MURSdC%%!-AjiMIIS8_?UIjX|bH2q6TY#N-_&EE;OQ?A#E#p3GIm}k` zA-=C&0vNu6=QU@G;j(sqzrVo>a7ayiMBG{nqyyXxFUOTa^VK95TDd|{;TC*X{>>AZ z=AOI$t?L`e)=Y8;v}*vmUp%iU$3KDF+H+5k$^z2O&#l`}aNc>(h2%AjeNe|j+(xB21O6r2eEP@#62v>-^f2J`p=Xa%)ztE?aA0m`8Ocea{r~r_1G7+`a>R zY@-hHe&xZjR3))AB6nED&zOiEFuj#~a2wzO*8cgD3z+>CiI=}Zs7s00|jU&Pfmw{>oaS$GN3K}XZ*MEdiZs`CHFL>H8>LS{@aSl zR^ym&V?9De$R9A7QGxaFip_Mm6eExSY&a7WZD4n9&u5smeZ<_FLcOf+zedv1_Z(y` z@~}@C*@fhXX~-h><7JWlBsNR9R3{bp7Hhj~>r+Ym98vrJ@?Pn^RE#?C-v@&;!HD~I z=kLeHU0BiENkPVqE)0!v`uFU93DOfc;~~bEi8W4XTaWaoU{|qCKYQAJgqDedFI0C7 z)9oh;m@@beiB*evIQqf_dHllA?Vzv*%b$8Ek*4c_l?66DHyZUtEUn{W0u3XvImQ2m zf|Fh#8~&sM8h>h#i!4)@`3deLRTTOCnO@%5{VCTx@rrQd`VO%%$a{gE&01T_ZfnBa zE%v^|Y*#gANG~=r*oPt-VW$%3qvJ7UhOk!~)zwG^a{IdX^iRayz)zQ~F&QBik#t#F zFT&c7tdcpFE0NC>hJ-bU{#M2pL?%}6sdh~lR?)G@FEIZb$#Y~s&fz428gG~wJtgUZ zwVF&$^3~5+L9V+f}sS4QZ*t!eqU)rhdd`^XL!yb2#h@v3ufOs%~ zTp2Psrl;@mX#sfwqs;STRxYZ76xKi4_~G+}n{EMlYK{1`s-M6C-V3_tv}VBLXvJ{ zGy^l51N!=&1z>IX$nDLER z_LeSMP0v8^jwxaJ)&+E~`c&VmF)sAi)3zAa_GK8=EO=2^svThOPRTErOhS4Vk-WY~ zTR`6E&xgw>f@@ASA7v<=N3Uj8P=?Uqmq03??&hkbvyfFh$3>{ZNTT*_E zuJ^6LO0|up3JYSCI;~L9)1MyaC8@j6vWKGP4QSpLzIc=^8F~n7S>O?}s-Aa)(ABa_C=f-xqmxD4v9!V;rW^LDSX!d*k+; z@cX|$b+#ot<7AUPwWY$8==-)T6JyLA-xkWo1gWf1nVSZdq^);RxhjQykC%xkm+Y6O zrEV>BX@+31O~?$TC|Xhaqho}U)_Z4Gwz%QrRE-)ga;a#^SwO*4$&W6{JQFJ^v%yn2 z2fLjD19A1A#qah@LeT+3M7o7C1#Na43G_b~jJNMsM#o24;m5-LX9>q+P|wG3xAo#P z)Vtc+d^#c>Cpw?J{^Ya`-k|YcI%!W9no{(Sztyb-r6Or;NZJd+X$Uff&a+qJXS3(N zb-sLtE}NSM0KSXpP)iHpK#~N0QgWQlFQkuioGRe99I(WNn9nuh7ym<(35-5nOtC{< zAAinz_s9spVH2L&PH&4AFuYs%9L|MbzwRGQ-&2DAx-BhBDE0(h^xFy%NbQpy_5t zCC|x)u>1?giP`$^+4Pa&`KeN;&b(Ab-E!IXZEEdJ_X{7Z3`a`JC(43J(aG`V2&x z0n>*Y6kvrK{nK+%`)$WMd>tnA5N+vzJMZ?aKO-F=*LXsQ%&!f;SieRYEGdM#*&A|- z_c5SG*0yIc&u#ckhx9S8#BTuT((i3-Z_E+ZS)Pf~kD3FX{)c6Js)vXi8 z9%MkrQW444#CY&l@SX6-$DuG)pdzMI(jJVY5DUJ$_Z1j8aol4xXohc-b4#s%MgVax z$?$L5zQA@typ9BU3Ue3pzbhT>fo+e>oo@C@XytFe}W*Z|sxHsZDcIga=6^nO&w>*h-)wC3I(bz$44l==K z5?7$OpjjZ}O-!GV)CqdEeXeTkfvvjAMZ0v&TO$5JO)oj{zo5YjnCB1)hsSpoHNIjjW#TMZ zVhsr2>x#{~#&FD{gW~tFB?~0YUmU=yj{HPg=F+?1gj1Wfr#GINJ-V~KT!Qz}# zuxuVx@RpoIJ=S6i(-RI{*oa-k2=prd&X3I_kw4ECENZP{8ob-BzBCb z$Fb=K1NpUUlyLCDhjZElHi-3iMb?4*LX14a-sGZcIr1&eFLPSqC$y&$KVjc$X zg6Z=uF^-$=PS5Gwu+kyTSEnsQ5wg7p=Jtk--J1M5y&Y`J;2PjJ2aXuU82;3(G?soG!1 zqVnxiOm=pW73D@no&Sg-s}0$>(Beg4cc+Q_Mfo;TK&xNLMl^{%_qI{KzcG${>WiG# z>HLG}f8yT#>7ffG#HCt%62>v<^EUrJCLbVrY|eQ0KQgGu|8Gk?Rs@t=mYGmJGzXtg z1+#|NxPXMV778tUKbS}MURl~C8f-dT9_V}a8fMdyjpT&q1BEK1&W0%)pu*HB_p8Ak zUdFW&Z=Ui2#)V#^d}7&}#Stg{6~6%&MYm3Lr+MCZtXp#^v>J1W<% z7z`gy{rm4~PzUgJ6z->di z@`0xV*n4htJW1#bFRw(ghO_&D7j-AN=5iJ^5O~J+Z@mx*Bo74GTDO3(I&&hagBrkV za(*By>nDuIzaC3@90AG?^`DxONYGmEDeJM7?zAFqoJ_S@`rY7}GjZ>Z$IAO++n&f98k4gMr9xmscyW!T*tci{ugDq+MNZ z+v@^;PmXLj3ctYRM2XiIJKMq6gC?EjFQZT+f*1|XqeexZo%-VOr3%o`2B~NLDFD`U zjhue$5c=vi($UB-fHVc6-F)Li@YBYu=;jX&G^1LrYr|0hFJ1PS4iuJ0i7DugqmRw; zm7Lh_C(8!t-2i?m_A49U{(~qPPAxKAV~CS^-~k63D3o;4VQ?E)nA!;bqwau8U+`PM zD?*PpjGR8GI=>DTELo}@Mvs8D^6Mi%S}k1qf~^I~k`F3U@pAJ)8#`JmxY(9*mlkLB zUg^DZ$beF@TvRuYSH)kI{FD9`>yDC-;HS-k=79)5O~ObK4c=QoK${l9iQW*lcfCok zf=lP?;xy()s9f@?Dl)|gT#}JAS>(DCuB^6T!AEif{X}=``<8CPxE6; zBp~3!-H9$#eRa3TYgb2{|ISLGv~)MSOj|FYhsZ$h$5I(QJc0iCy^RP|Hz$T+rb7=; z<+8o`;+!0=Vm$x76w06!Gm?#0|48GXV}uF_PC7`9d}x`(8mQ5thRdntU9xzxgdAI; zkr--j(}WoN3F9dL;N8lLH_>yM)qhn>uH&vZG1Np~PG-&%iZQV$p03LB5 zzx6_y3)i{a{|}>MMA@h}>g#s%;P=wHVf1hUF2}MvxX`bHaBZ)wxLFCjFG|&~KzSeh zZn<<$p=lmm<41o)bI-xbODluo^|PQe?_hHEhdBO=dZ~22{1je)$~-4Xcm=GcTrHL` znt;CM)dN*7anzuq+e5J1FC33Q|-NBVAgYeRwuFp+M-FXMnu%0YlDgN zg(4nYr12+1cGe6iyK+XjlV|v3Zn|s8QhMb}BuBM$wkXWko}-NM!^5eX!F)NvEk9w7~uo(mP9*RdBZy}E}B z>frBWAFp;T4RF4Qi|J||VZ_9uKT^}ykx|cXrWM0!j7RqaNAYhC5T=!ns{A?!2A_y} zBz~R4NUbBA+USOmlVNd^d$1lk)$}V?Hii~lkZMc^TSVaA#R>8|?-7ci! zx*}n>_B(|5RA1SdU^y@(_ajE1kr=Q&m1(-bu!2z$rm3paOe0J|&&yB$>&GsiNwoLA z8ioYlO0%!(EX4S&&5bBsE0Bbw{FNB?Zp>LST)~H-1)=G#yUd~;j@<3LaqXb;DHdID z+f}Idq$yM3h)C({M=Y;fELdG|5)(-7JQn{QgovmA34Nh$ik&qP!XG6VAivgb+|Dh0 zh%kO^CZ*wQ#mHmg+pRP#k@DN)LS>;Zk+td3-s+fYjEmnbW#L9I;>)l!b;IKbF%F7W zSy*_4g{v3cN$viCH0zwjnUb&O+wH;4l*C(I*;nZVIWKU%NCHwt+b@TL?li zcCf$HTA;Fj6=aVO6WV6AVs8RQ2HU`i9w*7NfShnOG4s`I3za=5Ie{d7>0AYnR9y2< zdH*|NL(qH1web{;r@B(c@R|x}Ro?1v$diS}*K%va-LJz)Su1(D4+OyKf^=2-6Gk}X z#hM!-!3!GQg=`aAv|)tX-<1pFcOk7h?PXq5Js`F>`rnIHeJEP@iudAQ3-IZZqXAXr zqm%z)vRHbd4GcRb`Vg_G1G^T_`FmGxLZ;PkS%KR3!Mo4vcTV4pJ>i+cRmgr6fgV=& zL4-#U7Fl2~=&f`@@l*~-- zZ@@R+kqSd)Ul?J?YiN7(2^7)Df0cW76cmHG_i8m%_{5$qDwEL&?_AK`z)9W%KgNS} zarsY>^`Q|jNBKB7_>pmr7a0e{X7*8w?oBYFTdqjRCK{ACB>f$dsRB1-XvkMyFF_+F zTlzy9dNh8z+>W;N3q14d&9leaHPBg3S9wXg8>s2gx49A!;U!W3`VZV0(GTZSL@(K$ zL%)>7JU(MQ2~Ee|rm}#usE7xV!=qLNf09FP(h+Qh>L^m(C%Zw4@07~-K5y*-cC**X zqLrvn>kD^=zE=q1m;b2Q%3QyX;v7Qu=Z7BbDzEeN5b zha9h-Y5U?Ai57YmI@ro;E6aL@pbuAQe+5(pZ+Fuj(Yopv8!wIggo;Z)U>Qv)9 zGCYO()M-6OcC^vK?*7V2u6CT!movD_6b%fVfAq2^1Xt4C6!;VCfd0IzVsc$y3^z)< z!K9KSh&Mib@`GrfA06g>-nT+PjyJ?gk*I4s;1r+iS5t@7a4H8%Rl0R9RDg8k*ZF7b zaL)MU6NkNhVEusfiS1Gp-YXXK`nezxI{rbL{!OpK$zDZd@a;DVT(&7Lj&fcc?HbXU z{qiUr-~9bhu6@u59p<>$Dso!@B@&-|P8lhQ3&yZake4Hito z-CTO;X(fTXG)11i&A@@@4l6SGKSWVpzh7*E3q1Hr9^TI(cN))1dXwL!`VUyOv`z|` zOhD%+@!$T7ZUpk>x=a27%(x)Erl9N4I25&@cTCfm1PYOl1K$-5!wEg&dKzX5h zEOqOolJ|+9+>fzMaCkQPPh-O{6fh5Qa;IzqwIWT7NC zV-sYWnCa#1dGF5~xYe>j}NTy=6|PwuUom8~RK55=?sd_uqSk_pm1`-aNRh7%+-B<^kCPR z{a^MVCGdmUgrKNi0yeV+GStKhf{IJGSDd1Z06TBXzMrfi$aL)+3pfym+QENJHlMKr zvUJZK8=KQWGVxBvz1z=$co(Tt>9i}rC-t29rtd&SCd-84LLG1z=lnC0O&Kmejq_8T zeGS|hP9GUY2Y?U1CjL_2w1Hi9KUwT@?t=GjbR@y5l;3FTb4&;<7Km!dqqneFA+N}EnJGlm+Kn^4?l!E;=hgkl!w(e+ zd*=?ODM9zsu|9~g zv`bWSV+2Mn;lN7r^d)kGVZxyJR58-cjF^k<+aj-Htg$JrxKKeT!@A8}iRn7#3XnUesGQNVmW*-CVwU)@&OF&%Ycoyynypk zg6n=uIK(o~@QKs@2ky?9iYp6$0K6hyJz?Ljz?bwiZ(>r}!Kp^q$8VMCfEFua)cwpA z*4i$&pEmaZ#~#18CO#>_Nc{L(tFi+4Z@6=hhe!>YXo}LWr#k@0m%pR3hM&S8nECI3 z;U0ucmBn)Z$3M*ARB>0E91W0<)4g+5#sHfAG8D#b{sUQ6ZRJN@)sQ>o^^;E>U2yOo zHTlA&Y48U5ntyME5|5;B%fTwi(SWL>uT_4vU>EzhTlVxj9FG6!D&ju^if^hhA2JZ& zO}Z2^D*C7J(Op!~F0&k(j)qRi-Yy2pa;+Vz4Yg3`G#L=090RxCze+_vY(dL#HW41Z zLa57^Ul1FY0$j!ab}7juLjBtWKA)BUr|7)nsrvsoZe`^wk{#K5CWL!FhmsjmQZ&r$ zRAxqH&x#TmkzF#g>7LKAvqdP%E;D=YpWpxY{B=K%d*1i`dA^>nGI&!rOjdKD2nIL% zms4q`gZ+Y6-BG5g@a{&5-rvG3@WsE?hb*uPy1ed}pLg1VpY!U4zNZP}nsU-}I*;X1 z`T98ReGD^t`hp@ve?8$e%)2QL~&4?!J8)(F0oc=krr}$%*Ur&_prs2K2#NwH$r?}CA z;7p^<7nI~FGs&P?6*^C0(q^aTfEI@PHognD#{XL$i=<_U#gkqd9XjM>pj|(CmRhVJ z>QdU#dsN_nI`<3={cvX#fi3tEI`SSj-dYpLV6=l&|> zXj|e6x=vr|KH8zMtfTLbtPO6Vb8u{`)gPy(kYH33GekKH$9BRyMbV`Ytp0l)s(fM@gYQ>(u^jM(6Y5j~D9i zukIPjd>fTj{+*EaMH3IWRFZpI=N#&-cSqpc0Php3Ya$WejrkCuoh2Y$Z!H3Rp> zDc~aVpyvLqDv(HTF%VKX3(ts(S4eaS;fUYmeB$LEXfiBZPEeWv7Lj+Lh5S!=(cR5* zRlg045Ni0?up?et`cqOj|3A>d{Fs}C?H6o`sFHix)(O4_Bw5Z~g0QzmhkJ~M@~B9? znc{xfIvm@6)oggY2hcjwou#bBp>Ak4%j|Lz)bz5!ZKx@5OPdF8eKnh)<6}uF1tJd0 zZdtf5B$dI^g{f1$Hu>PQRY6I3?G$XkPsXF9R|$aRrecai40z`*_Eg>XEwooX=+OG{ z9@w$MKgLwuKrPEQ{aeLRE~0-faQMM1n50A3&S2pWJWNa8mdqHz^^|I6qsj)DwK36c z#+eH3JL!Zijt2n#l+wTdy>o#Pz1jD)=B|SuOq|%lISM9Uc?B84=snf;bJ~V5ZuoM4^O0{gRaZafzq5Lf^jWD>i_Al~)+KZ} zK5~@fR$w2#eoPUZawZ>X?h$}Pzk=s;P!iY`#zr;w&kC&7{8GNstpSqk^5`=Z1mJZw zxIj!|0vxOaA*rojSn(ePa`mXA-1ar?=Fy}}uxIeqwDJpX@Yx=_>lRM~rBT+P)y6}N z@V(^zP>^{QkFJO`UcmsRlFTuk_v4$KIdOP$tf*xpVHU+uNk%6RK1IbfeL)gjj zcj_d9ZHRzOL0D>A4N`LEOMq)EDV(0E(oQ)04@TeRDppzuW0d>$mfwo1gzU7|fsX%-@v+G@JyPo2crL*AeNdF~1(=oaOtRCo(X zjn^=HHtmlY$xbaMntj0f1-3qARUX6YpQ}5+`6`SQ4sbM?PM^cpbAQP^U^GW8>u=|p zL`7hM=QC9+o}(|aNp7@0A!DvheX%ZhLrM*PY`s*g$3#Q~cJJMvMJ#FG z+}2`CN21yDkig6^OlROpV4M9T#IkYo(`nUP7^yx}>DaB$n4;*@U5ld?N{o4F)_*zf zND_aBL{Et$rq<(_MM-c%>OQL_6*a^mZ$OFr>e39>FlA@ZVGx2@9&dO)_FoiIoW#=2 zs}+x_vFgS!S$;;oGX`!%9?gBen(`BsQQ~0H#p$kX4jY{NbdMs_`{?}ndY%_6)Ph;I zruAIj&e`+&-i&yLWx@S+X2UUK|`NG>WH-t91$#hJpI8OR6gt2GY%(% zw(A%%a%maq_WJEccXtyDRynI%VZsUK6IyAF5A0z_{f~DPlOssb3j9?|orVY+UAyIw z{S})P=BHVMKd|Bw@9RJRnF71Fz7KTiwh-E>n-3t}A?7{!1YPZ+21b(wKAf@waPw5J zb-~PSs75-{)OMH-xZ-~{d=^TDhZ|gNGyk$do~infLP9kJvu6q0)eG>PaZ$%%?N!ij z9O`+c!5k377p@Z5J)k`4v5>Bh*@MmVkDJBAG146FxZp_)h)J zd?>cjYxGo$5Bl(av0T!)3HrxkF)GvshV{08YLW>B5(n2hLX0axy@{H}nC4$l$l?@t znPdRWYYx3^dOixX`6}HRxvK_Gq?%I5~ z+Yq`5^n>LMoT$n1OEG2l6S&XeAIQPa?)f9Gl|Ixke(xmiZXFRUk!g87{(9k2EE|vWj6HsGs^$uAyqo!TL9!f;+YM!ZccvC4qvM|_ zHo?&r)7gcmD<1ek-=y45NB~aL)Tr=E%N4b}@rMT(6`?o3JgMIquSB_SSz!KymT2tH z_}dJW#;ErL?W-B>-Z*(#aDz`~AikzE{;ZWV4vih+?Nwye$B(fv(@@JDL#5LGYq!;K zN1HN(8dz@F;ZKa3%*2JBzx&yNxDqFve(bRlKn&)FCY zix5c;w7~r@K8c0Q+Ni-RW%3raN9f!u=CZP3JN!ZnQRLAJ4SaP)p^=f@0^L2neF+~c z!~k^c+s>VJu^}FM;BZDUH)s$Z_i!;aSaC z4O(6PgHFd^AC*T9RS)QR@vgr@E7x`C&^;H>_N{gtTE=Ua&3>~(SJTd{3i+UDODc_9 z$&rV9YJD(~>MAFikUDU4-l!Xj{&TUdlTt?sKlYV9#u)I31Io?%m1FqY-zI|-9VF<( zW-6}iYwNI5GOv4nKoHj#^59?iNrsyoC~k-Atb$CnjPKm}LvZn!Zp*Wmb&%|mk+=xL zine!_3i2Q90k+7if|1MPutv73@N-`in5XC{`#w<%97gj>9oH%F@!Oa9w@)9#Lm9cQ z#76aifPii@D~kX?Ynt|6NeS?ANmz}eEnmQtD`DDX|cbG_>|uvEWr%JqZ| z=ogp~6a5YWYm{+V@4_p1--o)T@4E$1Urd6D!;v7<*yZrBp%jR@ki15v^5I1)v*}2| zhu|ZzF87zbCE)wn5{FX;zzfUt@&=2YFn3)ddW}3CJUo6sR8`#zs6HR$4>NcMeO}yu zXuA{)g2CX_E!qUgdn+t8)8%LmJhawFcbuVYwZ4i?um)Ihg2rkE_MqJOl*4O@OhD=I znI@en7*w$SX%WO2@90j-08;VrqOIv5B<7yXHr<^6D z>pg{dURNnND=7^!=%9I$)(qy7FhcXTrW+HD9Mp0IJ%}IInD&|5Ls)=LFR4MY9E|U9 z(kb>B$C5%UB&07+93>J1DFiu&u>Qf6Uc>Ma`!S7- zfLP70D8wEwiVxp&MaqW`^e7J8F!olt0*Raewb`=Yv&oFjCQ~ss^_@b>^YJJ9-aHsd_`ITfsT$%%ol zn*+uvKe=(Od4gEK%f~7=utykKmR+d}puhw|G`dgZi6SR9-`I@nUPKIKLmt&Nv=CI= zSS+9486gUo1nWHa8zZQPo3l-K(_q_65?1+4WQb&R?}Az2S7MOgX%3IXb^=}HYs<)h zKH>>Q(u!U3eL`GSqy*D(O01fwBkKRYjBv$g?L=#12GP@6JFA;vfbjGIc^2BRM3n0{ zdayMojC>nKj~m)vM1GiBgu6+jnA-_D`&XSR$RF_$)Z4=cb3fFKov7+T&OO@3ZFj{H z;f!p}A7Vz>sW|PlqI@f)T4#8r;X2*=-QN_h$SSU9Q-J-v4e}Pw*j%h-9)ty8sq=F-b|iNEUHDVf)&A_6GLi zvVJO0m>(iY#*7I+KZ|LdH><|7IFUa#_wtVmox!wn#!IfV$RRPR-{ObJlCjBm<4kYn z`>@Xeww@Y%nMk@MKbM|WDI))~^GXln1a^P)=IWhsUHHn+>K=O3w9DLiBA70*6EUVZ zX`G<+1FPVAWMTes6IncXnq||@1Fxl&w9~JBM3Cn>gc+JNOvc`urGe)ovUqF9cw4<0 z6Knm!c6^Hp%s9PCdYcu4T?oGMN&I9eLbw^m7s(WLf;*-v(8=z18JI%5tmf7ke1 zxxa@gm`sb=Zh*6s&NqG4#*hKyntJEtT?}nz z0F?Kr!MTeYl>VF2&|ls}F){QGOjjIBS#pa3o`NwWld(B)x&0q&Ca44rvaU}Y1_xns zSl*hU6FL6ozO_rFawPnGH^}CtXaL|bX_m3q3x=tuTk4o!z6VmAoy7OS-(WCARhRV`=rYe2+6}!1H~-u> zzkAmj49@L%4L^y5)6%)g4Tr_>USh)~yHY*)U56=9ztjpa`EatG=6VDRw(CgZtYX3Q z?;hvfP8Na`M!QajNoxGRC^u*F=ykAIQTt>wo*LB_xV}80qJZ+o$7@p>Yof>HxFR(~ z+rVMw+$wT$7H+XuGe|UIknB~pNXhsLSou&eXDlIs)~0{`Ax8{8@*_uur)pJ#E+=AE(6QAvryfrlV`~{2jrK0oAA_C zK}CI7T3@Re;)XB$zxeap;^LV~;$(|9D2XyNCujIGytE=YZQvdk%3ytYxapKE`Y#nb zIiIPD^YHpFz3V%V>ReWF`AxPDuG5n?-L59V18)~Aj7FCO6~-%F{rtV$*2eGS;OK)Vnm2rxyox4gU$%!p-dksjo0;1>((`SmKV3tS{`<}k*T}r53a}C zY%QW_|NQgsAMfsf{g_8lsT4AJ`g)TIaRKyFRCw5sp*QNPB~Lop^$=Z~R&M_|Zi({_J(}N=*F~@SvIi{eS)x7@ ze3t@qEl}gl;cUh~jOfs(l9OylyjWlv9?yjV^urLdF2|xQTC?=&qhOvoZn#a6?9h1@ zPr10kaqK0_(S1E>f;-76{9WO#gSRJn@iE<^@Ym6@XiDkm#?3@A)JAke5hdf zH3A9hKbgzdw91VBY4-3YR~AJl_lCKjTAapzrQBtFM70n0cr$i5evzQ|xQh49Z5n(? zs#PWb%ssUG5n~l6sXAJ4B6T2nkPkNw*v!xTUJkaC{zuc!TRHO z@40eHVEh9Wf5JWyw0n(s!!zt?#=+BxCpKHa*r)r<+O1J&=%lnhWETZ5%1QXrYh=Mf zPI_xyT?X7?r|-n6J~BL0vM;rnBn4=XkL6U{!@2S^M9%U{)JY@ zjr`+L-&6~$K3fo=rg1O2X8RRzvKonKye|R2O@Gt}pNoe*24|hN*WAIS`j@JM%RZnw zraIfft^^Jxx7x5K=faQ-`dNC$V8EVqTJLi9B^b-r8E6kZ;K%Q@50mwi;N3tADZ&xY z?!51tSVivy)UT1NR>nSt?wQ)T7l(X7Oi*tV6HPU|*MqX0+Drj{F6lpO9IgN*7xT-u z0rs$2-(E>F(Gy6nBm^^0ya7kFGPUYoe?YZ#(nLGR9A49}ba|GPEw$qyE-OE5yPgkBz8B(cl2L?@_=P5R_T1pL$=v6(?UzCI z;nl*%87?3lyy9GJF9@}i9tLFiNP%NYwc$Hy{-B0C*o-)=1nj4A>Q``W%ut7VbQVMN`UwmVWM$<`OQ=seEsY@;MrD>aq|2*%54r~x0fQ?yq13= zie7ip>%cF}L$;6KNark!WRY~L4<&^eEqPDgIm{!!t}*MMzBrDJKYFG`>(h&vNUwew zLj)jgkEh7xulZOvH?px#+KnvrEu7`yY{UHe{s=G}`J(-nUjGQuAHu4`TCTS_btAoW zf;6IwDcHpi9z*u`9wS%U%-V+SlMo5&(uBKd6G#DXy=;?PG&UmGyAqrcj!}}Nv0Dg+ zBJ*|?PlH6Gu~SMbvk|?&u%`{JB!>w2PWPPkl0X=xd0)3lieU|YJj+jqix1UL8RsiQ)b;^UiF-vHuRk7#V|!=N<19lBND6+)Cf# zdFix7T+NZn!wwUOFId{iIR%~(Y8b38M!doa>&MP;g zHF#}{IaK+w=sHgk&JkiQ%JCI~$6qI=x=AvuDky5Y5|c%O?})icG2cXjwU~a z-{;}NqTh)u*Qujcoo5I>9Wj~9ZyB)YLV_N*AR~6QY;-8RshPOAs+QZQ)k82g6PtNo z@`LzXQ=uz(g8~t@=w~AukYVbqQOyHe!vwXgpy5Z>--*laMy9*0;{?U!S;inv5{%B% zc#%VifCLp7h^jq}L~2mM;+$x+EO=B@5jL&|CwghKr>xqLD?^X}IvoA)&Wxj{ z9?X4#`1MI)8f5c`TMCtcDRv54Eu~YVNx7JD)63K}kmS-AIfj{TXeH8j#4xnf-V4d#;nNW>@&@D%kX* zD^K&XgkMW!_itYa1HI{XtHRtRV5o-2=)E2nSid=Q^^wyls5va2h-fl^errQ1QYmh@ z`SJnX;tO{$?Df3ss^<(QMeN*_xx9kKtC6|xU!wu7e;XwCFCX2$-+PpGyUz~#k8Y#+ z_s5aNA5#fW%9fDoBGxw#Ehu2nh!}D|{1h_T2HzN8nj1&9kV>n&4Qa(q}QPBtS#Q zyW^N=4#Z{!y0tG4!hd&8QzRFWql)r&+Lg-e=$Z*3Gxx#{I1y?=bA;|&g>>V7Gk3!$t;ngKK?Zus0^qtb8#I?9PgmF~xiZFkb1=d|4gX3>LdS zcKt~#i(ynZ(c)|{Rz0MJVzjV z*8}%{=vw@Oe}KbaySLr7>7!hw)bxnyFu2Ap8Q9F%0_LINJLPxfAR=<{+y}#-aJBa3PRI|^Qu#hFuJHK7OSmQBD^kpnBArFy8G zd|F*Se+vE+!W%WBS@8s|>g`vZ+hDNAW>8HO_zEM(GwDrc z{1scGf0R`Zq}7P|Z@~Eh{MF#uDU&e(AVUYM7{xUBcJ~J-xVQx53JCTVBIO|UL_-k% zAQV2UqcXY`Pz4 z7t4hHfgKCQ-^}U$K*`9t@c02%{O#-yqc5@iI3GJ%ONV_dV4-F08hO7C5y|VLQSpp; zUuDaL#SAO%krhI|r%a9;?W(9==ZgjghxshFBV*8RwY~Ma!Zakh8nD2c<(N_5AXC081|Y?;zzepo?X<{;7!r=MHMJGS(&_4jlZD*0AV3m&|zskeWT2!-9gT(WE2 z$FRui#X)xzkO{1*91p33lhTZrT?0Qts?;Cq7VVMXy)Ucvw+pv{6~*N=^BygjFU_zJ zEME!SMbmps-HO5YFZFsxe=k5Ai?lhZ>t2vXcrx{|`5ho*7nOFGJqrk4DU+f3_W?{4 zcU=o#b%k+*2|W@&_29=9rtuMo~Rpb|)1OSz7Ozy+;B!3wh%&&Pl*v&c1V| zjGNfEwaO3tu2(^~+bS9w!G2#7Rau$AZ$ftl)}=j?@C0fXGUN!(ci)NfRAt{@eFCxFQrkq`Xf zNqWyIx>X^V;MeGRQnLoT8TMG4*H0WW5p!Saijn|-cc~5I$3581DYB>H9UGWXtLYwj znFuu9o>OL!p#b!!2NGSW>k+AoKK{ysec0Su=wPkrQSRdDlO~PR0^r-lNy;MOWz26} zbhzl(H;lpKdb@(acSNM**^BbwpV+W>nar=>lJMp^&-xSJCou^cTaUr;DdfS0lKT@U zM=@iq^w08q{Yd&dryJ!{!tizXu1!BvH}+hYZS;fZAYy&-AN{ee@0j$GO$pTeel(AU zt0ceshgBq0l6dg;Ah{cLDDP4r~>UrHn!p)1=q;oTiW5)Nwr#yiJj zN$0<;m4!!OCj8AGUi}V3_S;BDJ*=WJH)(2zbh`m;(EI#wCMt!EO)?0Em?4~=p$lOGrIfDCKeOE^;+fvbtED_x_+Z-*$?Zx zCY@eE-irj>q4k(qjzkXHhjoV212HuN`ZoiYd=U~`$4kaszDJ&69Xa&NJ4Eu?O!cAl zk-ucl=TVfU5JFjL9I-(vfs~Ebr{urZ$EM%a7nNUsiT&!nb5HV)0FoK*XC^*=4ykZ# zXH80y#U4LLTFp)?BE4>Tj5WW55RH}IAbCkC4UfV#@lsLbvBqtlrmH>}jAV0G zGM2`)au>X6-w7fX6xstAth5^}4aYlI>7D`j+F1uJM7 zfzW(W()na7VYzIxQzyBcpi_!|7chEEur+h^@?Gj7@Y$2ZF5T`X1gvQ9RyTAIv>50w zePyjD*i=8MtKxo6oE!61&E>5pewC#V{!my-T#$6MpCZGE@%v8pyc)U0*>#H~s-J1Z zq$4*8f#V~=W;OOa+pYtV#;bqQg(jUKlt@9 zWU8BRVyD?tGpB=4`-rH@W&VvYSs1l%zv)5fvq?;sJ!m14J8>jB7&Q^v6qPJXTGxqo z8PW&3I182*DXy39T}p^i32*xLv4zlc*^6|4p@Hy*vQU!wOFl8@vYTPd+9C0M!Y7k= zS6>q&j`on*!+FGmceC8xl%I%cYcJT(N(K{BHXTdTxqAp+iZ816*%}E2NvFM*mNJPh zUuQh+9BvX;-`|l)cg`h#x!jcVxVVA%(;JA~c+^W6e=7c&iMNXI?oIQ}XBQd?C$;tG zZY1;)-cRZB*m4#TkCx0feZFegPSU5Gj-exOH^HhhB}^4NyqDxF=5K-|p1Y3!{QMfD z{yBV?oQfT@Yk?o_e_HP&lzIAOltWr->nnu4){DI zNmq&4I8{J3!#=^;!oB**>}f2hYk~bvxEkWQD;9pae3lruuK!jle3sBT)>C&n;X{k<_N9vg0iuX9)#e_2z z?Qdghn1qPcZF^=*q~GJB;K{^9>~m%8^eO*BWct_!o*t`#T>T0{?wN^Ubw4yz`}P?T z>S&!y{t6CA{QYyS#fBN!-#nAQRJN)ZUH3vw7KJ48zJjGULQx!3H6Z&dC3_X~EgqT2 zo!=o00kioNU785j%Xi+jRO;C9OiU?~sD}iRXQ0RZ?qU356?2O}KVh1ioMbEmlbG4< zKgS;{k7Ck04Xf{{b`WCOho9$tL}5y?)M106IaFBKJrP)1gPry)XQ!2}L#CJyY?Wym zvGO3VBl>CrQPn&f9m&iF!5?|!x9lGg6(+1t=IJXeA~c7M@v$7jz;w*y)O;QCX!Uu> zpC$$nZS=H7Qz;!|99H={YVU{WrKS92;_yZ^iSqw2A|ZxxR-|IxrZ7Z{A<{=P>> z^klxUbj2dSxe(dGOSzaq48nhMVE~al7=L(6@gz`utsADE>Hy=>%uR6_Qy|QxS`g5E z1=`3L<*L!g0AMKxmc5P@bS+(d5iq|V7}$9 zng92v;9`~B`I!Ye;K5eOmUev=sS3YGW9ZHXxNf{8q2N)6|LiT<68X*Gl@BjUh5tM9 z#C9?oPAE(wBuWVrK92NIY_guacoPBnbIkgS5m$k+$hRw;Tijsb0U@hinFSv33{Cuc zO$vlWJBnYOSBF&lH&{GY)ZrOp^%JIS(O~T^)7Qk29JoN|JG&Uw2urS})jJ3`LDR^o z&{yhXFh9J|ME{{JplFSkPD~8}PdApNHr2!6!JA^U_FRAXnJ@GmBXt?{@$3l?5YmOG zJ3obP2&qFG;~w|sEO!w2FLvo&;1gg~^n2P-B?XXA->;{wya;qmxwRWtyV$VL z&ajK=*;~H|4>-ORin70X4J}G`R_ymLzzTXdD{dtlVEKh=!0Nw8Ao51AMJ1~@h$>_( z8MX`sV#oVwD5%FFHrpX=@@o)2NJ((as;q<@F*l;v)*`_b-6vIVG!lTV@&(d7x)NC6 zMXhF0*9eC`5mnh)nxInLt;Jlo3fRT*=`KZeHoVg>;B}gO{VCwJG<#0Qs9Z=TyztaIW4fp8mhr@NtJ}2H|)xoS70abg6v=N4|e+ z&tWx%gKD1woTb8my2yTXJA(&2%{0S{4@bi!4rY#Gl3@7Eaju!K+ynk0jXf`QED3mT z(NJ95i2=vnIJCVKJmN*hly zGf*=RD4$QP0a+e)4^9}@gDS%t66=ayAfTFedN~*(k0WoqZ#WeQ`yTGVL@XLgw7Cpa z+r&b@efG~O2_`UL#w$LBQWkXAwq7%;HV1tPX>LWjwqX2c=v&ooS1>KzaP8I$59ny; zJFa$=%W@j(t+W^l1VLkso{3~{z~%473YX^JfEl*h$>gYFnDDBR*?+SYgl;BDGmKXQ zyUQ9PHv{v*tI-cn*%gW4l##?ObGZhfnWFrxT(lCb8?=AA#QPFFRaf(BHt+-g8PL!A zt%ZPo7bN**^&9BTnhhmv;vmJ>H+dPQzVJl&>f-q*OXwUCG8cqDgzDn`*XghaKroBy zSC(54xFD)c&vb~hdRjh;{6&eMFPoV9vWX;qJZ=_;>D=k?7@rq&HRU>`rz%<_d_WPMM&W# zO8LuU5o>x$!=#k( z^j5c9_#!Eox=`F1PNxUelw75+&ai;96#_1G;pE^;l+BBSC2r{bWoP*(13#=kQ?&j1 z84Xw>55cEb$Ocki(56)7$wCQNZ*PDe;WGx{&g4P`Zi*$JdhjK_NY)% z3XLJh6=^?dhj$@viJ3LLNBxFsV)0^SdfkZMVmaT*)74lSUpnIm-i>ITR?n`V&A@mR zbJj_ZyCO7i2XoH6OhL5%`B>f<=|padrU*r%*o3Vl?Y!WzCJTkMx-?mks2f6m< z?W#*(0P^nWHJb4u5?c#?VD+vi5K%L``KWdH3Fe^8!?U;8jo_3Q!YfQ3BSA$a9#^UY zu(uI3e>`P<5zc0{Pd(hem_osCnK-o=I7o4J^ZFjhB_Fv;KSWt zPzj0XexY$~QU=Rc9ouye7e;6i_JHsjUrauKa<^<-26Ns<)r&?&k>_-0S`(c3vEv-u zX;?WwlJ{VU{dv6_c7>K^-{m7Vlofsxd|%)I#UD)gq-3FS`7sP~}Ym_1}U93?Cvs+DKYk>mMbE zXi$>obEgnqHffAHzu`m5oSi2`#v2KC*3eOKu8C+j>EammK8=vxOH(w<-$iV4O)z%) zH%%8a zr$lK)#EW2^_4!aIA&Kz5SnTamNCKhAZXiUw_9vl8;laYSp9RE5q%+#>B_vX8SI5XP zR}lqr&+ED^W)lO>>k00z zmlCUx*FE0JB_y^_7=D=~bUB7*XM z8Xyf&d@Hces>q+7S@$;Uz z^#St&VLc%F)nEh_78Cy@I7v?wQ7)5f8~oHlAUQ``P;GM5yID}tnxocFFnpOwdtLn- zQS4R2DLsuwqTqk(ya_Cg#En1Rf{*VP6N`xta)MmSiRXU(Xspr+C-?{)p7a@PCBFUO zO8MHfkf_6z&`iqHM2vamRfk>1QvVW$&Pu=3i{``}Zd&cWnUO$hCt2)I!kAJXG|hpBh4Lw6t<9L3N_7zsW*X~We_!QYS+WQ-0^aUBNy~?Uk zKn@;cS*t$LH%7d#$7%GK*kNPw|1D^>K0^KymQMKPy~Xebuiz2UXypD0`Gq@jSFo2a zD7fa{>L76@ahV-Qdlbkj`Zm_u8Zn`XJcW$pVjY54gCi?+5YF++*J~MS*novD-;&1# z#7emHlMm3uZWwHpfARZ(ybO`^(NQqM?v^8YuHRG;{)Re#VMSStnzEEE>!UeVw2(R{ z%2S1X9l6QIlYAW9*eY5Jr(3{2cFHuHtxyAIofqxN)rye7Vjsx*QX5{YUFeF}?8Bys zy^X!wW5^rLj`sVKKM~P~P76ATHCTFvo+7Oo54@QTW<6TA5 z7_*IbM2q+kvUT5fZQtj}W3P&~KXiJJlxOmqlF7YAz8U>jV60V+{QXv!;c)#YW~>^V z+j@E%+j%YWoh`2h6K1_-eoC|$iQjjdtkJ8)RO8C$`(-8(xi^AM!eYA!Pu!A}!%>bp zHf`x&p+(JxYq$Z^)CrwOLGTV?R~YM{GWqQ+|PSh;|^V@UyVncOr{0cNN{pL;U?i4c4bTldd)$shG>oE&KT^a4!0KUQKH91K!syVLTt zY=PHdm35niG~nsYs%$1xhM~7CHxv?Yfl?Mx)^g5=V5QMFLUrRIAm;r3uj8U6_$HPv zR{y{d$O&n!9`;{^{YQQq#}-|9C&4_!>xm|O5tX|0U`!ESIV`#Ez9#?|1gCovqLe^m zo?>6;X#$wb#s@By$^rL4H4V)PK0s>Ttf59v4=C&(n|-iRfU&+Yw9hY+g6(G)-+xLt z3uaF!Fns3|2JAYq|55aF00+(U){@--CU#ZRf2CK1`Y}#g$Io2_A8!?@8qL^&(Rte$ zgA1nMSJ2$4^;?FZ;0(tQV!;fA#GQTy+`SF=Z3n`I103KI$H<1j=6&c8<$v3?K>$we z2z>jd(}N8ryW5$6kpU0FXf@6|AfQL!IB%1<8o0l2VzlP^A2<`Z=(1;2jp@5Zn_U}V zfn+pH)7MY(LFcPJIsT{+bedV2{L{bzRz{>b@Wf@r#$QvbG+P+nUQee`VN!ynE!iZD zWh&6t>Qm$E4r?GpKYhR0&K(|=HqeacJ%ke4RHB!8P2sAQO5=9iQSXW7Un;$6XNY>L zjxNhu!)N60d&6!JU>+EyQZAr_7gyR;LRxs?eXl0sQn4zyK$YYrb5RYP=FL*KbHZ57sBFfc()PGBOb=*))r7{Prv}77 zl07S<^B4=$55gBhIo6`)@&+Z!fnz(Jjx#dX+a$G5*H@Jo&7D zi?bXesM#95=cPW(#vlpBE`GsYD4%lsI9H0$K6I6^aazFkb4s0YhLl`4cQ=Gk{=i)6%tlsmM{CKrp&iS{|k@)}{W+GCHe z^hLs^z58FjPDNhSaLv=akHMbtI@&#B4@OoiH_M0(*D?2*#u3{?7mRJ{cx}6H8m6*q z`s+K{b7bbt@3K5acdWYpHH$9XCfbEdWp++DB6X$Y+b0W35VgW1P18gy#%AYP-h0HG zcfK6Au1R-5+NgG}E4*^YIN}hYX=e*7{ z&oj?FGk0d5*UY`|y!XAGxi`s5U1Im6-?q256t)edeO-6_8*65utjKYt+3Lo8k&yK) zE?g&Pex*y=zR=X>GzHONzH$;%cR4^nXDrC3yofpCbfc76+TD1^3>8lr?oiz>Qwvww0c=|xe4oT{E|=~ z%~G|V?z|hv)Sjs&wCcOB4X;#NH!t`~dUz{qo5NPo3v(W;O=g6xUh18pHhNQTwyJZq zT2zRQzkQF3+N7U7XLE19n##BRSlhYEN8I`VTEfVjX zCFi@V$?eYCajCF^C3|@K$*7D4 zdCpRponC6I@Qn5T^~b{%C(2prI!hLA=gnpHt`%Lme_l4LxnAu1K#v2k`aLKiv(Jv2 zmfvaHICBfNh3{|qy1@gW;Gsi!+Us-FL&2&lF>!Zb5j7GM9_s}@m?p~Ei0lC#I~5#- zWDilX@7JXW2Ur3Xi@fz*PDNCQ&)4l-22UyWUlITBBikt9)?bgF?>7LPG2J)U3Yk+m zdrzP1uWO)IJ)LY^v!#mK^m6JCHJyi4_?{`OO&r!BZY|q&Hf%5N^6kJXiFRu0?c;Ox z3(Ba`r5nf0Uqn#Tj8Z$B?t4*xekT7JI3Enw*zRdEw=SVVo;V*}yQqS?HsiKs>Vij< z%hTV+CZ8@+Gbv%G8CU#(bRo;o+p-yih|KG-`IZX;PDv;8MxUf+B$W>9>^(x+7@doK z?q>~-$G`d_#a|6X97lHMwXy*B#_Col1xK*RrDKiet|K5qD4a{}iX(MRVEO%NAAm}>Ztl`9 zm#NPnjxumF2m4O$c|C9n{(TK|$LHr0?t)m)EjFSryn(ptVmqyraB#9}w})PQDiC>G z8t8l^6Y!<`^{etm0I#)OUO^@g!KsTcJOZNA!H-`R_N*5N&pxC%9L}+(0hDKc~4k+NXjW5yub6eh2~WUs7Z&KN?UHpWbPE>~*EYWsk~b zZ^{R^F6o~bo|6MS?q4mhD^CTUtp;qzeVF-nr9av^SbiZf6o*e{v>j-}kF(=z0Xl@9&aia9h8jm0l5Upr1ZF?vP zK4@zqG7~HHq0TvkDurN;G zMiH29uraOS4E*z_T1^2j>{u|vEoExToK6O`?$5! zn*u&ke{(fX7lYefF%PCezb-&Tc!2>0W)!sZo*0!M^w`I~n{uszn`x6cHHT};d zojVCQqm>o*{k%>ksDDu|SjGZ!b*Ch)nsdRN7rHupS!rPF%B>RiU9lkGx5C%Kqha9T z;Ox%b%ZfpQ*}Sg?cPXG1R%l^(yAZ7Au726%&Yf305_WsCT#UA0Mh+SH_h+N1$L3L1}@|2;J*BB zsbry4(5xUR*EIA59FEM{>UT2(thx{pB4U&UyfR#KtD>_(TIfdWGeIetLq+;jwspNcbkT;eJC(M5G%PVERet@q#nd7NnZd zU5!Sdm*sPQ-kV_R^1^#9!F3O)qQY}Mmk-8KqN99?W1phIc6QA;hps>9lzb4!^)s4! zfAdsa===;S^xO8LalI^R%e<|&ZH7-k#PLAW%GEI-Wo_==DNQ%1J9+x~{?F4Wp;<!3HY4)V3c0Rd4 zWn^_*do2v1B4s&Dvh>ra*Qu@BPCjK(>h|IeTWyM|aLSxl=6D>XTT&`ks+&YL9ZYTI zGs&UM9kUd#WKz_S*jKhLM=6ydRq-d*DvLS-e{rWBmrHft@tH6!DWX`iQVTl-ODX$T z0vjX$lu`}d7lmU!1GvD zHtTLpDGbe{*v=t^%93SN-SzNgb6X+u{2jeEr-Euw?-_Njk=sQ6%QI@oNqq3+vP!DquSV> z!$OLyuK99KK_Qi`WXd@$E{|FoGg#FpSV)cJj$3_?ET%-?UJw+mD5h>a$+b^BR7|l~ z@XFsmQ%=Q=6-KRhE2l1*-enygEThaj`#i5cD5VOl26mJelu%cNjYq`hR#G3TpWRfO zS4n+8`els6?iuw%(BTg5;R?!FO2R~jT}Z9gy0=ZkH-}od_6N&0H zje+Tcjgl|bi>YI=zB(Glh19pbPn0(rrc+Bbty4lxqN)1$L$j)-0w|{kJ-=TSl~A+& z8dYlV6jR2c{DR+nS(K?^!{j#0EUHueOO}Ux8kH?x9el30jQZ?ZWiv~wl&U;pr0q~y zLZsw`z1wG?xL7* zwflLL@^L$f7ZxU-MkwhPN(3~MejVyeR<}M@U2-?ThTL)^CeHH?Vk4x-`xtN-mEn4&N^pAS$qGe zb6jLd$?x4@A=+w8IhSclzxjNanmqO_@yTZ=O8moz9U=$3sFQUTmalc}!K@>89BD@G zpf}AtvGc_Ilr+##=*+UyL>&(8e2B_b5;(Bj@P<$Mb8x3kVqyq5!>D)(-gZIus- z)DBkU%NbGJTMd7XnEHdGKa~YKZzX^quQJs(T+9HP!pmJ&!hB|RZ?VA^Nq0Ek7Qd4n zxk>48YMxvZeiv*!Iqi_{rCeaKfzxi~u43@hYal{ql{ z*xGwt$_<$EvwJOi{VB=bs(v}HQt&uaX6Nxt41k`d$Psw$0ac@+|>2e}~^U#}cD9eP4m6hZL*9<2U6m&Yi6Qs*Sp4 z0~)ZM@aZ?A_ZNVa{>b@_7P+8~3W^-%Q3K~%9_ZWh#8O+gPTBRbA%gmyW7YO^uox)6 zI@%R-u>dFu^1ZqO`*rq<;qF`IVL&G3Mz6!g)8NYGm2NzWB|v!Pq2*(9O2F@I)wXTg z1z;@||L2e{Jg?Y}4!1g`f&kt-1@WAv;KR$vb;Fz`!0Ph?{)Ie{?@t{z7Z_pzC0@JL zw)VMTvxMlhOEu+S&M$ZVq`xI#^jVJF*5yUu`Vpze9l_b4@1&dCyP-4?`DWVWjh%i} zh{DkBb>>D?yl1;YrnUq1K*+55()LT#!Hu2bleYTcwMBu;kbxNxJ=^twbMyrKeROsC zjB5D%&o14CcDrqW*xPN!&%Km@N0O*1mr)A1B^8~$s22Wz&4*SN(WCc-(YTD)vGAVeC7DIhawr2^67yiqT(mP#v2A|uNp3c z3yU5}U8%SXcrS?NiL%p4zZ%-JF3RE!1O-&J-f1U{g$BCfp;70RMqdza>k zJk6sxO?Fs!^`=pZJb9Bf#hH|de$Ft*>;fuxM71sZNHHbWb;bR~NHMiYNMYgjdKM+j z-ZOQ{CW_JsQoj@K3I85t=s}m*$wG=pa)WdyD z{{sFmsh&W8ox0R}&H_rdH)m~)Rt_~!)Qs!+p(oT*Kkf|8H9?f6SXo1qln-TOnEq!C zVy*W_C^~7RlPP=>& z_4Re)il<^l)R(cHCccNf!F(%;&pi4*;M}QLQQ;03zz!2h+rED-b#hI{yXR}JQLB0E zRrkw!Q(wPpyzSM$OeNH?bPjK{2EqAGc4s&F0OzAide1A}1MT0t6kF7aC{sa$iZN~$ zWun^AeT+MoT4cD~Qe|BhRiQMYZ#^ZG>R52k>|zE*EwX&c{R;9Iu|ZJ^X}<9MHo)G#Batfqc5szfqOemVH-nlPcd${kCW|TwurqudmQM`` z^6p(BR7_3p`TFXpObNxu<@qJCqJ*lNW_|44j}mH4^}Fwrr%I?*Th+MXXI@mtu;s|I zeT5YFGPA0T={eNagxcit@f?chg5n3>IV`Fp+MiMvE2i|Pu0GJE3ZFkXoXy(vhzjI2 zy($=d6Fk?CQ@*sqA1F2lswi-u0g0j?_Fi4?2_9XSw)!rcOU?E1k~{M`jXGdDK3)RC zsHeXJ-ja~zt%3I_%>Tf%`9P2uKHW&_x_})mF(^3Q*x^)w+*fj)Z!bdB^FO-wKtYf zqlPCuFKHA~VW+s8aym;W`J<+p3MsYJ=bXlbh<%+@_Sts$j}6jkd`e>)jmb1-(3nGG z{y#FK&-$mFv1gF+%e2dsGxaj*`b@h_Tui-xF_pGYqLGpRwPR$ae@wgo_9O2fKTMoV zIa7~`muZiY8D!#S+WW8mF!le9pDAbJX5R;h0Jqd`dRc({eQ=skr}^?%=Cwe zlZk_gi|HTJUq=65$k;LdnfCrgCVmDB==hm_u>R=}W5|5m#G1TAyZdTr@9czqwUBYs6r5_GvhFjNUoxbKYYd z>g9z~gAH`95c@KDV*k0B*g0tCp^K zgx_j}vHdabCb%SFzf?$^OZmzCdU2l2tJ6{Bx$pKM^C?|`1IJ_i`4#q`B|zrY*DGY6 zow-Ejk>jj~SbzK#8)JJSnOEVbh+n?l?{N9^sdCt#-jZ-ESAQJE7|Koj8y_eAoojvo z$9dM!2J0Ul7sB;w`4TYR(vQOB5xYtJ+y4;U?L_d&DT18#1l#IJzr;?He)(M@%hE_W&s>5XZwXp|Ig9P?2$Sb| z{~TF=tbQ_XQOcy9e0slfr1zB{^#12YV;GGV4#aOdy+7@u%N1yOEiLOA61#TV-+o#@ zi`GA+<#Wx%?&1l8aI)Zd&FFn@E4_ba1d%xHlZoDt-bdSR5xMCg!BVb?*faTzDZfL<2`4YMgNyI~vS<9q($8CvwrA{^JlH_jGuTV&$I$tyhqiD2 zXPlUP$sm(QnfMu*$)hkR92XNegG_%IUci+9i%fkcUo!17<%~Tuj=^-?%y>Vc+h^Ki zWF}6=AERgdFy)N=Z+lF;3^M&^cm~sdM$eQp?J&>nzhvh5F?@=Nhmjd%%Kr-)|4bbJ zs~`Wbc8p&Jng0CipNW$hM`j!tJEk7Vm6cz!f3^U!`~&~gWjAvE^VIFCk#kC)MYjp+I;T3$=@_D(Aj z$7Nd2^n)4KZ?s)r4av(1biUa_p9@0ieL9>jS3F4UcGLcX>Gm|~eD&=pX>Ym*$+I(P zyV@GYBek9I_F21yvE5)TiFbc3u`l!@_I(=&UuktEyy_L*&yYT1fAbu% z@2(^5YP?&D{S}74z|UQvnDDL7Zp~O0dHWNi{H!S$*9;STk#*OwT+L;T>xaIGfscj_ zMy~Y0t(gs`)_{!^#aq>Fy8xB3YQ8S z{IWP#fl$CY1DAKbJdXXz-kFK@**A7zf3-qs_mQ2CMGvWeOA#({Hi&xj5-t_U!=FyY z{6Exg4jej9okpCkP=i}%3@ ze|jsgL3+ir-Mk2Umd>j|%?|k<;M|94sX^%diAMUxL@;3J+n_hSxJ1E7qS$nFsNJ!t4{<*x1tP$z=IiJ0NkVoNh3BoYD9KXX5M`8qpk>7z` zW|r0v_1*_UY6iz=dPVwah_))~IL<@w&f$4*IDH&H??=rau{^2kg7J%S8r&+`VDfG| zmR|>JW4l#a3oy>mU53kj_pHS2uiWN@`#1B#BrY$Q{tV-Zm(#Gl(VsTBrLuv%jv|?l zR`PgW^@|Q*z4tL!9G9R_xi;#j(*ctfWPiNs7EBFn;L`fy7DDN=S$N(C8W>{#htr

v~HSIEEEc47!PI&CXgCAsX>dg~P>Ac<7XiNM;0M6To>_+H=?@wE_#}A-j zpF3}P0@d5{EVT_Zzhrzp(v9l(SHMC1vH|Y5I4kGle`4N7Y`Eb)=n7vxZ#>QL=}YP7 z^*G&$_#R%Bd|zsJ$cgJ@KeQJcMVPR+vk%EnT`J@A<*A3U{JX_Y$=Q6~UGz8;ACh4o z*`^^5h~d1(^o24?mtXvv$J;lJH}iO7)!wYjr1!UA^jDG>++K+Q0rAGl_dKqCHsx6v z(SJs-IZt@v?2Y>U60~{mG4s-q12ZVcEC*N()%V+m=9wJ(tQ~8j^<*B`9@i=9z zSu)4t-#fe}d8aFMK^f+;gj%lG{rn4VH+6?Kr@ytcL;#0#L7DeBJ$M{m%Y&|tKsLZh z`IelYkvD+*+4Q6kKNUm^ak-Z%re&0;eU0!QJCPfzk%zzk%9m=H zXk*b1FFt5z3Y%fC4K)YQFhT~^KpP54X$}~>j##7yXLlTAh=&mO|2LlE9Y!^YlXqQ0uO~+#j|3YsI`5dIj8FYl$A3rP*=nK~c z{bh5pZ4LRubuW2-x_>8d?9gj83?SaLQ0L>?6Lag=ME}0GlIyQ(JCEymp4|oq5#MV} zMS<|%*JfB_Lg(hfIy}50kL$0DZ_o8ttw2}~{q&znd_38ZCipvfD%CLV&+@)w$NjX>So@6hPAzq4OL_@!-nS$=BewHrn$JFl-sFD9HvG!hIZLd^ z@_qg{sY3;Q9qZ+k?xL>XXUeoqTtEBnH8dFZCyFvq0T{Q_zo!y@UwV+2XL#~r?svw>>E^Y(On}1`Ans)%32KA@?xRM>m9XkOd7o^}(#yPp`eet3O{bSEvz7EQoG43<1 zBh+4JogjNU)%qHgf0NFB(WF0WUt}x7+!Fm3WWV2{euHUVyF6kA-_N>#!D>0_PqExQ zjxha~XC>)(I24Qv0B~;PKWay zq!&)3eZ!g8?o1sET6^IL3^|BHN-y+!5B|%ezi`3}=Sd%KZB6{8&1^QsfbLnN=1Aok zt)J4H?5umVX*9iGaUIf~#}$pAjE<-H^3K>PrsjwfXDa+h=HMJaWs-NV4~WZD+j!Xz zhWz=QF`oT_JvC>jJc6G#w;K30fIKL*sW+X6S@C^=;WyBD=QAQ5@(wN5Mh$`fo~?`P z=zaXBYkv8(u3Ff%IGxsq+gdH`PI0VjQ`Lmy@JGMuj(H|febx$nD#xk~6EtW&+pS_O zzu$1uK%09MFIBwp?MVBh8{-~Yga8Aodt9J2O5u` zA2c2OtKHQ44uN0ar!R1f0k%9l>%}!-Nx-t2Fv!<-Y|vyL^rQQ?9!B@R<(|%uQ$u{a zyy^A3r$lHQxm{q%4L^^1?Ueh;Po zHh$`d2DI;6tSX;J@u^PkwNK=y`q}Xg^nKO%=jD3z-s;Troq9IF(DXgQU4e&u7VG(- zK3y(cSlt@ynk!eXm;40(%JJ5-wt?SmcVb#5aPO)Cv&zB0S-$SEG5lSl?%0I#jaxCy ziu&bYi^}~J2VeDTY)$XK_Fow=e=GPlOBcR-0bJao?hNf?|GC`@7j5Esk_G;_1AdRT zfA&#-bxL#2q<%9r?CufT*EVqIbDW-A&2wwl(|&!$Ad|Ut&eO1dsSEYHcDKH2P(G*1 zJ9MXh)nbEA;WGF+VRwSd0MPwjsRoP(u6NOTN%?1F6(`buitTF47+dg9elPAt`~LP5 z-Xr3`^JQ%{hU8JMR)47eqmuMI$xr<~J=#+|pP{1rh0c@xS}@#<4JGIA~_$dw)w~y7)=}hCpiaqJu>3Qy_H(@W8^T)s@IGKokbN0t*8b_CAb-@P^ z*#BtMa60)huQBT|2 z6_Fjw1B) zj=GP}UXX5nz(79UI&BK$^T7{WEo``9{X6>!CKP<%EBnRM^^L-?20HNRCrmszm$yWd z$N6?94RC`P#-&HGx5@sytphP3VSi(D048?4@A++wfE4d{Rr^08Ov!$L2?+7u_6$Bh zbY6|)v!I`(tl{f`ce`VGoIm)?0xn-wg=GosSdPWA2YRRJnr+bb7lq$b*%*&&sljhJ ztT~?_l=C-p`IF9?oIYhr0R#3`b_nNJUr(*#a((lLT)w=!5Z7u?uPPuty+y5f{cJSs z&Fdr0RhX|U4t3<|wym4Qf8@`^ndm0uUmB)4&<`dE?+@l!VVVN%GfRle z3v5c8Pdr+2=wG+!Tt`up^p7LA3=T(y^!pUpyEP*#|MFKI8w-0j#VMa zvx$WK<_!VmHmGLMK6HE+n1NHJq<5PK(1=UWD~bPilOXSfUPJUz^j^~2N!!Pu3&c3J zsk^`*Cd$otAdmM4RBg~N7W2;%_st{4_YVBpI>=vBHsl8Z(BYMUPpH_ChlqS0mP7uQ z*x>VGgXY`zD31pRh-Li$HR0)FESjQ2gFewL_T zCa&vrX_!Mk5u*I4sGly8EQd=q@*UIQ_}V%;~&fX_EG?+E2I3dAx6@_hj`KwX6CtjWKd4?ySUk@90#{`2o>?aMZ*avK})q-%|r^o0q*tc$M%F7?I8lT@H zUH^eS@kAgFEp39G4a9rR?YX=dzp_XACHkW{HXB91G=+I!K_p+F9i6Dd;|9AfyO+~^ zes=e;85F0s^XQmJ`=xUE24jjt1~)ReLh+f0*^KFA|M?(qY*1nUGs`iV%C~CGx@lxr zdqgucinrYY!uk4gU8i77^k~PmTSrp5y@B?>i0)bO%bMaI_vw?lUyt9_ETQx#L+h)ax2pB(c<}g|ZJWqKSNO5VSXd~mr{t$kVfhDY&(>{s|Dk+-OrG6={K_gBpGCBNsnH8U6aPcL>)qiBqE|2@Yv17!PKvYd@A`w z@%@1p3))isziQ-NMd@!SmsiocD813}GFq=^c3O=M7u*Yw(Kwp?S$JoD8SOVX-yU|D zXro3JyxbOZy^j)I<9El8aJ2j)zc<2J*QtckPrkGD2=VW~Z(vNcfk6#MG`z2Vmj03a zJYee!1Hgm`|oOA)uzZ>8|P`Q#*LPTwgP?#o%%csr-tdSh7xI|EwL#DsA(5ZwX!hv={8 zm=pVo^V?U}a{SYS0!gfAE(>vYfQ2y6UO7(_9LB@f!o2!;gD|h9J{I^hpHe7?_q^da zE&-hIOh|vVMv$xR0vr5eQ-pbNZV5$(cwdq&#OXge3piPn zQ!A3)Pa@5W1A42-w-XT$AO5hu6=@F8qbP;aXNz(U(39jmTm&tZn^)66Xdd2z=G6t1 zKqH$UwCr}~k~Belm>(a$JeFg%|a4apxT-Vv}5 zDfV;8U#Wc^c*cmUctzp+RB;`}yEFViu*B_9)Jx@`BGO7RKdJw`7v<7=a=l0+DB$!Zcoy0Dbm<{;(Dg{1$@pO!+YmW0zGkyFs^ykqZ&b+C$7`ma0d~0i0gL;FTsBF z6><>om1r0OrtyYF{2@MfEAI$)b7|OzJ$!t?@w)i@yYL3b{+4LJtvD`Gv`hBlM1S8B z33`|~KCI>yfbo8;Fu!cb5y#~y8i=sY2{GaMlr_uebVDa0-_>KON8o+H8EQD}GguaK z+QJ5}0l?4c4>tIU83NK**Tlcae+U-mwtnez`M~pFgFh=oK;5N+{`BG0GchiX7yR+R zD#+<86S8}rcT9|LG@XKe97H_}^*j`>^MSPiF{l}wCm%PD&$F|3)kjTY9c<4Yll*Sm z5pW3Sq2l6s`t_@3^YrOGYq@^do-XJrnCDt|;qtrD=CfEGjidWd00 z!MV$f`&NYCoFe#pC!PDb2Z{dFE_*rQrO92nzg{X~JWg2|`nQ1iPcI&n5suOr?nn5! zZ7KKDO7A{;7|wsB8}oF(B8A_vetBn$F7chTyK+A=PKKcY@LV>(!0XednVi#&`g}u2 z!TA8Y0bDP(!BAe$t`Qy4A)x<2_%0|oB8#u5LfW}qCcbyq#W2i2hqn?M9e9Hl#`~Wud$|4ahIAkl``n`*pkv}3lxhPWzg>#0 zuIgC{dk-=@aJa)2-x44 zu@xN{-zS$EV}?eYKQXk3@Ype9Ua$LpjK-sc^X|>Zt|fb`%Z%GleC}UAKbGRtc= zCiJ@K$J@`Loe8hsM!O;rIN|%LkatfA>(VsQlkvTWn^q~|jJ)%Ly!~;Ec(|9rz6ety z&MRFQ%-6@>awG2Nm^;Gn%N}u_!~LDo@Fj0&pJqdH$xc*^8Ta#hL@Y)E)Z33^yuYt8 zILynd`d$+c9NtrmzGp;!UVAe;jpFgbUOq9T@6y65pU`)WWe{Pk`O+jp@76;QuwlJY zW@AeDZDI~@hkKvT@^UV$sgEZTao@>muD7#2{jeL(g{k8B4sfrUF4r^psm1%F|41c< zQalF-u{;94-bph&*3H!l-p?H0-@yom^>bZw?)Qs$;eO<#Ip?^Y*i-F!{^jS7ji>Yn zTH|LRfQdCnxPMI>E#!6&N2l`jLeNonZhzF(cf1}G*DHDYPV!gWPo>QW{`^^7eZlRw z-09EzaSOwR!Z@;qW)OULr6$DB?Q?|t4jKd{bAFOm0mos%m$)5+PA56;=_9Qs(vpBFJceF)yfp2tI@b}|r6c@BDT{{Wf zq%Y(%3#)O`4^}tfxULfgf_Q&N!xV6pc)mSO70HmU$5EQdux>hsZU=m9DU6fZJ!wM2 z{z?X_6M7>@3i2Uyg>i797+*FX4>jniT^90>_<_e4`iC6_ez}!^cBh5>mb4ORdk?`+ z{&Vk0Z;~O%f6_1v`kXlLnyLwQ*+fC!8c!F=lf`($3Qr;Bw*{xA3B!B^{kvk^9#6wG z_|wICv-fF1UQ5}-P9+a4uup{6Bt3VrTsyIfCHY#a1|Tk%;__tlHlp{E8R*ZzC`RZ) z#ReV`5!7jbuB_kfs=R;82=U)DgMR|jZr2J~=I&WjD2 z7Z-BQ21@aGp_pHch>{)ZUF3%pPfBtOj+`&q;l+lYMDyx^{eR~t$t9HROZ0z2-rWDN zFX?eN{=v7sGUC|dJ=kaJIcuDz5!UZ&XY_vI9?S3%tGs>T&!0`xKN{iuvuRhERfjVQ zW-@MF|HkFjxDWYIad=}q*E?3IZ^n7*0bhbsy>WkIi{Gc$D}UCoYd7ylPQv$vE(h0J zJ0GcLqt_TN3C20tdCA(AkCLz-)9}cys=d{$vg^|HbqcJ%pPV?k&#M~it-N*t2XPM7 z<%FT9JNjit_4=eD+!uAQdP1HLeotllfJB1@u;b-6W=S{n?;9R}AKk)xf3K9Eb4R~t zL1D$}R`Lq$b7guqD#ddad+C@v?#+Ifb2hvddYb|)&+i}liRrdnm@zh@g5|o;Hq^30 ze{VRaG|C41eK#MboEVIFAnMn=onsdrUuL)p}bvp5(0y5yl* zK@9GFySTgmtYziQ>~h0`ju$J~z`Dd$4Nq6GUYo|(HO1E8;=Xk=(QKjr| z$En8$v@d0QU+WF*kYB;7Q-*0J7L~K?@0+&g;+_rLT<_rb-%8P+pEoTTS;{ho1x!Ag z_lX5w=;e7Nw~UpmS)Dh(EN7dwLu{YxmNC2eue#PBR?5<=)f+0}i&**dnEg~aD_Cqs$o9?Jr7W+{{?{`#OPS@wbDpDzma@xQN`=y~j9p&0dr3%T8JnbG zm(Xr(Df_--gPpBYDYL!1vyWYuQr0`z$8K|73G2O1$LH&d5;lCOXVwNU9=ySQC1*WioSx!$5Y18&V>;mX zX)c%KI>c9(u}-E(Cww|s#x{@s7WD2{DbvmO8Tn~;Da)yunD-v-*XyHKdZMg^C6^yO zRSGOWnt8UUyo7apf9_kc0pz1fPi(_|?9YPtE_6#OWll!Na`N}0JbshgJlKGCjTv#^ zNS>|ra%6~c8=4ye^I@JO~1cV>y2v((~LBj6*r}X zZECyqa=UJ2Z2XL(2PG_XL&3Nh^v`6&_H_|CB}}!g!Ls#V%9(%a*Z~_Bm9wwr>l8Y_<;?Ar#^BL4 zxc7GNus5&1${9PqBmBvoG8V!=3Q6D8m+NtQ=%hh+S&#& znR80nl@y(2)|X3J@{2FNj>F5?{bha6>SUI&W6>=0V?`NLnAbm@7K;0KK8~8(<7gR+ z8$DdV+37NtUFdOuIV(Nd zq~M{3oCViht=m*z&L)mKz4^@3GIr>C)ca-Y%h+ruhdKU%W$av5_^2G*J6M%4?D-R8 z{9eM?n#H990N2H!q8sF+Jr>=kgf&9WObvemQ2XA^eU0d*9k^ zRvCMI*SY)jCuMBnM)%_u&T{sr#ii3vC&*dVgiW1V{w`xSar^5nQ-wd<8`t*Nl;ig@ zHLq;5m9zP)JL~qH1iK9*U#v?8*0#Hm94Tk!t@j?P>@H_EnRRoDb>-}u@3-q;jpS_U zuAh2A!DXy*(nVEMw3phrqq(8`%hPve6xb( ztn#=+r%OlVteg)}g|uV529E;KpQww!Hq2{>xFpq%Y0%Kv`*cR4e@W!mGnZv|TsrgSwrQNeC+ z9Irn+wlN?(yqtN4ym{OEeL1r#`Z2qDR0Texjz6H-S;4x=R5sWdm9v#E@TEBB zDcwIt!MiV&vm1@F20v+6!3J3sv%s*oX5oM3?B!P1fs^N#vp!?` zXsY7(GWuxkTdv)$g58VL4&9hs!3-=`9^dn>f~^ldR@)1|XHog&Ne|in&D(&T72}c8dp{ z|MML2hTGytd*@WLb;lMCHZ7=RMO8cWK5A95q_|7!)zd538MX93{;+#Kc+YD*_b8OAdf8PoBc0V_v}af2 zJ-3DJ&1~F%>$4`L3ir`DskyamExG;@$_t{_f3C z4`)l4C)&=%{$Q6{n{!uj?(3s`O}}jHleS&^cTpks5nGwvdN{3``3`ZkoM~Ref}TH5 ztTU=%BZB-_R`#f2iBT&i6z!{KH|)=kYnffmKFr*%=vh_G99uQN`BJrp9ksYVdvezr z_AN9m_Tj8*wmQAV^69G(m$%A&B0pBmR%P#<=UsxheC*ZuBfqP0PwLS-Thyyr#WlT4 z=d7^~7}cn%@BC`EZqj()E^*bYMdzEUmJh1g+>8s&G*Az|56%xXDaO5Y4Yr;M(5PnP zcO3rN%A*?Vp6&MY7F08bgA?}0wX9)(lU-Lu`PVSl1-p+v&`{vJ(!k5xS}54+&)YW0 zztrF!Am5oeC|CR9m{aM4YFM&T>#@^`8um23SE~>c11i_YFLM{t6A9m z8n)gvNjopS2InXbCY^g-!){&pYWZYoH9OqVDk(Vu_nrj4n6)pzn!WOS6WLRvhV8qV zk^0cBhMDc!ur;y1f*r}f;bS`t_wTtiy?FnKf{mE5d*w@fblcoK1;3c2U=0dREgdsd z!7lemzVHZo-Odj$K0jW;_BhNquyKikRR}?*FeW{c0UDMTHno1eX@d$ zycN4RWfJa%(Q=Y499YB7=jiIV&aGjM;`2=JoU36;ADqtZLVYY4WH;#e@fx6kkT zHhq%G6h#$i^%fHqs2>}{bBcAq9sNGkD+*RH$IquLLKY~PpMQ7XfQbsWIbfy7)w4D1 z@PsWI3$kjMweGC1LI&VjvZN;YE53rDw^ z3a0+`(;dr!Xn&hOw|`Glut4*D&eM`n-t!kbRi(jhq~q>Ys!F!>et3a;Jtg~e)i<+o zmV&MNZSNIrtYmg^;|#rAm29$YWUURxrLmF2u54&t&3;dsd1+4xzH<+rDs#d*_-&QC z<%N#e&#-KkxTArBndbD~9HOsa6^GidO8j2KYNut?8;th;p&9hu3(rOL&UZJjz|SW$ zXA~`Jp=8|(-M^@LDcSt!Crhm|m8_YsSKjShC5zANA60l!!Bpyp*M7XLU|J>3T1Vb$IRb&vh-eQSZg&?F~$8S=gc6E%Eo1Y*P;##{kP3cBIYj zk#>gYUs}02o;Q`Odd1UUdTO=ov{v`;{uxR(;Nq~>pYAAeUfj)L%ts~Lan2}h+(9L~ zxvzizowZ7)s<}GjZ<3PjaxYMsb_LJVD$_0{cNOeK@%9yyTPj)X3**$f?Mk*L`-jZo zsFHPD8NSZqvx03ry=cXt)=IW*i}Rk521=H9V{QM|849-Zck^Zq8Y)@qMzIMm-YeO- zHtoh5^{!=qB93Z=rzu%ZRzi=e4+?gE{%dP9C-euS2Qy-xDA~+Te>zV83_CVspUBK= z*{sinT`qR1WyMxYGhXP|vUj<4My+E|Z*{HwH^nJgf}*9tGx$^gYCXlZ>q^%5wEwH3 zmr6EAz05`Jw32CLbSk=>k9##Ys~+(#Ks%WSbPhhHWcGeH{q*-JS=-Pz#`6^l*0PhT zPP(O%)!p2=-Cz*xIHcCUd0fdlH%%HFAXlD#<-?Z=_>#Omcoom0U`NH)zxKDpa?w7)9 zwj{0XVi)-H!E))(B8^&>>DqDrsX?_&-SFq#X{%~kljw0{{C3u|{oevZ_e3jMY2W-E zajTWA=w4y!sCi1Z(=1?TXFnzLPxzB9pQ>c$eYDNiy-~6uwT2_(8q~6}ZUd4(K0~|5 z1`jhFu4HEZ#{F-YDOsr6vxKg?UvPeX@1xosIRCaUYs|}C7>|d}Eiu2ZWCm>>f9;L* zi)KD@{!tA-llrvng>gN?$<*ooWhHZ~YF|&iZ7r+w(7m>+NXZiQ=Jsl{rk1szW->~5 zLoF+JoPW^$hms90`lMd|_8_0Bc+O14k7$*;gf$%4&3 z4b)MsWkxOL{cdHp$275fa#F#1->W(8x*GG~`T(nBd|%T<1+Pc&7yMY*adZ*j|Nh%h zML1beuSq@aWm6Z;nL2Im%*Ec_O8Is#wCbs-3rClQjZpkw)UPKnVgyn}!Um9&M9+e$ z2=Dq`RP3}>?EVTHzxeSb4KA-=zdkphA=+zDFKeG*@$Ieu>m2^0FIwR?8@SBWQL*6S z2HX;C&7V4Nrb<&3k~Y`{3o0thuq{1;>;1p|Pkqr}6%}FU_P_oWa{BMq|0I8;dX?--<&yG~^d(x#ua9U~;!Adhi+ss{DZON0qO16SWNewJ zZz|#(5d%f}8JBS;Sew-BP0lXq)>=f^aGPY7or^OpW#-{L&Cu8Lrlt9MTamQrLj90Xbd5Gm}%L^uB zD!d|O%!qdg89UlZNVi7J=W9cOUj38`AY;2leJ4>rucaWrx=O$+hUAEh4PPqI8JYq% zTq5A3DT1Ac&8er#7;_c$vmyk(mX$!?>nzA4^QoXR)}S3ZE@Mp>3G(`PsNg8q5rLjD zlb$pgdmlnQ4ej?vkXO$W!;cOu&WR z1^>Dn7Vv2&svsF#)pZQVHI3hKJTSHr3NqHyFp$#??)~Pp|C3f|2^rgZjVf5i`fCdL z74ny{TyOP=JrKxP>v2Lp)vw&S{7sP_N2jtAT(8^K!Dvw#^NSShy|bmBBV&Q} zJve$F^g+R7?3#H9xA!D$DCb8`_2Z}!az?-+Rcq3-IrtEU&>wD=aX)Y9jzd?LvF+{U z==w5tE>j0ROU6w5jK4=1)B8CZM8+-^1#&-{ng#N7<6XvayLFcKgGl~Yy%0S`#&k~0 z(4aE*&_|E!|6XM6O7xc;x7LI|4_cvT$(Y_-b)N71+K;@P3qIMQV6Zd(0V-U^it4$d zr^(pM6M5Y4sb7+Ky6=~-ZzKMdyVJK2Hq_79Wd|H$Rx-C6aO{N2eBv+u`QZ`qk0gam zw*jW8?B{kJi`R0$6~Bk@`ZDbv#Od&nCcK>QUT0WR`pBRRbRZdXJ9mZqw=m0}*Yjq} z1`fpkHMks4mW&0Jd>cThtGVn=m{RP~gAudVW|7E{Wz2Fa<6~OV)P(j~gcP00C*{`|W53{AhbNDCq9Z&aW zRVddFc$>t_k(cJr+hgU(UR?jt)zw_CBTwRf#h3k#p?uyC*^ePlhI`@bIukyvsOd%M zb9xfj@9_xgpbK4u=Wf8brfKLg4_3`u*s)%~3qF#-t$A>e> z+u-RSy`Jdhgf>(xAoUu;jw0UNE%}Q)KIzRC>o44y{)2I^rND2~R={+O zKE$6{C)i0L5;SK6JBl;g~j(Dg!ZW7D&M#Nzvp9A!Hv4FN> zIS+~DIxgyO7WG?+7%cV=U1|oTn<4V0xFkp{FRy0EISJ(E{((}yyt=^W-3Q3c{R5?P z^DqMZf5(IW)~DHt{F3TT%3rECUOdQ0h~;d;4ak_pm*OH`Oz25`Ufh4slK)bqc3@vhFV!zaAygky{*paOU&>dq zE2WppA<>fFVE&)~TDM7ZsT`7@YX8!c(o5?N1y6u@lP8d|HKM+;h_giu7xn&%;}oAp zP@Y+$TwTOhBG&STkg;%)))jGsh(kqtj=aE_S4CRVrznl;YXvWujJ@Imhm6szM|?iK z0tblWS%#;;uZb4$xHxX;6A3*t(Vjkk5M=Dm5P`20?MdTtbKYPw*1<}U_tO+mhd)R% zmM+Tg@&{MOri*^%?-BGuy#?%}C!niHYuzFTWb7_qKp;+AL=}$taIT>DKrBaiV}W0^ zl^lhhC1ogM^VNm)6P{Cr$XJ3dRh*0^^%v&V)9OOHHhTnlZwhB9y%WM6ppAlhoQ%y| zBFt-JME$t^0zF`AJ1&1&O(Tzt9oj|>Eo0`Y)I$+p^`IUuV~KY>IWE^xavat~i{ty9 z!#NJ=O+7)zKIf`Z6clg+C*onu;$W75Pl)F|f3@&GPx zHfkZ~s~!8s>0_Egxzvm2!eJS!O>p7%$7;&CeCfPJT>t*OnH+m7lTiS~k=lto|C%|} zA!JP5B!J_zW$ihCXJ``)IWpEhp)CRxtS( zL-FXI-Q9V)ABEU)xl5!oA{ZI_X8##IPsZF`Od<&PemXUj(E33b_cLe581!5jOT9Y< zD@GanWcH*Tp>4mw`^2x>@~Z>cH%jO?#2#ojZ9+Gq$K=m$VGdNWoYIo?2aR4ILi~Q) zZ9Y=Eo8zWA6F>O<#TFFbANHzp>Iz(Jw!4Vrb@iOl;D{G=&SC+B`fQz9O8N^-nl0}E z46c1KhwQz$x#caPeS)iv15kBgGKOv$b6s{tyA$x^@0iyl|JiwLo1VaeE6)8p0(X|R zim?FNJ8yJW0d`l>Jv0os`~LB9ZGru~4~5rsL;n3P-QEOx_29#5iPc%3=d=;HjHN%}GDTY)m+nH*|R)`wl?+8@msX-75jt`8wummo>a! zYT0+d11@9HbC2@=YSiuISF)c~aCaQ>S>}As_wG5E_lMWrzi|ESE5;2YdFP4e%Sr!- z_fg)z>UFQggCJwe8$3b8i}k4Lx>WMB>zjvoU{SyC3h+R|ZgK^;)4Sp8#iX~)z0Gflhsd@#NqmVO*Wa15B(VjZkdJgAIjoo2Ao4f#>`a zMWiz3=}r*?##b^AT#yF<7WkqXfX+_Yyx#U6FW~vN3mL)reR5C@ko(W1$OZF819Lw9 zlzn@Ij1cc0Tg&y;ibA-2cEbctH(4jxU4H{?=q;x072pc=e!|hT90iuB2y~9fSHY-8 z{4mrSVN*WQBYluiKG^~x-4`0hA&+Y$;H3rvu0AFBy?7?7AM(kg$PmVxC}A9L94(~x z>VRPu{31i4K0gc+>~G#K*y+|wnBN|%3A8;WgT9i?03$^Is;Rm`w-j*&H52HSqMj7z ztQGZFj}qiBF)EQ>Z<_9aCSv-VV!EEs1ix*0z$0T7g9W{}cuGlsE4c^k=Pr~hvx`u! zu9F4+1S$^X%RdYJTcTZ_4fuT82U0I0y%r*J_d!!@5?`XxIXOL0#HM0>>=kjM$d~ML zHqsB`0Wabev3wIn{R~l`W@XA}ZYu%fsGEZRCe|0PCeYG4imQQ^{Nie$C6w}~-bZ#Y z_;BRK2hB;KM7xV}DK3}f67p(l`XHC|q;g7p$(~d{Qoa&x#1mqlQ$&gHD$+FS zkw2e!!vAUq$v>&SbwxdAQO`o8dDx2dtwnmNi08%rF)yZV3GQ)dF1+LluH?Oa;>p@PIgOjN%OU{;)vzH|dM6#9J!svsGAG+CG*Ms24S#rUo#%vW)@ z+i+Sha~#L=5#Kqs+%=P9S8sZP5x;g6>^0xLh|`}~1v0|C^+edO^t2K5gU2D90N;Dv zP&kBff9GgUk9VaB0{i{JsvKv>BU}RA>hec!XVS=B9D_rfaen{p^Ef6|U+3xjv@nGO zSl0xlq2My6^?b0vKS)o!jLAC+`=U*EhoYjfewdbyu8DZGM+KL6%39Cyqkb5-;}Nvg zjO6vpzKkFYGx@^lQ$re|CtyFZTNw&2V<*?0=JtXkREvl{H*5e#cpUU%B({kkV@YwBcynOekO)@1tpT$Ej5Vo`RL{CTm+N(8$ zaFxbPT|&q3kOPDZYZ8W0JaX8ua52S?{ocIrr8uf>mli6-505^OOSJn?hgPkDQ`B9} zi9h4h9uMND#-*uIx>iHRbtl?&QA%$!pviVEEuzzQ`^_f(_xi_DD6W0@VeJlzYm<}* zBV2%)H}>_T^gAPajU%~g2e-SVAA0Y&(h>Oem3Az}r@pC;7gF5rYjH4&;#c-6gzN3z zI_RVU=oO_2-@YR*zd5#HP%F~Qxso#$Xf`?7?hE(>?c$^Qg7$B}J948v>VLuHTNH-cmRM+^UsM<#p8~WxJNCB>e7oz@ZXE}Pjy--X3VfXr#brBzH*Pgq zIs^QVV|!8^`idfeQf?%D)*(9qoz-WpL(Y&_8$P|p87NI5cngt7OGOZ z1>2g|Is-2T?#GK68S|QuhJgriVy4|1!k^O$H3|JQz7Hkbr=DI&^_}NCmOrnh*2WmP zQD1K_^&|W-bRA|28Oxb6<30I1vr#n$Vyqhc;r6v_nxbx z8CVf^?zu(@_?S2F04J-+O#PtvKERg zQI}LgRJ1E)E1{x=NTrZuPbgYQq(Y&nv=F65+pn^QvgQq0iU@trncMgN^So!~+?jLd z&Ybhinfc}UnU!R3P>c0hdT#6oziVXI=8o~8Bq$et!~Dyuho#KF+?@28`OPmUoteM8 z=_Lv(f%RAw&HPMBcp9s(+&`9K$dfG$T}^7iSi$e+B{Kgw6}wN8$9oj9cGg(({(H(J zy+A5o>${A-Ux6^phPj1yf_7>P}Tg>ceOXTg&3W2*td9NzW0D3awkM;J$gV_zBO!>ldwN^`8~~v3{&eH!}I#hYqHfUn|GP zueZRBwcqoV4yqftr3a9v0gi}4F}0rn5tz&f6yi`HPuWb(qWn}T6=0v3!|Pwqd=NSp`G9({whS|Vp zwRQ}PwTWmT{P`dIG!7@Z-Fm=mF%bBmyr}cR&dO;CC_uSSiBe1k4(e6Q~(r zCv^vW*Y})GE-!~$@t8i2$BMpjp;=4%Wud&CrzxEW+1!>duUFym%6uLd^!4|8DL+4U z_VKM409T(#H+av$uxTi75gy1?|riSWaU0&-9eAN25=}1EAapOBKEl; z%k=5PX|Q^o1w3lf@T19c7FjPGmj|NBTLqMTL*>HS|nug{LbedYh}*R)Tz?(46& z?|bL>y~qFe(RO`ub>I9s=EAq%zpwx3zIFoo+6nG!=Q1rn*fF(FUfE~I|Ih0p`{vCE zT5ixY>XY63`f2au@g>Yq+)w$#x98H=zt{*~F7Nw3A8C1^o%C(|yjx7m9r8J3w+K~I zdHI%Y zzkC=D{T0OO^)jPi2>gFn9FsLnct8L1HDw%-7nFPj192{*R|SKRk10Hc0l@k`rHg@u z-&xj(7s5S`b*EW8k(o3Y9U(5Zt!MSKpUAOxZrMLzdOI=?<4fZEuT?Z5j2=1;GX`Jp1cPpnY-1R>Wn2{Qw{ zyc=m=;8WWG7T4QjorjPtG$CdI#pCC)kv1e7ebU8@gCC9E$m+i}k7DJeyS_+L9(2$2 zg)1p;=Ltq)BhtXN{C9};YwtRwgm}Y}I}fzbUCyA3c0$Gx4E{Z&9Tj@S@a`ImA!;`%ZpBd@~^byD#yvjWRl8O2NPC%vW2= zLQdM9bc*HF}Uibn_Doud`bolJS?9FD>lX-X-p2DHpT)D;2aiHL9vc;--LG z?2}>AT#5W(+08kh#^JlKow4$GgMeF>&~rZD9rteEmpt~xcrM>95|eh4$JiW!yGF4v2Oz`H6NXk8ucVfnD=rRkU}Z{`!Fot8J)PUzjh4* zvn)4AiS{=OWDDc;p|AgWirZD_cOCOAp!GAlNlv{6II3D*ZUFSwmdGefMZL{oktv&@ zZ?`nrh1NxQ`L78zPFRP}mpD{ne1@CZ{!qYse4M|s-Wm3&?w$R$6?*os9dMBg_E}qO zq5ab%53MJ3Zlb@TdVRI(^M{?(}pz*XmuDt)eitHHiQU5)y-|;~|Oh}Hf9)$!8 z;>(N16Jo%NCx`B%b-epY{$l!WpH2*yrTRr{9hZ=QkPYNQ$m3i zwn2~jYu@aFhzY*3#dOkAd`HJ&PvQz7`&l{|(*8-|L+cAwVB(6*!L)C+Kexb)?C@%f zVSZ>){2Jyb&;EVK{9FGoXXa6R`8M01k)D}kEFwJST|)&THNJz8F9ICe8@HT2_g{;w zHrd-CH1aIzOWpCYq7@>8N>wn$Xr`y^i|rg7XDyWNAHZ)hv$<4**CzfVWJl*J4EbYX_W z`j@fzGtf?m#hZ`!16cWwnf+P$l-%hoo=h|fWb%p|s?5#}6_zaCxX!O)_4_PzSUg$w z{Wj}w)wtPU`k2pG^m@szIJHtX4(k6ZSUa`GuR$bm4pp+Of$V%ae(YM3z01>?U*97& z8-W@3i9h~RCERs?7_*B@!LUJgtHWmiZY~A@fA7IC0^^R3VeP;5kYO^%GRWvhbqtf& z1rwpd{16A|#FM7$>O@GqV(44QR? z$(nCwNmKdY4Sy#Pp3WK0;Afl^B8j|UA+KL- zfnk7r?mIu8N2+YtdkR zKBlkyB@GwkJ$>&hbC{POv5gwWeLgQg7{cTI1|D;K`R@|u&dVpk z+NhnwG%bL$kMlS;ozD-6J-=*G?s`@RX+7gBvugA}u4W>VuED))XJ5<|TG?DoRR zB%l7M`JMCz{#=NyHrDU%RuS^Yn_AwqECSkH`?ZwC+2%n=l|Wz2?jq^GKCsD{%DqhO zH&GmVs_u7>`d<){!1~QKl*537?};ZP$3Xn=`ZD6RH+mn2kly>u8JOYV$3m~$==m*z z8{aAaYSQiW*AKYl!;P(mz@s1abBRaDygGZ7o|{_Qw%8N6-JttR5aPU^dCyVe1(%Yg zROnuh^kqTuQeeB?2rm_&`p;)Zb>LM(f-^PpkY{b_F{gOBC%sUI`nTSFezz!a^pCy1 zdB92?o1Ff@ou}6|SOcR(zc&&8*lYJIZ#8g;yi4p$@SP18&j=cdYbr|>z8so7%`Y6hb-}>G2^wL`%9%$!h(v4xm!W%e;AoZ3-=wDV#ZYJ?WkDRr! z)!;KdEh%P$4KQBZKj$&v)jgh#i zH*KcMG3;+*UKPFB4m)4WIv_L%b{m?_2!4Y1N@$-g>Xlp1xyKpyzja2yt&rP#q|pvM zdgNEXAsEjK|M{oMYQUZ|J`>-rtma}0a-IylRm+K1I%P>og8wZFUhWi$ebbvbbI)Oz zFOvCjHYe_LFSGN-kNQ+{_C?~4{x}G@!2?zQ{c8cwQ&tolLBA>Kk-wG!H%^p`sK$5o z?!T~u_~VZECb1g8-lhf|pdnv3Hbded^w!L6O&J8VQb~<8KzYOM9dn2WpHs@ypm{#& z^T4-TG5$AZhMEfS{;l8K1gD{|_@HuSFXZ&I?+%=W-qaceqZwZX+=Ff4Z5f?V#JISk0o&58=fNLIed`_J);)wA^EjNsF+3NQP z$725$v@QD(@pe5CBepKh{5nHueGg23vWC{((u}NDTFr>kjWc6a;zGg!My}fOqyruyePoH`6<5TsE!0o!X9h zD)_I<#0UEQL~YaQd`HQ0&kEXC%PD4l+Y9;Xnp;}Bqrig;eNIb2HW{!aV=44MTdudY zhu-oW2l3M=&ukrNM(aA|`jZT@*YNX4mZvxK4znZKpXeFz(dien$S)P$S@4GB1HR`# z7%;9ElE5Tz4`pCD7zX^@k54biKj|eOSi$^M=a8>do+>T!HNy%8mW2YzRkuOkwfJZS_AEXB?mJWN{}g z)1Aqc{gZ`Aulws;7FQDI39<4yCL>upvX3pmv=C4BY+X<9nens!2EEt5un2D|cahB+ zM7V8K5&|^teM-NJB)#{qV^7ljNH0}pcIzK?8%Xu`KC=}G4~{5d<6RsO%1}WbX)BaR z9Y(kVJ{Bc{hjp_(gV|HM4&e&2YrZkVacf31tb00_Vb9kv7H^lhA7*x^uH<=Z`c5Kr zm_N7q^NsS9Usfb*e?_+CTaa+e*lqPlyO&z4?p*qk^7zBipYW959vXJ@kCS z+AH16pNF{BAZ$a=o`wxLIRyaxBEqB75FW!?c^=}D&C8?n(GB#j9^vJ}yS&_Q<4{(9 zCWi8?*Dp^!`j_b_?jxw=cQ4i0{XD z2yf@~OT6A&G6#B3<#-gb=k1C$)KgMhF^Jr`t|9+1*^6f55ri~WPf$!0af|n-ocCU=& zvFoY~D_8w`ndwzMiTADiWgk2ZctLjJNYax^ zn6PFCuwMI+mOap`HU}RP?;kR85ydyVN1xj*fN6F8PRIZcNe4KIBEB{ojk-M#@@|hU ziNk-92{s2t2PQm!Xb&CqYcOA296d zXf?`HS}E?`90Xn`9Johz|8SfuTWG90i}MQv7++xBrW?$uAXw0><^}fx8M$Wp>qEyK>ZtM{@60hY-h0_jaRits#UNrUpd-XCG zI&AmF9r=0Oz|P-ggDUTFUH>#cr9Lj__S|0`W-f~L8<2cX9lUbQwn<4VIjp-+x6_Vb z{``o%zF`CA!H?t#TS98UOB#O9Sou@HNn8~qGZ={F24|PTHevkNZar-ABt>@!cC1XS&A8C45 z@7$<*74lmfHFKX*Nu?L@}%@#e0hihrmvAv9O-oX!k-< zznS&e-+h(P-h2S(7_SOFACg~t>wIZs6Y#!js}T90=}+>lY5&po?=WsWV1GL#{5Sba zK||j1L%=uJWwf1vD~>*Bp>u-CqB=6UHv3Im&)@Ww^+5n&gP&vrA){=X$|}694qgi*Eu`L(^?j~lE3}F^|YrP{Lh^G zcRjCQ+@fB0@2`iRKyFhe`T2YKI&W!we8-GcBtL$n``K-3Kh`*4H`#4?eTE$2l zCuQDf;z~Bg^IOm#!VfCNo2dTrJQ)>2`9Ts2go+AVLbQPag=ZZ}&s43ni^{L9-GpBr zV839{qCv9Sr~$b&4vJIdLI@>JO&v=7{n1YomPa}J`4?{L;Cn7wb$A&td8d`|7}ASX z>Y;W9EgIiQ@yYP*D*SXA-z8-Yi?<`T88Tk!W^|av{dFeUj0fB`L)rv-rPgXJPB#oZ z!LUW1KQGpjRb%yy`#v-M`6<<2q`&RwnI(kpbZXds;FacC#)GF6d}8`48Vkb6o)h|p z+et58^8$z;=J7oN;{nS@dz+B_^zgO$WarXhJs`~R`|3hV3CkvpX5*`38*N2$$T*k< zJhb=+;~Pm;lqtnNr5?=!Z>{C|=iz(TS^bD79~gemL^r5kX2A0?O?J@%d`+%|jl=X~ zGnw9uo9mgLp~NtTtD;9T3=8RGJp6#ybEbbP1;+tsZ{)%~tiECCX(nHJd3Y(6iwC!| z_s?HZ&h&?ua7^CyehJeHrpKUXw|^qT?VtGf$n=+F^1H@cOt0IPf3M3vydLMl^XK7H zDWeU(5jdFX=k367LOzCHKM|@+@p|LrJDA>^bB9@Zra+6Ky(-Ls-j-`T|225m&GfcK zpJaAw4OC_I9#`<%&=YItpR4No9YtZA6#LG<0?x8}A7qb6&wgV%d*6+t)!F8t$4=tUf;7|<0>{rdpPMO%uZoE)8l;?vq!7(1jF45|Jb}8^J_f@ z9&vU+H|u})Z2osm8^oPh`#+QZVdI88=Zy2WN$A9w#4;Y{9)s}J$iKPHoy6`to*7i)M)mWGSFv^d>A>7H(kt>9<1o9#C1Fn;v->`rP3+#M;U<^aqxxw$oco`w5~m_z3rfO3{xu(kzY7EYjn#ppxwU< z8^|A?F>t|#6z9uN25%z&o^`5d4e_|rg{hwQ!1O4?5tPr+AMiy;*aCrUlg<-H21Y8>YUS4>{_qqEdh@ac zQmNp9!IC;#Odx-&XkX?H{PS|4o*VpnX58vwufZqp6`gcmd{+a9# ztW7Dn1AjinHD^&Q@<)q2&MnWvb52{2T8;xBY#)?uwF333VVA6iLjPU(q(9q`-K1*TeQzx9d-oD-G2V71pLJ=Ib`}5%!{|j6+@L91l)3Y_xkPQv7b5p*<%Cv z94NU z5nuWqpm~p?e4)eYLj|U-;`bwLA*=pWnd(39L_zq5Cp^p}p}2 z>E+}{PJRF9LF@AOpoQ&ekb})TG<;!a-P^IxCP6RW{mk)eD33}XIV%Nvel0qUS&)NL zb~hU1{>fk|DZ6bbKdr9hxeNNwg+K0~d+#>$d)}Ueo>28HC2Qcx&J((1k8Xhi^OM5_ zZCA+8C0PEQK)hg${jS_l;GrdcdE7HNOn5>0&l;=W{ab;vDzZPC08N)nT1)-kK4z~-{4n>$%Bj?T z!hq!1A3%lc>x;-weIC$rP7^r9@q7;HqJ~(snQ7V6t z-+`O9c;DNhj1RfJ%DhAGms(WWOnzKxl5r;K)tKmhB0WvR495H3*Db+8AmZl3CDTdo zPp(-y>HTzlOwh0CNAPu;*1r9iiQta zJUya^va()%uOq%cSmB~Ix7E~-obc)|FAccNdC|?jm3G}&@D`F(bd3JRDMn( zpT*UAXY85Y<)<^5p8jQX#v5!MQ(1j*z!oH8;V+s!S-&b%by&a0!}1wMSdC!%on<^< z%zDe`R-Q}8m#CjNw1V-6568IqB>&iXiq-FEEN7UP!2cer z>U0_VURO;oF#NHuh&^Xz;K1JVx$^)v-eu?c-$C_`pTY7}qg0nOJJm#x_D1`oVojNx zy&FFlf$WzyC70$yLE9Gg9Zbae=V#9DV*T8FyO;6z2yI~l((5NZ3JGK6*ArXuqF4ux zDQgIOR9r)-eweC?D9!g5Wz|wt-tATnqKx%(z>n#D_49m4^X$ar2-g4YP&-^b8N_K;`PEX;j|fn3YRrqbRKQwz>o)TX% z{3Jf{67b8ykfG%7uFMm@K>Z|d(>+9bDRWhhdI4WwoDppbOw>#^p!`~n{;Li};ELqQ zLtTKolA0A?!LM2Fa?37(-(P?8{d>|kbCHiHy-fcz(&RtBAFUKV1ik4cix$pIsF%bEN^yq!Af zZ2rK-@XO9E)7bsH++8Ke7-t#tjj2z!`{7UwMng!d*(dww5v-!7e9Brfy|N=t{}=HMPavq zTcQ&9Tk*Mo>y^tFnP}L=)kNo5=PTUhayM0LygA@k>=)8mFN$;7U7pW;CZsiSVK+ou z-2YZ_(>9tItk`*u3wu6))f&?qoV!?u;^W;-oXLu#di|c%ad|@H(@pOdb7k5ehn>s4 z%sDBh^^0>m!?~q>ig6I!~Mqg*?#av(XnD~(lR?KGu>J)L3VMddpY9yq1aC|IuPHpe8cZXWpTQT3ujzAlEXc- z=8j#yRK_jc?U*!8yPoSF6zyIH{t^CGtEZqbgOf4ojo+x9$z=-#9&lV*zY?w-%|YVNV?#Lw5gE^#ucK^f^Hm$}5{9X4aVZ*X~~{q3CO?{Y8PM|AkP-{+b> z|B?JQ5A)V|v%)CwQU|S74yQ1mW+v=6wLo6=@hF1^8RXa6E-TFKMZR_Yl*rT=dF;cR zR=in`d{&6Z=bi@S;T)F5{jSA)o$kK1bHpp;N7mPLUA%<-b`)nZNEz|V{^O&^m~XzR zgUz(jUrt`q4c*%hIJMVr_pOT)aQ5|nPT@zfzc`s1xKSAV|8}yvGv;lPmjB@?hfBHH zpF8?>9IxY!dCB=cI}g4#-hFU5)IaKv^?MF^(+T&6GCW`T_sEb(;G4Na@?41rINfQi zJg$pz?b54nL;bYcd*iRe&dlRNju(*MG`HNWeqbi}#*nRQ=g9vo;*^{5+>FuE@@+u% zVs1bAAIqqii*$bAmEi}+k9F5C`!e~~zz6e1!Ote{lrkCv!J-EGEC%>)`*3{C2;AXJmF@{ck!hHg-Sc*+R;} zbpN?3{h}55`O{L(!qlGigyQQt(Cc_7Z@wDuHD_LrUn}%tl(eO3|M)Y;=BqPs^a=eC z;&;Pt-?1h?Ur|<)MEw{%O_Csd@1MxdcTeXYSx@p|u@D?c!w(tr=jC1n-lM5JK5qE{ zLM4qMgQ%Tr+LGf*?`6iZWGZ*4zRB(_eXukeN^)TL32Vx~O+UZNipE1X>au{wE3p1u zBR#jc-B*J!vlM`~g?+mBc~i1_$GPPd)BI~nUwX>9C9;yKR@ z9+Z&(`T9s?EzM)c=H+Q?fvNh{FU6r(ID7gl+CRmle)XdDA+pi}7ss)$l}apg1lm0J z7u zM%2SEWP01{&w~FB_gppR5%$08Z;He)T?vpZ=TbaxT$}oBVA==(XLkxQVk_+N(Sf?WWw(E*xr% zeZ5kRPHV4#d#gV@#6h@`^Br|;`exTgZnb>ujTLLaw{(|yy@y>_l^^K%4Z`nT7J7yK z9?;0SPIWW0RzP0EU*>g#7yR?Ch2MG*XMG;m4g3gxWi-xVrQuh6ra$8 zt9o*Da4LBA_qsPlh}Zc>5;xDc`Yf2+Xp&CU`NiWw$LB9xV>X8NG#b}&gHi3 z-mDje^QlhmRl`NxbiVo zq4gNwXO`06(!i$#&bzk{1P=%c%`h+l&b}C3c(X&m4R9#>GEpA)Df{cRdKh9J@725i z8S^OI@KKgP2lKo%%fRx7fO`~RX~oHax9>L1TMj+FRP78e%*%s9a_xrDtB#Kqy@hx= zLgKx-E$p@1y-}L>9Ss9~CQ|$<5o+$D^|UiXrOg2K@fp!ya)4g_vW)2OJ!B_q+L7Pb zD~LAT0yOn?%Nv9C^<8fMxCgybm#d{3C|@RgH=sXI`Q(achkz=_Wp8}L`)hnJi{1pi z(;k5aRw)0gP@Ud^c84sLx<-0`uMhtu4ZVYl_1CyTum9q?SBQ7G`+Bc_1HGD`Bc!7t z&zaD;#T;l-n|_DlrB;cXC;7GKqTwdwXT;VVz)xcFUH0af6E8{6HpNXE@G5I%Tk=~) z8$UB%BBv|(M!aA`?Ye@aK>HmjGE_hLvrPcyJG70heaSDMo1l_GdeNQp{v`q*+)y4t z<(unweWUz|>s?bZ@>?Zyf3dvMCtLFysgR>vkGhhdYFuwJj`Tvuyu(c%@Ue@!7G&SO zptfGZRE>2k9w-VMBT<1kJoXej&yaZja3RS>9ycyg{~JG64<$KbfCuyE=Vv{WCb@ph zZ1%k7*p|Iycgr11cE2V-duSll+y1d&ac$EHQwx%tZjX#4z3(C!?0(Cz+ZsEmTu7oy zn6M~frwL)T;YnN43!OT`pT7H@$IBw9Jj!=uKSJ@i0+vTPf5VE!%Sv$pi&xWq>0%Y^ zQtD;#@@BjPiGLwP`tvtACfQXL>t4@8iG;JlWz4)BB{v$8oth3vLcRFp~oZ{n=sRL+gqX+!-A0wuqYeEj+lc0M+I+opM>*RKAFo$ow8Sp1ac z<*?PiznB57|2I@o>@dWeI3cb%N4Idfw@WcqPsMZ8Ga-)4Chgs{fYq6dRh2 zMjyd?Z*!V3?F-uNpL1f@Nce+DJJmzv2XtB|9Tkv&^%pmdL%b{)`Oxt;^wO&QHMc|W zYS4f&tDzU=kW}>(e($&N+;!U!|MZvX`%Z!0@;QN>70~ln+c#ecdc~1Ba%Z8}6~Ex+ zesAP`S815nKyOcnxQZ6^g1@zO(!S;IRlPPz^lR}YF{8l&JVemjSU~U78#3Msc8^}y zd#4lF_UC0y9QZ-i;EacFv2R^5D}Lbp&Dh^Ws9wxOy!_AlZDc0mrG!fRhGRX*D>QBp z5eu#7T9<4wN!U*3(3R7st6-e-g1pSp-x6-szf#vElu6sl9Z_~Aizuh|P-E;BX zVk_dNAnv}q*Q7g6HJ5ufZ=|iqlnSmsBsi}J=Q}=&roGeJk9D!p{?Fz)p z*o;5b>+n4@EUR?Gv85I9`j*jNriJfzK_+4 zTkRI;fBVG8-UfKDm+$&te2jRmpb~K0814Od7hdWLJ^LjZS2iH-$J+k$G{E=m*|*Cy z7kV~N^?n^jyuWRj#VB5;bX;knbrKMz(L`~rD7`>zHs0sgvQuuR(9;w2{PRV* ztfzbVW9X?ZcTGJ8`QxnSYp&1>%A4vN0=+xCJIW}2e)`tc@(6m1`fWdu0C|PGpJX7` z$C4H5(n-*3zr6)NkVM|_yU&00`)c8hdoS;Y95`$GHu6vDKAB%AuQAu?pO+Nm;3^CJ zp;GY2l)HI;z~jMRohe>^J5*&x{^I_Q;ZrDHs?9X@pm^E7D}%+$GuyQ+ z6U2`LBReW55^u1Ul&_-wN^AIsB=VyYGFAA8E^wd8Q}Tc}uu|L9n&M&6_HF4@uJ&fw zD|+uo&fC06whuhzK=q2()&`KDKHT&J8&~Xy&RDTHr2jVCnB>;qS0|F5&>a~E(ksu} zeSpf}*4<|DL9Xp8NAmZZgL289s{XSW?|RXlbd<`~T92}O41e#}GXJlWq=bJs192rY zkKG%vsXwuu^hS)96eHBWkZwk37}&~wr!0C-i2Z(be|8v)H{(SI$WeXP!hMW?6wBGM zcd19c-9guO5tL zvdta-p31TUgm2Ve`{2P)#Ek#lo$5Z*4>Z1Vp&dq4FQmI+4&l^=f5fSLh=Th-#@pt- zX88;sw}YxwA1~zKMwt6}iW}+mMtnR#@ySrFd?u9__R8xJ2IcVQQsxPF*?5Q=w#AWt ziz|-VfCZygGHgt}&+JydmOP%ypE|$8fZ(35bUCwknXW#|&nzCz-+zj9s?ehPW#!eA!ni66-EMD87@PE2$ZCZyM0hK_Q3c zeNxd@X^PW7i#M*_3Y^;YgPn`~wY~h4^q<{%$M{WL_RV>;4ib#o8);k;lBArdzQR+> zf$-vie@K{sN8Eg{jOKmiwA`W8&k+|Pmfu(<`yh|>H0qjcNKbA;?{=#H_#?}K@&ViD zq{|(H->ULne0nA1dv3Bv-%qb|^TYFw!Nl=2SSbJ}0WqkS$kV4Epqy^~+0$nO{?$BK;vT76L4MB}z>UzHY} zhYVZ2Z^1$Mz2owMW|eN>?R!qHYCwEB)2(`<2XW6|_T1wX|qS@)*ddIEP?(9iG3bDTflk0*tbF)@mXZs(J0Cfiyv~oAc^sO=X~zbBeY+hn;%!F1fDbA zxMDlnd$o1x4lBHWV_5x!diZsVInVAMM1I`TulUlybI6OV4GC#mQo}{9__1D@yT^%7 zQa<@xDUbWMrtPJfTrPJbQYxY6dm&d8KC4xTd&p_;D1D}Xy^eDbchRs>EZ`IdoZdO0 zA)hO(JeD67Q^dVViW~L_b_S&+uhGzL;;txH3Lo84!<7csJEWWBbN(+=Yr9n|xPPI` z);z|2=9QNdWfkA!oaN7u`R$e1S0+jAEk6ogak{SOeS0ByX_V`psgL28R!`2^dse`? zJ}jG`^#l0{!zYtAPOjx#nzTHX#^-Xky`p5lt-r%@+dZAe{Ve8o6>k{hUX;h}5K`-@ zx>>+2)*CIp@7ryz*j?-B)8-ORMDoFdii3B!c_(g)y!9;PhH99L91Xg|-Rl>fvm&OH zi`XiyzCo&tyHMYz_ww{z?)0U|^&4I9A-+8>yBGI>6HaVfto*f(8~S^8tGjLmCob&# zprNpgb1HT68?RK&ZT+LLUOG*{g;^xzea*+d%{F3#w?!qV^5u}~>u=?p$lV#A$Hmrh zk1E%3`TLO9oqh1xDC9d*_uPzX-crat-1gy>!j3BL_}9Txi|~Etk97%tboxTSIdz=YtGu$C$MM}QezzV5&kL1L%KU)eCnjwD86c)p&pnu2 zWfTgYvF>=(r&rck&!#0l4vNTo&t4xj9`{WG%Fh;G9N5SuR;v~^xnN&Edb;~HWyHDv z#7u3Fhnk}|Wnm!Z`RyT_PRhdGGoQAOXh6NHe9g;4xX*F?`j+s;X#e;D`{7YopL4#Q zdie$XrGH9(qCfbi(Jh0x*_hA699GVIh52o8^k*XN7ar_>==TZv8?nNkOIc{&^L)}DL@guA|GM2@1-{B(q_n7MiCtO87^PEPKY({k&V8r*E_ZYj#~wz#(a-*2L(tAZjh7)KfWs!&2a`Xo&aV1< z0eO|=r=uH0p*LV_VEY$5=c;Wdx(M~-Kfbt2`>eo+S4R@|NY8gs0Jf^c8pqT0x$Ql2mIIp{eGa&yQ;k;@H`K{|gKEv&R z7NxVY$iE2(cfTM%Jok)IIO%oCPEqg$CU*Y8ANqhl+$rQn{d#CGlqUb&f1HjJ$!^a^ zjU&Ef>bJLt_HX?&%9^O1NP^&f-@ z|7dCrC;Xf7H=pdDo3|810^eh$8v;N0vq~U{0Qix@5g9_O?)-T2+hYe=GCnl<#8k!y z!rVWzJVdJ28W0WSMc!P)FV?^hr;ca8f6VX@TSd?RI-A4V5sJ}Z=MC8}o7>3F>H&4j zsQ$x#A9ik%c3Wu-$&L4dHL7~)~}N^j#nTzZvp_fQyK&K%ubWx%(N{GP0sV>LUg?b^(A(^ zd`bkg0`k5>9De}UAZtOG9|i!5-sj~eb6!7!{y7Vjr+_sPuAsCFko}o@U>?yupw&wr zjp9U^oh|=1uyMN{c!j<9u5$d@SLk(g4`t^M!}9ge0eJf?{=7x*BWMNWCka2<^TSLg zu{_J}F+5M~)&MO<{d%$Q=m@<2VI7k@67gqYAoqJVj>*^QdJ1HL6N-WJNAb@G#H%wt zwQDtKG|KPV@#8rD7`lUO{0ejiShB&E;qvTUc8@pYOlB9ACmy&iLi6qU(_A&0zoxVA z3+4mo|MX+$E?)Qkt|q)p7G7HWd3(`gQO?2 z_xtNYf4~lW^w}P~2!8je!8s6r`}gW*@GxMjXM~w6P~-MB%{cgzb!Xgm^}?@?d1_Nb ze#NprG>H7gyo9T-$WIJ9<#&*HT2#>^6*K5hiB@CxiF2CW+o@f9RWoPu6P5)pjLA>v z*BMRl0`{KI4x#r-yMITV?6`ca4HF;x-q+eiq`z>5Y=Jtk{<}m4l|Rgh?k4?(InS&} z=H~95LhFA-k~1a{c%i+Xa5((3Z(Mnk0{ne*#qi2);D`D>6Bi#s9Pntj&^IkWUf5;u zoHXdo32|My0)Dsqed1I**xmoiFYgGvr{@VB%eX~2r~Yst!yWC0*r>?SeZ>27t*#|O zZXfHZD}d~otZX`28+zudF=TJgLXfPs_d;r&-Nt+S3bhIv{hx(j8^+(<8GS|HHUdghgrZ!T8in z>L;@T@kwXH0wX7kqlx?bh!4nv%(l$vh(f##e_kp02D_gQ`4y0caUB08u-k4X^7M6* zTkkvJUfYYTwjAv{+>c$wjd{;YIU8A>W^L^%PW$3V3zOUjoNQFU-<`YaIP-6;PVUK}=ss3g0jEZ`pOox*oQjyVS5B7ipFB6Rqd=Mi}ldnkL}n z5+BXqrd!XwO5ZZ>r)DkZ-FajBkFQnS>)F-IdV4Ck==IuO?#M%pdV1b;TS`55`otjD z&K0%X%b1^jwWA(z>jw(WTzRyL8*e$t-aApieS7|KO@2*1w|j-JnI7IlEzT(V+vIxg zZqQ=i;}WPQkq1QA_Z>*WGup{MS>-9jqVaQmj?M^^Bca zb{XTp`>~;YOdRsLWuM}m_F|qizMJwzq>2mJbV_<2J$Gc%_d;9z{RM@!S91?I!vEW}e*ZWY>st7S(S58Bm8gq5G!G!J zWfRdo8|$j(?d)rh$H0#-H@%aHdGl|~)@!3M&umW%&920}dN*=%L=w*VTsBH2v8f%34&2@?%lt4cfQA>pf zqo3)5(pC}ZEw*#HbQkM%p}Kgn80s^7H$F%~xpUQtFZX~AVgFvlp?-S(k2$peQ|~o@ zJd@g&xxRBZ&^OBe>oJs%vro(;{^zCdG@bHYKVB9|Y{fW)Raxs>VZGgc518#_5Y%6+#lj=)L*B*l&|@k;+8NLCT6+!e$darodTR}#rT_Z# z)V}!5U=~LFH&ojS?*-rSGpK?v|&Rc5gG z6a2dke|ZaW+T7$4={4poVR3z(swm?lAHNS_arwfN*(`1^;dCtN`FPU?7Jubaq8P>} z++lg4yw7qgsXncIEaN**FF#=MdDhusARgfLyTh6O>W{w`? zJ1xa~7^eIXkt4k`E%Xn$V*ZEkWqjp#KOa`F(@&8-r)7Q4lrGvF-dSId zG#d0{^p7xHH86x>q$|=^D1UkpG!SS;*T;c-?E%2${diPA$fM*5bc6DZ7eQ};1^9}D z+rXv>l@{>mMP@>_qkldNxQ{+F&;z4Rn2u2->;&s#_3}KQ{fD_K(YvqvN zWa0Aw-`(Z;=cGHlJn>&YrZ-=JYScUH^L7kv=I!oT*f$>8Nb{n8X%1h1@e!||j9X(= z-t57T^S5wLv+P(WW(e};V&3M2^4<wfrM&|nEB3CfB|jOo z@#dAqz^2RVU(kJ~r89ipHNYpog|*|Krb1q1baEH@bf9b3dVUB8|h2F^2fTE6xLF`UI2y z+|2PU)Shk7dm|NK*Jhg&RK73Q5gRi2i~KTt5bzPL$(1zDz8(8wNuI5vI_)>&f0d## zw;%CK$69fSFYHl}bXm|k4}Ni)_ra=l=x>(RtQ~kC$&6L5op??obZ(#t^gPw0!&lJK z$$x2}b7;-GixU2UAHDbAYP1(TrFD4ew58xB3QbGYet;L9Za+9*0q-xrfA^$t@SDAQ z`pw43%YLp*lzss_-7kwhroVTUB|Pr@e8>|Pyls&Os@-WUb{UEI+}Ul|5AxX^zuq-q zygY?3N}q)OhC}zm=Y!V>+b+zWi2Go(CI9T|cch-1`ch(Krn-Rp+HJ0Q8F{&XVY(Nb zaUS})A+38F_?Mtd_Uj|qpY=iF+gR*Bz9_6L_5q%MaWpp(_KozY_ASG>Jesme`6Sv^ z-qvrt3UJWAgUbW(e%#=hh40b7sA-3{Bfdw|zgCSl@FC;(`=#8$`x4~ee#%3A_>iZC z_ONe;%<0As;FGDB2K!(iQ~&VQkuw;V4Kh<6c;J1;Tsr9yjq#b~lN0s}&%LR;R`l{P z^5MsAtEZKKPcHE4XNLWsuJy!W)6hekJjpolzVt=XCXW`R$?I=Nw2CwSP?{2=+^I@muco2<&fd+I!CnCFP+JJhyhjKuyY zvu2%=6YRl4g>HQa>nriz!TWTnV%e=`oB1et7F`91r_{ zExMGhhH-0eec0Xv)T}$3)z~E9l&pkfM@9>{d09t-naz8<_nvfw1m$HGsY zIzMneUHfKc|7Xf*S9-wk8JHiEnu~9T;JYWU`)j%y<9lCjj0nxIpv{XeUq*ga`|8u_ zG;U`te&|%;{erfZ&OQJ;C(B0p)8B2lK6aV}{k`bwsw)-k&?{dYQ>=pV>xuq+doTKJ z>y-$c2>ab{EnfH(a?+zeGpXLrA)$oMml`|2sIKa25O?tZ_h6!m-eZ!sx@9r}Mh z3^YPNa*v;ydI4*v59J2`kE`#F%klgFr&35ngwQZkk?}6kb=`-AXb&ox?L|qXLTS>V zAqr8nwD-KPyQL{D?O~;5Boz_zd!6gPJ$~QE=ls;{vsn3-% z@jB?va<4Q`koR_X(fc%iw%t%*LcELDpws~{9bfy z$Nlww?d=-nfbUz67w`f)-ZQ4}!TB(z-`@@G^|Ru~`LiG$d#^`k{SfZ?WZ*hJ?@?}} z{O1#(#d2|{BKSWu4@DVA2>V&)dhh6?G0Ln_m}>2 zYg1VR_%!a!Y}`+e>&6A(ev}G5tc%;}hILn**MqEJDRdb3TilfeVYvSv-nWSd`|Y>s z=n~xD`j#`d5`a63zFOmc{Fg<*b*z{69K4EouF$b#1m0J7S^wn9en9P4Jje0>)Vp{x zaeB{h&U%IW>H3=wj~@mcG8X%S$B`?ic5T4v=_(snV0)suO1z()K50=L?-t^$~PkX@eV!)Dh-U~54 z_DBxG`t+4EXg}V>s_n=6iTR=QI$28xKRq6=%+8+1cJFF8DdF%P68q@!x9=Gf2pY88 zmMq#I&Gia&zSD}?>xLzR;xykeF%hBpONqM@E$b$z2;+D>Q<$JZyWL<(hyPt6K=Tpf zRgyF>sNzbQg~Rp61ZjSs9Rt%AkVTHN(^)n@p0;atWZzfkToX&DV=N2X@?iJ48;TE* zX^}|dh6|N+eAL6{n}*i}Xnp1{T^bjP!gLDk(E~-=&)JN5wESkR291)wm{7y~+;KOJ zqt%#5!hXULdm5$Yuz7pJayG9`fZL*Qc&msJU0z&|18Di)H4z&5vSAtp;ik{v?*OCd z5B=yRjk;m)x8jOA%nwmd1gmzM3M zp;$n__82?dun0tuEnC>~HF!G@%Rl_t>1nvK!y{L+u@u-T4qt)+FcBvYn2w_XZpGOE zjNrsm#mR#F6az+%jM+MtPwrvk5ey*XTEa+ATL9m4?BP;HT2Ds7paUa`Gigpn8P1M=4 zA@Vs&6Ip(=m? z0BEh)j-MlQ5)L8(7HTc=fjI`I4j0J6eAx-Wf^;+EvT| zR6Vr2Aa2^vsq!{R0M=7>UjzpsJ(n~(zNk_BEG#!KV*9bY&5BM(c}6u|4!72=q3wAr zzCy`^o&7R8{NOHj`Fs>RO3O0?fzCsCJC`XGEcCnCr)mA)UF_%o@+I6bU_GEDkj5`s z_(6p6W>D=N?!RY$J3`NMR%$6O#(JNTsU3Kncw0I>h{Lac+DiBD%bhNmm)P)ynpx>9e4HpdJeq#VKjL#>L zbpNJk^_sR<`fhR->v?wYLq`ey=ni--3NUETQ`*jM9W2v>EdT4i2*zt4M%*zT9TJ-N z1IE?u8I~P*yt~r5>V`Pr?e2o~a?tZf-L_o_^5vbOW7rRc`Uh}9A*|z#hX~>Mz%ef; zN4!trQm{h-+edGo!;AIPAp!JxspplmGVuR=2&aDGa;b6aXW;R6_&^{posRJ`XB-~7 z*%20SfQO&C5P`>En}(zG_X4;1M1R8Nlv>Jqg~ROZ2a-ct>uy9`zq_e&G>M3o|uYbbVhk1f%YyHx_fPXT5=NtlTw!E*e0rrzA1niUn z&-?a*eji}VKG{c-AUE{AP{V$Px0VhS0}6jHHd_f;aifY)3NUn$&J^Y+X)1MwxV(>c zj>~+6^xFQg-kJa}{pc%bw+Z$m(mVLv@njFErQmaa)0k?zh1OE*#1~jLx_27E`E;`YP_xbK+ z<>+7@a(0uRHLjN-xxmvefhV4QRewwz{Jr{0j~WNm43Y>u4}K)3gw3f1yO#G61 zZ$5FReKu}qyan@mas5>34vxz}KA0zi-r?`QoHrB^`UQOZY)if96X3V{TatJ90@^3& z=DUJ@1o70M%36&Zq?Qd=|y?yuv(G)Y-`yKX|aOEbRaHo)h{O; z+pNLQd>OCHFt2!B!_VLLzjxrkC7d%6 znJmZkyNAnn|877nk>D>lUKus77WX$gOPbeWS!v1ZBiO$y;-B|oef<|lI{uE+0|8jC zqSOl`81!2gYWXm_FI!`S(cq8=3UvYMv- z+2R^_2#0?WaizzD;LFU@Se8MIvqlf6XS2;nisH_t1_VD&%ZQDhijI@ zFbw*+qCvbEO}FDO(?Ne=R6vh6(mQw1b|%CP+D3^&Q8UXSxFLrt&_ata}?Jx}c zpl^=ur?G#T3ytTs*x?KIv%^cTvibWJpQCKPaqBj1cXsV^8s$AP;f3+f8?pu1Zg-Q$ z>}&A%Adj5I#1;B2Pj0Hbmt}1EM=K-`a<3$tKZzHE2yz*|)(lW_0J06Z z3oq*eCglMD+G95WE$NGxal2sizpegkeJrLa5Kg{f#}nf03#{GGwqrE1!{cD|#&*_% zZ23qV+pkGnyr6%n&&GS$ZIHciaRZvqWc%H8m@QANXCo~B(&4a4MPnI$oe1nTIr9iN zT&y6!<_R)Zb=cYp^ub_548TgB=83#b1UWIFqRJ2>IEbznOh{tseSjP=9N z>M`!3Bf$8N9~+RRIOR*><_2;(Ctr842y!+@K0{{+*5TFI`ZJtxAr4;PpasXiMH(w$ z{Nm{Mb8ry{+d0VO_;ZpYi*fMZyzBudz1N)jQ_jEz4(Bbkup#g$12!(;+Cs}UQ|#x+ z<{DeS3{LrAJK_pkzG=*s1>kFYSZ~hp(}k{J$S?GYSnp!X#$m*6cQ%~-YjMhP9bGX{ zesqSQ-Z}eGvK;*e939fB;IxkiN^F_FrV;eHUmWT1HL5trzypt&U|GvHxr?0n^Gv5{vrZZWX0@CxWRAlE}48gJue z6p*FO0RS(!vhAHGV0Z&rN|4>(jpA)mkd5!N?XC~9?W(ld<-8AXCqcM;A>NS#{+h7` znmU}ba@_@nz$XrR&co<;d9Mk^h))-3KV|yi7$V5p#UCL7SZ@@8&sGC2lIq~YSd)jJ zKp2NJd}v${&fbs8Opv0}f1H>I1p(_z_%i~4QiE*!(kITetm%L!k}y6Bc!Hy_ADw7N z>o1Mq2OiQFVz-ZNH%DmstPx&OfOGMerHwHUo3ZvJOx&Q}h#4Aq{Cs5`4GT#y?_)B* zVEz%YwH-t~s+5%ihdM+VB3Acq0s+*W{>~ z7^j!I4dMTB$YbySo@_fp`w@Re861Rj1G+tG7iJX~KRSc!o3(54G7u>S7dkz~y4 z^dp36y<}2JEDpCQdv^qfzljKjr5IQrwA=a?|IhHeo*6iupL4%i;Bd19>G>ExTKrAH zI2tVQ38T4w$FEs{YT{oTFhA3~w_pO#cWV4t0+?^P?wf6ddGSzO7R{$a11?st1DTuU zeio;{k>v&#UIDLpxX2sh1=5FpFDNf?#2)8wFeiE=_Df9mjVb0`O6lWAG1k0RQO2lZ zq(}R`Z}(DYDDZ!JT^$(jnV9xsJl(mSUY}I0pQhixSUDXXkJHPnTnGdL_*3+v9E`^1 zlMK9moHN=AAK-?3D#);~UGn=DXt>ahCW7AJ^1D>}b`j2xkD~}L_P5;pV=cB1&K722 z9y)EM+KkI#x9b`O?BA2u%GYT>x3qk~C>Jc{hSQC|&$?uoMpH7+p72K*xj6?|f;(xP12oI$p@On{+>5Sa}K<2(15ptpw@-^Bv8U zGMwJM#Pz_4U_Pn1{4hqH1Q8f1f%koCqT@4ue|5qB-Hx7y0R*0B-#c`F%KGzO1%O6-Ov7-8ApfTN%Exeb(0?5FFtJup#8KjFrektJMe%E=X2xz zY1t?1AuVf;P6}cDne&CTAJ$jl8WWIXoM3qeFz_5Z{bdUYI^MlLZ`zMByqpE$K>?6W zz%6E1Y1}Y;oDTOm2+87fG;Zbada)J|Aw1$T3>ScZmDux)jfKl-y+$p2T<>>>VF1EM z8Sr=lu7lgfF|yp*SX2(#2Dww8EuXu92{p{$jiDF-v&|rRz!r0G8}LIE0AQ^@$;OxL zaC;|q_|?bk@Khl-Hp)Zsg1xjeJH48_Y`xzCHfGOaW9+`ow4KRvwjUmCZ2jf$>~u>$ zvC-oiJ6vEkJKPj{dz}6=TpfTO&;lf`$aFS9hR%Twr`-gZ{u@Bts&Tx3`hV%rYS90~f8q4sfu1gYz<=q`v=!w4 zjsGwFUpoJgt_HCGhyU#U7wPH&yOVT8I0wPOe{ujP{|h+v{4f6h=J#JZ@KPoG{{R2( z=cM;9-oJd&%@OSAX7qpXU;h7V|C-#t#d^rH=7yyvtlBQ>^P zQyiXez-gD79J_Lkyc~L0?0=0G8+|c=3@^pd_z(lg^Eop9S|XO0U;s4aAdoUz9_8S_ z?`-~SH~;FB4u*I_9J?1B+~R^A0zP>MD`4GCh>e26I79fnCazgn_vAcBPZqPo8_n6c z_6~Ls*5mGB2VvgKvFoNA8thBSuBiLP&X3PKPnRwQK^^Lf@1T>^4d~p8? zC%qodb9aMN?*E?m?YLV9`}4h@-^=SKRcv=GbEn&EY0PnQM6$ZTL9NXSZ9B3cNn#k_zZ`M|?+eeeh7y7L zS|Sb^0_^Fg`2%C}lLeMX|29d4wTbHpf!Mrt%Ec^Pykv3@;Kc3g|Tg=5RFTeuh9CgA-tdh>+iuNa}J02Pu@X$JTJ=Ye(XFx#iyrTh49?t)G4?@L3 zx=yxq`T5<$9Xs&oUiSUGCp*lbs{~$j9DjHLc){#GI^CB=MYLU#fDetimIKg*z<%(E z;|Ywq?~)mqkCj%jJTW5HrwdrWDJ9JTFtS8W`COmMwh3f^m}fGxgIqC zI#Iny6zdK21L=H}?mY&ND6IQ79-(pTR&!|az}GG+LxTYSp0Lj!i)?sF+pkrm=<@xm zv5m%XrH{0I=$^6+V3ld=J0^P zeKH#pq2a>0AAPvC0g%hqj((nge!Tz<9@HkYO@RUa96Fqdi1&glIvWd z#&wl!`$|8yy!a^F&x5v2Hm(l9n;c$$ixXbNNxuM_L3kD}Hf)Ep4G1rP(1=?dmVfcYFfp3Pyo1p{C`NB+!-PZuBPp);hz#W<+S!8T4hu^d^LgX$c_ zqbyFhlY{@_)7b(&3>tJebQU!J)6>U&Ae=5{K-`LPIzk*|ar~tJ9`v}?;c&XR0im;@ zWo-`r^Y`EX{R^kF3HEfc1Jcz9_%B`hZ$PGt4-of8_<#O4{GZ)FeSLkCa_;%(C{?=H z`8J%}6 z7dHJ8fcO43+pMy>3H#BGT#Kt(Q%aHawDn=b=?XM+lg!B4qn*MsNm zUDkrcpQYS7cI*XueU$g=x6D=)7cnqzuW1W9BRaW~-x2n=h3@WFgZJkWZ?D!rK2eKu ziSKJwa_UioW~b{zcrP)=bn5dTZ{QCGu1Uv|;X5L)NdD=g6^JZ55&7V99a!TRSnkO419)WrFJtq#S75sb0GsaqtlRa;;b;)z^6#(l+uMQiZ9Te zlP3$+d1{b>ul;v9xe}zXm%objHVgU8CXH$f(oxY_W8GhC8qnfP+^Z8!3sC*4D;tOf z1?cldbM1`d`KYh;fY;EASmgO5&L%wD0j+t{cyz(<#NyBAoS0e@;2%T2@{43TY7+P9 zKHHs$B5TzQm)?4cnm?Mz+VZ5pIf|`6n)M3M{)GP0rC!gF%;2L-XY#9&=j-zU+6GV2 z<#%oejrJs>24{X*9>Fy9%4u?zhj$+Gj-M_1HI70DmtEQMVMaP)Rh_LtVJkg?Op+?NH>h+B5=)DM?x zWWV~aVWWE`Dt;JzL{Yj7Exe;(sd}pj9oR4M)oXDcDv_U>Gww;DTgWmdh_49MhH9Ra zpmGrR!i3Y$`_fUo`=i?I>J$_*db)euI}TCrOvf!QQgixnCVJ_phgK(MAk7ZlqGI6;q}8kP{yg|sH$>{tIWdjF?6lDHjzqOBW8ltq^s!GPw(4olppBh8cP(|7BcQ>_k z^xFJ|>pqcml*Mn@U^$hFhSLhEO}|sn#EtF~Gf^sPaLYZUapfs$^D%4rbTA3U*yxuE ztV%^+qvBVzX{Vvlh{2Z@P)}U`TSa&@l2L!rq4OOD$;ezU^u^%s9Q1fWvY6Lk89Eq! z*{{o}3eDNGci)^p$tcTzDE`HVB$Tl5XsMWR3VNekZ60tp8-4NGy6?PnA)HrPcrha& z4e_6Nd!F2phHkXqcBoyEjC9ZilW#Mhq8ptW&(@hHAo+LSCMBFxk?!c10GGT}bihn} zaC=!QdNN}0lFu#$4H?P|#jH+6wnqC0pSVK)qwE~+XQd&v{;g!8e*)56dvS|1^A6hh ztycK>CO;G>$rO_ms6s!lO#T<1@C>=RTEutrm7;fX4UZmKvCz$+DL#d23Z{t~{{Nj$L=SH5exjzEgkFSjt@YTFio*U}*?MnHDjKM>sgpnO6nSOJAGe}n zQRc|rk^M!{=+>u1@zh&4kVDBL^R8n~aKGN?O1{_L=%Z8CcHQ_Ol<}%=o;8 zFshzH#OFm;m*y9t+ovLg)-NwW&$6Us(o~t~m80p;k6a~4^S?AXKAs#@H`n__lzJA@ zDYKIv7t27^;#alf_%o5h3&Yv-=H(#grW+TUFD4r-ON3Zv z7NPG4udXY)U4V4vcx(xsD2DH7eN{@aDn+rzzf6L2;E?sNBehZW*=Vj~epOaY0h$<| ze_fTg1Z|vEy)N%qDSW>~P}q1X6KVCayixK% zd<5rwZ7pBCOh@w^UH^Kl$VY>F(1x|fOr*qY^qmeZMI$xl&tD%YM{eca#{TscXx4`- zQMn7Mk&(Ab>y?c)=*$T5CE!XavirR7#VS;ej6*7Ik>}jLXR~}(nObT6^M(t}Q zOHt&d`m&hk6{t;cMuux(E!w00#G6D$%L^hU8u~f$r^j_+OWmk9weD9FD z+`8~Nvb2;{&sxNQV%Q`|w_vuwKU5#RIUe?q%~%>P!nd>*y!9cSbAn ziq|Xb(rQJGIfYl1;rqfGWc3Fj@Uzr*GU(4I_|Az(r^WvH?Pz)JR7GHOJF2=Qn4Tff zfvR_h-`5svLt%f9t}1P9Lsiq3i#(+}&~w)vztvZCq9RHD?Q6n1(a&Mc)HMyw$VTf$ zPcz(S5yQJlJ-Pta+43CYD~n*B@!@>Bsvqn}-*)|`ZUpHd`t#5+_K#J{Z*bu6`SOwsE^8&jlTDlP3qBH;$#4exX!_npUN z?GAJyw>X1Czy5Y139)Mrd*^n;_g1Bkzhriyx7I5n=iGq(F4d)6IaaX$;@B0w557M$ zc+qz3qhvGc5tQu`Qg1?yS+nrFG z(!1Q(fuf$-wyMZ>pzKjbY|y55Bs>47|IVN`bh4s8T)V0ZssHU!9*OTl8i7^Ljrv`P zyEVA3YHKGdnNd5rySE)p3cnV0(`rJpNYKhh~EN3-W|D3Q@`M7gdR z2Y05{qe}5w;rh?DNZ>#7=cHj3l5W*7IJdh3?my782=;73P7me#UO6h zCY7qqX1=dMZ3lurq4Fxka9!tF-qDOwGt3S*P)%s3yw$24&w6y}5l^#xa}6qQx_!i1 zq8jNxIThOkes2H%RhokLGo!0Fmv34Eyxn{FD5J0rCErT7_$*n2D$alSuRXRL?lI#w z{LLyur3U)x82R{ur5buCa!AFa4$o( zCj_}q@Ry(qhi-?eP8Gp1u}V~DATfVhxePT-c1p!AWTHs9_VpvT^U#d;=oK<>Kkx7J z*^!xHm1wh>+l)s<8T#Wv=E?XMqFen6ZzN{rprsu(A+g3qDDc*o^}j<4P@9Q#Z(>3& zl9GG8afxmP8eeqWwy2~5NsDD?4#NHXyEEPgzELVdqh}OyZO1au+fVCxZBnz)(%!fL z;YcPrysYfuqeDgTeahg_2g(KL#KCpe4SIQ~bN@SM&HQx4h~Dn5mG>0Qey#IR4fv_- z6-m=;vDrw{)I}!BEFGB|AAhoNZw6A;elRw2B@=zVY<2)8_6HcT)aLt@~8H%dZe;?R!M`xbEH4~_QmhrRVdoILN07)EsF1Z zx0!jm9&N7goZeQ(L?_jBj$OP^fHXWd|CA8PL+Vq0m!C`(qT^mm>>5If(aQY}=Pp|$ zqUrLEs-*dG$bNW!B7b@;(tLdQxOGzuI^uU_ao6$~lzm9c(`0@oa?ofGICm`r)i~J| z6eK)Fv;33Yw9FDvxnc7wGs`4op3fUtEEZZk`{(<_p^~WL>H{w-%dS2sPC9&qnYi>} zv1Dm?yy@_R;_E4edIoS0AC9py8vW+xtq?i!Mht^gcm5MYk!cnZ=;p zcW1mV(}_jJ!(Ri^FF%3%wOxw7AAW+y&-<*>$Vx)U-D5`mwsfSBzH4L2yL2@Dw@j4B zBNOG1&t4omnTh_K+&R{L^iHvUq)oloe5>MdUQ3^@1=o>f)CFtq?k3J=Rv8Yc;uV<}z5_&yPU2|_zB^q_RMs~*+ zBX{$;g-wnr=sy?H{NCYsG$&SL%hq2hNNLlRoMWv|Q09r(lQ$kdL3V=mi{A7lA>-y= zha0Uh-#gSdV=?flnI<;d8KIfz>+I|Lx-+s--1CUxFASLPj%X@K-AF+DGiCf2E=)$e zjaTiuj{Bf!_j33BU#*ZycmS#EatDnMTw5re1U!;|-%^i-N$AEalWTAN;*mhGL;9ug zB)E4oFXqlb9LnfV>(w{UMXGOSS!9Wqpl*rr2Zd!RNPg=aUS+8y^kJuSx#O{TIG1GE z_f7OE;x)LNzTj92GLyeDbADkOT0s5%9(^nwJqq}BQ+i)IDlvRw)%qwI{kOz=UDvUv zsAXP6ny^R`D%6%2cf6I1lpdKQDc96V0kViu$Pjb832vMNyY(+mT@^aivl z<;(DmCV20leR#*2-d5CmA+kKoEd^a#zJuF7G80LOHqXfkWTM9_$NhYuU8U5HyURyZ zp^gkqhgmzHqU+wO1Xg9oJ{J-_2O@yl6gm#b;p(X4D_ZXwqkCl`y}i;FF|$@>_|ZZt4^bm=jA z{72&FLx)&YSNV(ks9p?OPF=GS5o$v={p)|2!~4sFou(1Qv1h1zp!a7ge*$tj`q1lK zT_Wl?)-Le9T7}$JM)w|UE=9{q7R9PTzp`NO)}vVgvB-I5XwFh7SAqI_#pc9gWGCah zbIqD)w7O-+y~wHrv|Z)f3jKz3)Vsp#_ZP=hbWQg(_fNxYl)O^$%-f$Ds#E#e2oLzDqiq^pj*( zZAw8?PWCGgFGxgFGbGlm>xxIu4th)U+|5GcKEJ+w)~P_3@8+(twW>pRDovcY5|R+t z#LvdBd*e}|Qp`h&e2V<;F;5yi$w!e@jUK5XrRc}&N%d*HbTs@i&nfYF8dAK!zW>^# zEF@W)m>k!~MBQHN&whAXimn^qv|D1BfSOj`RTG5y`bxo{CPFT`sH;`*#oJv~=)!@| z)sF(uz2;}54xT3pHZNF6^iqpco^m51MSsYpY%C(` z&CZBOyv`+(^F(D_dSa~!=FNnzQ{2Pvoo-C-`pGe}wSgG*^zYj5 zTuHd!KygBsO9-E;(9YuWIzlylE5p6RkJ$cH%-7npjOn9t-BxX0JW(%jeSHSwJo9Z( z!D*YI>&$Hj-nnvz-Xt>2r52a0h#({fmV7eQP9om(b?o@_yNt-mj4hPmi6wN;_P<=? z`-CZMZL^?{tR?#AT1^@i#SqEF;FhG!Y+`uU*Yk2k%|yMg-=?m(5`uSZ z^yq`3Nan9KwW4!P%ZaA+c9*J8DMXH;>%&bSUJ&~RRdw4NpA)Uhd$wF!%_7>~e~mf# zDVd1(Kjf>`QclFKNlX_vyHZ>CZ2@s zm;HPukKp_CM*Yl{exgA0;zRyxrG)pz1$Tjdc&CFYIn0^Yg(w$RKCypjmDuv>&xHGQ6p!BROrq`J ziIKMCXTN`{5)!!|D-?TH$!Vep|msS$Z4G)`j zic<;izUtdwR`)Xxh*p}rmdH~JX2=zfz7Y7MIEKu>Q!LD>7%v)5~K-uCB;#(TPcBY^arsI4MM`h!0=?wMmXj?q5A% ze)A7uoUtxh`R6xgllzIcF*CTxQtsfqV|FX3!%@1#%{qm_K9s?HwCE^$@z@u?%qGqmNXc?woR=XP!)wcWrnmFYj508!7VKG?;JfoOb@&u>_xCwQ)(@bX15UL#AF6lFBjEMg8x2kD{4m$JF!N-Zs6|&_>=53R|+sxq7$x>Sw1?yFZfe zc~BNPTXRIFc%X(_Lfox;JN%AJ^1AYdSkgdkwb64p(o;hwjEy$j&26Hb-n{PZ{W3uI zEdCq+A^I()I=gV$B z#SqW++8{2sjxn;rdyALnIz}n4#Ki9~DaK6O90f0bSw@(4$B&;px~#y!jMz;xlvx{w zljHRJ6nmmpIM_2@wz{T&b+TlwOgnnwqJbexDNSzMqBZ|99$ipzO}7hX z9kh7sbNpQ_OJVZ^N0EmitOci!MQq#c#}bp+W~J8Uz&ddyr(Tn92g6_1L4EsDUPimx z_FTF1Kd4o~wOvcw<}ki>`Ur#^?V}c06&$Tkmtye*E_nCA zy_9Zlt^p5<*J(_q)1sw{FqlNwMtOgd*)__VFRTC`hI7&+X-M;6pn+mmJ#ELk3zLqjJYb$vW z`jon|dWL{4%Zv2hn&m3~(39GmD?hfU&4YaJQ6L-;GC`(#J2em9GbMlY&JvO?h@uJ{ zWw#HS+LMnCIb}Hc2T^b9zbou#7?8CJeFACO>!`PCru zw1|4M-uHg6)HL%@>L0$VJ)23M%1h_g*9lSQUs~H7mgXjNW^5l?yz3h=GIaPrb*?&9 zUHrYWw@#5#bsoB_czGS!wV#cKg$y# zGN<-Yn$MT(|7X0LOmfj4o2w*8l^dUSs1gsOqMa-6*1B=^=RQAV)@n; z?Q`ahF^42Whti36MC|v27Zo2JAXT!rEwr}ZO>OV5?G9SKoV@>Ner{LM3`*_!w7li% z1=PTu&W03|Zo28+Zh2qnwyAzgX3M40d4 zSFWDL#GiK`J+{1wCIoDFk7h9Ih}(8zA%is*_qt zI4nQBR6w z9HPpJy=PCmEtD!JULCn(e=RJRPDIIoW)#M*vmj9*MAT5|8(w2I#*vR$o(J5HWsnwovT zocN}ZkdnUXd;;oS`FLP@L_juSuhA&9Dy@QetB_}tJe*4S7pO{GMc!k+tL`}vDPB*c zTPLk^riz%Sa}%t&-=q<5ooD(Fta!pyI`m_s{mU+ivr8mK@q z56&NYb<;PLc`fMV7pf+kPz=$I742|j4*yqoVPq_gc=>oNB11W!s8kWq^0U&tlj;R7*8Ur)O+d)r%i`Gi|lP7EP@nt_*nVOlVz_vgJ;(eQJ&Oe-N4h# zk#&DQtdnRY;t$w=80N_*&TKqoqmva!oa=1yJ2h57xF4F|5Up8BB&YMA_X>?CJfrPy z#VeLEU3b>2iF31<{Xb;S?aaH+{B}y|y<1o)bGEj8U~1>?lRQ@(NnF^&Qxo^1n=o9Y7<>E< zFSTYw@zKo(Td0R254{2+TZm6y2g$i+WrW(fp*f33%9yiRzU>;Xc}UN*C)`bz$df{e zWkXxWo0#rL^@~lrDwv^{0=PQG-VmYNGz5Oz%%^Jf_IPR7FsNNs2Sz_Sd}Z!ATkgf2 z^M|nMt9n&Ee-5Rrp=GvRN}3#Tlg@q9aDWu}KIDDZYa>a-FC4%9jEhoRBookq{xHWp zLR)234vzP5z*ODXlozG|ZAEqSS6}G7Z zMY_{GTXNOV4Jz4oi{7rk{?yK&zvn)F9z~|yyJvV}!##?4XqC9PJDR-ktI+=Ikpe0| zCSvn0sa~>I#7SUEAf7stm;FV);WqiIeRsye+d)*D1*wKpX-NJH-960l~PV? zq>NGT8F!8!F8x7XN{~1jeQ*&g`)T_v>-h={tJU(aj#YE9(sRTv-fx`2FyUjxyASfR z5))sP&psl~7z>S7=IBb7{&hme2E` z2Aw%u885f~sUQBX%6MtlW%D3oKP$w^U(;uSI^)llc!{{7&4FBpLEYW{sNsXT}m}T=j7x-I7uET|xF48OZoHwQ%;*Sb|Y0nA#1izpTm? zC+0-CJF2 zmX=%98O*S=5;DD`9LRdJ_dJ|Z@~$%uy*qf( zJU@iRoh}^qG9-dwKiBofiKF3+#S5i(7+o)51*Ti<4KQeQWFE_~&qz`BWgA0iEW+xK=&WMPxQuL7)j^i#%18gnH|4Tky$#wHE1beA z)J}hx@Yb89s_B2OJ>7$KW;Wkdr%*3et+1KgE$%oLS#ee8#YD8YFNjQsQN%=bG&7!^%M{e?QAtjw>PcVv`5vVvbn zd9M_G%kWjy^O4%p$MBFIb&T!lV)!xFZc=Q@V3=6DW!)6I!K$viDX80VfKh(cGs{In zk9g&`jE$rGtLZiepKrEd_QYJxWz-ujR#m>&g<(`J_I-PA;!@Nz@Kt)h#^9f8=B|W0lyB>#r8( zvepjh{{5K@`Lukv^ZV@k46(&C`0|7wvosfb)SlAY$9T2v(F2bJB?j-j!wN6!MHr~D zc9Q?qS8Bm$Tdq0s-zbICqk*oB%09tdAQyn@wqB;{w>T5d*hS>4a!MsAjHO5(K6S%22k zb=MPTW}Id<-H+dtuA;&yZ(5zPZq{a&iHQ4s)km8cchW{%)!#(1T6OnU`>wmo;@$i` zK+QmpCAM#wnEb?EhUE@wO~Ek1`usriSLpdt^6#;4n;UIgNQo)I6u*KKs(0 zHd6O(Pqj>Y6?NzM!17ApcCvEM%C(~!eN^&@%roD=`&f-z7wKnSoub_Lhdg(Z{!A9F z*0`jl+ep?wH1K|YuA8*?zrTjrXGKZ87xRQ~+>lBUTQvR0k5iZITt2mx4iFv8?ipT- z%}B0E=Z^E4PpDmt%JE*=Yn1Axs2f}Y4&;{Pm??t;rWC5vYSieKpe~6C+sEF>Cyne_ z_QoG?kj3$Bnsv7Bl>hT>Dv{&`a)aS;Vg62iYB>5$#~|x1b-3crWdHHgRQ(Bo>Z1Ax zQip1vdwR}Ys@(mH={22D(ob;mw^DpA*=y}MckFU2wL{|5;Jefk(ru4x?YG(KRIF>2 z(#4P`l$iyWRq?@7q@8h7wY=YMYM}!18292PcN=S2xR(4Sgp>>~Dh)|cVRF~jS(_gu zO=eAJT~ymoI``Zk>b$an3ce7gb)i;>T(HrvjB6J^=^d6kle@x_5)8^B)HAfH^-FY* z2}H<~-D_Qs+BmPL>OWoKPYs__ZlzO)&h`F7+M=2&Illbw=)2M8Z5P9V7%u8K!`AB2475D#!zG2oR z%v}Cy!)qdblSKDEyJ~_zzJ7QOQ-yku`b*B)tfE3JnC;c+eB{;Ckdm$YelfQxxW`vh zBSe#|oKsw|I4N_C)oHsxl{&VYt4KO!E%}7>Ibt6zNc~k^v1D3SkZOCSsa9{&OIQkh zyYt~{K2eggnQNx;bHeEDf2&&i8i}QDY1{YnQ$&f;?d##r&k2+H2K!&HVG@iPi#;O4 zn8b9yAkh&}L-ZvVZYupRo9JKpJ!#F4D5kn(`>48lFw+w(J5z9iBLdzGx^>WREv&N~y=Jzr8Kg@G!r8hHNXw-rGzk0$-a=8|{r-5*!J}eNj zt|3s(F$K?%ROXd5XU*cM5TY@u_2}EPCCs6fw?hujVlkhWg;rnpNoS^_-2cbWc|QWx z#bI1FAtNKaW=KXxR@`$@Hf5C&*_1spN=B5CRoNqCr_9W_=ZYko60&EutVqP`KR7?! zbM86M_jx{#!4d3LFiVR)V4})auz5hSmf+mgc+_>)o&9A+V^z!1wXL(&jlMqo1`7KF zjsF=v=4R=7t*}eRBK)E_;{-~!kjm%uMS-^Cz5m{m*2Xg&Qo7RgbXeIX3b%I?(+X9b z)RyiE-Hp$>1y0ZB&L})Cdh&O};1tHb^^;R_gApmX_&M*}-S z90u%IcLLc@2|ad1=kI^6xu;I{WdPUBooCmOGg@+29;O*1!G1lue*|Ta;wIr|-u-M? z1fQZ=`)eYE^>FQ%yO1v8Dt0^+}Mi7k^+3dUBia4?iZ5-jStrcgUi3}HKRoYQYm#9D84|9PY6favV9)Kg=R5%bSH zYSE2m$g_yG`fifjSia6>%ZvIa=i(vfI?-AP#(wuO@q2+5a(YneXV~#AOqQ6s!TgsE z_7ZjWKq&nX>>|Ai9LdGVwU?+KHuqqLAO90>RWCpk2>Qkqd|qLWHs4bAoO6*@D}%4| zuRdTH;cdz%B)^ctyg%#IAQPh-6yXW6OGDNbZ`6x+=3+NLn%}K6Z$b*PzHk2#n!v*C z7%x_kry&ambXSzCUttWI&EDNvMabn^&?(E@hSjnDBGVP>M;Ja6#*OS%Bkh(F5f2uF zu|-`D0x8XG?Crm@4IV63-{Wp!Bd`!fDSnn&Fzmm+>)2^A%_ z^Ficb-A(!Im2zGf*7PyUT>lS}q7kOK%)W+Q-)jCKd3hb-DvY?(Ked5;_%d<0Z6OS) zNO*Sb47RW{f%17PErW>8di4seXezd$vB?>YpMejf#4ZS+R50S%<#P=YYe*L!HY;$o z8o3Q>^;6U_@CYdcAm=}6yDfIg+&?6S8e6uwIelEp4Ee&-*)zjH0#wNPZ(0$5HPum1YSW-kr zDtWbb^0t!(7R|o&wb?U(aT8B>;rG z_D=y>3S?F|lNEP63D|6h+>id11p!W07}H({Y+eefS2?xAN){3`ar#`~T!`JS>`8$e zj);xs`Fc>x#Z<1Lh{5Un^JhhQMj`J+kTd@FC9Jiqen|N$6;N~*l}mC|z;7ImZC~p1 z;ab~*KGC}lFyU2Fz3}V_K;NGF@081Hc*y?m_SjxIupJ8(HKJ_+e5yPZOYZHE;psR3 zsS|BaHg%>zr}_YnXJ zskE2l_TkWP7g4t6zfhk`q+3*j8Wm_TU2>T2gTHNgI0CyS0I3;e=0N!bTbA}O3Dfp{U8wMlTMD3JWJK1l_W&jMuLZ~ zy3ByssMD8Du`fcZ7%BN5Bn0T+(j{+>23lO~4cS|HMMnH4HE-T;i+z~LOh5UXgA6Tg z;oA7uat@z3APM{;zYnGtFAt>u7DnA;Ntl{f=<$z1Oc~^D+^CD2-`naeIlOcE`fEia zUDWFvbHj#^F3L&I{e!#X57Dv6 zVWcz(>f|Z2Tca`#+U$Izf4}_>w>D}QWCKQ_{eSt-K1F_l52yyBj^mi|K&dvhw)|u0 zKz)TO?ZFpdC14;oto#kkO#W-IDtQ5D1963ATT%4&UquIXUoO;^XO4n>j0jE8D|>SD zXd5g)(M>((?*{BfJyuOR4M5M z)qb25KV>taaNaUk>WxcAq;av<*UF;f(T zfThP7QQQH|P_kvtPpoNf-0gUP9K4 zlv|Hyt)WlQh4yRD6~W8hwBr1e`QYzZNuy_FRY1kG>K$sG3=S^pM{1H9L1u4CuBHSz z@Ixr2>mr9DG>wb@w8Z-nhVQUPsk>*wWb;UJrB5EfCm~wXs#_0|?RH_s+_!*7#x`hffMRY7&xe$YYS0=IS45-`?&oBZ|NH0YyA z+9bc32Bahoe(-cBLr2KC;wGq3>Vy}ngaNrb1T;@?nf1wb0 zmKyH(DBv^*va;3u9wZHK{obKttirLz5IG~Q>TgI_<@`{C?=BXaFd{qdF^5pLz9~76 z>VoJy#Y%ylr{GzUhPf=?I?RZN%DV9fF?hPt^v5`Z9LAb`>i^#E3Z({inM6oWbQXpw z7lk!mxMX*r>!f;!o%$xUlZuFf7$b@NcU(~*ulc)b(wZ%B*^Ye}ZlMInsT(wTn6E&p zTMz!8ZIJ;veH}|q%zu!E4y%Xvoql4|fs{)cs}QNFYzQl#az>~`NEy1azF@ZB>}sSw z{XrPMI+w4@jUXaK_kFY@+Oe3)#ip+9Mugc^^~=l61jOyX7L={1oAQGbn^i-ybcArJQ``hTigBU{VyxnUgz)d zD-SWOFW+isp(q=X-LXwEgm)mt3`=Lm{D-|hBd<1yBA>r3K-`^|nqPQ6$M{lGNq*>r zAoH32dqyK#SleAW$e+G~1q2an_tCz>1fIVMn*W}Mun3iKr(Md%2=-O(2q~r@-f|DS z$=8VC(%+%OQ!`6gZU%|=fJr~%6mMSPHuwPNAQ|L!BjaYEW>CvRX1 z-qf;ltYk>pRqq?p^rsO!#CR3{pIs?QsM5n9jxdEaRlgMY8D30-&`aG`A zs^ZZs zr1_j?S5|#6R?1D(?)u3c2|<2LwZ;e{Me1T!3Oa7Pi8VP zpXKaEtI+DT{*F-v-w-1s1zSSwlICS1bCFY+;^KAM?_{$I{MKU0?!D!WSqCKXgkPE( z3GLcPCqJA=plrVWyKE|C`PRFY$a{;8Z)`>$KU$bpxc^l)#N4A<;o9`>nTR{OSOfo5 zjiC`MCY|xuYTShkd8TjoOV;OKqgglCq*D5_Ld4677w@Dku}+o2>1rk&?B~5TXDUnx z=}%`j%m2uZ1%Qo2mu4ai7mDOrJ@>XTJQre_Z<-ndmt8+oe`r(qPg7pmx__-PYOr&G zdHEc6M_7gGlUlxl_!pnF`tCLbkp`70eVz9T!JyGi2Wsn;b%|Tux9Ol|1f7kEl_HIJkgxPpi+dNb_N$)JNx? z?8TAib|ou9&k8Vuz(GSrFJr{!rn8wyjV%_Lt|nH$?140=VR!3WUtsrR->T-lZ^2qM z2jetugk#iQHa9%4+(L5M^CRlB?2($0s$?hZ9adG-t0QZjhpo4K?ND5G!s-ORgKRVy zsnykZFz_}OyF@)YHu>&7;@1#YNO-mgVT|_*%zPM!SW$VLZ>WEXJ$v3)A?uul@J6mX zt>0eGjm4&)`S_>N+n*%Quz+=qyg3bk816A|drdCzw5%QlwdzGpeS zwTiIDvCR`V?_hFWXOpRD=z;I&5%nkEPvqdu#cpc5Z%ChOS@aN?#K@EIhP8xMXHu({oP1>^|v)19`Jg3IqM z?$$7x!PEX9pCiFGK&{u251adoRjX^~KH0hie$!R3i4ZG8{@5Ww0vkub#;L;B9VY`rABwhgX0zk& zK)Ug+_Ss`!$gDff{PRvE_$sFp$z>;E z5Wn}}MgrM#(6=%mbT!HK!-XWsDlTV2`Zxj97nKOI$-RcjY)lHW?l>5HUE06EI|dKs zo*nf{MuVWLdOwn;1SpGy#$}7=0@e>2!ky+#@ZEj0nSOE{+-O_A-m2pbwbhev5*s7~ zE`5sXlHE7Z(ePKE*t5?-vE^1|xl1MB|4*vDv#uH*rcni4ZHof(+o|@wQ?CKZFOOuJ zks^5L9~*eL><@fVv@}|*+y~-q9;|Gh8iN5pNVkovmcU9*+O%UDF@Ev3{})rqBdAx~ z&dwsf1tTW^L>3rL0WxE;MbmTw{HNe2*^UbhfXHZK)r^-1{p%H*@AkL@DDJ-=?%|$- zqan2$qt{kI)at7An+_UOY@wQ#(#E(RS_s3W-p6 zLYkLMmih6vl1cdsT(WrBU9n>NYy@{P$@=m=#}f_R_$jbVZG%3%ROS`fcLjBPWkEQ( z;ek_*cFyt{hoX53d4sa{=g{n)=bIBraky*Im#?NoV(9o!7pkaYdVKiuhoFsYVKjbe zFG;OK48QsI&!6ZGKK$vq;wc$FT|9QrlV*ck5w}j&m*pS5jC&DlUAb%V6J~ntk-q~( zC}HVzE2Nv?0j%f_A*zeLYJelNt~Bp)(A zq$8$;1}vW|oT4+q=d)Dfg^17Nvok-9mx(pdFMf2ly{HrLjPV?%tfLS-?!r|uR7oG7 zN3TW26Wie>JaSTDgSL1Qkzvf!EpikLAMnXCVjsndI`U z@6cS0db@0AAHMi=bI|S-9p3Bqa3b{55qLMj#8+xD1&h*0j7{10VdJN8vLOxz^r5`D znV0uz^q6K;=D394J>OFD zmQEN?&EI-IKhO#|xVS>zI}U-?!Fe(<qEq|_idF`3K#dw>!z(JG)-otg%+JiOtee;_JRQkEtxm}_A?Ia$sPvM!hoQ_*q3t1os; zQDa;1H2Oah_Y`@^6Y5N2LVpU38>tK^<^yvGJZo(o7pE-9)$O);s<^T51=?*NY z|DR=;X(9G0-n!ZQVJt!w+GB_5J;wHNlcJ?9OGH!HR%`On2-5$e#go(bEu#F)S_{M` zV~-gxy{P&fgBZ!Z-fnUU#H1!)-I^}iz_e6y@4eZ}K_(3(qIo+dL`(c!wJk5oUh>Pk2^YW*3za&N?-ob3Z*>loyF>!iD+ zN@_zZz0?%@H2deE)LRN!$}(PFjpf0XCtR+?sd8Zftt+;>6n+TPt)3)>hFi#5)moS7 zlPlOohrYeYQ=*7aVUurW&xc0OgS2xkqLG-4R^%4zwiz~Soy-kD{ zw;7r56yGqVNkC+am+wAG4a8_etg?--dm*i<+gIuZj4=|5II_c^gxKweX-tGkEJ$~8@1o<|vKt8SDi-@rd(a-sAC=f}vShe#|U`IHU63!qA$d|^u^dHEF5Z3;y z7jGN;A-@=v31iIzG0)Jqd1uVR5$RVB+PgYgmnvfEY(8+$Zkf2P( zWH>}*D>U*E3zk8BR=akrz(8M5v1kT4)V*GVHANu8+hZO*r0&>lzItQPx`znnyC6M6 zfMYqD+A-N)^gzSla{C*lPuSKN&9T?fAfhHW_%VrP4y%)wqj}^=0zQX6rFu8O1q93@ z^EmI1BEK96#}h>+u$2V&sh=$i$nVa7y8INxkmhv7tJ59~aI9L_Uf%UNBG4LVR@eOv z3D$UUc%6C%8@EoKyX*ZAF~i?L=dViO#xUWv2Vz?Y*yFt~%v_CG@oj0B6pUdCo=oC_ zhW`Q91@iS6+kZ&%oy>HbWEOBaJ;vqmB?FXNzh^x1lnp3dey!9SE(GtWSI>}_nLxib z_0|sy!oc77f}D?y6tr~={!Brk49pg9nroI@LiNGWxneFm*wQz_B+aA(@ z&u({2$x=jN(4GG%CM9nH`O%nUa`qU|PJYpX4v_;f_jNC^%qhd^CyW^#GP>aKA~MPm z<^-LVG7iXYM#0qSA2B-@Zv!sk^xw{>jG$(4IL%WXYcO-)?8PPZr;yP&z{)GS42-At zYecCy0NScAB$w4ipyF!I)!UC1p=arL?wDm&_#!a&&Igv*^S~qU zHOoSSvOf-PMgfw@v(>;R@ zU#kIV4U_#wNH&Zfpmrj$3k9Dp=eBD|4}k#NytMVdl>ir+Rx4#31FwmPhm_9_LI&i5 z^R?V@@a~mj!vWzu%$YYA;_y0!Z|jwHU->cyM$gN9xqW#KehL&*Z8O>cGjU>8-2E*iq+J|y^(7~kk?%qNNQ zLOH2M-^|?)LSx^&+7nwgK`9a!$cxX{)|hIg-M@FhC_T{-QNS5xB!d`T94dpXBxutguo z@*;T#r={?4;Wzo$ZYiTt|5Qjr?5WW1MOEGE+7wjpdO3+@&3%+RBhTRNLo574_u$Vd zCk8aBIOxCJ({gCni&YEh|Ekbtw|aqLn_M*Ig5J1(uLb_F=&e}-tty_FKTuhE*BYH7 z(4X$Q)rf|OigKH+mZ54t)~~-Gyn-IiF=(=NXyD5^`%eS5z0krl<~?DGr_qD+m3FO< znDEQ{Y{lU-`|zvZR?-X6J-{CGSXH}t1ZK?ivlV)+LjT964!S$-pnc<^3ccS5JjqEn zzDU}F-8ufnM+=g_;uQcz?U%}0oG*eaCg;2q8+lkF`N>p=ATx(9q7o~T6B~qMd zfvPO}bqbfW-avc>xFB$tsYAc(-!BsQQlKwl85L~AH{<#_6*y1Yp4JrpY=Ok~6k7R=S z=!XlV!t{7M`8Y{o-z?NozeSYP^8>JYa_g5R^gzy~D@Fy6)4&oF^^5$(BOocC^Swai zG|u;Nq?bx^03^R0<n2Mf(<;h=Ar zS~{V|9(>7J$`T`IfHZ9!ll**aF#H9ct@nflL{1G+Oujw`@AhbvNZQ-O+=%8L4h?x= zt=~Y^Pecxw|7D1-9i4?D-&{o!$+>}v93uOKnZR_8|QWb~(Uw=I4LYNO-EO znSzcQyxH<#fEBXA2;aC#zD#1!DE{f$Vap$^LvBN5bmb>fJ?3%#vcE9=b)hYq*IE*~ z>GOH%k5U5Fr&rZp8*O2v>h7*q4LcZa_FZG=QYR7_oFqGQ<~j0}CT8Dh_c7*BDt=8u z{sBVNZ~wk|-xZ^6tq|q9-;d2EM#d4$I%1xKfz$Fi!AOS4n-AWy{@6Q)&TebH2guVI zzKA955d@>ta@f@_#6BzR5Fr0tF|X4nM#lO_h+v1jr)y3O_A&ZfeT4TGGKX4LTD)#Y z9t08JX++DhUS*#Da@cZ_b4dv%*2O_s>?teBlAb;+lI7EGLh>kL=znlrQBsN}O0vUR z|L4d9j>D&Mj|&i%uh)4-UBwZf%a464?f@iVZA^jy(Zl4;_miqB0+47zudrICJj_gK zdsJ`(AjJF*pI4mauyHF9=c!$Fq*pTiSR>pAYg0`0f3Nr+31;|b?1JG=3|5Q5n(0tU`kf@?Mt9|@ za-sKFF=;iY=#x3@XrhVMR?rtwE3D}|XZ;#GYpy^j(fkf+%CO}Mc+!o1r{fe;db5aW z2vsZTpX7@eH1C@0ZM$OUPd~k{*PDV2YJ~}MFAiXJo_mT;35+1e2?XiURU#6dwiQx6 zZ?G9{6@t>dGUR&Zc<^hL2*jfy_D|REeJnfGf0|$fB9E$>pE$%cV)xGw8f>(8BGGp$ z1O!!fv78pJ)Jh>CfX9+Y1)bzO=|ryZIknCs(i62BePY{~_;im1vluRU@GS80pI`Hcgq3zUWV<7g{vmrat`=nH~`cZtzQS2)#R*n*-t7B1rUZt| z`3`lx!oclK{8cM=FkJWG=^=R(1!^K*yilQg55x7h+MEssK*GnhEb4o~fXOja=*^Fp z;E$~V?TmjO9N^*UnCou_F_J3{t$Ul`e*1RkGw*otPDN-u*D)Jd+~e+?&8ULeOlB0C zHDll`dfR`vcL@ZViCM6m8v)TZ@A#SFSIEe~9{hoC5Y&3d1Z2#9hP!8zmV*naaOcP^ zgLK#gWdG5Tl(5!8>Y$!=rJWY=09~9~k>7=GMZ>{i%ln{~knT8ewHbU&R2TkfR0CSR zo<8KcGzuR$agnZ_r$$}-*G(?@5#gC<8v^3KYy%-4ezpy}zfjBM0RvSG395c`s8BhY z3BO4C#Qtvh6+F(01xDEK1KGE?&9~LbaZaLWF{jJSC{4KY((*lNd`s_H^h2?0_&qn; zEEXktw3e?fO2qdR{sbXCLt{pdZgKjQX4GlnksBXqDb~%=kvq+$dv)~q%jz8Fb8G*h z(qw`MuQ)_-iM^r;@pt+t0HQWM8v5uCW+ZfWh6Zhx&hGljD2hiVt}Z=IS3+wIwKTPb z&G0?}Up@~VUtDS!xsdXg+6&Lg0`(uF zE-eewx>q=`g$r-$<6cr^nTR`sj3qnSnA?H|;CZMs)$tx$Dh3 z_0s~kFqOKP+2(;NIscqE69Unr;n<_Du1fUFlM&DA)G%~k*Yt&!-9x+;CLQFycf_0f zLaJz=H===xgdCR|YtfB2wyeY_yq;egf{EuX*X&ja;(mzYK%Lp%P6zJu5&jRxle4pfazFGqyq(#OQ^3i|^rwKAO{` zqIb}pp9NLrwHMJyzB{G?C*0YW2T5kr^-1V!nHR|eJU+Nb!hEBXkvh7)qasE(X^A$5 z)I73gJy|CWR@e5220!h3M#jl%4F<2wuGJizoEPaw0{K>(ur$PvFgp~0bjXah&{6uI;$sK!RYI3w|UHCdU#eiFl zip#{a*`SKl;j5zUk~qy~ZMJ8D81Cum7gNM8h=w&Xw8xgv;&*k|IFx&KVDg+$P`oA% z6)A(Q2Ro`jmFITLxKA;Bnl*kW%_s#}bUB=sFq{D$svdifELvc}=;l4OnG9&(TYN>d zAq$YlTYGvYWxx%wg(VuB7H~(Gx5Y(e26XC3gP^~Ku-vXXa4ael?)Z@7~noqpoc6j&kG2#mNniQ|8U9o|z4>^iw!f`P6YWTfca49Gg zEMIaLii1FowcXm#2k?oBDo15`fY4Zmr}Q^JK^F;-alxbx%$WSs7Y_1);zZa9k=G9n zcs(1}fBgb%J9R|NqMC3-@OMt^A90w#y)&qU(*yCpghLwbgfOn;k%n1$GDaI1s;vJ4 zfZNK%l_>|pz^7~P!u1_WC|SI(Xg;)!6mMqb{4H8VD(H<;)+n8zac2V9oKu7?_EcB9 zT|~gCRtZN^5pKw~E<`IaPYk3K$M;4hEdVXq3(rg~3;0Hhek7_|7{th^%-rK%Ko$sI zzt!Cohsm=d2QD4Y!L`u=QXUCINPSUcLiR5Tn~3~>hsY{{{7bg{FGN*fQ>SI{V9X{G zZP7e85HyMKwV0KBcE_-;^bd5y-`*j~J?HuslwKmHe=oeO%XwUfjK`7RLsFad^NE+bNwd&t+G4 zxPE=Hx!4^ee$DXK!7dn~Q_bIT&acGQkNDK~$^Iavj*HsY>C=!M(a?cit`x*x zKq0Z0Fb|_+A#d$JhDfa4q3_B?I*>ji$G@*%hutHnpz-=|3%Mp@l>aR86pT4Y^S8gr z2L?-JrLJ))f#?Ba<-x#tL@-Eh%bxiymTNEXpPUHoTiXK365dnQ;24 zQu1X)uhcevx9}^Le&i}>`0@)f%=YVpS;r>wz1+uKb%YnJ?gaewQ$0dx>H8SgWp}a8 z#o^%()rW{k%#;P?hkw|F5npF%oj8;}PP5vqW(MmvT($C!OmP2SVxcPqH>j}>AF-~J zg|)-BO8=V8^}pJr~%HrUqf=u%243a zU4ii38^HDoSwBsdJIwm1Vvwkq1EQ(euT6fw16qxOFEO%cL&YeA7X|@(psapcF-6rA z5+$nsuGg;xh7@nCjW(UY+>`H1Ph&)(m$P6U_V5NY*(BU~J?H~UBwa|=pLBy?yceF1 zQsn@arydy-GtpqnsG&YP@C_W5yp>*idH`$;90ht?EQ4i9U&5NRrC>E*Ea2nmbeQ4a z`)Efd2}u5+Ja#oN0HlMmVMGe`Af|$a>&$8~sOg%DB+kf!g|W2bH3B(cEitU}RnB`D z%gb3$eE0^GO5|}xRDJ}{DS5aLTk0TjZbrUE4FqNhuEf<0)i7P(e7P)s5^xGB*v`)m z199RM_Vkqjc>PO}yU*M>h>=a^q_x?A{zn!17d|Y&HPGNKT6zE~$uj;+DkjDY%(W;U z_|l`PebEAH0%ACkjMg#j`75{xtFv=J))KhsmCq)!vI6atqx1bN4uINoL&Y9lF8oKi zP}86^F*@fTP4H-T9tc135p!?pfDW=;X$6WyASvpJX*wAJey8}+L3$ZLBcE-=413X| zkBH>hln%&n(IDgm5k`yNzi?h9ZAcui7rf`)Z>@uRer0U`{frrHccO^^AAZ5`YcIt; z@mUbAPLm_+ZVa;78o@g0y zkZ`Me2I|K9U}@j;0)Eght}Bacqive|rYh-{IAmaJ>kIZn8;)*)|-%S##e&p&-fOgRWuxDlwO^)~{SvNZQjTGd5eAS?pd2>}SFJYtzK zN6)$q>hDmPq3!{$hHL7@I0s+9_gcOT&K~ShER^bvrfd4x7bZTyJ45@39*H>OpXD4= zj^nFv!A?%2R{K&k_NGS3!N-@V#cblCrOV~WAJfVDNJ#+ay6k>$tK5?NOSSd&E z?w~DsmZ@l9v_#9t250=}IT;PFjT9=##bORDIltxEwNQHJ4^6T)b!fY5VN=(SQZ!OuA&CEGFe>spFl4UG4tMQt zZ`~KtM9;6v2O8Vdqfun{wmA6SqvSh71hkdmsEhc@lTk)%yx7}V?vbV|`ta80l*up? z)X&;N@63WU{%dP@**p zcSqgH8D&hMIVzeeb2Mjt4L@%=RWTd33XO}c7}NP=(AhbX9C<5d{I$t=pu@#e_;2cE z+UA3KFz_x<;y}I^mg=p(r;Tibc~g&~(xc{~kzV_h?$jM(I-i8VX-s7$Bzd?nx<#0{QQJ@=x{mc^@hDHJINZpSss3z@bjJ)-4SVdzg zX1)CnMzqw6Jy_fYi(hwSDNp}|SEm&sbS^Z)o>~jHSI*UdvU=_Tr@B8J7caTf!R8K= z^zH{L)W-nT#Z`&rvQ|iu-ud}({}u4SSLzovoj_vI-l0U3FU-tyAAQ9X0&u~0#Ivy# zw(!i7KiPi*?p6w_WfS-TzJzk7<@*oe}NMBo6AM7o?k$1;fTl>d_lXUyIth7M~2IUk2hq_S6` zR(b7>28WY-$Uo3Y{NOh-Ys&i8X=f7)p7b%c?p;F!T5gunQc1&C-YLg}va8sK;t*GZ ztYu`#mM|jBd=8VX_U{U;8b?IZ>szuHB%xR^Mtqa+2s^)xzBem!M1WvSD9~I&?Q=G@L}FRM5Sl{p{wQ+wof14#WFF2nE@}A?{^Te z0a9!*6(QItAD!M%vx@9DCD-<{j3VRKy|H;GI@HWt)|saqeu%;rg+`svGlU@b>Jzuw zr&vxYmHy(`dn{$1nOAy|9*9IbJbZDGhHRISDzKzwU}a+3o+}yYNYCI$=Yz01M11k@ zqSoXhW^{H$CaS&~`CGp#$s}EcMerCsjxuXOx+t@*Tas^LXX*c&8prqma>vEILb?-K zsnVirC7(fr9;)9IVEBdg`wB9=%b*6s6(KRFZYTmxR#whiMtuk-+41~y^(L~3vzK!D z5kPPpr4TUA3zi7hULPjNfU*3woi7&WKz^~}&EltL;g1&vPsv!>L97(_a=wEw{MJ); z{rjR3bej)(?;>~x$fTE9YS|G&pJBBIqEJde`aQ_A;hrR%&(66^DCPo)mohHC4&wtZ zjE{6(yI7#Fk`P%jArrW!^{KT@Uk=bpa%4Q4wSn0`ee)O&I z5C{q}@%FoT!0p`UOsW$hkf$2w(Nenxa@DEXJs9+%&c`)Y`9e#;kKQjY2BGls3iq$v zaer{{R8D}wiaGc$!ay<2DGWY7*IDkeaYqih2e|x6 zc!s&%4zgX2lMr-v1pWOs!ak+WpqMhoQnBL&G@KUmzSr{z`2Ar!629&YGY=&0(9#z6Y-@6l!Pd5XJ z8);bQz;AeH`=zLO<~LZ;aCe-TtO0(e1DA_7>VOk3g=#SvhD9}56$c^|=)?k{bxQIw z3=j18ZZzKjb#a5K-_w4>*J0-mZDUWN8jm|e=uV3^X>t4sR~N^JjUt-Q9?0Q5x6Ad*K9i#le*G@1TbTl;*-xMUHR}Xb z?Kd6@X2yV$q6%d!wE9YIwtV8TT_*Bb2I!tTC zZe=cBm0i5g(D4yx|D^l-x&wx%NqstRay1DJors*JpiaVnacaf%jYFJ?!@=rtY#qMJ z$(yQj@DYzDB`Fd&tVaXLYo>Tv-lG{y&3%{Z!_mNt5>;c`ZukI~pLj%z18T4%S{#Ws zpvP)gs^#5k(D|+jqV4Nx=$1qj;vMIUEBdZf_W~b0kT}?ICmW)6&fi~Vjy0eKrY||> zK9`|2ii;`wKjP49>wv&xR0_Wq6)XMcIgWE=iU1OT^gPd81zzO~}34A1GIW z-VeOeOGcfJPMi3qCy99At8#j6Muyy|-ZxQn_o@}DqDAV`Kr4;Dn%Qns(mH}yX@u@) z`R>5#DH(i{VG~RYe}81exd2gGM?N<`an$xdx_23f0BZan9pwTEF+QVrwkL~p44k=m z+hU7p6MTq@q^Lf=j;{{i=-9Z&j&GS+x5b(=qOs?66G|=-;}KD6Lj5;i!Ml~OHv2=E z(7`Wl&f02<_-2zV=ii8ZAjcgxsS`nrE|~13OtR786L?c4@i|+R<);h(J8e?@fWmTC zVN4Y7O^;yBNjZ!`!Xs+R|lZay=0kU z(P3~yIz)%Myc;eLmIy4oC^oy)krN9XzMv=(<`I`zS8`3FLM?KE1l$_tTzfF zwx|6jrpg`?W_l8pNZNp#go2WmjK#HFV9ok=+>M z3Yn5vkG^@_1#D*v|G9s$gpExqwH<$Qv$DHBBLejBkA{y)@K_SgAs)w`?|r& z_k)UK(nJ8{SQu>)Y0bYqn?^&dS zVXbE7=PI(UYM?Hgymu0%`{6=(lNDSHV$E2cmjYQeBFfiN77%r8v8VTPCo&T`v!ZJ_ zgV7trt-j(Q0e{+lWP4}vfLO`(mvvh6$mI3R;EInQFguOrxX{vBWZErdM9^>*)2+Py zc=|gH5bBy`uPqCgiGrO5bswX_pymT=YkM%s?#&eOhp8pj3#G>7?DYzL9= zb%|eki#m{8Wo<7)!bvR3`tO?qFGBEV@2%o(wsWBL(8x-%PZ?-`zOgI*SQn;SkukO~ zUk4WSiqu1!!LY7P@!R;uR#gNI=v8_2tQaH>4eJ`0lL5T$;LJaFQ>b#CML>Q!1N55|nwa&<1G=er z+Tb-w$SJE+ex!|nv3X|pI$JBKX2Mw)()s|%3mFFzI$j2Dj_F74GBS`fT7iZeR|90u z6!q@b&d~S=_0JhR0dROU=0^`a1R7*N%?E!Z0ZsiBV2iwfT;kXATP)uJ4cq+m8#g9^ zl+WdVB$skQ(IQ<@rBpP0^79?m>1z#Wo)q5xYg-FgOLCKDqhEp5UbJ>%r~rJ*d7B`Z zk`159@v1y5&I77?T*op=)zC|CtxcJ^5IFj~7Zwv{gN;CAQaRfP&~jq6eee83AY53y zEjgC~Up&W46wkDScV^2x8VZk2diVd{z;%DPnpZ+oUU3nWj}F*AQYr&VO)4Lr^%jGu zg;5^Ls8!J2;TNaj~OZeM^kGGO~=Rg{xN0V6X zGL+D{nW5mc1IYEa6s{>V;yMaXN8D%WP;I?TyC-o|U|mE`A=V4Rb0=5JSlS*CcKexh zH{Eaeu46r@El(6xFeAD=ad{SOF`f^pSQ>@GK90jBybFMl#z1-E=pWSiRVKsqjRDp1 z?D(=wun6owvCjV^T7s)imj3Z+o1kU;*}t|T8aySjf~~xT4kfsJZA{ca0$&fkL$YnJ zjdoNw1Hw`Z{EV_Ucf)HR^kJC&>ANTUKgDj-eKH+7RC2TY{uO<36!qCaf$5nxZwOomrt9LHIfI^nu6m^k{!VR90LK z7g{px81Uwq1RmliFLI&b8cOaZ^}KCK37>y-z2-8>3E$tiwIj#!F&eUO`uan=2j0D0 zS}~@nif)9c9n^}Oqwt&CzwL<{w7gu$Lv$+#Jsp%H(41z2OQ+dQ6rK{mFZE?V3H@M* z9z>dr1bJ1WrL~TY>o0TBiqd$}-eyxYUMuzkS&;#*m)SvC-K>FnGBC2!+ZLew^dwYk z*V568S1+xZUbIA;)#U4Dm9+3C#ZRnyx1>>;gWshG))}ZG-}hHpvT^7LvFu(|gB02r zai;3oM-|-doENi7x)NHGV8X9absd!rxZxv1!Hd(#-@NSE!Hui9dfGe4vZLPZ5sjTc zNpYXMvaVL`#^{{UklS%DJ<1)2+|*0IfM0Z#mAmalhZ-1h#vjywfYp^{7W8r&Xp**w zXCtW?I{xZSW2QbmZdeWsv-!3F=Z#j0+gty@)=Tpd%^)$&{c1zixQq=wp&E2b) zc?P#(Fz?-TT9)ysNeQ~)2< zj$mUadn%jRSEPCGF_>znO?vk2K9FquTH0v%7MkS#_)(ct39)e^OBT6W@JRKBZk}fy zWGU;@2<%%2$%HH{T0{#l$|e_~oRH4WflA zKRMQW!eAr1XbHw}p!T6(wbZ8#raYp*)Ye(hCqI}Nbvh@ zDXRpSYm{g^4wr`RYM!Tx55fSIRXt{1D-F#KZ_3s_6och)d0VOLq98EQ`!=Dx2z>g( zold;|Brju7e|sQA1r*km6cW4@ZJu+XqOukh6^z&@9l{h=3t zGHaNQ(+I%&cSq#S5*$EAc|l;6cO4rxpuwKx`T_lWV=R0*C!Cejl7TM&L||sT3E-RK z1p#n6-^ZE(g4v|{^IfxuZPBh?n^r&8MQom@&DV>Bihb3w! z{|z9WKVwxSWowXQhnC!8wzrtP$>5j0vwMhimY(cj=Pts3t!pLZdo!kJ5clJjM?F%b zV|c)^+l&<{#AJ((wj;)eGE%hJ@rWXy2P*nY+vcU}$B1y*+t{Xus)41xYqyNCcfSNZ^3>V;J-p!Fy=7WtK z=bac|Nde3)J2LUMC7hmoC6lQZ4cH##{?u1JLO6ZJ4n);SAe&o)U&=Kq5bJ8AS8$#Q z7T>>rU+}vxJfk<8*y4H`x?NJ9ksy)+H7}|b;(#WkA)swNf8+&%dg{o}yh?zQzaQF4 zF&<%#U4bX*a23G+V^@vP${60n#`(Y83IW%;mkc*^(qO3-)~Jz_4O%Y0W+eG94W_-T zeZD800hXCRz8Yf9hQpCU84ge0!Ifz$ol&Y(K&N|IC+cM&Oql!PIg{=NF7i>>&5-1S zBhC8w*F#OPg|F)8+u2*tn0JalPS+d2s>%qq_&`W`@H+OQWIAA1VD%5rdIx0rLUZ50 zjDtLca#Sl1d|=6_H@ES#M}R+a*l(e#16oYF{Mr*;1am?XtFSE={uo}Pv+zlQ>#~Vd zZcfGEbCc)$k-MWXf0{Vg+~f-g;{M2HOb`a*KCcPN=)49m6MmQtEEGex>MJsZf*a8I zOYm2+EOGSJSj9`;+hgDbQ+tx{w^8_X?XCEm#zjy)Y%OQwMS`cem2p*Exr`pmHYyHj zPXTJHndgvy5=xp1X>Odn&*PYq1GcsUh`h=b8h4t8m8nPJ9b1!Nn1z6=lBO4&KW5=y z;ah_j4n|$HiRsbL*Bcb>9f;uH_uXN_Qhi`pacNv6^yo~3fJ%$upJw2ax_|U@y znoVURE?nJxg3>4XBC7s4>!|fK8%{I`Xl*t>0^&Es<&~kDXj-c%A}Q^T8`j+u3}cW+ z%`$ZR-iff|cOsV~y_ja8FnQO4oCyh<^r@%or;rlv^m1F!%9$EBT}wIJ!NP%lEqbXq zdX@`+-Tx*!a6uEldhTIDMnEFEX(@b>P(TbflXzdUd5Q*)_8-Y_d8&Z6jo9YWi#p>9 z?WuuhDITD2zg>PsZz+bFa{T47BhkVI{~Ou>&n(a@2h#O|k^%TAdTV!)I~=vU(O=kd z{t?R2_oY1ZOEjubP{`|-t&c89>S)fhDdR>fajr&2~{_INT*J{H+vmFBA_;^pXES55trg;pYfno zW-cD3+64HoUzaA!?_vP;)G8{vwgdifX=S*Y%Aw-qx%;`wVM0kkI{{he~%gKsQ1 z+QwN-@bCox_i@Q$c<(61vtD;@lymOkXlNTX&K$#)0Qh&|tl;G~hJHKT+j6t3jZYls z`D3>7qg)tG@?G+H*3O3SwB9&NX}t)4T=6_xS^OJZa}7+dG3tTJpQSU4d}`p(e_Yl} zd37Mv^`}0Wb1kgw5BqyFpbK8XhK^=JXCMLJ%rQ-C1=w+Qo{@TC4#l)!~0T0gMNQ~;ls|1J26DT z;PaxZzmGu_WSpqf&@*@sW;K%M7blBgK4;&d_KZJNkG#2N!W|8ISU+eRDkVYEdzW$| zZny(q!3SF%lPBH|0WsrnS24){=)+Lr95;{-7vhO)U&HE^ewZ?wyMR`W!M*B+PuLlw zpHBn@PVU<*xlcXrGXc|&8>f-L{xG{u{urp}|DXwB4)?@?!MC>3{HdU?@q>K=a zGwMI6l7TTrt69(Q)nllKP7nUT4cSkdZ9AgO#agsVV}r$)5w*Tpsv`*j_-A_1P^9H4 zM(@FzU@=sIurO-xO?d-$trZCwC1HW*Gy~Ev<`BZM3A-alJx#ECJx$bg-U42DFXZ_qCkiyn z$Fye^WI}N+w^t?B(y)J0zMa2G1Ka|X-DIDPVg47IpuyQYAi{{DotG^PxNIL<+;QN7 z&fbgxD?02az2kk$$QKu&mZY&twGlE zeE)uu56(6m*d&(*bxgr;F*+AG*kD!uYw`}*p-71H`<@D$SxQMGa&Z-W>$wSgaH zgm}1&=~Z%b4s`pW{WGzR%V^evOoJ|w*Fb5k&ob;(D}1V_n#Dyw2ILgWP3HOObt`LUOG4=*}~@Sx`hnpO0Fu6*GkT}qAy;-yJI@enML@bJxk}JLQme4Bn=B%dMt!X9e*Lh zf}~N`$I4}ujtV%z;iErEo+0>c*}SOcC<|0~?7jA^WCL39$#3uZi3gBeZyJwDZbND2 zn>_{%+tBMb<@7Qi-obrD$xoRE#-IY4$s(hSE$Es1KP06>Fx1{}SAC(n9laF4cAJaU z4JY3G+)AZ)ANNa^zjp6q9vY*5dgpkh1J%DTQ?18>p*wwZ((!esxFgH_=g`JTwEZy{ zz9W!^Q>wGeZS=iCaj|Oiz-Jxk%BXP~zk4u#z-N#TVUGRUod%rZ?L;hRL=A4bk|V6W z*MYCFR;HavXvcTkOp)nGh*LHFrIO=)jgw~_*t^`T#`idNy{3#iaS^G_cq6wCyv+Uf zFWJEs{FDh1i;z_*-q|}6s$!as|B7#X8>QKSC&gJ3-ehXWt29Lm!MQNUp{S_yAh&zTo zxyp)@QV$1u5YnLeCW?OV#MRKKpxKM2Wl|{Iy1lc0+89s`k2 zHa@@9H3xU1J_nSM(}Uqi9{`wBv=%yp)UaROKeVRW$R$nP{}4QXbiBt|8eRQRu5;m>1N;l z$_GQI_@uK&BEjYD`YR@8(_oG~{%lq*!0S@K|+#r)p0sSu1J{45|!Q|jp zUXq?f82Ir*S?IS)Sgy^kJxUP`esZWMHPITtkBZ!cLkwYXc2MW2F}M|Sq)D7IxfKT& zde8f{GK2y(vfpm8Q$CP8$4!L0(h96DB$mkKzXVnDdc0o}W5Iz|>g>h|f6_O3Oux?0 z3grHxe2`Nv3@1J<+6wmiLqFS_;;Vj9@Y&LtgNdcG(Y+dAX%eWe3RMeR5mD2-PaJ4?gj~ejWW{m$qg#sw8Ze{PD3V`Q#5xS6BQ*aVU z@4BsWgz%*L{248~2)TPX#XBl4gHrOoL-LC*;MI=YCc&B(XgD)zQL7{ZgZ6stKCQ3; zMeg@CzoZC&29zZ3>CuEmYN3o@Go)ZzAFtd(7wy-_qKle{M zBG9MH#y0h}5UAL&(1=+$#JZ&8lHE_Z@57fk1c}1-k-W8ShEkUNMM^-Mh6yL{AhcFNDD85EQ ztj>Pk-`&E9%VG}7eDn~FMgVJZZ30$vmW8QPyaZ{wsiN&ex`41+Z>LfG zGsnKTof03K^T8%c4U0e4h9Lz!sqT;I^RTujZpClsKVYmrUbMVd+_8A)>__{-kx0cA zQc|{sBy4lnVsPYR8De@A(|NUb0C7>{zS5S+3C};(-S_a|1Ys=?7v#?J!+wGldfp6G zFh&?4(jasbD7_Z-%(2|Uo~k{{w(?y=4kIfqZsq>K48r*xSflVPkqM1iDJMT!ma^El)7B`G8$XFjSD?SVoTj(+oV0 zCWSk{Hjv0zE*Meq-MlQ_9L@{ztxxLQgzq{3g|Nln0rkprnOT1_;M0jpPCu?uNLsty z!gj$3{wGe+$V#jL{+xUJ_fCf*WWF0I-mmTiI0dQVlw<2*dP8R{FHH$@+ux8zNJtLY zy#K*zo~3hAfEjtFHgqyayf*t@^K=?e4;dXzT1UsJ0)5?JbofmA- z^9FR9O!R2|76Vs`zVj=M$-vP|HK7F06v6J*TjI?_n(*|v0x=_pGYAk1F+KOv7Di3& zyzTXxfx(QbDh!OXpht$9ohNn~T9B<(J)b`Wj-4KbOEzriCxYY53#B(^v&KGi@wG0%hlm^Ir z=z>0kr)y(=eumHAb2v8HJ%sH1@*8B~86fS|)#S^+@*zi`+4XFzHek0hEm)a847ho> zg>xFCpxygZ-ghK@U_~@Lim^QaZ__`#i3Tk&?v5{w`8WnWCo~=ACYVrSu3e9UWj@@A zJ6ye}ToMiZev_%?p&A}^%tu}B=8Lbn2xe%yoW>)Trtf`c{S6*BkC0JaBE-cHRuw{; zgi!B9+ecmw+IZ}zek6r?8Qxi4t_)VdOba( zB%)yoTsOQtWO4Kr5|Yfl);Qb)bu}`-#Tw}G(?SVn|7r5$O(n~FH%<*hpZySxh@E91 z{*)kYf@BN&jdXol_{@MB2Cm9iMRTEpQ%V-X6gKzu2NT5y0_kL8lBtX9Ot}U8h zj&Aqr62?34S2PV9^Pvf!d|n_SeE6$C6*ul-Ydqp(v2KIg{V45KaZj1Nr>T@m=&=V$ zFleyH-B>M7po4z+5L>foZTnlaH?b!}<4g}4u&y`tVH-!C8K!1)**eiuh7y)XF74=7 zp`N^NRMn_|P!a)$@*DK?=v4lZeUdY^m&hEKbt;f%>m__4tG056?pJei9=Ag$*$-X^23 zXLO+qmjKz9I|`oTw@{(Q*Ho2w=}4=*|F>6o9roaA*`uepB-arSrL;48{48bti&{7u zqII8tDE9@foaxXX{VX5%yL0K3T$LHV(WKeAaWNDVrUMOoI)o9|0CT@F5KP1+A}vEL6vO)GljVbZWT%W za!AAz_wg85d|Jkhzw}X(-uWVnc3YRW?lPnJG2@WpGw6canQ;-ksCL1hICYP0j&tGq zdxooyi7Kd`p%CAHt|*=uDps4mc?0h&ET!rfG{6ZC7=CMn%b?XSg`SchlHspI^*@CO z@ZgE|zb0RhYvM9a8{U*xB+xJU^uCPd6zDnaZO6DsdYpcr-GUV%MXhvyMRQ50q7Q;Q z$uz=AaF09WPi`}w?GOvIh0Q% z+r*jX7a0DWY5q5C9yW$~7w=dO0P=mgecIA8Ff&7$s{Uge_I^@WLFZPXHIaq#G;trO z@g$DSaw>ziDqs5>G8-VJz{Buz!UafKL%}x1eR5u1cjYF(SPh>Ntvy+u&w)?X2zfXR zT7by8H`yA@E8sNFbm@8Q9B7Qd%qSvH&L(<`Y_1xaKwJM?fd&|_2z8KKR zudcqAVFSHh)>_9U1jD_E$HLLYRZu$Mv_{OmEbuhcD@86z9sW5Zr*w?nfI7$n?$ks- z@W8^p`a()GIJ4ZFG$t7da}0BT90|I?R|1y^;s)HoFM^rC-ezy8oYHCLW}O0#gChqV z#N*+JL)xnXbz{&!pj(YF#Q$5L3b7yraoQ%eN++z zSla*B{LUB1&{L3c-jsmeHk-b;>A2yvNW6sFiRa)s>)yyyLtcozyu3>D#0NS!IXXEJ z@IuW+j%;E}esD^I{RTfLH>B$O$Xc+)4xYAR8+C{g)YUsA5VREmgIeD`3SQJA7Z*M% z^eOCMn(wap^4%l_Z3(T6es`sTqL2XOUF8A-q73NiQ>UQ*RWbLA3O^Cr>%ZTq|D8sh zDd?levcs`CyX<=6 zio?##G(66v5J3uc7R7?}jj--vjj0EC9QN*C!@HKhb*)K9SLXuFd8?9>y^#LG6g8q_Cgdgq=!@;)$CUmE6BZ?2KJj#%l@AUz!}Kc8yD2mJ zAxx=~M;8JRulW{k~_}~@@Q0I(2V#Wc23jq*`p7%Ff)NVz<;$8iU0dz zj&QIX)4F%W&o9$})bWZ4K5QMvmRHqYP)ZD9kzWN|ZSvx=`63^M1Nt=NrRm@9sk&#F zmUcm?&igim?N1V8IOl7m7a0!>QC3F2cZHNQl;6YpNZa#CiW8C6fcvL~bLz18SL0rJ z*%+q9;aF`nmW+IeB2Tjo4h_VHq7cG$hn7s!5TJzK&`%4wjP;106YvZ1H7b{-mdzF>CCTIKhtHW0Em$_E8gl(1-rwxIPs05z}WC1ZzN0Z+o&s~R%lut}8*b23Z; zyO;P3N*wAT_q%p2rj0@9_RH1r)QMO7-NqbY2DuBQV>bddAW6t13fv>9Z-2kzpLAs0Pj!P>nyR=hIDSRgm; zT(Xr2bjzFl_pU+(C`8PA%n^FPjvBSU3Fq7)(=(KN>nZ>~AM!8!M=B0Ug3jI2{C*M4 z1jyfTG`azntiS$ecI^Q?kf*C(Xl`-o@kbPsuR_5Um(EByErl0s2OoXUU z7ACxakC~2w?E-2+Ru|_;PVOj-jT|I7?e!Io?buHg@+3o(s?mKu&MeTa%La+Liy*V~ z75}%NdI7`Zyph$g55Rexj&L+A8t!a!Xnw#H0Zu&Qexo)3ytEpOyiL>$qZY(25oz>* zWQ%6g7k{NuJID4fj+zSifB;jH=S3Ry%_TBHyR#NJU;9VZ-+?YTt+k>504*8|$JD@ms{jLC8AM~!> zX?;O`0WBP{Cb@Z45N(Xsh#w*Q1`2=u^_3Fbgcpeni7$vIK{cK)IZKT6xR}6z^&c`i z+>`#}aIDe@oV~|hw?qFOr2RN2qve|qlNudN|MBdC3q+))I28l#9GJ*#Q0ssb-1etB zPZ)uAT{shUqk;>K)u1ibew~0bmepZ&I%TLT?oj`8M+ujEAX4t^sD|HY{F`#&+%2^5 zRP^DPiWkmeUbO!2wJoYtex-ZMoCX!l;-XNJlfs=EmHXTaQM~5K*Fm;%12ofJE7=>h z!P~ySeobykhDQjWy)xJ%jfT%h%UT+rN86g19{C0-;qm4x9(m*zXcbDa?6SHATK=`v zW?xXi#izdy^*;dU-Oia4OfD@>{yW+LGro@V$kl2+dRBrGPTe}*4yr&MKa$h$sg|Q( zZH${4Me|Wc71r;Zf78*^pSr|D6b#ToA^RsOs-fuekG)UjZTC^mgUbrcKO#`AO0dcr zbq8HF__3A*&GD<0DeQc7xA5(w9moIwcmI6hM;f_(1HVud6F+TYiaW~(iM`7xXPr`Ll=hw3_~Ufc=~E2-=Yc2`Arsh~&P&62NvD_2EEeMaW~P~= zR3-SNw{6Y?tvl$@8*_i+Zf7)sXU=bX&le}GE=-ucAB+F$dS1^Vb|3F!s2b}`HpOW> zNHjRVtKiz;-tQkJSJ2-qn{{cSwrE_x#$N55JsPBOM}|sD70oemcI=DiM@K%}XYdI~ z;}uvb(BSEwS7CErrUAC}}! zPQO#ZGfVF!yl^VUM{PgEm}%zY-_}KZ#)}TcL+ zdz_(3VBAZ{8+VCWF@5wJ!4s|?-S|r-gYrL+LzS5?;=YvUXRQUaamkIv z%tzDW=ukKF!*9{+fN67&SU!Uo7y7F2^mSDl{qmHda5Y694Sn0CqY!-ZfBeB_w^EB3 z*E%nA@RMl^5bICdv8)lG)Ta)eL}&SNDw_v6cAw7T=W;9_iT*eQjnrp|zKV`Re;I?qYD5#5ZvUFRY zgM0PO0}WT+gAliHUbnUbAi4xN4u91EUOF_MD|rmgeTq5GT4UNC#$W!vdkd`mLqj_zDk1mW9!&?Vgp%PO{dV<+pr&iJHgoD6_=o;# z*3)Q$+Lq%nq~8nS=X6z%=ii&bcpGx+*_A;^x5<%Wp8OH$N4~ri6J7@Uw*r1%yqO7Y zy7`8J0_p(S$BBn?1rs1x0Pv-qY6Nu8&oaq!6+kvI(*?nT6d-S|ZHsLAfGX;opuda0 z;G*)bUd8?kc=2*?tk1qb7|O^vWZ=^W`5OgD+^4`39)x^g->EWqM8~ z|04`?D2DEuH9AAS7c#=1f_*?@lXZ=96$WhDf8sNjX~9>1D#xqmL*c3UT&nLg{s6}Z ziTp!dA#EJJMQCCjm|%DNhu!sq67eqgW7J&Xj#7!A^Gg>n^kwQRnT0b9FSo19n~(;B z<3g6=s@~A;U?*XYLj_!V;`e@jZV_AgvZWCE2Z3L1EjhxFKv=Lzz17#D3bc{96g-Gh%Q&c$NzYPqsq?%pLpu=__A zJK;ZP1;}rX{_us|6=g1K<9g7=Iaa;sw+tY0X&DH6!w=14j{oDoxQ8g~H<-8y--e== zgw1VAVsPunCYy{TFF4BPZKMfegE3Z(G>&cOz`U+Tfzl-fnBFcXEBWypP!X-B%7~dk z+F4%LzeQKE>oOBh&feTY+Mg4NiIq!$T@Bt(OP7Bl-bIUhUr+eX6+%bdnlEDk{AU}3`A3m|*#rURE?dws zj(z5(j+|HSLy824U%E!Tz?wQFRs?dk5GMg~y{0oyFp>N93G3PUn9%aB#L~Cth>nz$ zs-X2#%=6&X(jTHlEXv|-t;^La%<00RyNlLSWP;7Fr&1sd8?RK50gw-CqAwmkh^)hU&d^hfQq^G%z47|B zXHt;xox9J?QUfryxDmOF%J)uqV+>P?u8c^{Pd}6OPu!U9(raWVObBVr*7l8F(7`T% z;HO`pDfXSc;9{}T_trkW{>`7iI$Ie<>XV7b=9CVzn*Q53I%t*JSn2lwX4pr{LRm-0 zH?7Ho^IzF-eozuxt9=}+x6rDaI^wX~Pk_iBsIPZ#i6f(u)EDf+x|Nb*nWDdo4!3^M zE$poASx|D*zQ=sqWxq9BxW9+#9Xlo{6?q|1c)C^n+>IEOTPsTAYp*o>%s;nA&=Y9z zdJ-eaOo>tY-YcyE>(_H><7^N`x0?d;(awls=$_JsS1_jHXDoHkwFJ3PmUuSszhPv? z?Oa}lo)wnTIZrI~$O;Jw@q1wY#|abL9buT_i$Ru_qDDj(bC9@omq#v)=Mi2tbLI5= zQW)cB&)7*eb)>_wr7o@FHb!ScVChhnh+W+qm9AJ!uvYEA zj}x44AUEJ$tH`5BOKZk8{zxH8|TwxO9yR@s6N=w@Ye`W%(DKn>@aa zz2}G#SI}BV9H@-$*4eIN)hvBp;)|Qeq?}3I;TAdMmRiU%cVh;X5AGM8i^#wRcbpme zgNiWx?&YgJ+Ha8Hke5FHx)(5c1*#A5ClRzG%uV)8%fU=|#E7Os^O2v!heU=Xudut> z=xV#gAR_THuPyT^0ZI9@RyZ4%z;XKXXgj}b2A3B7;`UYIj$x?VhS z5uP7-S9EW(7Q6YUYsK*TM`XxbuX#Il6BEje|K6I%0$gt5>xUkcFjX_~%ON_}=hL8o3#$)kC>j6|Ds+IcO;IQNMYkK9Z7ERa?$xls*~h?q zqgujA5Qq5}&X8P-c?UOzC$z5ry#?NLM^BGQ`#=kVGa>w&A;9tL6=u!hC(z&sBuuL| zLQ;xL&18lu(Avkz_uW+kpfq6A(9>-N53k7nxz-v9DAOzV%Pi7?{gLU8#UL+mOzgJ}mOQ3-$L$`pOU>I(()|go|mG?ZlOmLQRPlelx zhWHx~dPnhLDLimpoy5h10__peI4vGSi-wsD5{O4~;$;6NZlWnNGC$3OzgON{zx9X~jbn3GFx3z{olUY!q+vbn`mTmrm89$1{j)?Cd z=A@LXvTn}c@4Zua{lnY=t=eZWJVh~fjcF0Ur+#AmUDKdGw5Y%C+ZK2idd)Y! z;~!+!U0<6FrNOHhL`@=+NN^>cQgmJBA50-sQ5agHK#e6^m8`aDQGsxdn{VpQ;jM0d zOOg~Py`tNpQBN7l_Hx;z^^ORzw^x-?D#LE3b+!s1wCybMvDqm1g^lhnMl-Mkm>c7-9TR zxD3sqp#<8PxSn)JPaF*&&CnFSJp$X1m)(Bq$54dkDVm~4gnH*ZS0f}Cfl?nrPdSlL z;I5TD6~V^a&}en$qT|b-fYfbTGf-d}WZ%C@*_W~pW&WzUP%N#1b7Z`Cqg}rO<_&ch z$E%AFCDK@0Az6e%t~B!#x#Xzz^|Gd+A4gzpQDH6U$pHMo{$Hj|*95=_p3Ui$ZvbVx z#45lej_c?>qPyxyk8<8GJmttmhvq(BC;J)y3(B5##oWZaATE;YCADxG-JvpV6xJz086BzkTNTHG~tqzP;UF?pN<_t-uG6^1FbzbD-D-zxbQVpb#YCGz+s zT8{%}vIsw^5nmwhs3{I~mZ7VB{IOi+5cr`_KFR!G02F!biFnUe!j{x{LW;^%`057Q6!w+^0u*t_=X$ zs=aHb1|6_khW~1>RtmVi-x)hcQ4P#)@a6Psc7l;4#p zA=n`L_DPrD7>wDJc@=0U!|!aVWC0ElkVW@+B<&~)nAuw$N~zq0n)=_r1O>T4OlJK2 zUTeUK|FVC@e)Jw7B^Y0s(6|HBy=4a6)9au=}U1T)w?7IPVxRZ$^3!q*8pqrs6I_Yb%!v1>Az*-cIUYQeS6)Gi0AH+>wO( z!~`V5+nkV$L0e;f3BBfaHX!w$o55{>wVxPC~DI57G)a+jC* zB8*wRwwXhE8YpcsF|-SMz+gHX;*i}FADMf_AWwoYczlOlB%PZZDk9P5!Z;1!-Wtdx z%tT>OWYZr@8wNoAjn_yqa0RIlJJg}R{R@kX-CQ@Q{*8!-Y9NNOE_Az|3A{0naplH^1dP2$3SJjn2-q#hL|d~WUsUZQRn8v1k@G3Y zY@XuLhcngKqqE;=uWGzRyd2JM0kjzN?Jl&nj`)QAna$rc)2hWjs08_O<+)4Gb zrqi%lrNpbzXG4$_`+W6$bQl@ok?!SjeuZQdy_ysJ@E`Vo+I)qFG6u>2n^fLoaUF|| zF=3K9n}NysR23;ERb%?LEH;7_aY%#0=)J-lu9(-Pz}@xAKn(A{v>X*BOn3!en!8)^uQ50w<6oM)1!msXMXPXsZ&CHi+4k+0vDAi zxzAwAT>jXLS@%xS2pbG1kCoO?0Z6RlK0l9x2=->i{f@(BI!v2B{d^#B#LCe^i9BOV zamcc7MywbB|VkF)oeHl>OXD+P12 zL#4+1&M9BR(v>WxEH=L{bhm~IJY=G@Z&o^o?uVQy`>!?Mv#NkWcdYf2xQ6mi@wnEG zZuqQTAWNz9$`bXb^8-rHNzQvmyy{T8d-^$d2 z+C@i|^gLG_9+g!ndG;kdduP_8)EH*+B(IAT6U*`Lc#H10k{xvFT*cXup{!U_{!~Nk zQV|L9kZ&}Ww4TWh3Vtg^ELlv-CLOfmVfyV@Jt@MVsxalS!Hw&xC;wpIgt66BRzGr$GjqhoArVQ64dizaz9ESfkX;epIoopV7)V z`Aj^XZeGbTReLUq^E9T=8oS&)B#s$zP`&nfu&VSnK8ojjLc5aJWnp0_!Le4?cT^cJ zlV_0N$J!Pii9Cp*^0lBPi6>Z1WGPc&QzqijQ0C7&my7w;7k@o`+k}i3DCnwEW0(&0 zyW{B`b0k(!-7fkSq3$qT{1H@KIIWNk!9PxZY_dqmU6Y&pt|Db#P z3ig_z-163>>B;@?PwUIycd(WP{WOm=KA3_kwc5OgDmFewUc*_Ge&R}k=ajNJMjE&TfLrR~7WbKvtdqeRL1dgQAQ-*R>f z#0t`l%}-emAhA6r^rd6pu#f}w_9PY}_-Q}z*L9L~ENxj&?)u$aWIfJ{k9nm6lZ@%N zy{|oruos?x3#-d94nsO43FbIN)4^T$N>v)hez>ds#4`^`c_DE<_eBrJGVou{(bypJ zkuKuf9nz@((RJm~RDIFEkSU4=DN{m}l%zDgcTc5~L@1&VnKG2j^Gqp9GEW(c%$bMx z?tSJdb0rx{38m5?MDn}S`{Varzu#Kc`mDY8=j^l3xo6nt+~+-N>J1&kSZjTH?+v=5 z>sM>~@u4v7ZSvLBwj=QK3vWKr1#iqpa!H87qI2Rl0@?c@x6WhSuESI~vqt0Auf=On z#|vZaI`Qj}LR^GL6nfsP;A82EqX+tu?o_i5;q_}DYgm)D?ye)Vsg zztX6ClajXX@BcxcyPK9fT)YAb_VCr|Zj*((!orNIk)!bSTQ)LBV!Y`TL+Kpp3-76o zqc&H=zkH`#QcqP#uG$Jkd2tO>^S6+cVYy5h2v$n%IZQmmNDaE_JRRT zL{ZgEWIdpB3u}J7=yiZIzf9+uw48<}LqGqii%x}C4ZE3ACz4^i!83|hZ}efrG1-ML z{t^UL{jpCTgP`vnR7=&1K2WiXeo%{%ChTLh&=%0I0=@1od^|j@0n_O0i%mMm;Roy- zZrqVJuzOCK+q-|(P@s(6d3ymW#MYU;6#GUVQad|p#Cl%~vU{?7^WGE#m`!!hAMu|- z@Z}}$NIgXj_>xI8CCG9LdVAEKwQ}k?+-y0tqFN;tN?G`R`N7qB$oc7~4So87u*kNR zpO-E_gX}dwUo4zygbZ58Z+ZDXMt@Hl(LBWW4*h+JyQ@_`pdSh`Vz1q9kqOHm|5$O? zFcwZX37{=Yr^1%~AHv<&)WQ)DYOF8JsKV>3A3y!plLY0omlUm2cZ5DorN0kZ9|2`< zNr|@2$%g_MXN-8ynZkcKa_J%>vGD3oy&`9SB|+UicTccV-60ua@8cXYvCv;0xq@{8 z3sB3NNA~X@4!}CJDo&A1cBFv!OS}6iRz$nW|LAVtdHCL0&+6t&BhdLFp-3b2|K3l* zD|C$b-a~q+th;_S_Cj*ksH%0UjnFa4V+K3eYhg3BZ_#U-i(rXn@oi-?g-~VCA<^aS z#ZYYYbtS>zZ0K<9Y!Cdh06PCKp&+B^A)J>K2>za=!Rym&mU__h@f$f?F4yLKSfMoG z`@w1Sdmpwu?-4O)K*IC;E^WKi0`>Oo+^!hJfGUk2zPXZB3K{D;Qz|6q;e-^fS5_;= z;YV7~wa!0z8_(b0{ti(O~u#K$bCXQLzktDAAqCMiYuy5wWH?Vq#i`9vD*%=?lh@*@NN zKXnJGb6)xI^MK1zn``3XtDdiH1y*N4wo_>VNpUo2PxrU!P=5yWLD1&UN%VKuSBPDC zAUd4_1<7u`dbckR7W>h*cu$A{Cwp5NJZP~9wc`R;h^S%w6#Jl_$SMh)zo{4arZ@v$0E{OKjd|C@P9+)qxYN5f%n{2Ic z(>Qqf%B_9M?}FgoF&%}v;sjVCM|01f=n3eJ*P)0u-c&f2Vn?~J&;}oxF}|G{7z0&p z9=qJ+5(V8g?^!%smH_)UiX=Qf|h%Now@`4MHPrvtD2&ARdaw}(*XePbTo-A-`p z@oWD1M}6SCZNofO0~esP0fKJHc3P0RlEjAVKa%09Q3qX*)3@QzKJLT9TU?-{@2?-b zysQIVe|2AWX@?dpjvRUt6a4@R9iGe1Bg+p9kL4<}@T6+)95@H^Oi1B?1kMOI;i;I|t2eTiu}(_=_HTN%0WJnoZD3 zljc3{QA^YnOQ|1abJwHa54Z8deY9R1m)(k^XJ@EUXV#$Ky7Pq^en2&1T1)^QKCG4~ zILZq}r}j=n_L#zJ^sTn07|v361&224O>BcUZ#>~97byzQZAf17&07bhip_1?E-VQv zwlu3)zY~OJ%!b9kdh!;#IY61y}hw(;mSvPKclTz z`)WVka@DPOdIqnl!fD4gSM7X3_q;Nvn8J?!A9sPIa$->|^^@hsLwToPQWN=|h1sop z=pv^I-IK=}sN4e5V{vK%kXy%%Md8Bl)PHA_q9jY+($hu$K&O|wsVRqE%!-QW(F;0; zj_e583|-+L8=hGAlX^4dHs7PHVR|^NWVyn)n|dzHZ$d^XpT1}GZhfp6!DIIrPrZVLi99Cscp48%b8^_brG1>Dthz`i34J$FiyqX~k~>!}n|4xnNbOnE;*&|e<3E0_a&H8EGmx8%HVmY03sWk- z^vs0bL#u0ZYN({QUD&(M%d3zc;4ggkbU_%^H15Io&tXpVl8Fy9E-empgBaP^cY3w- zz8tmw70%go?+5XDrFD0xKTpY7Y<=KH&+fY_pmq(=MSdY?s^hZhVfR?ni&$>Z&uQL0 ze{}LH^?C9A*Lh+3^j(u`wW*ghsfFwOIQ;kBrn(ArKe}CSN>%NDR$)X}r4OG0o9d(} z)QyL<=U@KWL^qz^7`m+ELhs%BGsX0T0sZf<U z)_i~DdAjb+_L~tjL#p7#vsH|7dAjL=3U1LbPU@HV_xU$}%TjeB^vlLRno#>YSPb1+ zb*YARlQ|#C73e;9R%u?D*-CBVVNnY~-zyBh(mbJ)n@`Ek&(haa`DNou6L$ z{KG7pDm(Q+FE5q#(gba2NmXH@UY_nQZU3YA-#YsChr8aK9{Np5|F^)iN@0vvHCdgjvFQ=LLor7gwR4Vt;BuWk;6C!8FkX9%m1lq$I3L=`dFN*gWZLM;U@|QO~6x!6h<@%l`O4DGE{q4;? zl=#Wn?7vcdl->>bdMkKhDZSUlc>-4#&?tq++A3OfDYLS(uiQF{D4k6r@+)2jQH=j> zmp9UVNTEk>U7a@DKx0TG7Bb#Grp3KKJ;?9cMr(*tEd0aML%Z?hBWoRZD(!XVmCy{a z$FyAGzpugV2HIhq`2vh(`ULRuhy z=#y>1zbSi!{1X@BHk4ILiyr5i^RElAB@1zV3nMHbrGHA(Ml4D#yx+%OO!IW#W za}>ZUJ^aKxl{U-gTENezLFwn*yh@JZM{9nhv7F7S#hU*E71pTPQtZbceM@bed*X(jPAQ2AYhmq-P9U z4ej!@zR8Qz4B9m>W$pa?$N`8$Ej~mvvAHtAEjTptZWb+tU_fE%f0^F?5lUFuVx6LtZjw$V@ZgOC4zC?LVSw}VM9@qOs zlPe399;p6F*&zMs`_LnPdUeM`zl;S5dVT+1@7?ONv~^RdJBE%$)y;BXzM$xoOu^N%}j-@pL1dPzS`qZxxAw2gxJn7rpbe2u8T%fjYu|1YVJxcHUJZ1s89H$0Z^J$Gf z*Px4@i@ZS1v8Tpp{hG8Zv!l0vYh*g{s!zQrE_gA=B~cpM3o8nFn5dbgKqb4r-*}n>|7Ut+Z)HF^{ zG+nm;_F)H{>eam0N@tEb;(fWcB5;O2Bf>6tj{6Ta=ftb%Y?E(P1CiPtZl!{d%~jsH z=dA+p=Pgm9?1NME#~eSbZ(SOoYpnTx@pkP>xaozS8~>v})FU-FcOPWk2XU`*(#p#@ z0lB7hc9>`j&Xg??L0-u-HI1^OQg@Xy$F-)(nXhM)3nSjl!T0auVE-Ep_(o-l$sHFHXv+BL`?fpI&^y*-*&W_Dp#gq|yn7gY&;0>DvO!+#UINDhP{noCI6HrQpN?lo{Zw2MU zyHi+y(H(1Hqh1{;@6Yw{)YOB42?+qv@-3`h*r-4|`A?rb{8b0e8TRY;)Nz5?PFie_ zx$X@kE4LYFsa%6OeexIPA}+wccY8*ivNnb8+ec|`$Z~@kMSItssq}(a{#6&bUNeKf zu;?D)aM6S~1=tmQj$MKCQ!h@%E;zssI~Eg~vYgTH`#+pj@Yfu69p{hFRMmvHTfbIWwy~`f*j45sVV(tLl@we~^if({a&6nc|U-&w?Ds?yDb2Y6?ClAthI%t8o!p$(A**PTQS3|1kXZiQV+pDPN3i4cURm> z68&C)nBvUO)(@^jJ}bN$*0ad7qCd9dFFmaph`>>sd! zS89!|KTs+Un_g{{cH`!TZr{7$t|7e#=JwwvV)NV{S`;2Pp5J5-W!1J{otx8z1{9ar zX`KpC`DqGf*gi8K44%CX~8k)a;YFK$ldG1-H#;oZOA4{Xtd zH)*~u5idIq#dnViOjejdz3T%va&oCa_rHR{wmJ&TDB`SaZ4-cl_P;%PKwb$tut{RN zhH(V_9R5&1ii#raP#f`u|L{iW`s1x@y`^~|=M!0*d`I@fyOh3gl<4IxL)48XL94{~ zGw5O}CpE8o+0hl39TL-bMNv6y>yy03AJMlbB-}d|*G})=Dad2r=}WzHD?C!OCYajs z+~yAYV((PnI4r!Z#8^wxpBiCsu%6jnrd|qy2Q#Q3CY`MsGJeOQ~OS&(SK^+)3(*yP1o7@ z_H%QT9@TrgVQ`=GdHQSJS&?+Q2KBNdT@4xyqzc#a#+W9Yr}85$**-6n=~r5PmPR%o zq{@OL+6MX(bme-{EBvQi=qYW^KkcZRbdDI^T#ocZRH^RvyPO8Q=%3$xJ9a^hgZh)@ zS_Ox$B~_w#80vqmPxT+^orwoyfGtZ&MUE>rpq6ca4%&Qr5~`NX?$icqPiCI#Q-uA#rQ zH@M>B%|?ZOra#hIF-voZvKBwdwwLayo1rn9!b>0Jp0WiICcOWHjdyC29|= z;h~6EG)MP0U%3y%w9$#?wy+-bE-;=gs+PBw7Bi6YGp4MNrpoi*dpmIw_WE3cqRBL zuFdZTI04|cRnBa^KmTOai0~q8n4WMW|RtYI&CMN0?#4W z*uoToc^eQ>*JM8hzDDG8)pSryQW*jtxvyJtMj0f^vb8tt@C9rC9=u`rr3Wd9%2heM zqZQfmQj5p)c@&!lP}a=wQ$weomAa&n<~^KHkcNSaDbkw}m^ zDEa;{g5_K<*k6{ADl#YJ?RJiDl_6nds{I6kuZ5HVJ z@{E?4Xb);w9US!DUO`w3cKw=nq=D6i!3!G%N`Rb>pOWQL9Dr0!+@40sAnLVs4ntX9 z$X0LRT&aN?Afl}*K71Desl0z%{T|VP+b*z{VF-g%yS{$zZWvtF&+ql$MF*6C%I>^2 z2AHu``S3`x0X&kAnwsusfFywly(HwZhd| zJii%W&`(^*R-6G|JB9AzE9wIEl}~?pO?Lwy3bg8zZ#$5WlFO7fs09(o<#fb8!S(fX{9bj#>bb{dx1`rJHe7e2@2EFmz%K8Uk@L_w~X-#h! z=-yxWAX8oqtk$q7+IANM%{%GWuW{sq9Z81+y(MArx!%eu?H&xoJ}LheQlo>1^cOR2 z3e^DE$`3CIR)UK`)yQ^h1c*|26KCt`Ai_>|jkY`js)D%2Uq>RqqxAiu>sJx5{y}G) zWoj*0b zD!cB50Sn(6{qk-EwB?G)=J7JXr9#Gm#MV4;^yRS!5&T7fcG{ziV~E0#!h8<-k0Da}6-hnMpLWhrzi5`eim#1Y}YK&P;4T zfZ@pvvJsmY;AWfqKv@U_=y9^5KgP)bmBLH+bxRR&{(yW))_MeReh6J;?W2R+9q0zq zNdpoU-xVmYcn!O2b*crzGbp7;NL)xUvmcrou-`e+$AvRQe6t`8-ao0 z>7>=N7Z~6<<6Psn%?xlr)ZagN1XMWGe---a?h7#I2*0!^5+fJFJPdMwtTm#kq)+WKluDG zwHnOLo%M^zr~s_rLpMvJao$E?pS@3D;BWF=rVSmpyBY1%-03x-Dc#lOWmpwB7FjBS ze%uJy|B<%eCyxGq^|Mpwd1h-shhU|?yLdV9dhbgW$|(W8vuzh*Ltr4&D=ApE6$Y!* zRC9akYCyQETl4#bDscEf&&=`lRX{su>Yw4>BCtmtQvLF&2td_5?}~Tl19;Y~y`Uxy zL{`j#!PY1czV(sDxBd!{7&3J+tEU{8S3X_+Q?3|%TPv@8qU14{RIoevR3{NAp5{`U z_O1ezO+nA!IF^Hdyz9@FR~CVR9O$q5ktg8SEw@jPSWuY`;VSAm7F%a1CQE5Kt;m2_L*5^!|6(=d9X z0KATNHGdwQ3tCSLot<@x1Q!ogryLS+1$@#_;EKRhB4e@6fL$?aM9KOv1w2k zxb8msmj!x=7zitKoSiE~4ncRG3%#j8VhnnNo!K*iGq+WXlW7F7FFNLz?wf%0-}(IS ztx_S<9vLWe@kS|fK~+zly)+NFw~zUD{7M9M%VJ|6??)ry*4sQ1I-Vg3&Wjt;D=Uy^ zg)20-dzT=(KldnGgj68mqFpf(`{{_O#aX8?(OQJ(=lg_HZgmK9#wO)jQyFqeylJgR zN)gJYGV}1IdL%3ES#@=21yaCR{YO5f22q#k7xF$)izp{8 zzWSrufapk;eA|`Oh_rn!_7xs3MN*r3X5P+JAzp7}7C!dZA#5{AXR^OEA@3OZH9I+4 z5OdS14c@;ika@>{OTUZh2>PS%+I5E;ko_}%!`paTkPM{p*}vdcIR?X07&Z+<=UQug<`g`Euu zY|bjm{<9tt)%|kRLa83v?wla@^L`_e-pRktM!pF#=C~n0=GuguFL&f%lR_~rZvXk} zMr7v(snVlp921|TH)->>B11h|K55Bq2z%YdCmJu>5W%*rh^fFfWcII8yRBO*VxJj6 zbxLSMTEdS!;@kTiX&8As6)4<+SYExP{L85W{r{zMK}7KuZTHM7?l$PKMuLcKfdk)1xW?DI!ZeDPW%c4Iw~{^CQV?!G!im%8d{ z!^2wSlJm^h{?bN7ka7ba?{7r58mr4yJ!?eXeQ+6`Om9FqKfY@D9#@ZK->Z*xz1@b4 z8=PHwa;*)SbXnH>=hKS3%=sGGmD!B&H)qEE({4iK!uZ-XEjo~YSI+e)p6x&+3@Hy9 zCfbpC?%)d?;jM`KM?YPkpUntzzd+5%gMmcD+R>K>=tx>poyM$3C9=((Q)cg_LgZ?o zMtZ>bW8_wp_r}b)TI4>XtJVEHf~@O(?AWDRjUY11AsaW8B2S`s`gF1uAt_(ZCA37= zBbl2^`6vF5|edpv1@>V ztSQ&cdm0TRV|{fcHwqske5dld?Y5*Np9fyYxTHKl+Sq+HdK~@0wql{lNO~kNj;lM$ zhtAW*Q{AyuH=iOCe~=$a7BR^B(u(1=7yZD%x4V+9r(?mY^GXk9GfR;dFY+T4s)`VE zYGZWcyHvy}St@#)tuFAHR?XZo5((sWii6LDS0Xm1kqh^VN|Chl?W~Fqvysit1BQmH z?jQ+fZ${&2?jY-s;6<}^7%@1!Z+}906>{ICP=CLE0di0NYru*Nk;oyoOIK^su7c-g zq57?lBf*eR?H&IWDWG)IXY21hSwO&{&e(HPKCtBXYjHVU0IF0^=`CH01xb*8c+T?- zu+FZf+(P^rxYN8>Ax*0sl-_ZXsYdfXZz1+AMb(i&zdCn#gqjYzm$M5M#GZj@^XJkQ zmX+YV=LI**D>dNJd!J)R8r{LQwIMQ5hvLB67qXP>gL%N}?MYpYnlkWx?Y};u&DG$N zM9-GolV;$K@!zx~n-joqv&Y}tHWY(jWj&uhc~pZd52{m#kI}$JE2A&#O7lU`^O}?) z+j8*s#sw=F&G)|Dd-Hy9jseQp3-q#&t6(IOI( z7T)pJ0{zS4Unbx>;6Eq++SR%SjKQH{5^^*kAMVf7K8Apg-3J;Jjq1S2u`IQneDxsl z#Ng+*($(N|IH$!8IT&QvISe0pT?;m`n_1DE>Vae><6ul+1K`QIcX4|f4V*ujm)ddy z2HflGkG=D+1x>#z)dIap?D-s5kW0uWkSx-5~T!X+2mzrNhdwtOuUg*(wLj8^Ai}Qy&JB z8o}!jakmrN&0w?G>4tMn&0z1F*9<tY`^8P)}y}83;J)u5xN?MDuGz-aWMr zbo_eKrI20=ZmfIQ(o~4%F=nN&6}O;y?IxMuX=Bd-;y9rf43a>`i?VsoB?gc}uFCD~ zLi6y0f7FaDs=>{jA%2Z4CBVh#&~NMTT=3lR{*ae$9hhf)6ucC`0M?$t+w*g2VAFBe z>1Z@xmf@l(Ox2YFtyGDT-sU>+cgBEamt&T+3+x<>P zBFwjLGBzpz=e-1N<+HMZ&Mu)HO=lv(w`I}7q?!n%E`3(NaAP`haKxw7!?zUtD~W-( zUn>9u@`=2WC*nbiqIiT$Uo`S-7mM2q`+Q`iw?M1xp*7O6k87=paLBuKyLdk=Y+ z=tYt7bOe6-{buEiL@+XROzvUTLu6DzLvY=?zb zBAaTtpME%zj2z2XJaxn*3t3$3I-+e%|>II675~e0|I+$0bsO>>M(?{rV}4eA3=4-@%0-4V~^8lcs1M zXc_EUxmb;4^Eoytf1)8j-2=m8-_wvaw|N%==V-`^=hKO5e~SKjM5Q@Ix}{?i7Ldg>n~Tac{$SX)M1N)Hu}AjCJ#;~@>V0e zbAA8rFsnuq+}++t4kJj)*0n(=e!z&>zg+R0IR+BTc;gY@M?>K9UKieXCCK{?gLkCF zU?joNP^!HcL4HYXOL=XfTM_bz{Y?91i84s>q(3m9Vt7r=7@lP4U(hn`0XpGMnc#%!#16wA^tfA=Xd1M5#PIo z;#X8_k>PGX8}VCph`*^7mtS}t@-a{*K+vNWVZZjk^7=Fb*%d4qIiLFo^xloRHQi>3 zI4(O!Wy9$6P53Kz>mP#nKHQwH)&nE9o7$Uz_A{iYJWP7JuoTI)cBiDDr6Dt=&2=+o z2x8T_qNGoNf%u3W>+%w1AmIVUI+LReBscbjRoesuxufPgpnC;DeoGDN)Em%|tW5%3 z><{P&*E?T`p-D$9wuBTv38Ev-LN?&I7L15H-||{RN01)_YQAa33`8y`*bRNaNZZEm zlb@_{d*dE>+T`Q+1^{SCvDOCd_4C>O4T6Q@Kv||zD&gZ z&}&aVK7Sy*^3eIOGz8i3dEYUmgXr(ou?fgZjWLj~nZj(p)euB1x$^W61`R2`=U`aO z4kOgLOk;sUI&$&e*J_b?2I6M$v$#&I5uu6A&S~6eMC8vMeKLFwL6rNa&xFPzh+Xe& z`LIL=D9J?R#Gcb_#Q_g{S8>oL@e zG)`Oy{(k5kQht39{Tl~GBo>nRjKq8rOGvCBvF1NAvwZ1)^#31^S#KH1XCkxS0#g6q zc$of~dS-n8MW&zsBC}i->A(6v@iO(y_AujQ>Y43l_6IXgrp&}*(l66b4k39GWATESx?G;;$_D3-*(iKJZ66}?J%ilwkwvDnf{q^GwsYc*54q;36114+r{)h zP3phf5j=lV?jSLo#FeCV10i=^Be2DZz^sb|>gN)8nk;vp^ixEZUrm;)*CTiz9SLM5?aCy7(3{X} z_Y!#5l)$W;1P+k=!V83aI_wSF_2XcdKOsAk_GU9eHfnDZUZ+f+P+w zzbhQZ^^3b+;uz;Z*bDgy{*w|yKHWj^xF2=kyj(d#j^HEgc1na?sPhW9M>~w;xb4Pk z9Lru1_A7@7Iah5A*Y}ta{t~4>;__mBFOHST6FBPLug1}?lW2!hBP%+T$HBAB*pf63 zVrG_b6g}aLbf&)8n zyP2mZj#>L;&?RRa^j#<7I8d>S^VHXS<9MpGAGhC~7Qp@GU0#EiE3z=g?WR#gKZrfo zL8rtxII>_*$MCn&Sv*dyi%IAdM`eZ5CJYg`3wZhW{Cz5z>=MR-^RhKZabC)bL3F7c z2TI$B_}NOQA7Sz)qXnW~KL#F;^BG6HoUikqG|avuY#z6N{*L&Ui>%mzj2@*`4qDBd1EjxI^#faASf7KY__zM)IPI4Ju>;DJ3&c-(w# zMtGc8mA*1CyT(c%JkAnTU36(02fLj+aQkn*XuQA99azBYkAIMXx1(7^1YHWzIILQ5 zf7iP^ zyG%dE7oF0_`ReNB`14)3+lk{&_$iJGIej=*9M;0eL#3b*E~iJn#j$A5EROwUcX2G_ z3d8+Hefo#DDx*JH$v)Am4czNxu#C#MrB<5$mDKTH&=81W;S}70b zEf*5=Nj;rdKg=QqaJ{MLLp+}Aa>V?S&>+?msapg;^fuuyu=EQ)j)z%P@p8)NR^#Q4 zuo3;3g?|4l7Uz={Re1awFD1||WE`~bO~LiQhW_E`7*&kp^a$a%jZVblszo3#xt_9_ z5b_z@H#mP&CLvdn>+T*B=UoYX(Ex#xGXy`vjgX&_>uM6YE^Ekr!2L~x6ZQA6BzPOh zb@jU@Aump*<2+ZGXqTr2fzIa%I}5o^k6k9@JLG;eN8%L{rN}r1$o=S@HNg)c^~V3< zE7=qF29hsC?hmmfpXuM0hv02BB5} zy2#=Fm@>0Gv!9u9GW|1o%yP`<%+xd6!K~-$fBZA!K{wt1)efeAre9_p=w|tU@|g88 zc}$s!%($8T$J8_9V13nVZ3e6DEHfXBytF8_^(89$THY+o)}?!SJS z{+aW%gXBFXk?Aj$l&46%MvgmlGr{9wwu{-%%=%-Tn4NLQMW>H37cPl(7T-aIDq=V#`GJ$0I}_lpzq8Vu@5&Y?3f|r~|)O-8!3UrE%0~PXoGGs%PmuMpF4GTm*?aC>K z`#Z)-?1SIuiF|umv=!HH)C;Ifb@J36$-L9n$HE?=$shfeu%@JHe?o{t7sF5$9tcV{D}FBn{P97EUh zv$)^eDd+Ke)f!vze03k^BXkKs^U7OP6$}SYeMhI_I2g;lg!^0PZHq2tZwVyuJDY51TQ0S(Fn$Z^*3e z>9)n}$hTJ*cAb2vi`fO)ZmVGV?cROj`dGd$pE}%y>FFQ7WqP7`ZvCapnEc6OS_$K= zw@RMD%4cc#t-$oR6<2<_iDG5_z+Fss(&*r>}Yo|eplb1 zBi1gr<59N^P?YDp`y9i*^X8k4QC!?}VjQcl-*FP}-yTPK238*VavdL+xx4|moRYB_ zy}B6(D^8w4Q-E=hnz#d9+Q)&+^B#Phy;TlIx2kb)*G#b%!&RRC`1ufaCTm&btlwfreFE`#-TT}zeST5dD29IQVFH+5J@FVH7U#ZAN}sU) zUZ*+XirEcKmTzLuDdXQJb<7XNHU^LLd{-wve>l(&6JoqjHcNc`Ub#w~n?jBD)nWQ{ z$5;3`_Glv3g$xRDPBNU_g7du&Ji^bx2L}7{Fh0DMhU-^IGVu9l@;VvEOyh+uSe&|- zr}5`qASa5?C)K=AyuI`8VK|TF1mg?FyY5;Ngkc?99bSKF^dWp*sTCK*F=L8?^M6?o z=cdlP#5$X~gIEt)4-oQ=Et~Op9Q|J4{MF})^>oEL0*~|(>#W)%;#}Fc{2Av3ml1w= zT#5DggFL|xT``FF*VA)Pa9)@panDdXPn@GZSP-)Gu^x2GMdxGn0?vyVAkHlrRwcO1 za`O+4PTz@jdqkS>|AX8QCCGEsJ92;1d`QH(;RC_jqDtU;Ujo_4{cndW!Sj7g@@a%U z2oU(2+?Rij2%R7>@)W^q zCikUvWWKV3tnV8s_mcSl7js`HWg(Kcg~U*De-Cgc{GK866$g@!E*^ONn;nTbcc~L{ zG}&+B3;>uWA-!i zoX5tVK+jf~fp zI@A$z$4?`8`u+J{P7RCNkT>tiP3vlNlG&&Mc2E z@_0MYO%TU)Qbv;rTuvboO(Jl)fkb9L&-9BX6S)00i8bW&X4>mXJ@dTrinW3usuCEuaA|mi{%scn-j-jH&`n*@L375Ut zmvF3}H^4FfWD>q_HZP>%^6}O4I3i6II4;={ais}d!{z&ytI$V24rF_XcCBqC;@QYe z+_z`i@2|q_UD-68zh^@qjtAc^;`nm!6gq^^e5A1t&l@Cm&EYZ}h2Vah&pPAsr9Fvw zzFhHR={d%iZdOF6-ZqjIDl2jR9qVd5Z@-;uhs#~71@QdHDD^EKhlTzMbgH8F zkCs_@UUbEE*%6buLW}VH#cE$RIu+5pGQ1PF|K%Bs!{kPq3!Yz|bcsc$1bUDEdl1iK z&RGaP#^m}G`>z=K9}Y6c5Lx#G&)2;-y^Y0W^Ge|_7&>S23u5?C=fXY=JwCOa!t#+M zKWS-9&OCH643i@#;@4q$rK|I=m#!#6T0-|QyReTsx`d5`oVNlUn7vItbsd&}Wt?jk zaYyl{cOkkJp!toT${Cy=`G<8%{EXWSar_T&`$ahhPPNb26yRUte(Pi+RrijixcrC*HGl}5P2Vt;vRK2zC;v-Wgmq&p;(`g z-i_tC2U27ka#73(5D2)BqIvg~cRSvUgI|~Amay|fV+y;EIf^L;7iO{cNqE$WrJ%Sg z^rYz-6q|GyH?jQsN>KMWmM{Og^(`5z&*hfpISv$$JgG8Vi=y4>#ZW^O)nlzjuzDs` zhlIsY6i$^={)ghu-D;_7Lufn;^6(>6R-|)UzDMI|$#-xsLd?rj<~fb#mBvbN}qj01}&`)-!@j)S$5h-T^w^u0>7Ec)th9K5>8@m32( z$1RQiIw(qv9~Hv-r{Oz)yd#QYCq^!BMA7yB_ZX~Sj%+D64nXmhu|*NqUkrbZJs4m9 z=+AI@G@iP5zRUTj{Huy>Mh`{V9z|KK-=EBczd-+m3B0{|a`fZ?I$sVC_nD&cQQob~ zQAPDr73^mFP|S3jH9d;r`yMTWHZ)F62_c#uV7Macf5UFy4XP+^>C3AtL3yw0 z&ZJ^-D*kvYX^oYyGe)-{w4G}ny~gToKE5>qL&@XW3fOt=cKn)6*mx-Wrv4rqHwp=_ zJ1{;+d9)P9J0g0c6gwaJm-O0WejBcx`;GZMUdi?Zi;PY7dXcxZjd>A-^ZpmmoLoXq09G_438NvMh?J9J` z_+E-i4>9{v_`w$#ZsiRx#m4pWfvG$CC{h(}Cu4fwu^IfF<$j2=h{@OfnBnWjUA;Yc zJXhi}@pW>OK5-r?lwH7Onb=BvU9;1v#O2nH#QltHjwHVBNwE6i`V!0I`1*Lbj@TdM zV>aUU+vikp`?bbIT;}8&z}MBD+b{6-v5hSQ*YE#Zi({taD|Cw=2bO}8XlgYM9@kIe z>t38#6K=0LRe;~CyxPHr^N>x2xc|X3#Q8)mmWaRi0I`p?j1d?q8jbTJ!-#WEcq_p# zdP|%KCM1b{bDv%+UeC6kDV!gx_#DTz6U4bl%$(pej6UP_qrc99^9@6Z_j8<+L_b~3 zWW)8ma$5L0zyCA^?;nwkL_2-_baB7UuEaU>jRaBup%279Y~@AlZ~Mr6BJdm`2kj=# zTOmP2yPDS$`u*g2K!VIicFGa^r0_H1dC2Y{_`4Sg|5M>axm`BIdo-I)!rrb*@Ox#5 zcv5~5vR2G?ygeH(EaP!g9SQ$nf{15}6p;sTk$KGs`5q~O%&*Rq*hj|4Aloxdo(E#d za~B}p9v?;BNB0Q7(DzI!yZSBl%pRM4SiJ34VA0fvM#CrH5qRc4~~^X_KEn z_)tmkzH1P;tVQ5WGEQ`I;c+m}8R$dD$l%L#B$e!zod3nEN9`9#LIUyUT66@nO zavd?tCDt?Do3=P_JsZJ`q!aJ?FKZF&;JV&$-0oTtoLn>#cqW@t#2b;3iyuuw51% zn&Uv5MH}afxe(`)8u`b#eJYm?udnb=P#?y-zxo)?voTV__3)mR_$L~p7=C|uQVzlWn8?lGan!JIjVhrZ2Y zxGyvp&!?*cN_(+<=JUa!7nt6QZO#tEpU=kdJYH$r5jHFjdC*3^hv6#w3+Pn~njZzF z-okiOmBaYCf&1_N8<_ma)c!AaAHE^g8u$NrbF3l8Up1`u49h33z7iS1@{sAR;2-AC zXW4TtW}mW{F2wAA40^+{JpHueo2^(LIW4O73d`@U}tBZSLeV6sJxrw`2FaCGOQ1u=fL_&nJ1bQCu5W65NjB#L^f$CUb~>x`_FSGlc{& z|Kg2D{uHCg9^(~y7{w&7r`G0Ze%2g|=(wS>P3vwh49^644q$n)kegcG3~HAS@ih-d zWsX7#yYnb=7lbNf`QG%}sCAc6-1hj)1wS-DU2NSY7lWd?8H?F(R3CBEFAK}Juawj% z7Nh!{@5#z>Xue)C(4a7c=H=W?-J_UalOGS{SNVdi=KPf-hOhP90z&!1eTv@Jp5t{dz4UnJ0k61j+T2Sy?j-t2+ealq1y^*JTf6RyjXu7DxH7* zo@D|!To&A46M}x;YdIF4oIv~kquezW`w39m;;YON`(jRcQS+rIzE5Q9R1x4lbho zLNk{9MNE+X{1NGah zx6NI66vZ6DH~~~&zhv-x&&dfu;k;IlY@Pr@Y4nlM`EfAo_>Jm>#*;fU)L@4C8@xyh zU60~-jhFPjXt^(EX3>wpjDr&o-!>(n$m)8t8#`a=WmHX0qR*l7sKUu!R325Zd36NE zV2SWR7Zi_18FFIdQRRt3>BtEoKZmi zsrNcLf;1lU+BcJJ0u28LD2K@5hNDF zv9<*U*1l2Ai&I#RP#o^~8{*swFjJLXHIME)(kAgHGdd@6RUQQ-}6AvJv1dm<8yt8%R)|)I1W|@ z;ry7##<=`Se$bkg_&!x- ztd09oTQ0!+Gu+t19*gsruNeNm4!P=;it$)rdS| zKL>&5!ic;idU6YHuN)`NftNFgbJ5S=#C_Y~1aS^n|DynpZ$6&br>mj}zIG*%Pxu}u z@&+HJZ}|E0e8?BPov%4w;r?mHbvUkf-G=LBp87q);?9s1#`{^WQy2FyYVaBF7r$C5 zoL478dtE($B7eGkl)(OtL|nh@h`h<0o6yJR5U8X>;Kl&rIo<(;KRZQ& z|7V1dFANd9mm2(d{k?P|pK47Z?7BGwAL1p>9W~-PIFIJB62}pUIFIgKNt{RjtR~7i zo+bPak>?@~G7n|ux5K2Ye1zadk)Ip!B>6mKzIvSGZC@aG?d0bY*O8yo%O&&XIWpfC zNG9Su5=!vh$1;QYZr0>#Mk%<~s|xq;gy$ogb<6S5oG4^w1b&Pu*#TrEV{%e0BO zyG#g~LHd;@{Y*;}daeLsJfATp-6fCiFdW1pdn=P~^rByj|$!8IG3Zd3?=pq8@)iVxDgNLfCVKi21qdC6V8+ zaV6rm`A*;~ooalZ+u1KxX&&hZNckxF8G9F#uefof8RUe zUT3xCd3^rm7ZB%wJ?n}2-LSBL^IfIGaFmvMim%g=kBR$^?m6OfLY}?*@$qlA;tZZo z7w^@=_krApTzH()0ef-(wsJhUoYC%tuj9P8vKO#*U|Jy#_kZ`LGwx?{+Aiyq1uxQTd%S_x=9y`^WQ{ndi=&JMY{%&zzZiT_^lSLFY-m!*^_n zPM6M`G{XAg`@#rsn~)7z4@AutByk(tC0~gj3BK4{ivGf{bfO6P1@`h}evV%9nZ&2A zozNojZOiF!Mby7lao=Hy3I03fi8Er0Z6~~H0($t>YCcRy*<8G40?66K216bEpTv5y zE=ktwBmT_LI0{}R0lyw2vJ(AO(a*#_Q!e-ysaeXB2<;Od_dj))2L1y^~r$D zCRjp)or)?h$k)~je1r49pyd4q)a{F#OwBNk>%4r`dW^r1ns1-P@`gE=e9;a!mU-r= zgDzOGEJ0oF&H20@vSag z%kYQV&xk(x=CkcRq#s(1%$o%`YfZ6>1z@stohstU1uk;VW$1cCj|`;k+4$UzKo2sO zrQAjTdwk)^O`d@4J$SfM!3X?x@iLzjadp%_!42ccXjNon*Yq-R#!fQ(?XAd@P-VfIsEV!}E6!e%z#c|1E(3NF_Qd#prPs&}ZW5M-IaLvi$D&V!O z*j3Wl2mQQPTL|^s>$BVyZO}h~pSP~?0scnu69!j7UrX6Dd~-k#Qfi{p7frjV7;*jL zgP-BOl7+j3+ACna$FViQU(i_i0?oa#-8?p)a#{80ZY{mJD%knV_|9K!vnADOq7VgD3`o26p? z&rZ6fJO_J+;DS8T}}MX$dGa<)>n4Ej`)ZE6%r(0Cgn2WtLjPn zwUIcI&5Q~0U%LjCOOY2FE=c-Ot@~Rq@~mF65nhw}E093&{C2J&{*U9N-i}E%tw%gOY5h6(R2Aum@OIknc%}~Om#5#ev-+1s z>UaOeO7@RF55FOPIYqFU)IYD7)(=iAUlSg$3msqUFXkiblZkrz{i^6P+W+S}ULtmn zKc?;CYov8aa~iE{{vM=}SDi+oQrgZBOkI?{j?On=o}*Z@i%$1Fq;-3F3>}}%@uTxQ zSI}t3)bWA4t%#kcRq_drOVjHDJ~vutv3S$^Zrx!zpAq$j@VvLS5u9M2v(q%9`L;~m z7r=~rE@SFXG3NW9^($yS*3LY)^@OS0TbTPBx0rF~Y36>#>fN-x7EHZ&U!Vx;?c}`gi%W zfrHo;aA=I^z^o^9+&6>m9=T3Ek3QFVGN70|e@9DrU*fp8;CMybJ7r67p7T3WkMzz# zqBmu}KO^f(=e?X{TrMf6->d7XNFw#DDRLrlhNjQ_Kd`_BPnOg0Dii3X<06D7{+oVI*ge7@;q~%I zwbx;JgPl42&mhoSwoOF$MckfMfaPiXQyw5ju=hkF?}+R-7fgGuYwSlnzaZigqNd$7 zQcsmq5jjtB{+HVc+{eCi{_iN3`z#-DLo~=g{2MWLKu3_|$C}z8kHaLHT<^5j$pG^g zt}I`H?RnOel5@p7tOPG(eDD*uInlQ{mB+T@e6-W>Kmh8|o*_?l)OP{}(TYNVu^BgK z(7(3zP3I!d*Kc#94Pb?_kbx>-e~r=n6Mz?#KHozByp&%i9`&U4u~R%cfPWNkiM|H> zD6z6p4*dOkh4fTBj}gIPoOK=0apMkWye>ND*BaD+9>0Bm90A_VFE5vxKzh{EivJoQ zU-LjZ#*KH%eJ~XPY~^^ecn195f}um1*p5eTeqAHrQGuPsFTt?qs(5YSuJ z0q>KyLcICDQFXxdFVNR9QJEFGpxczsY={8f>bZ9`Wus6AT~j#r6;4zzx8=ESBR%9^j?Rwd}6 z^geIT&eaU+zRj)EGwx^_|JizIycB^lJ|EU9UM_XCuUQF_@ntDh9VwVLsTik}qc(VP_V z&UWfq<(T>EPaV|O7GTbNoLzi2Tt<4noGWoum(=F5xYyHkZ{WhxM>S1f`&<^T#@#M9t_np+YqNelf zlAEbkx3q-v$!6*u=fiAYpH^y>^HSc-L+w=WeJjqt3^>4fK} z?#7}wu+9u9{u;u?pmKP)!mnk)^E<~ceZ-?EJbY-HRI=dc+tM zPxK?9qh;OH?3HyL6WQ<{gZAR5mq1TWxdgi`h4F0KJV#v+#$$!wUXkDMe6X^8?|uOJ z9``B!AywYohN9byA6) zp?`%*zUG-zB<-d{>*n|$wBGamLfg+jN$WeS)pY!l?=Jma3l;@hmuj%nx>KDQ=a*oa zBK7+0p!H#f8B>><(e?Se(e=rN|0TR-x%9e%bqTFUpD}fE2*Zes6xQoi&~ zJi$|)u7vmK)G?wvcRBw4h~qgzvD#@YG@Nn~99HMbyXiyQaob>)C9*?()XiX`JL;ie#o zBbFR73dHNjr?WipITCU5Ho~->r&}{(UMxLc>f8U2b!G0M&qQ}Fh&)W@B`v4X8RRv& z^pgFTp!yneuEBo8MF*@;y~SV_KCkxbop6*0=IeuRZXy40;ZvelH~yA|S34liP`KqX z>ObA@j-hN?Iw(FHpBZzUtKiTmlp0ZdtBoXIXZNF);eSi_;55}7S-S5=tuZxRa`#^{_)x| zMpPg0SQc-JYlHHc@N*>Yy1ga5=o-|=CA)iYWj^?S_tWp{f%nPs<8Djf%~DKwqYCMf zjlC^Tz~7}`ii^yF^8owQU(A$3e&tomm8MX?Wpk6rQYe=zJj#dzJ7gsS5=H`Ge^I0G zmkrdTGP`@JeqSlydojUKho6g7xxuh+p=Uw%%0&p0Qc^ z6Io6MmHlwHU(H_V=L5D6AIEf2v9q@Qot*)3)<(bga?sv;>2j;R({O&kVZG z3~Irlf*+ElFrF5#U8oOwxpu=$NcMwvYESJ)N8=S;l-l~PlrbR&HI#CzEE4QJ*BbM^ z=RMdPZFtg_4eh$?>@qRl9!zw;+nn zze`3tHP3#pHXQaaH}N&S{HIsChg`ZI5vluK(D zMJ-B)Bkc_8LzH2q6U247+}>EP{{Z^sDK~o#*z@@F0@eMXU#0})lU{><*{0(){1$#c z`=#&Fnn2(4i?J=K1wH7!v}$t~jHiy9feRFYSF&9&-4K4)>EP-41rWy+F|*~E1951B zoNlF~pgWC!&tIw!c{WQ-Cg@m~w?_&-LVZK70p6Nmuk@Ma>mGuR?Yj7HIt|93;j%2_ zwSWosy0H}0^DqA;8=mV4tG>kp6nMYh`J`$%Cf-k)nN&WC%Swke>UVI6zn z$Rx~fDW`~@QFTuzdW9#}j+_(ts2xUh(vgB~m$7}R0SOYg^1p7=U5I^A!9j@i_ajLCDf7!skXKQ%o|W*{dygYJUt8#pXxMX; z_&K>Rs*kYUS8Lys{V;j`3!_+mZgwtg1;c#4Gb0Mogtdm$>thm6{Hj%g1o5i}yfZ5S?}XZ3pqwQQRGb*Tj5pb>i#^5`QYx&&k4eJ5JEw6$p4{KzKgO z==1W{+O*y~w3*gH*^6mCvpR&1+t&TPL+s#tLg!oA&^m~{g4SFAM(8-N-S4@?zKNeb z1aI`y*9RY@>tE4B$LktdIElSH{9}Yy&k;z_U>SYxQj>+Bv}e#SL)HU!ztTwgc{g{0 zw^MwG{c>vUL^pW`loK6urPGkqD^OQV^h>pwC`ogSd?fv#TV_elFFyR5M)GGyR}!Ak zMnlq`U&s_mx3nY;Vt<_xQX=)P;=4h9w@j}nk~UKtAnjY8iiS`1byI7fl@L1~>)$8i zcBvXa(J?=dZCQrpM~iYy@wq$b(?j&q1q&;p+t)`wS$yD7a8YjU1)bmqow zb1Z+9v;gx{@@I|`{$8|5<%nr{Mb-TVJu`{^(cfjPhLYhpLKm*3AXo zv{C-(xB}>=wM)9&&9%FzPU!->$627udhDuVM&Nb<1T-Ni0sy-7j6q-B??*$bL-4}*)#4+x_tsoATA$H4F^kXkI zaqQfcWVT_7wYz(C@1CDjM%ebbtNwLSvNhJNKV*9-@ou}n@ZTaRmt!_6t4w}UZR!fH zx7H3*KF!Z|gdA(7e(t(aXb<{jx0vpQIZa*E)aKZfQ8@;6u3pQpV-|y&!+KkE_Ucxu zC(8JK&E7VOl{Hg}^2OalTrJe=2T6Y>>RYK-@)ELxi#w>j z?+k9tSMH>SPt7%RY-*;A-_7CT=x?S(PBg0AQ)#8nUp>2jPhT5l;Ob*y^{t%}J-T%h zdoS$Uv$d@}4f=&+EY^hr-SV*OpI$zU8?*cA*8)MmeC0N0Y%yR^n(s8rhvD~aY19+@ z3j4(!PZxR(f}Z$^DHuMNO6bx7Na=Y07@;%93Bx| z9aSQiFs=U0;UUJm4V(GH@Oj=cGb)Ai$myQ9ChCxXwEz5*L3l1~OmdTPemMJ8-~1Nj z-}l@3=p5AV_FLFk;61dnYM~v*u^0tSHbU_H3RmTB>4N8udR#744A%{9QYt{5b5^9` zB>`_2hB*JKze^zN zU6t&weK@Zl+`8%+;`NhTr|}_E~_7 z(I2SaSKf!^eYtagA?h$itpfr#Kg*#D#P(YB~Nhi{$>!TOK5%qROxtOjq_ zBR@dsPdCO5W!1;lz9I-{MNejFx#J+~yD`1L(K;iNy} zIQvOjzK7N?^~1izu29z-q#Y@<9Yjy0@25z;3s;+w^8P3~{aK96;Viul7j9FK3pMejPnDcPH|~yQnlAN4=|$j$pa_(R<;D{-K^kpRd;cOV%C1 znN}k>K7#^O9-w|v?uxmOzaQg*d_6wj-S3sg4*_1`N#2O{#(iG(3Hf`(cNt(hRU-Qj zK8MZ$j1X-=cMD$UcYyU~HfcCdcwAg{665vFixNb!{d)(7g7F;NzwI~wvB2}%6#Bvn zdBsbnb+NsdwI+A*xvE?BZ2)!BtIubgaDA$M+%F%`<#3CftwY{ipT+QMAIz(IT|&s~ zWjWD^ad`j!jL*54KI1$;70|rr-iqfi@BIx^S*Hv0oBFz>LubH`_+_bI!}VldfBB1> zz?=EH?Q;e2xH|F+e*>>o%(d$~%!8I(>(*ER&(Yk>Pzrcl?&)Xc0Xf%vGB*Ss-@qb| zl@ND12mg`M2Y7#8)^blnJ!%u9vG;)&o4+N^8T=PZ#}7kCG5=*+JI9$&48`(5y7e7jqe&VxUY+y6jX5&TtB`DAtQ6kN~MAad3L{1eNY z^t`+->W*IWE?4j~3mi;l34#CP@^9Me3%u@x$&fbCK^FoRPi7zPrd(UnKU6_{rlUIQtod5dO`TEzwD-6nZ^6lz%pTN&lm-ais{W0th*m%LYxxmf$ zR6?9V$Hw~I>|p7k{GIna(S>-#na!62ltJGqM?_CJf!^74`sjjxS7E(hW04e|&7eAU zGkY&TZ>RWU&gwro-$hy7&2{+=?~72`Mpa>8Z*i}geImq_uD5OEd9$INVwv1jXw=k6 z`Iu;1Y-VLp3WHKV{6PO5z232W0PND33e3Kn*hX!(2`rsq@1*|Ob?w{*ah|9FpS;LF z5XVtou;Lx`b6$+&nBcQEDyT{9>8_Lx>TF$8-8YD*-Hy2LlDvRHT}^wYWDEK+XW^F5 zn_sq3?W?zaI2qSLt=o}1IPL@excc6^Nzj4G7s4h~;dgLb=)3%04vg~?)yjHszly`{ zsrb9z_FWsQ2<7G{HP>gs?|8v`bj9Kn_>NZK{pF89e^~8Rl-7jtmRDW&tscfx#v(_> zdg%Y54j+~ki7+lAb?c;vp;iAgb~!28-Lo{4p92YzvSk3;4eRzbn-%+ zj4LVK*8%Fg@x6dg3+i#q8RY*6^)?qdPc>!0_)h<-9tigz9kOWYZQz~Y=icKByq-Rt zMg!n|9$oDA0LI_b-+#W%fW60F{;XF8WSwa1wF5k<9Q*_Kxj6e5%>52Hc8G7QH1ML3Ow%`tKuI zo~(LsKj(~Q#6^6){6GHs&`NuWHU#c0g5r4@wO790{ z4E7LzsS+Pa{N?_S^miLijfxW<8#{e2-Sd$m@xR%nR~xWi_U%5TzW%&TgjbnE?<4)R zPa*Y{e|2m^-tKA!;TavJ&o3Dm)B9<&4t5aUjrhxz$a{S8B=MuxA$bISawt--$7Una z?(6rp)Jzp)=@b`Mork;oXGIg~N z@#DiUvL|u;oe@aVMSrRDlCex4p0AYhEs5rkPMWwNiRXs4yTy%RI|4g@d0;$cJ$F}_ zIq=p5t`SGQo^PQx7tfhXMjEd~p5DE#Pf!vJj8Z)ZGwiU7vPvxp&V z_v}+G5o~uxWO*Q-GpK*^YA;@|&wJ<_+8yryD;BZzY+<@SV8Z=ipL{@v5TV3i;OAO| z?HPf2=Hc1r8_-|=dE)!H1m@rVAv0DyubjWR{7)wE?zsl!x`5Yys?t4nN*f`4*W;u{F}dyfWK6Bt!g=A2m3Q_BlA}mGpO0S-d%r}3I0JT zgKHtIOFwSWd*}=GOuUT`FZKjKy@Z1=ss_#lxxJYVg7vZ7M?E`kh0=GWg# zrq(3}LVPG*?z>WHFBR3n`*IcB_qL1ot%IPR>AQ~;zd*fP@;7I>I)Xh6~>=;Lk-5{w-IBb1xEe9^{^Q-bQKM|CPuV+d<{- zkobMz0sQXT-&j(>U$!h^?8EaU`W_l(U02(v^Gm*RI9qg3J2V152HC>ze#O9O#}Wqh zeAoG~Z_p1GA9$w!aI{e|Nnvlx#5<_|YmF=-V3*vw@^3$3{rw@g*WV55)2>l|^>wP1 zdTzCOTt2dciqfBD)bIiP%-yN)-~WOCJ3M#23;4&>Yu!5z$+b~ArUzdC5$>dNH>cdV z3-N$jv7BLT=rUCXa#^p}5}PgNR& zABwX4x>-IO){%TyF4=?5=)c}6eE@jV1Mcdb!1Mf6F18VPWef5aX{5pVe5DhLYhYX? zwMpd5ftm3YI*>7vxIdIUhqWjYu)`{~Y7Fcs-M&$94e->Y_2JXP(4T)I zN_7A&<95!%eWB>=jHd?yZGC3RF9qJr%-JVKkbY;Z@CxTW?S#h$Xh)HjOF}f@Ox<)o z*0Ve*R0ijb^4jAEG0i?NWiR^4MvnaRae!IRS=M2Eb#dO)QuOOwM>$=Qcm2mPW8~T7 zRsT)^Y}y_ikMoet#@l4yr~B^gWaPOI|5%N@gi;m3a6p-5L1ev_;hH{*^#4 zy_xWBZd4N7+(!HH1!FYtga-XSGxM7jee3i z#BcZQWIbJ`|6wuqn_y@WiIXIpvLW~HkiR1WuiK^^O3v#Rg(di)f0~j$N$S1eLGO!j z>gEyspcT4-?58YHFkOngj=>qivv!Ih{c(i+b25GL z_mws|upZH8D(xJO|8cFyY|B4c|Aeo`iWUoA03PTkubYfo%14;4c~Dd@G!w+{<0d zA|23akNc4eq^#NfQ4SE#oq4$$V7-68!E+k?GRwMk^BzTYQH{cKL3?1{6>ZsnhXMVt zD02gM7Q~ai#y*{RI|aHXYT=XX$V$0IfF+2B9Encg4h1K!3*(N=2{ARcy>m%F5=hg#Qb zwqVEeA5@~w^jgW1L27}u<6jN_A!s}(b!SvLKk0&5(@p9l<5QEnQKliNYh zs=to#T+5(F)@$6Hc7=Ve=SlPOU3;lB{)x+7r-rDIP}>W!r`xE5ky&&09%!Q`ui6`T zb+=L{o{yN=Dzs5QxH}uHTH2^f?CDQ#IJHr3H!=kO9B-q(hy*N@oZUu!5|MpZmDNU_ zTz<4?XKXtaEb>kK(1$k4B|_nbg?Srwb+#8nu)U4?y!!-K(7H})P}Pyu@NO4%`G@5Z z;g#)Folo{3bw(SN{?GBf>Awyta=TNeGQ<&9)*b7cg7edg35zHBblRyYrQ%Wr$9C$x z_T@EZvR%}&)Uornpoc0<{ZHz^KEjB%@>vgyHtK0e(ELHpPAaW>pc&5>Ne|xJ67~z; zJ6q!~y%)}ZEKy79?Sb>l{=8p@ji@flW$if;0~l|AJKq>_LOelg-5PUmi1#r5yb<<- zb3cq6+L zJZ~QY4RQ{__gGn5BTDgw3;B`?#*?lv_R*E_zHU9_f<@~ zv@8}uI|EkIf=xZ?bPDQdvRF;uPSinrkAwG5Pfsu3TrZ+L7xRBAq>=rbxGSy1@5T?& z-{)Z5bSApVMl6Hq7{NcLBrR}YA@Ro#O3c#m`sGi>h+o#+agUrM=8~cRe_YG3CMma? z?L+j2uE!3NzHmT{=q>N?wdA^Mr|Iu(Iru9RUWUPQ!i(Nd>z9miTEBd)rq6?XSx28s zzEtZ;?D#55pC{pBen-M>P9v%3g$MopkDi8TlIGQ--&doU@8g*X(`h#W`g+MM`dqLj z^F299=64mm?$Es6F}hxxE3`ei%mcfnm$)k%TYwq1g-`7Y!eIHXRY5N(up9tT6 z{u#nE;Rz(a*VlFK_V~Nse(Obag52;(BaXMnTU!H801CE9k?}R@{U-@|s|+?19knya zjofEi#Txh*TcC?FUz2*lmd!9GF*EZ=Et%ZZR=2veQ9}@i_g1hgXej)TWi?*4(cEGt!5p60sA@j zzePLyW8_cZ`~YWGoA5bxP+PJU_2}xs2b=Z*PS@=eL_5!U1!yB*TSu}0`EU0L-@@mA z=BL{b+21^F5rjOW>uw}2mmw?r0@KkJ-_9Zb*qAE$PSL&!E- zzmk3a9KhlqJFDiSzmPPk#d-JP&n0{Ud%|t^x}Jk}q#w9G-3afIeJK5W)E)ZCGj6`!U)Zl; z%pbdI34D2>ZuYGZcj)a(>01Q4qwRr*hVR@V>dcKrY~c!n)N%WZBU2JTsP1%&BO;vYUsfw&< zF9FbTJdOu$pU;GKfY|q%bt=8oho|R{^{4k!-%s)l!%J_JrBJ+a!!-CmQLm&)=(k)> zmc`l@a85Razy3;o4`t}^=J<;Bebhz~7MAVf5O*7CnCJq%Wz935Fa~ioy)zg4X2ZFm zWY3@c+`7F~YT}>E2Jn6u@8z-1J;s2?-Mi1Qc2He;GJ`>|PgOkoU76h3cIsr~zrF7Z zI;hHJ+gu|2I;e)spKqq8+o_(axtCVK`)euBjz!kCv{Ucxf_8~+?W77+ew>e((@Ev1 zuWML5-9ZVeOet&4>Y^-1o6pK-bx~IsMu8vJz&UM|%SSU7c2RqKwSS0Dbiw;$%}&Xn zw*(}UyDC8cnOmx^T$0>HrLX#QDmt@^3SaPDmnR*@>))6n@nsCE@IVZI67YLGHtI{c zw^Mr~UiuiSv{P#>&YJ{n?V`NC&$Az2!=R>kgo0iH|J&Pt7oBq8yh?bfu`8UD7UO!P zd;TJN`Cg3A)0fwc{!DXaCTFFh9`qC4;UW z3jpgi50;q0x#@bdvpl+X~E*(dlxgPy*zcIW?8U*yCLvf4va&k1A?o=Ku_N3 z@yhxQI_-;X-D5t`vnG$n=iu|aCdcjJ1k4944#E={Z$0ERryI|Ut?{y*oB%u1+V;HH z0y|if6aDZxEU5Ncngq{@$DV`ti_%l+jUm?tZkW zSBSuK)LQU98SC{Z8@Yk=iKOB&E&Q(GmTl!_C6GRNx8$x5;M|?lylQ|$-0Soo0KP9- ztRVr{n>XEwdkE>=NG}R?=M&!M``GTU?|+kUUR`k@G6vW4Rna+uxW143DWrmNF-|t$ z&p4lIS53>K|C&>F=dUE-kLy0|)|jussK$ApmHns~>NwA9lL?sbQermO9Wb#cPyaR` zU+%44=oglzlosQ>{>9t!F1DNDK5P6jAY0xc0c@|+R;&u^89L7L2e#P0fdQKC!I z9%&KmDUf`I?Xv65B056qE4|Nk{;VA-=c@fg^Z+lFOmys*WN%_`wCD=DylFQn*LY6r z&3l1LqVcohI2r$Lr)S((yY=o_-IEYmC;d z!q)V;qS705IfphKx7*J{pO1dR{EmX3KU0@7zr(eZ`JIQL?@T?+{LU{74q^u!jv;8y z{GN21DgAyL{Idp6LFaNe&DQOy8YzK^f_)e(>`+D_rUuEP1WWSOp2xN=kz0b99-E;r{655 z`&+~AIN^!jr|tAorgiC~HFVk~lIC;D%n+VY4sBoD0vgqp(0u)Vy8b#=TK@{$(B-Vm z?^R50qtpBIX@2Nk`u7-!qV?kuwqIo2h3(@baZKyI!DM`Medr|PvZILJPjwtvLdFr- zQ*&ZZymvUcPWRT^Y8;;;hIIYr^WT&5oj+(D{@AXRj3a}#<3zW6)|Zp=z?xBlYc?hk zyyWOY>Nh;ZL+Xvy7$o^hw~7hwkEY+}Gh(OX%p3MzAw2aZT*U6Rk^xuIj>2yWWdDC6 z$ZkK*M|@UXET~f%ujzg8rB{M|k@saZk(_6bS@Mg-)rH^R%S7I`90Ou!g7#jrev#g^ zhCHX%OJ))NDrdKJoL2;vohJ4+eGDhBBk6~d z>~3=1Or$oc|NB{o!s3_-w-hF`Rd`t}ujD09~wWPU825bnhA(aDd-5QvE28 zcCN6xnPmg`WQCSD#y!)Py$r{A<&_&Ni*VnjJ9M%Q?W{eo+Kuz-)zqFBIB(wNUpX83 znK=hf?g30N?&iSuBi(N&AwOe8Zwt(_XE%~TYtLD zeht@69{%wf{j7k|N*#>PX1vZVDgyth{y5O?GQ^iIY z-B|Si{*Q{Q@@&WQ9;)T@MgdviT^2glUkbXz`Ngsqsi1opQ@j51r9!{T_j+sq`*=DZ zbTFX)zCP=ubl@+_fB6=_ZzjMh5m5%`dc)roE)0eJSA}xN&MmVRS_byJ9~gBNhe6G3KVKQ>3~@svzGq|o@VjhQ{Juz# zL5YQPZ&!eGuzPFOh4UGj2h>OEkJC zZh&rB^n80DwCfP_tECh4Wq8=DNMW#R{h3?R{Ll}D*OxI2VEt8hd)E?Su=5SaJvJ7w zW9r1R=y2%oretrmeeiobWZk)Y0Q9eF)M*nxDCbN!Xu$Id_0K9tW?&q5J(jT&27c;r z(j|O9kZncMiH?9S$~Y`+oTsRZI@sp8;wbb>rpFE*b;Tihtse3x?%LF*@a|gQ|-9O!A zgK=mPC3ENi@Qa16?BmIY?;Zc0oze&TcxsEwRc~nT^7n5#sAEkBEo@H1cx9E0*TL`N z#TZ_2=7#INYdFaFfIx*Z8=YhseayM(Czx)l>$98}n z&tnfa;Q2Ha6N~7rP`)r_uo~yd0Q>%R*P(oWW_-sxNWawE^bP0R>_9P2eZchG1M!&V ze6v>YGa&Vf|2FF2dpTZp7>_YnC>~-9_&zN0HqJA_KBaa0052+~TjP9QonLkd%ZqJz z#c)0?;Xb|)=V2ae&r0-TnzJ}fvApr^#;~w@#lA6wd z!>`UYVtE7KTt39Gcf~WPb$ALaKx}@z%?__`TANS&<@%l1Vlm$+%a-gz zCukTAqMh5T7~Pm3QmK9qaZ38p7et1;If;)sWgBh6bxF0X)N9Olkv;5%m~lL^0dZEv zYqBqU{*!?frmfGvBX(?X&nD-k)QT#IKi*lcO6u!hpZ?BV5Ho&i`C^FhTA1I7b%=5xcJC4YNb;>y==Td>7t_}XKc)3wxC*V` zRXOSZ-@NBp4dH)Dp>>=lYxPb!DBze0uPbqLbmwP=;0b^l}utuJqR(cjguWPXo2 zV}{nTnP=(x4qMRgN4hV`C+%o6zn}3#oi67qq4^R$bbU9Y=>7aB>2&#t9=iMxQwL`< zjv>yLwPM62K(APg_>fr3XbQ%_~q+QrNAZYcUzGue6Cz#*6d(2#S0EzHmP!WVq zAQ;G82f*MWX*f(t5C%KJQ6@fSt|#C}CHb&9K@c_}2trVo;D76r|H@&JNAjbX$Y7!* z6E`#C^>adKUNLh$aNr-^50=dLN*kE}C#8h>e{GzY@qD}I^mT6C^!hA_X=exXyU_pr z-_s^0f8%YsUmcn44>0>tk=c*?nEL|;{dB#vnd>JOCJ#g-xu42YG|ud!aqK2NE;ZTd z^`*dK`n%i{<@9$rT9q`(^C0t(=Iec@*Ezvj^tdePqtA^vy6z?QKYl~oDHlkO7jtiV zyd6xZ$GhNze!_b_L)XU_PxCMN)BHJ`=<}tD()4wDHFS9cb38u!PN!E7(|oB$`rK;a zaX(_GwH^KbEl-FfiRXJY_EzHa&n7yb%maQhhe`W+>GXG9CWS4@bDHfG215ekGDTNv z5v4;Igr{;enPBuA`uwYK_hG`1JL^W~6KWl8uay+NPEs#VCH&x_x8!-{F=Qcj6~xl( ztwIa>d5XD7r@0g22>*-NG~w;8vdqKw$2tPE5xXL{UBdbNy`6bJ`lsRj-51c0Xx?~B z>^$Un^e*z=9y~zKjr5+(t|R3-tS^wyI`M?qS!!QM;u4FWY$0*}rea&dFKyla9P5{M zpH12it1=_}@M%L5_X*Z|MB*);Q#Gfto##f&2`^)*HnBTm$c&^DVh<30+V(YM-|*m< zmJ$1k>>q%#S+pbHMXMY2h}A$-9$eZY~G=C zACODWXj2}bqoiCU`YqQup^sQzscKb<_UwMTyrJy{W86;#rNAED~6*{KuRV@wAnzFShgheTNd-d$wHi7B^u3 zT$_E1LC3UoK5-}qU2>Rz;b}3zzRg_Htf24rd=Pl%0lcl!u7k>etcxP{#eq(d2|MGc z4m`oe=(*C6PRpAUf_Pb#FE*kdg1zD#!IQEfE~NCR-lgcm}ECv z4k#y)Un>q6sApV^I%@TWfI`$q|I$3Q9RSn9Rn;)9Wn$4L38*x_x&i+m;pCPh=Qtr< zpYpaw3Q+lRvsMS7=!oS%{0`t`5T8O7@Pz&x7kCHut+H6Fz7W!?ikZIRfS=|(kHzoz zT0LISpay)gu5NvO(9x%jZ?RkhEctOl)f4KQ_pB`g$4AfHyRjyKa%N@xs9#G`7K~xM zS8TG~5ckbkYi;UqTs%+w%7WufyR_gvu5%0amWu8LEZme9wgr%rYv-UI;7+|yjX{84 zRn!_w0KKoDOs~Xp6=A({=+~y(^OmN7&NlG98fXFbEQ*;Y^BeMw`kr`ihWl9)s&{uU zFmQX1On* z;5(yS?C146PbX~yG{~;)!|__Z`tWvKf2id}8sdE>Nb{e-=Qg-)e`XD!rP*$umw>s! zugQ0eW4cO<>>xe3LUsj?D+^nzq)xC`Gsxl!1IkgFDwAxUbY{` z--ma^g6Pobuht4^@8ly*Rs22F$Aj0}0v@wtwBvK)$r`MJ&xzcRz%IPc{<^={(QZ%8 zI(Cest5FND<2>Qu#&ASC4p$x~-%D8Nzv?O0*CEut0(rp^rBAV*8HQ0XK4-zhm!z@0 zQRy^D1Bkax&-TZ9+@F22#(K0CEic6UJ4>vdVZP4HJPS$aQKVD~W%JUL5-w>v3-H zBzky%XIli?8BbjUsQ~>xv4+Hnx}CF{Fl~NzK`3I>SIauW(_B4^TutfB98&HxL+kd?M7mw6 z>2Om2s)cm?UHB;N*B=GpYM(eZZc5Za%+-lgNkg5@;tc~>oIzxEjY zdj+vDzJ=WB7|obPU{|>8Cqw>1<`tP4=S6pDTU+s%%;p zd3~gH)#i=rqPnAQ@>Bs>4Udu{K|~)n=}6}AiRu4?7y^~ zMs4Q4LnHJ5i})~g??tAr9X>$wbnR%|&CEZs2QhKGdI3xk1RI1~H+<1zIz3@TC% zKMFzEtopz7cV-$M5|R&p2>!RO_%9vD%!ffm%KziTLr>E2OoSjmN&nX_JVgJ;|L?m0 zcy`SG8D!!+=KcLVMqii9{4O|re2&!Pz^splnXX`77i&nD!y=#XU~x|HzkU*A@_m@= zxR=cG|Lp$nel3~#6m$Iom5_S=yU+jb2M#Th{4l1y3E${(IlO`%$EGH9`nDte99@W~ z_punvb&HrYeSL)%jh=lp>P^z?sKrb>?fzTmF#q3A`yQHim-)TM*UbOF>CGH(HcY-d z^Z!$p1kwDj%<>~l{zhi~+|1`E{4LGXouZ$QSTd8L+nJ-OfcXX$;C%GLCJ zy&j|YpX!U~=X4v_d%`;{AVsjzi|&Ul%yqZ8IQ`s3deZa8nJ4r<%zfs1Z`KEzKmC;M z#|_N?Ph`?U+w{yV94;r+ne`zRGSdp?aK; zn?q-azsNpEe_k5tl|5$~(c_!xE7S*)MuvH)k9VbO4`cf_5e%}9Qi@V2#x(me?EvJr z>~qdSzJr(~gcd+2hAHJEzCM{s?8%B4n!xmfT@LMtJG^+v{VVpqg+~O|oo{)Fp9|6d z@d(pFAu6QYI!K@RBTs*4g00+7$olE)w~J(bW>~~HiF|(Zg=D{|<%gX!>S;E^CB_&p zJ!dND>YQA`@lth*mLQyKp zzJ)qjN>L;fDO!}gZBm3%M3zXRBoYLmtoLSx8Eu-`u(P`Q!cl z_5IA8b7#)XoqOiY+?jK*pGqf7v3|n7cG@(Awn|X@ue;-WGIZWvaU$K_C;fnE@0HLm zUBtRkU_i!=^VNHvN%UjviGytf->eVwtci5b80R^$PRhu4zC`2~_5YG4(741rmY{F1 zmBstJITD-R66tAsnl`2*e3283{W;}D7cP=UX@?VM|I9~t&v}`iIYLivjw5kz;LW02 z#l(6hL|1r$kh@e;okiGP(!+lYh<4HUibWIlS)Bb#98V&#VmyxXb4vH_RHFU)t1n=G zn0Z!`-h`YZt-;EKe88>KC)OWo;dUe;?` zxPwT)f2*;EDEDC09rKk4WrCcHToEQkYAGin6f&O&)+5yZdF0o7gq}t1n~CQSo$b;j z>W@5GmQB>B82qcA=--~N(N%=}x5cNa6ZDuE^I)R>k_%6Ki1*MKS|U&IGym2h)q~Eb zJYLmH$l1sEz#-^g)I1jv&n3CLZ6M@(&9i++U|Oo?Dnib`H2Vicc>&rLeZ+ImRAjI} z(ZMEMOe&P(3XsFBsY9KF|I-^3L}CLDz-fzPxL?QqG>i!-{(~4Y+_wh zRkk#fSg*I&H60@A*Vg9R<9_wB%_Q0tXt;DMk=}Me5x09uo9PZB?cI8F0fCQpuAfhQ zcjw|9@V>mN!9G_a-`S9breO3xFy)y6A$N~=%5_4{Bac;#iGKL}FTa71jOC&&JG8&?>L4!9ancRE4l#%_!*pF^zH;DDd(mngIo*8l2kM$}y zI2qF;7ax60lyfqC7S_)Nso$}llpQyK_3CW>BCL;$b+_aEF3Y<(pJhqzBa5BY!}&~| z`&gfqUL@z^%X`UrE6Kwa(*rt|zFO)Wr^K^kV`TR~Qj^Z}Tj);sP_w!4r z{ZNx{B!6)QX=nVQ>@^KtGQW^Z);Ii!q=&ncxP1+YrSr-C$su!+&xEoU%BeUpl9b&% z$)2Q3xscDH!wvQmVMzaa1`v6rV4Z z7R6VWqtbi|vnhN+Aqwt{%b81I8kLVeI-HLNF~(|&juzcGjXuWz&~yGTUql!6gJ_)~ z`rjZb7ZrlbL4)i+D0*H*7s-nj>6j0FbpPT1|L6ZdEn0Vo$`h3@LJ?iG{t%&PT_Rc+ zj8gT=QvY>Cd?NWo>jlyJYYx?KqVh$2NO@xUMe>OHUDRKqd{H|@{e_G({G6y>k^CY) z(KX=Wo{`^X%jVb&}m3x^=qsajCr%*UZA-ZIW^P8!4xMv5M_PIvthXbLcKAd@k zTyJc)C+TAsNnA!fw~V^qBIqR7Q6B?H`f=(UU;ZgFtxKI_i=x(T#?*O2U20u1Lh+xw zMDmZL^qL+u9=3|UZ|eJ;Na=_C%Ot3yF~tf`Fx#)=NG$SvfLZSq`qY~lX}i7oV>SlVITRw>+b@RPkw+b_v2QQ ze@+GYKXzIjxxb^bl;r#8E{Q&yNz6G%@<;ZOdVbB5FKDQt{W?cEv~_^&FU1l(&t6Pq z;Qu>qw-h3Y{4+_KSk9VaRopH^wiSM#TJ%~xufIt)!FGa5u`wFL$PTCc>^fwV@>p4F z;ODdKUSoWDn%wu24{Ji3E@*LlX-Q+roU093jJHXGt=)cwy^Bs@w z#PV26DrOP&K3JBG<6Qjh8f_uc<4x|n5U7%tqeY~9)gPrbON;!ETgai8xZ?BiIa zqS=If{(8yyQo?TjTDAq>kNd^Avz*||`Ek;Mz>nhPNcEue8l98yd;I6R6jEX6|ALI~ zI|9S~XxJ|DmuSN8)Ai2zi$s1&w#N+u^&88PDnj=-g!}3VeAJ@N1F*;XkjKG@UB__ejn>LTA(Qd+2xy=NF}2G8g)-U5@>bhTM>bNeqVyr@q1QqQV|mA*C*|8xtql<6cFj6C;#B`w|CvZ`}t#jFR=WAtz~$e zK1|od-`{Um94^0gbS)mo?<4H6JgMF(_<7Gj(*HxFX$7WN`7Fcj5)Z$CaS}ffm-8tl z3L}F<{@32E`vKEW^pbia(mxE-;~$adiWNDPSk5&LZa6^!t@hSdy$eixB?ax|UPtE~n}`1#w_q#hT( zBhe<5)YGv60TYWV$prtA?>{P9;5 zznVWuN1J7sk51Vo36#Cl5KiXnQ})BZl->S?qTi=5m0DkwU!BLt<%x@;U5Q5_l}wILEfY1 zo%THr+#0)ht9cad%Umpkm}0~~;n0uA)6u;}uSw~A4<0BzO!xob#{+#^Z>7bW9GLOC zX|fhN4|^mg>^MCXo%27RY}gy!3r^pSZNm<*!K|n=(I~4IHY~d3Y%b4+J6B(B)j!$; z(+d+y--Y*p(T;L=_qW|}O;vYeT6zyuE4lIoZavU2KgDpRGaH%$-)E*Cqk(Q^-|Ky} zE|{=MK3DZD8v^$#OI4$C-dWcD$l1V#)qiKKD~_bWfp3{=*RQfbX3>Qmu0}oJ@wfM6 znLdi&SJ~jJa|*@X+y0&5$mxV}L2BcD61rgP60ZL8nr_f}YZ1_j{55ElD2jhNh3<?$qH=mZJ9s#~0UEHDn|9Lq%hCqB)*c09TW&6^3g4je+~$diOobQwDqd@pzqYp}Bm zvL%w14{(s53Cn}B@CWTfUwZk&wi?Z=^<(p*qFIoA?5cB|HoEUvGt@4(ngJDWm(5G~ zPJ>SeKF(A*O#@|><2@Y#ov=rK=B6$-6IwmZ?&`%cU}kg2w`N^B3{Mued7?OcwQABz5)LcEUdE#~ww_ELbg6O8Z_& zgRBepoEx%f$gj7q7k?fd%6=u49@@(Q|D-{=_0yQp-m_kRoeCZKZJpwhJV1lHF;}u4 zbkM*&?8U%@lQgjF4jHSrq=7_CtWzUuzxu9^y9F&Y_!Dxh(FC6Um@##K7_KCfZ< z6w*OF#V>1v9UX2<=U3Tu(O~DnTRH_u4z=Y~N8HqCpt;dvx5We+oYDLW>6k*POpJXu9eC?s*jr zijGvK#=oS&7p1wY!caWMlj~PMGp?Y)HKzwlR4&tCLzA1;&{rCq<}W{+FiL}Q%!XU? z?`bexRuEOeqrs)~m#=(VK!?_clEw1IbeMWMSYv?^9hAdPhb?rXgVVID2DPi`5TLpC z?+ax*lvvompC^q_Hf_b3Nl2b!GWFA=&^Y*L&$4<-gUkCkN2I3Gfw3$|Em)h5;+-eO zURq3tS#bxfQa;k)sK!g5yPY&}={H>c)QSP^^|nEwElgO~zW7%H@H6BuCtE7ZRanP>=^Gv^8_*c&9tLMl ztt=B1G%^*>EoMTQLgR4q8alk-)P_87q(lF3(f1dJ7_evkvD1@U7!cBTWp>gS10LNw zJZVur1D>vW7va;ufQcj92LaK2*7hVP{A9rL+Jr0}G>*e}4;7uQLld<0~7`}%zAJe>93*A)dLez zyPVSQsxM)J{JY)Lk8Wmy;XFUPE(0dSL_Lk`Q$YTIUVCnpo6Cf37n|14dQ5PS{#>qb z2BkN*-poh-f+RH`y{`S2346>|t(z6ZfEN2cDNY#!Tq@RtT5uWg#jpRWEb>RFbbC`sKt^SmQ@^_?t z(L?Rm-Wg=0$zwqLJc;v$o0zaPFDfv}mkH*JE@&o7qyBg(zgro}8GP`XqyV*hhgI0V z%@#~hZ=0apzMF~s81$`bDP@9|zWeV#x0%op_jm4Q8zwaQhp>atdtG9fUor{F8S3Qd zU*XAw(dapA{ezhhF)7vC+ldL+PIO&JS3zEVa{2MRV@!CXIBb3D7V^*Jl_~XaD-!}2`B_~1jrwDM z*47l{KgnM;SkrqKdT$%@<=VoTpn9d?yEx)wjCZsjvh0NT8y}IYkWTn4|7rcl)l4vG zStB!tKLZ-~9BMa6dh6!Y<@b$-G$Ose2)! zXZGg}anO6?-d8f6i{xAVZ?>0dCurG-Pd~o36JqvRRJk%b;qkOnGlF)qP~0+ER!9;H z+DA>lI3xemjE-@4rXT7Ash#>+?I<3rYu|UtJ8mqPnkg0{m&$^x$M%PQ^Fe-|q)Uct zV>)4F%*_U`HWc@EitoZ)OBURh@d*q##RAEkXphZE&N-(%)m1m3`r~REq>Ioz8_j!m zONj+B`76zJTv?E781A%YHu5heH@K?YsuO}2Z=Ciu70IV2DL!XB3+AnqOE_Z1g7j}6 zu023@#_63}&3SKG&@6V9dk@947;LOiNu1gZ?)vGsnVH=X`pd%gQalUTe(_fNbQa_! zr&VUH=mOT_Q!%?syTEg`O}v{5idT~Q@kuvVrzbk#L_PK-IIK;+oKE8f2gc%N$-Z+cLuNhMt0b;fRCnA z_M`jdslqcX|nzMcbW{$ewJr`==P)|Ju=1sqht$Khgo3E&FX3 z6z;RWoI9r*LcHib{>Tr*b}!2too?uy<$L7E;8DihY@y>EDbpEqE$17z|519OpEZ40@ezm?WYBvmK!!_CN6v>xtFp{Zx z{yc^a-f4ec7$u>5Z91jf`p2`uT)X$y#xHF6WsqW}Ro)BygA&i=kbjHDDX$8}Eqfr) z`+Bu%X%G0WGM`s}kqzM6mGyHY@(UsrYwz%+7dH2g_tVZr_p!7lOmi7V_qdX|Zk72c ze)G=Em>^XDRMjiWdR#WFnH1q?eHiuE(F2dl&^ge>PxD%bKlgxrnaP>uNUqry(N|;g z*zi_e{b@of8^pF<>wfX57ZS!crF5<2g7QM?Mceebuu^8Z)A6HRxYt@{P&SVPXT?4b z8lU5!_)miH)CLan69Va*M>ue_)Vo(}I~Q)ev0a^3+6%wcqjFpsy`X3O18S@|5WaBE z`3W@~*fO%qLr=hgQ(m7YBj3@;pZn=)?dH9((In+?B#MtyuaM%Wrp*DJT&3;)8r`1K`4v1yZ-A8C>`^ zMP=x;4iC7^)k%jIt$X#Nx@7FpW z%oppw@-UePl};^+%Lh47t2p;_xE&V)`&()S#azf+{ru$7EqySWl{Pb|st?+nJ|0R7 zi-?e;lcGgjChwje7HF`I{H>F56sSP z$x$B9hqC!O78?tBKnpSYS@(bkl3Gc!>aTgQQp%?Lx6l&1#Dfb0{nzVl`0!5Gr1GmhA2J83zSr0F!NkKie}}5_;7fg^#lch_ zjF5*&YTJ%9oXW*5Z>!>`5i`ypI@?c9+&8*6&JaAiRm7jc> z2g+vkHzoKyXiqa=9){#^{a~~?#YF%~GhKv=K3tIa@#djz30iM8?J93S!-r2>_~+cC z_#lyJEvM=!0G%0S&Rz}zP)~Xsc~OTCmmIh3P+G@_=-Cs!ysz@%L1#|c#M6A(es1=^ z(RF;d^P`OCpeg_fyN~yEdQknBQll1j^Psg%!?J7)ZRs;o@lyd>C{7WEhG1#VA#x z)?Oa<&)Ui5c47iFK5oVOZxz6*JFP=$s|DaF$k6mM6hK*mnav9)0R(xhzbWkEf!3IL z-*zOYxb3vs0vZp5{I>=IKR#5@Sk51k`EdP>d!Lzy5Gqx&mfc5~c9i!?1l;(~>Bq#gkw+_~v&E-QzVX)t_6GDi4I#qAzkPw2Z!lTZh{%0zimeN-Uq2h_r9ko?LxajN|ddj{B z>aSI{U+c`uFXsXZ}J^ZB$8UTAq7*Ub>3_?^h@34C_Y#JkBUhLLIuF{P-DoN3*or*YTG~;A-KnmbI@NaguOFq zEQeDsO)r}j{+s+GN z?3HWq9MoSYjz1qg;4XypXqNvh5Q1*alGc&sLg*dmwrt!MA#7P1^;i|jG4n@E;kiK} zR8N1ktaepD>~UXM(|LpkYbsTA|4HV;l>VT}jsiC9zi!8<_eAqp%4o1R@*8gaS57^> zK?q@zW!vnLoCor_ooRdd5Ic=$CNsi?i5&%-Hl%UDZ%gm%iHSm}mzW+sP$vX)*P)RC zseXvq=6ulJrXLDSeYt@<`{DjwuCa`@5a6YW)AWTx2$T(!`!0+6dDonIOQq4c(c}l2 zpzomQ%;mFYy8UqX#g+pTefq(DNAqQClpgF&`!GEfwa4b?-i!N$5c%+8)(G+=Wg6!Z zI#GrVJ^{V|{IKpr@k{ST_eKaoqJqyl)+B_1z%6If(Y&{4qs7F<&--9a(Wh^z-YAY6 zYxk9}G}JGdMoqzJ+%K_z|0`#GKddpYj7@at2Tsls#~qJ^Fsn6iYJn5_PShJl9)t=Z znAe~kiR3-3HdqJ=i|q5P-=T3l zXY^9pgnsz>c2?opFd_Un^Kh#TdY>m%A#doT5b|Et-B^M8@6HqHkvP5pWR;|yrCqoX z^0n7U<2M@?7kXwaD-pu<_v_C5dWpW*jEd@-PeLe|+T9UfDS+I~UK74F^PuVY70r1^ zgrL-uBcHNY2+i($3%oc2@N$YgZgQ9pc^>P2-YMe2{v+W!I+uhnL#2Aa9O)Yq^Q4na zvji|%P9vfwmJ5IM9?zI^uorrj7Vg$Z-=Bh^b*_Q05ELuzez&=EYtz;~SnfQ- JaPBTP{12L7Q5FCI literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000030.vtu b/previews/PR1697/tutorials/out/solution_000030.vtu new file mode 100644 index 0000000000000000000000000000000000000000..d8a379027b57c655b5adf4b5500a35c7acdff687 GIT binary patch literal 19045 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000030_celldata.vtu b/previews/PR1697/tutorials/out/solution_000030_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000040.vtu b/previews/PR1697/tutorials/out/solution_000040.vtu new file mode 100644 index 0000000000000000000000000000000000000000..790cd7e0b628695883844d6e240148c1b124a812 GIT binary patch literal 19091 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000040_celldata.vtu b/previews/PR1697/tutorials/out/solution_000040_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 zcmbVxc{tR4_diLpWJyT&k!)e?WEm2YB-yePV+k|NjGa*llQmmL+@?^3FxIR?23fLi zW#7gw8v9s&+V1E6KG$>ozTfNl{By2zuJ?JpUgx~e=b!Ud2KlKxPdhx4lZ^O0IxIH?j&mS8%76$kdp!M+C$wvU|={LdUD(w z;c9-{<-rX*gq_CUVSp+PFR${yv;GL4gzvh5?ZLcvyxbpvVfv1Dp)L>vTm>K_Ed}^H zr~!6!JBdmE#QBx<^VlzhpMf8Q>M)p{-|rH&+@N+p#oe)UKdJZ^>^~4sv_T=@pH$KS zUPma*-43Awu=DT$Lma>-4S_m3!oepIAVA^|i?YNol)wF-vi^7{mHfMg-|hLOz#a;L zfb9`3-Yy8g|Expu|EEJnK~d&kQvNrxU+Uri1&^$p%s)#04?M;vRVkbR|7`1zIr#5b z6#v1ZEb%`&sr2IDP2qQlKm0P%um4O{d*YGHxb01XO2&np9$-dB(BcrD57q<4M^cwbQq#ZBxx z1$XY0s0Mr^j&=DDmJE*5HRI%SY!?$Nm08g@W1u%7yhneXq7%@@Yl8OADqL2)w?F@Q zE}nlnA_&A%7h(|4Kc@_SqyT{Monf(!oJD;|->n%?Glku-oN4N^^@%oD;}jk`q(t#g z$2U{qnKtMec62i{?H^GGSQWWCU*fHdFmCMZ_^?CvFmd>HC6Q*M-U$nZ^-HN=&+i7g zbSvWBgKD!@!)M9WBj|`;+}n!1cSH}ZpiJvra7ickb}Ia52!vi2Ax6O>kmKX~q=Q_gb%07Cp6Dst?ZmN874|*`lfXAhH zdFM;*Q@#kcl-ukr7r|FznL6sH0&T5X2%r4THT=Y*@x+hgyYG-@BZ5e>-UJ-aLko1c z3a2OT)oKd$E>b+Hza3rhM=Nfd+(jLt-;};{B~ZlRKHo`F{DSg1Y`NPe zy{a@>KUnC(!o#E=-TFRozl=_(oFR9oBu1kqk;Q)ySa=GE6x}jk;M5qh!p+XyQwPgF z*A>yUQ2oS0eT+uL_EYc{P8-YdG})ZChsf@1be@wI{G`VI=;8#?&r zS@nZrX7n06Bdro9&YGMv4?;Bd-&=uaR@gQ4JFeS37jJCl2^hIb&r9B&8P%6Z88J_h zSogS_>uu*(30&s!8w;O+;_N_b;B#YoTuZBF%|Tai-P}SVg}NKoPh-XjAEF)gz0WA` zG`}5UdvX6XUVBamaxwde8F;F{rY?(;9|A94Uz%_7;vEUGFUyeU9Mhk*A%9np7aS59 zOWdkZx-vylcFT~SC+9h+ft0kBZc9(c;0nfsdHPP5`;Yg|k z!!Uyj(^p31szUt^&%9YqwtCiH8Mfy1Vb^nA-Cg~=Y6XWU%E=l>7%8u#zF*2;?q8n<9<;Cu9VEtxrNm+!WpxE zeD2n$HneO;+>*#Om^~RMUNvxzrv6acUM`w!Xvhz6=BvCfbFt-So*$_2sMIMU7=*X&;Ue;H9y$Ua8GIMqkTYk)zx(wa@xGBjsMHrRW!(m~Sd5>3N{6?Z9~!&5x52SuUG=das<{6=Fjgl<@N-tmeWxwDq>Dz066` z5==gZ7X_mjAmr{7@}xT1#+f*h%H2V2jkDW4sYy87T`<0{ZnP(d2&EV`b2{wgqHdT; ztX*~u@>Bwbl9TRL)Tvo6D6SeI!Bi-}LSR-Yd2F9jP@k!Xpk!TwGJ`aw&E&#=X6 zk_yB5aTyA&gz_)#P+#S1V>DM0W$xscDvmbMrA%ERR#RUz2n=jb{5(RIye!gM=#jM| z6;tXQp9bgsE)Z(flnutdzbU^(b$3u@+CJlAjIV*#v`zdqsZ>(%PZi7{!+7vvOMI|X|?2C85PifP%>DhS(-g-nXcibj{Qw7d@YeYC~s zrBDDBI5#kmb4*n|wA>di_oSrJu=JxzKOc9AL1n%(lvyEt(r$D8hU~OC&Z(8xV9J)?Kvu9mCWArYJ#G`cO3o278PWI*f}h* zw(W&Tfm~-e@XyY$ACEg*#&_v(Z^h5XZ?tA@CC|#UHc%J@>sUqX0^-9_ElR1)0?VTG zs|WE_7~S=}g@bs6`aD~cJf4472QM(A9WhDj@ek=r0de1X^wxn%65CQ9tP^k^P5@omvb~=1k>AcP@@yxM7ZGNHowo+QSt~9|a zUcSp@+(NyNp4!1VpOmx&6(McxE9rw7P*JCz%iIed;n@F z0Iv2?#%9*f!9weks5Inq0-WkTZUu%dHQCH0-)v~aR?SPNpm#R6WrcIJ^V@aqG*21d z;;hPZ0m&9DQ1&j*-;8ZNeEMOb>y8Dc{?T|_ih%zhI`Yg^58M=eccW$ee#^cQe(%m3 zOuBiI?LtUHI(e`?H~o=G0lGQNa3_5AHrTFC&oQSFQt1qCDl1%54&zHraPs! zwRX$TSfHZ>D#5wr8$ye@g4qLeekb2(uP!M+?LOZ?nS7-Np7OYI+_GAmy(G&vzLn#+ zTEc^?cchDfaET(y=2)FePFKVKQL)}6IxZKDiLGUJmP#OxoUZnXW^&}K^YvLuO3+B@ z4!{$#b6wCCBJx#Q1JYCeB!%Wu-VUBOqQl8=i(gq5*KFiBqDRuLiw(BPIgpovy0u5n z5*!%6Jdd?%siQ5 zXU?)sYwzm!s*rX;(w`^ETn<*7txZX+*|Ce;-=N!q*c!OQt`g}9#@^5PHZ%en2FgYa zw(HOsIU2V2lNZ` zHhQ?bRDMXYkD7?DR_u8gsj$8R*_qnjMi*LVWym9|gpe?`i%uMbH)hqeS}`*Xw}kGq z+Q#gWS33nbgz2b(Sg7*hc$+Bu2@iweLNe z`g8DCojDHs^qp7GN$g~H=jpyN63{25s81v}?A#QvslFf&ExPBsuq@{>X*dwHWtt%w zn;ay?Z&M!{{5hadg^vR+T5&2=g-hAjsc9IlZw_=ik4!`bDaA9$bd9HRmp0+@xh@`{ zECMo55h*oaWQZajuPjq%=3VeSGz@e>Y~~oNJYtb=ow-o2+=E+7{wj4Q&3Iw(eGM~_ z=}Bz%xvME2uKI`L3Je`S7ehr>V2%x<%!7$9kMx7Kly?sr;m1W&x?@hRmuP^=Yq}J1 zocBv~h4;==3^BZLMZgkNVXretlAl`*fw44y+1i*ig!spSeVC)$oj2g9VccbEGt60` zEuA&yzj}8{M(UG;wc15;rmC(5e>_^fHKe45c3bSRA4IeH?VEn7Ks+u<{$_H#-jJ3r zpYO1ucdi5oMS9N`A($w{KLCk(iF5^^(5>POlw(6&+Mo-~HFSku%|xAxB!^sj6wYr& zh`^P~Dlxk5L@XxUaYA`z1`5M}y82M>i#Hc6g?*BZ*HW%yrO1#x~`V0SzHX zqe<$V^aaq?y&y#_M(_LMCA(PJGlY+xVvi)ZwfcvL(BCYl5>=J0&URLh#_z0r3~cCC zQ`utXQoFLV#?*Yh<_^0eXfkUNNXf5aj|j#;fJomH-$_zs z9?uUrtj}j54ivv`1dTa1V9y9^Ot=p6);X`Ap9$pSI1`q|(|--McVW@3qHVxZ;aLiX zXa6FRDQygzx<<4`gBPcJ4lbD=JSXj6W_RYA0_i&5wepnyRFIO%h+rf(t}aje#hN#i zX4RV%TA(?uoKeh4ccvQqDrN|#JkJ~QkgGeOyfxKD=DN0BC&;Em}&q$xhe74|JIOGN1R2fsX+eV`xA{kh9x17DxHhZX;pn&W#TDD?0- zk#egx{aYqy4_#~KUQb=+Ww+}&HNz$JexSD`2nguA(Zna#ydmxbxh&r>+I%0n%VAyrzlOhGcqP3R{+kP zOb8E*F#-j%?yxvmzQjPL{R|E_Cj=YZwQxZkD}tXoM%WdKosqMbHZ>#e%YcG<0&#z7 z5;X?Bj6l;a#0#l}?Cvxl`9-nR6C80P(6eM8)CEsxPzoqXDyy%w9RPt=K-5_P~3R?zIVCrjFi zZeXG@7Lcx;!?HC=v)x_7lKW zhu(wdej!WQ$ErZcY=A~CMtT}FdWTqY@4)h!Gg50iiNg3V8Bi0xDrreOzB9o28+_;4 z{Id1efDVfrqxTMzGecE)#tjRu8ZI$eG^EY<#uH*P=AgrS^^MAg1JIeA~p@q!juM$3ur4Dh)md!!CJUC}I&#VlEDIFv#mY(^oSSs^Y# zA;nN3sZZfA_1kT99Ze7N@&0bD1)QH0qS}4w90RY|UJnB@F-x;2NK+b0u^399>yzTr zNQp~9r^hoP=$z;Yj@$&WD#3}I)q#)Ik%`rb`h|n=3rF@BV8s_slqQZWCSX|; zr*nf2VuOxcgH9B34*YVC%yQt1? zQ9fo#$poNqf~2A$P{2@9Hu+^qT!3F9hzPZwx32@gLblJgS3VJ~jL54DbFGY7u6&kS z8ER1(JyIE>R2f-a8B5xu#Lb!>yrlAd9`1{tShqm7eDjNH@p~e;M-e+&x(x`xW?yH#^)(iXPH&!q*do>>t=%wFonA> zzwM^;?CxPv9YRrU&QYBgqgwAredcYpvuw5p&PbE@Npbjii1kS(E~Y$YPkEM-5^BcY z{N!r;OSd-ql}4ttkCc{;UY1?wMnCC|c8HC(xsP_PT*brko6dSW*u=~li90C3fr4;J zc_L7PC<&r10!9`IMPe0ni!SS8W!j6BMT-EUSgE`skv!}**CM&)BJpLcDn}6?2Uaq* zh&{E0(xRBfqU792G1o{5vr-9dbumYE2~|KbTR;g92~I`@W2Azg4ToI}hhNZ!)3v}j zTi~YzVdn+mm$Kn!oM5a@aQb-|_dJ}54Njd5V^4-tn!;F2iTuJgHD-S%{o=2|Ci`Q5 zuYt*Y(^Bin$Z4V&{V5X9kgKA|teAoV6-OqjQ=YGz4ah}h4bI$+8e_3mgvQDU|B#mIDMe*HC301XeNDlf z)N+ZQ%T!xiQfaf_MkUq$fAatF5tv{*#)*btrequxB=ost{zzCp*XZ9|xlQ>0fVR!o z$|WA&Yo%1-m*Cpy|8V91AI0bL(-^~tiy z@*%uA)N5;3UaA|7v#*D@yHsaQ_8*_eLQ%@%AEHoO^N&6!dT$i}U~To=##dITzr^?d zvUZI|)ztC1XW0K3-wwh!QM+q>-BA|^@E`yB-|>&Ob!YlYur~U?7^T_J<^>hC>6g3|6h{l>KmIQ*_5arR zmgEbK{@;zSCRh8P$CtuIThG=F{@)kL1h4+<|Al>4#D4I9h*+zH{*};g|AiOoizTb% zf6)J0?|-G&*3SQ`yiNXF((ZQ&{Uf1m<-a6+y@dXh(6)MQdTsT3aDkX{wSS`j$$tTk zh?x+)#q6uZUYngZDwfD2BveIWx2=6)n-H@$drSGJ6f^Dr(tf3+{$+_gfDfREb(8Q} zlJedXevpLDkl0%!;k_k#?h^hR|8OF9iaR7?za;!kNx6okoid3Xa~|ZytgD0$;R7pT zPk9H#>|7HyAYy)B1lo&tP|PZu1^yKuFfn_SF7T!Os39>s&Jm@U$@75}vFnn0KKz4- z*s;fgURQ}C3n^Jtxm*@9$R5h8Z0ggPW<`AIaO zVm5n_GN)a;QO8B>z(a&y$X8r=#d){HC{CMq3;o%*zk%~h9;<0PPh=x>rXwoe-iPlc67ER{l8CiPW=V_7M{uLi!E0#;N|0OxSyvj zi|c-)d~lkptu*R6Uw6Su6R`{OikJ{0W*J^Mg7hCoKD^ipeqX_f8$?5Lzw-Ws4R4-8 zn z(TLnGpp~!8Vo0xO)J09QlM~XVh^YCrEFcy!b1!byC8{|pCY$KItUHB7-$k8qAlfa! zkAMG&n{)a1>iDJSHnJx#ACyb}x=oGiK=uY0jZfzG?`WhDm0ee1M&;3|4p{MG=4Bic zPSp6{tA|7r{eP4Yt?%+urW0t;sNE5&pbc>WTGXE-JwMN*@;yKLUnClDxJ{pE=h_q{ zqOqw-{5u|U>x_UPW=={y5y8Z)HC&m`|91UGAvB9wddq39KkD;AL^=`69r=}i*Lsb< zsl<=Vj^0Z&%EYva=!N(D6scZtPYg47J&o{k;`Mc-umHvEZOQXAl8^RK`lkpWVwRkz!q>-`Cp-9h*nLWk>mRMX>F0r)x<6@^VXFzSGr$ z>p$s10aVN;#i!~JeQfkXgQ(#Xzedtme2|TuLd23)9J#(+O#z>8FM{$tN$;%nZ9bnI z`uS&&UaP}zK7Y=vTh8s8f2BYzW;ugDb3eLF!gK-eWQ)%N+D=LEZ+z|m&Odl3l(%Nm z#v@{B3HWT#>(I`V^Aqi-a$5RVs6S(e5I+}s}u3xli1|Rn(sWn`0RJG8KbRLEc`iI_wfZpMNM9hwr z2>hHx!SC(2P!0C)Z58AN7)|2qV+H=Tq+i>X3;g8?LU}A^8`<@c@CT+LETUdNd3=7z z`%M$d3#psnI}8@+s=yUo?~ao?r%h)Ou25cmT(E0ng6@D{o+;>mm+arfkvy8z(9Qq} zpK)K1H&C}B50l6(sQb{LD3O1`YNPUUtTK`pVHAl!NCb4h1Yex768KdV-XXWj5%hOp z)e&z(p9OSY6FG*seoo-!Xj*_zmyCCbjUeAk-GMxa2&fi`QU9%kr&&Yt1c{$}B>Zg& zrP)aO=Oui!1Yd|Ga@w`2oOTnkGgrcUVRn$*MbfYF625JG;w0m9e4(JXrAes&m;+!D z`$W?N^`A+2K3w42C>Aqsk9JvVmv<9%tAs~T!hfRw(5G2JJa+?jmXLW+`uZeqqqI6m z-lo4wGJazua^4;2^I-t(B#}GvfyB8&qVFw{dr9oK>9zUYX1~qvwtk2t`fYmL4E*8Z z|Kxw0pL}{k-lo?^+w2fZqW-l}{+VH~&Hpw#wi18&vVy**guf)IzfZ#Nmrw*<{D(Lr zq2&@ifB-Ik%s+sLQ52%~+i*T#j^Je^^68TA8z8BdAd$Dts|bl)M>6lbOUiX6^0x1( zA(6j5NBuX^ ziv)g-WLx6YL{foY&nBBFZj*3|5R-yi?se-)=iv&Jml2C8b>0GX7@<6Z` zO5qRn6(#yDX|w`F%;iWUr-K&KKmhmj7wlZq6X?$)^yRTXnF~02Nvlw=qk&-0bAwQC z;v@k_yLFj_DK28#O)t6K%EN-+-x35n5v|xBQNFp(n%gxSBkW_l>V)zl1zI7%5mR<@ z>i+Q<*SnQ|obw7vl(!PIWm2m+U*H|e`7Vove##E_=6vxVQ(j*7_yFhSVhp%nn{2*u zsw?G(3OJ`su*86g*_~J4Fwi3APBIfx0EII;y`+bB2oO43U zaDWiACewrh;w7dWy+(R-4o*fW0Pa&4zSAwUOs>EE ziap0w9}`+|8wc`2jfh<`lS2}@YardsXc{nW@V>qWeEx@v$dXfLtD zGtyJL+_0JCg|S%|sDAeY56p=UyQ24#@R_UST6_=@o7&=wl`3XN(#u_`d~CL!6P4fl z8IwXZ1j|t;GXCRo0DPPWb<& zWAA6w-oY_i-)o?^V~BgA0{E*w=EzVW{w^aI_lx~WOjiu3aVrO)o*PedIYGhABC4y7CA6OJ$5nKgv) zeJ_nUj!K}Lzu2Ca2X#>}M~KGx_PUJqFW7&hGbWAvQLY-awF&f3z_8EXK=0e$NT+c= ztPnYy&Sy9M%LmhV?OK#+PkNnGZ!e&6+JAOj2-)pEPT87h#-f{gGeHf1Cb-*!e!JzK z)DyI*KB_N$uN_-NUiF~OQ9pZHLvDPs>yj(rS@0p_Y4S6-KGcr-)qQ^&pa#yn(e>A<-jo6r ze%?@9J?tv^Irh<`Z8SfMWz+#NM6AhX^(M08SFQ4$^q-BNb)y=*Z{P77NUwWivL1cE zzmJ`tkbbdOSQd?wbC_RmZ&166kp%}pdo42o^b#|hh3mf(4f}OIzZvrFZc9gz{XkKe z8QI_VF=H&zk)I#%b$C;^KXx3Pmo<8(6K$~2%OL&cEna2B`}`P$NGxVO{!ZobWoUUB zwj8Vz^_Xg+(-&{PLwfJ@R{`N+ycXT#=dwF}%hkxwvOUJ@$nTY_UyY^lQ=MLeI~6gz zWH)yu=^ryx?LzBgME~{HRiL961T@e($$0ASLGyh5q(hrXe`ntrIB;NGa?kU)B5Qn} z$Ag59HatFdZ5heqNs-rF9+xKG9*3P9apBGb9*<)uRm6fgb?y`$&pT^ zS5&i`k8j3ZJsxj9{3E1DI3Fow=p8?<#pzF9LRKPn;|5sB2U2foGzYD8$0$V zNggc!xuBOZOQ7-BEO@=0x`g1w?Dj)61O4m>X$avyqa`OIhI=BPbMxgH&BA%FcrknfP-x1W-8(M^edQLRuu_@3}x-p2{` z9&;dyc|Snl^RVlYy$mhkd-~)H`Ukv)`VD6Vs()6{s~|P_Gl8ZLXdBKwMlAR?{HreU z^SVSYUQ&)^6>o2=gdZk3FE~@P@Z*6*9x0(AB!*mr8%ACm*%WFgQ=;EnVqcm*BjgjW z3i<;ORftz@!@m-L;w0y*G%7|pWiQD-f)eK!N_d*(BNz4yL3|jZ2-)c=8LzhSOqbMKCBgA(iGto2iC#0%8P)$JslP>%uc(?Y zte1imq5LULci5jMnUCMI1^LOb!g_gyY#EggGZLt>nNWUSks3l?bpS1BF&lq`J|w>H zEAJ%F8bl1AapOYr#9t8+d7QUjOxY&b$9y z%xRn>eIVfUjzWD|pj+bes}6JORA3H=kUzB$;-s#DpjSDb23W+-`FL=KkFmTZ; zW8VJAN7uMsuUAJfFxc;$P5J&|uyDH`>5VqHkBEbP#CAH@&#IT=dIv05x2N(vkC#{y zB6ecLBfd|)i!I~$zs~_rUOu@{6%k0pdbD4Th=g-!REmgb%nw5asvnqgjhA;vXMtM7?BNc>Q@B?QsATv60C&m`KR`HS|H|Ow3Z<`lJwU_!v@$jRJV|qx?wHv+Wgw zsV!!wJ353=c}emY9NDp-mJ~iE+7Ln?9_NOk`MmwxU1yIVUR8Pc48lKSe%~-8en-E6#uWXP6SMNP2NKljO5)3c22}3OB4E;D+wq@=1R5_3TY8pm%5A z%p^bN2TbWt<)_U0IuWhvu4YPli*C2C?+X5e?>u$FADy3793^>XyAhZe$jh!XT}F0V zpY8K|3+jB+{UYI;Bble;36FbE{Uk;DerIOa60Se`F>qu7_>amqHwYiQu1azyJbF-D zrdwa|n|B`7N(JBU=EyC!puP95O(vW=STW3s^7#=?+n-(pf8<@=DZ+Jfza}p}3)-_! zt~ufUE3Hd^pF#PHZt82zz{@UqESC&wUVU}&dEj*S#>l);;5Tm0?{5OVlpAK=pMlrc zEA`oH^9SQKY}c7`v4|-hQNQ#V>e{mj(N$ffe^y-ea*%KjO+WeyXT+m~(11EGsdwU~S z?b!$3t0n8Uvkc<#Y<1(`@H3&pEMo3Y)O-8yNW7ewU0nFi=83$RX$@r?r@-E`)dL48 z{17q2jt%Yfp?~V*u&Ms4V#X@BOxp|pbnyv2Zq>1zdJp5J zp{{mS2mYFUdjIJ?ow+^kE2R|pZPg_anvQ{Vi%XA+!Zuv{qN1(aAFY3~K{gs*a zi_VRM_f48a{kg88>b)E^HqZ2|73iO)4$OA`muF+^>57gepY5lpaB_+ZT6#F?)AgSJ}CFI zHBFEMza{M14H4|@GwM2)&Q(*5c5f&D&zP@8;1e??_p9T{&xW%jZqs=uXwz*2I!}#q zTYHe!SJGF#`P3ip_fA#h=kJNq)9HL+6TUr**1@&XJy3b)P9j7ub!$1_?aAdNL4? zh;4dk%HyWLe4Z6{T#-X;e$}2i&y6wp3=Np?zGlMAJ`K+NQ5199MUwD2e@Z$pR zuV|{UAGeMj#`hhQ$-;i8G~y7qpY5@WQ@xAXd>>1zjpX~*^)Kiq?ER9@;`S!FY{UjH zV)fsId*-3{D5HyWo$CNJ0K9T*_CV7AW;~h4`7NdqeBb$SMUBUQ%XSugTqXn$n!xRT zOm!w&^7L^b)n8cBjki;9+L!k$ZX&ip$m8}>A`^M_9|VYSuF3}iE!!yI`y>6HbAF~L znt{BV3jrdWcOMeKLcBaF;FAq`MSNc^t=8xAz}MK;P<|o(1=rtQE#Q)^?@RfreN@_5?k{ngN{3M-Sxss+sz@_!qPJ3(+l5ivylqzsm%qdB6ufoWb>?dSE+)KR&0R z2D!4kKsTvF4Ee;l0$){z<0N>SdBVBQMiXYB@7G??)1EI-mr_ccBHxxK^!M2(Oe55@ zmEf%$4v29Mo79cV&3+30{n8~ME@q80uzf}kKpGQf@81~Mq=1GNM^yGg%#o-0zD8NhS@;!6A~Vai}T46eZ$#QLBzV+3i|ye zc(qc3pZ#b!P@dx>_??n2)c>s^$md}ek^Mr6AHEAQ{Lo*tO6b>>1i}7mQiEQIWZoc2 z!TDBFhraM08t-u=c3#qTBlIs20X2}&KvIW3KoF-^W z7aJs$+ezA!!Kxtr%b4Y)KYX0P|B&1_{(dj;MLI&cNw~lVtPptf*??)Nm#iu95gh~? z87b)PiV)_F+Y+JwNywU#e$XtT{O}rqFFP$6pMC;vjt>>$#Noq2`IR?9d6cO@ovsQv zJOb#B{P#O6v@^?7n6F=s3+L}s@xpv>;Rh$+uc^X1RUHYq2|u)JvU&YMhp+Is(WRa` z0Q@+JK0NY-?}T-jw?BaM1)G2Ja#1D16!entK9cCq@xpq!K1g_f<0KjdhYpmp_&J z#mkF&72r$a+)_21$Fs8g-}I=R<8?Z`{f#qUbN!WZ12AyF8{(7bpqSYe8eyPC%ycUq zP%tjGbGV(!AxWIy_;d&N>q%PjA<~PxSAr8d@{|^Fyq)UZnLIvTFNooBb!B+{M6z=~ za}6du@`7v?77EVIgNA;jddcldXA^%fI#QFUY)cf6tGBWb-=p&W>gJfi7{^zZ7l}8y z*6$4EleL$0<9IyPLp_w_!yfqaeOWtV0A>{4qujooO8Zsm-kTiX|GnGD_pSWZ7m`T- z;G`4hiN0NFpi29`-Qf+$WB{+MUu;h88CM+YL40e5*&{077Sp6bI3POuNdT2k_Rqdc z`N5~DhSIcu?+KV%OL+SC{`RR~Kz9|+@6Y$uhTUDrk8ii*wi180L(+U*XcrD zyJZxwUw>-^&*%2}G{&6tp1GeGNK{^Lf{#Dw{jGCvkso_ce9)%$GY20DqkM0LVJ$W? zip}f1o zx0#f`efDT?gAw?JJ?|f02s%Zo>#gUID;V9nFbI6n?$Xp2;IcH^$0oyoS0Wc$esKmZ z>|ux#HST#gXd~j|dv;ipIt_A8%!}%v~$EuDfpWf-$^lhM@#1nSP zz@F^tE3X-FxwD!alb6MKJ~+aZV6U%JOsyN}-|D~>xzLMT644sc4*S^XXv=TF=UoT* z_ZSU%veBM{bS`nx`0cw1;-?W_$_##3_M@dyhOVe ze)TC&l-?W;Jm&A2me~b(rJ-yL@Zo) zpleV^a-y&#Q}SC*nS6m~@uZXxtB7@jMu&j`8Vd>+l}^n{TVO`%nYUhhqnb z24BNH)t4}hWj?_B?UyM{R09tBFx_L;HQ=y+k#CcB;J)Cy;nS1|y!W!T?zqMV=ddXT z0bSnXdsN+?nLQi%to48H`}D!Pm=Kf3d+^8ScrWt{@c--aS0xtsKGg@Sdmn{-s*~59 zxA60`??cyo^y{@r^5Z1<+m!E;;fwNxZxgBpz`y1p&mw9tPmWrtT-{KQ{n~Q*_gO7C zzq#EWnhpJ}egCfPg8Bj0r|-l;Z)nfe_v8=Ye*fIyyJLJ1Z|?M*@HPeS2Sm~87oe}| zb@;fZ0@knd3x#YGyhEEhca~#)0~4bB=8(#V1AG2p~t~<(4N+A-nA=bq-Tp`;?O0kK`q%t}0Rd%zHZQD#a}|t@VEz zK>rwotfx3~p?U+JMgY%=&5zT#>_0GVrW@q9yc|QFz|W|wktIE=9obTp$C#9uHaHJ* zliXpSsr}JaQ?$sR6YjO#x4#q2E(xK8?>4-I%WwZ!<^s{y~aE8 zbB?v{W+)*4lc~r3Zv7*iyNViK@cmyU%t}P;AS+r5?N!|WDTb9)8F zBLQG=|J!sD2Ou%))TPS{;(v+taWF%k=kQh>Sg@Z>a^`+6>t(_HnnRxh@~P8=bHV)P zH(b8TCWYJG^GPVbqn6I)GPfvGkNmkK0c7k?A1ZO+K-|bY$mR2m2nEru&{x!ihMB-dL#QN+jR`{8sP$Z)Uq>m;{p9V*Ll(eVIjj*EJ9 ztmXV{ISe25Yd*x(-gXes<2zvn^3*(mPskGVN++XP$Y1Y5x1iTi@}B(d1&ARpJplLv z`9o)++=pM_U?1rw*zYJ3@NjADOs?N=0j3}HBPH)aMry)c*m1${Tu5%bY$cx`=^OmH zJlF!m54n$naDMH=f6pmqrudpvZw+QImB)`4`0+yoKY}(2__pwqAYULk7r90XybOL& zMD>P?FZdhUG% z-sr0^4vpFPjA$n#P{8kV*No7+ufpp!hOnjAy1%w zNN9J(EP;+*a);MDHVx@y*txb{@U!bwP0k;w1N@|RbA@$g=QjckV%~<>@$x<$<9PYm z2Eb3qA0^>AGN{L_JRBsD&kv^oMt-?f!0*zE!hBt_HlNR@PN(I0oC(|#%>6vwa0HHt z+1#I-F;Kv3As!0E$ELL6K#YAX(3wEX+^v&@kCp%2*QPw}3hhFk4-DEB z;6QO!uT#ufvXeYu>rL8cuKq~6s1ItWx@a$*2d=yBJ4ku1`o6ng5$=w9n{$Zbw9cd# z#$KRvpDjH=@mv0D;x5XIW##pXq4zEUKSt>4fwxcn)1GMjkg(2#Urj$)8PWcvByTdm zKlr)PkM+-k4-GU7wFdstUHaom68O?P11-uxhg@qfH5PhN-?d-GqP*m^pN?PPTu*@87aCYyzl5o_uBnaI#zS=!1k89{WFia~1ZMnr#0==L9{g zf|5hPgH!dV_qRvByW&Im2f``xi;L%~fT|iVJ1&LtM*%rb3(;PMX4J!HBKQ~geBBn5 zue;@RrV@5PuK(;O2i{iS_2$B_A~t4K*(;6ySdW93?Iw4o zGN(*-$wO~K>4!xngmXN1O<4v1>dz!!J>-Xb&-GV&Dvrmyp|y!=jlef54bzkop?5{S zS@*{~y#E+5YVk(2doA0om&t=hHt*QDv3QHbhIc==ra#ULkuR?MtwXz}C+D7<7W3ta!h)!Xeyf7tQ9W>Om5$fTBbQMtLdnKhWXOt-$)$U4lEKCZbI z?-_LuozVDO&wfvJICbi76T6%l5L$7piLKNQYwQO+U)cS3pNzhE52`ufhJ0lM^QpS^ zGjbTdo1E@aXPgh3e?&h~f&cO=?n)(!iuA7KZk^(!i$GZdV<#PQ*?( z{yGzfbIR?>7w2^TRL@Rrx_y5^Y&|O|dogpzta^5Mot*gNpay1f=H!q=a+oi({%Msc z*0aL$lIUX%b!@&#{9r|uI(A@Kx~GbF9gE26al3qJJ&PU~KfT~@E!$oC?{2+Y9lQ0$ z<>DQeS{73E`)w!BTJ~UGD@$~(V?`0u!UrjeS@k_1j~aa6)s1goOJg3W*c?=$`zEQX zl&We_&wD{bM|}a_cb$GKhj8kp2Mbo|F^$OGVcuh?)&~u(=x2PS3c|G&lTc#IV{-a6z1pbOZ`d|q4(xe z(P|y|9Z>M6_i(Ha+nY?4@MLSUk3HSb+6wcCW}8>^PP-vFOH`p@h!pt{S)@6CbS`Ho*VigRPV zc3dLd{rlKl&s_LfynLI@Ht;9nEYf;_MjibeNO3IPcJdE;pC}*ipB45U_Yfs}Ub;YD zuHX962l7b^&%{tXk?Jk~hT^MA=?5?J_radz42t)`D?|ByEA4alKE?B}Jv|1KeAm&2 zyA*d%znsP2VV+hKuO<20^rZo$*A%J^;DPZt`Yw(9&90l+kK(yig8LPcJM4VBhx9`} zd^kk=MVd@Mb3^bKRVE!KeGL^~4H^galy-QjfV{(XZ7%X{$y zI?SgPQDsDvBmVRu`!0n6{9ec*H{c!V>wk<>B|jgsCo_m2VVv}yX!C(Fe1Gp=@4<0> z&_ZvHC!d%9L@T{y6UM!7v>Az>l9L;72wX#|7xCo}w2w zcyF^toA39P*{`|&zExMazV^tOT<^|EA%8o)_#5x1_qRVh@0i&Wa0d0eJ?qWs4UgYk zKWFH>MV_WpG1-IJ*eX z8qjW3-FrTMZnJ)KKH8ZQ?;@6cVVW0F%T}ZtL9L6wVt_`5fv{7hyg z&9{=i^r8zmV5I*qqQebCIUc+*IP3uNc14vJiNtj0cBOh15 zapavoA2%XAcW;C3W0F6}d4qw*`1pUsz+-*?bLHpZdBZaONiVl@;3ks0sdus@y?Jqe zc-}Z{>)fRz|1#{$cZ!GS7q8>)s{<$~h0aop+ zk!GOP_Bt=fPF#2+F1qk;*Z&88DUACNu}WWhZ|tIJc5@D>b%H*A8G!c~eKg0BUsfKQ z8Yyng@xJw=H{@HJqViL~A20Cczh^vc7a>Rc)4*eLUbOE%Z28-n>=oZ@{OX9f{O_Nb$N~b&;7uxmzKZ-Gw)cu7y$jSpC`>)W?&ze z(Lbq!^74y%Ek4wrk=t_m1Gf$vx*-1IRGd@(CQQs51^imGB()#%wC`;@dY=I0yFAZC1ay#pb|^Kecs^Cx2zjhTJpVr1+g(F7=nbG!OUn zvO$MmJ{2*eri2v>O7R}Yv(#$dgJx#p=;Pv{)56MY_g8kwXkZf_U;2C5wSn2}NHx}v zZerdl#mXMvo0#33b#A*4HL|UH3ulRe^VT=j>K@zzJiOUl=i&EerX9O6c*^M}c52=p zQU2GjO#b4Nm*VMP+4k@gX)hl(v(OVK;|^6evuuaHy&n8-VmmY~>$0?(nXyvzFU<`t z$dh}|%jw#}0=zHuH@w%(RF--EdlA^o6vxe;XZN^?wg2IZ0gpi zX|aErndhtOUrlqGSZmU@%r*AO`l+*O*b3DuYuV-+W@b0( zSg)D2Omt<;q3thgSs(3h=Xx%zVQYtVcOF$#h5Txt;d}F{*l{JVg@^yuu&84hC-xZC zvT5zKU-i0E%?5wf9_nLS#kTLb75DV}7bgB)Hh!w8hHX}s*)Nw1J0Xi-$m&!x%Yh}Q zpG#MbS?werhMJdJh-xoc@F;2Y1_~m z7Ox!IPZ>D=uHk~PdKEESxwqET+ZgdF^|I5ru2t;B&PAJa)`^W2+Kiw$Keni5B_~E~f-{=7P zZ_YD|kC10iiTp$R%_RF7y=h-D$O+UU`*w-1EV97oIB$JUc)ekMk?tCjrr+FdOhZS%OUy4-H9Ccu2XQ~c<4Z_1IIsdHaj`4 zvT!aIaMnB_@4C4X?!(TkzNb0PY8jcr`4jc~I3AKxKF{%e>luG;H_+uIxA!gRKF5F7 zZ!`oy*W3nR7Bi8J1|N@AH_|x1XG5KMey`_uaVCB5aTT82&(8t20F3xudScUO@;m5i z6u0;3q<|-H_7d=Da=%^Nuk7;z{@diA%G+0+J&F6NWRGgFbKvkPt~X=Q3*PVWf`$BD zS&c#Sux{qm9PMZ7=9$7h$-A3lG&*52ZIycNmExIDsP8b3ccO@9$V?FA0(cbMqa zqt^I^0NyorRpWj)=5}gF{Rs(D4I+7Up{FtNcjY$od8p9;GslmK=WvY%`E8A994Ce< z@0FwZsT;v~{`2Ie^?ZE$9nRz9?ep^^Zzq58Rr~}2^Ic}%6SAK<QbS zhJ808J*n|GT>1RX>)VfTtWoo8p6|T$Ef$GqoL4UuoFP5uq^G51CuKkLqddUz)B{G; z{=6Md_yZQm*PgEqrv9BwS?Wr8QM)S@%Vt78N<9q+ZRF)v-14Dyv?4Afo7zcVwqy&% zLtCw)Meh-}mN{C55}q7ADQ7_z=zYH*+GfzZ^rBDBUzD3Xli%|caqpJ;egABfuZ&zX zhV+h|(mO`Khx-y`F`Pl~!|!Et9{4=}FgJ56I(AaJW@`O9AB8u#QCj)1`NLh>hF=f`bQ8~B=-}r2E|5Mn%4(Vp4 zo`;@(sch-vD&RVk=CCL&{7!o4o}~F}5g(L$`&~d@R?AC9X%^b`OnJEFW+m|NnJd>< zS>yMdU;93<#QvtG>h*U%_RAUVRQ5DB<6L>NQ=fGBk);^*)58Y)ZEYu`tc49MHEYEg zbL2^1{#1|~`T%+L4#`G;F%I{xgom|mYG%V$+$*n+ZeeG;rYyTL3;S5v&Pw0uI43qv zC|C7Ez21#l6|OBTsP*&vJujP?Ut^%>>i2lZEHk<0MF*TyZeF;Mey5RLoZoZ$zh5nE z=SP*GHOWmZu)-s|qZIvK`HyTT&?%AYUnLhcu_B-D)m~j%*q7!lpXWF>vDUwJyGOLc zei7m6r>=o~gkR_UzRoRd+oIeS)zD^UTeMwydQKDjp0%akwr>^Fo3Kn}t8o=e>|MNb zL2V5S^{BB4T-Lxw+7|eqKY?|%HYCK>9OaKM-M#>P#uDb`405SqKIaC`?DDjpCEC^X zd_Dm4e317m^PyF2^~=Q5Lq2|CcU+4`W;#~0GdCtKZJA%k{wDPDHIr*#lU9`ZRgbA+ zz3%t5o!734)n#;6&sbN*ii)DEg41f)JdY@SZ{IprvA$~AWxFbt;JZFD&Z3HK-s7p9 zW>CevHPRWZm4C&nyIgkMFR)E%lYQp7kO{bRaZ9SykJ^3pr36GaGLAJ zd$pK%SNiJh9iWAK^jS^b%P=1f=;tS7b;CQ(zMGvEL9cS^_7}!D-%K8|X^Lr4J=>o* zb71o-oWnPa+n|j3w6)|;j0*CGAzu_Ll5tMz;L$gJ_Q*PRzCI>qDnlMMsr-~Q$y=?OE2)TLu?J*;OBL<11?p-dpaAu z+@3-{qh0tEdcROHa?txp;IGY@Z(V^r<|}#M@1MZ8&#;eM5B)=JWCmuNTodvBYUXhs%fuQmMmNx+DKRxi+EG$xpzm zWnWGQ!q2%rBg5un9jbNQ(<2o9s8+b}_zv1z9+){~7^u%r#WNI_{++RyL-B98wZdzP ztJ{u@9CjVFQ~%7~E}-_gin}NtrH+jWr#R?&J6S~dY_>u3o2j5$)(^Lz1a02a&5m%{ zt-LpVzJeNVYHrbhywJ2tQ~^JSl!e~i34XUx&3!FUAIp-wDCm8^vTzK4$59aeD-Y|P zd1xnDLEaGk$dKN@M|`e5xgEU1SdZQGF5+%u_fLfT#@U%4A^c)kUX6=x1i;9R9*^1nFrGSB~%OmV0nUMpj= z9NFt@ad`saoJ9-OaI=i}-lr=1lKk*9%@4fZ#nF74~Z~tTu$15{sdT< zg#jE7Mc%dId9tV7JKzQ$?-Tk7{Tg=LmgA->yLTKvu8KOx$Ma$6yhPGlJakY7(YL!} zd7ikaqVrYaCm5zKqyBCxJb{EY-kq!o$|QNPjUK1kwV zth2N&%_rS;mR3~Wp?>uxqH^cO@}xIb@BDjOm)m9;e4u;PYQvw$sowA@qwz~XjJxIM zS}K1%_+AC&ulnWt-u{lbCF^*pnCw(N(ru-4PPhUmtNk2`urF)e7H3129Uz8f(SgHwr!pqB*;W(#`^PA~a4?lY^D*P9X z^0ME@mgs=rICj!#4aBt%NyhpIfL|6S4!=1N^$gVRzH|-tX4eENy?*yMaHhEhJ z%Fje<>F);Bx4x1;95|+Y-JLT5uvfQT)Bk!@Y!;hcip?~Xd z>92CUca(0pF0Tvx@?eC_!ofJ-zkYJj@&NX^4Kk{!`3A_}-7|S@)V_foU7dJ8A2>?< zv7v81?pf=6PL4T+`@FwKed`+%;7`oy>kjty%;Trr?{+xYU)G$UZ_jPD|_S_)cX9bzmtx9SX%ck4d%^ksbk>cS+g3LW|3RF z707EOFaEx+yHpGFkqz*7zTeC)k8nBbqS4GccsZ6%d)mO#wrfsIDs5yr`$iicoYulR z4ozOU8aT%*)AePuxS37g620!La}%34EmSkLwV8=h`hHow5$)t}+-Mxs%$nz)+C4n2 znN=#srp%w&%t{mN&Q}g;X7aT!693vYv)%tHtzG9gv)I$li_OM0v(wiGck)eZVzzzE!iE-WQix2iCG)8!~@J0}n-%uWF|-w~84w&wux>a~1pY)csvVw`%s*@SjZF z*cw*%;kmoUxGL75a5e0*TNQg+>{E6P^;Ugz33nS?#ro@Qy^#`A#c~=Q@`4vvvGq&r z&%5|kF}J#m>t9Y*G3_|hb^}4DX06kSibUS-{$Mrv;40R`e)qT3q$>8)>ulGE`YN`@ zzMk=0!rpGnbkD#q5SsP|gIb zi#K^2e%4vkurb|?j-FSjV}XH_D#|9{95Qf({C*?+{YKl>-d1?G`rhKUH@j2CZd4<%oCEY$>FUEQ>pCh&}L|)gy?aYs}>G12wkP+*VU;Hck(&X~fTDEig z=y9#`$Y-xp?WG31^5d_3=8~n=ta59$X=X?bvD=H!;81b7n+7_OOnSq zVc@+auT6y9v8x2t&HCbC@ytp4lQ&}l`WPXeFIdrpY4+V@bjl~ zQ-}NDXRX_9)&bNb&v+c^hv<&LpMb@?@E?j2R$iO_1O4$CAT@*XaCIG?l+)i^ z(O+FI+77+J%j0%kMSJglZ*`T0{=GL3{t!M1EGrw^ z^QJ!uTTbyhWTQ$j?NhObA0MXuSUO)k4m9&_C2Oy{2!{|Neh-lZGv2~@uM&i;JDTbtfwFS!8T?VP+dom;m z4>_?f@9z15aMvHN9Q*T^bzT)jL7Er>h0RR5Yl_R+C7x?ayqxRkp1tY4|4o+ zuj5jVUt*2-#gSY+W;1_Zrr6)1f%u$>NQ0pMpHBOEUdQ>|4kY4m4{5iMr zaNf-GRjmow_Mu<5!Se{oS7q04B7T~~R(`)|y|FvTp)#%gIS!i=wvOi=J5Px01Nz~h%4>a;Cw^5883%r*$;D1x zu)f7hC%Dn?W2`>DX{Pzj>4YpSTDr~C^stJw3qyNo*br6@78l<`>Az=UZ1Ut7Jb6` zagu>WXL@haq@EXA1$tZS(GpM4>v!07#_qWdJ$TGx@B8zdq z4k3PtuXgzCit;P{1|EK60UWzwpvVn&N00uu<|E=pnqOIh6!I`jf?l>rZ?tzRF z;D;XVTQ6CnJ?F2P^?Ha~zqLMB6a$y6Q=aW|4LB{qpwQ*6EAoGNYxi_ST-{NodG;dg zoq3wDjPxu=ozXVOxxdUQ`|&y_++RAokBWodCLzCN*|ge9yO~+ZI0x4lWByxj5AM1M`_6|oL(WAa@2}g* z;hb_alTNAGIK;CF=j@$LJ&{+KC_m|-jXi!Z-DScd={N9O>CWHZElo@zJ!Ef4k0!Qe z#~T?F^gkxfa#o`)@ZZgbf};h|0k^$BM7KJ%40u1FJ9&-CUed!+PmWzMuqs zCCiJlqu=3vPi}6nmCx(gS!1_*7AFG+EPY z0rtz)Lw+pN>oL-X_ z^+5dJU7}eBJ0I*$>KuXH)oG*h*Z-(z_Ubza8!te<)$eNH9q7FaNi!XfJc;3!jmnAm zJ(Y)_>is>K&-HmHPa0$XoiH$)Uktu3!94a0*4tN^Q$N;VU5yC{9&!$Oi|>;f%CfMI z>iaA!4}x42>So{sJ!6wEKPm6ib9uWDUa-4tip2{r%}nodWlQi3|2tzhfHqFQ{=lIciUB<0e+-7 zU%La^_Yx^4or2!mKi0dAAfG=z@KX}()cI`KWCXhMiIGDd1SNUzs0?b^{$S(Lk{Pdb`b? z@Rwz<4?6rc=?ZzSL*oz97xnk>a0mVS;mxE9ln?UT8A9*drWAOE(fKgt-gbq2@cVl| zU$_+fvMy12G!Exw)Y{jAy8nLPo&Ju(*x?PY=)JMZeC240>kbK<`MpM;HJdlkesSf@ z2EJd$z2Eze_K}{l=5HxZpV6_;rG51D)sdy7=XtA||6T9C6GJ+aT}?-S{&%)@71fn# zUr=`q;QK|at0sR>S7KlJnEtL^^4-B3r_}oKl!K|#}OC#53~_4HR%WI*az13 zizR#S)Q9mrME1*PJE;BopXT>SK44frf0yU}a&!>QtF7uW@w86`o4$=DJ*|5!9;8>? z`CtNlk2gy^dET+!Q8wx=_;-=yb`uzIA6ZCy=?mXE@xNE_I z{9LkQ`LWkW!rKL%)NpZ!{X6N~YuYb=`fXWDe?P?YT|38Jp!d3HFNj6?FTcB!DZklq zZ@X|>PYZh3?5#$5oz;xyRaoy2O-ka9quf602nHCqKS^7g@WI;^7Dcb1XX4)6I1Tcq zAuq-zgRaz%en<2CqC-hNSl+1d}FqF{58Z0U)N#Hp@>(pscXL(V!yn(Z}K8Vii5sMjmFq7V_O!u z7eg;#(TGDUpw}31Z)QK}C5C%sJnV^mIc!N(-~`-%t&Eoc0=-4@m#mIKZ_CwBlb+*u zkKxXGV^omOpXXEYCc_T*ZGp!$C&C|}Ia7iSvF~RT&c5{&dPZX-L|$lD@v=+&9=tb- zo}-`bhyHk8e7t-p^bF4&xS)yn-S4}qk|pAP^sT{JOJ^g0vB09V0{Mq?Av$XZW4{zV z?|*Y&A=X`ijCT=$vWZ^XBnY8=MDYI~HPKsJS(_}Gze|^5w znWb0o&UL}jXQg#b%=3nLWAf~;tk7ioMm_A8bF+7C?YpstJ=5LyBL001D+m}Gxh1`h zJ=+_2*Qs9vvx>PFB3)O5zw6Wf==6&^`iSgt+!R{v!Ud+X{pZQp}B=07mqTidFEN%eUpt6EUYoX$^~7TvCv z^&GHr*OB`*EOtj)?c=WX{|9?-8jf}JHH>OdsYo;s%G97jAw|Ph6p|DgNCOhlAf!~L zNE*mgh7=jnAY~@=P*kXpGL}+?8+8vTrOsOW=l@>sd9LUEa;|gEr^km@Yp=EUZ|!~W zVePfoUYl@4U*0yq+fPnxTlRfF_|J%Sgw5U33hTe+*t%i(u@=PR_r8rI8`numj%ArOdmpK{oa#Pd z7tC`DXU$0kzSx?5KcYd;Rham=&l>pBn}xR+&Fm-RB@ay$Jr3*KLXna=phvkouevrD z$_uJ28tw#pzyX1;lS5U_q61H1eu;VTVIuU;q(Yr^+@E(8+w!`~~TzuVYv4g8D2u8*)wv##1V1g2`oo zQ!1+ji-7ONQoX->t(Tn;}l#kRo9>A$9ZH`g4!Zn*Cuk(0`PogebuIo$Tud-Py+ohRk{S1 z;=aT->iQ<+JABMsEEMoNX5^k7;KovsgUB~wm5C#+*Nr=eYLKsIxJ3x}FK#s%LlywD z->WC${O*|kP;U_6;pD_IB9OkZad&|Sz~>MCwQdDyU*PM3^ZV^Yw|_X_rmLqKp*`F4 zo0~VTmrGyIh6|ivm#y)l>*WD;n`p#yf|OR_{C}6P-WUDmUnVbz!u0CC2WGgg3SQhn z*Og@xB5je+>d$^(w0~YZ6b6y9L7&|JY7X)(7Hr8uT=3uelgOvFl&>H44!a3!sNH|* zRt5+ywc4NE=T=cV|(nc z(Dky~B-M^)TY@6UxB>8_p|M`_c1?5mnJt#1qVd zsNcoP5ID{N{I2Ftx;}?}^``soG@&MX{_(_WFWsN&#a^I%A5N*z@6J?lrueoyj33LA z>Ooq5qI3^Umk(>8(0{x!<^R0qD3!uS2c?>SamfN~BRT;753$D%M_T)%F$I#ItY z(WKYZpCfKZ;vA%BHU%dmR16fO@euBBxZQ{Pna1#plIZ|XJzGlsV2q{}(Q_?!NGG+A zoYS60{qdh=bo!uu#%ZxTwTm3cQ~*K29@E=34a?24$fNd&kP1N$)Z@z77pT5hsToW4 zp}v^w?~s3Cqjm)HPxlD&#^2+cgO?z#my5)H@56q#N%QoP6+mzLG_FJ!#?cPvrvm3- zy)>&XO+&qQS+mt1Jh$}xttp@kxKzwJ9n_muzRnKLgZb$1ik3p`7e>2_vJlGI7|G-M zKNKcbjN>7=N$m&P$s*1rz{Ohd_y4dm0qb>nhT|L5Q-ACcyo=|AuO^H;d>qo(Xy&A2 zf8u(7n}zMGC2h15+s$&Yt{L^4vYV!A_?>ailU~h)`C$+1kxLw`mve3h3+;t{&Wo|{ z1WUjUxz6wXRZUngU5}V&nL>ShayFLkfpz+s---FgrftW2@*C&RzP%9U(FIC###=VP{v&MLOtb@jeJgnk?Us9$Q~J^V zHu1`t5N+UZj!c`@0`s`yk@&MH|L4%xR?a|g3N#BC2jvzw&08!4^4jZvb9xQ@I@KW` zI+bC(NmOtu^}iDlYdI^?QqYI|q}Ql||AhY2h`{d~Ipp2^n|7CV;NH)Y3oop);5_CO zTj-4p$PwP;V{?;Bo=RM}w0r@V}}zZ=d;(u^kUn=J=+!1X!DYR<#@FKkd^v6oG1 zi*w`5vv_3O-cRms@cVI+6}56<{{PX+C#MPf(OFeR7wci&Ig?QRetRt3$1rr8`V-_{ zm}~e$8PsZ`kXct!hc8Xxl22mi^$Jfy{3MYZiwmBzN%M)-7q2UG z$ybSDpOr5;Jj(H9iRH7jS4C)*m<^4_w@TakU8eq0urw|FjRT`h~eu+z}w z#^DJ`REz5rDeiqrePl8>v4)|U#6@Fd8B2}ll z-6zDbi1+6HJ<`WngZB5sV3{F2grI+N0o*MT-2-}+u)@0b#MeCpyqdJ+occ%^pNLD!P(SheaqDqG9E-#s(5*S; z2L8=#;l&-&Eb_jmf44Q*0ZR5Hq)apcKUc9j(SqqL680vNZSC4a=KN?73qRCL%Eot{ zd!zvSX(^+GBhb%{_h0K87GjawWnCI)AG1hV{N!6zTK#1EUe!4>px?iC7k#G%{kFZo za^j>C76~8By>Jioz09P?Z|8wO4$E}KzPX@3hb!!JPXzs_M>nA;ud5&Y#E)+;>VW&M zY4u5(puY^h6Lb`V@veVb;94{21sX3N+E*LFzW;|ni4FAszhVX7k&~b0rxX5UTMk&{mbNRk6sSU3+jF|j}*Z?arIjIl?ph| z5j>sVItT1{Swex4YA{YjWCpsEVced(P;e#`pj>xEM=9uM*S|W*k^#_*JhlJT!gs>u zZ27lCIqU3Pr{lgw%J=y064*yfuXB=V0sZFY>f94k09tk%3`~LXrReD!IScqkrVq(F zfILRsx*w$=e_^m@wKk;dWS!6m0Y0-8+sC0EQl(>AeF*gXjAwEIwNTE376tw=pud>; zrvUY!7f!AFw*%Z2(JinF?+=1)QzAyX|xW2W{tdfiZxa-J*Gk6X(O`%d8=}vyfzoQ;wdUzkb@7*%7 z;0p33hUy(bdEC?FYVh1%_Kko%mgBPRpfs)@^`E7e;JOrZ%2p2NX+gH+R9qiR#lDR} zdc*3EHHgNXsV5RUd4x>hp{~W zQ^FodU*|p{8u_`-zcUf$_=>q9oVoYpb)@@j_ND7O@7{;+n0|3~k0_=q=N_Aj>!h1~ z6)DrkkQaz|sfbTgPM{)H(ITWsRXX2z8 zCxLnde0Iy2e8;50ECc*sUor6wP6dH_26Tmspaw$v;Yq?2zZ`mo;`gqDS_0|cvRY{R z$I?3L|ID?M$iVc2<-=O808^XfDRn*V9@ibnj1N*|*3hMv6QD>^Q#7^9=GK<6Bp%r7URc~Z?K^N%fFcq;kE$Uy@TTv$d|WlHN`^{y{R3@-DxWQ zy=NL_)AR$Dcd5SlCb0V#=F6KY41wEVJm)?ZLwN92EsekH$1A^%{pIVSd@Jlf34c6g zO8|G1+TNd1fcJH(>dq^^MX|Rpp7WZ z<5tnhLYi>SJHE5o;tcSaHU`V0oujAXo~SP1U;gB;!uzjfNCCd->Vl_90M(A!OGUsunzqZ(rmYF* z&r-MR;P26q|NQL5c!*Q+kp0ptt&hx|w)}Dd)GNoBr_%!SH@jg|G5WuF`pegzgLUG} zIPI^iC1Cz}DCOUc=RLQiR}I0u8X+kY-3jYP>)XRl#&E83G?w4Z9nOWK^t-pbhWu_V zTcVCbyG2T_FO~rQWBIRNzJ&83=|xlXwb~%xl9GG(fbUsri@rY0znKTm5cb1!?kk7bL}%w!aqlEHneG(JeJRBuM5B1Zxy>BX6JFil zX~ZFW90Y7y8rg)Uz>T?+$tF9i<{sRU%K?Ag#+*_&4v}*>EOwudLqy%L35+Ra6SuHQsI&N!Ps6B zci^evR)~9$e>q2RGTa06dgnIWL;A?ViBoPbkbrm#@rK2YuX@QOejo7l?}fPgA8r;} zgT3p{iAbrkJ|egGT6a=#9~sHwy;~3YG`^ALdzyR6?S0EiRYKuj+4P48opt+(r9kl0 zw*qkQk86}v8PZ4QjqetoE!0PZCB?&M5A>4rse?aWdi9gB1BsD|pno0YuS~dczmH@o zFA`{ixDP`7=PP@z_Ys!dRk3sqi^R634YswZDS^A=P%CrI& zxpF6q)1}!vu0>k=YU^e>HM?$ylvDiA|E=SMmO}ZxZ;gd>;C{6O>lsDwUyaa-)|h^$rLXb@Y)j z;;EAx-@v^xKA9`YP>v#>lnm~R*IjXtdXwEx+8=xpoc{>ySMuUHzTjVTIxpwjG}t$# zskU!=0Q%gjfH7eQK#tz$A_eat{eo#y%T1I$Ma z0r%flz&vJD@%PawkS}%T-=zhhZ*~_RROW#lZgYi` zEcO0zA_-v7{V1dLKv!Mx8Z-hp??_g79}av1)iZe)V1GX8-=`8>7yY6lK5GJf;qQN~ zPXQllPESR>YOXK$f&!#FPpCH60%$Tcq|*)Q1EGi4;X0riKdT${)bR5${(1lv4+Pbs z-7mg(!E{{Dngh~;aXlGyNT%;2i3f+SuYvUAW4STtUr>MI*&U?&s$8qZ^=Hxg)|>d< z-6?F(>i}a->ptQ7oIgC@8sXZykymKHSgTl4g7uManW=#KtW=!v2ZW!aI%lC=+7`Ez zaebZC9&`iw_}ew52R#N*yfqxz1#eh5K1gF>{ukv^p+i`wsAmVBcAKCFwUsUOaWAwNC; zQ@+?xgnVMIj+8#6v*`!o?g|}LuUyb0PH_@AMD@CqFU)C>rfNQE4J@~~MhF)-%p??D_ zAeK`Kr*X)qsRZgXKnPAkAwOvGNbkDF;Op}lJ@}y=^Sw`#|5AO@<^>Z6_;N)92ng%& z{cdV++;R2oQq2FO7Mc~yAxCJrFP4W;ywH9J)oW$&xjUfWL3bs96|zkE0qH=7@?=hL zrRi7R!Zr%*@Z+tG!MO`KI3p)Xs<*SY6m{9%4d)K2dvM~{4X9bxw)dNxT{=_`Ke;d* z_39;}$M@sBQJP#7fcsLl&P^c=kUsf)V?U192v!~k`Gqt1e5ieLs_LmGz&GsImdytk zBzNBy%a52FK)=6foYN|l=i-d`g~%Pk(}nA~9X*y`Bp4bK6(kLOgc6{TloZ z@3zta&L^)LQ|S5if^%M8NbhZ%M)#kQZD%BKo@rK@FOKt(*P7_zN5C&!@HWZ}aGR1S zP23-diB!KWhk5(`67y$EVZC@zG|?a(=!1NJwpat*;+f6cBv=pDZE(Dw0`vd-bl>0- zSf{k=Q)zrLnStIGwCm1z6Lkge0YA~nDdYmbK}h@bqX3hKZ?SOSuk+#E2`=z?xXr7; z`DV*rxoLPWB=JVX)hCdi&at|WaXTeC)O2wkw2)LEK>vn_4HbRLfWO+H8u=VxQ^er= zN?1=1%@0TuX#hX?h*r*#1uzb3ch3C%3;c4fEIS`@5%05aRW1WLRVLfNlZSfc3OsG+ zgM8yfQ;z>?1HE~Rjrp&wVBhpB`nenJ+TxkNr$Rd{w{%$i67+V();_-g@PjRMv)UC8 z=bMY;CXfFD-{(7QY2XIy*78aPes5@xUd8Pv*{~j$3U4zOfP9a|>T@%J&wza3`a=E3 z%e)rz1ir9;GM@Ud?k0SjrFs_5+k9s&id3lsKbbe;9UZA`vi zM2~M8Hxlf!vU}9d%ZI}K9-A*UpFl5{Ufygg6vZa%r}~Svve@Lv*Y8D9SJ~u=$Y9(L zv|r5%+2aP~+F#<$834KVo}Qd>;wJd>t4uUYgY)3SM*~%zKyM&p|42xJUH8tLb=%#* zzb9txjIXA!?^%@3A8Y&$)~6{+t(IWdlJcpT&<)V?S`%)gm zK4Pg(p`!?!*e7zH34wpsRC)C^Uhusa3*GcCYzM!T#jN#BO0a(lJT~NTmrYFOJl*-} z1e?@2?e`YrXA_GB{U^$A!@MA0Jm2Oh%u`<-gKsv%I_=rwvAGlc^h0+&v8)FF6@97w z2BB~-DE&*swBxXj4&;i4R>QeuXi`lc*zqKOc*}eSJ#2OKrdKmSpL_NwIJp~sHwE45 zyAB1Q52TD-P|pN=PFT`K(@MCvvSC(tGQ`ce{C8>Z70B=B^wh)@&Znooay`R^{oXQZ z*$BtOaDKSy=h@k9{p8iX&^;R=ewulPTu$pT7{3)3-yUnic}2w8N0YN)T{EjXcYU~@ zNNhCbH;V2j|8~{3_5z=n$F8Fv^LoaK6UblYH0S$T=r0||yT=E>{!T5%x5S|v&R-ghReyt=#Myen9O!2+$4cMBan<}G zFfSMSZHE4{pKZ|JS>?i=?{D=J|Frh}84$PO!mcs9f2P3x;oFvPhZOrr;fkGp64rfW z>Fktx646f{9zSkWxeerfb^eCZJJ?^y$IVEW>?eaBB7U|v`-xBQNc&L@IQKPwDPKMZ z`fXp4-Gy}^&)}bsKY8F+wrN~%J&YfRDTm|&LEhg#Vh3VC|IJp`Tb==SfLBk<6W)To zwZ86l%xvzu2Kif8h%d+ZEi=n^%1VOXF7agQ#>Md6 zQ$vOFn;|`W@^W(tn17@?e%=e`!aA<8-@^mObNi$qou}~oaH?5lQ$UZ`aLh3B1wHzd zDE~osXosUy%f?heJ&bB~TXDX8YoU}f2>Xm$8ZNKacUIMovL^W{B0lj8w5T~T!# z<6NYFn%Qs=V0(nF2gX5v_)%qTD|~;!pP>EtK22I#T;4PI{;8D~+gCw7PHc>rgZ^Ua z@w4CF0N9~1+`Jh0&2Jl4pnlvC`$-bdskS#{dM5+@mu$;H8%TfOZZ9AX`1;F79-;kN zHtyuiXHfnlmb0e`(1l!n=EVVQw&DMR^Rs>B88e)hFJv!xOJ*A6_`dmiWYn|Uph z(cfrCVWh--pzqQ;`V!a8B%#J%xW1Ywo~lCo*podU&fxr?7k#S}-{rZmU0r_&;G!%^ zOI$DCsI7q)<-lKA`lfyZz{V$IIE?@|C7JF+`YVBIV_ZKsXtVd?Iiq-b?fEMJzfKOT z!Tn9`@G^h26PX_gmd5Ybmu$<&^|CnP$cJ|T$KJNHMZNy%21QHMe|-=iZt-6U(uFSG<-(0Ad&yb){7QIkjT4E3WU6+FJA+`HhN@JIb3V+dhnZ zH7OV{4dx?DReCOdpB1wTajW+G4k%abND3`yMZ!KX+`_z5aE{6q_)nhN{igTpR$}_E zwl#$aW%fug=f)laRIl6GJZ})w7aOP0{Gl(_QGLy4S~b<*)TY0sdg^MET&iyg4@WG+ z@6Vl>M(weY^MnR4{{!|4O24Onnd)g~KUZ!92L9C|vyu-2EZF+e(Sz zQ&gAJ^8fx(ptxq+O-gT6mZSL6Z*YA9_`f=zq_~L?J}3xrSL2v_m*TyQeY?TFobpXr z2y7tlc<}N=ScJ_6{Do(rT7X~VL306I2&eg&UIV)s#PuNx2;vj&GteX(#Da7|L?L|< zs_Ou);n&6VE6ohPL4(re1r&`vmzSEEv2zjcJ$X;xlRb zb+E=F{c$Y{2!1>tutK0W3^07dr+rJxUMI=4n*(^6B3?TA3zf5QZ3+m6amKP~|68M!1{*iHhgg4zAgu4Rq5NeA znzX#f4^L8jZWLULfO2@D{L_(7e;l(9n&^Iy(iKy;Q2zaUn0}$WY6uQKz`x3#**7IW zgY7fqTNE8c`Q6pBD1M7mPUU%9!R${1FSb$oT_>h|5tDDUpXp{X{chQlPG|@?Ph2@i z7t1eK9C(QM+5OIuI1i00_5Y22NfyQb=y*L*;7Ip5L6c9?{dMn^M0!3_E~hsh`Af>N z;EIOXz<(T--*DRh>f0VgtfzZQ2 zkN#y$i+KjQrBnkA!w-_KtXUxoA6)*V}3;XbNdJ>dC!fIV7o;9*JF2T1Ri z!ufW-ipW3YkB&;z#QlYWXzUR@A1L?ohL=IXo^&WG4e3jSzt2FNEmxMT5&+Eb9OCVD{49q`yy7F7v=KZ(`# zLwjEMkIcj@(C;7gUA$xu^oo{WYi)rpaC~bLz8|`?j|ELwalPStV`YpK;>#ojBk> zePwWx2f*6=PUm~C!H(IcsJ=WK{8P5LyjuhM`19~fZu7x@`;WE#O=1h^t$A<8mV=zW z+q3_ufj-FRem-&%=wU}6rg^5rKIv@xys9c_5BK1SymwHpk#B}mBk(l~IICm)h_f1& zMs9!~t#SVo1NHc@XXjaas8`dOfJirx_vBrV*S`RF-9wxtKu)ot5$P&`bzK*H4nTPh zn``BqpgzA3c3*6R_8T6k9aaN)X~}GtK!7dwZ4Rcbun#^SZ7mCWe#q9BwfCXkr1Da) z9-No#U+;8+56)3`KUksP4swnJn9K_RJy6bIdlA|pgmaeHYy$ZXew*{p6QJxt6T=%I zr%;8cSu}kA;d9M496voFal7&NvvQl2dJOj?yqS-hK+buFCJ(HEZYp(~>N_iS&!wYX zbz;;4c+e31p`MIgasl!gOslTm5BwPqA8kNAa$n1g`VxRH8yBs80q|jk>3(a_pB)WO zmWP7gud^xZ_a2bjEzN7jInc9r4o=BE2m4J6{jF-^Am;*`pxe~|pAT|tl%ah8@l{{P zLcLZ_AN#xm^l_1^DzEQ@oNL#_+}i@}dquKI;wj)>>%1=b!}oF@+4bQ2LP>sgzYYNI zw*7-)Jiy>JSuL|6U9_NMy(!>F3O=4W0`=?CF6GY$ygRcg{4+phi@Em80A9@0Q=S0y zenq7@=zpr#^CV&h*bR~_HHyq}Uz4@w7W!v~EqFg4@2y|{IdJhQ;N>aVGua@o+VcqA zY{+kLYKg)aX!jle_-Yma{gz41!7M1x&Lg4&`+0Hp-VK5PrwY1!KL-3ya{nb*0o?UA zE*I@N1*emzzT>ZVVpO$oHpy=yxM!{A-u>8_aFA?(fA2J^vrY%Azg6W z{VRCi^#EtnL!_6)+@Mcg-wlYsN8 z)chD5#I4FO@EQ2;kCOt!AdEMqw@yfp*;jA?(>2}{=V5(nMcc9w?)82ghvgr$a!E#d z!6`**N9+;^PDi@>hriO89yRNPJ?iZZ)=Q@1`nBvy7qx49_`BUkKFzLcRBtC`0}4pr z5cUNu%CP@CW&RZD*B|>)zt7x>{8ax|GaaISB4558q47t=r@f+f%OBw#bp6h6lAwCe z>u8A=m_KNx2Pht}&Ywb!5d4asN6_`TDVgybo#831i0PNUBvU_<^ZD24dcK*riLUQ^ z4PMcFsWW;FkWZlF2Gu*}=7&+ce8#;Psz=P!?W1~()wwNH&xqjnq~+*Tn$Y|)b$cn? zv_*{at$P8-F(BW)CkJTyt6+T!mDW2^{UT$ZD#e`_9-`&X%iKWm*@JK#0r|FXW%PI% zQE&qR{Apengc9Kb7FxUK{6lNyu%8@j_lIr~}|z9;xI1Kx#dHSkrB z>i4Tqy@vFZ=S=!suqGp29RWa;7U|NX5R?j!0-uUw*Xw#mBB--89ZJBH%t(B2#<9D3V&qi#$pT}ago8*yqNOAIT`-IFMo6& zl=_vye~s?zcKb8=E{@gGI6)ykB=Y<*OaP8FIop zGr+u;G>wm`PeCTrPa;ZC0I(a4VfH(Jb~AoZ(+ZeeZ~VQusd!1NMZ5lK5EQPhTlyJl7VjghvCju`sF9G9sHf*N=Y6;G#bX#dSwgi0BmOhG4UCQk10&AJy z`C=3!@4Sbw?EtyN?iAB@F8vru_fH&+U>Mlo$Go((7U%I;+xx;ezpl>oR>b+(D&x@u z^b>l#F=qkt&3Bzi@5zn%G6X#a^r?hlD};TwzHY&JUQ>T73|!E=I0xwby(TT6?u(Z2 z;Y+5leu+!fB3yMCj)ehgssz&cvBxBU(*L|>H)H-U<9-dIJiBt{P&u2r*Hc)U?nL)p zN6$TijUk*vbb3&Gip_mKSzO;9)HASG$o!*Dr%} zzYpL#`k4PDJgflw4GBf{L%`>yDqXx4V2od!wlL^_iBjYr#$T&V-hAme=uwK_8e32g zm}%4vk*~n6^5x&62*5XcI(eghZ1aHFT!i%BIR2*BN$-AE(KTA3mkZ_C*t}KL3Dm1{}<_jU_rp2rR0fYzPrKW`cd97zx?3h1laG( zu6d(gBl+XC8@B(?n>(x!ca%S!rwMXeZ;X0@{u+(!v&luMmo?g&?}7RVy_w8S1gI1q zJ?H@Z1HUsS#sR#-zsT?^KR3~~Ip7^ntdJ8qfhDTaO%QeMyY;(ejLukP{TKGblIYdrpr zH}*L6HUTVaTi1bh+5@GcGAL*4ipYKRcR2U749BHUWJ&|t2?ULY>``vBzbV65j$qQ4 z_oyecX392V|Jw9hRs;Ql2fkgl#r>nkujjh2fWFysPg@^A-xKnS@*q8A*L5z&qj&su zOKKzF^X!8o@!p7UxF=Y2V7;AXsBZ`G++Fill1Y9py!WHEn`8SP? z`t#DQBbg|VTAO+<_JfnNN8X^kMJqerV7>nwRr!wTh87dW@qBbV1j0i(OInjoqnvy% zZ0dUeYSg}Q>jGFPyaWtuFkkO|K>JmB%N#2Kz*i}sQ`!aPtbAF&1n-Z@X0eT5LApEd z+v`+-Z_B5>!+X{Vg=*pGH~FT+s}#pqMCeIh?DxvD&34%CFJ%&&aeQ9XNcY3!F=taSP>BS!XVf{DCU( zt#RJbuxF3p?->%|whQSwyaB4O{+zU9C(_LwE0S)AN=oW$L(!=VY*}%ER znFF8+K>N(Hdx!Y+gQ736Uus?nbwK>Q(rP-dR|u+uMg;8>(h3?Aocl`MxsUm}m3}56 z{CHG@u5WW!fqM?%rQ!ruzbkb7NtlhxSt8P(8V+?h{=HZ)YzC zl?vjHyMCnneKLWt(1X8iIy`R!=^U{#y1qr6m=6m!_%Cf10Yf*e6Su%D2=tctbF_X+ z%Bqw;yWQfem-4iB;6DTk^f9lAYG^4-Z?;IgSGK6%kE)R;o zcV_hC6NS!{Z?lvSmDB%97^TO3W%Lm3;ZXX$NgEmbP4cFoTe#(-g z`A*Db^!2ZkQ)vC~6xPx5Z5x^VNjI4F{lY!?c_CluEC`zbP`qXrw?3r@i@H0Tq2w~(9%w*`(7cuF#(G3aY zb8TgyWdj4bsNO+7b|-^_5&(Z-heP!h(hu4)-%- zVHPGs`oJh&Hi|wS`a0ddwk0TlAxAA8I94_@zJQ06ZNS8(cFa*g!2PKQ*aA}0%L8J0e0CX7K zH2pvOGwi*X|M#dot@9YV$O|UDT#M-!4HZm(KWW7D?<|-_@q15c0U)0ygR^I$fMEaJ z$?%7b{@z|N+adpLm~D_Aw2Z+&jqW!jNB2<>6qnL%aToyq0pF85-_?GsgOQCPRcu!1mumdR4Mycq!C-+EC%(D&{!{4u-m zzz)vux|#Xo2ySx#cQ$4Cufl4E_|4IM+8P!!50oe6((*E{ZKd<O zCAtsXyhOto^N*3=4-E=-7Q1%3{uxXx??wFgMHjm6%3tq+84mQ_#SN66KEj5M3;vmN zgem?+r|S*kpNra0BQ)PK5rzhwvury`+c~urj)@?D%F-89o@>2)v>v9~UT<)}uza>$ zDe4nna%Ww|{nU|JQtNSlB-5(44(Tc~b?dM^p8r&H)F-ya&U}jepW6*%Q6Jja81MuA z+Adg@LyrYHPlRklxD8Y`tY7>&<9mqn`ffKNnxe64xRN7UnbR<3=G`xjY>*Eea>my+J{*F zBf}l}D8KMQl?c?+23&QwAWYO*MdJwY`D}xM0q32*Y44H$?zD_-)Qd`6zgj$KvO+E-#lPG zq>jHwrA?Iq#!b)(PN+mVFG{t6MGe+FX`Jc6u9cqf3xBV)<7ZbR6ghrt8~$EePCI|1 zK6>!!9wq#a*+gG(JOKMBC zAI<-zT4^rwmB^&SQUvi_%iHO>Y<*1TV#ISYoh(rAuF!iu^a0>ZIXP>zS64^b-p73D zt*vkAzO(0*6zb_eHY(r7-(`25q7>%8yJz?T%4d7%Ujy>Lt9nf1AX$ERFM$2-{G#f4 zNdF;Tnuh!xBHvdaTpqIbJj!cwUV9wEM{8DrA_u?ojrDYVI0Wm`{rs{qBdd`AN4VTh zgnyMyLD7YNX3fA6n-wq-z&+5jfB0};Ss7^yE(Y+9rQx+Olyl)$yA4=w%L6k{OrI6% zsf5ty&23gFlc>#o%>9sfT3Z%r^=bMrIWj@eC< zv+=trvHY+${~+JHHqi0ydS@xs@6BhGz{C#ktBe3FE!+f3)n^Fj}3 zx#Puq={Sz=W$sgcv4G(P{1Ki76#mq=rS%N+CO@(KiuWu!f14aPq;&rI5QYoVzaRKI z1M_7{2hn-G=u{fz8@m7vd?2^j2>pIaS=a#b&s5Z;?IZW?B`qiP`CU5ief3yCVZ-fW z3JqRmQ2LNkGsW%9nDr_vm{~7QUb{`{&VJBcpj;s?6pv6G+#=w+m0GP7_mi@va`GlJ z`tg&-*_57f8x>0!x7T2s0B~0XOdkNxo)x8dG2a@>H+Y0u-w)-&aR$&=S*@Y)`8H;q z^OHiw3+lgxS*MQuf@T9e=;k5{=Nd5Umf%a~J1cS919VAjJ}A$}>@9^IHyL`ZBt!oS zw=$8Aui+pxUdQm~l%awG_HSV(T^ySa=()Eb8Pc!sWWLAu5EVr5zcXga8H?frUy%(% zzxspGUv_+D@(I0R%71FX;Iq-~9{8iyGWqvTV(?`!J7T$mU{yr=5N>|}_U&QPL$)%o zqK!$nAJwPqCNt@_*$n&zy#@1$quK)S0E!Fc8spChcz`-1XZ0Nh|BCKZkUnWt|6lu! z!Ch`JP~`&yuVV8Sly7J#0k`Du2b zYhf~^%V0LZ*Nw_^0hjflgdNTGaT(ViFs4w-bQQTh2CF1gz2V|zyg;&2ZV zfkam}F_`j6{Jam?yCiR<{n6l(g6~sp-Jd|b2-TB6xBEkU2gj1^aCvxVPe`(?#ga`H zCzH2-l_9>>++1CWaPYUDJTI;t{FeLN9AXY#W0McpN5T(XXOjb8e!8yP!X~N{s?X+w zKXbo&?B0Z};hog3?KLNQ$8Bz4f?ddoCE_d1%}lo}>lmJeq!zXI8Mu zhN@C~zBlb;-eDU_oe4eU4l8NQ;d+?&XRH?~hVyrCxpf26s=#lCC-J1zx|@VOHE378 z)=TQso2)z1`^o)TiCOy3;Jp3cV3X}r*l%>1iaR9rl4T!PsjD9DBk8hw?TzC7q;KqC z_u`4*A8X;bt6c)@9SK@fa^bx_-h#aq!)yD9h?DZBkH7ketzpJn_=PdWwYVEmG#Qz7WX_plQ%D;m+{iRk#fVW68;dsqJCXPZo|1A@^WR`$2W03 zB=7H45wFRgNa%FeO9rbu$@hU3X^{pX&)(rvvt@h8HBL^pl{&oR7jsPOMLonL^O2s^ zUfM&ZtyDa>QK_3aTP&Y0Hm-{#&sP<+>+K|_FFDct$vwn-&mFt_Iq>ew?b&8VF5N_1 z+4NPvZWk#CExoy5d>2vQ9sk8Tx`(*M2hWH)-9wfYPBuCg*G;xH5aGLVUBn?+b3-}A zP5?k(QmIdVUezWU+3D zd*ici@-`>pKt*d8@i|wNodR*!+pNbW625KAk!|QJEWmC zaRP{!A3v3)?_o$QX zZjtf7klRU)CskRDJnkgx^J@-oUf)Gj!hN!$c6O2c{#-#1^DdIuuwb*dSr=&);Y4q~ z&_yi13Wu*X?jjRoj+O5>>LLeLIzM^{@9%g&H^1nN435(p8qP ziY-Jrz6V9G-`+(Is(u)14}f^>8fB~5(4G<|aTPT{SJXTi9}TyzGBX;6enY++y6^RN z#&i+?vrDa4v!Oq@&giyI?Iam+;m$c0>eJ`qZwmOd*&{_9Jj-;R5l`)$kh9&)brh~a#vZj$Fe#%g(LH>q0Ym+UsRhjcmDS?f6T5UZ9i zL01#teNM%n5egvZoTQ<|kXPMgrEyHmGr1nZ`)I%Ps!tEeZuE+EPVFJvXFNYz3-58> znJ(=(+|*6_XBJ-kE!souZnfEeH|!ykU*~&#fN{Sp;>r348@kDvMJu22wsw;h_4V4> zw%sJkWYXs4ce+W;Ia@NnvYS|rKlqZ|=pla^WA-_`=^<>vf<4?dETVnfZQem27HPP- zy4fp$MW*xL*w+@@LjoHI-Wfpr9BCUn_XnCRco%c7mU$?PbPBH)lFfj4K9+oy{EzYd zP|4DT%{?TlUnDbi35#6dt_l$G0D8@*zsV3UXlm8ASw$`w=jU~?AjBK&7+e(^y^=*H zpZ0e6;m0BeQnEf+r?N=7l=iWLvTm}V?kvlP)lC8~ytaC+f%8>*Q#;Hjq1L`nzq5Nt zdG1q-$m=Zfa@pdbd0Frt>W|k3&F@%b6DRP`t6CNb4&3;#4en*T&#AgJ_>@KdRH|-Y z0`Cw6i9}70fcQc)bwu{sLtLZC_hwaHA6evHeuDKPjBE5`<>BiPKj_``xuvUs{!6a- ze%7pB!a362X*Lt?sZWYuFOk9`JCqtt7eHL2fkVemWYn|B8euQPZh%tR4ty)CpL$=}K`HnSYhnF1nsY{)tT~T>|Y`^V@&mCqPT#={ry5v50V$=(gkG5a-CU z`O%_W7Ww^tuR!h8UScM6VS_Tf^Sb+aUC`-n7O9*5%*Fl@i zbXCohmr;cE=kf#L-UaYZYj#HPZQ4rr&a&wVchdWo&DiEdgW z)bpfAXdT2MYCiile~BB!TYB_;VKT&1s%%($S`OM_o}k{Q{UE2bz_r`b5YK6=xx(j~F@kXSpW!k<;Gl?>!azNr2?0s=?#^WOCVM#fv4qWY;tWpQ8|$;M27wK2cVE zWPD?NsXe@pOJW)pJQIO9RGkZy29H6U1MTtJ`4R9tJ}~HwWcQLc6X!PD?1MN3^G!Qm z-s&R;-aR)b&Scum{Wzn6gDqr#aXyD9yoXOFG-UyFW{oc~E_KBu3&m6^8tX&}6xRZJA! z;Xc1+@k$HDxIR*|ST?V%rH?!~E4G^K?&l4aXL0PqgtKhDFvMt+*KMU?{{XP1qqZRbQSYH*--N(Qm@3rC9{2K6A zEB)pfufQf16=!NQOxa|dTBL0^+-o}+-zwc<2KwmEb-cT&@UGEH<=Bk^Y$Cn$?HXY% zHaWEK+{2S_uW!d{mzG5fAr646_Plp)&>r$d15r?}Xly0ddIFmST**2vwhHc9P0Di< zzYOQ^%M?z2hqwePJ4G$#JHfrF=2olhNVr!R`zxvo;*S?5@IorS_7kJkMhdK}a4*b4 zO5`Wpb2C)B+O$9&&dKC$sy4eY!XcMxe=~^d#y*tWbrRmqUL7~)@ntsAianyu&0-U&@z2)I8P6ty5!*jc zlVFo7ev3^7tJq{9zss;`H_@j=`bLI>AK!CnCsk;dCi69CqMPyF*0!aB z5JzO_oKNNNZZ;9JIG+@^lml^dql`_qa!6jaW=rNu4*8MW@Hijh%-vSnYTEFHO``ue zt(h<%;?;S4FKAbR_;=U7=A|9rki^G!-coLC!h5*pdU-C?~h1k}m#L7Xr&X7l(ahlC|9-ns_j0qzo%4K`TFA?Mh7 zA6eQQQc_jqT;&MmxFihU59N@u;D7~c=^Qd!wCT2737fQ;+%caE?JZ~M`zz!(oABLu z7jzohyK++M1}#+%>7FCdY5kT%1{S@|E`P@%Lw8*?&$Ph(+B)xbZt#wid0q3_!EYRL z;jchJL>Gs2Xz8xC?d1^dOV8_rCUA+fRb%7T&m3|pd+$|k;0u4!FwP9(-hAzo^!odO zLmr*Z(2?iol1P?+w4e-^tkGMZprXJf{j$v|FJND3Zkze^{d0&9b0WsKXApjOlZQ*z z&*PFsYn4q^mvYI8`Z|kQYdJ)7R>q3^dK{AGXU2W7mqP}3X{fZHqIYb zAkIL}>1w#YEc;8b{{h5d9JX6K*JBo!u$}!bUJ&DwRbJhhzEJ-C7n<8Ou5iiuOR0yZ zMsta;MN?&CEtjl&ck->*b{@%l7!|f=FPErzLH?>Z~yH$P~lN$ZGB**n{Qa;Fa-|AMee-p&JZkXwFp2a1aQ4i~?;61KC z#~R4GMrfxQDn2(qbIFFDf3ll8z)moD!*O0WlykGP{yWI&6m(go8`@7<)~v%7`a|>i zD!K z$+4~H=6&Rn-Mg(PbVD5MF$$9vd6Rg=+BxauIyD|SYSc4SJe5a$H`$A|gPhw>YaP2k zg-0GsOjLR=$s?6K`7Q%>9@%x!-g>MdkE|+kw|MuBOXi)9;|l-el8>_jmrPyABO`p( zWoD~*WayQe``9%+GH^+-WPTBc{0k5_TL7ko z+21NKKx8gPCJE>8h|oB(prTG5#F1SZbK8zbKCyqeKON+eoUl^0dl_B+457Nk4KcQ7fe51&m-D#(rVoa@J?E`L8~sv_0o2pe|RR31ZmQFa{Bui*$}NyYNW!qCu58=!p!Ob_1<%5`{WNw%uX8b%ypVCs)9vAs59@}U#{c7z`ci`@=eKjo zMB5DQ&40K=JM+tnNARAD;QeWNzplaWn4>=9Z7GLX%fDH$E`UQmUJ0Kvel8F0mp#ax zI~LxXYg$y~=m_yy!;CFHvpB@w62fVJg?Uz6-M&Mu=)}pUNp1{YPZ96k6suEt{!) z(v&iemIP%Tvpj0UCkmBBJ2+DUAD=56rf(Z9;s0GQc2r(IJbwMZ{W0J9@7q&Vx_VTM z|Nq)Eb|1FL|MT|5w){_fI>P_|ziH3^zP*5CQTU(y6#d`I z(;lU7_%CqzD86zO?ihvtwY>kx@gF#4lT zv?JA#i*-ynfdNccr2fC?OzWj8Q4)aiC7K*xbKx5#Z9v}QZ&3UOtI;l2vp1_;)bnYD4V2iiOF1G`;s3)9(yF+%ar&@IVF4 z&o8Kff^4#6*hkO4&v08BHgP1C4_5WB-q3^dL$Clb#E!dM1!1R-H7S+J|Zv?Y|_iixpNJm zx$>+m6~JTjZhlY(O!u4Cj`_}t)+aFEOkoX=BH+WSkz!2Wm9%gG>$$S%odU|-Z$^J1 z)+*Lfd&Dtqf0d&s zqSrQ^kE(!W*9xv6YR-Q-R|$~EVW1MrnU#46sv};U%7f`Avm9L(0Ge(-aAhUn*i^fw zjet_+$Mn(uR^MJhA;42ot&UjU?Z=Xz*p7DS=^n)V%!SglA2|uI;Mt_g^~GDmL2%TV8@^sT`{K##jA%h2xq&w?SOfV}IO9@ek@F89t_ zz@)81bl&aOZv{`rCQdHOblqq@4WRZ#TIbXCG8|Y**SVQXzZvRX;H%k;SbAj+Y%DhU zajt;&*Kg%cx~{yRCHJ8{YYS$B$7GXN>ywNS6IZcmd-LkwE<-!Q#(4MgU`+RsNL&To z|4zxCbe~4NMaRu16%{d(h^c|cAap`M6cnibqK6Nu{-H>5s^>_`=sGNIc7{j+_Jv#1 zeWX!QN6V?q@T23AHbWFV9-9c7Uf74&=6HwB|I@oGWKrfi6ixT-#NUKIoTsp#ExR$@ z>~O|&L;;o4UD%KExWh|m`QD?n{drdA6zzK%e;u?3rUUdg9c28Vq9fzyoK?zc`rAU7 z2FUNa&*Tv3R0$xc{dr9(6s&`9<@%M?Fz+5Qj*fT);8~9v_`Yj%58>*kb z47vyTm*1OGEK^LNcHVp#NcDrh_EW!S#Gg#tak^MX^}dB_Qp|h@0ObVqU!Ba~I@ul{>=vx2bh2NzljGMmsb@AhKHTEWJUz!{ z1Nu3W{0Vn8%Ihb`pB4jI8{QmAobS#_`G4&#o|N}aV&-H&>GFYkE=<<1KWR_=q@M01((ZxY|Lmf}12UaP z!2h-LKYM6(kWPmckYlnQok^t24ATEs&;R5bllfaGkr}xEug7dMy>GIg|C=Av$#l9b zpx%_pehf^`o9kr$#AJHFq#QO`Ps`-`xH>6=(}#a-!aJ$YGr51xQG?)IHMu_SOzOK& zmLHqk=SSu;o5^pY69oR14j`MzPs%bEn0yIzpHR<# zwhSJcT-Vno_d%LIlb#2x2=(?rbVA%j7ZmVYbh{wmMRx%xPB$2vxZYyqdvpQ8xoUD< zUz+S!@mm}SHi?|U=zaUk)O*L9k?$;Ia4#3oJkT@f!U2GFSub zn;gfm2YC82qjx!%$=6!O__O%SIAd(`U?1Z*c&6civx&42Q_e1I6O{#i1MPtH)dftw zxA>X%hYw*#AbwWQq$qmtIT*qwUoz35!8zw7t}x(Z4cIX@IinjyaRtW>m`R9tJ~$x2 zGc9ljKs~&|6ipBP2L`jr(7oxjzQ5P{Xu3cwu0)7yMxIo*dF4QHwc1qZ5X9x)ap)lM z!$L2bzT}rA#fMt&XgQHqaVp>P`$_Bn=EF^8iP@qQ?N2?S7!to927(RW?_8tx)oqZb z<)2A~&~nxG*QmTT>Kqh=eOY&Z9-`_7e%NB*--KOZ0NF&TRfpOY)3x&~%1bZTQy#^t zd`RoRE4+i|&)VxudBM@bmRi))Q~`PkD70rTtY|iA7Y?Gb&nZ!eguoZ3Y49VOKbgB3 zac!qFtUOq^Z|=cBLi>JC{~?d)SXNJYDF2oX|t#80jT#|I8XrjC(mL&YUk96v}P=4 zfBVzhb%2lO1X^qc{M&ebKJwRPd26k)yxddYcnv@&{gt~>|3#bIVCO36PiUFJ1faT= zjl)(*w?4=D5$g%@iMMA#x*>0SE-%Ot!y!8t1J2o+KZyN!#j|scHemGh-%4ng*MfH8UlKx0G;0- z@5FxIk(C5y1H9nsN;}Nw{&vXaF-I3L{Pv+ZJ;34CCSxpD{Px2lv}^yywo=6N@!s@2BmXmo z`jOs^T|Y4Wsr1kVv?If$bt=lmbC1yT-qCb#TK?&;z!lhDb4i~!qHW?qF4TK)q@fzi z{q0ew`?R(ryi6A4vXz28*#6c+zjN5{ricb`;NZ_f79T|Y6s;2v&|dYIE?01Vbu`c9 zQ1M@51Nl-r)|0o#(5A6FK#^1kuDM0o9E6&=EcINFW6~z2L z+kX&YVLtjcL*QW(&wbZu{5WXo>q+~wlFte;*TP{b=9l!==_CH^=%nXYd(#YBZ+NF8 z#Z8~VokG6BPjK&m-NVp5z~`@D(SC6p1hYV1-2?#G`E?ydMM|vLWVbCZl{HK-FhiU= z%bc&2bfI~W9UmhRfpXJEsh#p_r>WeY#>Cg^8apZ%=YOZ|O&wlJ{rmhwm2^D%J4|T) zveTUuKP@$-IMC178waz3^{>G22Y9IlssTK9m5~P~nEusF#`%SAFddM;4v+1CGR6$P z3V>k(+2$}>dX^uAJ;*=Q#H@pR9Uy}22(yZ~2g5YrIAKr{%?CLMZkG_fVbvg}Ki_-xpi~#66nXiP+f~){u09H1YCyId5lgK%VnUnQVGa#Q92L#ds|Nj4c+m6Ev@_PipvPru$CS{&U494Mw ze6GoQhbQezogANglQ_eg(ZkyZ)L)O=3h)OmC%}}g4A!PHc!nPEAnr}_br0GR@RNs` z{7gRvi?=Z-jPw)g@tUmX$46|4O|BZD0dOxT%;c*XFsL<)!CHR?_f<3dIoE`dxhLxj z&|~C9WeoPuX7 ztjptL%>1_8X6lvGX7amznRLUWRszkQ~a+Bg~CwczU1>Z>vB|71=3aZ@Ay+CFl;Xkz-o!D7qWaz@ibr(iz;HIXc9F54_W{%X zV+-c|(p~kB>h=A}gcS?xKr55VFM=7rF&vpkW$p<-m0z`<;9p6xDK)Y%xD=%Ptzn9CeFnd|JK77*;IsldJH1Jisy^_F0T)2^=e{ z5XYXpcgFPhVq!B9i|uYtMXWeuB8mKNsk&4o@`6)R-LQbb&sJ@LtqXi+Xx<~leT#Ew z+|S7NKZf$W&+?Rq_(T<+KzS%i7#>c5e?_*=Kz_fL`z#OE_h_~Oy{GmtnI46DI!k#< zkZ;NT`_+j&YNz(12$c6^oe@TT!#}Px4p;r2hRg-Q{(TM1K-{fG&i#f>URi>>CA<6 zWkc2E4v;T}eu%Y&{3JcAC^J>$6|Hxtt%3Wyl_yf)LVlCa=JA(GP;Q{!<P z73XzBz7R)=OC_}DaOErK8bA)dUsF!41m2WXHGL11o3mK4`#IR*E;)E*8tD74Y}@ul z5$bKxOWLIde0qmM=KA%JzkNBchCIZ9#On?_00(xL+-M-c2RCfe8Z==O#oSa@qYU^X zWv;V3=fZnZ!TA8A9pDcV#WoMv!a0DacfK*$^()?kI}6%%l@(eM4)*H2)LD83(pTrM z-6{w8X!CF5Sg^C>)5<%@uhY!RUblc<|2W=M@<6Rs4rE%Utt5tUw@xC?GJcdxZQhb9h^J7w9;~+pN2m|;xz&5v~!K_LpyiH4|_#J zeXM9cor@0OS7To3c0xUl@=f>uECL?MtE#5B5#s2F?U(v=fG?UYZt#S9t=`;&gD<@M zT+hC22pHtFBLUZc)csshE5K=gR%(ktJ^l?J2S0#5&mlk2cEIe&B{{g>ojBiZ!*$HP zZQ8r#knY@L|8gAUqa_cj$^bVXv)O^`)Yv!j5UxihSKkls0mIpEIZR+YHmbKY;(JYK zmfA8$XlLKsmNzaS4=Vc={eg9(e!}P_3&y8kwf@c;n9uvo16AUn_k5)7;R(PN?Q4p- zFX9)B%Pt4p7ty1N`$IYH({4Q9$QV4?i~FnPWkQnypuhcKE1m-%UVU;`5l~~vrVY4X zSes_g#C|AERj&UD_I~sH#DV8S$;gS*cz*C$dCU>(vAJdhj2Z49Tt-EG0IdU_g?<73 zOr1-Gvq1iLsw@=GMV!a??8Wni(V}zfm%#jliJJeG1A9$HMze}Re@wueV+Q1(R*n)f z2Yi-WMb9^V!;7C{JA5a^fWZJCjGv%>R%T%|1TwJW-NprIXK391UX(j;TFpl6mA*jz zslZK52t05uc>1gy?F^VufvZb6w+)WDW4cULA}|N=GsT;X5NnT^$76lJBBRw&uavVY z5mBUc53SF4x49(hd1~Bxz7z0ri|1xMXI94Lb)cT3ZTJ>M&Q;<-1>v6LJU5L8swedz zu!Fx0+d<<{T?7;7?n>j0DXfp)E*j@%Oq~J&9@e+lewu!@0T~eNoA1dqUOnV**G8Ft zx)bf!nKVvn*M{ysTCZ*5P8!dApXMJ$J<8 zOyh0q`R!D$*gHbY1%(~5gpnOpWKkOn11AEFxAhyio_l6 z7reksKv(EBVweFm3%ExEh8ggb`&^3l)-cQiB(X7pnlE>Zcm=mv_B zlix8|v_rF?_jMZpV2BG`%K*9~T><2Ox0&L`1cqlFnFZ4d>Bg2;RL|$ZFvZY)=V^NK zv-uRKmU2-frx`o7@E8Z>=w}mvzGw!ZDs~g_6AnAz@5c;ogH?d?ax??*!WITwPc!ql zW3pd<0Ze+^EC!KXpgyl95?pvM`oQ$#bS0Pxa;_+2k90FLE_FK=)AUypgd&$Fll~u^ z?oq!{nHf(mH4s6jG#3zO9p$T&>HqtVrWc0?((k~mBHo_NAHd}Va$XQq@1xm_T!6F{ z(pTg30opBPuxWCBzv?nFC+vF6@4{sY*kI1|!?usXLRkiTk$ysc_P+B1G50)lX5mrj$kHYddV{ zeqGr&Lf5f#askbsI+{T99ou(O+1gGDE)?KB_*)hXEZoOE)uHL%=boc_|4rbRTyT%+ z(F6kyyf>kO`bV4p4pAOn|JDTt1l}8_tcDqe{a-HtFUYW8d*{-2zlGrjgm}{WkJf+t z;vkGH@Rvt(VPyahI`bdZb7Oy?estxJYqZ|!O1J>nOTeYhXel4si}q z*<<<@JCqGSIv8QQDRsHvAmJXc&71Z=*Zqtw%5j{9^uGM?^rMvDE6mh_r%BjH*_JeJ zu~o}7P(D9Ce;e}S_tQJZG0tu_PJ4y&P>dv8!~joX-2_Jo^(VJSpu8+VYdyxbvkQ-| zLcQdIa#$&_kA(hSM!n8HX?kC2Q+0ed#_w#e{qvE(Uzj0!74=`;_J$P*_a-Lt4VW(e zR4V{^@6I*yp?F_xJ-R>)^|(#SZYfGhQ=Fe z=m1VXvGxVlW4rrZ*;a_}`DerEJ@FRr9!KN>i(Y5Vk^{WaGJ6c`dsHu9)rILQ4-(}8 zm3@})NBh?&Xu9J4b$R*=2XVlA-Yq)U0gwJ}6h!+{Hs9WaDE3)4WgeiTL3Z6KK(9BA z)3Tu5@7KcK;yv>g<)gdjLi)_Urh#LC#d`(b%>^!Yk8vUFQmJ? zE}Ulr$b0z~_XP0w!?k19XVjtmX|MVpz+av`bgI||<(8g1_`L|qtu?XxGYgnEGtR@BDfoa58m_vP$`J#7!$H2VqU9;XA>digYFK}uLerF&# zOk^S7U*y3;aaa#N%GG^V5HGjz$%@;6UAey3{?3Q-4Zm%c3;7-8xxE4oT}j zvpQH$f=(AIIzNH9&A)5NU?K2D(P7@N`(eLx@4xc`#%JbAsXO8eV7}Bn3oXDtkCcDr zy}*4~Xoh?k@B!rewvoEiG1 z>KUwSOT&GjY24n%uH1-!!2M``lQvCgD7bIChmE z=mCDO{oQASJ@EUb9b7iC!0$^hM+7{Ab+oZYZ!HV(N&k?Z$1>Po!N2F*!#VDp<4<-n zr0>#l(~yI8WDu{oL=a>$D@S(=th4v3dWUjgex<%WOl|@>aA9EV3OM)8I=uQk7mU|Q zH*>DnhOmy_kG1i2un5O#JE`GL7I_`wrJe!(pR;PluklTAuW*-Z&)z5&=`WfnR5{8b zuU@=85Tec^MS2ASU4txg_US5vqek#teW z%yi~+Q^5TPP9Bv8>~cSTXcp@Ea6h^Ovg(T$d}u$9(*WJbuMo%hGC#2MqsgfYcCapvj7YBA3Hr?$_O%*-{{K}0 z5r_EG*e!;BX^tJ6d1ozNuC@eZ-UplE0w2zQKOWsx0nGSzJP=XKJrG{#VIA4E#Nqpl zWl6#pJcp&P%}_#rEBoKjXL>)u(W#E-;hFGfa0 zep>)oCOWNq3)q>QoUqIX>^3On+k)wu!kaE%0vy#0)EI?yYdKyyY+rI?Fa%s!KYiK2 z7-4@+*&u}YL4KUZ({p#6m*IWO_eH^;sK3f5`4;ByQ_}(B0DSm_D=(sTea8U$+oHvG ze^6$x=3ImNifL-^P|jQsXNV{ibSrTY;ER2W_G7=k{S!He!inv$?<%uV{^i+s z;w9Mmy=TsC^v`=2j?(wEL*FZYVShiG>i>u1dfjaYjicquMF`d(`KgJ<=_&Klfr!HW z+xd+Y`?OxpL3ul;6EHmR!z;sR{BIrHN%@14i5BHK&8xPKqTTt4tw4m}oG&6u>y>wY zMESr+mHU(**nFSci|g%k(zM4|->0GT^!}`9X%w~RN99RiqHy0(#s2{Nb?sf~Q`Fy5 z{9r2^%QCnNh!;%5Emic_B;)i74!cJu~RMRC*t$ z`E4agtifOJJxb+NJ?4DUF1ktq)AX z0QSpxHXSd+mU~n$P{Nz`dsTQ7Fjw$bi~Z<$&5+Rt;tKb$$@A0^e|uKZarf9HNbBvr z4D<}rbJs)jfYUvp8bBYs&IGh;MnVktG*94|4LBhP-2yDU4b=l?z$hXHBvn!z(qZaL zabWoJLw+Rs@ZIzPGz-Wb2-l2&dA!%CEGfmbmpKiIKD)i0pwR~9k(zBv4#7rL0io6=1C$?F)q zz2`7;zz7U4==nZj=6k|m1C>R_yeX=_X8LvHBXd4D+QsMxTWqBHGRyEnAHJ6iW7-XW z%IHP4FzwU@ETnpMNAO_^?x#*Lb{=&xrRiK&+!Pfa=TRJ=-$(haggqX7fcJ7S{p6U& zoDUS@p3?N>y6LpOh{^NAoN3HEjx)z)Nb@ z((;#j2~Dqje30&w4>i^_{hgc})w^>KA6no&O#Uui=L+RQlh zgAT(u)&#1w5z7^J{S6}QC|E70o?y4hqhpTae4E4lsm5a&PM;RRq*Bh z4S-=rU9{h&H_lMMsdC7)2=)GHNx#8+D9>DzQ&_&&a0MK^VIOMg!3qODkXNX)7VxgS zrGgA#d|&pD5%8l!X)cek{Y48xnrNJqo_U1Yr&Cua4C!S}u{Q$&gG^4^;(6evU*Zmo zZ{I^r;8R-Qi~Aaak&kca-?BUq;<8+1oim<85-qd5FwR|bxu>fSn8fYbh_ai!ae?2l=<|81H=ysAuK!5bxWsb1S{V_#L2rQmh2h zBV6zP%LO^6+|hVD@EY60Yga2l`+utUzz5jyPVfJ?Xdmbq23@{872^APjl&ytfX`^$ zczXox)U30}`~!R@B5p&7AIQh1*nZjw{3WjIlGVf6@SVlua`}ajfA@VyVG!gma~Ui! zhx*j4ju_(o?GNQEHObnr-~4@o`$1ND!Qpom^y14;j9U)5S1#3>8B>~Ys^jo>*f z;;Z7z-2mkcp4T+~GXVd0>qelQ7~G3ZEPtU1{H*QS=)=kj;MY%Ee3!3gk$IX<+-e}J z6eYat`OG4$#rbFVC&9c8yFcze%OXvzsv>ibPRWbe)9Xi#zecTeyg1<}o_MOAk z2J%@@>RXF7i~QY{ut()}r}cbTM+>9_xLSaxJy&eAzs?EoG!DVZr!C-}#oPB(GpuuyvyQ#Eev&J;+gx9>NR`}=ihbU&E{DI(JqhQp-T(vP`!Me=#UF2~u&c;I^>R_A zo_Z2+&RJJ949%P3S+mxdS+bVVx&B zbbJ*A{W}SrH9uirMQ0XB-GcmI6AN3|fYa6eeu{ye0r!*V3qU`giFt>#!8kN@Dk=-Y z_(WLs)Gkv2{-u$b$KSvrX9RqI{{?-HjlTX@;apU|{_k=LI0rfV&FU9}bI@+qJp0~n zEaGjDop*SYMgEvg9X$j4^(4FCI-ZCB+RV7M7S1^bL@hoxf!!n8KkL!YOuc8gK?hK< z_b7b_sqPlaK)<)AYb}fU&{`_L%-s$egr$M%Q?k9fnJjN=Fb-(y^rIaPcrC# z*|F6*9Au?!&%Z}V!9BsF-lM-^+@h}Cipd52!q7F#@E+pe;J0PyS3i4B?8EcH?6ih; z=*P8Vj5N@XyBraIL*s*@K|abEp4)Ws{1f%sJ`~RpXG0ekU_4t|uz|kEW{a!^VgUB{ zsg2;f(6W68Qt(|UD|f&F>rpdYp^Ej#A8Sp=@`|%9o>c=@*1hF52E5to-6;i_d@!#W zdH)li+9Ozh=altJPXZp5z47x9;JNA31#rBc{Bs({_E=3KCg``z#Pw@Yek9dFaE^2zVRPV_!4^RrkWrmI>@(Kx&;a`Q5j;qSyy-Xc4LP<`Lq_3P2j#Q{Gl zZ?`lva6-K$d?PauHyJ#E3q-KH{&+O%?aAG$i1G59@}US!ACKaq;~|=&{TcgTAMo-A z-bY!5cX6OB@muo;V%;U)i>R;SR$qa#dE{!!vy&|0SsG;NvKN#O-QM?+@|ucrpaqbw zCBgiTsL9Hi>IGYB()7=d9VmKkf$$D`Z>LObLv#%JMaPAIQyJwimX2PO|Hyo zivo|0|UYDcrf2{XdDiv`7UPgxdNo$Iy*+~v8g#j`xzuJ2p86H?maO|`(Jz@ zhwAYMeWH4rJN+q|KDbHO+hbc(y52mepMZ|TI`+OmW$_3eg7RCfExNew3+uY+JpB~x zGr;sEeO8nQ=G4uuKw0Y3t>(v9yR8qPa(={BrgczKFQ$SlC}=; zA?x-@zEI*R+nuUUMHD4@WV_g8;_-aKhV_~`}2 zC!HIG=qCc(bWS5Ly-`yZf;?B}RQU4$z|R$NdwHUtxDx4|rViL_<5-P)(cEX+%>g@S z91rpYy;-s!3g&HfP8McebQc#=UwVQ`~>)716%{4pRD9AD9i?YGs1t5fL_x3*eLy& z`-IRgCokZC>2+FzU10yw8Ou35`y0r&kk$pg!21ptb>#^GkJJ@;>~RI^PaFE&@3@sk zlD@_Y{s8{^Z?DJjbGX0NPLAdI>jrUW{>vxBaGy7S?Ua5$h_}6~68fHRY$4eSshTMn z5P#k`|9t+3MP{rW6YzoZ+Epfhf+~RjU*o?bX;w}0`8c+<03X`melj6wHH$1~yZXfc zZ6s4}+dA5hmJ$nrm79`XpFI1QAi*h?+Ca{lyuR}z3;gT!wuL`NSVVSh+ltZDbohUV z*2nzvjv>kM4ZWB5HNki1ugvdFX(B~Wqwm$GJty!#Ldd(LQF zYbEzS3GTO8UQfgt=Jtd|rW1$tpH)RG@=1>c2glQhJhCY?m3t>CBmB8yRvgowkom?+ z98*aQ89DsV?_JUS+x7-i0?wB7iGyxN|0&-he2 zi9X$58D(2Qb{_uclJPF-t%5>Hmn z;vXEbEg?41$9?^~o|EjHP0MCyWs}%tUvBV*ClbXAMQOXG<4K8nM);DRa^jz3GT-iS zEjhEW%V-qtt%dciZ+w0X=cGDgo<$-MhpR1K#r!ED52l!04LVmz{>Uy&3EswnzpLv0 zb?_tjkFRUGv~A$KTr@7AaXW z8~CJWS*Cs`@X6!~y=x}0KU2zeOGE#%h>YiZ<=e17=YHFowFC6wb;kC)0^CdUKAuqi z0lZ}IOnrV!INvIF+|2?%ai!wc+63Us>q28==fS%{*6jUpk@m3v|2@BK5Bn+V%Bu-M z@Ec;A!nveoL;U;aXi*INTX5|3z_t(;nKrfbDd7u*E< z-*Yv!9R|G>+Ir{Tf!>^m_w(@g9HW61>k?pJt9z~podxCoEMd1@06&zo@Ah6X&^Hk; z4RMC_r|rsT^?;{0z3&-V591*H&!77(@OsYpD?1gSp4XvLE<2%Lfl+zGFW`JLu`5(= z73l3Po$wKbdIm}*G}nUu=zZ(`wIF+T+j@Iry;o0&9t2bxHx@;ndf0MT8^$U7AM@-m zUbyCEbD{r#zj2W{^3#h0&oeOI+CHj>4@4k-j9t;g_@uY}E5_Z(l86y&LfL)Jsm-{*QZ&;uwE@b7TG@W=^^1gZ&sb zG;Tuqf$iDf7;kU?nWK;C5z>c%@BsgOTVjLqYu!imec?rzdNY2Pc`<6^RtZnA5*#CrrulJF!FXjy2iQ`gkb2=C6I}o0|%pgi-!&ul7B^Lhgpmhe5k zxj(gYjc6{FpU5Rs{`bC)dG}wD$LOi&mr@>^Iy~%&<(jYKFE?R4eizXCj_jIAd3$`r zK6kXUC!2o{=2x%VOvgi6N@Y6A3#)uh5pB1g0^$VxdELJEX#er;JZCZe>MylFD0^(q zr+isn)tmCfct7}=7o`977o$Azpph-*lL{NxP&wHplk!0;4ohmkpLPkw8(GH`u$=T7 z{*8#j2kuk;C*a9P%dNONmFjsYkJ0|P_YG6tS*8Ar_Uo7qJXb-v6t73L-0`41YDZ2( zYcQrK1zFK{J?zMDISkC^`%nK-6UYDTby;M5;6Y{qlS*4wr-njVzosU=R zKV_qQ3I3ldEEhM|=qd8b(i=zmaejT3h9VIM+y9)y{cOwBg0} zZ{DAHi03!;g+HjCbmlsFA&^(zJoOFzQ|r1D3UYu)yX5J4*mhA3{6Pn>`$qpEE-p$^AVL@XTF=m^tOUrdYAb@%0bk#}DrW?Cchp_U(1ZMwzjk!K2R|CP zR*wD-anLjQWdZ29d@K(X0=+#6sc*l5Klyv6uWA?gMbn(o!@nTETa$bY2HY8yZp8_D zODy9b^}#(SXL9%6U%=m*${rgEK>gyU)8B+Z{z&W?Kic7-HYYI>;>O>uH?o zFE+q=r`>al6WkN|O&dAdFbaG!I3P0=?2w(aOy(%mZ#!eg?#Kcg| zhZ;zA#*g+fh%XJ!7i3l89lmC^R{1Q5Tc=I89pX)Ak!Nq8^v<+yAe&3=1d8E4Y*1#E z*;nX?q3K29WC4C*rGoZ_T`VH0qG5a*+V?dQ{1n~7BIX61%2B|Br%x$xu$lvLkJI== zk0%R$w`U(`ZS-aNM=tdZP4>!7?*sR91K>N~##e#eu_XZbf}gyP7@8bd!n*9H>0E_zm( z>T9x2PKCY1u7Z5*U#d9GJ(ReZ8+*sxC?>{hyNhqsHImbhh?%2c6XDy=CCnjIKr|1m z(W*|kN(MiVY){pGM&4_0A8-?UL+&B*u+&z%1@2nKDe%)bcXMp`16ECg4+j&WK)yjcNXd1 zoHYr=WPD=5CBI^lyKia7F78^g!}3yZP;Pbo5Kcm%Uay$lm`a+>Rra>OO(d#=(<>LLJRxbnVxK=VDIt%Y-1=gzvf;8alCiO!v)sUi;D>d%FaMM zZRjwK1-+Gy&s5Hd!8>(qqsaU#8XUEHle1}Yt=Rh6lbNcwV_%!$tx1;V0T!7D2eVw%vc;8g#(-w=eUJwD9alM77 ztBLCN?%otGxMw_Pu{Avx;%L#&54nrr9bvwVz*FFND{4%NKfylzkZ|0$5ciLOs*^eJ zmyb(Av!}qmDtV~+k_YVk{VD(NIPknJ-`uJS|VkAj0K;*otU zlHvYhU?r5ZpC5bty9W5vq;j@7w4=3oVFbRXD8-#w>r=%dK1G#HS75zglHj-`1N*_` zo5$D^IA89*=^gz<9{fq^w@)+2;hy+?sOA{(*eX?v!3b!7m4M~yPT;Yxr_5B(1)j*y zmNwM@dxD!?HO0V=>g_wkYoHzJpF`1B(4X9w$KXL5#&gjA&nVb+Tk-VA3!qmN{d`{; z==tUz*W3d6l23igy#P0bEPr7L`9~FNLwrHsTz9^E1Lz%^QB#Zl^siipL;|4rm83Is zpweZD?DH z@u^lYa3zg5mp8x%!EjIYaM>Bu%Nstblm|FZ<+l$g|P#+Z}sNW za*V5u(T1~7Uw6+cUaa@Qwzz(@zpKdj493fUIzg1bykPC2e4`@&LkZri3_U)63iUPy znZ=>rl=yx0JA`kCMCm=>r=4X$Kp@U$T(QA;xj3$>AN9`n?Qg+ymC2@*2k;)KdyM_u zp2Ie!=AmRC$iP$7Uvk0XGT!6-S*Trx^@U3Q?x8&A%2)!u*YqrKI*0iO##YdDw;E%r7i09E%9lUGutEOKmKmoI zXNx_eJjDHo0OdccI>u!&-QA>L8*%g3nju8j0s+dScDo$dgfjf$8`{4>;m&xJeb)bE z;dt{03T{UEcJmHR#8Kgz*@!vvYdR4NrvIh9A#v7qE0oo2f6?E4t!;>;r?&q#(#KE_UXV`2fW|nsZiU8^WZG4 z0uS!+J2oRBd*nG@N)>$golV|db>DH&vo?wB#&VLP%Q^7fojJsNm;*dLHfg}TGl4`8oUYofp_f1@oKQ! zd2QwEIiMdSVD0|^{GG9^!5JK%{B`T%szGnlp0S@(!O!g*I4qL_@g*flC8!YYtKQFS zPTT`}I)8MpJcoLhM;Y+Aga01STiLh*>OJ7b;z&IP{(4K#F-PD-Npp@}5`ldF>w<#& zq1>_`U)PlE0{(O8qO%>e(_O`()e8MlbGyI(E%;aaDDKc2h!29zBcmbU&n;YiB3G-i z$gkRJ1FtT4e?7>@f&9hLKziQ}LD-i8cQT6ZvIy_>Bj+CKzb1#mX6bsuIXQ&yR`hXK z;GO2DzAtNMksmix`|qEG-(R=^Kl<20;#GybR9fJkt}gzN611ifj|6ac@Ut2*Ya&K#>y^kUl;{iYP z|H~xF+ZPUv3S1#}CoY{cIiE|i($W?`T%JOVjI1mldnS??4fpx04n84<`wUDM*Qb!4 zZ=39eXT^}0U(%ObCOjd7r|v~pa>2b?)NXA@r&OY#=V5pI*khu9-mK&!R|XM!eR@G4 zJCOwCC#BB_PAAe~Kkl0Ec}x=gN+B}e4^>AmNF@jT zr;KzgDk7G(N1n3O%g6+0u=j@a6q593v5HYb8gUZxp3?1|MARS2$a58BlLx-)Ve-3+ zNxoETcb#-9`O{JLOv~so;oJ3!>*~@J@;qvvZ_e)&vU-1>ZD2w=`DWm`v1?x%+<&<> z$ta}~9{ma%+j(h3!rf!Ri=h-UR^96w5s^&Vc3sHr`Ithy|9hji)hv}v*fe((3qK|o zoV8rfxulWBA_Du{MpKE5-TGPDNiWF!)`_uC=c~yR&9g%-+`wD@Ggg(z20yuI^PdXf zMUn56FP3N)li?Z}r`V`+;!t8d`nbCR-m_kBQ+f^e$JfI4FNSp~EB-fpn?nXk*jGFE zt5PAEn;dwM|6&ahw|E$!3hV#KxzSHbMc|JluN2Pbe@wo{S{GfGeM0;-=N=c7e@Qgv zTc66?-$0Bsh37=U`9V9%JStH&ooJRy#2jCqN;nocCOGDlkiAtaXy*c6 zC{>evIRJ4Xbkmzi=_Wu`xvy;s;0Y)7fxux5spUggM;9 zIj>mqGRhaeuediW{ktW+lV+?Dl@!9b^I+vUc=uH>&r7)u_i$^h)nog?KMY!}4!aNa z?IM4M?O^mvQA&za(;de8Cs*FDdLA_hKE;Va{{>$4b90ckcX?nE34DR6yO;jHI0>9b#Q(Ev1 z_^l}ui+?ePuu7Hi6g60@c47ZE(Vmw`taor02`G@;<DCk&5aWdx)8S zJ=QC;rOE{3g;f;)Rg4SUqaVxSxn9$M$1IFnJ!@K|FyCiM_!5jme=}Sz+yOg#H+^f^ z2lDv&;h1lr|D#K9@lKH6#0SD(nuT>ORNmJGdVzf_r+fza#`j-gZ$NLgxavL&kYhL; zcoE6=dRf$8CA8@s#>;I(LQ^o#J`Q+I`G|mW3gtP0w)d*gju{_ZFJbXMTdI3DHGJ07C`Z^9*rdiwmw7GZy6gz}bQoC|GM z+l=wDJU)ZgC(X?iu|rQXBPVPaiZvy}l3kZT16xaO>}o1pF0|=!E=5ZHw5t(_nX>E;);Q z<)wMT0$$jMiaX_l@LW}A7~>cYDB={n&Ia_f=g6qH!uoxCbngm%(Ca8aG(80J^NWO1 z@&4Jz@At_qpts;bupWzu-`v}$2>Mgk?C*{R|5o(z`}+s_z<;EK7vGhD z^IVB{p3fh+cgfe0x()4hp3Lkpmjpk$s_j9r37nI1FO`R;IZmR zbR*f^<^H1izk1@(?a_Z@Wd_->Do4N}KAQ+jh{tv9VUe__9=~I|8%gf|+Wc9Pb>to2 zBgL4EbfP3qN*9Ubli&;akM+EOf1WQL**V@wE^cie`SGrnT)$<1I94EotX(1bOd+;_ z_**Z@l~72Bcdr|z*L71#e$<*Kp8OIbu`+S2aCJRN*1VU;ie(Y&!!r_xN7Bi-jL4R) z&S}Kip13cX{+x8Tq__3?)RNyLf4bZz8c0}c-7;4h7Rj$BMI`@t z*%yNiRpge^wsZUA>WNLjIsI&nOft)$-r#p+CK>w`P!Q5nK<1P$xL!4<68;XciOYYh z>d1v1qr;wcS!CuM*9ZxoY_j+q*^>UOfc#PZesPXh1>q>4^7Fy5S|W2~Jp9Fo0;++Y8`LW}}M-VS(>f8&LU^Nil6K}bsAr3!Sb4hFoygxf{ z+^yz01MXEly`RM{g>}9*$NqtRJ!$*Fy6*w+b`Sfxl*%u{I^C=oF?}xF&z!a5GZKP( zqn?X=(?V-Wxr*{n4Jj5m{oeIuS_qscbUc(3pq>iZ*OJY^8}_z8I`dyc4Y_+ieG$hH z+ynBvq&Zy$Kk?FR{e2nm11D~zB9B_5)iN=J@m4Z0!X5TSevsfdK3LzM@Aog_fOKaO zt;7M?@4IKbst<+rnbSOczzX7Od~1@?64>82$+RQg5Z{;H@|cIbV$Vwp?;N-%y?*SKnxd^Z0|76=%< zY)`iypsB|xdTy?DhtJDEUjICHF~-a7o8A~;JW_WVba4QDsu5Br3+Nuboc_J#JrN0s z=+9pZ-&}%vyWPaH&I5Lb4X0on=`B8Pk8#3F@Npc*n{fTNo~ZYqXO8|&z|ymghgATr z3vM67ex7f$wL;!d@Xb<_#xuK%hwg*?f=6B-9n)rSbB|`N;pUe=o(IL=lhtlB4}SY1u^YKc3E&O+&kN z>%aJ7{@w#qW+8?>-cIjB&M(RRin5xn&lBv|-gByMD34l-E=GK~{U^P5;X5n)1?3&f zgA*|Bir>9Td4&GuL3%$^lo+@K^XDXAqI$knRx?+Dtn@Xg7~^GUdGZt-7hT&$@V90m zuG`$8@v_k7cM!&(%II8i)JqUi%0RtjDcjvRU)5Gy{$X5o&A!=n0&vAf+1EH;Yeywg zF@Ne+eFM~g^iT8+>ghgm$i4x1_UyABtWUmWjvVF(zRiA)`k#1DzY_uMzLNFZ9xyiW z=N;_Nf%#tayL;0p?pru7rm{NY^8jN9}z2*EOhYrAcbRM6! z7USjj!#kH70$vm=?rnp7LFF^*^6;4AwzxA09Hn4wGl6HiRqTYv> zzW9E`Hr*c{0D7x0zmF^hz4Wc#ikBeWqGR3RT)-fcRW7)%5>Ae%x`5t==jyIoKrhBW z)MXG*vNP=9LCAkJr{6Rf^#^6o*@B+@nen^czz;sG_cGf7_YFC_x zXOZYrmRrwFWfA|(mx4;b3pgqrZqI>tA;WLi)Yd_L?m~Mc& z41DzIK!gJLvG#mn^)Pss(T}k?DtMGdIQiTU);O5GU?>m!>aAG7nG1YYqlp$5csYs`ed-dXd{W_oEysZ zqLyrWGS;zwEQ8DtU1_7~SVEQt-8fS}+(1GcfBSALZ6sC3Ce2|h>WR$X%U(k7vxw3O ziL6y$N=VzWp4-YVvdF=b(?MJiFaJ|nl&@F@aelY)_$G*#H$z=b`5<2Memy?0;9EBN zYH9vnZ)Oh3p69f_YiR+w#U=de@XQL5aDUq}0mE978vJcaxLiItQ#5Trw=$Pxp2<6Y zj;nywt&tyWcc>skCcWpSzt<88sk|5WuN0Hcck?FRuP-2SJdb}Rcoh=kVKu9aZLdgi zyO~nRnR=44(BF9=>p8spZp_)?xleYun<+F=RuVq8L{LknAh`R20uD|bJA}wXFlK9x7p(Mr4NJh4j zln_Z&T0-_}Qg&oylfC!ed+!ycGFp_R)c4%`?)Uip^?aXu&g;I;-OoGT_x0uKFpQV# zqE_E%lG{+yNXv&cQ(b75lktN9*nKK*`(X&{S|9(oN4;MM>xT;e{p~buM;>unPGX$h z$kDg#KwS{j`{OC}yP%$#Xcf~xhWL7ge%`vT+=*IL?sWgo>4xvP$R1t;@!8nXyqsf! z_8u6tWexC&pW4E84s@^{B|X^~1LJ#mWcXGM;2pmhoLv1tzogkDwh!j>Y$C_*nm|2E zU_Kua3ge>1FU{Y^FkY5F6RE)C<%6?@{m&p=WjJ@ubJ#~(s4a3i1MO+<$_b7#uQWP!H`nPj7S<-@Ei~V=i?**jZ1jFqK1lZhq&S*#YV53Op?u0`dIm7LjKGd)<(7 zPIcfB*@y1fl|lP?)O(g^4D7{a-1$3UynN>}@pKb}3%RCT#^a@PKs5UUz=yP7v+=rW z<*~o%_?JhHnT)6{wLFXU341nF0jJZr~cagKf2CwhF zKD!|g_g8U+X?%>Jw-Wi59S3;OQRy^ZuQ1>*s>b^uj(K-}<9<9y{EP)B^n-?v2HdQ` z?v2=qXv`1(h@FKE0qDP-d77*Nho8F#;PH~m+*Jkl%YvWPABzAkE>`~{>}R&WiUZa^ za*ZY9<9)j(ChTwX%otqt4R)Ju!+~h{|4p$NIk&O*`!JbL`!QF($KeMW+P~uXjLb91 z_$~P?hwNiGjkb|_JgfDV25i@3wQ~6YU~J?Ta-R3y*Uw~MXYR#sGEcvI&rTNGxwDEU zV0@*}OU|8aGlXbB7S;t?0Vr7ijqr(>yNQGkjHS?#aX#lMEI)vLWwSrN)cWvCH_P^HnHIV%+k;}X{@p=>2Hr8%z=TzfOcnO?pw7~XhyTaj*hS0C%-m}5_ zR;37qyMPzxiay|Sj!Nt@H35HCwycqMhw<{jOZHEUFkXJ5YOSCKy|%`nOB|s0aQ_Qi zu$vc8q{s94m^WjV2Y~nU)bG57*X@SwUCH-t{^szm;B~kD4|{G0fW0`KPcgo~xMIt~ zp5qWcGW_{9=AAiI%h57`y1lDv8W`_)ZO?)JAe*WjuAqncz)boS;Xy4nP68l5k`u{& z3^?#*eO4e~&t?|yonW7QN8sUM7*|cQ7aA{Xz`1g|sW2y)Pk-g$H%%_;LT7f|jp>AS zgs?(yv`+t>d+UlG!2EtibXhh%ZPob_IT`FRDtuM_^|}`$h02#B-#B{(3v^$3J@}4(meuqG^g^ z1^*H^+n9%g-n!bC8}lD|#&15GfHz3hXM3RS(4U4Er;f09qdXp}sC}iqNTspJWCX^` zMakNI`gZxqA^lo`gjzK$p7`7z9qB^blgHlfUWELf825Elg>{3`(WA@KrKtSSH`O`g z64dp)BZ3d+f2&qLuP0pL{KrMB{%~t|M5aJ}5~uIY zhW`KXsMaGY9+*E}i|!Eo4((O)hU?Lvo#>3Z*QZE0zZ#(x{^qkj-~$?sWpyO$TI9fkWxV*`hGZ>_lr>( z5>_q|HPEa^HmWrxFJx|3XJRXopWJ>0>D8k1?L8{=dQ~VxN_tLK zqyY^*ei@n6RfmK*y;n+)_Mys`+3LzOEl9pP=z^|U6*8NM*NbRsLYvRH`TPA>his{y z)sKLEp!u0d4APuW}Jt6(0? zdgHFHJ>Gkz#o3!sfz*scl|dbvH}p4}ZL3AeiSBB0 z;q54wduBEIbsHMp-gau^coT{;O_lm@v>sIjIvL0R*N9fP-rOTHT7^^=c1rk7mm)v^ zBLNc6E0FFn-ea1yt>}KPm)R%TE;M!PPN48eH8SRYe|;TC8PXRYxwtG|jm%D@{857S zlJD&`g&S#M-=R**IWN2hed05r*~9D2&EU+WvrJt`pMR7}9C*SR1Lw3VS6KgDM|Z`X9_GKC ze`0w#V4l)(TcBtT&P_F*e|p#$_?E23nU9wNQ`O8~Zie}4;>imYz@L=9h&17FzmqFc zrvicJoclRl1nrS8zF%q`%nO$41-_nve(nB(u^d+;th>ATA8Js6^Qjr@V~wG`ir-YS zZ-@TzvFU4t4p?`{Vd-G=hkilrAbTyo&t*|=urf*z#?RP3!yHKO>9*i=DbW6JUqAQc zB&^3wZH~Ti0{Dv+^C}xH@R#$CM47Gte-XNHPa+ZewWy!YmO{{v{B>l!NezA+s*UpI zfqsV7zxS6L^gCO6KgU#oyeRd=UFrnzD$BgAWZ+A0rw9A-{3bNO|6nu36TJNR8(yb) z`0ePM&!CqVasG|(+5FBaDU|^J*l_6|{SJ1T?aiSTAeTFe1or{ox*^p3p#=O{+bN?u z3wlF!n+Lc*UK!)L7Y23)$pV?bAYRL2qsohb$99Mny@T+HE{|t;+)rS-J#Gc)qx$30 z2k7q_vlac;f}PvZ`}`wdM_+_*0>VHMSGde)$`Z?}I*R_ITal&K8#? zJdRVjReIrZH_5!O665WTIOHWU3>re=cguBa1!nCcPp3)F&y4(vCiy_yWkS;TOP@*<>lb5~Z)4QU zr6>MY$W{`)^Iy283&OXvxsq~Apkl4T?-zd_ScG}a$NUs{F|@0|Uj~@})0AXA!F+z5 z&mq0nfLosR=!yW|tW62U{B2K}G#}InYM8=p2Eg!6?w9!cHS(9bu0oBSaG`#p)Xhtg_*cNP4&zSSK1cYCuf zicDZ1QMeGmIJ(IOj%Rgf%i8tz2Ndg(NbBecDU(*zKG65zwmh7Vp+4sM--ceK zSmrCp2LJzO-fVH(WuYD!t+{pU5LYuAUf(|{3*+pw!y|LDus$yn;xMcc4C~SL?`ASJ zyHO8SgX>^^E9}EQyR)$!@?Wn z?;zvpbL}X+!X@wmbr*Wv^PjP8|6>8p!uIg4OKj>&j^I=vt1-oEBp@@15eGlyCJ!w1r zJ`ni$PpigV-5n@NFhf4ZRMx{FSqRYGZ zzZq6_BhE6!^x=CadX}tnL@S~L9r{+izrCXmai#?A=O61uy@rP7ziFYpuj>|H(CI?b zuJWn6*E*2}%`V<^EO1V{*_pL)M<2TTY0hRA`1a58yuT8`UFgWT?NM#Gk0Ek_LGj~4 zACjB!_wT~zsUu}}To!`H z)?*?ko(7E{??PAB(rTpr=tKstwEkNw;oNZR?^w&>HndwRdUtwD6Jne@#O^Xtk8XTh zN;ognhz0^3MRk94ph0${#x*-SP?2)}udKgKNI;%e)ReXfRlGQ?_;a=e{c_r_5<1z5 z-dUV?c~k}e<9n8U>&M+z^toMN@eWld`aAu-=H#s|%y}h_!7M$e_Y=L|#{-Q1UEVCQc?~~cP33y|k zzmd2g@I|rW9l0tyVSb+0OT9-2)=&11t35M?{!3;>oDSNvvVNS4B=9(nb2itapdVl^ z{B?H!1K^3OhED>aUHn!HjP&FK-t)0zT?6QgZ-#GUfc|g8HZ3zLU*O4mv`{|q$w``S z&p_yJ9XU48ss#oABJlJGLClIA0#~iCIIrFw^^gI1bO%?+9Oy|JUKwn{tT;`Y)-- zC!6@eE?wn^*lFOCw`@NBy#)PUm9fn78qkY*TBhQ0K|X+Q3a<-n;7dJS1^uWAeN4VR z$d|4k*t!CGS$FaDVvrlwW|4a)!oys}`ypJ{!tp(hXImR5-!_m#-e>jU^{23V9zh0x z3k{sdu^)C_8(!@Inc0x%F&=*>Rn{EG?@BH3VyVDTRrrp~Lzo%fi+a8Z|Oq2AlFdyuD zQq_pVLqq<0@Bwad(1IJ$VB8W}*NfvZ@H8OjWzCk>mEdvvOxV^1>_^7zk0Pw6t4wdl zNz>c_YcXQq6D?d|D6Y3B44cjT11APO`UX z7{8{U@U|vj_^cVoMv_8=AD#(~A?tQDzglRq|4|XznphtY;LnTk@MSf!4rjLr*LQ#% z_ye~404vRP3BK9(hw#;Oi#j5YC2*5;j30nyLa@7v|BePYNj|^=^O#2zd(OR7BwXkX z0O&1Y^$}y*JBSXjDjJSg177$_v0sGMQ7k*X1ps_2LXml>fKG!fy2Fs5;1-I$Vv3^A zen*if%PIa8bpZ_p`}YEGh@W50u8Ltfe*HYW5Zdd`Rl+B|uIq>6d}ZL`C+m|muF~W= zJ-@RMG1Su_%K2|y348$@oTH&vAmL>p0mQE3KcIOKZfS2q&??akQV8ut>Kf5U+@U3C zpk_vpRhZ%*!zVZ5kNPH{yO+*_IjpUF%Q>K?d-z5*3PM~q!KVI+TRh+CkN^c_h3KrE-Bq1 z>AFh07PnW07c2@&fXfVWhj2bcKGUYh`E%{l19faK9mzn#HyAm5-~hS#Hyn2d^ew9G z#HcL7NAkhkwz3`b_QdQ<7cjrJ^@^7^g8r5Zb~dlV{QIiKH`dS4k5_~+U#JD1@MHJw zFPC(oKXcqSkN0Oy);{(21hnK8)UAbnQ}V+*_i*U99l0h-VqyI0d@`Kp2=Uf=Ey~LQ zN~X{ROn`l7Rs2zEh+juOgYF98jI5*(_A{*LP65uJhL`E^;cGazasN$)HrR7+cxUYl za;D7M6}+!}qxu=#G!Og2is^i6fPe2IxQGSvW9L@7X~<^=>8z!g1!(8dYHc!b??La? z$V=P6zlGwofiDWZ$j8pQw+_akHK%u-@`Z8J%v$qwuRQSZr8^ImVZ2*B(w4Ih^aiEF zHI6%a(S5`7-WOo~x4(XE!&P_>|C$i-4KQAEn`rz>g>{|ug`HG-@c(tO_~ko^Fb;P8 zx_qqx^6hY`{ohdVf3fhH$Q6ixuFs<+9>(F54DUTLpZ{sry*LeiiJqe2qyhWO`!8?* z3Hg_|@1r!MI*d0@G$uH%ccU=QNAD#BI?(XsrqpDsb~JP1koM>USf@VN^7`ktZuF^( znw49z7xn4qU6(5AMy~Jr`yK~$BIlJct%^?IO)H|EV%puP?#wmUyK7-Scyr0k$_D!1 z8$$Wfkd9#{wKtWpKWn#SyIL&`_gbh4-q-`{P*T5nqdDnd9=W7Ea2M9+WbXw&k^mm^ zvD|G)4#xQuAKM?5FfU@@yf2Q|a}IIyM=QcS$gQARAQALwUH7vxZDAaWl--dI{Qqyy zLRtE@UZhtLzuDcQ4`p6s=hc$vN6Gc852&>JQSq8-b1^tK^g&HxG9J#Wtz7R*T{zK; zJ})h^CdeyMKwPS5Y2ZE*gJd!i_E72dnU{D44+AC#-%NR@Ck z%;SRkWsr1^T*Bv|W%8R|LH$2oIbR_Ne!7)Jto2LlN4uhrpPw8OLy{uf&)5|svi3w+u3u%Qp7Z#!_M;#429WKuM@dEJYcOdmX1 zfO+KAT^~12eFa{Y={dZMsu$&N)h=IK1pXxi+H(Q#WOSJ59ESGvqg&pL8~7aUd6k&w zz|XqOwtvtEzb=kmrpkwOd{{i=e;)J{I9_RYKRGq4|@*x9H~1NPIQaco8~uQ(rD`G%?sP43=8d$Xw*J=im`d=$#9 z=*HV|YJd3OVM$e8G5r6LX?67E3o58L`YQ9cyIy~R5&pNI<9iP{-iBGMhx9N$_)j)`dly2QM;-b$b)n{vTPZ3! zu%9g-ZT!**o_}=3q3Sm9y^SB_D`0)sF5Yr(^(_29(5HH|70UIi3eUm?1K?@rR&?({ zKakpJ!G8k$qPEUD{}Jjsme0&KK{>> zyYnDDbL+N$S$zuU*X1+hPC>n+>Z?9}5&Q_9jS-s!yBwXDLH&T+bOyIPhxhSsJYS0M zscu*meVYvLJ7hZjK^xwuk<-lD0rB6SNZ2$7{&Z#7U%}%iYu^Q}&+r`UYo1rMU@tf* z?T+`kLyVLxm%>t{(B{rMSBmF*V`mP1zYfgw$4NW?++R=-h7VNp`C1N^gn~l zew3?R4EkxoGKGlEAUB*J&BgJIx!yUs9ndzZUTOuxD}Hj3b7OtRbTh#aPCa5@uMPmKkGcQvxFED0lt;Fkp%O@8O;{Cnbs-`0NK8%;YcvNsc>V&*n#k|}w z;$0gaf2z$2G*>~-d(V#^ufr|m^_bxCE5tA$1oLjCF4Jy2KF{dHy*~-)PxpxIb57s& zOUC^7)bdm^9w8)^B0a!y0Uf<`?1t*=83~O&$jtuyQ0>`?^t%a zuOEQ@R>|NH!tqi4&}+c@iz6-;SZ{17rHFCQd~_NPZ+}=#_KU@?oKwQ#RIzP@Uw=4g z4MYj@&FKX&VWcbq(bJe7s; z(&eDv`ETbb zy#J*0IPvpFg$Ln#N}lFKZ}H|n;iZ4GUJ<_gd2TJ?ry89{2=DzNR!sD5;m?U))eWXS z@SaV9pNVXp`jE^=?)l3TbUWuo^kz{MUaTxLLhL3FQuw|Vur>VrYxp+;#=}DtejHlL zLgc@}01!S)OF=;k3buz+@MI{s5Bilg6nUF21>ez7(B?S>pNqpZ0qm+^R)oC1JIB>C3S z6DNtEi~Rx9KfnUPV+1P?LGgfmP5nQDTkeJu`+Xsld}+nkdVrooSc+i4O-jBvl;lw2 zKS8nklTX357T96fCo6>N1n4Dvi{OU!l<>p<@-1%_fVA@i^u8$6&SVE$=+ zoA`M}W`w-wUcU;FY1}eNI@5MuI)UxJQd9CRzx4~zPu+?k_8|p<*NB;?KCqiKfWIklVf&H<6|D4P}w3bsz`ub#FLV@A+ zpl{^<_JgCFJMjBinog1YzFe0a!wT}G`bvWd;5zCd2E0EuPbX-47RHV1=|2N-x>#I% zAtRt4yZCSx@6T<$OS5<#FkX}H(rrLrel}>Z&<{`8Ld}8oqOal^SnlI2^~dw5pI5fL z#r<+u{@f27o-sE?&MkSaXn0_IPepDn+;7U9-=E74*s{9uEDom;T7ZIq_4ehAa6E2U zOw>Kb^SJ~3hvsm6RVgJOs2rtqryT$-GKkF@m&%e5! z-*2}c#?`qI{Z)RD_y2it29K{)ucF@K@v8Lhf7*CFRqtRi?tySqr|-4QV1Hm}9zNX! zy#C?4$9S9^EvPTRejh!d^<*93rXX6?T<~k%u0ug|Fi)tK^4ob2cp2Tt^~v;b&QIA@ zbg>is+MUDOpZE~gRhp`%?*U(nnfYn{P!`IE_K@@+c;D~g`QGm^pE_IUEq?*@rY13W zo4+44)f(!lK{C1?jqU>>0ffyzjKv&5Abg!)n*JAXD&z zn@%GNf49bSOSG9BAkAaD`Cp(nYMiR#fc)7%IT$?x{tf2IMacpl^fp$<{Dhj8)oeRF zAO55%{4Lm@*}Gv3uM2QnZfCE7d1yjpwBj)E$=~*M)}MhV@?1T%xB~q2`*%sJ`{2i) zi&o7D{1o5NPO~1~o4aFtH#@|)Ib8SS9!Qt&HSwDrpwAcR*A9p9i|-~fHbMAj`aco2 zfK%Kyl4l`2E1z~2w?omD)t^n^AKU#e>G&L{(4Zn8-rwU{-xH_>{?b+CpU(nx3Hg~5 z1NN^}`7dDJXqtB+&j|1uM}WEtV8YaeUlo9hHK*usIgd0kHqya)23M5q_F4(rM@4pt z3A}e?L*I4=;I9FjM`HLu7F}LoJ_Pw6V7uYD9K7ehlENNMsDHzJy@s^V&H|tAbJha8 z&(0Ti)Pr9N1-x5dKt5bBbrETR_qj$ysVG9a{$8@8dJNCgK29>nyfK5@kD(TxtNgpu zmjl5007e-aa;`SNN{2IY0eF~iQ}y=n#cWs=ca#%pGpr|K<|NpA_BX{;5 z=w+_SFk=2cbtJi)3D7x(xxy1rqbft|HsIBA>MGpd{FQZt4+2B`+@B;M3s}C-lt~fr zTMDxm?qB)V8dTtMW!3z@W!#@8?#cXyd34yDUeUMkzOC=1q;Y?h5ayD71d!Lyt^n&F z?aNWd{jeA}ZB#1Qjg~29QGvXbrBfJ}+vWG4lJLBt{7l$5_M!+*BHYt9RNZG<4;UJ;W4EG#bg{WeSMsa$IIvFb;; zvA4v}9G`E5m&+(We1-K6KPu!g7M{l+euR2xzIqsAxqh_-#`LI7RM@ZHlx96F`!4}PKd5WQ?2Cg4#1krW;$um-MO1Nn@eG70bBq))JOijvOD zwmL*+eX^PO#oI}d?LP97@V+i^8=fD+*SP>nuNxzNNA2e%@)8$h6NDemr10eB&7cOE z%48cs#V*KJkgxm#04(B%WC5<(3p5o_4%2BsRcr=Ww~K?WimZd(gzz~GfIzYco&;8n(a!4yB{TevgVE?`XzZm%Ye?T(<(xwD)^9+C9738GLuw4PT??n{682DKRE;#5vm?-(?-$1Ev z2{kw)V1482b%M8kQTA_A$|-i)@)W=M>Tm|Y`0?pDK?(Plq<`4;4gL-e;j`Wiq+jS$ zIx&m;n@@hak1#GJQO?~@)hdF6(C-#dzQZK75te5_Ry(vn&KJ!uohN?kZxbW=(9@p| zISBQ<7d{^hc;l2QG%zSn*j2!IY#x>)09hY=Ao41jB<*llcn6tBd9F;7@BkrNg0V`J z`K7#$8;O51atC>S+aE!gDZ=;}Ji8zFTbz6TwBYe*VSv^O&o>7A7A$oDcO+20?Di3-2T(hL(_*nKgylWy73BGkG2X;Jcuha)-v@i+$b4u1 z%Edms9!1;x<=qazz4^S327t4Zrcs#Re^mF;(}8jPWaP-S0?4kmz58%FC$kG6Ltx)y zYt3Ulz+kU%6+Au~nwZ_i`keh=b+O)Sx-Jy^ZFKtaEFOQ=C#VuJpX%GPA3AOBBx$lq^!Y{T(Oe3!`F2IvsBdLO5E{lh-PI6&_H(UPrzZuY+q zV?Wu#$9CcLIZD3wWCT22ro@HwvFZh%EzZA4{Wv+yOK5iblkXxFm9Hz&1lcX+Kovir z?`qe6Ur0xNRpR+#@NaGV?BC;%j=KH#v(^IoIEfwZ20Ig3h2FEEXGQ6sEC7u^_4Z>P z#wtI$(FXL=Tt9^G1LleK>v#eNPyOgU3uvae{wwA+1IJX}ZwG967%7i2lfzSt9#Cvt zP5|?+8?Ag1*x%*=|7u*W1D;=EG0!sfd43r4jmDj|%(%WR4eZw90jy{i=D_O#EP3vd zxISH9+$+RzE%Gy8!EVRq^0_{~Eab8uL*mVVPf1 zfabTaty~3k(bylY0_Yf$&Whi6BCar&9ng2#UWglzs>D(kr^nS#W;4#eR!h7{`jVxT>xS!L_BrRB(tyvhrBC8>3Kv&$Ps#xDHFAuG-w&iEv@CBRkl&B>ULhBZaZ{e*fVkVbXoDCE0JjZ}#tgsa~ZY{L98VRk9A z4#L}W^-lZ-Otxcugww5hs2DDqh5ey3e-n5CIi?)HlY4D>38%-;`L4l#fWH?nv*UVHrl9JM(_`)|NA7!Rj}EBA`v1b==m_Av z^h;r^H+%DB6P}Mf3LUY*^3Rf0{XxLp4NJ-!0h68>te*uxd484lp8@&95f6Pwz@bgk z_i%kE-cxe|&+ncbdccR)rQ7GmKX z;5X%KxP2vC*h+MPpQ^c82XOjBkK|?G@<>qOirEc#x>%D6r`!0JP7=aDM}7_JX>xi5ope7l#Q9mRe&Yd=@U;oGdTA7EVk%TbQ)dnCr`F}4|h?!e_i z$63&b^=Fyua&Y*;`E_L6sw`|Ld{ZIG`91E>2g8o};rQ#a+5Tetb$P60+#TN%dJ#Xj z$(VAU*iL411h$vR$p(T5$eyzcwu=t=h$Z)-xH>?(^ww1 ze0mJyQP$fnI6SFHfEvpk3G2wXs@+2Q9-EP;Ck(`pk4(L!k@1=(@G8+yyH*nWSAC6bSl`k1N{-kIEtB!> zTkm$#Uq4)wCgWw~S~y+}c0<9>$hhQNVNJ$Uj|W3!oPG0}mBe?=q#FnhtUHR`A^Mc> zc|>oo7)Ii`J{U{no0U9d{=j8wKxA8=bfT{e3n4NC7c;?{eexuI{t;6oels6TNTHnX zZY0Rqx}G5CWfqdofxVRd2~Cqe68a!3$ zdkeA`!X1};3GN+&YzA3;FH{e}**z3qegSd`%YqK@_c}no$6Q1)w z>p(XB1KSjUORpiD0e6PLV}NeB7y$3aV1f+&Kmsd4`tKC}mtjt^WBM1*HFXM~F**SB z0_-jEb>e__>nZVs+d#I1>^DJq&R+zw4`hjR6#XpDK9E_qP%s$NB#{4lP%x68^1L?# zMef3nf&S5X3SN+;_<3v>MW)$A!5&~o*skJVyn0v!8J7-5T&fs>WD#`y7q1HzA)Gu0 zX!TDfG#lgq>^>l7%@{Gu#YpHjp!q*}Ep{7ZGTi~hsmC%d4UD*SF!mD#w6}jUc?`n; z4-fte-~JCpweSz<_x}0YjOj4QhkPiQ^DiIZQYI2!fU^hmUC`PvI{ce|9nPo7K;9_f z|FHU>-_#^Q(C^}E2+#Rr01WzvFbEPk@L&9oa5Vyb;lJ=ZSOgiL=E6wK0NMZ9OPFJa zAb))E3nBfmI)Kq1Zm-99U>|fhfO}s805&F3^v9_v_E#iv0%6@v4d^Q1(s7C%&A)k3 zJPk!YNKdg(5u?=0LXz>YkNGd(v{Wf}qAw}&-+e-fH}hXS6VSWh_^bZq+bR}8W(Jmt zF?jnNLBX%A1g{-uAh`Tn1d0yEe+4xna}3iH+-Oy{B;3N7iC~T(#cwy24dlIoCX{+}(UeCKkCT=MqM<3n z`aZq4KKA>8@0z=K{GMdkJ%xFhecC;;uO0CO{>BUP`<8O(8em^E;Knm-pT(M3hU4kE z(nS0gE1{e(T#&s)#=&RP)PmT4Y+xVRw~4W$tRvmqqfOFRS>Xa*1dQvSFP_90CsN;n z(OKy^KgM8oK9X+_tyXqp`SY0q5l#E@S@ibM(C@o*(w4_$uOYeWj$t0rQ;c=u4H7fH&p5RxuCSo!m{2dCY`g?`a%= zu}2WJ4CwcTb_nBeCV|j{7*jSlox zig0^~kzuiHBgX!(TX-@4vWqy0?JMH460kpS_o)rA1IlinnBM_7aITyhmxs8=iVNn= z*(+L0m{(n=HQa{7Z+X0y#{L`=dsl$@TF2p{j~GpVhC@XH`zcm79Dhb`UJJ&StX~r?XVvz2b3l- z4jfSZi!oMQp9lL}$t2N^<;;10!hc-TRhIE{wPwb!vkv9D!SfqNy8Ff?J$2O8JF$Iz zU@RTZ=ea!&pYXiPwd!)sE*KJmk_@CfUuKjb5@oEJr- zj?1UuR%r>YZ<^oVlXc-vw-pBL7k^~5E=GgivN#-HtbZd(*G$m04E+2@wm7mL9X}R* z0_(@m{UY_=P=wtd>%ZvmkaqQ=`v7e0!~E{{_z4^y#6=-6PskfYn72)L-r zyR`$ak-p-;YIlOg^Z|l9PZ0v0wV^@CtD@H@(!tAiUb-rxbZ^#UYWD zx9A2LqUX5HN8a-_zk$Rv#I=hcUkemFJkLPYOx`nknx4q#?Vy{6a0NbZf@AeJh!`lwOSyHl~UII z+&AxdG5R3CL*sNpsW*GzlLH4``eq25qufOL-1TBWGjR}RR|*ZmlHEZsK+lv z2)>o3$U4w#;BeheXug1%3ozUP8jMhQb?Z9FHjpKtH^z7zXDgteC`E6NUk|d021UQ! z6|w{5;Ao2cbxfJaU9h`_!?&HKgv)wU_=8RnC7(q;K{4QXJSqOV)9BMU|;cz*@ z|B1f*oyL94(e-Mgzu=W%M7`8tq~nMW7s-iHA(_;U|^EHwWch+BF9!7ssWs4f7`Vg%y`cyY{Hu^XkG^yppU z^{Oc5JS5>L7llNw4F$bOtU~XOj#O|C7NEypj#Rd@WmdGWGc%UHQ&Ta1IysD!uN2Lx zbG?82w*>8^onQ!Z%|)BF`3?rfR3mXNpGS8_s?g5%wx^ox1;|GDnTE1R3bIic8mW1n zh=Sg!gn#*2fo|$em_Dt86Zf*?FErj4qPf{+zLH}ZsQH@p9$SZ0G)^UT=Iz;X6wf6FCB63SAF)yJsYu~Y)x9aU4X={kM6(nG!HSb_?J44W}%$w6xHbS zS;$dOLQ}pV5xxuJx90P=MD+L8a>{j%SBTxVerofRbfoIP#&h%OOtgOT%}$fT6f|*9 zu*=yt4Q&*)eE4htE~)hS@z^CJ9f>p@ttkGS4)>Joo9B3(j)ElhBv|)nAS3VOhIRw^ zo+HoXvgpGM^po?0h_P!r3amT2#kM#dHMkbkvlyl#^Op)HIhWGV-G{=9&)73icxYg3 z=eKmkKzp?;S1=1z{q`DToXSN0De_A*`!dm=^(?n+H8W6)aMHvqYX? za`dT4&)xa3iOhm7gU7fQH(ouSBZLl0uI(%n=@vHM# z22!|v#lnOx1BHd2(6>lR2Yx7J;@O;rLTP53@9?D|CgfLmD?S|wz4iz#>CQy@-h1Q} zn=_HDp3c+fkiWOz%O>pdPC=W>X7;!bCZq8*SAp-lU!l^>wVCaXDM*KZ{|!&$S17&g z#8kLKGO{!Hvm8B=fCkpPAHC%li_)7JsBHOT(1XSHAV-HJ6nEV))!Qr)d2M_eVSXqc z9iJ4jGNO$^e-ftD_BchMN$UGe4#egtJhM(UOYf;T-fubNSVW zwRtG1qv*Opc_y;dQOWIV%S8QGwRKCWv(Qw|^9qZCEF{CDyJJUcHp)HNm%Yw91=(gN zbzbR8L3eWY-}j1pg*H3T4csYsg`{bg@-5p^(2gNfMh3+gv{pJxMa1AG+JrjxpzsLv znx`qS-XQ`h|KVaBqAf91$q>R~41|WDwezwnf-rt2;t=XM+|) z{;LofvOHk@B^L?ZF4(2CFCS@TY-qRv-*M21Klw`2s~n|jN@RXuuS5(R+FC^tvXPPE z8=->%ImpjO+bjD?K6*KR@@Sz`3EKEzouo=xIbv&)(rWEVf$zb%d}^ymMGLn48wa;% zq4o7^I-1(@kk0uIxnHzJ=+j|U&NkW?DBXqb>3`l~Natg)Z>@I>GB|m|y!=TD68_5( zc0e-|zC%|@i;|>J(G>rKM^tjCnLT01#MKcAR~NbEl!l-}S>+Rx4l&67WJ{d~^oMo* zKUveVD$(1C{T**MS0iSYeK+sHy+vEDN2MiX)}b5Q-V3TnmBYDF!53aTDv?0$o%YhO zDpa-W6ytQmUz1jC8fi9qL2NkXy__$>mE`sPCcu z>Dp5@=&N19Rj~`1C{`zdWvv9`eL2c&;ujaoszc|Vp8B9a+<^SP9FTJh zX+f`C|13Vg(T@5uH`#fZb)dg4-8~Q1)xmd=)Kyiy8&K_oX{)gpEhtUUr#bm!J2F1U z8K`!k6MfIk`|QRJ-*J5w%oHY7k6tKC-~OZAg0|%--=47VK$Ut82K(#beyw{srGj~t zh>EouCB3Ub!n50WWi^^nR@sfhv&+B>9L0MxRJ#yAH|>*wGv%nvI+{NIcr|kKWHJtP zY(kxtd-yE*uD*-Z)^vcY2dpgcOU&%cn!{_)$xc9+A{Q`w-!9*dF6wM zE9l@U$InAZXDaQ_RmVQ$u~EuZv%3#f9pUt!+tQD=f4?e&e!#s1Vi#_;clIIuHw?G; zasf}dB6p(3p&y-3J~&@7)Q={=CpuHN^`m~Kt7q6!`q9r9pBber1`v%Pb!Y0w0W{mI z{NktgAUdCR*?y>J5Iy_-!Cm^@Agb;%Y(Kg%h}y2!SJ=l6A!?d~A!=E}NY^gYYQ%N~ zJ&Ak~!`M86@`wDt1c9Fpf;1)7 zkfg9x!YvV}VcwV4=ejG^#3k~e68Alni>@(YA#?kcwbBlQWeq?7ov9K)Kj~y0Dwu1z0zBP<-tV_tXa8%Zoe#_t|qtnP16a>PKr2 zf8g6P(1*N*ugm6c??Y2@U-(|F?L{58SvmXcVE%bIpK<@XA!yH@o_pK|(TRiaP1Mg0 zAe~vRO@sY?XpdWB{k7g+WMUR`T1a68HJBaZ&3rP9_=_s&o^BjMk{^Qx6}biwSG_^X z{Y`Msojto+MjZTaZslF@wYE;Q+sa0hzOfbVDQh%M+}DJ3&)joUpKnB;uLhWRi^Bid zX6D?jfgj&gny_Jh(}t*yYiYVnG$Fo~W}`{#X5_)A7Lert>202@tvBpO%m$}F^~iQ2 zF+ur=<3%mV{ob2jBfd>YsCe5<$D3Y6#rNk^Z7S@yAHQ4Z3*Ti-y1BA3R=o|;ayVb0 zd)SOxW)0L&{OvE0fmJhbB>s+ zMQOXecDsjGA=|O7=A8Q~k)48}tg60W> z>Vh)lq5b{$bZRq7i%<8ChWp=YU(xJMkg7raE!@xP^~z8$^TFqnmx_>V<|FDaea-0h z?C+aRs*OlGRwOV1<_WI<$rua^7o&h*29Hh7!TrI$=NEmVD^Z8{dUfTkmFSj6l@!mK zGL-R^ZNqt`68O&gHSvD$a%8@{qNx5^1saSmOmFHhM;kZL%e?I_K`DprYENqvqum1* zu6vJ_AOrb^_yLbH#C3PQXL&<0%6@dS@vvqAl6rgjIsZ^DGT#1XK7}q9W%eixN^lh+ zvnJ*7%OUx&|NKcJ;Y}9e)0Od8txZGqHPnx<1-?Qjzt1!L5Y9s-nPQ_puGwh%PJXxT z*ei6kMCe}jtCz@mt33;KSSUKa-S?tYH%tq0cMxUQ-&P2U?uhR7SWTG!qZ>uUY zbI{JblR?yj*+^F?$(E)Kz6)`1*)Z8Z8^M7{k)`=8^!BF}Z9aDj%8lgGtO!m)H8g9F zHPWS_p{d?Vs%z=!@smLhJJodbL%~tW&hZ7>WS1kbZ!rpeH{#lE9T$nNo2Xg$p>Wjc zbV_E(=q37~k35{XJ%2Zk2P2U#h0ywUvFJFf*EtdRKE2X;!M+N|ICMo{H?rLw z^36P(?TADMGOmAFP+yjf?$8P8J?70smt1B%IM1b{+EW``+lI4X-8s8>CNu|)aL-m9 zgn5|THgT3x^)$rzDZocdEgfm~ogR9?o{m}=q-gF&ze033YBjX)B%{WDFJV!^6m+vR z+J;T+75Z>T_R_u+FVTxr0gohyqtTnOhJxDVIMnX=e9(z69&L`h@~6Bq0adZ(#XdKQ zLkfqVU*zGBL-UI%+!`}+=Pyt=4*C?2`0e(FE>=MPe7SkAP7UTMjPo`jqj^xeT-^MMgfuHv#?^5_CM>A_)z0rRDNHkLOVmG9Q98*`JV>swfhPmKl8gNy^j`+jsOvq-Se$_*rYkP&=FdcL zggU=_d8MJ@yD3?(VSagT>EhmED9<*>MjkqvER-C_=|d}=fp!;0jtX*QBJY;JEe6f$ zNUpw5PsJ_?t%;8=u(C-;D$IdVHkPS~p5}AwHGwoV>&aKeaWfNf@E|IW*<7T2`f}Um z9eK#+d*vIoU6H76kMoBMH<9UyoP^zKH zx2ukQ-M{V=eLC)$B}_5`(u(7}Fzt1^v1+tCes;r{{~fwZzV)3(sRX_7ZbjcAx&+NK zF0GnUdV}6b^8TIl>=@6veB9xaJHAisCGv@m8nl4TML0<9EoyBqK|;w;iQ3J-?Iz=| zMoV+D1)AonQ5QE+$}RpH)a%jt?a;CJsQ><-Vzwm=Elta6D6nWmcgm%ICyzFx??c`i z%JJ2p78FXkos@N`_@zwMk7~#JfcVDHhnYyJb~pMUmvh~Kr4l{AXPb1#>H~V&QcPZluL&)6;eKb6 z(}fEBpeI62hR}Nfg}2|Fc#BrKHRNs_<5TI|?LC3cIQrM8WXY|)9i{84P7;30@g;6fp_~gtq6A)pumN8hZ=ZPKz9L5n35o zhpUDM2-l8OXaywu2tuD-uYa4dYrM5oeq==7On{aayk(sYgxg|MUj9Zy1jojXNYQg8 zjcmVu>kCD^Z=7#?>w5e_2_y$ucRUAL8f~T>R4!Y5B#05a4b=oJHhQ-!oZimpC#DP6xVy!Lk_=5X}$Ub_DUpIp9D z-v=4WqXhrzK42TSY@R6Eiy*|@i*f7es+dFI&(-U6hKRS%%?rsv{+PY}mgQ-iDCAYZ zuVl?HwunPjm9sUY8n&Qvxy>tA5o4(1T>AGg4B;bJBpS-kL{=ZY{gcL?fVt>=GW{&^ z7~zjBTk;(Dz|1Vk#FqK9Fi{yJ*1GB;OoMzXcwqb?cHi^g(`(NoF}cxR`<%Y#$aQE! z89LRDfjr}f;^s{VldBX@f?W$Xc9pH@EMpzQQazzWdA1(QD|ud#6wQd}sVPEi z3yz)KDsW54CW9dnRQ((CYPVqn)9SBP_X+-m{N7#dz886jF||;Id#9WQoTBR3m0do_ z@!Z0xbMpvGcQK>q%K3#%sF@NoWp7}Hn5|-y!4J&Q2~z76YQS&ouV}tZEF$mKx;(^& zma(PVJS1{X8_4#yDtVXZEGE8tVrlHAB)Gu58-|~5LKMg9vJSXrkeEO@uekC}j4x)F zINkgRS>3rW`Oj7e-ngCcj?9S}UYRJp6Kz5aMBF*cJX8m;!Y1}A)@}~idePq6n^+UJ zh*9-dI@Dv1?oV@^Brd?z!}Pc9dJ=#m-K6BgCLLJZ*j~*w@&unZuI?wj)`OJ0C3HUj znSlp69*z{nw;>La%gRn#z^QEa(oNC`Al1|L#cSjQlvj0|y-uPABecZ1XlD`lv(k#c zYU=?w+&U#C-lh*Lt7C&qeq8~0VwuYY9}W;Im76u6aR*p@35sSX4~FuC-G>#I?!yD_ z$LZeoo{%WGoLG9@9o&hS-_a0{hd->>?Ng{z0rcKo(pAp`B+>3tZD)<(FD2Cl^AB-Q zMqIQeX2%!q6}~ZN{szJ03kgBDd~JaYEB$7U%R}H-R5IbE-~`uKMZq3_kTfAsmLyQCBaRVzu$(gs6pig^{11Mtl?RqINd_WVsQE)#Z=OACAd-) zBH?k61Fj`fsOe5U0erKGHO?yGz)Q#ff+0&i2wUmXdV19!-g0aZQ9kz)@(svTS1lJo zj_ryO{=zrVnx=Z1cJU|FlKQ!F;{7I^h^@I#B>ffg{$Q}>@G6Fk{1r#(_llvHC%tAc zOAw@8&3t6vs1He_T2a|YHXz^MOGm?^9qZu_UHMpI0k7Q1$maiH1(!=`!;t#{P)$m7 z&^O)|`b_HQmMiH2IzjQ4NGVwmaQ`z`-&i<^regiBF&6`P0=(Pirfz|=k%hrL&u>D; z92UMP2^Fxlh$NbFp2 zHr`hou-l4WA#JCDF7|!yT*eYG^a#P@rmg~^g%P3;E&6bN2q|TYP=T$o0vGE7gf@3b&fKYtr%%xKRZ2j7DP~TI6iqC@5bN_L`th_cNhJ{CP zU+#eMd7w932#3byu{S`SMi_P4H6!pXj-KMZD<5?6I-^(`kqBzNh5lfL&*5X5XVWs| zkub=@O1-$j2i)@)3^ww$0VfBDPj9@HfcNnf1}~l_EHE+0(1>{pA@<%$Jv3avvPeQC zQYqV!)~S=X8UL^Wk|qN_*YBi|CM1lk|K?ZhLXyZriQyD7sqmO8HeeLvV!Ou6sCW`y zGx^pXO6&RmX`jd+LB8+=qrSl<)2UMo1 z@sNkpKnvSh9Z%2Ch+X{Yo$Sl+kqREV|LAz4u)%pE%spCz<>g9|k`0}8-|Qmf9uG-=m3J`K zfiQKisy*=MW{Q*EAC22sRv%UCXrm1QWY>J6Sfz2HAB8<>t;%$68DM(16-pW3yg?#kkX1clQgXP+ZNX1|F!#Mg-uZ9M9gv+6i?o;J$?2(y{BfPJP`I_I< z%67;=sKj%w-PwDIN&L)+XYYE3xLQ5!$Q@NcmI%(f0zUj+&@wtFVsaS*#bA8{^ZACS$V*E%VOhszZWM20>}{&Kb)d>ga%`w zYnA-2!G(<{Hcn4I*G1^gslRhj6u}n6?^+EBQ6gVHZaupj!iyA?owYeR9gi)TgrNGm zwut+T=4EbU6fr&fwo6+;6B~(sh5BadA=z)ma}%;N zgbt3X+<#IG7*pk2R)>qt1gf-@2VIt*2__EiCxwYWHX0SbstPWyAiO9d=9eAiMyRb` zpDWZmfxQ^WUtO1MCgcg((VlYbC6o<6_2RRbX?*ouFx~!}Au`rGR=Q$%0^t%4qTZIG z$A$z_E1yN5L`cF*4D{%C8c)ZE$NJVcH0J#_untE?3GOjlrOzb08c(#gP4d!?5blXT z3upOT3H} zq1&axIF8Xrw&q~0qW~{kcQW8%5$ocUJ_{jrkgUCIox;L|}}%HxKz#Xr=RY*axdi?r~#ccz~RH6`^tcx<9re z%V7MqHX8ABkYK2HEyj{giMyT?4@WB0HamYshF~4f7fMXlBazNB`Q7BQWNccAfjfPEqv*&cyi zH@+oe4B=1Nx=uVt^vbUvo)c}s_SV~vqek}-^BnP0)r;jwh)vz=gcnJeYF~PK;1xH_ zrF^(+O|KWZWW?;zD>{YH*>3mQI5%NgT3OGz97_<*@+L|7)liIddPqpBWdw^cG9m9f z`wwG>wXAuL{YdD`AWr{RHCXlYZ-2Hf=V8GGoFAN?uOPmcbsx4^u>qH0>r>>5zmc*j zBr@_~7&Dske0`Ck4~x0}XTk9;130fkA9e!242qh_w7rCmkUtNsXnwxl!oIxc$_i^< zM_8o7wnVD-5mK@V(LL5nkYwBB{-YP9KrU$Pi}>pkF#KE1hmk;P@b$)QzfHutj zVp09lVB&FtdVdTXTvWX9?BKT;yxAO>Op>k!o1*qxcd|{vpS#Z)d}s9F*kd{?RkYN%T2TAlv_l0}JQ6!^NK#}o?@P3ao! z&p45n_kI+du((AeG5rRrzZg|NH?j$AgdN3A%qj3++9coPUmw9CYWgExh9bb8xHYsA z^%-`jsCGy*E&;74?WTE@pP}iSgr12rThLUbkQl$y4#gCg$#%|808P)PG|Gud*unxC z+OMp`yupp)ua)iK&$itQ72RGipA&GuxMdoC@?&aI@UI1#KeZ%fZyy0M0pot!%pc%x zeEC`o$q4Mmi=4ljwZO@2<=pLlax|$|*I=ja4BjI*A3@s1gg4HHJari%!=pC)4lXUT zp?+H5H^QFN_^0zP!$%Fy;6za$Z{-aAf;fGGY?sk5=%}%mOBXc&Q#{y? zbv6t%-h8d}@JuCiE%N?dm(>6m)JMvWPoqHFJE?M*s~_CsRtQ^czxW(b!^h0JH?;>+zHvRn}UZlBQ+7MIcxZQ5u1UwNnb`m@gU6g z6Q(vjUaE}7lpKiJ=SI08EUAJgW|7jFxFp%&y zzsm)$B`bH7kZ_nh=R5EGG9I?f(F^J)xq!}_NijFmZv%7c`}EZ{v0#^efRSw=4?G`Q z>zOI?07C^nWT_&w;I8s{c{1H%m?yo+7r62OsL%c*QRN5& z8J+Z+vmSadQnWQyVY(kA|JQsFI9&>8g4S2^;woUNS6X3W-BYMaG4pVgJ`A9FO3R$B zUjWfOCNku*4AOfaH{8Bb30~THwZ&kmyBYl~!Z-vFG_EVMVIda;QR|25VvMwrmO zVwgWcytB;AsBkfvYT#mMp&RQvUdb1?cMVAQk!ywP|PjL)24y77V?j`n@32{wxc ztmlN>Vvq;mWo>WM$t44b@K!!ISiJ~>PZGtjKa&8r2J{z8{ggnMB+Kq~mw3>+O@1_P zdJ}9%7#r&^*g}pGo{zCjSHQAq@y{WVub8wb-NEaXpBP2d?e{`u-I%P{g~FCcT}ZF+ zLc_aKWsI_TYkTdOXW`nf>p=KdkyY|d`T_k0Z1nE-Ws8DFEXiGeGTfpN2{>PJ^=<_- zB#S+0e>wgg`+Hu6fAZTWBq}$_#%GHW*ZV80yX`Pe;b%7Ja9bw4HTy@w_Ui+NpPt)~J8Z>Z~y#L>df|IOu2o}-2S zziANaPC8&VabL#Ku@W(N`|V=jP>p58Xyf&7pCA-O9Lyd{!AP{9UMoXQ3br@6U3>XT z4RR2sSCQ6Gg`CRbnF5v1u@wJs(s;U1B*VIw*70dHLYd)W|KZ6nCSw$zYIX4g_Ir$$ zGk2s6Q9`{^sq=F%zS$A0<&z=UpGpT)lIA_6Guy3dsjUX%jyCod{L+LG8+1qVTQwm& z=30k52Gv-I=np7_F$3RMP6AiA{vZdZ3Y~g(*06^B@@zlC1d@DRVo`0f6ZzDZw{6Rl zjfE(0z3Qh?K|E4BwA4PCAx=knz8~UEF*2Uii5yb{B%p6Ob7mk4IT5@mFp=wpJvftw zMaEu6q8FyCohOtL@fAkW@M$BgfA#R3bAtm`^>U*=AtDSZrL8-C=PImTV&tG#1ofjph|PtWBRM%rGm zu%}$%#MDFGs28jl5$lU5Yg|7MG(L0+Z@)!thE3c3X4b4?K^RusOW(aXg>ZUoZc5yv z#eRQO37hUEM>byvr}`UNB12UVV;i((uwm^>R|_+i8ykW>ZIC!xM8xbWi$p9FX4&zn zrHRWJ`Nxua*{{O_Q5H6gAw4CJ*-hTEm6GN}9`G+#SN#(~Jcg|`|0!o<7PmX;?f2Y~ zN3*fd6Z8S{N#R=AimEPlHG*{El)M3=@BYlZ@MwpintIm%e8FMk+b}zR4<~Zuyri$2 z;|D&BNG3$EAw~|F(AaBpiu~26`S>c@uy;TppJ~}@PbR_0-3i5&5v)j5ZGr3s0s}&V zmN}{icMx{V1FGgZb{Z9KC+S8j9TM7NM;qB+pTREP5A46naTPNWsB`?0%z~_4SMT8X zLWzZWsO(LN(IJ+abS?U-;uy)p5l7zb`v}2UvZvHr7^@#MNsgXWM2w`)(@5B>V(~v` zy5}C5BTA9W1Z71(WMPA~E8ENn*-pM?e8?h+T~tv!ku1fFsoGy0cxCL4gm<`{e;^Qw zusvZRxJc<@Usyi4QzRYZjUAt8)g)Qu4#W2(QxA8{c&OY}=R`I}JTe3izwjVG7s&)= zFDN75Ju54oB^hEroVIXPPJiSy=MDEQoor;RS^5(y=!wV&u*<4OIAco{%KS2}9*7sN zSzG1*1Uu25q;^Kb2}x2=Yhb=*iH-K3cydcF2)plem0w*Z5lMSvu5Kgp9;?`xXDSp#x%wn4Z>q;kPlvdpD9NMFm*JX%uViGB0psWd*m-?UUs;F~RHCuHt+5{$gAycc~LLKOuq^AHd+# zMPyj7@c>z6gG6!Vbrwbh_*L)o$!w(`h}6&B`Ex;&h$nM&8m-uW*xZCy<$@wFP}gYX zN_uex^wVwZzw~7UC%G56rb6go^3SFB!_2I}Z$ILyp%EMW=VUW*II0D~;1t!B&pfd2 z7nK7g6&GCX7Jd67K^`bsn>4ACTEl#|%(2w)Fc|MYoU_pkKulNKKrf9NG*Zy6o7~j{ zd71A>WoPfe?C59jtjvADq+4IM-&e!qeWCbDg}NcQ(Lg+3mSF*vSN~`p{;>r_t!#QX zCmi9?4gPx?8K&TLGX87)yD7X%&?lEuyah;n?|O04T0m}1a@|@!Tc|E(*;Az{0S*-^ z(wi3m)Cr|tn{9N8W+n0cg_8Nc9y0?^?Uo@gu~OoUypE+1L<5C z!Km-ob^9gg`|^EZNS*4w+$O->M_+h7LL4B|3FmhT<6dwa9Gv() zP!ETFO!(4Xhr;{2?t=_jE+DD(Zdi|v8JzNWqcTr$2QNp%>K%tvpdLeDbYP}8$XIHn zClPmmy?R;xda-xG8V|0dA>j!x{u}vy$|M`MoK@O+FO&yjMca&=d^ADDH=9&AoeP=1 zThWA=<$>Z4r)~}g41=v4gZl?@Ef7#!yvy?~0S#Y2uXn!9hXzkqs4J$%Ky>kXr9>R#D@qz6PP%V}-LCpujyOHs?%AB8piSP3%N(EB<16$_Ch~h5nlc8HYmGcE^Wz|n! zTpb5yJ8jg4^ZW3r=5`m~6C!kIr{MTEOOK|8S{VMx{|b7X7G+!?twAZ70F3}@Qgnq; zm|d3fm@hBelUW!%j~j~VX`R;k0{(H=z3iYRLjP@f%?Z(xtx6;nL_qiVn*brzBdeMMbBldkR;krBXQIcLwjjekOVbA)pT)T&ig3sf( zi_+uj=rWtYDy_5|zH{-$>7Ak*=qH?>zsB1c%~v~*4;WFPnaqat!@>Nhnyh3fsoNoV zG0inun=}tD<;n$h6ByABMor5;UMbZ7ttIPwAz_r)m63syiXDA@y@BC! zKXV-Mj#2C$zb{<@qe`F0iukvrCyw2Q5_qx+Wr)u{9nKc#SzlAS1PYU`(JoPm;ck`F zp{G`8&_Lp1N?HX;lwriTB8uV?8dCx^5;Qqco){O~g6q!chF$=VfxRm_nnQ1|lV^(N zUHRru+D?oDUEv(^6={@*e@pe=D+Y9yhB74e7aclix5DNBdkO!t4mB3|Srm2ZxDo#57ZF;{ z=#yF>auzR{7yOiD^$%8AeB~NClt%fC6uTeHsH2isxC$QGE1+NAPcFg6^Z4-7hYVaP z;&{5##?G{FK0JGc$;2aM4yZsGqq)&G;4>}hIu_pu??3<7fyo3xF~b_w{{5e@Wc0_U zg3uXgeL6;f#<&ff_O1y0&#o4HZkb4T&wc?5zFr9US#kjEb!+H|kKHbnM}ArQj^oh% zp=RvrQVCRks~{+1_ZARvMkiaxec1Vf>NdT{KcLlVnro`O2_z4P50Lm?*!HQUPi3bQ zdL4K^3|zc~SEaaTWwx{8`6*#zyrPt-^kvKZoRT%r{$9L-cjhx>CZ<&$3k!q2%iZgt zl21U>JhSI=hXbHi?x1!ru!Kt-3>X))IwZ?6iR|Sqf@e;{Uj&+YGXIhTl0g6tg`*GqqAW@oOOeEwXte*1}ds!(2HF{hY_@}Rf z1?uQX3+HagoYSrp)=~_U=`JQQQlWB8~M@(pPy6&Q@K9rKJ9Gax7>a0 zk#l^|k#SC;uY?RZ{~L-@`R_9PFkE_&7OMo8^Z3FC+*pCgry${jEP8Oxh+iPZnj3ap zE&cD5k`~|(mOR}ttO0C-zQ>F` zRrsa6Fbn=?1lWJh%AWsE9Uk39i5^g1hOEN%NvjXCpb9UeMxs*^T>HwGuy61X%x1q- zUEh_2WDB!vsgy2Ix*zAVQey*@iXdz%<`gJUYp3DY-@z1$X$EoHNyOxdN*Ra!Jo4IM z!Q0w*_4reX+*BV!LM}B&Ax?eB z_($Kl0<9`+|Jjmv!eScYrrPqvl`0$2k~zFM(zS&RQT}7e^ZATbvZ407l1&I*v;AM$ zdzIKbXwn=1G6K6V`&A&}934Z@Yhk8VK)q7%@fcVg8n~X}j<{;x_CdTj*JiaGf>vVM#8TSL)qT=lUmwA$M`9>0+(GoO z#Lb+|>BbxvBy+@nr)Aoxd80>fty%tkAvGgd7Q%N{uVG%cKmsGiiKiR^2}L`yl0Tr0n0 z!IK^trtQg?w6e9#qIx>wm3JX~ujd7}r}uhwt*Q=LoPFkzmlq+MHz*3s z{a<3cMuR<3%_Rt|XMaMzS&a>($2ICqj$!}Aq&DlC>JaaRbsoW%8f<6eB;|L!3E`v? zB3PTxVUKy~#6O**0CmFe;bnhzm@y1HE)czB?p;ObUjj}Wlqr`uxj6@yNxw9iunJt52L_13ml30U&3HeP~C z3?kv0FLGp5!PdpeS7hzCq089gA+pA3c->Z|RXs@ts$b}_IQWJFf?4d(Y1eB|4SipQ z05fpu`&|4T@-V>umHmgwHGLpH<(77duo8-Pn1XYAhiN<(QG2JJxJN3j0x zYYJX{BfwnHvr*`01ViI)4@~Xc1`b6(f*5@x;V)gS_2Sfcz;IM#rDWREoS4Q2xm*{T=v;V+@CJ5LA| z-)ms8=i?uB0RwN&jgVu)A>ak}@E1$^Q&{Cxil(PVg0%FIhn|`d0FL?C#Tj(N8%gy3 zEE>@u5ogPtD+`8KOJxpYf)c?7eQu2j(|f4RzC2vj`2}1(IzwOKo(yXct;XSl60n*) zXDq#13+v+iUT)Wa0>N(>jvO2&z&p2f`**KCfZ-;hBlSClu#QxP%?-8!GIK1FbN}YvP=*;aN(d zv$q|;Kojbm;9S{F5XtW}L!&~0{-<~|iiG1gc(i*_v+u!Q_=>%2{%R6AYH^U{^f8?b z-^U)Ze7Pxt@@jQfowQ^?DRxrRSKF9znZwZ(?l1hPKw8|tUQs#RZM-&O#YhNOd@{Db zz|M#tO^=x#h)|#vY&1_BdoJNmLgKnL1;kL0#8Fe z8{?i$k4cs5uc8*E>pigr3aIYg-Fvr;Wbo`|$I;K~*YT3sHR8LR=BVoP+~S#-hbSdt z@atmM1-vCx<@5O{eVnymwabX0fd>9)PS%|WK`V(;&JyvvEKs~<2?>^~1T!#N3H{6$cG2#UE@m@pyyBuH)Yk zd?7^UPHjjcu4_%59krT(8$5AbQ)TkQ;~QNV0&)#diP$G{GR0=-?0GJ|ZoC-3t#FZZ z@JucqXu%!k=jwwSN=nFDhDM=|>`P0RE~TJvB(V4QSgUaE^rh^p7hd3Zg0b!lv!|#u zJ!4H*PCi;NM-h>2m50vAHLMm~Jdg6=I}#JmWsZHnU3LKzf+)I@^VsSI8}3O+J8ZEL zz;~i^&VQ?y!x=MEny(V6vb$a@nvsO|poZ5%k^)d# z8DSZsObz^-n<%%uhABR!SzdCtGzXpcH|M|0^#Ucc%K1C`CKV0N)$^(9wLujgX8Cwl z+v2av&F|W`3gZ=-f2=x!nQ?F4dzxqKw!z@O!~AdMMSx{L{W_^>4>%Lo3Gcn$RzQa+U#;1W>NmDW25cET&et_cgGkx@&b$ait{?>n)>XG@2G z^4%r&|BU~_KZGTLJ(5BAQgDxv)zktfySFBqbxsj~wrjKV9$r9IAH_MC#dboP?1!Hi z#a02mh_u1F^c`GQ=x)I0Qe!-pexb-`ml^-sxawJ9w+x;9L#5`Jw!xiL*KYqSGoY=E z+S%@UGaOMJqPz8~7UH$;11DK)!6mvc9u{oRU<@6Z$Jl;182n;n7kYXS5Y3q<-HXnJ z6vG`B90w&ZNxg0QUt}qGHIa3n!M7XcF&YKhNRPn4O`@dUcpQvIMIxRL^1*OVP+Zk{ z3|i_?_eZ4c0$EL%a#m*+q!M3qK^tb_n}fH_E?m7pnCQ3dP~re!wtV%La(^47&$0i< zAj6Du_r07`aoK^jLnBJ|m%l-kP10~G=D&a&h)47O%z>^%9`CA^^I&dYAyay55bzS4 zc^>vj7HSa&0!sV5A>A{t;iScCFd+DH;!}PKXxO82^p=W%6?@@g+HX9;x8Rr%?=@HO zFXvnEihV209NwrH_m6^KsFh+aSSJB}+pUs6oDuNTVn|l@pbNBXY-qg`Kb03zpo-g^vnLkXQ; zemjn4P&&rYs`}9nlJ6q{*A#tW`P}>WkpDw_9J+j(>Xd{f-jxB?()lphFfupN^(9na5vhK|_XN1RJW*r&p$9YUiL(06d&6hZ zM@F)D<$>}}n`Dv0F<(0U`-+MsF+9D*yLZQQ2NCwkT4qw}z#a&he5KS>f@YB~@8%iK zV=GSP+vjW_#(^}4{pna@P3Z2 zSbEAEA=RrjNYOdBM5Cv9*r24+`1FqqEG{mN&5`{NlEa_n!k}1$5kwKL!c-QgXUpWiVXW)xlYuEgqZ-L2=TZAIQFewmMq=)y`OgtGTbObj!<Z_F;&r_({FN@D?mEKQn+qtq1XY zq)GjbZyEbwV<~f9>IZWE6G>dmqe|?z{FH^yYAI5DKvrV@BLSPEAS{^uTgFOmyh~o& z6aao)%ITE~Gl;Y8#u@n^ZCEbikj72!i9jMpl%nV#qSQRcX__;R4bj(1Kg;@uj197n zFCXq>ndhJGZ%C5?nKW+Ec^V!#V@We^(=G{mQi8UGGs%GLvQ6Qp@Ge%8cBbW2#(zk_ zY@VI;^f@T4#^TKxV+5`t0cyPgB;Y}n?j8o05mL-IAlHu+>XmO<8>1q?Ql`uinQ&s z0LXnZE=GRR7Id_))MnLY!xIc^)J|lz!1Byju`?2pz_o&Vr;pzb3Ja3%cP@Ftg9TCD zGaTiBD^KSEC7}si5B<66Vz`%0m+;@ERDKvR%mf*a{6si5drU2H{z) zeK4bd|PPbq2PB?=E|TDz;x%grRjrqNI1*n{1B zVvS-aEVjK8pLcHoRR65o5E1zWr+Tzb*VX?39Swjf+fNW(0pWEe$xX0dIaAB|&mu_Z zP1+f{^ABnVT_j?N;79G=UNx-UUWZ+A&SGVbC(%ubuX42ur|?p{;I%addNhT?*?rKS z74_#8n%?YF#%b#>@rDC#RD|U)HR}ltz}xMjr!3(_ELLfgpXAP^T#ROMSXGuf~i6xaDD}?N$K*NIPHCb z*)NppxT;+Or{J6*x}SH`vhvUf9Va%B4Q=&Ah15HBb_auTtT-wsMd>CUWF^FLB}ofS zDSAZG8G0Q(avKVrme#;;SdU2yeTfUx%}m_;*oH^lDA(zKgX4C} zg>>(?(r~dWGoiHoMd*tsPwbwZ!SJ%5+ID5@4fxM9?A_WEI8NClh(x@|K(_(^ULbKE zs#vK8ThLgrPjSzi@cWEj5#&eU+`Dz*J`{(PqqW3RRYm>9d zxoctQphE2A-AkJ2l^0a`#y%K&f&Fn5cSt=dU#_HmN%Jjw?duYi$nFa?R`*$fKyVzI zH?tA!Fs?fJrnCih8gVa8y$R7egH z>kd@=$c5CLv<0SZ zLrVN||H2*12W}s!egoPL>QZVYbyT%2D#zxPIo{}U+V@^D6Y71VNH(LN7wufWc_nla z;5gH|DxG^gO2(o{xe$B}jlDMZLy-6u4kE(NA>_tr+umI!(NQJTPk}%A&W}QrS|EME z>u)T&&ON|IIpcv(EhvUX4>m#ijFhXHy|>Zt0@PH*&E;t5spBB2;~XCvIS66u1*EQKKc%GG z0k$v8!W67j@e<0XpYAj=;8mInP31Mr=+VE;Ie~Uc{7T}ZsQ$ifc;88DL%>1>rFXj4 z=YJF6F@EB^OSa^=hSSkL<@xhyR=f$tWE>+N5uPo4GuHv-WeFCYDMrzx-9M}LA5pyb z&t3m#vjQmPhm%T%cX*Ebl&EPmmu=C~N9weL{Wd6>qm)i}oig54drE(mix2;_`?r3M z2|-WG+9S``Bk-|mpp8XufkW#DCnt#$;G>i&ksR}M zAfL+`m&d&UM{9nocb2t74q8s10JHbNwy~zBJgN}(MaTVgx^D-~FNgnRUu=MHeP@00 zXJ=u`HQ8BO{b~>(?pgn$DhZUG=&jK{s)1j;M7NT4&EfQ~<0%-)8=xU6vzK(51!i=g zzF@q^0K4^+Oo)Dnf{d^x<_O0}FzdzVcG`PRFlyxWPLthrP=~jExSAjXd!@_!CZ#Vy z%FwucPb?eM#Z-E0co>1{Ke`L1^;WR%N9wbENh9#=%*+lZrv|4IYc@$Dp8#(CG!EKp z;egpNG2+pwTkvkYRdHU;Wk8+JZ0qEG15|Tsh-g;6gFd==l|%M@KsxPEld9wi{@JB7 z7tp&wtMGIe`iFPGkj9*H(}E}nyDE4#PJSKxP0^q9XnPLZ{~#ihA~%mHkXn7XVlalK z$NUH)9pZ)q#J2=?zHtJjXGh8cncp#KfK3w_^$x!s^B6tN>bY$D79^lOQ$EHz z5mB>^a^@$0kI_ti991#;hVZvbUs@t&2JKIpB`Mnb5TgvPSBvqJ*rO1#uxyW6q=4+P z8S(zHIishiYE+OOO8lZxe|5PZQ5$Q{h@jiTraHH4{cZmt)jtJ&hXD%=NGvWAt|fxA zvWVE%yk^ADyQXC2`Z^Y(dDShd-~chuy*Q|?$pu@g<Ik6qY?WNq|L1(si%eOo7Ax(gpdnXmE9SqX_F)1rOSMSKr+^ z!rG77eDU*_VXL6C&AB=UfabrI2&8!kuKhkyqEh4r@{0DZ$|>E4iN^L!wcZbaN$}W< zW#2IPTF8?5TtXh)vYQN_Dt88M!qu|xbR^-`m`FE&VLdqW!_9Ls!35l^A#d9stOmPp zD^_`DLjVbzbKb)KL%6h=KlA#h8~9w)x%ogc5in`o?@p_H1xr4X%B@~b1jcf60e?=V z!0&A3EO(FRNye;CRj>tAL6%W8zL=>O7H@dT$NkUHdB;=z#bG=vGg+09J&NoV;v9Sa zY)MvDvWl#b1{p28Y-R84%{|AeD1-)5*(rM`O27N}{l4x$_rAX8IiJt-yr0HI;3OKs zVyKdi#&#zdZAXhhpM+7+-ug?_b?&_id43r3*wT2+b|nOC8P>H+^Jarq)#1HD-V*ew zTJOA!2Jt@ZB9~ygO9mY_5BJDQ$pj{3)xSgm$5g5HZ${ zOjdaE;{KAtDG{vp{T|00hY}=rR^fag_aRU9MGnvxSrc)4N1)W8LKJgCC&{$ z)*nf}2%p|KbV&$1Vy*#8XO%Jt12@aISV`1z!@-~YbF6w$t&33h?ujD)z(b;7b3Yot zr}Ni~4>N_s(yHz6lI-!R6(xbXFmEWQWxUzE5Q*((JwDh^#^Rs*?7FJ;;+TKty793x z2N-6V>S1->1Ao7^Z)J7d1#;JUQS=1n!47HB)!PQUvy!L zXJ(Q4vbV6-n>qCm?kkYs$ys*H-516O{U~I8){f^kK8Jr_tHT*pT!ujt>3GiTuCq;T zA$;d^fz$ANE2f_(!li24@%Q31QHkAl%q+o?$;^}tPu%*`73&v;2etVg=2>*$i&f?k zX5sBv;jenIP=7bJop~%0^P~c6sF~PjlDFY(<=RYx+wIsrON%Mqz5^SK?CkTGcVRzm zrj^9I-T2<(C$HCkJFtEs$>6281k6``pI(=%1CQuySq2Ps;(HFc0mrwS@qf%8r!^lC zuy%0uZ(-v1yn8U%7=8j{Ter8C`5Rr>{^`6`Gutb8!6%68#o$Y5mBUq&G}!_598TJ6 zW!J-rCKra!?G=#f-nVZN$KSvKi3*k{t*>EMy0V+znJySdYj={DuNBIbj-8X4s)Ir- z?!$d=h&&7uc9*t^*RXz&ovL}e3m%<&!yr6>;h6B7KlDkhu(k`sPw|ecKeN=IbXv~o1KMNed2QmE44BV z7R`|&FNp$y| zV87k@8v()Au#LQu>p)l)Yfv+7^cK?L`qiS~_mT2YHhjL7G0p++(!|KyKed4=Q8}jr z>0}{S@6Wcb95ozj{`XjQ2nRG>Q05tzyM_NXMAbj^vc=jCV~;E}EaBIN;3ag=SSBRHpr++;L`+m5G=^M>}g;@=2W*>T-!2RB@@UsRK%!#g{R2IfFrykkA zCqIT$+M@}VGLAu~uhqtKR@;b;vOZQ=V*-_NCkk=~eMbL{@%$?+tOxqrTF%PS(db!R z3G(W_u-SO`5BOwqw!g2s9waK#O@EK;Mw5p;nL6Gyf#7oYJ<_iGh%PPd&^?}h z#6NiY_Urfs@LSP(MfznilKEJ(Y!TdmgvVAx>l8bH;5aHWEMUY2k+ZK2ce@ew?2_(@ zz%L-Z`pL^5kB5<$n#gR6S~eIMtJ&&A0OCRIABdS^G zW8(+ma@G`N=)Rz#t9%_ez5PjQ5h{)}Y+Ci-JGvtCSM9$VOS(b)A@Q;QNMk{)L%f@( zY780KN$G zw%7ZSV12L0C_rrxCCR#VX1L{p%FNw5nWbp^tg_! zgltz5eH9CAGyEC}2umyXuHUvpOxFS=a-0;=C}NIX6j2AHXJ0BGPE$hc-x5DO@=64z zEC2bLr8$&U#VPB?Y0g%vqq@Fhb`jk z{;F8beWKmS;X!W>FLjdAD**oT7)ic6Q!2|3eND-NHwlK`iZ^F({8fR6LO=fNVnsJ} z3ir*9p9TLFFO-m4ZmL{{nn66Ip?RABH(ls-%RVHxQNehqWl-Qc%J!MX-f z;+HOipJ}c~>W2K$d|dg=Sa~AC|52H_{Q}sso91d$VkpzP!EtSafr6fdY zM(#mU5s%t+6}$(WlYq(8ne8m<45WPGTmHHKih*3k_DprtfK+1$3gZ(yZvwzI{5X)zu4i1 zkKlusfzhzr2zav|-y&DFglOx--Ow-vjGMFXD;|}F+bcoZ0|K*v#ty}YsrMlHR=bTg znhvl`9&7H*SPq`A>{EN47J^NolCIMmi(rB`CKUfXU_^W@8=r47#Ev>etfVOu2 zna#}nkn-)w9oza%P(5};_Gjx)bl2pi8)@(akaLdKOmt+0_t$`8t zq`bxU#w?h0hTI{qnG>$M7Uh}=vf-1J9^)A+hImhM=v~dc984l>;O5#>!nZ`72Q`b- zV5{$}`-z9!Xz$?()l7-In1OIMW}fT}l;~tlpt^PjA7tHfCef0E3lGhPj?d^~d6v5u z!?u0#T%td*=}i=B&An#YX_du=NyGOk{nX)uGqF+~W!A*c^?SeBIAA?7W5M7N0GWR5 zQ-@A#V_UF02_Ij8ElU)?zsm&TOowmwK1EKDis!%cWQHp6`Ne4FTk+EPdg}$yGfKz_)ZZUuQT?MMZbD3gP*umdh6N z?fAXF;V{qrYnbn8>6_mtg5dR2KEI4pqp@Xky7DEF4s4+lE%2cZ7m$#Q%Dj({^2J4ecc$6y4=DNJmNYXQ;#8!#o@|y_GZlR zay=rws2xkcW;^v&tqG@SOt~&Sh{p|u{%VK6=fL!?4SbEN3)|Sv@Y zIK%8)wq7QJ=a9Y4)7J<(#oxQ*lwAu8n&MGtA*lsgQxtm9 zrj>wplgeo z)Zcyt`&Fa66^t+}j*iOMJKhexi>>aQ=xKySSrm(xva6w;>aaQUB|o?&eRV+o(Pg|~ z7ZXxKXN6~~Im`aao51PfsEX5EvM`?d$ayV;X!vg-l!8i13}^FQcD!Y2haGNRjQQZI z4~GqSN}DPKAye+^G~fFS7}M6)__pXK9B?o_dV~Bjrle1+U>eec3j>10byA?AaUaL`As1q$vmqV(jll~oZnV&5;{mTf5u%*s7WyM2TK7kKkD)%`pGicCZ2j&o0eE3G3;uI#<2 z{$uPTlGHN5TQPg^G9(xTv7V1AReOjo&KgF3+=~Gfa&i_OzE9BuOY4Wf8!Eu9s^srZ z`*%=|EBl(1gga_GVg83cD;oHcFNhZ%{(^$`>c6S`6oGe9V{uB`>0tR(zy+%78EEHs zho*5wBFMGxe`VS|k62|Jck}w+p`U52cRCpxz>A76Bvog!k>-y#X!T?=3J%JpoZRaJ zRFS6e@$v&FFQgbsNH`&-{rGiT6?1Tv>qq(@GI_wQBHS(@7K3`D zHTna7MSx8tv42EZ9kE+}J^3X{5A}adR5Iti2poO?kv9!Bq2uQ}To;asf_#fhG`D`= z0K#j=&!DL(D(3rb|`U zsyLj0{l|ZcSM?Zy!GGdTU#B^dg7^7reTIVI=T`VHO^S+zIa^$z}PhNiT ziO?>6^)V@0INoMG1Q~$AaT?xG84biRl6Co)$4$`tys7ghhZOM1`1I{c4L``THoBG{ zCy!p5+-g9Y=3tVSBkxCcBybVQ%HGO43yf^9{nmecpd!KXbAKPcCnZ}UPdpXa`(Dzc{I3`hPFOxN zZhwU~a{J~J&qo18%gwnmjYRb2Yz}Bq9dm74!bnW-bLrMrEs{Fs;db zj6_^E=-!h>gA|_IvQ(El!R>!6kB+dtBKm)2PxzSrL_Y(=lSPR8SGKu3-CucfL5W|U zjeg)bIC#NYvMaHKei;rG&uNguPh3T*>qn)aYzjSP_Z4PnQm=KFkDCDtj38iJY2G#?P90g4L znEK}6J9qb==ycRTs@>}o@K*!P=DXXc@!%qTT8oY<^kP1|ttDj-Wu$ryxW$jbCAW?2 z@1Zj&gwV7u`GXzX^geg1D>sKv2D{lZmL2fbj|U-Yt}<}6I_W@&RsnOlIE<2DHF%7= zIB;}G1Ftwups=*N*w19q+fiQ{&pNcQmb{a~0_^K1za?$qYi00PXDJfjvr*L-DT#p! zYCkV7sS4qbZ{qESUpm5uIOWizzCL(I^TR}$?LD}pmBGnd5(kf(({|h#`44N!PLsvy zTVQ4T$+SFObI8tcuOj5aWh{G+!IILa9#iN9Kl%B_4BteComYW37Mzt)J5nA7pD*9k zdWOoeaTIe-!99$}ESAj=U-HKSGQQFCLw<1P#`BtaNpDOX$v02_sKK3aqopN!*?4Y2 z;CO$68xD`xd^-{I3_c)NKQP_tzz4bV{)0YkSl#*#Ums&T4mX;mF8G-U9X5hbuW&T~0cIA-S1y z!U|(M1P`A(eSOvlMRN>^5Y}pF^eMjfY9)e#zi1lf)De6k6W>fq>;+lR?A5z-y%nmT zWd3>XO#>wPzO6uJhhV7CLZB}nQMVZl%49bpsPf$VAb_ajj;vg@`?62$8>%UmgUJMV zd772Rz?A^qH937}p0~oCaQe!Omn~4I*7K*8cnjR$C{|q}@^cvq-)U#Xv_N;M5(S#9 zCaC{u*F)i413c4Zpstx-2P0?#m?G4x;lhes&ef}V@D6>+y=Q5Lu(o&g@N$?BX6uiz zW;Zg0`{`mG_c9xxvS@*6ZqW-^<#0`WBPX2GV{|%h8(#;%T+yc)M!qNjDHABJSr-FL# zD&X%oOcJR>aq#{HZ^5~BSxoJ4M~^144ys(aI6TkP2vs{>Z{f(9wCQl~yWg}=+j zPMf<1z-?`)lmP~}6_tzkPmm}WaSYZ;}0znmataBSqqd6(8yUP5^oPH6hOaMT@t z>AXPI@$LfjLBCQYD*-Hwq+{(orH(5fzZ5MJW`cvs>iHc#A$U;u7^#P~JsuEFy%L>m z1}9BPyrP5zuuqtjcyh#1m!ed?y2Lv(~fO^zu(Zjf;5-C1q;%)PO!@v0o{(Rln z8zc`SI^>%c_7z~`f}rdFx@52bcc}c+4i>2T!E@%6RvmD16L{z3M}yr>@4VJ5l!7Eb z{|KLtK8?A>qk5xS{-I?t4G9^4S}6Bl0I$XJ9y-3I74Y?M7h3PT`t`u#GdgKzEq7^$ z=tC;;F*5sm6Zrn^+vTo#fy{CSZ;x3WfL7Yc2T5b)U^?X*jpX%i^yH>X_Rq2waI@3Q zo#IqF@;>3Ac*rgo#R|L+`4>75s*+MvOIfRsVOWymwV6s3|W=-YPKA`)Gc(D9rr z4+Br-jcl!nc{Vjacds*TOu(Ch?OEb)c|?0b*?IJ;BRH9%t`Pht5cmxpsi^mq2eD@= zcAA945X2m97) zY`LomNbs{B`C-;!i=4p(K(s6Rp+i^(#PNhv_% zu$meDU@fxC+?;*7n+KF9cLm!XM1cAJsAW6$J4i2!pOWR$eQ;0D$y_M90MV(doa{gI z3Osc=a|s)Sf!keY@>@28ky}^*Z|Ro^U};40^Ek{yz{@2BEq8;GD*f^Jhk@Y7QA$q( zoj}ycNIPcwHv%w+yv(AVD@0$v*)Z`8wgbi6!5$o3&%lpWj`5$q9|4(Qjn3uySrj)z zo4!W<3)oi<9(p1z0%w=#c&qQd0RcU#vf*}ZV9d$cEb8Waq^KsJsrpzg#E z8%16Xj_Hg5*6U`K3}PLq5HmA~hBtuV9h-7`%YIOkS9#gfi3M^R_9Z@49Ri1Ep4~Zl zrxDG03-!M&$OX|))6-4p-vi~*UpBGS2cY0`ZYERbjE!i51(|rufB+3l&$Q zEZGd}6BtMR^YWJMvN3U|?;2Pndg`9rsW0WmwsDbb;8f^T3+Aoj}wVl zp*ckHbCC&-p)b`|VZH!~&DbZ(eciF7#Zcnc$B9^Ko-kh$6OF<0=k`a{bx{0q=SME$ z`CC;Ocq})g3c5{&+;*IO3cc3l?#}A@!o+hvl0Ph~A@g$0mz0uPSURa!WRhG7g?-8N zzwV_%>BeLH4vlxA+gHW)jraoSOZ|S{+O-6V3`X*L#1%uENj`#vYAUp0@Amedi-aMq zRBUTPN$?-p&8x1>X)y3FnV9$0Oz56N4X0h>AUo%mjjz>rpx$a@w^UXT+)rUHAF?6N z+xULd6br?}$#>)j=gIEDt)7GGxJ*CzF)4>BZq658^coDxwX(&og@SYymjB_zQ!M+A zt$OfoB<;D(T}J2w@=e5R!eHBQr}y^kQG7K0&fSXp7Wl`50afQT9r$YRhul<>D5Q;o z3RY`Tu)Lw|W9WHjIR2i|`$dHrj%%HaG=47+*AoMQV2muJ-zz?IA>uClaYOZxT!1ri zKluD~hmjVx{4{!p{xBCD_!Mk*YETUNNV4zIJo1OMTzwjDhtETXp0|%PB-OBk6frBt za1t6mT8R>!5`k}g7q>FQXy7N=y&-mc3H&X!p>s>U9aI>VYYgd8K&cxt3(K5jc)q-n zQDI#S63DwF-oH4Fnc7+lrCtzoX8Xp+_!X((;JCe(h2>uqBCx|f+#nCzsK(w21RcR! zW9%0>YALa8!)=k2`=pTYv_q}`?kLhIzgX~mO%i@Qzt`|%hX80hJ&&+glHup0LhX3i%Al_z&GFg z;oJxnCd(sBZ43B`R*P&p6i7bu8Mv}TVmw%&r5T__{WJocZGa#b0O`KqGv5Sf)hTu ze9QvZ)bECm2aOXsUp{|B97;gYLS1v)LN-9=9qH~Kb;wUNO0)e_9TNWe$h#xr!zb#;T2|@YtnFrmj?&vwe zHtbJ#05D(q*h@hc0<1Hs&XZjCN2#c2C-^ck@6t(oD~de_Sw%%Gi5+SOW+581GWUEy zs=A^Vld&HPlVBV91@?EguOd**7;#H-Y&@p7{I9SAc4o*I0kd1+??z{uSMD zOAsAvA>;3BiQ4X&dfqV3MbCa*u{@Z)1d5M*owQVxZy-(^5RE{4X`R)Bt{k*f_4>yCtyh4X zhT87_gB;YnDxT7pQGi(0l1?xxPk^6Snt#j{%m9&VB^JAG4d754&t!XgIY9cu(kE?u z5e4=2beE|$0FqynlCiI%vEX~WZBorBZN)M=LA3^WJq>TGz1fD)=E>SN(T||mG&>A$=EIW1XL?7C9tyL(CoCLk)flFTV|Iq0%<&M))v^eW?%Dk3R0>~wc zt~6Hqg06GWYODpUfQ9lg{bFW1eE5c!W4!|#mShZ&n?6GdN9r@>U=AG~Y303wzjHue z6;S`HQx=DWfepyf65dEsn<& zf1Y_Z;NQZ4Q(q=g_M9Stp5JE5rP4|9^l^nF)W)abxLQ-WWR*4!`%k@q=N=Pgs+4sa zZxw*z>zi%EaniWnqKMtuSO*Fux!E2bzX;22$~hL_W)tIM1`c05166 zpy}LT0vY$lMax6Hp~TuRrO)e%@Y-N))ERF*n65dRJhAMGL&=j`u6|3vGu9)Sdm4}N z?sbYvw!gdRgqx3R5{Us+{FrvhDaQcEbez69PH`RI^^7gx{^N)bX#2k&(`CnMO5uNg zcNya^eV>dYV}hX9&3nmby;C6n(hZT__#`+GrNq@poTKY(mA$DK^uShKBSkth5iptG zp2fJK1j2lh42}6*7`mEo{8q^mev~aR@Y?Z(kB{KPO@4h57!Q>u4>e%sa9GnfK~)m#3zJSs`F+(6!_JPT?4NZc za6lG^J6EF{B)$D=Zk5Fm()#n*+#oZAOy&QaERW@3&7jgD)Srd}Rb-W`%AaDwT8cU?onOwmS5bv>ZRF7ai(eD#BJR>w9t0srZ+1(Dzx9C>*XI z+|jdHgReX&KYR?;;G}7aTb4Ez*ssR+9j3{^yCbS&qwM!ERaV7TEu9~Xt+X=Sq1@vN{a_2}x)6h3%G`) zf-M8taed_+@bK>>)uD>p_#_U0%Rba1wHK= zn8fbIxkS#(Y>Q;`^A=)GgspMACvO~eHU^M9XV^gp44p@K->d?q`*U@r^R8%OJSEVH zPaNOXt$r!(Hi8WHE4_wE4}bxesVx<8zhUacd*Ops9Wo8N#wz2gignK>W}M4lfje>A zQrbd{Fp!F~xuk~^V=@l7HSJC_ee(Z0XOc8w0^UsSr3BT0`> zlqkjPdar}H+p3~ggSlv2?6%F4<1nIS__e^%mjjlaTf*9Eo`R_5i7!*FC5S`K$@z~% zJ7Vh`ZM!}F9@Q6(+un022fh@KHRq}#0H^Lq!hM?;$d-dlRU^6#T-oV!^IU!p-dvMp zyy#nq+MmCTS;R4@CUu@J>tz`bA~$_k`FsNimu&F72wVreCAWSR)(oOI9_pmu?jaIfNq?rxW9JSA7D2hiKBa0k#7ilyEqvwVv3(#9zLi-lsW?$+&_cwHv2tvU`DxMNfV>Zz}Sd^f^=XEfOsg$PP)-JplhwkFf-?1|q7^AdGPuoUSdI>1uWA)db*gi@Tc7rT#> zqNt^_qI7j9fwKnB_uuTNQ2Vj(B(Cb};7x>G!2L~o;8K>ZeHIc_npdj01#Z)z!tk_} zN3v|70NM@wj8;M?FWaKbq z(VySP-qd%ygUeL4LT1NZk(RJb!zK&S590a!v+cku5cyu~os)(II1a0?bdY$WX|Ynu zLlr^bTA}Drka-*$yTa4?JHH(n)(J8AyI&#Zqp7y$xxB&B*w*xU;(fkMI)-n3DH-HW zgxkDWDgn*u1Ba|2LWxtK@+A$%5OAGMHcws!aiu%7kt{bG zptyD_S#T1`6>2I|rYr!Vjfu$4FT3b9?~(KiEN8II6(iyqQwe0v5_mm(q5)ZuynWYf z7b?;5+*&sL4R+3jepr4-h4n_r(w@qNp({Lm${TE4@ z7=Asb7FoZcfUVa*p3?0Kfn@z{`$I3OA;VOP7`-8pXSevZ%jB~pTzh0H-_2@)EBE7$ zkJ;M7Ey^SriN7RJcvt*a@Gd3xF_ThHGopm;!5xXzhs2;&Y+8}_aVH#fuIvtY@K8@?rt(_B=03@t0-s70L1ceT&F5DKegoB0|#s!x{@Ob&a;gI53 z*ydZ6=AKgwujQ7YHpePR;RLhK?p}qli~d6a)2jG_d9ms50egIn*L3G4v4`$)f0*&7 zjXKDl_9aOCnG0N1Vm_7T=>%D7>)Aqb0&tFBfKsAvE_^rjUPbd%6U?~7u`1>*32on| z1eq*r;xqGcf2qt};B6@l;RwA4SZ{kd=ul<}^vV6Q<70Liilr#{9DU}AJ=k807wKJx z*MGMus^wYY^lFW^P^Ci5BQqC%jfB_>n0&`Mrm+q-v(B?S2G_#al{MfR(FQGgH)NCA z36Syj!TFvKjqr3-ufQ-(4LthDc-XVHk=XNT+?$?5fB`DC^Snmw@Q95LX01*k7g7hi3Kaewooz6-a*&AAV@wRY{qe%q&FnBh55my}QiS2sbI8_8tdUl0s? zvZ?Xz6^48z0#;niU2x3aHe4vX09#Y`zo_|82E_|QJ!87sq1$ybi%5P9B}K=Rg%e)G zl5O?v=#6e%fB4BIbiWfn37QEl7HA_P&dANQno#9r%-) z{W%$Lj7`JbC7V47n58MZ@wUQC+=-XvL=i1UsW(xvXDPoF4=}f z_O)v0bGvb+_@&O9-#hUu?&sKlq8-y7;-jjeN0?r6(`~b{2`5@8_jY#H-~ef}Co{7( z*pZcGC3@-w)?&-lbCXWToYvakD@g8PXx?+XZ=exVc^4g02yDc0AMHN~xmDrMQX&F= zFVb+Tv4m&E_D$T&97IOpLBQD`q;5|3wBS!*#O}nmax6SABAdec0H51;(fshl4$|5u zeq%k_hI=2M8y%u-z$}_?lD0jc+;q3&(GMP^ri5_0f(d?CJwupXXKK zpMoZuP5QCes5&k+$k+$IVK`kf>Tv~j+)@_QVY`Q?ni`WQpP1vDB9qrvR4gD(G{e8W zkaPH@ctzI8)Ll0WgS0OEQ~)} zl1w?m;L=^nO9!i!sdA|;0=Rq$dbp?1)Y0iI`&ugaNagzb8QJcB;8c!OSxE=Q&jtaa+} zaK0D9A5P^)DY41Ip9FSYe(xH{CBKK86|D0{K^SH$XT~G5NF=DWsKtdO5&f0Y0n^A0t>E$Jf*HSVKri@B#O!D^2yJ zaD}?EEJbmh$S0L8D1IS=MVHJX{k(Ybay57S%tKPRQ##(Mk@o>TDyT>}dUp#IpY0f# zub%`@w#fDW^Ir$YkPbs&PcQm#=Ev^&qFgi_^|p0vv==mXe7hy+&Ik{zwt{qpR>0m- zS0CN1NpyJDxcY|r0N51p%1Js$WZ8PYq^Rg5gGVkU?oft}qBFDOzb?qXMuBBg4UdoX z0Mk38zvHM|(V4>F4}Xn+6ZM$g_{g(qw5s8?rF5kv&V0{}{7n_0qD~u~wXH?bO?MxE>Zk&%#j+X!-2;GhIw0k!YZyvx za4!)??ey{X+ zR|(P)_3vOVN(S%+dwIy}-1UJ1WxSjgzz$fl;R>AT}@J~T} z{aJkw0?gfbM*J$ME_N))>swWstY(j^(e5BTWohE2Ww(rI0uMtEnOrFtxKTzpDJoWu5?@7cnA9`jt%>=zx=qj|| z`9{bprQgV)Syfrw{Uzu$@teR2!X+NPa%lTNJD-nzh@dRGI=XsoNTurq z5qX7Q6BZbZWtbF`3R8@jP&xxSe$s*f#T@NFZ_~2e~Fn+s3m%)_-KB>eOK%A|@eC zOVMSi zccl(c>#<(2vg|>h!Um!hAMGL$Guujqy#RCqjnioFCICrenDvn)A6@eCi>Xc!r75gB-eu%U8ky#zGExXR|Me-K3c`R!=S`c$} zoLh9NxBZBm()s)dIzO=XxO1T-F%9(HO?ww7FpgFj2cti*9>bbR`BA^Zc;MjHt((#` zVpuaZl9M*4t00W%) zrI-O=MX&#UqVqUt4lt#nV_QW+vI68+Sr33Y|75w%HXHUvw00G8CDuzirQXHvA8vfEK5+_D zf2v%jjZub)bH%luH}&wvb@hD<<)%S^o z;p(}Lp9+Y2$ZXWmUbP+G{bZimY2<>r<&B@7-3oz?Ub0@<(J{CpKSt%D)HCSprcGgK z)dbJ*_CKDQ(}RJxI_i;%A3nvpodKQ0pj7T^bs?u*n zem30+-Fgq@oIlzLMVZ@=lo@nGDOoC7hKHT7{@L-)DOLhhv%Pm+j5Axr zLR>dyb#BkpE$+thcVY~zA9r9mQs>tc5}jC`wCL`mole|wJ$|-vx)Y0aL}m+K>ck3o zm;04SD^bTOZUw(@!=5hFq^a@VhQ;~S1rD)71nv@dp%x$ z_9l8&s|h#WI)Bie)r@aSi?YJZCammSN)?E!@P9{@iN?Pg-0|VKQSd@Nj(WvabW^_p z8^#!gL>t#)!#L9%n?<6YB+!5E(dojwu`c05@$Fd7ef?{}aRMIbo+0(OZo;8F9weRd zomkTTz@?3@1An8W|8VqgJO1)Aw%u#B1^?TwuzEFDi=W6Dy@E^_lbF58yYGeZV?GgX z-PH&@|s& zFTzd=O4;B$0aKiq+7*NeS^fc9+~01FmeRq@;RT{`Q3$U4x_phiAcVEc{41C3$H37& z9yadS1F#?4t&{(j6n`)sol(3gg3SwZ=)Xq^{*F%T!U3J|98W1(wg_65A2;w!JsC-4{Tq)vur|eH5loOZ^#(okQsd;<^cqgGj3Q zzWJQ#d$4%LNBfq34^mc!Q5r`m@tT?kvti&DWE}0gG2Hwf9Im9*;6DBmxo>}4$=FIn zrgxt*46BmjOk3@vg!*n^t#Fs*WL76|mPmZ_mb3%aY@ctxIZ_8~lQQ7M?FR7mO>$Fb z)gS;hUR`-B`AEs!XXJ>o8!{nlW>LA42W-e%1pZi0f^WI}H1!XHknVnWirY*M>Um=m zI`TFX5acPsz8;T3pT?_&1>q3dDDRIFyHka3H=RrK`ISkGewLkJBEr9F(*7w3_Ijca z)^|y7Q4EkjRuYs{S_JG_hYD9X?;_vR5p%{lG{7}kQYa`o6wvMRU%#kN08Vrh0o6{a zVE&JbTPeF#AeeU$jj@NUo5f&1;vZ!C|mNt=bOhx=YzeGGmq(EF+*z<^{1uw z2c<2s-y-&>u7oL)Dh&TaP)tUyE&K93Ljfp@ae8RB+5v2)+s=)Ads9Y%F!mClu>u-k$!$+8!T~)?ZT)SES zP^>Kym_o4tnmdJ@EN*OOeNG^Z-7`u%J{G5Pjbk-Ub|a5)ew4H18uN(CTdm3u)&{!- zIj*lqXFQ$~&hU{F7_SzpJmwN5dExwmu-F)-%jnRi!nA4dsy}E(Kb2^B>e z)tN?52@n2!=CEVVQThHRp)sqsmGF?kAU*!(BH?#}K>UrMhbjeq7L%%kL=``S;$xX& zd4&JWm469Vyi!R8v0Z;g7gaPpY!yp%1kiL0d%y*05%7aWeemRMSyXQLC4JON4cN&| zi6pPy02;PEq5i5HD(_#4@n-aF6O<15KHD9A5Dz;m>9vo)?mX0>})X~@>@f_>v zPox`Q4cSSJ#JQ1kQ#niC`(DJOGuQr8%m4+kS`4nL8iKpL558n;SfKD1H@9|ybJ5!d$kkWS+_+H`Q;OaygW4XU$%H zz33|_@j%|B@hwNdxa-9Znwmf`e0bNa!%u|jzWE0Sf2#v;TXM>x$SSm3>aLmQ(FGJ4 zxyM92TLAv)9To%c{DA0dW{&Y?jAM( zDLFaOjQ5?9h2rkCd$M|9=$}rw=qUvFW#2x2VDlX{eUdj+A{`M|>0_Jp6QLlw>p|R= zuxNCMKAgsz`7+Wp4ErR_Hw6YRO05pS@KRX>_bi)H2D14WE5f{q(kw4s3k;`O$opGDQDQW_iW# z#K$dpg_L^Oq08=L&kO|kuuXprpF7oY=%~8RHc_bz6J;2ge)D}qqlYq%nh8`Q>OQ^| zXR+^KoUy7^nS}@U8!P>Mx|arbq`FP1|y3d|lE!b1BmYW!1|vAk-+ zfaeZND8$&ny6>b7j!V(KyptsWKR&bVhd!&|sKpCRW;@lO!mh8{`$Ny;UpALC2W_n& z)6TfJZe_ROKsGlWN4ga3OE_ryFii&Mjq@j-Gna??0SA(A9XG9L6MaVV!v?11GNXL{#+Cz+3Ov!rAuS!`F|W)+_4@!wX8>#%XNjFnN2t ze~_vX-ZEmbuP`o$d_0VkVLPi}bL^sYh{`kk%v`1BiijOd8+2tlDOe5_K3y31J3&%% z?++Tzd)B~eB<`~yV+uKqU5Bl|J7VvB4@P8LEpVe@y?$jb(5hdx^?|o8{&%V=Mnl0Lm-^oe7cO$ae7d&kQeLL`fV3UM4SpMZt$6dx zI;HP8Dyq(IZ1XZ4-ikM`lW@Vt#r=%e%`4!yc)KPe-(ooG#rM@}C>OeK>j{njqU7o5 zS3D?dYI?Jq*okb(%ae4_vaK3m0TK3p05ktsEmhK_B0Q|yKdNLG}AXt*&6c>EM$7f z*utb#_QcaCogw;md(I@4(tn)7_z5ex;NHAh=fGPYc#HphorSa;&d9vJ#5(y9Ykp9$ zifb{aoTsT2QEdbqttzuK+W!O^o*A>*XA^_H8!k#W&Sc{!uU}`iUn{_si3)+EQ^_#( zi|O9!cmKi6wP8Iv{}*`o$Mm{W3K=+)E^*~3%*7*dy|;5);^7AK;Qro)FqkP&9UCp8 zk9+MVcb-oU$ELx4zBU))u;hCF++UN&@V`IKQU7(>QFz0#`?(lT!k?#j8*xtOZW$@AgMLL9w2!LXjb z1PA1qT|uRJIHDy^6qToAp}HR<%tCRv>wJ~$RjovPGf__OP<1r6+AkG9OL$`SxiE0{ zv=+XtaiF^Arv*Ma{6@kg$Ovng@QzOETEIej&2pEe2NdVs0geHjI7VXP38M8{d7^{zx*_6bo{zCZ}I4#q5g4Ca;1D@yg3zxK%R> z3;g<+tSfE{8zS3Z1}Hf}?jQQs_kKyoGE}~0I!n>`2pDm%^ z52!*jLpk;3)C>5<=5(YEybp_0{3~=-%;0NF(S9R4bsU(bkyEm)gOeOL)b8_J!fKXX zLD!jgLx($-=Jr>v;hw3RB1=sYxNQ8FBey#NeUiEa#rK)wom?MXlp=3oJAo^sGZL#n zd_1`1^*L3T9B*axqKE+=OFlSw`;H6rJ|P;uZFLM9(%$^_LFy8gbD=&^Qmzg)meS80 zIU)~T+$F&H88z5yA#;I_T@!~k43u-n&|rOkdXDTEakwv>!EsBR8z<>7``*aW#dmyt zf*+sYz$*t_i|FWtAcKC}3fo6c+(cS8-pnQDP0{^Ngvqt$zOf*4l``7(Oy2J{Rt)1_J_w-4x*a!l_JC3e&DnETCnVN zIXZvq+nH-Oned%M`}XlqPomz1AFV>X!yru8dh5JYJIcRV(o9`ciw?yODCYVwVbf<% zUcCJ=gIxI&-iF0~1Qo$+%=N-8h~qiE$3K%YH1uWtSx?qa#Jl*Dh~_H>hgk#!qE?E4 z%{|2o!;S((u#6w|@{a?uo9EBD(|iPHQ{<9#1j~U5!b~e4Gg0K+MyiBg1Sn*R;LzFY z3G8|owcETJ(cfkqh>n>2(uP6yzqUDBw1^J2z&XX@HkUq*p;%cVUF6} zNEU*q*GyKtF%~E?sqnG}hbM(=RTACA69ise@~`QWeScbE|OkW*mPqjf?=!)(6!*m>|&{4O&-#0F5l813hA7DUN_ zW_$xiMtnnAh)5LhBBQRif-Zc2@VlKlDr4r=eh0zWjBI#Cl79tzt61j=J$+} z8ivhQ?~1($u|pNp5l+vD^PmJ&R0!!=Y98MwdAEa!5P%x)9MEFQ#WHqCu7<>tBD->p-x?YFX$E z#1kC(Kjv0=)X0ZX;jTxA4v{)~lK*L}Xc6!Gkozt-C-MZye{5K1Nx)lYJTk8=5jHhD zGL|Nn$us++I*!+G6JohWHTRG2K@4f4t;K3b(8b%GkCrPeNpnwm){19Y2-KIalL?~&+#|ZimxQ}yMJgOd*4eM?yI_&C^|w0>0FYzK^sJ# zzr5h(mzqfUH=6b6H0P2tf6kCxSv^Fjw72M4@n-TMDict6s(@k-MV=3~RsnI$AJ^z< zDIRY#7gmNl_dyBnoj*P638?Da!xl%o$U=v~b1S#j32Ujelr3c@be87vLn9M}(DkNM0vA{hP}dZ!#k9rP%2k+2UaEg`qH$t}LirWO~iK{FR`-rS{t}X_54Nquh5) zg$CH<+{>_-6GKN#9%SBB5CX-vVdwDCd!QiFsw7q@6j7U2+Lq761Deb51mwv_4L|qR za$cH1mZPfFQrFHR6=&Y7{MKBcOH;m{5Ys~4dp~Ndop}kUYjeb&tCXYat+JyoPj>*d zm%NuGZFPYrmECjVj1gL~R*T;vEP=v>^9;^@uYsPya=P4}Ve+gF?+^XM+UQ*%r-z5a zRWPt*`dTg67MI2{Kjkq1pMyR;_eR@KEV$QF_2tBy;)1*INf&z~qGP z!$5jh@Bz_LS6rV%)&2Q*RUiBSIVaSkG+r*E>IZ7sJYEx^(=I$ok5dSWGA70_JC!1t zA?JwC;?F>~@VuRGM>e>+AaOlNdIp^#AC$&kUqrpO;>(Fgb19xh(&64%HkwwN;EMJr z1kHadg1(KH<#{&~f1 zE@Tw&Jv@D=nRo~oeT0oZ8^@v8H?^F6L=ITUy2@mh(}ecin1Uw-XV9L(zW#+28u+HA z+Uu+)h09kEW^#Kk<#|zx!0FGb(0rUWYxa>5jybyTe#AHzuE}a?)Htvg&NMm(l$P$p z<|(w7M*~hm7i?wOW-0?yhs<;?hI|HWs-2PX>C@=X4q+YhS6!4`(qg8c${rl5kJtE@ zcp-cKGddT?0nkL9uM(<}fqcCKmZb8(01qSO*@E&#VC-0P%Kv~Me!`$A&+}yoHEqV? ztgHoa^tMg&jz3H22XmyvUyq%T=09(3?rBk&LP;4XS$GF2T(!qxB*z=KS{Ild zQc`~7ku7XWl)1xm!5OdmgtzUAm4#9l6TJU^J%??m{f6uGWbu1T-So$?ci{6PTI%Qw zQ|O>*`lEeo5g4c!7eug~f~nREU&|Lx;bb8eRrgYWV?7m^f`pafFTR+|AtO8SYyiLK z{IE1WoWyZv?ymy$6iiS)GQN&doo+e3A5+5z!L=z`(F5@LTQePK`UiQuzMm+B*{E@!U<}0a>LvqJl#2(+kjmc5GcQvl!6*_N|t{VW#42%ig zKXx9fgo9wJ2t9benjHF;bQWGJHvKdBLmmEC1atg0p4pTa!L+zw-|Z~`_gQQt_#6|1guzW?+F!?T%x>qI!!alDp>fUWoJ=`f zYvgINN*wyy9#~+*^)3%%K2|(eutdA}y9xCBQtW8C%aX$XwS3pDb`=jK&&7S} zzKBOJvv`HeEFqo(jid8X+Hgv~E5#{T2YN_339;?afS(4vtg44k!v3UDHg?MItyYY| zrtP6Teq6dY(|7AMp7C!tU%4wn>Hj_8gXKB#L-l~M$A?FN=;;rMcf}ZB?t_+xig|ls zR-T5+n4287&_7z~Z7hZ5)gDqf*&{&jfP|25hXg#x5qa>#h$LJM3b^MZU;*RzmHjug zYy%CL&J?uXvw-_;OQqCRbg}Cjx_<)-=D1|1XUv|P+R)K2?Yp1&8Mv=&xRF~~5tqh2 z4VIqN#V)#r0aGJdSVPpfO8CPmN)B4v(o#+pd!;VV`IRZ+|CA<;$m@LY&8YPv^LaT~ zC3$tOG;|-_*OnEw9eWV!^t&EjOgILA4A&G;aqNXXjKXr=Zk*Uw-qNruM*{A$`u+P5 zc?1gHKK#$Gt`Ar{1eVT(3uA?-nG!({iZ|x*i-qKMGputzD)K9rIo7;Vo8Ngxijx1a zqLNkAhI>fEH}YJ&p^&M^gR!I?eAa*u z$7I&6eejWkHnTSv_c|Yiaf?ltp8RFPF<$X6Z8bPCi$iea=fM(C_~(gJSQ9($kmLWZ zVk3&(`a*hW0@l&tsEIMdcTCW(+vmdy#j~;?)O*oPNe~aGKWA80+zG?^$N!po?19$@ z9T!dWrclq@s3Q07Eo8-VtbJCB9u^MtJnE}Gi1)bNymByq1t>pBTTM8=1~NDk%Wk#O z;(^u!B8JZd@uP3EouglAajC$`j?AoI;BBO$T*tppXeV`q%9{NMD)Ta%p11D@1HaN) zRsSsl_pBR?nO~}rP_|tyy=@iZoQ;XwKkyE8mZiLqHeCWZIif!+ zbkn;phtG8<{^7n)@}u!Mdf8qxU+DM=G!_j>Gjq0~*(WqV>s%_3#^6^m1?w@C;nmJy z9$yc#@b5@=m<`^F{!)=ex#(Y&byE5Mcn~b}PRvfQA3WJFWiIe49b{VNhb;a|ML!M? z;nh9i;23p_=yfe8Ak)x?3>F#@Z~CRZDwp0M{dXUq*D6N?XU~`@Ed@8^GTuHo!|shj zi{%sIYC_R@ht>xTas_~&*x?}I@EC=qxqtYV;EcTUn9?s?@CWfT3G^Yyiji27o*~bk z0+4KW?p5CnOZ3SoMEHWA8~Uo~8zVaB4{}X8m$=WRgW;~Q<#jR`n7TXuqL*_-m9<}` zj|CWkrB8il_8MFV4g*vFX36{D{DLs+_Dd(!jWrzBm{owE8K5#G3GnVpbLKDlOK7!8 zwB!Ah7s|^uasT3I0csPUD(q*F2SBA-t|(s}`5XA1^{G_{*R|Z6bj*Xnhi4vfv{%o8 zf6~a@QPKcOSqMx&+kX}$tzGT6UlXHzkEVO^U=VmF;eP7LBV}MAq-=L_>H>06pjN4n z)&g4gQ7=5ZkE0iBO7~m~FN0p5p&pYL>gcBR{O(t2ZA9^?wM;?)7dY9E?v73hqSxvd z*Dej|qXzln+bMg8$d|{jCY*;{VCNBXq zmW9QP`8m*neUi&SEiFK%Y)QiLU&+s1g7*$@pG35JZUJk{hfq=3R^G|?yMXlHO&?at zC9?d+?;A1aR>+rqc2OoA%804|<4-3KA=KqDGjHq82o~78KfYI5BUK1NF4vlIGM@X= zT2ZtJ3f=#M{lInuDd9W3GJ1TJ7zkC1xEuJ1JkR;&(Vr_dMB`_w#fzU9DSbBAoH$;5 zCm?s4z-Rql^5@pM#z2R9LY;q~))B{SV#Oq$?@;y$!Y#@@V#veS3e9_x^I`+}rz&Xr-7mW42Pr1PjTZ&#Mzi27gJqXB6Aq zNu|>&Y!4y%CoY2i-7OLF=i1XC|Mx0{g|GnI<0rP{@y&|t&G`t@(tiH+12-}9meihG zYf_s^cMWZQE;+6$)kxJ3tM)3A$_DpWW=x#Pq9;=HwvSl|=|QHtgR;f7YC`{12Oh7~ zW*6t4EUlFxvfAuGUdwetUvg)LiPw7VtYK;Lvi!H&H=Rx_?*xz>Mht>ZnJvQhoetVsP47l@aPg<8W;eGem=c?ms zm*ZC;`Q0TeQteMXkvAXCNGKwrfiswRDSVgs@IkwMZ}ELH_7l5chKD1OY%Y0knl^+K z2_Xk{1d_?Eqx>=ND=(8ixxD{voG>8{dYXmRWZoqM56D9sk|UL=`A@1Jx=5JqUi0Ap<4($montgH_>V~Chy3@YmI;MtXN7-NZIE`4 zwqI^>(}T`XR>RvbM3Iwq%oB%pZsf{qye;loP8gQ({mx%+Aw$0=OTTCRKr|fG>Iv{) zBISqweW~lBqc#GMrIyl-!IX zU~8zeiCi|B$#Dg@z3V3~Uexp6kuyu)Hsnp#ojZbBJ*NfU3u%MnGhy!pB(5L@nlF8S zi|xTt)0HjixDbkUVC*oXo<^pxMFZW6rNmTM^>tk5ZINDx~ z|M$4#3AnHNE@5QQ0p(9dJ_`|b0f!UxB_GiFfmwIaNtz3>2<**@|C4nU-EUs*5PEY9 z5c0XlBYUh7bx=MIvv>rU7@XFE52pZY7W*lqauv{=lA8pM8KAl!jCm_Yx4~UTe6qUQ z0sZsXb#Cd>D@16Ri(FyR1W!l$a<?Sf|_Cs61g@tLl+F`%iDH+7C75i}(Aa&{3u=-#Wg6t&FPAoxer2bS4r z)ROavoBqovy8Oyg2 z$d(2;_P@Igs56kFBu}K{R5GwN+u3jI*MeAO-sU+%2Z$Z}bm>R!3TQEnf5Z{mhsturKMsw50lO}Y zCp+Bx2ue#>>=q9FLWSKozP;G21Duk_cTQ2O!PvZW8?M49paMVlSOq+~o8yvLwcpTgT44!zdzg63T1dgGeF|@OvPi?-?wtO6 zV|Ky7_3Vz$_f$~z1;cuWaUoK@?cFf{YXRL%Vwoyb{)-gMS*&huF99>RJT2p*}GNAAv z4!P!XeADg)iLab53+`P2%$;wpHQinYeZvvjFN6kwhn4yv^4%x2_-}1Nn`H>Cc{U{V zuzx{o>DP`3i%uasqgZRfqtnQLGg(Ht!wb#-mi!%h{39rP;ZQU7|7<1O(4i0BDs#f^`lojtCOAEO4)95m88RMZI$F^#h@4K#swfqAW4 z2ZqsrNtEJk$9B+ugGtQqN*_4f_3}URL@}~_$h@xAjgXvgLlsQ;47?c6jpToS3#2$7 z9*(2radR5_VijbnkZI*X={GTXU~9V{T^yjs`w#y3uU4cL)rnM1>9jNe89#?#S$7-J zm4_|Q{Wzk*OTCAm`HL!1;e=Bm({w!;PtHCj*=`PYRswl@zEI>oV_fn@APFo_~6PyY+mn7~Cx=9LQQt1)PUR`D*l@pu=SX;ftrN zz<@)>og?v&f%8Igs~_`gFc`D{w4qBL=yBCM>C*We8OGQYR^h8Cm@UNn4;!W4{`T8b zyHjc4^Q>UfCypn;t^VrYhog^>O5j*S!tvX{h^h1&Wn%%7b{58$_`0CZ$+oy3hIZ(r z`O?v=<9a~6y27%*MF4FLGw-fi&_og1%s=kk)c^+$y?)}>UY8-|*{Is+>bt3cyT0#}^a|wA&IgLE zErEW((dy<}@|FUkC#3nzJkFxzIPojOMVdhCt5Z^EnLOHj$Ka->sW!V7NSg&Zv)42M^pKq^rn?sHer!{uNRKp2tPhv-wjb(7u~% zF{p%i)n2NbRSBY7?7~)t<4nM&O2tEF_bNHL!fVnhHJ6$H&R;bTfEIhVI+~dt#X;om8{{TjxF9EC5-l@3RYMS zlRf?%eSiJBiL$t_uP=S02MR&W)EC0Wi10+lZN0o6^22#nYk8J>V#h6mQ1xXmqO|mV zMb*qQ`7hleuJP12a)UneQ)FNxaVfphbuu8IocdX|*hQB{`m6_wO@97Nrdn?Q?BV`G zl#JvKyn2yI;^51t*{h;S^0XL-#J^I4cG@Dr>RJxjHqBgXb!3=WG<|J4FIPm?NwR5& zciRvx1ea-}crI~rYSUevcZjI!XfokbDj^=*UDV94NF@C}b+pp#3?+X4=boFn@`$hs z-4#=ro=7USJ+R$BN8-Ho1>)OIId_%~=*t<=eNVc#{*-%59La9|s|BvIhz?&D>ZQcG7q z20TV9YQYRM)AMsJN|ut0Ii;URYN>^$Z)hB(CVQm6jvtrIQd%7;NRKORsAbhU$&*}D zs$^dGdSWc^y;4hb>t9>55v87~mkLgAvz3sjLEPU;vJ(BBTUYLfjMSnb zb1H-CO(mCJo{wOrTa@2JD4xt~ z3Mv*N14QYa_Vg0Ov97QuKCTxDUZR0tB6(eDmi9yaD^EI-;i}@pt|(5zza-b^@Ig6J zQRhL``|C2K*?i;u$|L`jbR^buQX5KYJ=DUt3n=?C#etOt^)oWW8TJ<%>|+~386NMJ7U&$ZC#+VgVKP5G_WNaA}!>R2SNwp0aSWd7@VR<{RP*F9=>;PW%$ z0$sC#0B;!ik!H7k@yBPSlhe`RhakeUvj= zF^QoBHbl<*Q11IYbI}hOQoBq(c!ll?95*3^FEy-rH&~HDO(vQ=lR*SWLB+lOdACW1 z)G>u6e1hy|&;OA6K!NP?_2bJ5(k8mXtqv}8dXZCuJN9rzW)PLrxf}16mI+l`zmAs9 zZL&9#>#2p>EMcv;aj3O^0=MAw!@~^TE+kH(;$T*x4Z#(gpjJY3i@^at|QC_YfYdH3c zn3h%MD&Cn(TzDSXzi_XVTvKv<{?fF8_&LbS84gCta!zmkVak49yYEk}@2OZ)WZ=Vh z?#^UFa9@hz8={!ZuCnuv2^%JAD1XLujGN@yx{vK{y;7*lhP{Q1*8#nM1%nuOTu1UD zyADn7YfO_dPAg)7Z4$KuQEMkkx#=RuS5q!Nf(u6?L*ePErK zd9(lf=L<6EGO@<%=64X~W|S4rxut=M1JTDF56-PnqW~YnCY6HJs{MBGnU_(0xFu>fb$dCsApW)x?1@r(hg#t zUgp#Xi9c;J&hgwrUDg#>pL4i@i7T}KeVB>@H_YRAEAft*ZpV!p35hXu2ORNIddW}Xh0w8$m}lsUi2Ki(P0*F;tK`oue)}iqk4nz zvVWw?@if2}y?(NStg#&eCwy23kpta#l7#Lg9($lI>N1KwJ4-STZL+7XK ze?3Z=247j^5>{KOU~~FJ!m-!!I;t|InEI)?H)IlwJ>ndhcT4e0qfw5MUV5^($8XjR!&O5y&$6QasVLD6z* z)PhcL&{*-ZQe<=(IvPRsHsXXoNQoU^y+(QLAty|BxNQJ?37Gimg7$D>S6V`H8*o9bzV^-;D3> zMQ2`rD-wCxfU2wq6be}@(dn)iU7;Pmp#Ge|k2+WhzM9ayOA)RCw1*z_U1Bc<1&_?v z+-Y-w=e{4+%KVOKmu2^iu5Tuy|0(t_u`vtDAG!53OE>`VGYh6P`gs8B5y=F%%^T>v z{ogXP%P~kdUUhM7FaeqU5-MblokQ&RuDG(uE~AbjDN~0VKTy4$Li3PDF$e?1-EQ|G z@ap=b9Sr+>Py}b4_`}FvbnqaJR~TzNg$J}}z}~hT5+Bk9I9&2_0@&; z3r!smBj)d~K7;#f7CkoAk1>x6pS!gO}M2EVf08zrVMMwV2Mt_F~ zU&)isNc*nRe}@G8K-+~PUdM%3XpFH)DwaAH3FQ9086Xo1@@`sA)V&P?TxlnsFDKfe zRD!40qJDS1Zs!_!~Vy5Muq7b6Ae|(SYR^#Vy%!ch z4sHQ7W^R=F7?_w5;P(sJIL=m2ka<&kKQw{IR+0)Pta)NpX~>O9Y9y+#UZc zU_|K)+Pi-G6FZX1m3(c>z6bE<3$YP3vS{x$`#Jt#E8xO-==`jj36c)|Jf}IpgY*Y- zZuRw^0A|4=ivtvI@#1Nl7kWZxk;bgc0Gm63+%Alq9Agv)U(L3ZS?e}P&ONKfOK)}~ zAAWf`559dU_w1$J0-uDzQqghx)9Yho<2Us2@uLOuw_v}>mg6RIhL`;1(IN`Y{rzw& z<1Gi8JUyg(|K14co*t$D;>rSHxK!A1!0s3Mmy7$r!+r%Md%)U2Yi^Xx2rW-47Nh~Z zEb86AMK;J|za15NTv~~5=XY(g*h4gVc;7sm=WevGbvP7CCT^`N<%ZaGPzo|b>oF#afuO=~E?IBp!+B`>o_mid*`&Hc=x(VB7xyw{>)F9+@ zTM_4EBjJ4U-W{)3t)#=zl5UxBMEu;Qrpdn?OQwkQxWC3%CCP$UZI8@SE#VQoEJ&tev27O z2`C^2wRbfp1`iQm>gt$T?|&v3m-2ScT`MPbc1QKH8-)_xR(!|lIo=R2j%6KaRU9P3 z$NBaj63ihyPo^!j?T#lCxI!X5Q$vX0ftn9TUmB4I?>HCu2<4Jz4k(kN-tpwMPjSx^ z3*CwN5pFc^Xin;hzc5wlHz%)&9d?4s-o*D0RT>g!!-$Y;ISSdE_sDyO^tXa$PZG`{ zg&m)-m=QFl73;Cr-w^AuDG9+>1Ie8g<D@V@hRN&BX@?1-pKi+Nba({zj^)cb)swYU+&32reuVfOE*K!6Ebvh`1st2HK`Wc z!>~bpj#v~e^?EEMM?RF@-7@|01W9*WhfrU3)5e>|_xy7hxw+ub&jTkE9B_ z+Qgk_OR7n?mn?O1ktZ~0d(s7^C_ebB+mo`Qq$`aTw|zQ0@n&DJvXyZyj#}v?NA2pd zpUH3WG)kUM>#Xf*rFcpoEa$CLI+NZw-|u_Mt81)MtpmZsLCNNuOm)!So|jcb z8^ePm0=Xu72>v@9zh&fzAQM&JeWz54|Ig@jjLaf}dP+)xo;3*0nu++$Y9OffV#L5h z5J87&6%!5<66Wt#W>g9zVUd4KZ0{=sqk{bhtp*XC5T{{y=z$;LV-xCfcYZ` zric};7MURE=LIj-yhHG-ZE4iq0TPsCTp_rrYjpceLVS;Z`W ztA+|^HLF(|E1@ETvCt*Ia`^mkVebz5G8i_X8*LR<1D`e<73)2#f(^EM#eW`_!?9O& zz0Uhf;ihcG37_d=NGry#$~{cUi%9CaM|`M&iw0x5yNpWV?ewDsjE9RLb4NS_7Ak;J zagSv7J*b3hGrL;wnF`1!AAZ(XtqgVxyIIbs7QyC3wr+c?Jg9I^ZnL_%66Of#jlD^! zfKChe3B zQQUaJ%=Ki5yj;HRVhDiumuUZ0ogFTxb=$it4#Pr)b)L|UewnXI@xA0LM%Lz<*g;=Rll@c} zuFAM<*UXWFd8J@x8Cw}1yYO}T%Sa_2`f$|epw?Nevf$}>{%Itx`9Aw+ATl2_@{3oO z2vp&(u7#_nR}r>)glf(dIp8<{w1f?R#^X2FY=i76d>pHtWsPs1RO7A9n4b0)jP3UI zZe%G?#u=vhi+Qjdzxpi8y#FGJ@1C*Vj0tJL-yiF>`tmj7REFn0=j}`Jxz((LAtRJ^ zC0PG`l{UgWQLkLC@;72pbEm$Ugk~IR#?^W1eI-6Sd9LSzVJ%Ks2>x@&zaA$&qORrK z(~Ng@R%-3$ZN(pJsQxS)BTToji(EWVk7a`+zSi+JYgjL!OygK*n zSIZZS>!@x&&iP)Cn-9%>rW0$yYpW+R=cGHZQ`zNTVN_k%?Oa{e1I}h_V-fWuIG_c0 z_`FEleAa?(C)-WhZZzW#CZo-MwKycxIbyBbpD)rxCqyCfRf+A!AwqvMtN z7OXyT#qykx`>zvI{~B++$^H(< zalQCvNY{&dQ!f?vHuqw%F1@d%xEFIFs*TO_P1t@H%Uo1a6W00Im!&(?go7VQZH!X* z0KEJgf6_7=@e3vaEqCS?Ob|c*a6N3nDeYUt!H=|#j>cEB96}xHQx8twR)GEx(+ptFV*v37%R?I1JNN9^PPDKTQng-B~|LrYz zrlAOK8FMsEKL75-Q0tL?{f!PR|M{#2V`(pTeBYpMWYvoU4oP3*aP7g{K3r{b2j5}Z zVHPQQkuEHHa!g${qY*Rc)6yC~qxjxlZt1wm*I@Z4Vk+5vCAfmwz1S$V5G%N~6{=S? zVF@ScN=!N5=s(^uqYWc*U2|bh3WYDgB{}@SET$O8|F;}|`B*F7u(TbzO*G?|s*-lu zx9c&J%UK&K#~PgLx~FGTLV)3V2bNHfXmNCCqxk47Pq3FY;i;=&ulGV7mN@?` zV((89PcUBWUJ&cTwjr?rVfQ+)LO|)YB$`%yAULleL#`3O4xF8uVXViDGdDgPhZSP! zP;S1lZ#nq>#nTm`ZPD1TR^yuIq&M6V?jR$b9t&G9M-Esd6yrJ10I{O9JlxcIOMKfS z9-k^MNmNy~hr)`nJcrYw-~*4TOD{Squ)b~U?fEMu_|)4E&}4Ty9+R|Y=K6CTYgT9P z;V=0Q`ZLc)xxORu$rr3yUzaNJ`G(CsbQ!srWpR%Wy+9Doj#M0EnsA50Q%RYg4E6Z# zvoxxztF`!?b_l!36$-atcE>k4pBVhwa`kA#@|Rn=q{DM5m07l; zMKGo53I+9A4x#!>Q(T^QTpD{q*^##?bk1J&mC&k z#aMc5#lef8TqO4VD1;)~V>J7htKbfkA*sl3B((NRlK!%B3Y+Cn;=pmyu!k5n{hCn- zLkGQNFPy4|PXiJqCg?D%%5<^{3#@@}D)o1=3)I5H+%9L>&tlmBa>Tz;tpVzB(enLf zY=pCuY8<0I)$rv~P4#Ld32*n`UEn-h2W!DAA+2i-(A#*}*X45~bj$an?v0{wIG&{( zaQsENZsBGg5{#*bp&zeq#4a?##lO)Uw)V|1vFXO5?FPjwlj{8R#=SadP&)kQ-lay^ zczUzF_+K+TI-YMfbd2JCmJDW=|AXN96UWD&U#o|A-yHNsy?{#rd1^^mbv^~ce)W+>cg76`){q2F>- z*!Jxvc<*@Fw~3uiP$o^*rMJ5g%DDgen&I0B?^Pm3&HI!@!Kp8S=f|3%{C^<_pmYly zWcs)M5;ep5p5QzQ>SlQR(7Dxl?N+GDu-k#^XDj^NxAS$OU^_ICx$(3ls0|v3jq|%| zv_Wkm^3anR%I8@;T%f7l4v&^LM|3E4!qXRB-v9j935A^EAAS(+gcZg@317@wppVtt z2RVlup$1n{2F*|%^#1ZLsE?g8Pj3>bj45732Bu%%g?=fzw`e;li~+Mq6{4g-5q8^oUOjzdbVu<2I#>F*DkAnTPFTfHNc`H7&W-l5nDH~f#D z?F;LG6V{4V$LQOk{WbeHf8|@?f#EX0*+Wfm-y_BRnqrF2+TXAKT|^B$#Xf`fE|kJX znRebdv0`{I{miK^)rIf`-SEEM(UkM;V^cDX4hi$DVaNRIayb0e#^H!xF${}2xl75u z5b{?TnhZ|YLu6FJX1u!&=Fr(x?>=rt@NJ|U>zZtAdEQ3>lbk2A^fmBG0mso7q_P0&&F^S`^AjnMyPQUBktI=J|< zW^d|j6BP;czNv-@wH!shOI%GH5^ zxNZJ`VnB8QygGezowf5dym9#ZvprIA@aftOMPFBAc;J93@2<1{cu-x&bXuVpraR>B zp)t*ax%Kpl4{jyHQ)<>EtA-2w^HcnQJg*P#F|{1pBVGnszhwx`I2Xdi-!3a!3@K1> z_32kf8Z-F!x3O>-_zyeD4;Uxpm%$E?w3gh-A~<;>GemnP6Iwlz6A@(?2T04aXz42i*&?Zvs!?bA{*FnpVk} z`bGqnc^D3Vho|8`N7SERmCVD384Q@w)k4f=?HgsXAeB_T_CUOUY7}-`B|eXkiwk!SaPPsw2T zGg!Mi6|xvdOmd!dJEt;qAH1B9F8z<;wS4}qarf7ZsGfy<=|5gG6f~>?7dmD!a_=X1 z^?podR4m%<;_8;lc(I#JK5Hb6QMTfiX~=>MhO5KyG2iDIjGQC?6&X*wV00^4t*Z9? zkKv#+7+rqgHKSs-Sv6@{24kIyXzGb_`2W0kqMvbJOJqE=31v4|NoIV#WR#$>=@mnx zCi3FI^lOG8dloV?&R~ddZ^NI_-l(HlmwWX?OGO*xFhp1T{5e#vDV%-zqZeU`zFJL@Bl&&6j z<1Hh#g8hA(D1#wv<>FH%kjscR9z4rq1!&#-VRA)2qw%)X%=4N&MjB^P=U8DL!>2;w z%DHcO4E@umHU50eV|a%v9`Zk#%P4Kyk;XL2W&AwB^2*pRkD>Coa_2X82E#A&qKRPz zgHd>SRo}=6gHi8x>0GK(9%DvJF@M`;1|vsU?n=qK97f>uy`JizY{r0hb?niY97f83 z-L&Dud6nWL1S z%g|C=ns7~k!MI=B&?>B+&nS30$WrY0j&bk3fX!lNF5~g^u);!-Tt?cKK`}|!JjRIQ zDet9w3K-mL>}ylf3K-uaE_Ymg2X?aA-I(oTFoOHS(r2sS_nCCgl_|96Gu$7nkBeGb z$Pf|by21A?o1yz@eZKSFT!v%*<2(BBJ5-tPY-}=X3mEr=((QL#FJ%0Vsd(kHq>xc0 zJ*%o}RLEF$UNz${3;h1oVS6#X;&%+;Z9$ol{kaU^2fzONYYorkcVy$Qq(a8F2P@va zL*Xrq%+6%IFuvoCEI}uFhXiKKxX|(DvHCG-7QT zBXY~W4+(m}XYW23dBzF9yVbR4p>TK+;{^BI&1x&k7-7a!-&Jg@8OVe^=FZtVM%37n z&>z3vGvc^v0-_WO8OblTY;1);Gj{j(jy!x@$8e5MZ`~f%&Uk&cDdTKY4|+*sI*tFz zlW94P#!MQs|406hmjAW;|MXtadN3#%_g}yNJMKTd6k6{UjsN;hqUCrR|5q=IF8|j* zla~MW^RNEjJpN%Zt(QRKKfSlKoJgZCjh|@zr(a0R|N6V)NX>JSF8?=vBrPv=pz0;< zC~T$6eQ6w^ak)KJe}eAMla@v3dVgAeafZ@6U_;?6S{9_osio!1=csy77Yds%P}oDa z+egdh$Ek9$BNX;tr0}jKg$KPUblpjz#|sLXS18Q3pm3E3g&SnicL!DP%tPtB&ZGKu*P!H3D+=XUnn^zg@AeRU@}4Re zuBC8=FV#<1LkFoZf*Op^f0W^;G#f$pIppHhd@OQ2v|XyUXtgwhvAb6ybYLkXPsu!FX?K zKIrd9B0G;RfFsg_bOt4eY~mXVTet@$Zs;fSg1O}c|7+OoU>FG%@n-46sCyyuhplsDUmEIu;(2J6Y+`9jM1;CCLd z+&$t>(9rJ-spnN(&A{d5m(CKsCh0hWS~G9JCG?=Ollr zCz+3lge|daVy@={T)w3JGMhc%xA{9)VB~e1UysY1c+Ur6+!8;giOXGoeIK*~T&*%k z?+l>J;zZJZRZH##Tn}Gd6FdEK-^QN?Stm45*%44fa2vSH9%Sv*Lohh{=4Pz#$9>Nn z_qSpH1zU{CsNx#db8j!y$Mp@-<B#V7=<(D-9SU#(#uiyCnErdNC$${>p;&9lx(L z!1iq6)Um_(H)Vw`F0VRXOrF1?h%9+tokpWFxSvz*=GU+t;RONtSe}UzK8yQH+wjK` zqsVA}pDo~`eitp=Pg&`@E{sndF3RHmMNXExVSKsJD<>FGZt?FQ*8yWDt0pf3)@Q|@ z$NGIWBJ;4`?!snvEVrm0{*3##l(O6Gexh1~~_pZa$7 z3?4sK`>`9YXKffE`&ct}!#I|AZ@ub-^`?$=&T#_#z52pMEc*?vx`)?C;+vB!)_Yq1 zz6j%8_Sd9;HZ(-+F}!I-_IK^t*W{d(eB25lvj^?lZ}Sf02Hr_>t|q09lk=vz=qG89 zj6+E~=ODL7SkI!Km(-W9+Dp!p=6z+-pX~>OIoN*PlCz^&?~Byorx^1$Cqbz0L6X52 ziGH`~YqH;5U9W~<{eS^YvY(cR>R-ls@3ZS~VH`0@CjG9~l_nSvn@j9ynA=5Af1;gW z*~Jio>f91UZ^PPdB4^4~5R|LzrSzQk5oCY6g`mf2%FkK3QT}t&*CJA0C|;b4$KUUZ zh=0=JG$7?NjUxnGjTTemTsD1(^<;w+$o}|MJ4XCxME`cOZm|vwq9>_Djq?Uk@k3Re ziZ>hXQ>dj)p+hw_FUB`2jyV0G;)q=mRUfyU!f<+C()Cn5$1GLuC_!QH4256#28q3& z&r|WHJfG4JHlpftA5e0P{VQUpIM;H5iCk2?x*SW{@iT_9TTqT_mqN#HSRB&-Uz&F` z({cIIW~w}r<`4gP(l5H*erKxQk3r!bI<7l7QF0C4pDN8ShPvqf$|)RFq%hl`!ZlYZ z2WfPm_3zTWZ6Q4`Ra*Yn|52Kk4Q-|Dm!Nr?k7opd0C$0al{5h>xOXDof z`<~PKaM(#dg8!rUul>Jq|JnV&{Qlql%?pA#83+C$2*HKm6B_T+_>af` z@B01gPnx#(-*f*%w=<`)jIRGg<9oUsoG%$KoW^r>z1u0OT!=1jqVb;{5adWZ9{Tw{ zpxZgndd)Nr(dBIPzR#xH&CvD#=3hpahb^W0?WXtLINe@`-hZd}QT2rrls~vj-wO=r z{pfL?su$3qFoNFas}E4JJN$St_Je~o-}cC(?IJaDaQCF87FLHVN}z7!AlHlfaa)^Ws|fa;Jp@Ow2h~n%k~rwDPz_tF2dVB*B|M>e=^r?9z{gdJ;0OaxHWkdn zxMd`Y#CxOAxN3ZBHic4_T|6#Cn^j#R$K$dP+Ut z?KS7f{Qj=kNO;We>SAy)U>DyOGQMTtFzJV(oj~k;`R+X7KWZxiTCtvKvgKopRqumI zKR(<>aKwAiP-qX~S5hjjZ!ym-v|MS0%Z*qseZ*+PH%#WOdOfZm%OdWqNzQ-+C&WFm zoS2{W3iFq0!DmM?|BCz*-H-b@?kfHa^RvJdZ5^!lSigwyyHBYG1N5kU z`G)md56amQxMC;ZY28Gb7f`-I;=kmhjWC~?GEX@upTjMu-qzfM%!;H>dO&^O8Xw^h z!0$14j`#zb?LRda^ZV#K%9Xf(tGbp^ypEaEYuvCs-whYLHH+|^37p~8a za_7PKvq9OCUM;|(p+r`!S20)11+P=*Y3q+}fTz>PwqvZ^Auvw>?AgLzb!9%_EB_3^ zSSWvL=~;6WaCS+Bh$-ORcJ|>uKt}Ro!IgmSj%A5k09&oc#6)^2O_*=Yhf4WUr;`w*JJ}8a*@m8CBjP(+GBQE-Se)1*pcS%6k>cZ(B6P_yJx|_6@cKjHy!|#qDym zSl8frXo#QNgK<@R?9zU+6D#j>aC(y^QV2_^uv}%ahFIM=u+xY#gztyi$?a!F(VHnajwyWiYF7jTEvdkg_#5weWBu#?JT8d zypBSSPkTu}1zD3s&tYo~LGM7S-!?5O-kGjoC3>eq-jaH$a84qp_fc_LUhWwwm;TX6 z?3@zXO#J>f#q~swrTQwtJ0DDl-tI+I{2HF5{xn=!k2XY zES-nFLGv)hNornc0hFE-tsibo$$~x9b8#r4#&`ch>FeZD^#=5MdfcG+%dO?qJohzG zdWl?=-r`iMeFV)@Cup8{mgbe3G!KQtOy=89+j)lOqi5)H(SJOYmWSy3f-%iEFVW?u zG?vi%HHWEwpBhl8N#7ek&~~KJ>vOo2va{h3rN^MxdDNYft?2ueE8TwwjUF^Y@{ZVF zL(4z{i2N@v&q>!Wrpr6&apBMsy>S}P(YTq`e@NedH_+wt>2e8L{z>!lKYCO@el*{f zI8Dj7==OgMDfz-G3e)N54bF(NlWsSU)@yL1%9-aV{I{MSbiYy8sPg_QYTd5T>zaO& zDtD)!Bhseim~!fzUEfH_=mv$e`zcJK@9E!1seNP|Pn8Q7Q&<*D?W>8a6t54-8KTy0 zE>-^8ld=Q-pw6X&JEeDKE44qb3sdLz^dHKO$TmuDo}m1Zt39Qc9Y@uhxKs63OB%>H z5|LECMc!l%@iUu-sBt!gQRAE5pvKo-N1dCH^-D>+H(MqN?*8h5Lxd6 zB6vEN$|te;Qg-LBq2?WEU{C6A3aAo(8PhPAwExMV^zNl+llsYnFG=~Y;?*R-)D=$o z55q-oNc}Z$D&OTaTub6Xq*(@B!F$kW(MlpqTR$Z2Z|(0Pa@3u*q}{isNANohZWl^~e2){syyeB;N5i=MtWM;720i(IuT0 zBu*__&LI5%W>6}rmr?sp@`etD#5s6Q*a!{%(%Jaz94TV@Eglw zAw?ukhBj`X@`yiD$^Bw{8E-eP|70`ihsTjyXR)=Nuq zs>Gb=i@w%h{T#2SBT8KB31e#4mGWz0r7X>AV@9gDX6*wusd1IF3MdqD4}rgskXH|C$4>rn&GdyrK$9LAAO z+bVx%3ij7B$&4RmFrW8*+t=s8IF}2XFt7i5cDQ^O;HBf^x|z`b>F_|#F~EcUcV_~i z{CPLaYi{VLr}t!tIN+o7p*x?U{!^5fLI%_uN`BdR7ZCo(GUuKauv4&eTPCcVNtV*Z zb#UJiPOm-~3ia=o%;U)c6cm2_avbI*@%R2}7qBv#cq9(gQ9?yw-g!gCH@wkf;SnukE&|t8`we^r#70hGMdFeO2pYOqcXr>A6 zbl%C&egK(kQ1?GU;z(C2{|RTn}F@fx*PC)HIx5#8@^9zwrH#2^JQ~T+zFpk z)vEom*iP5HW{wkpFIhScdjf`DtS0x4!ebjGuzt|Oeop*cq|2O@!~tJ0Oa4;>oYnMt zj?dxS*Snbbo^7adyu##swhh0RGHIL(%-^&2ISrlY&w_R%Z9{DiQbPw z7IIHAYq<#&4W7ftb0p44KX4&&=TgxEND23#_3o- z!=!)KXYa|q%`B7R4Q7+ny(P_@Nyh73PVxW9K8oiLCZ8d8TB}g};!6Q_pUNH@Bl=nF z)ICW|DU-z2OUhfwIwbIM5H#GGK=f*rC|-~z6iepEpL>qzA6MB%^f*^!&;QhCQM9O_dCVyMig+qb)|s4-Qk`6O5Ho z_R7Dc=DGd?rB_)-q1`rqVo&S{HD8~D)cYnSnr~gvp?FVL))0A~{Ku&KU*a2T{hk+5 zyvFM)5mgdirrgVEP>V4wYX=?nm5K7;ke(!dR zwnMUl+Ap5k)Vf#+PX+W9?3khTGR>%R_Am;2|D)?x%fBQu zh+iC!TTbdb#=jCfjG`0BIp1jPMEqIQR$ao|^&LgY`0B|oiT*r!>U#q*7M@Z(-g~x1 zgqN$C4HN&On!AhilkL2h`1xt|?#~*95)zj$8pthHvAH<*DlB*acf@V z)iYS$&0%MTG28ck1CEpNS$alTzW*m~E$-LhtX&1}has_79`o<{+NpJz2N)$4B;)#~ zMu+n_Zu*3Hzro}9_F6u|e7bSol1n&$*c5HJAJ>0eRws?)CikBEMOYT<2y!z640iij zn+g~ZWk%ZjZC-1Q$E!NFsvqk$K2+?$I25~0k_o)+;q^yi*p8vXZW2G$4r*$i26>{n z`XJ8BE{$Dy9FHH)Qdfxi4ad!s8*zWBAG6CaFENk^tHAdJv+@;6CV)v8?TG5uvYgV zq5qK6HENE)^L88G4|oB*t(DWT-?bfhgQ>`FcNk|LTdhYW;KF_4#t6_K;m z-5Y_=yPm!J@jloE{{ipv3@2E>^XoZSW?`IDe-G~lJ2(om62*c4zwuP;p8Fg4(`@46 zGT_T)Cd%t4b77uW8v?rF-f--wq4>bB9#qo9TEdzGdF_Xvx4EYRZ*+zB2-ef}{OC*++`B@p z_DbXDnOfGSCJ5^|-8%8C9@cBLyZb>fJdb(5y~kJ`naIo7v#bd0O-zhfow%HdHm6@L z(}49~yf#FC_G1tFWBagpqe3tGyMA$aNj4Lmh!0vRzJQ4y+S)Da3j$srY$_Ibya)Z4 zq#MYbWTN}|TB565nCQo@#dA8L{bOMVnc$tkPuFdlX&vuIXSSDcZUTEwZ5>PG1N&K~ zJv-v+VZZDND`$anzrhKa)nIqKuWB7X*y$d7-m;+s-V3CiJktU58{+DF9RckOIka?) zK;GRU&CdJ)-v=gNN%`;@?qzPK4;Oa=PhP?KZ|@|!)ld5ryvw>#@B1&aAC>}NbrE=Q zJp=B=L1%J~48nOh>l;9r~ppo3U%Q;L(-+vtgA47 zvfS*2WuO;-QZcj@${hB|P~*z;7DfOUKXM<1gzL8_*ZJbHe=s)E8Vkq!bF++WdCsI@sry`A-7E zzQcXv>c-?cC|?xPBh3aFWUG32G1%jL?bWyo)}QaMhV3mnqWcW{!%_eFlGuN8%Vd7Q zekV9y=sV6&@Lj9Cjqh2!rZl{e1akNsL= zMp!*A*VrZZ8P9|N+@llNZ^cI(NyGlr|Km^s_9L8ok1WRVpyoce4qlgRu>jF+VCS3q zoho^-jxY0g3ob*sx6{_lFuGcKr+IGUQbFbd13ZAv0BE{_m+gyX=|?1f`ku3g~EgOSxtU=v;+ z3CmOx|6INLYOtTyYd+(G03LVB`eX@sxTebv zuaDM12OnM^r|0g^uwC<+9AEJ`p5s&Gy_kAEC%I4M{T?PfAp7-~@hE1HLg!)C7Fz-?7m90~hv$2k)r;^N z{s1mw*Xb41y~v!8;%6%?|0Cr|KXpjIRh!0%Y;!e^U|tjTov}b}36U)hyd(T5ob4~^ z*Qt1tlvhQ>5R^Bgz8~y!4}iaS~L1c;FnxQxA?({B$cXbzeFvpF#AZ-cWgI6Hkh# z78Fr>p?nm74G2~u_9GsuUQC3#M|DI}dEq=WN4$|LGiB&}3kp3QIAe4F^Wn@pi z*GjJ4Pwe*S(I@(hdg?pxW!cpIwLXpFueyjDpQoKd#%qdavouon-_@eNk5tj3>Raf0 zQQ1F!e~!}oNxu*C?p zcAOg5!JIMzEgfe_M#&`NTJ*pJ^#7KhXO#mE_IWbNB{eJptdrMzfux-j0camtvtyO$BoZf z?S$7y*xV=Y3!D!Ml03$$+S7Nj-}Bnmtclyt#LF09G*a}LkNrz8zb1U52Kmdz@@qIg znJIka!uh;2H773N@dNrr)$lk2Wn*MM%9noM#r(Ol)AR?9pR9ogl(AoKDp|yjzo$5% zc4iCqyLpRTE@3~+?r!tu1;mvN4Q;9TJ`f(Xek;y%Neyn{!+t%b>_;EwzfCfS)o^}u zQSqH2JReq;N%DP+UsghkF37(G%id)HZqqN}D+K(O?7Ptyuu0ceTM4j=$F)BV@O+hz zFdyK~MS8}MftT`ZZF`FIh}R3$gAM|gWQJHy0xq+)d$Ry|j#Yx<*fYSu;eckaoyuDQa>jm)l zs%QJygdyL3yvX&E0hGtb4J$c9KbH1dWuCxiByT!JC4pUw-;OrU1s-{5Q|`QGsDGin z{);NqFBN8Z*nr${cH_Nn$S=D$j($p7$3!2$hnfgN|0hn=SB~{To;~OLnO!-s4wk!2 zhozY4jYCf3y+PoQ(WZCDfrq=_O_j<3-W8X>{)m4zvXV3}WuuHHr@--XUj2iLri^eZq|6o;RF# zaj$L5%e&CRlwV(?iwDvCo$jUgw+y1TTPiEApYKOCg8EV0{&b`6Ecwf4-*&#QQE^p!(v)pC`zf>@7%6VRH5M4eaEm9S%h*NTBy^3 z%$6^7<37`Y{_gM5v{vs#4QwgvIz}MxEiLP@5A2nBdaK_a_CbKXz1$PnN1fvJs><+u z)Xb09#l3@jq+7-A* z2|T~WF-@^XwAOX z1z!8Zg+12^czM@D#}7-_cOoO3SF?UEx=_fI|D<*UPky@gZhesm6B(~uAbJhCaQoVOc+%^k6z z&${O8VytIZ^LOq?z#*-bTz{coetY?|2S8uXmgfk5Z?${yzs4jum#PjCc@iLRyq_WQ zA-)G4QAuK2!o1isxh|-}Igl|=pYILl+hXm|>pEB;wSii+2Idp$;iAj;2K=>P+yg(j z&p4R<$;$w{hq$=*CBplxS4R(i5P|WJ96igb56Hc5OR^haw>8@+=99kVj85$D8qBMn z=K@aDEEUrR>@vEs0Q=Jry`F9OzVM?y)B*E(cec#|wP2@un)lgZkW;JHsO$mk@UCse z`Ttu!Eeo+fi~C$9g}~kb$zer&-_Nk#D|a8tAH5oo5e5t`znGW+_;AMyP8RSpcQe*| zy@Pdoy;Q_m3-p(0%bR`&S;_xl5caRvU%eK=c@e*j8V9kzH?Wx^@pgGxB#Ae7!xpW? z@n-qePv@-wjiYyx?=aP`WW%S^z)$z7Na1+V{&Sk}zJm+=cH{iWEjH15?9W*bC|lzC zGsmu#WBv4#SsFNA=hQf|Sg@}g$CZ>)p&M9V-I1sII-u;~ zd$)1iS%1pq4DNSuT?)B3{HlG{h~taisu1;ODe{LGlBvAKU$?1|!b{Tk;;AYY7|S z@$;71M3DGb=Mjz3;z{iw*0WYOAn%2CAp;V}x!iVr!SgCy6uSi1d;fRiCPu9*=1h#z zdiy9|U!g(xzJrfC^5wffzsMmjj+%NRz<`O+^A(}sa{zdA`7TzbA zc36n;8E;Ns!gG{c{E7Z-H^slinSY61h*mY3XOc-B$vb-aQ+f3~=`o_eT)CR8&+o)n z7qPvs*&GPp*~PYo^m{TPjI8eg_8mm;t_{T}I}0e@cV?F2p-shsm#+xDB({orTxW>U`E zp-kGP>+B@!Rk3&pnIHdp>V1&=RjU2!u%kpTs)+h~%Fp7;WZo-{sr9##a3u9-rKs=a zx|O5IeAn;%PWanEEw!GJr>XDFTVg0)%Vl$ujLRun9EI0SK*X5H$|vH<`pxa{BkMPy z?nK7Z{F@+(_1Fwui5$HDbrP1lBy-7k8_!p8p2o6Wx%eZz-xf`nknd4GUI-%hNLx#` zGF;!ZyIuw3y`Bv&7xIi#Hl&jM zUO&g4?2F7cW%69F<<3lDy~`}qvRF@DR!0Q4->nf(zNgqZZzm5fFIsEJga4k90~K7x zviKF(!`Q!U=8|Z_{>I_A*Andi>b7oG4hL-TzDoX1aAuN)_@NCUZA-A84BOfi>>uWc z9^(rERPVMd#pg(P$;@-?U!AUG_v3!Tw{G8M2IydMlH)!2w>RD+^RS)aEM_|R93NfD z!G_!Qd9#r3xl1kl$7?`OmsP3)x9577ZiC0O=4Du8|DCE9+x7@>e0gr;PC(Y}t{T`6 z>sf9Z!Fk{KKS{R|0r?hOF~NTHTjzlMXNVu$9y~vR?P|TDrn?o;QET1tKEQyuuuO3n zuQ2?r^(lxS3&Rrib3pdKR)10k{Bo(3t)4!}Qvx?qCa_(-ViCF!@44cN9PoDrdY2vd zd4k@nYkZ?w5ZAICfBL=!zO|`;bg}+8_{+GFdDmc^n<8e5FfTo4H92Mi@v2<5KzrS7Il9~_wpDo(&W)=qd*2&~#5y%f`UYFZy2K~Z+DZ_ss;&I%G z;7haaOq8Jh<&mfi%;Q&Y!3&tr@c@41-*15jYyR3apOuM1(}kb^VD_LVYAbIqyV`|3 zTgoo`g1zBvS=>18pUu9mRXqmz#|+<>Lq}o1ABx?yy}A!+t~dBFXBQI<70>7O-^oNy zV+|S)Ax~(1`J}}e$M0yXK`QqKiC^e-_O1gl51B}P;DX}3`|w<+X0qK1Apa(nI&OM) z7zychuLxW=g50A&@b0hgM%N_vm0uL;Mp;+?eDVk#M5nauM_XnF(etibTGO5V$jaJ0 zK6WG2?^z;MR>ef3uN-9RUJoOqwA7Re!$IWRU7o6}{sYM}JF`YV44^r}ANoGq52Lj` zL21K}hSA(9>E2R-A(TB8iYlju&^)z}fVBoAh^6kmaa{Q@l01H#HO+At!Jm=8{IGEt z1^-GD9@x2_`Db6={94q3wp%Io!+$`79zV&`Gg;h* ztQISeDb8y{#{{lfUR&6K*uy8^Z`;~|M%MREx7W3yu=Tf9th!rJWaNZ&^W_$FHg@H= zj;VH(T(RYR-Pd*$HTU{-kyabpRTQqWEvyBJ9T<;JKh=V^O>9*466u8Z181ZYGP_Vk zv(V)_xYu}ct+tMXd&HE;9?SkJ$Zv}*T{HBf9Tj{Y~@zsP|d`uQ{>xaJm8$ zY0qu&uLE8yx_2yGg1-%QT{|C@v%ejk7Je`=nBRrejdHqVCxQQb^pt)I`>FoZ6IS-L z78GTaHC$fUiq4hKjl0s`fdup9JoP5Kkwjcm=N;JpN*12)lrvh;LaqZ+m%gV@0k-qjwt>X0n(aL#Pq z_2%&2&!VPx;|I`oUe!mIM*TXpf7oPiJ-*+^) z?*V>aef7}Q0eCNyTvN$c0sg@L?&VMGK!1O1pndWW_^!y%qB21Y)+;u3Mi$O_wfBIX z61*2!eEMQ_42++*hx4lR1<2Pgc3+jn%|r{V)j}Ul0B>CJRbw9b3#N!vfnPP`hv&%h zSAk!MT|b>40`u>zPC2av=hMnJA$u0&=BYJt_#UqJE=9od5O@b1sg*E&EyXIeIF90z%J_;JN8!2fJ@-Cn|a zbxNJN`3jJ~#A#+5UjN(Y_tpd682XoEWfT^Jzp6ie&u$s$Sn8ygUvNB7 z@(UANfY)EPTpjau2iL-AoHti?csAh=Xr;m{fa6fZLu-5N_jDQ>hJJ%Q{L$(O&L3E= z*v5@{^^VEDGCx4&9Tu@To^hG3Ho|}Z4#|hGzMfp;MU21S+cx2N zDrDw0jQM(4;?_p2=ekXB7T0e&)24vuZ@5YNy$@id@=_(t*W=guuEzBo{{>269lG&V5&NnxqSw+9M(W4UQGcJ9$?=}(xonFd z`OX(kDrDXVWXs9?ek*VjIoWyM{cLxqmkKs?Nfj{l-_P}{cwvFcG`vqbCLikA@ z7&lYZ1D{(3wVN^cJfD2K=uQye?djDnxE?urG~@PS1rIi2J==Y;dES5x885$Le{oF9 z=N&$8@^d^GcwF_NM@d*uJNmZ1&i%q)pXH;&$_|Z8gB> zS8k7tW(D}I=fNyKcs{yrIr;b;$@~uZiu0Z&|MC6CdBM&GgPB91_wrWh0_;E7)3bSG z0C(z1@-_fEpX_~S0riSJSB8DS-%1O)<*7rtZqeqf9e_q96~#XR?F^!s(cu5i$|XJK z$9hSe4x&(gW$fc&Nx(Z?_f`smzX@YG^8Ogam&vgwS?7VrO0-?(e+vDxpO-X91-(z} zPVNZ=e6oH`br;k>zjq)p5%PGO!#N*ogPzoG4~Iw4Ps`j53mRZN{}(mWd7v-3Qbj7{ z4}34Dt>xJZ;|FfuwTuJ&zLrb(LkEc8MhldyKY;${mBAHEHzu-Hp8xnV*zx|1s-^+- z|43Nr@A9<} zACvW!GD?}~n1#QUMnC*sim8H;AsdZNPKcpWEf({E=)-TIz+POf=w@=6CaOH#(8tIvg9%L>ppSc3q9cb{hVj1YW}2 z8@jwpWEfpNJ8u0mb_9J5ValsSF;T$pl_5b}Al^WcZ1#V_o-nL zJYTwz>eTNzx8H;4Li@MxlO@9_VQHFAxzZrw%F~u~o(KH-b9B1HXg7Lcoa{BTY6R6v zthwa6YZ#fkD}|3<973ZEC0o^k7RWCfofB$nL8Br zhoHX{qokn=ZRqx4i%&}qb)t`Px2k@1ccB&wyH$1bThX2XKUJRS7BtdS;AUpkiUwuI z?4wHCQDWZS2$vI`sOSF54`;br(M|Rv66xPtP}=x({n4*2NV)5ifY$tW6!dvV_hFX~ zv~^r%wXO^^0cO&~ROZFdx z`^riOAxoZlOmyp8gIX=d-Fa>ZXSy`?u^PYF#*wx__5&WGJBdgqI^P)IXSvXT$+k7CfKAdaEuBRpajybX?-&k^qN< zcYe|XJA-#LNqK;tY@p_j|DfDvaBt8OKq1Eqa>;-q&%6bdfyc6c$hCh4^G|FUUwi=c zbwm7hhe0lBnc9QDi*U)DIFIl9F`u|JF@I6DE^@_wKR{$_AC41&O%|eE@yk8pXcZbA!=EA@)TEto(2FtZeW4VV~vjuqD{r8V8cem!OXOA*XB9a&2=L2taGmaERJVRA4f<$ z?yejbhD$?Kc?@2mX&%sNM@FkgSQNqj2ECxwFl_^+G>`#$y z?!!*5ki=D~k;;wqNUm=+9Ryra0{6h<#Ib1%G( z^CWLZV_pz+T!8S+J1O$yd955-M)*)w@4?krPja&+4_-IbgxGVqea*W)3!1l8|E)r+XRO^yvWdf4F@6Bj~Yv9~s8`nm6_w;k64#dhg-= zobc(`U<4p*`1w7>fQd$H$nOp`9=N#{w>KM(R=EqfBTtt6{ra4cqL!QBw}kUu!m$08 z4PAx10pFdl+4>3a&LYoMelQ**{ZXxIJ@B~=ze*iJzF1jV{RI4gn5ey99QaYm4EAYX z@SEd_-|NEu0$)tqAM^_J9?bi5Hwg4rOgTLD0zDo#S=-y-hq){NyxB4i&(UW}R2b@) zG@W)=2Yo?3k8B_8fBoH01%q8#e;@ROy@vO=!(B^PLHmPEy2GbI-)s9b(HOvvnzUJK z;3xaX8*W_zKRjSwRmK2212onOw7@vCmZk4Y;6A?NjrobKFrODjBX>tFfbZ0eZK{U* z{sM`jTaJ(qcwCXVkR5o>hBad^I5soU!h)qKhbOy`=C{65x8LAzn{{1(r+~jQTu^7X zhKV>1EqXS54f^YTQh80K3&pTj3^+qSiV2>dS3o?Q{^Uz#iF#gU5a< z|3H7|J(g@iOjKIeD18Uwugc230S^@5yym$ZhWdO*p5IojlFJ-H>h=kX{UIMH#LZnM zco*Wvky3ZfDaa3`eJCAxJBS{$1Rjl<9zy@!&Q=>V03PJNP8$`#d*s|f_!ZS*bW`xv zD>cY}O{Q|(9N`&8kK<3Z*X4Jk;j*NYp~?Nocy?z}`sxv6@kMP7W9KkRnJ@SD=Vq1 z*7XfTsOzd=^+w3U#aQ{R=HY8aWg+!K96wvoW!7P7uJ#t>s}L#tWl1}lvvWb4vS$Z6 zw)GfCIXmQ;;_YtgNVlSurBa!9UbdiI-=EP(mD7N(~*ahP@_HY&oL0*pa zO}C*)_>#jDg*f3ojFsn+A! z+u=MMa9~rq4Bsor+WPBdjJKjEENR|hY;8y__nLc5UI%J;))oD^qZ?^kI4b>D3i$~0 zjk2GE+K{5@P_6cYHq=zMM*86T4y5sI!!}FZZq)Q^B=w6O@O!7?$~(aGF52Xp$>zX4 z#&zlT2H->fJ}JM_fWK@wt{asJJkhB#VQ~E{*dh4$jSK9*^$v%!su3{n&L9y~lIOo#a^tjXEJ^StjMgrQP@3m`c-CBcz2-2{Z?&)cT_L~6 zCRjYr7V>qes&#VD;M_@;$&GMezPKlUjvK7|xrteAMdQ##`-gg3h)pUj_{(I4I z^}O58px1p~DJu->U+a0E+zI-}rY#Ssg5I2y3BPc>;JjPI2m!2CaTLVy!CR+qH;z;M z2d%#0__ob?lg~E5*@0gJm=_lPe$wLzIOkln1&&K5oscdEymN8RDpSDT<8>WsfRnOj z-MGBWC5|88zkmEX6O8%R0snRWZ(;mB`R3l&K(1QZv}Zq{YU-!G`2G6F>P1;t-|51m zf{&nQ(-js{1@d2ijzFBRd+GAS6!TcY8zY`LKM-^O!yl}FBQRwbwtL>42f-K}ziahk zWSX~K!T7qMcP-XClpn=|l&z8PBk?^K)hdTy1?xk*G`Azsx=q@TA zztt!4eACWbcX2z9?5-ZXUW$fw2eH0tp5tfSujHU=H5qTt=q=nn#>|cdud{aY(u-J+ zH}^T=N!)Tiv~wrll}Qd8k#Xld9o@@Gu%e3F-v^y9ma z^&HY`&G0&y)-EM^Ns;+KxCzfuy1E?ipBQcR>j8kWsU0#{fAxxz0Ia`}=k7wRXReLm=7Sw6v{0PArqt04KV z>ysQkxctYPN5eSp6QuRQ#~iTfw7Lk{FSpakemV85{UBcd)g@-LSnrq6mLhyUIj=3W z#PfZUkrLp=toL8NQ3J!Ddb3=8kJv*U% zT=>Qpd@c<1%3AO}E=lWw;3?3XR`@dT0(ea3p~2S8P|hcIEDQUafR1lZzXEb+UOlOf z&;Os()%ZR-c%e!O-^;j+uYK$TKbVrbF6$`xuV1H~SB^os&koPvXW&QgJ=vj$|E^=j z>6gnsfS)xV=DyVfd6@IgHn-T|{h-1UD`P9j4;^aS-gp$oS)g`ELl68>w%R~VCHT>y zBoj@>Bs_-~8b%h^nP`)A=mK@{>j4i;JhY&{?aQV58$eG+xw-NU3lkYQYL1S>-+dfk zsd@Az_+JfkOAk)aYd%|Hu?O_dy$fFP2jZ2+S!3rVo=l_~+4_5q0~4*-dvWO0GuR(| zyBb0uA0=-umm7Cw5GkFqd(i~%?rP(H$DzF_

5Oj$oXt9Ri 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000020.vtu b/previews/PR1697/tutorials/out/solution_000020.vtu new file mode 100644 index 0000000000000000000000000000000000000000..9022a88c39712b664524bd0b962b57250efdbc96 GIT binary patch literal 19000 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000050.vtu b/previews/PR1697/tutorials/out/solution_000050.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e03eba6ae7205c036b1302e5b809e8dab19dcc5e GIT binary patch literal 19110 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

<49l!Y9=zX5#PTNUp({^obNhEGLnA7@x z2ilL=%1Y8-TkJxjx7Zy>Ft&7nwDStr5%iCs;~ihXFp<&Hvjm^{WfJ^R)J3qSljvA0oo0u{hEOrIoGaxS`+=)X#;Z3Bx`LZ=hDWTro_(t?0VAQZ7wcix3I8**s<*$ zCg;)PvNj^mR-Pr-l?ZJn=bU(C2I2pMoWbNA%l*KYjmLNQ_Jgen`NQK|1sGSG{Uhh7 zQTVESEPvkGKuY6~?rO+`;&K^z7#$=kE5YBEs{w1$w~N??MGv zW+0SxA(KH*S&UPXe6Y2Yn`PQVfnqfXYW-&6@hKvjsSWX9dpC>x{trFy9T&UA;uT;dezr*HTb&J%=gl# z0pY(QLnwlEYixXl`%z`8)OKSYhu≪_C)kQU`Fqx6Fns^Z>Ug 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%0D*r6>16{}XyN)?`Vr@9{y_ixWb1vJa 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 VhL3jcaBYMEPX;t@db*6k{{TfSSyTW3 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000060.vtu b/previews/PR1697/tutorials/out/solution_000060.vtu new file mode 100644 index 0000000000000000000000000000000000000000..ccf9fc5a4f3084f09b96b68e5d2768a725889724 GIT binary patch literal 19131 zcmbTdbyOVAk~SPdfZ)O1L$Khkg9Hc=ELd=N85{-~5gf>yc-q@hyPG?^SOXnIX*tO9P0XE@EmVNk4z4buv^?BgwErQLGPkq) zBjf(No_}om`?7y%_`Be5fD+Em#-M+?C}RgS{=0EX#`b?a{)gIs(fG$Upo96}p}1+O zEr8DU#;&5Y#*U8W4rb79Co_|JK2=e@2Q~tle{$ah#{{n}XkLO=p{x5Je{&*$uNAcfj z{aYUV?@$E)1x1AYKQSrtcbfl3=KsL$zs1+t3i!WqmYk+Ce~X$3`+rsK zA`<_sufGNNU%scDjXnO9wjsice|)|&{^#)-_aAf5jG#1-o}%t!$GBc|@CRneOp+7{U=+R`+L(3MIwP*-{6TN4cihM$Qb(MeX%2=I zO1Bx;hth*{fzf%Zke_e*71dk6%GQdMx+zSfdu*if_JvKt{HG=;+C_(DHPCsQOG2`2 z0$@EM*kkY8_TwaE8$lur1L{V3Blug11*Q+gIj3;pw6q^a=^1r!z*2B!MI@llx4e5E zlk~}e5{HNx zq`JA6aXla<`RVap{jO*3X{yE<>DcfwG9cI;@Y0b2u|@VkyH@Xhg0+_zz%PEsL#S+Y zQ$j?^ogg_Usi=2gw!{kegV54`u*%rvIHEM=AdXw>haO%kb~uY1O!#Yb|JwP&Nx+@c z8=i+GEs~F~!wmMRbEh~ipZUG{ zTwJB|rtPfNO-4s-Q*_OTm+cY$lBnZSgUfwhcR~T4j1_*jz9HHzF-TY4u!wrdcL0v0 zw)S1#rByyIXCE?nvdimD@2%UW^_CzUh=~-u(NqbAr4-cuwB1FFf{ZF93ND0t!1`5& zxKD)FJ7z1b38-+CBL~ZU9_la{>#<92YoerD69~L!IVxXrfLX3}_Q|E@^dZ|@pC!zB zV-%Q`ufAP`7Bx-ZEaOi5W3p;@7k*NbZoSffDi^eeh}-oF`$pYs^|bluD4Pjfc8<{O z5i0veZ7Ft-h3m(!z1GCk@pbK<{(S6`-(cK1ZEYJ0u@opzGoNtH=kHBSr%Y(myEO`ZVs>zO$czC}CF(lG?KD36PDroKi1+ zMQ7}KbMWx0M|OwNfw<@ykK^TZYx@r*ItQ0u=ZAZ}Zq!QwrgeGzb+K{qQ^&NmZ8fT_`-V@FFp}^ zn{%K!WpV1wRncj_DB-X3(Rd7OGyjffhF+Do%?||>zD_(%cu9abB~^DYKi;UR-+P?p zTosm{OK%?vi*Q$utVRF%N)^qYZ&pO))XPT{y&?MnRdV*N-Eu{2#GN&ExLH28TgQEc zgH5n1{^q+SzUCkh47uPaS^xWRQ}C%}#*9U2Uokz4~4dJnA=BB(r>KlvfHTz4%GoZ=dOJY8x}h|bO#NBE?a>oY zWi|ngQ|C?aDfd&+gDpw$i$I-PMs1z;KIm4A`EJpPZbxBwe?i-eF}U242dK?!7A@f@ zo78dV!iRLF?l;#}=^IZy`S4}RsJ8D@W8r)`;;G6SHk4jo3+e%|=27Ja3u8bNibaT_ zuohwont~uS+XxU+9tcefo<-9@0Ti%%qjf5p7N8dd(uX8f0IpFAv$v0aXoDbCEFGhT4EAYhGy^oB8y& z>>h9KQRZkA83>|9c}tPxv|E;oqFAJF@4If@+aK$_9H&%`$BcVlW+czYYlxPD1E$rK zu64D*(#sXv&#}rRRP(=Dh^SHnp`SG}ZbQ1U6mzV8R#pde3is?S5$Z6>p?4Ua{KiX+ zWXJJPBW8%ec0jOS<9}@D?cR!g6jhm(m3nZ z+^``*HZZ#f!ryHZ7g1fgEU1@9QJEFpG|eN9@>G@C^r*_mEA|-Jai|lEd_D{CX(KRn zcl+ko6>b=_rssxt0R>#kSevLr)7PjW#?S{3F2Lk{1N*vW-~746V)?7Rl3l7$ z^z9S(3NUR+zC#(s;}&WZ|I&+aJeEEFfUi3W{K|%(1Mj{E%i7j4zY=#j>>M1IHOeN4 z->vfX*ZDR?3H4>3bA;v8Fzw3qC-FHl`RwORYNmz)UsJi}I;)^?n4LC1`OsIGLPieS z^-mX2HJ>i3-3C3$vo*WR7|2;qUpg1A02;7;qx!F9DuQpK9oAWSSt9EQ`g21(zh1v_ z6Q}^vW6sPJ!%O z(QgMXfbAAp&v#@J_^Op&+_)U&b=-E`#o&+Y}FB0Fc@1V9pq=r z=Rzw9uSo#`sP|4q+ciVyKCaHwVWMq5?;_N$%q?Nxo2$tpU6h`$)f!_C7`r!U7xj$CY%mJHD2NFDC7_W}3vdzs{5VY@3j0@|4gTtv70 zH%Rb)7-bBPPrEg6TZ6H1A9>#TiEp>1CbZrf$39$OTss)4+B?68V(n_Uf2X;S^6s3e zTUNbkPs!#(BPw4fKHn+bi_Nf28BT1dC7I_mo|Q=vGg_zmXiny$qmve=F)iZy%1Y4}lXH{9*kI}A(jEO zsqz%mQNKmG9Wv9b+Z^C}^?K3RtErVo4v*BTDdv)3%ngp-j*8M0mV3|rBR0Ivkd`;Dk_L;W%ub@zo5<+FnQ* z1@Tj;u6O=RD3Wwi9*gU@<0I7kQhXXRk4QXR|5XQE&L9VNyusPA{TOo#{O)1 zD;^ZbKe`C>eX66aGHg`ibWn{W8ZFbvP_r|@E7sftFLK!G!X@7tQCj$}WXVdmnEW+A_>=M(ukVeu5ZgGtlb6e7@r)WLP560d zMj3yZ*|8#K4F?eHzFp;tgUHs%0aZ-Er~m|A|H=!s=#0&nwMG+4X;5rkYq#bkL3!SZ^UM3f(jx=UFqbR5Kd(lH^ZEtG=<-QVh6-Rl}oM?_mI9nteb8gVH=@y zuw7v(HSg3V2~$H%Qm4s!^Jo;i_z7#8UF&Gs7Z=;uu#!=;vT3-&41(i2HJgcv8$usF*KrDD@3s!85Zu)Z1HOo$TXUV#IRYIk<^VNZFxT2#^xZR!8@ zgGdrtL}YU0VBL9Sv?quijUOAslTTs{=HE}YH(hm($WV?d*IV(C4#&|R@%KDhsHNh3<^km8o#r{xE>Jz9 zrY|s-SPh6oz^)7%HfR0xBVZ|?bnl&?eAt|_=cCiBfO$Jz2lxOv6DPetF@TmK^+p%( zFS^luQ-E&efGx`11e13eYTJOcdy|_*+py!Gm+>GTK-i`meKaAUa1&)Pzc<<&BG4Jh z1y=PVT4(g?vD0}f!zE%P*LeyZjt?SF%XZHb%Z;kM$}Q^iLED~q3JjHYu>wbhmC(CT zChvy$M5zP(2yY3@^wP2&HbJVet2KsBdl`r?*)hYw$P$UbFDvji>6LWY7aoA`qz@!h z8Y(sGrViM&hT^C17ENS$@E@?I|Ix#y4)~tz5sL3*1%AjYnU9x(x+I?~UrzzDw`5Y; zRp8N^fQ}#cgQcu*G$uZ!QK??MFY!q=^9}MuSH)I?Io{l0z9k&RKFB_l)vF(_qPZ4E zaT2OFnR*KChNCV3f_Ak-Hv65w`U>7YL*E}7DwUxZ-}f87_m_a?v$t~u5CXP^{10Ul z?CKoY%zr!bhf~quj8ESkWLr9-pBiSbKQTp( zvn_g1$B8T}dPhSvGj6@C&MM``)d6|wMAEbYyG86QsUU8v3#mTtnQ_O9XTF`$6MBDffb!?w3nNjCQ;U|9)T^Z7|n$O=slwQVfiyGM(iipJrs|B1)C&W9RRx>cN#u6#8x}Rq#0Gls;(${h}|x5Ps;}O zc>N(HE=1TG+>ZBW%Uh@?_6h9W-}Y=?<#*@Y)AS3^jEkR9*o3;hni+q4fk-&pN(TVFHs&#R zF#mZw_Rn$X?%cW!qY9|nAC$r86AqoU<31s03 z#KsGxstF`c31muq8p0UqH7V=yvKy=*9}tKb_QbI8d1oXU%z=Z)O%l(Iq{c;{#*I0} zMIn_Mo0^iUoswug(sztuiM4A%xoa-AYl%Q;Mnh$xh}Z>3>481@@Ke5^xI~CN`zc^ zWNlh!ZD>Dt0`9TlJAzqzNCw;V2D=0XJD986tgE{et2?5rdx&D&cw#%;VteTA+kQ{k zm3L`pcUe?-_tl{zj1fat5o5#=gI^*>sr!ue`b;^txDlqf$UGcbr#KT1QooU;eosve z(kAKie?OdNH-vTEjg!%Zq}T1HH;%bHptwB3x;$jRJa+uP$GNQcwY!;N)V4aCnScui zg9|4=l!G102|%yn2(MxcuNF|KdaF>)Gh8LYQbo&B%~e{(Tv{z;Tg7)&#dcIJMpi{b zR?V4SMUq~Fr2C6Nw+3_R7sXNyo^TC%%P+E)8WiteMBX)2k1j7zoZq0hybf_D4spSk zb;0O&ChvE7$>5C3;6hsDf^6wbXz7Br=S;chfj{wvdo z|B=`){u=*z4gA70BfaAV0$RiyFT@1o7X)kwrhn}~{O69pM)ZHqJu_TfTo7L%6up@G zYw6d2E2FO%f0Yq|7Dz8@n23t?kdTRhd79o8onIc^DOmE1RkwvuL7JZVZNWaPT)}VJ zIKpY=@VrwNgCMlYU_wb;=7r=?Mho!XGjBF13p6&80o5OaQg6?An+i%2&C2d)P$=$S zU1$jLq6G%GH72BnyI7~L`lWB9`j+2In1vr5*o`)2!Q1ViGq zE?Q~|Zvxy{3RtvWaWsn6@?Ya;DV(XE`()3MUy*s;UMuc!DC;*)x$}e^*v^JpJej;< zMVnLU6%imA4V!x${nL6y%jfZg1YMs|%ndllB(ZaTjM=6R1;6FJM+wllw!!<+OtK84 zvJS723794r34tnEE|mLVI>Kt?eRNiV33gjb%JIL#Z?~hlr%3#9Zc&%+0 zYt^ylHi!UyTFqpOI};Og!FR2))$r@6)WG0E7C#g}New=|+A;UHwc_uI2 z@(W!P4W~>h!hLWqx@nQVds1vUz>D7sOe$iB;lxPp7jorZXSzy8_lU0Ctlg$ho#>3| z)7GA7RG%!81@8JqSt}JYOp8EnBDC>x_x!v28CPl4#b!I#L3Fv}yA3|hy-n?NW~Gee zQWi>p#DF98jP92^Ks?gAFV8~_LXx~*3zpfgC=@J#CL8!g6+yN?V4teK`QK( zR3XRmsG_A=CmM#KrX}}$@wk%Zrp-F6HmH&0d$>~(w@unD0tSWtD%bUMW(K^u{Tkc1NNpruz$%CAZa26=YuE(d^X?9IIjV0$X6@*Ff=W%ij6Bu! zYYk!|^7ZR)Qge(h5*r{a?y!(PGU~B*8)5-28Wh$B({_I!tnN5OF@6=xLi^cOZk<#W zVObK?QXVW}6n;<&v9n`)BNt8VHC?pZx|KGN2Qesk zSIl=%=;7Kb@ST@!{b>FO}e(HkvOXq2m`_18?BXODy-=tDR(}?V#hv zA)4)mHPB@fNtQgI;gKrlz`S49Sk^;J?vqiUmFXJEN&q z9_cJ_ugMH}m)o|nA~!++($YSm^bDNHKWt$5L7n|*bB5nGx9cb(()e+YHsA}O{-%!& zd2Fp6FwyCw@FYBQ{RI~h4%*8_qDM^4+ z<}Jgp{@Yq}53g+6O=Exc#qGyg^3yaCAak+l`b_%8x*P|h>R{rU1u=Zl^&sjL138G6 zK69@aD34+acOF=GbdVeBA!n6@7|7$4=3*TW=|6VXhEBwqBQ2y26amdQHRaqSrN4K1 z<9xY|6>{!*KtgPC7tX))4UK+Y*_>L%u!AWnr0sB>r&3$jo1md&hKLV5<8Nm&1K3GtD70f&a(a(AE#ZBB*65bOI%w03g#aikoCh|Oo-~tg@zq65{Bk24Pb*tT0 z?liID~vUf(}-bbU=5PL`p0gZCO3`J0Bw}4MOb$VU^ zxV8|!zwI4*_DB@x7Kg*|kT#=S%Ly3tPt`p=qji;NQ}~S8$2xtnvKqY=LZX&PTO&Xo zk6Jd9IZR`AZ+Ap-g7F@&7sb~RvhB^*M&p_NgfSl35DRQFt@t@4lMC^HAS;(Cn2v8n z&<(&1i;y$=L!29#cgNfFpSRIBvv{|_{4b+sGQNbid%CL_f>OGlkrG|x9rZswy<-KDNla$B?O^yPE+%WSxHJ|q2$_W3d;8d(TpM4NGBE|9 zdhN?vEKqsOzedG$OiR(JeeGn$KJRozuxVhr5kxMG1t@i^r}P^!s^V}~xup&mcw%tT z%)!c<$G1%U-WnZyXT}!+5+EMC%!?8t&|2lS{Y_WEcp?8>~(@R0p#$MM>Gy{@8tAPq>5oe``n?a2Gs zf&|bCSb*n#+{ATDE0Npxr_yOQT6G`Q#-A@Pd;pu5rZ}g%mQ2?Qypa>!OjY}~%$EE(V+0z+o0%oC9N9D(m3Y&*O`F7#}WrPL?e$iVwEhNOITrNg3^jMv*6QQ!U(%i?vh z8^v-(Ky~!%Ln}bdfzV;3_uPqgv8Df^a4@MwilN`AYrH&Grf4=BTrey^GSE`0o@Qj_?kVmkuN44}s|*Eet)_L+TgR^&LbUj|o`P*M^O@SC z^V-gkWsG2GqWp!X*^bF)f=x&aW)`nU26@^eXfzg&TN zcC53l5D@$UY%!K0xHpo@?NYJ72u#l=F&DDV7NcshiWn4QS+VQn>>DX|cQX@j*VncY z8sh77B^$wejTF?pwl;^dCKxdUHi_UoGB}-TL^WWKPjy6;*}4tx zH#&=_dv}U5i(13l^a9rJ@v?==-<#+I^PUp#TI)0$l&|Fk}v1KeKh1A~WaCj}ued*D`U5ImVh=#BesV=Wwk76LFt-k?rrOtz>Evz&E(;#HisRqn!CpUg z%Q(5PSDSI^V%(hW@gNIGXoz~>>W1R^?M-K6Zy4^lnJ-h!i*k|URChP-^6h-p$T9Sp z31^#c64Nx@{`y&%EBlvGgF5W6nO23%Gm3%8taZAE^u-ybvgY+Sf;vk`0DtYiFPL^Hh6rD_>w5CH_!LEqOyt>>C$kk z6rvMg_)Dmc$$__oWCy8=f3??F8PgqwY_^pma8)f=P&0n>WcH+;^ua6KKL#&Giz;k0 z*9U9R3%{AdEB$w*80ESy|KxnHQHhUt6=z@e;_HfYgg;GSUV?{{6r+vT7lgYxJ(~0sZ=#y-T@dO7``#3wPU`W0raw zh6>X??2WYw-n_D9SX+4!qrAJz)0WMv zr@YkCp_DkfnlPReTi~t7A!gEUpn&}_&)a?(*T|pTyVzPu!(f=qzAWjKo)I1QDpA4N zj?$F!>~R00A>|f425SAjxn=d7g-MR(nJ?{Be`gD(>h*Znq7}BfFhhN-44L#zZL<1o zpf6%iHR*qs^~pik=A~bzHItXk7Y{Eum55pu`st{m9})~Tx8eb9K$>#L9zP^?nPHf@ zQxFdzM-a1gt2=Y%>Hz7OrJP{SZP;R*HxZ=we0j7lT|%O4ld*L?NT=w>|9bx1oixZ3wb z9#MHRZz_IPs#!I$=6|T(F!sK!d*rkG*l^Buu*n+pK8z0?riCUfvD#xZR2hfZhnGO* ztyJOj!AXPZ_vGHoZp8&xMDg62gP#dhvrBllL2B)vhAWmOt{s;T=w~`v=-LUQ)=#m5 z_hdK*_Y$g*`yMmNdW$JD27c?;XFMnl1P~96cN!I4d@KonNpFIG7IUuW8|GpWeED`J z|8+oI4N^jO8xirn(fgKNtwS{kp_Wgs598^4(K+&ia#pv2P{JCeJb8HW>g!>o3E$N; z!BK6@G*_f^|=NZau28%rG=J80S_KsY~ zn&V$oq#av+rZ_z1Z>szVayjrq?%iU!wH(8VfU8@t2x1Nm*_9A;h5*N-QlfXLkGRbj^aog@_3lK8;~ahEu0k_ zra+j@wyWAJ&@x{nQNBNg$|vU1tTX zWw`FQUBg5_SgZb!WBJAjll(!`o6^Z(6=YP3Vs&rP#X;b8`m?gnxyr>tP{!>u#iYGs zk)QF&yPr(PcY-`!_3^7m!jrE;-1jSeg<4j z{p~rSGK%mCuyZS)rZ1f$$)eAw?R2ZsLwO1=p$P5a^IA)av^>aefC$15MD7GcIFeR( z^iJ304in(-2a)+QmUeHdVUsyyC|g_}91Ob3yrf%PhRM>5laLP&*`OHeZ8Lo4pWS7u$r`w z=_WqDufy8I)Xrxx!W5!7P>=fx)>B@jk9tPWQ*Ei}Ql6rLk~FVvMLk8>9AaZ5y8(@! zKsw!3SUV_Zeu`IPN53!(CgIJZb?tQIH(cX~`e+g}L|flcI-+Ml-3!FGs%eaXuzNjn z(YBy3b1An80~#EY+m=40vv8_B#&fU#?gYH?pH9Ft2SoiR!}cjENgoopq_x~sU7K!r zNpS{~7^f3{l_t#=t-L+T*b~`%^ciOab9w76v7?ws>Y`Bxt0Q%WUFO&wz`_H|fB zYv38Fy{JXj>k74O{h$6WA@fd zPEp%)o^dxQxjEQ4!Z}~SO9*$D>2q|)1N~p!a7((;4{i8umOa2`CW;0_Mx#RX(iygT zp9K3ZnBtD|;I-<@T6YNGOC7IcG;yfZair^M+Qik`zA*FNAyS&S=2EzKTa_|}mHGQ` zeoZ|IAviG&X=76m38(vM%ObP|9gt)$va@P|X$|sr;c6PicEgJ8>ABB2sI}n1Vqf9I zqHmK?L{y5_%Y(U;T_tg)@#+?}S8x(|eeJFkl_S?>BHb0U(o9tEM2$tOt#&w6c_@1_ zG2}Vv4h6+2Od&3H6k*^LmwyVYQz_?ZexJH{Z{wW~MjHj3fgAOypQ%VI?9%`CVM_LR ztFnoG4GsA;kr)Zv2_)e=>GGE)rZKRG$0imUl%{uqa8#_3sH)!x4Idzwg(BQOpZigf9xJop z*}RPDE>^d?clrW#wTHr1^gkEdkRBMGURKiH#g}?u#l1|GB~4(AK0{9C3H84P-lUVz zDYsN+W)>i3rE2@8T^`g7!q7;{xY<7{E_JMpeP%}{yPbP}d)@GHUSI2@zTEBh4|W!1 z(DtbawJq9X!tC*vtZUA9n1H zk*6cL<;Ah#NX9Nkm!Cn5&ZzA?z-7u;`o4_tb|mWZcFSsJ_T6#AUY7b?P;2qsWe|9v zRr6U(VgAUKnH&%d3%Dn_4b1i1UlIlpyUV_`U^GO+)O;;lng6t$lT`cWrpsMHS@lV* zh8tol2`_K%PeV7j%VW96T+Z$ybLwvn_1!LGl zej{c4;B5v|rEw9*6aVF3g6rnbEcRMLd#%X_3D^rIGoM+i{f-{!`uF_%qUoo6bF+`k z-ZV#D-h_Y8;JcIBETml-f7~<#7CTtrv%LBZN)57r?q|fw82-pIg{yRL#V8vcav`#t zHft#(Bx)NuMCGKDU3o030qyA*x@W^KTf8Ul{9KryT}_xyra&V?^3b1btV3~!2GXh= z+qlJ6m9f6W8L7)O($_-7Ugyj+ionRIMy8ueCrk_r6~m!ovH}-wpBeVGt_RHC<;tWO z4>T^?TJcqj9nop6hf9U717TU#c6%`dA(*O_#0Bqmbi!xA^CQ2zu8@F_%G-=FcAlxt zSN97}`ci&mUyh856kz3iM`heI_T?e^$DdS z7rcOB`8!4J2WVyNfb9z{QAZCTwD?z2f%nYra;9xKri;o3M<_XUmc@ zEIpsRvOE;^&B}0`Z*5FYo4twH#3QIUzUbvsM(jl{pr!NhI-DxW$ zqh}5$n)Z5{t+N6Q^7WpZx#t<3T|(GB4L;sL9UQH{Vza!?z{#OZLiKXJ87~k}W@Txp zL(rNR?q&YgkC9JRYpnlZmBTnXT1Z&wGRFu}%wxqI1b^VqiFi1W5WNvAS)$T$s%0-^ zEloH)TWQ%j8+cAVNRALcugE&I*Qs2%QHi+h`SZ_*X6y&TY_tLfqb9jlWM5#t@yHT_ zBa}^fE|teHjmqY8W~HOAsLZ3N2S)vQwZYAg)iR>itDMoWLwIKEwaDRk_S_{`ggC7H zP$bN|3AiI;KID>l2A}UTc>mx*(>&f%Pme%29U}B4pQrLS;Yv78;iJ2T2n(iCGGWt% z-kpV|cP(nGqYeDdcEU2#&6n-I24t&r@q4~>QQpZzc!gidSAfkkXDRRo8L+g4+wi+UFsWL(J@b&psT*-rZ66(-eMS2{MoHoat%41MRFh~! zzZ{=-zA-_`>rx^$aVW%I#)6>t`exW}@`YoC!RfiV7m-7%!H4Ura+7^ZDsa~}cd2_f zw(S*=$@l62%8z@Q*LfN)*_*ab2XEAA4k^ZK1=bwE)7jnyN<`^V?5{|;t#OKdfQjc# ztjgf=xZ8b)u`69@e`A_9lr;dU0LuN^m7O{7wkzYqlz2SQ+**rQ6MsC>X8Auua8dU4 zo#iW4k}jQQ90QlQ=BpK9hbtXPKC9+ww%BJp6ovPb#LQO-t0?&tDU)XGe4CX^`R3*LOVO|)+!?MWM(=y0nuJ# z$2mf)^E+hC(T5M#ft$+B=Q94&u8*ryntQoaIz0>_WRWBs}vCgEsr%B z52H8u_FCtc2|CXVJxxtkjj8RG*T#46Rss;=yI-lFEEeSrmylBRb?xd=+@oh@^%q|f zvT~9TcenANf!tKYqI9mMU8OW9cIW7gU`lQSRH*osgJ71S$1$kpcw6TQqz2QZ*l_74 zx>Tk0eegS1W5W)rlGt8fK5}1k8YD{3lpMvgMVm8pL7u%Yf=PSG=VJUHDaft+Jw8pj zKd7y8?=@Muer2BHT?)K_*uG?!oAj==jiXa^nY`(DMh)9Kwba0M78w6?;iwFG0i!_p+Q_2F)Y_H=w7moRHT((ny6>^Fl5|v1cQHIbq!NboCYSLK z#$n0#3Wp384tB9D>scLndxLlFk8!n}oE-ZyK{~A0TEo~u>F0nT2crT*khJ2oiV^vq7qD_L1adSdx=+h>S&;%)@Ev=VjH1N$Nwybebo zY3O(O?+(B}|L+r(WRQTSE?FN7$=UsZD15k=~cQ-glmL3(j@pEOCIRbZs0Iex`#Be-=^oMzlyo%cGbi*L4a zai1lq=|S~CXv+%!sg+MqE+E+5em@`GZ}N+pyD-amtW4r~=}-&U%z*USPKp+DDFmzt z9kTwB3glb;_+5q7_OWKC=Jj`3UF1(mW+W<(BvG6Pj`{1hlOBwBv`8-9kG74D zXx}>Fd=zhwl(ZREqw0ScRof+of5Qo)-kJzG!emN7p-ebu*jig8*x`G??>e*`4lGf9 z(*}(3WmPa%nBk8G0zP~^)n0H*nP;%Moh0-ty5Liun*#$d;Rvd&vBHtRen%XY?DABw zFBhEwGJ}hrj@HFkNWYu&t8Efadd}PLvvu{>rBE}2XiLb_yf*Wzx1Dq`LrWW$yd^?cgV4P>Lv_qMmNm5G1lnh$(I#Q zW=qnY_MI`a3hF|-x2h2}0`M0sd(neD6g=^-Pa50r-bb&;OFf$!Tz+AKb9cy$&^0g~ zCV8_&qYEbXa>36B#_AkqjyGcKjLus6y*;f);1{Aiq5ZKVgQpaOB6&oKOJ(+(lLwB^ z&Z!kIzSD92b_2iMw4UjEM16@yWx8+I{1t_(B;FSrb>L>GG)nA!4o#yPr*p&C8uoy( z9!u0lqn2T7%ZL{tJ-(@=8!wmbB|i)0A%*TojF;$0oV^hS=XYiYQ9$I?_d>67etbjo`=JT01P0 zc_0|p5(#`*M4zbn6tlu2vAZ;<6PUdltNz=qPa?BlnOC~5hX)IiF<&U5h=rgi&5BIb zJJDva$hoDAbqm*^;@;v#8Q(!38-X z%KnCQq(p24r>Wr&5!;b}UIT(MWu9^?R1mvR@~`T~lE(0}rlUER1*!di-<0?>Dh0Ny z$kz_0NZOyTJ~U{(){@aJU#bg|*%n@Easy*%`gwvtBGpot5tUxIei*AZ4VS`4)&n0G z-p@aL_t&}%r^icHH4=%lsEzf_XZf)9e1u0cC6KzC1>=LuF)VMHS1liRO&ai!5`PnYs-ne&6qdg$vfwVxWiTff z9@?~Zt+(9-a%N$kDKA-#Zbh@JF_*Z#dg58;y!}WVj*D5x{2hT5w>x04dIn#wrIuxP zK+P)EqG9LVg5P3LQBmQYiU8m@+y{FjJ6>vda&{O)#O|FAvTnH3V`PHCk|LJr_^vdD z8}wtfa-~Bwo=U|^cG<_v(~EaCZ4Un@J_f=0A;gb$j;VUX6m*fZns%%1dCKoC<{$QIJItAON_@Et*S0?^GI`xO2HnG2_eUjb11Pan|bB`#u(>N(7 zb7afOR8WXx;iz=tW^xFNw>n@pX71#XGdi;+4nI0#~*FB0%ULLe2yV} zn4dj$=RfzwQ0@;X&&p=7CV$1Y1uYZ?XJ?62KZ)S^eXoVIDTT5hrP3v_G?q#9QvGo( ziZ#B)HXY}%h}CSJ{f7Y48ReOB#4qxTq~vxM^LU=R%RZ%3jP!~IrBjbt)VeC{{ai-l zwchqqPh2RZeX>w@AaUK(6rU+wL}9tkg^lfN8A!VXh|i>mvD!#|`~65BUR!O|K9W4S zGWvqf3BpUwlsmDxog6fStrEWz?x@B;^h+hBwlB-n6Ee<;d##lzd9!|)*scnYCXi@N!9&c!$ul+ZR-n+5tXx6(R2ECqr|hvyMxI zI87kj{va#Y>OeU3>&Y+k@WldD&-dO{CH=GP{Jjd!Mu4t*>z09)JoZ$lAKy5RLy)(J z{EBoIHE*9Lf7E2KNN#cc8IHm$_XkGHNxeL)xUO6Hj_A5X%*vleVVSGpy2<;+xDu4! zvU7w(G!jodQW4N9vXXg2`mT#nyV81Z0f|vgDFXSHJIvw#?T2_qOIpZD27ZPs2$!^ak zdSgn$4k0a7!06tB#SsBSAM|u-#>MeakscC1Q{+%~)^xd6Ad5{tUQ@iE&?ui%6R4O& zq2xf#EFGdx-6#jYR-)tV8`tQLmSSM-Z)F%+$wH=CVi6z1L9NiuBH%TTnQpgJ()W{d zlDcv%y$D}?`BlF?dE&3;z3DY#)LD*51rC$?479vtNBW4%#_s+=lGmFjN$rjz`FywS z{3*$O6n1yHEpdBALw?ts%Z=w)SV)#z+edRSOx5`7Z<@zin^8ff zspzHzkL8+;(gq~oOdU=1J_a+e{pa48wzni6bJ_obNWB(q^HiNo@+{$lf0D#@3Z+Rp zRg+%OI8yuGruZ(YzmxH|M=o(Fjc?lhQc1wHi1(}hBk{2b88>7x#KZl4&NDWigKN%w zYdV9)c7=P%rw9-HW_vF1BYMH2EUu^NZwfDG?~nXN-UGSsB0?|jp^!d%KrUnqgUOy! zo0)N9Bm`bf@%#1PB+=*tlvNN7FW zzk~3newH-%`vwgw;^IT@ozTfNl{By2zuJ?JpUgx~e=b!Ud2KlKxPdhx4lZ^O0IxIH?j&mS8%76$kdp!M+C$wvU|={LdUD(w z;c9-{<-rX*gq_CUVSp+PFR${yv;GL4gzvh5?ZLcvyxbpvVfv1Dp)L>vTm>K_Ed}^H zr~!6!JBdmE#QBx<^VlzhpMf8Q>M)p{-|rH&+@N+p#oe)UKdJZ^>^~4sv_T=@pH$KS zUPma*-43Awu=DT$Lma>-4S_m3!oepIAVA^|i?YNol)wF-vi^7{mHfMg-|hLOz#a;L zfb9`3-Yy8g|Expu|EEJnK~d&kQvNrxU+Uri1&^$p%s)#04?M;vRVkbR|7`1zIr#5b z6#v1ZEb%`&sr2IDP2qQlKm0P%um4O{d*YGHxb01XO2&np9$-dB(BcrD57q<4M^cwbQq#ZBxx z1$XY0s0Mr^j&=DDmJE*5HRI%SY!?$Nm08g@W1u%7yhneXq7%@@Yl8OADqL2)w?F@Q zE}nlnA_&A%7h(|4Kc@_SqyT{Monf(!oJD;|->n%?Glku-oN4N^^@%oD;}jk`q(t#g z$2U{qnKtMec62i{?H^GGSQWWCU*fHdFmCMZ_^?CvFmd>HC6Q*M-U$nZ^-HN=&+i7g zbSvWBgKD!@!)M9WBj|`;+}n!1cSH}ZpiJvra7ickb}Ia52!vi2Ax6O>kmKX~q=Q_gb%07Cp6Dst?ZmN874|*`lfXAhH zdFM;*Q@#kcl-ukr7r|FznL6sH0&T5X2%r4THT=Y*@x+hgyYG-@BZ5e>-UJ-aLko1c z3a2OT)oKd$E>b+Hza3rhM=Nfd+(jLt-;};{B~ZlRKHo`F{DSg1Y`NPe zy{a@>KUnC(!o#E=-TFRozl=_(oFR9oBu1kqk;Q)ySa=GE6x}jk;M5qh!p+XyQwPgF z*A>yUQ2oS0eT+uL_EYc{P8-YdG})ZChsf@1be@wI{G`VI=;8#?&r zS@nZrX7n06Bdro9&YGMv4?;Bd-&=uaR@gQ4JFeS37jJCl2^hIb&r9B&8P%6Z88J_h zSogS_>uu*(30&s!8w;O+;_N_b;B#YoTuZBF%|Tai-P}SVg}NKoPh-XjAEF)gz0WA` zG`}5UdvX6XUVBamaxwde8F;F{rY?(;9|A94Uz%_7;vEUGFUyeU9Mhk*A%9np7aS59 zOWdkZx-vylcFT~SC+9h+ft0kBZc9(c;0nfsdHPP5`;Yg|k z!!Uyj(^p31szUt^&%9YqwtCiH8Mfy1Vb^nA-Cg~=Y6XWU%E=l>7%8u#zF*2;?q8n<9<;Cu9VEtxrNm+!WpxE zeD2n$HneO;+>*#Om^~RMUNvxzrv6acUM`w!Xvhz6=BvCfbFt-So*$_2sMIMU7=*X&;Ue;H9y$Ua8GIMqkTYk)zx(wa@xGBjsMHrRW!(m~Sd5>3N{6?Z9~!&5x52SuUG=das<{6=Fjgl<@N-tmeWxwDq>Dz066` z5==gZ7X_mjAmr{7@}xT1#+f*h%H2V2jkDW4sYy87T`<0{ZnP(d2&EV`b2{wgqHdT; ztX*~u@>Bwbl9TRL)Tvo6D6SeI!Bi-}LSR-Yd2F9jP@k!Xpk!TwGJ`aw&E&#=X6 zk_yB5aTyA&gz_)#P+#S1V>DM0W$xscDvmbMrA%ERR#RUz2n=jb{5(RIye!gM=#jM| z6;tXQp9bgsE)Z(flnutdzbU^(b$3u@+CJlAjIV*#v`zdqsZ>(%PZi7{!+7vvOMI|X|?2C85PifP%>DhS(-g-nXcibj{Qw7d@YeYC~s zrBDDBI5#kmb4*n|wA>di_oSrJu=JxzKOc9AL1n%(lvyEt(r$D8hU~OC&Z(8xV9J)?Kvu9mCWArYJ#G`cO3o278PWI*f}h* zw(W&Tfm~-e@XyY$ACEg*#&_v(Z^h5XZ?tA@CC|#UHc%J@>sUqX0^-9_ElR1)0?VTG zs|WE_7~S=}g@bs6`aD~cJf4472QM(A9WhDj@ek=r0de1X^wxn%65CQ9tP^k^P5@omvb~=1k>AcP@@yxM7ZGNHowo+QSt~9|a zUcSp@+(NyNp4!1VpOmx&6(McxE9rw7P*JCz%iIed;n@F z0Iv2?#%9*f!9weks5Inq0-WkTZUu%dHQCH0-)v~aR?SPNpm#R6WrcIJ^V@aqG*21d z;;hPZ0m&9DQ1&j*-;8ZNeEMOb>y8Dc{?T|_ih%zhI`Yg^58M=eccW$ee#^cQe(%m3 zOuBiI?LtUHI(e`?H~o=G0lGQNa3_5AHrTFC&oQSFQt1qCDl1%54&zHraPs! zwRX$TSfHZ>D#5wr8$ye@g4qLeekb2(uP!M+?LOZ?nS7-Np7OYI+_GAmy(G&vzLn#+ zTEc^?cchDfaET(y=2)FePFKVKQL)}6IxZKDiLGUJmP#OxoUZnXW^&}K^YvLuO3+B@ z4!{$#b6wCCBJx#Q1JYCeB!%Wu-VUBOqQl8=i(gq5*KFiBqDRuLiw(BPIgpovy0u5n z5*!%6Jdd?%siQ5 zXU?)sYwzm!s*rX;(w`^ETn<*7txZX+*|Ce;-=N!q*c!OQt`g}9#@^5PHZ%en2FgYa zw(HOsIU2V2lNZ` zHhQ?bRDMXYkD7?DR_u8gsj$8R*_qnjMi*LVWym9|gpe?`i%uMbH)hqeS}`*Xw}kGq z+Q#gWS33nbgz2b(Sg7*hc$+Bu2@iweLNe z`g8DCojDHs^qp7GN$g~H=jpyN63{25s81v}?A#QvslFf&ExPBsuq@{>X*dwHWtt%w zn;ay?Z&M!{{5hadg^vR+T5&2=g-hAjsc9IlZw_=ik4!`bDaA9$bd9HRmp0+@xh@`{ zECMo55h*oaWQZajuPjq%=3VeSGz@e>Y~~oNJYtb=ow-o2+=E+7{wj4Q&3Iw(eGM~_ z=}Bz%xvME2uKI`L3Je`S7ehr>V2%x<%!7$9kMx7Kly?sr;m1W&x?@hRmuP^=Yq}J1 zocBv~h4;==3^BZLMZgkNVXretlAl`*fw44y+1i*ig!spSeVC)$oj2g9VccbEGt60` zEuA&yzj}8{M(UG;wc15;rmC(5e>_^fHKe45c3bSRA4IeH?VEn7Ks+u<{$_H#-jJ3r zpYO1ucdi5oMS9N`A($w{KLCk(iF5^^(5>POlw(6&+Mo-~HFSku%|xAxB!^sj6wYr& zh`^P~Dlxk5L@XxUaYA`z1`5M}y82M>i#Hc6g?*BZ*HW%yrO1#x~`V0SzHX zqe<$V^aaq?y&y#_M(_LMCA(PJGlY+xVvi)ZwfcvL(BCYl5>=J0&URLh#_z0r3~cCC zQ`utXQoFLV#?*Yh<_^0eXfkUNNXf5aj|j#;fJomH-$_zs z9?uUrtj}j54ivv`1dTa1V9y9^Ot=p6);X`Ap9$pSI1`q|(|--McVW@3qHVxZ;aLiX zXa6FRDQygzx<<4`gBPcJ4lbD=JSXj6W_RYA0_i&5wepnyRFIO%h+rf(t}aje#hN#i zX4RV%TA(?uoKeh4ccvQqDrN|#JkJ~QkgGeOyfxKD=DN0BC&;Em}&q$xhe74|JIOGN1R2fsX+eV`xA{kh9x17DxHhZX;pn&W#TDD?0- zk#egx{aYqy4_#~KUQb=+Ww+}&HNz$JexSD`2nguA(Zna#ydmxbxh&r>+I%0n%VAyrzlOhGcqP3R{+kP zOb8E*F#-j%?yxvmzQjPL{R|E_Cj=YZwQxZkD}tXoM%WdKosqMbHZ>#e%YcG<0&#z7 z5;X?Bj6l;a#0#l}?Cvxl`9-nR6C80P(6eM8)CEsxPzoqXDyy%w9RPt=K-5_P~3R?zIVCrjFi zZeXG@7Lcx;!?HC=v)x_7lKW zhu(wdej!WQ$ErZcY=A~CMtT}FdWTqY@4)h!Gg50iiNg3V8Bi0xDrreOzB9o28+_;4 z{Id1efDVfrqxTMzGecE)#tjRu8ZI$eG^EY<#uH*P=AgrS^^MAg1JIeA~p@q!juM$3ur4Dh)md!!CJUC}I&#VlEDIFv#mY(^oSSs^Y# zA;nN3sZZfA_1kT99Ze7N@&0bD1)QH0qS}4w90RY|UJnB@F-x;2NK+b0u^399>yzTr zNQp~9r^hoP=$z;Yj@$&WD#3}I)q#)Ik%`rb`h|n=3rF@BV8s_slqQZWCSX|; zr*nf2VuOxcgH9B34*YVC%yQt1? zQ9fo#$poNqf~2A$P{2@9Hu+^qT!3F9hzPZwx32@gLblJgS3VJ~jL54DbFGY7u6&kS z8ER1(JyIE>R2f-a8B5xu#Lb!>yrlAd9`1{tShqm7eDjNH@p~e;M-e+&x(x`xW?yH#^)(iXPH&!q*do>>t=%wFonA> zzwM^;?CxPv9YRrU&QYBgqgwAredcYpvuw5p&PbE@Npbjii1kS(E~Y$YPkEM-5^BcY z{N!r;OSd-ql}4ttkCc{;UY1?wMnCC|c8HC(xsP_PT*brko6dSW*u=~li90C3fr4;J zc_L7PC<&r10!9`IMPe0ni!SS8W!j6BMT-EUSgE`skv!}**CM&)BJpLcDn}6?2Uaq* zh&{E0(xRBfqU792G1o{5vr-9dbumYE2~|KbTR;g92~I`@W2Azg4ToI}hhNZ!)3v}j zTi~YzVdn+mm$Kn!oM5a@aQb-|_dJ}54Njd5V^4-tn!;F2iTuJgHD-S%{o=2|Ci`Q5 zuYt*Y(^Bin$Z4V&{V5X9kgKItH+5* zi}2xpW5@E1=9@tO`R{)ty#J0U3Q*BM{$Ke{-aq(xG?GVCMlt{3=bOfdWz%@_3B2~@ znCAGLczWiW3=L7`U;F|gnABM zes;dj9_~JTlPB=;&49vxTWOVto2R#fkB_tcUI#9O~~ zZihYpqXnaBm-K)CtDX?gZd-pl@Bi8G|ETsK{fYjo=djno&B5LGf3Ew7*QFTW68bLz zKHhlU9DJN?eGhm#(D6=!!hhqnaQE@`_S@y_=k2iD6trNJeE-q!f7W+&-pkY%`j7h9 zvZm7_+8xyU*RLSo6r5*YXEz7FiE`w>KF>l?zJ(*;h5mKV)Z=}g|L9kMslVIz|FpK= z#vPLrY%h}kHNV2lJYl~+z7C%M4bb&6I9F_!SmLBEOr@$)l+c!uTsM+JC(^?w=> z))T}r106ML6m4KEuRQ^N-URS9ze2r#|4rhFQF)?(o`V>lDlHPAE#dmMgZaZHijJGH ziI30Q$>U!Gd`AEEum30h@o(R0l{2mB{kKMOHT<&zi~i|1zhxBl81i5L|9@|On?Ep} z{$I_n998>2&M&%)eeY`HX&MjQiw}As#=#qyO|7r^z9WJo$DWolHC8kXJl@7LOO_@i*vHamX_s4+|9j zCiOp=c7=H33gY#5i`P$gCR461%+zaS zGyD_!0XW3;1H(U{?hpEHVfcPtKM{2d|CerW4ylh}cne9Uy`mQkPv$WE&Pfa(FcuAA z6Xi%o9`={vi!&I0^-~-en|$X-!#E^9o~aj2KLCfUS;p{2PZ)jW1vo(*B6O4CS6*Vu zwc8o$bC@ZgpMw*@Ar*U>{@T&w1ApZLLp9C}LIpNiSow|8M~#f0;!>u*#|x(1dpu46 zhe!sSQQH4nj8YrFep;`Yx=9Y<*P2h|PwID4`F8q2*d$LG#87{SAv4Y=51IC5-`=5m z4_LVJIAqjE+%aq-8!k=xs8sx5Z1Pkfj`F3UIKgaUrG+b*L$-G&QojG|YRW$nx(@?j z6Y0Okl%Gu&)ACsXK9uJ?KS0Z`Imc5vjU^5f#39S?MZ(Hs6N3#8D6ewj5g5uQjxX~j zV!5PxC)NMb=}z1EsNq6+kx7z*SiV7g53EpFKlVDbzNx__THd}1j|mR>m{djSwcYNm z*zO*qX4<~S{L@t4W^|s~Ij~6&wl<8fP&q}h@putM2n*wPLrkV6JkmsHUH1m&0i0r^M4$FyJRlmgiDY~mp$4j6(% z5@ocYBMw>Hdu-q@$Y+?;fy?2L>9=0f`i;F(u;n=9)ZzXLEWdj;_`xvH*M2YFVLM6F z%hqA}S$EO1SU#+3c?x-xQ_eP{fQr25S|LBa zFPjoe+bdt4z(KvC>`E&kDDRA$zLEv}UP;gKwLm8yQ>XU-n4{W-dONgU&B1<#r%yG& z_MR`fvl`_p*L|bVp0C|+Hlke6^;aO;5qoZ;{1C`1=W2%i1R6B>)e+0*UTV6D`mH~0 z`hNiZopsql5ajoMr0Sy`GUapjp!~3Egke9>#7kB#6F{EcbUPaR-(Pb=;S0$3whC@T zd(A%;r%nO+tbmFLqyk53^n5`6aBE6Y1W^5?rW0uAmH52Pzk#M*6ZnQy?OTT`+EHla zaRKMoe%pl~*zc8VXIDV#TfckQr%+2qrgp;V-s<6d#FzGXLGIr57Vg0!*! zooCw&kw#mlW+4??5C~^9huE48*`eM?k9E;VV0aCT7Y^BmrHQb{-qXnLdb7kex(5QN`9S~gx_aTL574V(4wG)HCXR+ zmCMdPpbJFA6S3ZfxF|T{IAn?4UqFl;qWmeFuK$#x*>F;@N$Hx`0N^;pTi_R+NBhhq zs<*o9E!}UHXF}-y_GnoH4i)BE`Z1g&uumg>y^!bH%T*)QoSI0#+hnCj;#h8Z;rDx_ zFHNqD#`#?HUG)g+32vQjhIH5KGP?i6wR?ha-CjCns*mGYEo}G;^|#*anTq3$`*g1j z*He$sUFwgL#BWkMDT(o$W4%PFpK&v_rGBMuMLe8vY~q;@+ZkxK)+g$}KJ6-{{%hfN zTdMzh%DwSu-!=YcaKgfVOVa^p!X^nfmQsDMx8NqBe9i(VIO;j%(c5QqK6I>Ln*)E< zaR;p@7Zpo+$M0{O(auSEBLGd<#3AgD66!s964QnJ*Nb|+NVNs`({?M@!*oIU=EHcv zv5C(!=KSE_&rsc%C@SBz5<@@^;XDSn4AeUZ+$rk6fo_4f2q>cbY}p7(1HwTJa-BOc zO+Xi9A%I|$+ugsZoolb=Q2Dvh52^gOKcgS<7m*L__dU6NsQMwEuNj402O!9_;zZ0reygG5wqI@L=_AMt*80)6QjNLGQgUGtQb)MqdO@E0mZ2n`Z|` z|0bM*C|`mED54g$=O0ckFndUCPr3r$_m{JbMjz-{+q_alGNoBkEjXxDLno-kEhEH z%4xGu4u?I}&*PQv;qh=NQaSw$p!bzmjwlS{MN?|-=c&DvB@Fa7GTGnvy8mP zh2aZQnR5PcG>A>^uVLg~rx?BW1`OY>%X!k%vY;sYMk>9ar^i3u*`u)u~u^gfLDt4&%Sl z7c;nDCjvX-kTZ>Ww7pICO!<`bKFVA5;fLZ7b7Nd#9Aa+`FcJD?=>iM{0t4WX<`ugs-)Od$mOrobrF`&B zbQEl2>gEO>flYG!&{1%RRZJmmU-g+6t$#QBA?ys;7sM4-0PJg3OR6W7K9$ywv@W82 zA{!kbo2;K<4}lE${hC|!{QD)8MBC|Oi@=8kzw3eynL~2wchh!*eYVl^T~Y<`!P%tm z*fv@oy!gfsijFQU7xFOVPYT-&O1+W zL~5u+A@XqnYT(&8!_%lIi(dq7y^)w>tY#{igJd)>s}B>=lc+(09fNou4Us zxI;N4vMPq!+pS>@E&*^`-x=^gZ1VC~1jQ+ZqxMq#KmYZXQj`zOdUBrH)m(NDafQk3 zeDIhYa>$@-J(hpIKIn$L!9sBekif4#ndrg>>app1ES7I6YXw)zA*Jr0dl8Sg1)d4} z1$6ArwI{_u{#*h@2f15!3k&VeIqT-74fLw4wbEyhzp==kbrPsc+Tf!dAZK~m@3R8RZNBvB zJ;*Coh$OcG^?FyOSp@R18>YK?p*;iWWMROxjtL{09=)6mXH*zc@xpbwKj zRyG37&AC?92~MWl0$n7LH^;hgX>nHT1~0OIG-iQMm*t#ToA zaa@PDtIbEfk-BJYEdOflvJ$^{qTNU))|;awXoc%~o@G!T)*BZy`!L2w&n3H*J_0q9 z6{Ydhx!LxM{J>)a58a7Pb9w>;{0bx=i_nTByMid z$9-X6`cx3tpQ2ntH;(I?4un&n$2UsA49B-PSi=tacUAo6!axN!#ZJb!Q0SS5Gwy>t zS*_d+>Ong;v+*u8Lt8gAi{sb;TJ0~vDal!hJvs-995Uj6F{o+oiAUL?#ztu}x=q|I2K7p>$ely_F;{goQZJ#?097C#D4YZb z6o=I0#a_Vqc%@{jj`MSB$agU_u z%!gm$v|KxV6zxyQMOq&9bKI+*qW-)+SLwWpee!`sB8RNt>!tdi)DR#+`FIF7v0rz_ z9??%jRQ`<@HyjW`U=R772$&|IwwIt=(BHj@(QlDPKn~wug24eZH-o!}@-dXAp@Fih=@9?i^$_7|po?WB8Df076yN$@*~djX(;e-PS1>r1L5 zVCRr|g3p=yJpA^maXcXXJsH#sgjzPCKMK zl9{-5Aum2C<7e~}F|37lOyP7zy;H9;C=JtR@}Nzxnf6|MW$=_xI)k(HRq!f+O$5$V zQT<7`C22cnbr_tr(gCIe%9VC8^*w+?{v1TRNHt(}V82ReCh!+{cHLEHFNpCQv;8ZXXpDqzMlb`kU4 z`J|cl#Z(!+Te%En@$4)`7TP_9(+76PU^l?q^1e$MPY%w6mX~2Mlpn|C2m1NZ44ujw zmjbVREsCLh8jr3#$kY=+^Ps*MPd{Ri(YwN%r&@ZEz$O+nkO99^$&`=q%AKw<>lL7SyNtkKBE`NTMvi$m~sVIrrfZKDfa;sg7$RZV&?a4HB-J7mo2ns z!&@))=q7+?2X<2WiHFk#br}8IYZ)rKmDy+EevsCMcBf(57wTOd&BPCXvYGvMd<=eQ z4ry8EMCpZbOdO&h$9%V^hnf9sn>gPJ zr}EKjOej77?Kv%vn9qTg2l;p3M2b(}Hr}D-88XbcZby(ibX}x=mjC4%@M+ zPlgoy`Qm^^Q-Mf{EggIO|2QbJ?VKLpMw`obxwd(6}Xb5hk|a zJpW}TjP%EBPhG56kUd1lm-A^2>}ZJR6AERpyf}2CGxFJr8Gn)g6AxDcz}xsv^F#hG zr!EltQK%O4MY|e){rQA)_jwm!VQ`4+s=`aCA8ui`4ym7hiY%UwOFtfXfq1;%&`J~K zHyuh(qQ2I<&x+Vy-p7em$XklWa}fuZMBk{zbF}&y>p03sxN(qZV-u-`$2t&iU2Z+E zfcU(?MC%gTv0Lwp0haTnTFykOeLGGC@khFY`PDk0x}*NWhlTUX>}BsD@Bza`?ua)$ zWj>t2xI-~#7aQ?gLF@&{_y7*)$mSp(bA4)?Dha$o>%%z{ff}`lA4Yp4rStDk1-@d( zF^FV2r=90omg z%bGM(ppve8Rv->c{p(wWxQ8tMT^$Sbs_+a04Z!27yC!RAPWS ziB9OZ1{^-cx?#%{xStu6 z-yt&%@}$p>Rttlj6*Z^1flyzLT>e`O{X9~hb*LNaDM%cM^MUexZ%n!n-#kscq^R=? z@-`1uyViidZLC_6zaYdvZf&yy1)!a@#Ibf@ui}OrEk58`n%~vDq1?3Q(S5~1z$F^1 zKaTHblMhkJ96MpS=TjPfkSGM@+=6LUpWy!6dg=9<-O&D@4KKb!{XP0Stg6L;o|$_3 zMn0Q}+|2cx33OIuLyqk{z*WH!t8Z(;e5`3T{|fe8|G50K)+i1cedE--EU?>1d~kRR z$iL0E5Wx6n^y#gOO-FNx-Mc#umqBlRd)t`Vpts!m<)dUMzjNwotvFCtNs!VGF5Dxn z^Umo8Dta$#$&n#8(UVx%paA20w>ZHu2j*vAkZ0Lj(C_$NEG;q?;>b@w8be`RQIoIS zd;s>B+qG)!hxS+9{t7KXUUasQtT@o6nyRz?l>xu&n>?}?hdhj>gzs=CfBtf7;JHC#W)6cL_j}Zpo`F1jjswdB zw-K(!2*pYt(KTd?0ffx{VlAkNyxec~+#I z%WI#2-ui|~`M7^?rk+tjJ;lnTxXr-t8~(Ho_sjT1w*?DUY8Vlh4{S#k<4 zaAE!vs|?W(9q$$afDgDo^e`YW@GBxhHqF47`cG)X@dbIfhNHjPS5-sfnl76J0I(3Z z8@8NA{VlDVv$}!5TF27Hd!>tytm!#retq~AmV4RQrlLPM{iz^X324tsK7VXiZT9?V z%ww!C-4~B>ny$8rBI*ZUQ>5o&N5wG3_XlP#rRPv4xlPZf!~zFM*m20Ycox+UEoq?V z+_CA;>3QOHc`emnv?Pe0JDS3;nz7z6&&7IlAqf1^U}6=OQ}ag7al)|Lfx3 z(RmOG#{?&v%$2!J&so*ES@gU=l68f~X%lLe(sB8Gg|H0t^piGIy<@fvUhpYRq38AN z!hQ6-PK;pmuc_ig3O4!Gj0hU;Ezgd&qT^%V0>B0LI;F1kJeHAoPWw5ocZuSTjGz6# zQE&NZPgA5ewr!cH9~JtI<_E0@)=?axvT_r(^Y+?{lrEHH;)kssOdORb#^5@)OPSQ( zh4M^%bNn_FkDS@Z#1Ho`BQR%^FI8}?0&Q!&NcG?DY@+;=1)1<7fZ`{_~SJ{f^5I!DoQ>S5%>aFs`Er zQW3~pCFi3YLB)c1_O2_G}hZ*7_J z8YwXAW!>jBwBNP~%zT}*W$^ZtT4o)I1}o9>>lsYEeNhfru=5Kqu1Md>@J)Xi{64S1 zi1zznT_2@uw!!BHJKCRPUOgJ%^` zZ%GjbQgBbclxb&X`U}c?y)c1+!~2eTd9c9QB;p#A_ei)WMazAv@L~e)gZfs|eOjt< zk*>?G-@ddwaDzPUM>)KS@)N)6()D>*T!i`~ZN;}R(O~~Xa7WNi!RtpbQIN-uHKzV< z>^NKjZ1QBPHKl!9rD^#o>r#rRKi&?m!SWYw92KM+^dzYNl!}7%E3{WAolpIYm+{xr zSUx@KFGQGt!y|4}KPH$VO!57#mVk#?{{6)aNK8Qf_-)8rq$iKC==`i5dyTgD?bJKi z*nrcUi`HX#P@q371c*aNoMC`$l47b*i?nISwuM+8Y`Xa<`pJ|rWsd0YtGl1|AU}Ln zF9XZ{JiX^^fEM~=#Xc=r%*%btyS*CAzuc}%L;7>As5G8$zWSTj*LhI*&?+~Fn)-rX3n zUn1_7-4f>d4d^(lQ6CXcD%^Ya3(rf(*307fexk~hD~0E%*joAVc)lN+%z1-2ef@{} ziM>#6Hfg6k=7k?j_`4EudD*p2<0il{D#>RYu%7O{({kyc_abE4nN`4_^}UcH41D%U zz7zpC-*;}$&q4fMm7k=F`gwDj@^RehcMdI?4pdStr1}6*ziIAEFz;F!p{1k%{GN^+ zrK`ZNAC_LE2>kszOQW4Yeb?q{&H<{JQEwjup}g_o(r{bA z_pggXU(NztCB1H6p!^&-AB%J*F93YA{Yd+hK%fCJtt0n<{^^@)E+_@}YuqZMY4XW7u-Bt+&tq*4NxqkT$4(vQA;jNh$78^&`c+QL%GqRNTD^3WIfuLu zj&gf&7~<5*{%4l15EmLu7`oxaAxBjux}sU|eyOZ~qKsNENj=|ae)!mK`WYN)dMS6eUf+b%OCq}WUHvhBR)J_B5$EMNRM5%R1~f`Mmj`$+WBMjPpy zy`;ujvQ&Wsc;EA~;en5^ul#h~_#eKz*U9dhRM)Ql# zgZ>?)6yp2*;k}ruUEAnIke{7@>An)gM>kuJjhYJcacRS*MFkNYqWM>8Oz0-agC$Ds z5`cB0tGPbzOc2b!!Tf^Zl@K5P{2(Kgz#*54uk4wq1MA*nT4U1%*tZ9>Z_GAn1a7Z?P21pr z0-Ho%FbG=@-}7+aiKcxE@cn3k>eq>oKY0JMGA+M{_)ShZ$M?2}9n;BKZx)&m!op76e- zcaQfzkT=Yc`Z)^vIXY&xxh3#o(F-oS2K11wcj+A~T6##|IH5WG6%cnUZmHKYbVacRcF86#cWrpxrmjdvtpKI@N^jd5)Ti?+}Bg zR{hC=aZa+;)KdZdvGIPM5g^yRT~%5FdW-ywvM}E<=ET*|A&~#+-I=HZ{=(g%Pc#*H z{@UP0SwLkLD1POG`8i!Tp#$TX(v~^3=x=q_ADfHgaGMvLigwr~#?kZje)f)jJSRLl zYn1SOaDMqV6!mtG7B0v0?y2*r)2J_em!&BU^5?tidvJVO)(5tuU!U7BQ3A(ZS|`wo z^^DhFyf^{mH^+B8#d!&?9rGOh{`uPSCwTuEEHj6N@kWx)goBbW&MQtcYu!Pf9rdG2 z8};rtm6iiz#zZc7*o!vHG zQ;}D*)s;hft9>iY|Cwk_pmBq@nGB8px(vtB`?xVzwo#n&a??9C)L*hJHx}FVoOJ9s zp2xFi3^t*?)J3cuG4$Bsn-l&puS<(aq|X{zumUi1jkt?I?D#-8Rl0c@Lb;) z5;%|o}-+H3(8Z?tpX=(`-G3$zabz=Lx-L4f92C;F#TT-LqkZZgWp8tu7-dO~g86dxTA z?4&sDO++OGEO6cp^fuvlRM$3kK>gXj!hKL4=y*y6`Sov&==?4C!@Pe!dU!U2`fM{CK-!gS=I#0_FE# zX{PHU+^L@O%XQ#0L3!#$yaLpEvEWk)-mr^>?C^W zJWTxlmX;T#G2g>=48SmGw_D^S#g8c(B~*{^5r@tX@f}OQhrxI*?Z-|*lFB=UFaU(# z1Bm-jJ547%fPq84XIwp9SBW0Nbp2*ph_6FA|J!=n{&n9?^gEP1F`@fbPxcfn1jzfO zy3qJ|(W7qq-NcTsr0Y0FWtgtxeLZ*Rx*ax*7r}j$xLFV;81QUh0gdZNBvM`>|8n#o z+`vG7HDqiS>NV`lrTLw|S*^6)`*SbChlBX+FbJnfH{Tu4kKG*`Z^yL`~ELS|;P2b;Wx@WFIy*IK#o!Cxh&4OOcYuinjM{)fx z<6P>u4nK71z;;d?zp8?MUwEWn82NcU=jNfEYcnOg@SM=~D|?UoPpv@T8RH1|S-O2U zfY$DK)`otT&-3gdlxIZ>({~!$%NESW{Pu&h>ooD5OjZSdFWT9BI8+Dy?pC{3j&FcB z%=!@^3;Z*?KP~Bi6Al$uA3$8M?s2koGRSAApHh4Pd|j1hNgVKdj0)nefu7_gRXOx` zI{LK+ z^|EChL(rc7ZLOJj9_{t~<$eRoEmFFYY{CEAD#Wy31>7LMZ&hl72;7GR20c*${qj?H z(qf@}@|yTs#69Qw+;+W$^FMr9$7cDLFs?687Kwmfi`L^xBgmf*#0bp(0{BO5%%;#$ zoiJZcmP;?V08S1uo`d<$!t;OC|HAoh9FQ6FasckpI%-2LA#cn%=hbDl6!Os1PMj(S zy-e+ur^kRjpEy|xCLA{8_1l+@nE~tN<>)Lem z_t`&=2Eo08bWU0wQXY7TBklDWiw^J<)2<+utOxJ zE~=N*ANo@0=hRQ$&tG#l*NID7)@K!TW&)n?kt!=2$0f;zVe2Jl^b^PZi5IgA`pIy_ zmhxZLTw=EFLu|?@E@?Kpsk7Fkj~w5)P*@T0<@&rQovOJ#K(FAI8z*65~#B`14Gx!O0McQboP(cI$E*FJQU;&dCa+TL!!l_^7t zo!w+b^%}{q<=rHy-e2CuubUWW@{`ByUF6f^hXG{;T_ksPbbh^fHyQK6#j;YOn{=98 zG>+qTk+EN2#Bj8`$g%q5w7kciWahZ}vvwZpBER;XxZL9g^?I)f1*UY7ueCBZ-QAsJ z?&*_%-|Xll1z)YsT|C%BBx<)Gsr=qULS!-%H7a5Meca+z3wZMO?&JIf){$V*g6@|7 zZqmAn&&J)LhwOH6@jI~(aOxAMB?c4V9a8-^-|KLH6y_W|enoQ^`5^sJLbsudq>pjs z)UE3wMr&#<^I&~UR23K3l!bf0>csIS4V@&vb+4yGU?(~Iy+n3&W*4!zTc>!WyN5*g ztH_M~2chrleG(5wsu!`keJ+kmfxVBuFk%3(o1^?OYuvQo;mz(L}0dzHS7!F zoh7Za;l3qdk=!|F*axRS1SjJDTFzcOMikbaQD6N5Ft|8Y19_%9L&}rDUsyhrmr(#e^K^7*xi0jl7xP537Wm+yRn7%K3z}kA zqaFRb2fyQcyEhg_f{62ftZ#ZM2Xy{+>xS!C-{OY*H;5nN!t*}iz2A{43D4=EuU30N z4#!z?eBMd|bajZ%t~9WFVeXVXUl`X>PSY`2&^zwoa}Dz#VYBu72SHDmgb!SXd3c%h zY_U4%9sgo6We$w*{{45R&%uvMIB00#eVKdckVX;I>uffZM*O+d#s49m6Rdp!A$ZRG zdgf4%yx?CIVZ7%#mt9_pes!qDa0cF+2r0P%5`uR=*1`(tzh_nY=PH2w;+W)J_)gCw zEMFMwd$miNVV)=8T6Qy@Te+nJm3m;0G=HL=3dohtNSwo8_tuSBhWbfTQja@;H|3j4;}>0% zLqAde>hRtgJQpPn2-Ew4c_qW+v0iny{!x67r`~pj+9ll*N%29Dqh~wL%bA!fpU_ST z^F#0hLN>XTco1HMvx)J9O_pd!&bIxKQ3rdQ!zga~ej$S5Ym+IC8Zw&(01fWJZ(g9dx__Kv588W1zJ|8j zshSFa5%xi_ehb<)betuO{7N_YsW;I4J#Xpzg?cM>8XvrIog{~L9=kG%;`M5u=k#5G z(or+oZfPbPfGxaJsABMBP!Uvvc4mBq;edR#jUweWZ{48dSf|oN<<@Z}luj1bqUE0N zW>DVD;|j%JqH7mZo;}Tp(hAi=s#l*ON%5W5D-Vjd>bi>Pe7H}0N6TB~)>His=^WZl z=Y*3qUOTcqg7$AM+Ck^x^C|c_9oVPb3_t4wdhgQuIcT@C_c@9uH`fW$@8Vjvh3Y-w zY@ze9vPg>dcVulom5b}mrT15lwW}%4)LN`f=hJ0Bp?O>j#lO@p`JXcYNW-9lGWxsN(yLQBmu> zQ7=#e{vZL=5B)1b`?XKo1RoCk?U-lJk@9nYjzYbeHx3HY_3-&+9IoT2&$95;3*KR^ zoap=x=p_LMidR(z&Ywoy8M{%3`hm3m8?!5bU+=%t&JpPQo54Z2fAYf$ArOMNmM@|P zU@G=tabfn{51)F%P})*-KM=mmGBQa#hqqZl4ztsGFX2o65vn&mK6awX2?4BRm3gtaA8tuPhOXEHtLjQj0 zWgXu^pw{W5H#NdJaZ0L0YCW9KMZqcMCjfUU>$&D!fpRlDXYIL|hbfGSOaecxt9yBC z!8h=mHna5FPQm<)`;&*`STK5F0OETT3BtC^YWOOaZ_v9rEWTzj8^z-{om3ssqGpcbTl28JE}{ zrfNO8?!y#Hp{U4iDGoapzY~?BIgt3KYD;m%-sb{$HsAqTbu;W}ZrMbyvN?#wj^6>f3)3JTT@ve@}o)7(G-6}KInX~N&2+(VqOH7?9E6SI_J<&G}FIc@yPBc zS-#FYTh{lJ2cfevqB6Kdbm}ZS|3EI;FT@pgi|Ha;5AWA&3Fso*CWO7nz28OF7@b~f z!v%cy#=b4XzLRWRwALnVZx@kmOsrU_-bEq?wm8LX?;_t_#x-S@brQD(*Ii+YI?0HU zN6z*Sog^gd`pd8zon-ok3Yn+pI*AzPQAgwMPBMQ-lKPd}4&vi@&3dwRCvk1BFG^GG zBuee(suRa`5-)ql+}^?tVt7=sLRY$jG#@Z(*duCdr5U0f!_E?Y4cq0o8!+5 zzMTj6360?w)Cb|d<423i+Pl!+kD`PRYCs#(maKRU`j@?y9FBuHAR|!zmj}EnBY(uR zZbIB3zlS^D0Q{ilRrb+UpkMIHm`@Gj<~^!EzW0p4`>D+j)(b)0UGuR^HxK&1mD?&I z4D^Bgek;shzi!``jB$EUVq7-nEpDzoegW}MRod%1%xC=4^=VuN{O%a(%Nz0vv`<~@3puUlficvu4LtlP7C>J`wN=cCR&4D#v; zE&l7VKigv(n0N8as~bQ&BfHC`@f@~z^QjZh@w;zgWbqtMaC%JhM;f{Fyzrb15c>%~ zgn)H&mJFlbmA08Kc+MU@pzDaVPotzZ59BiLh45E#I7CWn)fqg0J-64CVH~h_;sN@O zX5$`3^=RPxBSLD?{%%ip|$xI{+Oc^~R6k+b$h$}zs8hxy@dqxjYMPzkL!AToiD^GLZ4 zl^6DTP#o51Xi4+#nQhx>9#hKLD-_!+3)@TEH|%bsdg^r>Y5uYFQH27QFPgj48)@v) zdlYvrH5jD*7=DVSIDJ&+eu{^KyH&p9c%1qd&^W`DXjvD1#w@8EcIs2tnz)7oZ_ z>mlLXcX$W_c%iiy62XwK{FO!Xv|W$<-k^M2Nk9+cwD&Kq%#hDLIB`7cJzcdk4*9+H zzQ>R+b5;(+_i`uNPKluWg8gtZ#gE@a;Uzu11C+UT2II@#!IqmJfyOp$hCl$$``v-? zfCPS5xYzYK)|g?5JAUGWO{eVNIGu^0y* zh+Zs?`}Xw5%u~NW{_@Dw>xd_>z78tFdKD!?53nC?wa+~k!24^o8mxo;9TS-%g7%DZ z3jc%qQ;Pj!Y$oV!pS0mx8t~%}KXS#qWXVWu5B8UJIa)CQsQ9gY#uLFW42Id9KMU;~ zJUgvN4RB}kZ(Wz|Q0`oC)6*Sj$#CKhd@rz8Ek#2c{Pnbyecv(w_qhv-2iHLPOjU;k zxNqI86Z^k|UXuN-ll6f2R&vrVaNzuSAiw%t5cI$2Zo0hHZ^&O36?(Qoe>tTt70aRj zj>@e^C!7br6J9f+587GT$fwPP`@z0duUS}pbPKKzv0)a)bhoz1S*+JjtS z;D=H*oMYaPr|PJ|`SZa{^7bISj}2N?cP>-8heQoO9XSu}htAwvxVIVZl~)Pps7{A> z9;?1AI`skWBX=vLibiyk2jVMLv>Bc#Gf_g|z`LTrxpw~WVyJo+@01>$+ zcw8j9pC}a+U48$UOT>Ps6-(UcA-^h)7br>hl5^86a zlZ~c7Ja5~;_cqxwr7wz0`1ht*vdsrbp~RhcrH=h%$32s>Im-qJcT`fSwI`Rnv%R7% zr$0bG$1AQfJK9fj=42haak8Im6-pb?1}Zo1%e7~KBS)(~xZ9D@PjaohF0BggCpwe6 z8q8h#$;p6cv7%*MV!6L@|AoPJlG>xL7M{o=Uu~MqHvoP)AK<=$ue+U`pC^B=G`5rE z`WvjCQpqC0YhHHGG-HvI{4e))vf9Wjhr8<1X^!9nR1*(*7bf98Uy`t&P)}LGz5I*))?)$l||mOz2KWJ7FlH) zbo4XWxmHQ)@8h3cqioLl%@r;EHM z8LCZhdPrx+%1`qlpWb4lyf|DQ-tQRs4jLx3lj}_q-*=UEkf(8zU!6PMO%}zro?Mm( zxW!~lXE5k}OZaX3I-W)LFFmbz&aa&m-COAiVTb68|L_r(M`y-uPiu)OByxE_*vT_MFt2iA4f)iwdZWsfs9UYiR0@xd37 z>wbWDQl4veV%+%Un3g!+YlIY+tnGpPWpB^WlseegYzqZr7r>9kR{KWlf!=~q31+u} zcJH&5tI+~Kl{WFwb=W`B;zHw{A-}&$@Up=WtbbF{7jMUdKe(|eRm%qM4f3}xX*Ze; z?;7{A_Me7!zZNt+Hi7;1cwYQuynk@a+*-SPF6{fZ^9DVD$AVvMO0I=?aK+%Aj{Gm+ z2VNZia|7&9F&%R31^th^tQIT5K2|MKzj+D#n%%*bw>N>G5O38KEd{>K&G54t^s}IS zi7VbSNSR;v8UV^#p|s@)=ozmvjX-~{|0abTgL{+Y1;4_hpxxFlp`tP{Kc~+IYbAkR z37@Y}Bv6~DKkj8gd&kaxJ&O6>b%u*3i9>suQ!^T-Ks!3R6ElWEFMdVjzzV>zbyBy^ zZUg;-?|0p0pxqr+P0cf*-LKo#LySOg?I}g?D5&S9KDZ6f3%+BHedsTn1cHPRC*FRy z+XBxQ-JAaD=-;Q!JyUTTXq$fGB)pfGI+L^)&#x^BB7g9Fi8&nF;|=`!x{W$#fw%wM zWQn-KsHt-o=7*EVcZp)Yu}o#pu61Bfmh~nx{Jn3(#dCU(K>l4~<7mtu%ExIg!MtdN z^ZB4`pq8^D{`vwv(YDtS^SF8{lPd5$w7R4mjd|2PihugCpVx)UUZXtqLgr4SV_)s0 z_@!mc3W|Gvr_S%{1ie!QtLVFd`Z3%()ccY5A_33iA5Z?!{7>HVHoXSme?_06e`ji| z!_Rgc=k`ZWXQ1AjDQdEK-qz;z(f9O2X*~mo1I8WvI*9G%1igX_Yz}EN^~l6|JTvX( zBeXMIF4hA1S;vSnQqv_G%dlM;yT>Bf-W{uCieH|-f$LU~&zQc2;-ly~ZJO5={WG}^ z_38qk8kBRdSyO!V@UkG)`>wW`=HWgkhL)n<+}?NrYEQ5dmH$2#P>=Fsua7|j65gF? zOb$jGXAjql*q-bn+MY+IMj7h4WsReG-UCky-XQN4mPqHPJLCqM zz0u$x;->1~*X2=P+3idR(kUU=O|d-fr^;9?H(fg>2>DR;9{RrX8*4npq3JHYW~kqN zg#{0M!B5$1_u_io*;ld!uUhC~11-gZSO9|0;c_TV?F>5aWP(6;|*Ey1*ZO=)353%|yJH z)=p3~#P>HY+85oEz#q9)x5eOl9j$wwcDP=?4DQXJ1?BUjA8r|heYxv{b)!D${XTgs z_&$_}UryNN2IZx9269tipZnw$-FXW9mNV;wB*0&&oVF7}d^KdDEP;5a`>E!LF6eb6 z{piPcR|i#`7yH6HxSw8MXQ7?7@nyeVAP*NdSMPcv_>Zx!RtCT80mm&7YZigH+1X6M z>w<)^ivz*_ia0u9j=DFUf`;RjWwVb+U~Ln^LY=xy)BW2 zI9EYM?@|t&M+-|kZ~yRx`wZbN1w&ANaPQVsEr?UUHovq*996cw_0Jga@BJmGcfJUK z-xbLFJTL&gd-8l+q#zH_=JZ8R1>O;cE?Ss)2JZa~^lOy6AiweJ)m@Kd826x8czzy% z_g+rn>u0TD6YJtjY6Z5FBE5O(t>eLy=OjY z5tpRhnc$oEaez$l+I8?01QVLIR^#yMS)DeEI|KcAGe*X}1*eE)uL!h743X~YQfb)#>LDh+`1wkB-R z%zf%yl90l3-8;f1pT$elL*=-{W>9c%uUB+<-(SG6~IsD@N<$mJ7>xzPycR#uFQ7}MeV?TL#=Yxm2dq1(Bd(`KfKtGXuN)iJm z_mg`!KYU_~^pmPdhTJ3xs3&{&i_NNjQesk}UAL&8cy7(OcH}OXNLpwvTmkvF`v<*m zq>A;EgHuB@pU&(jmG4CRma0M?&mnkX)*UWcdbYSE3-WpGb)OCzjq4{D6!Rv!{pFJU zpe!$eY5nBw*ruB^*Rx2J+}#n8bu4mX!Y5}7z%yUh9I7jpXOSW4fFcFJGgm9lZK?!( zFqFD?_gK*5{~@Gl?*w>gy+@^$35%#ViP_yYV3Cl7y@Nh6EFu;laAYKbMViMQV2iw9 z5r>S_jsEp4B2i^9<@y^IsS`UeG--%M&b3Mvos@1TrMoiA2?%9+G>@SZHG(i+m_aZeM$pMdo*{O@CzFP698C6Ti~cNt{iy%PJ3b zlTBf^PFJHKKX>eTz;<8A*Bxu;zcL?iX>g6|O2`*J$sYMM&A*G}#S|`#KHpAqbZQKaC4+Ty-xaz?UoHIMYNucyw?>;JoVx%Vj2jAM#MY8RY!}8S@!o{@OzgkeSTjDJ>|LMU%voQ)o}u zJzsSM+S#?wxAqd~7e7}G=mk3;zPB&efN^R0rne2jI~acL6yJq+=$qXG*2II}T>a$2SJ1xy&Wn=qps)HP;JXu0iI*l9@V=;6 z{kbllW0!`Gx!~^zOV-_Gs{p^|?C+F~z#q;#zX8v^rIjJ7h(mHs@BGB`q%>*&9DE0V zZS%%IVj#EEuhP;1`Sy^lJMsJ*dtTQD&#i*4UHy1&L@!*$mVxmHO&%MH=iM@;RreNv zTq4roR37jPr^*zUft{}5N-wU1-V}?$V*GnN{kQ4^*MeTwio#p?yI;Q@a_(rSziz`$ z#6K&_Bex=c3F`2li1_9F5JwHiBOh2&j_2UoyT9Rr5a!3}Xes95h8`U{isyCXRRb%e z*J3+&y#cxEw+#pJ+D|Zj-|+X>z4az5k#EVUaYVf#)63hC-;j2d=A9aX zM)4tj=I2`LqrBixv=!>vJyCW>e#+hE1mvajD~u3dBj>Ima{tRcT+ho@+~d!I+-OAw{rf{VUfyxU^(ub! zMVu+D!-mn(tMUE6Vu(aVGvJrcQ<{!zLb+bt$ZmYk@#fmLub7`HkDle;40?Y|*$0Op z@8Z8{L&QEPH&@egR0F!$M9$P5^g<3*AH5HLg#YZTcnzSOw9mc?P=3a68vG?l_&XhU zo9Da&J$a5Vy9~+=Q;-1qpUXxfCD6lRmZOaTyRh<{knL;j~`SWl-Z6>!mk$1ziO_mG5~8U;S^ zr-tpn61G8n++oHNya9Tp&o_D;z6$%Q$Ea}7yN6s1sCJgEhIjl~s?+7cFI3uc5Lec|^ol1=7 z+NqC)H%r#$$FdG`YG7;k;KdGNu=SCsmowbEt!XluoYz4b-b~*7{YwYgXb>LSc&CF% zPib4Uy%g^2*e^9FZSEv>Q5l6R`a8()rJcy#LzVetsM1j|_Pozv+K$LIJNkZ z1$^&|uY-%zU|sZC7Hi7x>?FH49=`c&P8SKTaNZ(o-b46DYgdc|9C7}d>+(~u9=l&8 zOl-I9BspImq}oe&kvTHU7UeDJAtoP%?D^o{{`G{lQxJb--+7v93HmkX`M#fp{n8Yj zG_nrP%lKDL!4X9O*u|ac{V@RKM-JQNoQ8H*hv-I{K)=g$XC241YG@C9lKRqCoX46f=4;5o`e^cWRA(XZ2`lyZeLybn z*VkXxz>jkcr)~l|Sy;rd1UdcUPgR}3r%tZ4wg)*C{&jVD-!HP!vnD9N#-Q&O=(A(4 zss!4BhG(0kaGrh=9y1s1$&sJ$6U;d*#DGK9)k@@_%@ zVf4FXiEcO`0_Bm~7V_Iks}9f1LdJAHwEeg~F|yb$$4yV^bKvkCb}M>7S` zFEqKoh4K^Cub$S!^3t+}XHhQN`zcn?gOSy*bkLX ze0^BnQ7J!&_VUw8&Nz(wAvP*|P_D2!Za?v035MLZP*mMlft*&?8vhq5Vv$=*b z@Ok`yJjg&l-P#8|tMIzIw%v8OU+d8^a=#eLJ*^)qqMl`<8U1L_HB$9g;Qu-J%AW`E zq^Ee!TD0f9`uur#-31A=U>vu+FWnDde{2r@#MTUSNzj*X`cR&Dbmk}8%h3)+zBVX- zxWLx@4~)MU7x^up;Qje_fIUW8zn!ebb~z?n_`#T0_&Af=K`H_kbBN8n;3c<))y~%ywt5n$dx}wGvojt zOmB!_H-L3omDjg0N0{F)hi@zsfH?Q+<{g9W5dZC6o6fh#6|S3@;fj!B5arW4e$Afa zmFl#L{@NX<|J++KuoE%R*GIW=JoRsiO2&BV0R4U7L z8|Mh@SL;e14c#zKynjY_HncFwr!PJ=L~dw{m`n)Lh^{=>)r;Lj#4mV>+#T5O_#WU}F}#OH zYJ$ZARaVi+A$iBO!rN(N$TR7mhZxw=2TbkLzlO*QhP)IFsCI@W9&P8OjNnt$Ibq5U+%eV$RK*Gwaaduu1F7SqXwM_#oUA2eUwV)W=T z8Ywza!{L8|MmDf(_V_^DkyeD^ z>}Vu1w(GkM*vservj_dbUOreWy6zRkmoqGi6Sjf9ly^IMFa_+Y+VL}|odxNH|A|?9 zv-${8-*9KZv=#RwgYHBCuCxng`&|ifPL7S7uMSAj$-5Bu?pEUw(tJjw>j>c4`dP`SAdoxtWYD7->}8)-r9d&*%dN2=r?tUemdiSe zCBXaiN{mmn6W*u8+M!!(VZY~DbC-6?rmDwRiNk*I_c!aN`M{o^ zJG6HS*Aw)Hb43Xt7cA4AnFIJ>pZw0H60rZXTB9U>7s!p8`K~?#_WOwXZes2n5XDV{m#X^fNx3UIJq0>i1FaPi(vOl zPDL1?op<=;(Q*^yxM!r=4g#Om-}YV|Xx+(+D+WQ&*R{2Wah{%gY%6F8TIlIoeBIg;ogQh3|l<*k_|X*>&*j7PS9N&ae|0 zuVYUiOGi6Dw{i6#%AG%V*dOQryD#P|;B$*7$9=(ltVY`3JGc*I(j+~Ga`P9fSs?G| z#E~ik{9eboLe;=Gg+xoB{p&o{-;Z{m+kDZ*8dh!?@I8xd5V|_68t~;GE^M4%ycJp-t)0cSSi*Y^5%;{yVxcb z%S5|8yv9Qr*V6*0t5zV+2_5{i^&?QbwbHgbp`5X9r3$W})9PCF@%ke<`_7>JyW|70 zhA9D-AN$RP%d8Lk?b|~7co5Lb1M4Zhc7GZuMtO-V zANo+fVOvH!+V@cNst34_(Ve*q5+4Fyn66%k&#(9V@@bUQ+HA5O@Bec9{tO&fjg3p?CwY2fr3;EVbP#Ww*xbm_f#JiI@Pujy0g zE(VVL;du<@W$7Q-w}AY*6*1Ee(C)gjT?|p!$2gL=Sru{T(s%v#RUmh1jdvUR33@da zr(OeI_+N-H9sGBr%jP|e1$jFS$+5+-PW~c)?s+k+M^@@G8*ak6x9Z~=dCR;8D2~8e1vtkq4FeeHTWZCMx9KT!g?i5=!eM!UJh))F zOAzYk8F`3pQ~-b03uG`~o44FWp}8;*@kTB(FNFEDV{z=q zvu1GqwY9Gt_hnawc8=YH{-ozjPUHaZuiPh@1vuol^zJU=tdB&VendsOc+iJ|Ptn6AHY?rUD*r2SUdKT#4ocVmJ{a>DNV zTpVMPMRQCiZ?0kzpCao#7z2ju)VQA5<>kP8R zB|G66%)3Q5O52-mz&v0x>*+IjT5UHMz(!6lXRH%wl~~olJ44xZ?iyW)HaH4Nn?_& z*5`V3Pcw<`sB&O}FO!_@sw!D{mr1nlyR7mpWfHs8ebR3JOw!Z8-*v@aCaGMZ-dB*$ zB+7B(I(v$l#B=<+>FhZsxh=&0@{0+R7{Aphv|Pv}+EHt-+d)6MoD`DVQV;jr>X5v6 zACuhQXQ!97jY+D{_R%X9n8ey`)w&`$U$)OOc3Owu=eA>P`aN$LQ{ z+s$LbIp?zpf3MNWO@^#b$p!EytTv2XeS%J|@jmbS1?y(J!`lVsNz%#t6c;wpMmjmy ze>W$zg-+5gnq4xipp%eB)hmY45T7g;v+ukIot#ga(fXMMamovW*6}frV-jIU>3(!lbKPO>=k0Xz?Ag=vF94_fJhM+} z%NH8auXq0to=GR1_93|pkavm9Tu@;~CyOTQPWH~D6Yu@En(gXoq)s&d#P=2&F{}!4 zFxI1!s|Fs0r*A{~>du=SLJ&9Wl&a7jK_kHty^;xvbkf?Ty^iBF;D{8h6Dj^Q^3B(y z!VmlyhdWGj1;G!&DJi{bzcBbA=8UE~ETog$ZT22M3*dZTonX%&IA8asx4Y&}Ea;!G z`0aMs4@qWo5&RcUBc%m#dud8EGX7il(lqG1>v3PHLFF*v88a0*&`u-!re(ISwxe7c`PaS;y9FR zsrR>*0d8u1TW5L#<}rUp zr4v8gf9y}xlIJi#3SZN@84LFtUlOqW543wP$j8tD>UU(sMtZ=!)YoX`%MN~^q`@_d z55T+{_E_P{VQ6QS??daWFdydZzpWwwbS*J;cno^(o0gnL`||VpqHm*6{xHZzWgoQn zbAbl$GN5vszI(rf>-Rm)XyE`kp)s|K#y|rl`Z^I`&EGk(9PJ}-&->V4aDB{hoG0c5 z4cPtG9nWD`+N2bT0{t`YnvVNGCBpxHzJ&GBI#YX{OyG4?b1!Q`{p_d*2l}&D*sc1F z`|vH}wR44`o!wI&AJJ~qd3y-qxfXuDS6S#sH*(tOi*~a&h9?}?-c0X zD*uR^YWRKp|2((w=ApioeuF&N--$sxz3{$Uzp@P>RX+5H!Y?xX>#4Y6rGR1zzl6D2 zQs@1*F?rP}T(Dy)71yz$BA7Z?#>uvd+9wHTETZC2*j&qF@&EAK<3gPyn~)5ggYBy> zxlQ4xd$s}8`LOYV7s^=9;9})@2+4-9R=Cde8H6oE`3F8hDsH8z=?azS;KK_Es@!D> z>w78zRnIB@Z?!*l{~obvD(-|7-0VX=<=RH!ON$UEBm1ZgpLcKEnr8f8B&{ahrGQFH zU$w^jvA3zD;$KAnl~M7wIUAqqqJEj_ADr>} ze&u0H#98ICXQ;U5gTBWWVf~kxWw6>%IeYh}K+fV_*{q9Yh@rPzBTatF{U<)LmIFWg&7IdME4-Miuq>aF9EVu7^Z zu{>zI+SyJZ#}_)d0~z;&-dq0t`Xa7dj)8sXvJ^oKJZ`7mzy&T_$8)& zXr3LG$Ek|^g89e!nD5;Y&f1Y#-ZVktQPkQja;Q`>uWKL@) zzR$Ox<)6fOJHbkEF?`>zcG|SMgWijt%q`S|c9TVQH-y4EG`v=Wzj+1B1AY@Oy#{bT zYm2FY#bqWLzufxbZs|A~kV{;U1npY7e!b8Gc+X_y^WvGakQZ(tv-oW%_(y3S^Y=j9 z#9JBV1#{qjUss4;wF1A7=~2tap@2It)D@rZ27gP`y5r9zf%nSKFtdSq_WPT=Wyhdj zBIY+GumR6jF-NEx*3COh_Dtu2-~Uc|%hxE-dp_xUI2Z8b-D7J7#^GE^HfMoY^m3RV z6fWG#2YV3oqUK`^_-zKIhQ&3bndF0I@L&hvsdtXdeOn!wWcN9@T?Mrak}#ZAWit!s zy>z#9=BbU7(xpclUPGP&Gv2mk0b7_v;91M!QZ^=G%rUWh?*{voaer!)0Uu@R_^)jE z%Ot0M#l_HN|t1yUVD! zdyPT(EJJ*^-e!=^mdDrY$1=!t=*!t3hZ#iIA!f^=Zw#V9N}tz{Gsti6=o8^@7^He} zN1yX428kGHKP;%qAWn%J|6Y&-JZU4rE+oVxOaJNL`f!&)uDh2Gud!i}zP6A%W2OwU z=GO|fwS-Az!ehqbM;PSO;ar`*G6r$%>)dbP&LDfgnkm$4GRQv3-s-9^_-#Z~y#8Kb`#G_X)A6g6ocK z(BY~cCcDQj1d|)Xgt61a?zq!1IT>;O&DwQ{a33M*RkWWIMk7R&f1La09LTq^&o;z0 zZfHu{f7oNm@lSptsj)iLEeZZb?VyfvGeG=|9l2Ueqd`VG^F?RiOoV`|BPTgG9?=l10ip4#Rm)PVMX$^@B9h zBKt~&;R1fV)8p5T^5MLnox-+l+aZppUh2K4{RkNjRCsXU8;#7!G}LyTq>&GQIP%Ub z08XzHKJ-lh&Si@3T77RZ*caW;`y_{GX?;u;_yY{w=DcWiB`9oKSExL=&WZI zOW?hIdg;mWDZyc~v$p;k?cFd*wNt4dw1WBWC^N|%{9acll`0OydNa(59#4b(7L&64 z)}J6>$MvJwI<9z+$Z9jDk1;HZ&e%Ty)ZwRhkQ{82Hfhn zSoz;uxL^E@?q@**kRKtxX1m_M5hC99+~zyX$JKvhqAUUDu6I*3bpii%mc4Y*S-^#x zN5_->pxtwKc8)Fu|Kfc=)#2SRKdM|~Ead=ye6~}adOXaNw_0UJd%&+KeZx%_=kp-p zi}BJ>Z{Q;uB?9$t%#<=QZ+!m?U7qJKPd(Z=y~Y!8=}cJh=pDdYk93ALF<+uog;MAW zm>)M}Ur)LY{>nlFo+m|M@8;$oD=fhI_^EOq=6!cE&kXzmdYn-eejow*9=J4-i1F9r zTYmLn-t!4%#i{R5uhuj*hIVWw<$%o?*cDpm``^t_U%2c;&m(AO+9~ce#;5RPf4g}E z=mi0DLCkAja53j>CEmv*ZMGcr35y(T#Q35=BCq1mUz44`duTb-@4sT1;tA9_!G>K6 z>T`m6?xLNIeRHilALM#;Hpq8?9`QFrq5kr-Xy2EpefWZS(Cyx$D751{lRCGd zy;8Vs7rqy$?3MfZxX%-hE4OEJB?4EvAZz`#MV)iO%SU zi|Ft6Mcl*Ny)pA1P$MN;E4Gu{@VE{2s##!QjCT9=i%;;SJFs(`(@!8CUQ6Q?L_AVh z>BWI^8#b92pj|xYv5|_yEo`)86NK`P)t~hdZ(N@@PU)p0v85DoLqBB8KpgPl^=GkV*NX(5^1ESRvR+0zG2&hEb{v+_fz@wwi<2V!}~P*M4!g`gF;CQ zu-)cHVrWBv-n&GfD*3b$vM1XIuF zvwb&(Yg6mIDf#ciE2wz!`XvB=LB1Wb+@pTF94jcAb@w-`T$OP|e z`G9u@?^|(>_X5hLYHEn!`_0AY^%CE!Q_0-$2SD7APG}s;7rS&&`?~BE&ihfG84&Rv z$9=_RJ4)ZjT%RcUEWQ{>!~y%RoiAphccrkX48(|xaKxb75*eG~2p)GypNMF`5-|6LMA zzxPLr)AfqLv%T^Sz;&vqNL8IO;Ju7{eVTaRhdN4K_`bDU6&>#Zex}~~JIYV@E8NF; zC8eVN5q!U@4osow&zvZdE#(mfU;Txe%K-GL@;!(d!+jEcb`8_X7$Dv&M z*e`F~zYgKx%MJiKKPqj1Bdp(Zzq;6)0v`Lc>6M=q>?cOXZ2c4maTr5iG~8%=z~3Eg zx3mbJCnS%JHx1^?%7h2($uQ3qg>0-Sfpf}HUk?_?0Pge;CNJ?j5_?{llNP8yb9?uQ zKggF3Rz41d>p9nC^7TObVjEpwpx;;Mn{%We$mcDLy6pnGFIa=2Rqd8 zPJv(?{I>RHTYZqTHhQC}=eYmLh zJ;ZlLIv8_8UIVG77&VV44Dumiv0sOg{=_ev0ApYzokKs-wSZ~DT)Wo-y0v$Js(E$HvYs!}^(O};;Nn{!u zgI#j1*c8?U?f+BI>Rk)^a#-9^_Ktvj@J~PFw}ZYPOH`HFz^;8dq%+L{@mNcTI)C`W z`k{!g-@*je9aY}H+AB9OA+E4qb9W(wNX=V);y^s?$M#D^>Vz@K0@7bJagBX>* zPg;|5WF{RsdD?*&;z8U?jc?{y^Y(^@XuupldM8@$Z%=hp2 zO?K~ve&N*aP|*VW*x&P|0P->`IX~oz*}@=mg(@eO^?`m3#|$jeU>#;5VwUF$I3)R{ z=e)TL5-+s8U>PUmSzE3CwEqX-nIkEwU{0DSm0Be z%L&C+HfTvbz2TH-XTHZNx<7EiEN3KH4bmsuBNLh3${{`fy%l(?-59=sp zx>3PGLx@xUsFS)L;uo^+-O2Ab3Ao5*;IgFx#LpPHS?7bECr-;e6*~&+?0GyE%F+H~0%;*?#sW2|4WzKP{Q^Is1Wg-luH-*EnKE0Hu5uNfiiJ885w z*dOjP_~?+cafG~bSW=f+HcZ?utXa-^YMAJ9D?f{oh4}DmULU8rAy09Az=sufBZT|l zFuMuF%db0dXm!l85hBPmXd3s1xSD@5Z>F|F{DbB{<2YFF4TR-oz0-jCqi2WK5x}ie z*X@1U?t)$2?!UtK0^s2$Q=Obdh&L%=Y@hcW{Ct}=$9Mt9CYKiyvvb2lQB+o`_uw#j zxJWT!e;1vIyErl@OovJ6PJaQBF~Ikg9?KWI50ewQMv_*r4p?jaPxPEi=;R2wH>LR|1@?vV($8r9g7>vFpyt{; zN62qbG^6qQ2IK?Sy*Z5y{IYwt@d>vJD!!|*^!j|8n zk$|%wIJ~>B#07TiqN-mw;N<7-Qa<|qpig{Q!jXrNhwtq7H&qbtAwOZs?+o%`hLu82 zaNm`}hg)30pM0olqJ206{2wV{+)6ON$XV=tzz+4l{3TM20aqt1?cG=h^I(Zrm{|zK zxpno}N{+!iI`J)$Hw^IfUnhlv`!N5^e)4X*0RHMW>#V;?_C0{^I0VM8LU zA8It$N?}}0|Kgujc+PnL^qlV^@ZQ7<@x%|o{Al;@yRS9aI}uBxD~P)z9(4pdKs#|; zHT-=+PHpyO)CRb|SY1F9^Ihzd_;nlO(@tD@o{WAbLj`#WZ2u0Y3709JH_i z7wos+0D8_Z{k9U+zv)rQL;u>Wg1y-%Xm{DTUT_uAIeb26Wue?q+gS_!r7rsmJuBe4 zX0_o3z0e<_W%H{tK`u#wC>ub1j%WL6#M{rOckIP@;NM$MhwX%VJ^RJ05FhJbGF^c< zWH98zTs&VE=n;{Cc2`7nSMgS$!Lufd(EdkwD?P$?%8eS7&|loSuF?r{%!%~#UWn_5 z#)Mtb-gk`dqT-QLcHNLgoFOFqW)I@wHd^PI0-&am&#$5%FYWu5>uArLMEKTXz2Whn zOA!|+X7}^sIwVxj@HVzTr!A4nZ(+airZD0F2Ln?`AOU{AN?$MZ-(7imP7moJyTWaF z{lSiE%5Rw@dPfoE=9z1LM}4(3TJK~1@dP~p((s<%{J0OF^K|bka1aB&mH#Y@?cbO3 zNJYM;?}!D~AJt)}c#{l2%74pvqH_lE=kKZ&(^xN0pYBBY*6zzxelV%S=e4jrF6>t* z{(m+eLw(3UG>)@DxxNaGWyq81wB<4Y(N#&PNa?hgty7w+{QGQ$NHdo3&{b<_>3inFB zW_>5`pIIBVPU5({l)~fE$}&_t93kEm&r1)YaI@+r7QXKxEd0E7AuB)JUvU|#J)6Ns zibkmdYz94IT!96>_c*brStGzvD8ICIDOEmd%PQYE$dc#FV)3Dny$7*>KcW^Wj?~+1oGjw(9O{9 znXmA-0N=L>{w|=GULT;=F)`LGJ=vD9`pw`NY(Ic}*3xoHPEBGSHLl*=WA$^#1xS+u z_4a-&`M?dV_1ueQVX9oitQL9-@V53hcygGRJ)dSGU%BPpCgg37hgINsUnY@H$y>DS zrPf_FmG`Omk%Wut-YCD#EEX1QfaBZeP|sEQYnIaE{Hj*!y7lKH=3>2o^NS>u=W{ft z>e-6&D0#&wNZ$eFHFi&_=j?oU8WvD6e;2`V8ldYgDNyoH4<%Fe{NUt5`Ok$N)V@u2 zye5^`aYyX$Y+MJd9bHMy8|6jniugW1_}-~(1m)3|oQJTzY5DtINOu~P459qqr1^`{ ze~{L8=o7|+G?vHbWBb1pimCrso}E`6<);#MIpR8Mr^gRboKMJVVF4`nXg>V`<*oaV zL&rk=&ki5zKB=n<6)~PgHQt!gvsOu15$lsWULQnx_BZR6;QRXOWQG#H-|VA3mt&wj z{?~?s7{{S0GjSdF^R&vMk6wWJxFh3l+*z3Cjdw4|#`#)L;b%6ko4#?C!(nxZD|tO6 zFARKFo0&%)*p<}^8%Oc~+b>$mjrtnX7xv+PhTBBR3XG@fEGSRJeFe`5pTp>nc*niu zGwKumz_|_eEIGrq_C2;=FMSNlm+PsEV|xNgbBu7_T|K`b5&btpVP+38-q!H1?fX+e zACptF`LK>EtW$j?2`1shx+`%udN z2iRK&jztwIaR1_{&XX8-Ge5}9BNgP2iG4Qh1^K0gmD(nN3l_^+1Y^IwUaxlm{Z{1m z4+~r1mzRA_JPq=@dflJw0DZo6?O7uY`9-R?=o-p`pD^~3geLb6zyYUYYmdP`MWL*Y zfwe7MukxGi1mKJde+P0BVgLI5!}GaEK7;+3Jvnau0B~FXiRnYI&TE}4a{U4Eto}1o z3}MhaI7aZm9>B+!zohvgJ~0vaUiuPnk30LTd-z=#so;V3FYrH_@8GcDhxON!Hz%w( z07p3*eTwY?eARg^ea&)^lm6$Ht_bTc>Dw=FH~^lqvSLq+h5PK#y(NtMv-b~P<2_~t z=akdq>vktYUJL>H*uVpLFVYz6FI@l}W+Z3L9Sr*!ox7dxb^xx-kvE+O_)PI)x#=xg zz(*Yd?`>7V&v|lVOegdQTVcRVF6`eN*e$wb2ly$iUCatGf3T_9v6Gw-C-i8$NY^0j z+kaaf;&>GFeC?66!xC_o#%bO%I_Te3C2XDtdRIxY?bn9qp2yR>9{0~GyWq2+kAnB)_e1cW&YY|G&gC;BOa`C=?Bc=hoCN_I?Kaefzul z!H3ZQ69W}f8GzUMHm_V52=$r$FQZanoHie%S#AYxRI;UjO#(5}?Uh zZ2o0Xu9PcpIRw{7U#coS59I;(%Kf{6(&rV#t%ULhkEdLjz+b-oGX}rQnmg1rh368! zuH4IsINELVmN<-aHNC{k+YRqWWC61b{Y0H>`?FU={cYoI; zZKn*4@%uGf^J%a2K<-;fV=%^Fa(u|{DgnBn(S3>&X#O$3XuMCcKth%P(7v@=_fbFh zke8!~ODhWFs@0&p#?!VL=lP)p8ZDzx-tuW-H`=S@)O%;p9`OEcckG4olX*O^5Z8}; zo>`3Lvni#!@;GQJbUml&Ai+1sovf2RR z`;s#iyYN1JGgsZveq9sEYe&EQ#FuF*-c>U!R|BtKJk;up_`l$JDlh8&cBP#?wzH(C zndNu)T?JpHhIro6NItALu@nu*`bdX!)cIRB$wk+ZAKMTTgX;&L2bwL&&oFeiqy9%C z;w~Y-=!fAX(xE(43g3RNONKyMc&`%fH(;RA~> ze@^uVqMTXMEQO07DBYoOML7GB%~-!e`yK!`m|rD>U!mN>%k}^qp?^bkDV%uWljTt? z|9UE!%KO_A9!=r)%`ey~T+aPKh@z)Iou|tCMvW-kF2sGDx<0tdlfsGPTGbSeI=!e( z1KVH5u0ZKym~n-AF0DVp6kqh^8YO=~asef`wWWdbU-Jc5Q0?)i{G{4Znaf7uv$SXj z%CDU}Ye)4{?lW%+zuB!;r`oZ#PowZul1Vj%_fA}6eP2a*D+||GN?}z%X%1(+;mCB;-@9}Rh)xHKdESsSI>CQo_{!|lmC-fU9 zE<2!nw-2zur$(~)518H=c*Syfe4s`Mvq4Uvoh7FM(J;tg!0iaAANGXD2O5Ky0UZSN zi}l@rN|B!@!Qwrhvgia7s5imOp#JcG@>gJ#A)j@UMZG|KkQ>_uEbzC24pTG< zcAt>1oPutIdc}D7+kj8YfaMJEJV#(T3bY)et&n=fvE)-%qk=GBwzJy*HqFw9`xZ+M zlDbg!La;`y7lOyB@saq%pBfLNWejTEafk@O9|!idzMNV|c^1I( z669+(ou#gK6f>guueWf)2l48A|515sx(!RH`Y(O(`aya2=KzWid=p6V&)J_-}?WpmjrpQ`hmSPQ}vm=yD46I+Lq#%cBWC! z!OTpc&a>SME#HIfYA%cXgnF1cr)>8`yX9>5)=l%**75_ zq~8BvIRdovw;}ahrGFvaA@HZVb^5WLlpr0d{R~b2#i*z8ZqZvzD8JgBe+<_}w%ge( za2_tuGIHDo<@Ir6GkE>v`~&((cl>$7kN%KD^6Q#$zvhv?Kq(KciY=Mw2~n8+ZWRXFw48z`5Wz4IF7D%J;;BTjRRIG*hS zxaMSacPs8Azwz|+K);ooiHSAZ^AkI+`sx6`>DW1bCEzy+JL{hXd&;BhOYNUs^wVj^ z{*gLwri(a}>kH8=Aa9fT% z50|qW>Zwkb3&nNU^kabm>^F7qQwG@XpZkTGIY6JJYx|yr@{X{qt*U_Q&e%MX?+5*_ z9bQ>k1o&IWKJxu0z)9;luS#qKdmqUmQM#iwX(b%^`CjB5mpBLt<7J>*4{wuO0QKVSwJwO0 zs@~qeF$j9n)t!fv0B?7s3CgX9epa|#Ry7KGPVLdWBm_9wt)uvmBFNKHJ#rC$wQPE< zi2J!))%&*lL%VCN#yC+DZ+-<-^zH9l zd~Ym=#hs;rmJh8Fl>z$w$U;p#A7Yl(qdx@ro_1CD5$-#G>`xtbfcMrQ=koal(69F_ z=f?bl^38guPUAT->sj;Mb|`-lsXLALUwq-Dy(pBI9+IJ>|HUxJU*IrM=VKY$@qKrT z&zVNN?p^$Z`cBET#6@-V1BnpAp#bG)wama#3hS&*H)Fp-d0Ic+4e3cQA<-33z9E^@ z3;+LaTlEfnPd4BABn)N zc_PSDhV!i<&;HwZokH;ASp0vC60522HKYc;G{FAQVJ zG#O|>d!TnU%M`EQ5nT5Q>%Z%)q0X7LZ9MR!6Zp3?$^AH=HOc)7m;*HZ;?b*!tCw#R zq2qO%xjffkd+l=*$5Ef|)l%8mPQg`QNvv;z&%GdJb3MEZX`YS&AQMvK%u)cFG0S7VI2Q_a11n{1{V&xg;j`8O}edr3U0DQnN z#_O1c^~v2_fUw|PCS;vO>TP?V3gvD+zTJ;J+py+wlzVzu5daSOmHH;B`|E7HPT~K+ zBaxIH{lo*?9v~+>_=xfgwws3n;DUYb9dm<`dJ7u>fB?Uckp>`9$Zv9KK4q_$$9<>d zHYG2m{D+ky<1Bqf;B(3#U!@#E*>77@1Iljm)mKq^j)nS6VSU2WWC|xJbRVYb!zN&v z1LZez)G0i|E4&VX49v&o5KaVCCqtXE_i=K{0LZ`&Ta{4wsj4@Y!vESCCKR4HT?uMK zeS!-sjwSa)4JB`W2h1(#f5QkagL;=z7A|kywu#a+@6!fKkBBg9s(wk@V~T!yyppP4 zY}82cr^t1xz2)!0TtYj)w*p*&c6p7yQ1$UQ-c$5UQy$e%8o7`*9OOcScT#fM-yTr) zd(1vl^zLjCRlh+@o~qX`X5q|92?XZw-tEE#0QhGmS=aNzZVvL^*TAg}_19-u`~pc} zfhSE5De6-_Mp4@oRz1xQ)Q0-5hj2Tf8(qIq)c-%6*Z|ofvHY1BtNsV9?(jY<;1{Vr zvdF_zq1@Pi>kFR$)&oUY4CQ$!26F8P%Yk2kw+G$_{(Yn{7%7UqkM;OeST6FPd=4&W zp#1;q39rV(`=Y!XqFBG3*vttq+x->3LLx%Nk_a>Ec74NhiV_iY>> z2;S4DtnwV(_JDQ{K4bAGRl2j7UZ?6S>tJ-VT9tJTJlr%w_9u}dbNi2Kl3ZH#>a<$cw>m$ zKgJqA*B>@h*U9W;jf+3Opc?9bd}GP$!PjVzKPHO{Q1Gk&w{Ch({QaQm!Dk-4FO&`%F}~9SNShk0E6FP9_x9NGn1)yjtf~(*EN7O zL3!)6Hfnwvk7enXcwU++AE!l8^6P}JQ2f#`FSs$RuO?Xf<{V(XrxJdwb=MLz1~dTs z%#Eyln+4@CJpwPJoT|KGyMpTLJjg3#{+suGCO_jdBy_TqaoVv~VsP@?(!g zDSObk#tuGo1okf8sSC?R7p#Pif_Yj=o|?CK0^K9A{0@Dt6_z)?m8SY(AYcwvzjJ3O zbQIX>k#YE=V84}9+zI73&6H66))Y2N&0AK|rz!a}n*8vG!+GpuE^Ckm{}=aH@RFZ; zo{Ue0R6Cb9Yf*lW{O5d>9SGXO{Q>Q$=7VkC=&us!syKr7PW@uTeJp?OWxN{k+8(`A zDR}>=p%KcC9Qd4Z1MOI|QoJL|2Xhchw4<-Pp4~*b6BtZPBMgM)|6Plw7P+o9y z%|9&P)j11q4D3hkUtfv!wKq%%@+*pMsP)oW%P(1oTQ0nJfGGp~3R{eou|9G<0yZY$ zJ*>{A;u;=_HR+=Lvw!+m;RTel8!ju323pLc8iD!jpV_6zp}$Zw{CoLQDF2pN+=~7= zXB7#TZ@{-i$}B~H-U1coMm*2s)~_&@gB{t3qYG2>NJ`A8>t zTcYrJ(~P!M;B$qCNB_okU#rXWx7cshRctbNz3-%f*f^BWc|rS%yg#2K2kLL8H1!#A z#*PII6NoEn=IstcI=J%km#t8~SZtLuey`(5^YT(1;BVeEWf zPOY8MJHG=z*0IVE{m6p_G=;lB*Oq8GmH`b|^sAP_Z7(8s;rifsgR~6NbuFS7@i_z6 zY2{*n{Fn-Hodo$)pT$2RK5LdFoT#6Dy>9~cFW*`p6Vz|xCCwtFqRnl~@Oi{})||oX zo{lAQA$}|OGWmvd_v*PXu$}G65kh$V*N<6Wu%AqR^SSKzul+pKbAA<(N?UB^(*wLI53v41aB-lP71zx6a~yUZkHp*2X0sunn-o_>6Jop}G1>N}|Kh3tvRpTPTkENDwW{fpY)IpP197j$eD zUg!I5avk2s^~&5gJy6b{f4&y+qV10yRm9)Y@u^qw98#3&{7Wl=n+SHUuyzCDR1cp$1xWkhd)^4O?;39R@*?Unb->#l$I-eou;L}<=ZHM>U@PiL4@zrA+8N24hjgRA5p~|{ z!Sf?wc-`i^mpl;v*JbI?!*;uO>hwJY8oJw`+9y`m`E>yIY0bZWxQ_j`THaS5asTt2 z7z%Go&pS1N<0#Bp*dPCgr|WegfB@DHR<2ZB3SaHt5Y#J8S~3owPbbd$0lvR0wpU)l za>tQzZ)|s==HF^8->6#@hk7Zil$K(7+MXmpBCyW8as4^|5A9+7JF&bdaN`Kl==EZ5 zNUL>J&tX5q_MZrjkDua$Ke4@fx80BNzFgO~QvT^vpTvhz&qTxJ;E02H?R(`Ste<=P z7d79CEiVVhEBKGRe{RC-Q`B9`v0ifqK4S^xH=nJgaO#$0=P7&CIp666mTPzj#vwgp zY|xGEKDSf_0|D*(rc?gw?31wpSZ|Y8a2LxDa_UwfE&nJ@;pF$re5rZ+fpgrI0uKS_cpZ_CJ@nQuE%1ibqsC7VYpEL}+jNixq{-|Cv4&G0b+>#w02d>)#t4XA)!!VpcK8p*cXP~>U+@g3t2^p$BL$s6PIg43% znyZ74((9k9235XqIXa$UKdS5w#rJ(dgbC+K)|pdOuvn3*ul)}fsl#lC^_x%5r^?+L zwJEwtAAueG|8fWfF}{n1gCt^E9>0dEQFdv70W-H=oU!wvYyfvoE=t10qaPodj^Ue9OMkG8PN?F?A$ zIi|AsEeHdlU1dYo^%;q*`cZvW{f&B7{hrS(IzN+DUJ%Hl`_Wwu*C(U8aKEDhEZQu^ zx_=Cy7ObC-e*;inepWqtvynIJmLJR(Ws)bp_CI^|;Jo6#C8Va4LAGaK-1uc4lZ-hA zGuEwUlGcAef4{!QBv$PKyuSmOF5;1?M4? z>lSM@pJ0%dXN3n2CNfB8ht9$fV+PsQksCcnnnAq1W#I6prLgZ;22KZ{aI z0Jo0{NjcmDKho`1v4;@%EOju7x9h+#DdoLn8dXUr+8iHZuG+wNn{N78XM>;ccipy| zPenn_V~(`*a6e&cc^tetN+X+lYIC@bLL5!nDUnYQH@<{T;br0~2J!sLKk%8ao9rxa zv8bIGAhV(kVRg5_Pr|<>s`Lr?BYr=9T~!C`tFa)vrJVgl`g6pt&*MYH_>#PWsW#+| zO27PY*Kt^9ToS*cei{6?PjtQ?dI0$kcHIASd*Lv#{r#Fa)D4s3;qXp(_}+GIg43pm zAviZE{chEZKQuD^!9sq%>M-$=8y{+gb9P}*?*H8Pe1u$8{{E$UY=kUZX&l*PNhgaf zHoxjQM78?JceK)|LI_?}*Mx0^dtn)t(g5PzCum_Z}AtZ5<+i8={h$ zXNSl$p}SsEjolli&@08Mjyr0MRKjGYHJw#eJU+MLQ>#kk>n>%s2m&l$; zX*ucLPYjBzHi=#wBnsyG#qqm`VBcGD?G?yF?(}qxCw5FI z@eYyMWgN2iI)(^$oRC5+=n+=bzGnIge8**Rl3CD^A;N#8Wnh!k5P9>9?e8-u_zq2L ziC9qF5D~W1I579z5ZM-ZT(0=w5aCQ}amZaVM3N>hzLvWSdChendZ$hglDyV1uK9l; zAL{etCBe4`iA`#k=5NPAGMkotGopErw6V`LZD}1K)hksdT{aC6ce{RJlY;}~mcRL5 z+MWUOe#__h%Zfw9MDb6(kMtn9SYY#)sXajIjZQE1(;XnAr&fe~fxPaF_5bo^)rLry zvZuJf=|S>3`sBjX4g-YOGotc?#sHbIc0b7v`QC#jyAyJhhDffhNlHNCAo)@$XzmN& z!x`?&{jf-WfNW+cM_*YD`si{Wn+zBvN2hw2ac>7m4EMb7kas`Gy%FB_pJ#tS-qx3m z+-X0E<52x}bqlEPEEv78dw_74Y?t_wI6yMYH*HUv9w0@OVV*Xvc_$~J!F=mv!DqlEA{Qd^iCqo|lYm>q%YfnS|_TNoH?kxkv zHTv3-lQM(EeINbuW930oKDFe2Har*a_Q`EL*6>^nIa4-I2MAYZ?^clogJjvuEa6zy zL9#e=y}_oGA7oKyYISzy50VqXAHcO@fV_T9FSs5!Kz@C=AShHYK(e&*oq!nU=WaO+~>EwF&KfgMDSrj}- zxITTVNP>Es44Zpa^@HT(=Pr>Bok4QW=+3#3-Gk&a-}=+)NrQxuQa6?gdE~G7c%?7k zgZJdjqd&jb4wB2E$|hm(ouB5-r>s}LA0(1=E%m9zL!_zPDYH{|h(w5Z4;;KVKu+W_ zxFsjydFQ(Lx|2cDk>v83`{*FCG);I8N6m>Z_t$+pVf@Rgsebqd--$ffb$;1vc+dDx z`pg)>cQo589*oXk2>JSiI_jeu21!`g+L>7xr;%?~JR67c-NoFZ+Vy3K*jT@eI{9F_ir;@j9_G`G>+QwaQFIce;WK^vHk{|aS85pr)Fg))nW;-BO?e}++BS5u%+OqK zFbU43FTOSqnM)^^qScrF0()TKefy}Q6`jzvwb);ILw@4*o?3G+(McW6SgYzjog8?! zOw|tL4&UK3n%YPwI>&bTzlFSmHW$h=j(|LOwSog9kWOygIuumpPbUxG{*^lh`4&IA z`@H!WOd~6ML?1gq9-+tHu2NHw_lKKa@#`IYzf`Gs-PgZ2=|oU>rAx;_r-y7(!GkTjjis-~t+S^wkfKHg#|7bsj z=Wkh7bLI#B5*-qbr`wLGPS+_of>nE;0@B2(Av5x9Xw?lpaZsAY32N$&72 zj$r6#`Mul;=^4-;m49~d7DHaC>h|)?-!#&|yZOY|5gM`l!^iFi`K2w+hMELu(}{qd zN}w&|uiReq!Qguwjii$I@~V(0GgyK){_hrz1W8FWT!ir&FH`Di3gggM%lLOWj<$p7SOf;^kkT}?j2DZCaa%m7Pnp< zCOgDZl^?-5dWWdJ-c{R1h+Wo9QSCiCv2}9PISuyz)@bbF1Ny_{bce}-!op!V&z-P| z{|Dd;@jpDFknif}=povD$hTEm-XSP@i%zC}d~Q$tr4#-Ao?a!|!(?bfWz;)(z6F!F zn3ZC5qUXwPS8qfoW_H$M?;!t_?!p&)O-kwHO5`1OewPta;E}Gbe;@Rbd%gFGF~o%r ztuVp!kUKoK&4@|BKK3`kqu!9eDRa&|wv?C=^4a2?nuQSH+sTpkydsEOx0*NP4*r(j z@D+0d2Zzb>OXrWhkc2#}CGPM&;Sq9MoZ0$Q4*YL2CvxBWgP$b(!D|)FXRvRok9ZBk zcY?Syt}=#+P+XY04&<{Mk9l-zP6_CxL%-hw@6%(;q#_k2oeVr}=d^)*;JjTX`<^@; zCU*q}g?7vilP7wzhrh!4ukiQPKGWO4-*Q8$`E(Y8UNU5i`TBf#%-d8)SKDSYR0`t4r%(h*X9XyF>s1>mnS(#*)s1^?EiRMCI%UA8MV z-O9S#;oRes)-MCUhKYGg)V0i=BSb*=DxXc~2vKtMx|()u6!3jR?w4AK&)=H-XIO$k zdgi_oSAo18V!0hRX9$DTY&=!gsRsE#mK$qXTQG~3vqrS@3(Qv zGT@xaQoWNq;CTijlj4p;KMoWRUxWVpxo~p2=*bxQSDSE7wF%-ao;~eXuYq{A?loIv z0jJx(wJ-Rh4f~4^eIo8|h5U)00&_y)+$?ux3}b-_gSelFFi{L<5Zk10JZ^BVGw*nb zm*#6YA6d6AX6bS!@m21t?KEN#9p#q+NnVhLB(bI>Eg$lh?3?3$wShsbwq00tl7mU= zv(L;Fz`4%V9R6Y)J7N719QNWmoC_^pqM5||h(Y>=^gFa656bJE7hA7^o?o`@cDObL zex`4g@AvIykcCg~+_F!Hb;3lIaM=R}>CP3-ZGt%IYv;ZlIRfV=;|wpHk!ytbk;1w> z5m?7O^y{*&fPReOt(atw#^l&S$P+WdCNO07gF)WkFQ_5Q#sTu}i0dyiDPfSTnC)->eg^%o{yDTsgGuO;wI$V1zqjLH zsh$gy^Yci+c-AHVyb=Xjpyudn0yd|sV1=ggdQ&dfQlnfLp; zt{-UZwt@+V%MbJ~bk=2cBb{>0!>_&$~_Q%S?%DMY@?LB_>@O0!9svrCO%=7sa%GjS0a`D>~ z%1-Isk~}(v;Omj*jNzN?6z@|r@a@CCcS5~omOV5H;eS5xR!wvF1|i76EJxx2*m zIDG$NK=6D?=oHe@etwDt+VlFLZ~q#;kMY~>#ed8zrV+DrmYnz452QYLjxs#^14X?` zt+#;h*NINsA-z!_{PH4ih7msR8_9EdHZWld3AQS_j%H1vmAY2(T$CvkdPLSfd2R}Q zd3Y`GFFkxOWTKCf!f&WQoBKNJ^b|U;LTOFqm_~O*9;Jk9!S8H}8Cn(?Oe22d0UsUs zoV4$+={I?cQ)tg6Wv=BC)2M+n@b))H`2Oe5@k2Qw@V$+1*0C|e_f76>JzTnVEqw3e zev#62`Dr9o-|~XaY#QFPe&}-X*fi3xk*fRbHid%x>}>y!%dB2DC>Vy~}=*ZyGV>Df++DoJRHKx%B3N)9CI~?!nlCX_V+4xXc&6 zXZncQO!qhV{_2n>7Io?a_#UQBW$#d^bvKM~VNZkkto9O~t) z%o0Tk{3J*HX{H>{~JTPe_5iT6jI!!3M9U*%q3PpyUDLwy^){(3EZ|D??CMcamHG-uVDrt}W_VWwIWyle)o{x)OQ zCq9Fo^0k>?eKL*MQr)iW_f8|;ju+z5{^{B ze+c+DmeT7)=P-?8KD*Rzv6x1}Z*%rD>cH=4oG#kz0>2BURqW9CL}~_pr{Z?r=AARB z_hh<;9Q@u_bBNC8SdJMaJ4a1e;GaQ~Z`=&ElxNWK$JcAcvwoyBgWhI;6c4k2-*3$gkzD6CgM1H6pX{2SMtwqT zt-YYHUUUEExXKLt{^Dz?e8(Ad_DIC&`JfrJXE>!$WIudwd8Y^qKm3mDXA4*ACK&(b zHHR5jw*&es8+m{q_OMEI1%uzXWmlXpaF{_nc{xtHPBZAP>!~l&(2r>q&dCp=Gbp0A zE5cKI1|=SyKEE${2E7^0Nx2g~gQACX|9Vkp(Bb8S4nh4;u67x-e+2wa+EB|QHp>~b zdw#O(MJfCaZv2aLG7Ph5yeW0NDg-B;Y7v8#aR~dW!x?JOsa(^WCV- zovM2Bi)VN9G*nHaCu5P%l7EBUEA6j3!tb#0Ni|L+O3a|Z3t_8M1!mB21vAe@ zgBg@>)pPaI2lzeR?cRYc(lhWoISN7(Ft3M`%rz9k;dfEEy_K0)&LR;Ru2K5o8RWOf zZD6DTzn7bF+Mx>k@I{jHvjcv=rTpZT9qyDFB>kx>PwOQ3IijM;3&w@f;!xpt@Zan+ zdj3UN2P}&|b1LnizhtJxaFfVgH^(D+_!0)YuhH#oNL4Qsk z=@|sOKW8|{8N7S}6n{pmZ6?w{8B7DSyw zlk-xPfEy48vd)>9@18=6Y?re2@}|*XwbIi9n4hIL=#T)cKgCN$x*yZvevX5uXv_I2 z#5ynKIvh5QbXYgN<=3A^TH6nt_yqBpuZGv)lkybOGqq{|fqt3SoA3?e&zt4hTEV`s<7iTm1jI|V!)XH_zyCmd%U$H! z6n>!PX)o7aI}3b;j$A;}g>~S2MmjnT^8f$!KPEcb8wd0p^sN4lzV42PJzf0lrANtQ zdr+gNV}}38KS&|^|I)`FBZR+1TJishjF69WI7JX0c~t;flx3xpUBuVB@V6XNaXteB z1F3*zsXj*fYWRH){P(_&z|#M?mTDn&GHST2q7xxGjHD*0%ggbY3mrFf65oTj|NW2F&VTPu8IiUnGyebc=RN$Q5&Zo>^(Xe_fBDk~{{8=r zKmU7w?ILfVW9$F>d|97%ocW)>|9Id(9{7(3{^NoFs|TcI@E;Y)FX4_QR9nJ*|A+iv z>8eZV|Ai_`vh4q%FSjHsEa6YmAQf#~l8u&-a|wNxu#8khMdM2{_Yzt!;prt@wiEw@ ziu#x8)mcgxS;7lTcw#C4&yw7{B!5|wb(iY#-;NWgNO~!MbSZ!3lH5i*LPZDm(Ddq; z@~`fq$)3cKRCH64CfknUf>g9=sXy9F^_*X-Cu12+Ps@RZuY_snK^#g&JC^F<+Dl7s zAswQkRA-v(u!V-3lxZloRBl@ft=+^08b&G7@^dkOJ^aMsRK&hi-j$7(?i5JFvA48x z4}`JdRP^T>u7HYUe6ZnE^x-Y;Fcn$q((>oDKm>U)aV^37#kBGj9JKVk*J#MOiH1x; z+lb!l_cZxSHBGh7>N31Cs7Un=&A#f5vCsi3@^XtI^?%%>PV#kI zXnGIN{vhcCo770VHX$Y?|FL!>!Ri%BB>%{xha~@kCmwMss?TnQB}ql@JN|(~sHk;| zDmZ|OnCxG`jHV)PbBlRtz?U<0yBY%Hq086{G{;* z1f3Lmh@JpPJUEDobhVSgFe++ip!M_Xf!9RO=))$`zuO~O`Z(X|_#`-!UC4Qb?P8VN^I;cYSG52)POspSb-@^Wb?!6H*Kxj$u-qSY_NgME z&(*stu}t6D>`T(WRD8vHjAg%I;!#n0s7JLd;K15a4ve#_-C;#hQDq~25!U;5(otXhsob#rfVZ zf;qPWUUwS_!ToYferTZtxXkuls083_kmCw$M`K-1hcO_JrkgGHr@JTeq{c=F_1IF zb~2tX<;VV8HBv5#{g9cf`VE(txh1-Y>odHZ-fjq}z;v+&`};VL-oPX#{ z@NR5Z+Q;_o?to08fuC`|_YBx<`Um~Fx#su|K9B>3PX1K`Y!OJx!{w|m`&(iA62H%{ z!Z__t*M!rrcH)3WMbCb5HDH;?hN}$A`IJ|R7?JR*EG8Au@s z;7SkhRv(``wqJSg8(EA;uavyQ`T_^0a40n@&{T9M<$YpmUJidFj zu0DbLyM^z&1xA^{UnIVTed#CueY-lH#F@10eZ=0Ifu=-Gt+60+BcyPMq}v)_AoDM- z)r-WP^HaSf-H?CI0Jpd7i9Ly9Nx#@h+%rl&4m&m#Nn}%qo~vk&2bS&X(Q%CR`%+0e zJQ5&$3+c;xKKzf40(YfQ+fNMnjt-+gG*j4Qc5oakHQ|0J9w9RTi2(x0-44GT4o9`r-weyonH3h;x@|^FqvtravZ0 z)ANK~4C@OXru8>`$qp`@4e2*90P-#&#}Zz|Gy~FWm-Mri^nWhpLvSMbYnS@ly)+K6 z$Vs}-Qa&Hd3S3XX3K}Z&({LV7J4m0!?gcDb@~@6D&CYjAdJBY*Q_)^snx6K08V+KB za%+~*Y6&qb!|B;e^#Um%GNH4Op135F=>ziYQoFoM_WoYVH(Qb~EZM(dY20ou_4Djf z{f0~9-?PO3d;j2qRD`1f#xqNLXP3&^5`!UsEiK=lOdN<8OZp>A?G>}r^7Z^^cnc3J z)Tgq9p-XTWR&!J)q6EvKurEil-sspyeOfMk`nQm?nE(!vjY}!Nk$9 z@4TR;t1;8`zIx&XMMWITY5aaWJ?8-d2ABRsi(>cRQ(X z{|b82zhM;dyxaNLn^1A@D8g#7BEt`_12@v$)(pnI2~>cO>r($Nc7#$_Z;CZ*YSM3iaFbkp3*H$iqn#c$?89 z!k-k%8{xnN>+)4SvClNUkDMEFE?kDAI28po9y^73yK*R_53c83i%BI$!8<<=kanAt z1?53b>=KAG0&I={o{f3PiJbRwcwg^*PS=X_k4(PkQvsZ=y?BEgFj?qxmJ_10S0wm_2LI)`yg%{1;~^>dDIE;ugp#-4nX%)ZR@d~hd$?? ze!#+RznWCQM|56is-WI|oR<|o0N&B7uI7@3c6na}&4K((U(1qHii*BOs@dp(zTelA zD;NQH_^|431Qb2}XD%AhCOnW4pJ&ou*I3p-Ii)N6YcU_+)|59K4_L(D`)3_s!B(RK zMUZc)6y`n%aW@X$dGcPH+7e^j8g9b_s&4Bs;zzk4LEWy?wYJ>;W2EJ^{wen~d#)^qPV6 z6L{WnYwNgj0#3a77EVIC#TujBUx4g;cJh?&pdxd-eQxp~D?ACWOND+M>3tz` z0`wONja$Hq@H;dwv9Ak>c2cZaK3;r>Wnv@6B_ z+cKyJ0i25T%G=-K^Fw!&=zY8{&aJq5bU&bx=@vr-cwVba8vCQZKuQ$%^N>xy9*zsk z+T@oFK>MOUIcstIPhTqbV!xD2n!Ln%TbGI2V}Gh>aKD@CG>)E8=S&mVNEq^~A$MLvaqEE+E9)R^jX0~zTcD8-@Cw4k* z&?Rv=i&cp1N8LYF$o`?WY!ivAHEzZveT`l>FcB&mW}YYZZvBNBAQg$Mq3wfAYcYX` zc_;cyA7dWhVPHbApIZBpdUDp~5Zp2Ko?wwl`akRsj^%kk1mK>>pqT78>w>+=zEsRa z(_4Nlg%Rif+*k=G1(=6#-GQONJ{9H)8#m0u@^Vs6UmdnVkhhn^_5djU5)(0q?}3<@ z1E1-DZ4HoeZXZE8CCn5d4n2eJ0!CQF_61m?MC-@ybC^hhUx#3t0Tx=qHUju7igv%( z^4^5Vmr5PT{;6PG01d!Adpu3jC(Yox2;^c0+Wx)uXDARSm`B^Fga@d0)A-13*)q~! zug$xN{-#cvJrZy`f%W??K{DVS4gkQyUo@0jq>Y!n9gR;VG}6i~meBg?f!z)IW5I_B zo|>fP3r556LAqx>t^R|>G`%`6d{ChxItki%hvk4hj4_ELyrfIT*rzkh7ko zAB3oc^QC8K80A9Kcils?Kjonn$uIY%t;;zh+W39Lv=hqFg+Mq1Jh|Zu6r{rMU(wcS zW;b>$>~9}vygTGAJ~#v4DeQxaVgG&0M)FgRU`NCHzeGDnjJ@S1GAl0=Gyrkn6m9(m z+&3rbH*8iAj5%|aV2{dk=s4WdMwAjco&!$|;5`Szi2T8MkjNU{X=J_9nY|!6e^0 zWrF1YYTHK2|1MpGl}AMfqxVK)tU8~z598~jQ4k1#{~UNkc(laVqZhHv`0XGMM!M2b zvOh3v{K|mkA`+BX|HnMWgDb`*D8xnrpBU;d#u;Kzodr zS4f}7`^~GE^RKbqHp66?7;w&0Od{>3JoRG5GW&JQzjz-DUAKQH#>1DZ2!9{gt3~#Q zFk9X!taoYhoB(c@(TnLT-p}ToHpD?XEQg9G&^;iucQORpCKgesX>FB$oAL<4m#rpL`BlGXmBW z?=Qves#Pa(;P&#Le!Ge5Q890Rg4>Z{JjRXn;syi@upY~OeqU@~wNF3|)|aWM0Ss`dSTMe@I;Lf;o$j`n+O(gx&Xcra&-o2Lh&P{d5k1^lauMIqILD}scK95+HT{zDJ zC?YGRYpOs+k4@IR-K7TSBje~6C#dJD*J|B7up@H+is8db5EpYyO1eQ#)o{I`!3;c8 zZ|0)uHaI`2ejL?Qgn4HB=%pXjv-6bRg)b|Br&@QGF#e*TcYE!I&HyjYa~*R`g!U-8 zfqa}$-<9a?A8$cBYBjfglpsIR^EEXA?3*0F&?f`=+-Z!@st2(+{bVhFq|@T?kSvmPJOcZ@>m|upF^o^25`d2>qpX|@>f2W-7dj1o zK3F&;oCA1bhndQxD2>Oy?jmc%H&@wAKXt-qLh*I2FcMtmyYkWxzV8<%N6rf#;gu ziuVsnh5nZSL;iu_I1cEGDQe%W#a?5s!<+r9_vRM9%r6$|bDQF7zM z^Rjru6dyfctkRk-hG3U)9PiH{kj*mro;rZOLchO<2Ivb_guGsabksN|s0nsB8p;>#~oN=3v*3LdND)kkNj*HI2~j6SILQPau8blh3#v_@OGQarirwTP0Vg z83*;qY~FaU))~&df;_=%z(1O=^quXY9DPiqju#$Z$qlx=FuojoRaN*LppxVs+XVQ$ z#P^Ii)N}bF%QY*Jv&nBUJvxNNcqdo>JJl^+E8!;!yC*gjePY6^}kuMBSo;q!dc z)k7z(A$_^WnTYowH)O2YmJDdzCzrPX={wB#Yjc3CbB{+RAM823S?2m?u=mKX3YJhv zk8%m>908R1t#ksf`;5(J_jH5(-XVt*Pl5hMCtH#0fIC&r$?XDr_9Vr!>;x=D3tY;e z|1>JX7@u3daYQBH^?Of4<|U3ZV#iMJ#c`+Yf%7|jKGIK?`hm}R5uvgq{{3(atik=b z_UjyMv@ouWAtyKiSs3V&a6A)LqAS7i&sp`=O{}NRQU4a}QP@80T?sg}@zGIsz*{Dp z^YQ(KY}HjDf-p`Bd!umq^NIZ7+riGG$q{FdfLuEfVuAhKI(>W%KF`h878Y#=TzqTC zjLW4RSr3F9o{wsFlYJ-2Huoc! z#J*2w49Gs6p9b3$=;_8D(!sb<ef1A8h?ZNAxyF!7&ihuV}3x=N(<^7+{LP zn}-jPemL3T8+2H2nNp-3wdi&++>f+(O`CDL`MajI7+o%gk#QCHhHtDPj<5dcojV?=%n^G} zT!!mCNdI%4kL1Vp+YlVP!c8!L(17IUKJO&@N>c13y}@=RK_gojE+|iZFSZfmR>pX; z-&<)$5jJ^=Su{I8?WX0Q zrh{n>`OoU`!3fUZm)Da1sQO^X0Z$31)m!U9J8vTs+BrEf%$Vr?xWh^G*5BAe&}g1E z@AwYV%16HlB=bloPM_r8OMztv_0Hd?ol7=2ye9Gkh*mhAemj*-op_S z(l^2RY&mkoev|wR^4WS0o#(L@LS+F=fH>rzC;*Y=9%TYC`Znv65OAi|fxDP*ue7ccWKb z2|u7;#6Qh7fRl3SkFlM(TXQ5Zf0ozN@WisPeLOqX=aT05We#}5r1>zGtr9EZu%Co> z$x`sX_11Y`o+cpMfrT=xr!o1i4D;%P>`%+^emqj?KZxI_INtJ3SOn0zb9KW_*w@EY zGS@MH?0QBe!W7U&W>I4U;InGVUwqG*72L+_2)s?h%(%uE(%-MOG`|G+vvV=xG~`nR zV(&3Re);#J;v2BvXU>cB=|TRr!O3(!KtGiQ27E3s;oG3_2=ou6C$DM(-tgec+8zqX zm({!{#UQ^p=iYkELvj^;jj_Gl+c>O@fhWy64}56>J;m!rE_skXPi?r$0{H&7g&4kH zHx&?Md=0$)qgLj7cW9rv$)>Lm>W@Ce-6aG2wp@Jjw++CTj$L)vPG3bu>kekh?*si( zmy$Y$XKe5jnmge7;%DcWk3iADoi| z3}@FkfS=I2Nd_qIeM(eE^dRt)Gpmj%+d$mY+-`N^M;Ef)xog^#LP5fgx4#-6fcEIF z{p;QhJh*-RBe|m;sJWUgGugZut#>Yv?Kt0sa$U4v?LFU(wo14CZr#>}zN~1j&9G=h zg^@o`%HQim#R}JVYzF(%bogc~0%2cG^MAAo>J?3z;};sIpm8OIf;KH!FVe?9yS#+) z|JkDa8tf@l?fbGWg@Uf?1#_K!L_zwzHg_7gZYEMUSzddZIwNYk9V2t zr&!?k0qW%ub#Q)R>fm{7)Roq$)jc}6qR!@69UdviyRihSRxbGhWfe0p-L z?m+;=39|ydG+l^O3HR>p`U?GFep__Fp&KP`^oo2F){U5|eYS5k?nbI~Q=Y-B-AG}B zXYrU#56Zk{7QKSI7l|4lMg8fa`Qq1m5G${MN7>VEbcv0lt&XNs1^&)zS-}VASRICuAO@H} zZ(9W(SHihq(zPmC+5n!DGHp6R@95#?}q1iq0ub#-6)PX#E=8V zw|2$4B4273a@Ak#n*Q1apX*wy#TEnS(sfp%&*8k}FOt6bjwuD*i0l>$#?^Bh3GPv&W*au6lIkW^tU*8ujfN+BGd$!MxDfAkc>6-Ggi`7aVV*V>sCHzOeUg zZw20u*vd4?eF%eUGTgXAylS8%**vadG zfEVws*t`#L>Q2mZY}c4X?giY>v%8$s@cHtOaHM)U*y(AVbq)9Hf~{%_K7UF&J#1bD zc-miLH`bfcT2Q?U^PK&xWcL{8_ip*>{0-85UZhQofnT<69rqgoEIj^64ckBD+9r?D zW#~LPKkR$;j_{hFj&xplTsG;fmcw>RJi8183-;xm&w$uM`5mR?elBWcSOd#tl49X_ zzua|!6D}ZO|EZTEe8q$bU+1&-3fB9bWJI zu3&%ai=IB>J`y;)k)FI>NUJUmAWt zy%*=_-b)q3=yU@g2wk3`^6@$P z-z||JxPO1-pGjkV0UMzToZsbKZ-MdmCwNU0&^1KY02&A78MKE#q{q)`65L)pP4bh(ln8n)%n_t8z_I~7 zrPdV$)h{a%>>EBp>@8JbBC;z7?Hn~PlR?S_9$rKIwUF!v2Mw5aC7mRF7aP!EkoQf{ zo~wP~l_fk{z;%K6ONUp1^dALJ)A;p+BZQY*3-^=q;~Tihxcym%AAkUF866{fTf7dD zayh4&z!AVt2fo{4WcqQO*g1b}fy`637$?$B+H!qj7w>4=3p_90jK3iHocru0aXD+# z5qRPQaq4^ePn=KR@O~Wg-e*Y?#NX?x=Sh3lM7_y)ymj<~11j(~g$Qz=v3|b*ob14k z{erw0WjFTfVdOc-`v~KKpou8FUfphg+=u0jZpTSGcKw0zSk9jjfq?-2c07><^Tm%r zZ^`>6sk`TH;{07Lyf7f}+?+{q2-ox0IQ%$%zva(gF*wM9U%1LS@j6K;>{Y_~yv{PR znAgjO*?e;ata)Wl&I3XrFXwSR3msYZxPRB)ZQZF3XxVkh3iDiZ2X#xl?vY^eGF)F_ z$14Gh?woEaYXLp!_ebJ5!gu+8Cf+Y5<-Q)k?d;9!_>K1!1=KHy*Wa17g7#FvPL33> zJ%9xqm1JGAnIAig`M4zGiEBB4ZD&-w@V#8^m&@$NfQ}D1_u>1wzuxN>&V#%o(bW4h z$YhTV{Zl?+S-m~YJJbY;|{7%X0h$Psj{@xvZbq4a$ry0ID&}WNg&b0!) zLFL0nv#FTVmmlV1$}qWZlTs%y6LGISx2Se2p(T$hR`iA3O zDE_Q**CF7iy}ITD{`ufU?UrhQ8q{LrHs&tX%)S0*yvFWpO#ZL|doMYmEM^gWo~Q;bb-~ zKoYaTH4d>wNUqSv=lt<%_&z8#qi_7RNac3W0Gmk@>Wcp87N8Gte8YhqV!#6%`Sg2S z55UXx1%~?@IlGYE9qrIF++8U4Ls1_q>nrrImRee;*n@5#?JDJTr=b196Pm_wj!B@G z{xq_!6Nx#<44f41L7I|7hg0af(U#9Sag}fmTKVnoA2pSBWPj|&!?{zfh+p!lP|eP6 zwCYtv#2y$g4WB_fou{2BWXI0s<6$jm#G0+zCAtaSUR~`H@UI)4Vi1d~>g_@n+D)H> z3foZ%>-#7Zg=Qo(ddaZTpaBJ)vrG1%??U_XlLz|4x{zQTU3UlYN&4`euUUXko;$Dk z?Jn@i?>htK@9*hEQgcZOUpzVyOUK41?P?UH;~;SRj|<$lYn)C9bc1{Sstk6Yf30Zt z-|>~#`diRe=6pG)&7H{MJmXyZAO)Q)4e(XD4bPoUZ8d(v{1R35e&7i5X+VK~YXi=j zHY0K6q`l<|UC4Ax`gH6x1qI6%YkdCGfG*A0MjiC7MJb}2X21VvKx?|ZdmUywkk-p% z)>DEMZT*HX6j)Dd*0XEhgXck0VdWKfVZHA*7|#!F1fCWAo5wf^cv;sW_DWbUIl2uu zWFbCu*E??54d=`9VtVJhzbR<5;-}(*THtFw1Hx}$J~$|7^iq~X{B~s$J__r0R>DX} z9o9uH3+pf5tFV6iZ#o=13vuKsf5BULp0?by&M(ECL> zn!*M1w435i-wORYdcLOPHSqZUGP-zNI8hDSKRd|Ue|6$9Urneu z`3~QoxR>@#;(ajnO|wZV;BeLn^#`C&XYD43_amhPFTY|Qf4-&q0ls${Ot@y41@?re zU$ia;In(9e)k4s>=a{>G3S_=ZVenB$c>mdQs?ihrlib96Y6$Ed(kNA`1HFvx@$i8a z;17P8d$9g5kD^VOPwsSmDvsN;jH*z@`z+^?=a2FJ8J_R&j*)q%T0Kq|I`eH6=H=Yk zSDLYG*xWgR@ud0HpIA@mbwu52K)>Pp@CgcdE+y^q4D)P$|G#{AA7*wrw+`zGXl|dv ze#$;{xMe+{@QI*RSZ_s2D?Q#dZN8XRYVa5M1Ahllg7fUzgH$Rbx98 zt||%Pdhg_}1cC_To^4Bba;MHg!dKZm^$3qL<7g-O18c)c{XAZu3C}THZAG42MEZ5B z5v)Ind3agJ`dB1-y z@t5LiE5d_068(T^!a38~G6m~xFx_+z`z!nX`B0p$#Iu_lW97zU#17Wy_<|jt6RO-G zd~!jhj>wHdx}+b5(h{U!wPp?^{mUBKz3rc?V}wt}SI`k2$bP_{oUbx!;kX3#h0Z-A zpqa_jjj;c;hH(YxFhlbSg+f6gtWu7@Qa*7X4KRPe?7P-csVY&a?uhx2I~n)5}s+n zJG=p>pJ}q(k1?_#i}-^2dBXmB|c z%PGBV23Sw1gy|f{*)DBi%ois{D-Hzrf}g3P`BLNu=LYuPPQ|BW5myjT`g z+v<+zbw?4;R$Q*-y~-%IGi9XH5}!94g|}S9>)?^aL<^SpPV7qz1H8LhP!F$DF7Ns0 z`2IKezLuTQ&#~Qt-kNDg>`Mmo3sM2cfmEwIq>>rzh-|H-xCX8YZ}Y~!a9YXxFe+u_O}GGad_`#_L^Jb@njkvvwKj{}dqZeDt~HSq8lD z)!B;aPRM^>@oG^Q+A&q*EYg5{#nBVid=S@@Zyo>T$^_@*Un}W@q5M{Ht6Qf*Z|r*e z5q5}kyv@CHU*Y~NC%~9%U>WS!^lOjQKza4WBMYH$kEQn1XDo3O@a~$raxEj^fkE7D z_c*#ynr2q*1x>g=W;!xF4E4Phkubgre0f_k-K`JD;2vunemd z4d9+~S2UOCxCK1#^3i`SHbFt@tW}%zCAyGuTwqW3KMIPzuFH{W3H*H_by9FMJa>&V zVaax-pj4q;{|g@7@OjMF z8W5ro(2cIPc@@29qaayJQK7z#-ROzehD-;23VLzy1K;tc47B@PgoG9JLoSSU`8#$B z8sn|r_VQ0Ry5;L1yRxYPiKLg=aBWYmnp*C=f}y+<`K`{@d+gbRUdq?Hd==_IcXhK= z^V9C4!_Rr>_+FKvW#3I_3)OqjmWdw6`GIbv3tyIIa=HTTs7-V-*?A3>Ow4EL^i(6h zV^4VYr@lh=`I1SSUAoYU-5(F#49-W2oau+V9zRA8wvMy~CKaNhn`X{y6Q7_L(h~n1 zvzVXgo}kx5|BME_3Q^z9piu*``%UGd1V7 zu5dmsfBfYM8lTSF^)R{!T`ZbPIkEg1lJolh@J~bqDrXkmdiz8b+A{Qx>-)W26yYAV zmHN5}_0DWq&+z*RT4TR_Anr#Aayfb9xs^c~yl3`0>u)i#&!_?YXtP|kEVT=M59V0!1MLpv_$MKA+^H4C4<@V4iM>P|%+cK% zLiNa@xKE*us|oolRPab!HzLmai61_K9|qVPr1ZbmBL*?{?0UUgWDq2vy*IuNmANxy zGRoGXH^##aLl0_Ew&1gEqFgUf(bLP7Y8$E%YfJ*FTC9cdSr2Xf)b#?5C$CIx5qW_M z6cYKpJ*$!BjPV!qkL9SXGWsj`vPQIiGIdrj0Q4PK{ys3)fMn)bADsQsfqcssK8Xrb zQ080CrVra2(C;!6QMtBiBrbd8jnn80#PNc1FqW$gA?7%K=5<|Y{bKsz?0%I<9+x8e-Oc!H8#ceV!TXCf<}%nNJXpToT3{Tu65 zkLY=k?OM3k-cvI@X?7j48TVXq-`p>LHfeAHaK5=F5zip zhIM!P>+!*du9SGY$ncMI}Rk~4lh*o8LujXK^?hRjFKK2*d z?-bj3_XC{EuQ0Q;4Z?Xj%t_YQ5%dpU$;_I$5B%52YwOiZl7Zn2S|^k%U4?_s*N`2D3r3gVUcUPRQs+T0J&-7B=z1Jdlx#y{Ey>n(%bD^{}s8 zQlf8EgY>E*<#9jI^T~^D!tYNN`DM&wJ9XnLw_`qOd8X?)#viA@>R>(@D?pXS`*fTg zKkqR>M+O&1y#JN5?Nh*d8A|7R@xCa#Qikx|z`OJ-Ft2{9^ZNkaf5$7gxN89ZZr)ak z?}-9FNhV+(5LVC@b^!F4Z01u20e=PU_BVs{(udS5c>ljuCVvh;2WUx;=njSa-KYI- zGy;~VA007<^cyh~`IwhDR-c*|0vw7?03rwb*TkYfuKyZGq(9~<;%Xh_UM{eoa|@P( z_6P@HGipeUYRIDE!w-R1} zfajra%?S_INpl^*&sj`LKflI$zh=|8us?EM3V*_WzT>~e#7;)Y#t=Mv3Z{_;ggN)))2Y4-k#iJ8tqet7mHz@IJ_YIQ6Q<7 z^vgL3e^M5B?S*Vo?)r|JWmwN@k0#;qAH$VIaQ>Y18AFV=&ua;v)X^{C!0mgRg%EzK zB6*nb&P?IWn2Fz6YsN6noogZ0>t+mU_{33TxV*jpi{jHwNFc8f;5#!LoVy zCin<2+~+E&IN)yAlq#w=#221RVbdBA?=~$zebx}}L*~R%BDxr09%yW)xI=!)NadAEz~a#2 zo|B+Q+3R#f9^z$=HILXRJH!ov1-V4vk0YNCvi3nd5mqed6@fS{$NwSITl>2Pjv+;rI&m1z3l#pWmtk{;Kg*+usFn z-?z!Xp}-qm@+3a+!G6S(n=m>LJXY=7qe?@#j|gDjyG8sM=&kMAzvV03$9O9#_I#qC zo*a+#Eh2FLHl#eW585?Gw%I}cpjR-E%VpzUBS=c z%*XQ%!E?*F>mLW;J%Jo`rrI+}-DuDHHw-eGy~t6w;8M3)H>&b?3MjrrK|{)3#(q%l zB%iEVDLfB0vvIi{YEz2t$HlcJ$aW)@Lh0}ija~4ZU?HSztQ(yjjT8yF(1z&imDWAG zlUU`lXXvwc?<@57ee2D4CxAb_+y7y;Xg*4~T~QIqnuV$}=W@o>o}ya`2AzlX`;dvO zYLw-XR#cI;vYqAC1C%s-*uqY%09}pVUlN|1iQ*J@-7}4ad*1QutvOqsqvErx9oRSA zLq=JsJBU(@ejeUyf3xT|GLeo97Qa-CvJ2CUm5UxDkC{USJbhWHZT*n=p3`~gbD}qU zzkVJv@zG!p;K)WPllJy@R$1t$cZ&A-NIufOrS6fmH48q^`a|;0!EAJiIbB^h^f_8# zHQ70D@&x@>zIA1Y5?4++vOjwn8V zh%U~26%(2+K}t~{!)5BpWJkzJdmj_8(r#K9tJ_h;uLG}M;9|5io;s>m<5 zx?oj?PFfe|bIj(T;JccQCCBnnqrzdHFs2-IyJ6X5Vc%>dOUYwew@`qb0{)fcROO-5 zA~H&TTk_Ct_wO2ekL4oDiMx(+f3i{IKq(J8l8dSXj2jiw>QO-Og7&e6ADy`a_lcdIs(@?wQa> z=D_`b?YalI4a?Dut1r)pSiL}=bpNswt=bTkNq2K(E}UBq{;{kDJ!)&u-;f7Skmp#) z^Ov7W(PQ!PZsq%psLOoTYeOxq=d3{P`cwR$VPEFQl@JRx}j;>K@29#4GV=mxqJi=-p;HA;2-ioiP`6 z;C@l2^D8}IW1&{_J!oH1Kb@ll>W%p@mzgRLrgNZ8X20bq71$9^2eL26hVem5SrfGcz64h%p0uyxdFcF<+T;4XVbxfK|eGeLCb1 zjMar-20S3Q#{%mOfA*7-Ztys}0~%an zPQ>>b2|8%!B*g6<1qx>P-eY8R=vEf!H!#`+odY@M)AM7Phnh_a^{fHAx#cWOi=f`T z1}&F1(3Ahu?}FR?DjG}m1MCmG*?{jsUeF6<;C=H$*T4_F@7muw1rKiF-Y>;-C6=`x za;(GeOPH?-*ogPl9ucl|ybnLzxh)v)*B(Wx%{cw`s<8n4{(;YU%xC=G`4s(w6S%#C zUj0PumsMY+GjP47FR#nvd*NPlO&i>P*=~_7cpvUOdb1waQ{>_8j`#Nj=E+!Wr}(hO zjqQNy^siEII=hCX71nqDaXuNhf3sGe@TK2nyoA4)N$w!LZ_3^cK41p($N4VdHz(u7 zNWR-16>?9yU%r><@hoVO`?g@oPIABbRwEEz9KiQKFZnUvXZhuWvHNZ+;UU~zY-+e4 z8CR;|MP#_oo4-o06x6@x zO)BC?4B)C+;WOW09yr+!?8N6Bn+bQ<8-PizU6Jcxy_vo=amAm<>2UCgp8~x#xs>n5 zkk6+#sJb5Tmeaok{Cp--^9kKvc<#ct)nWftNN)+s-y?b7SFN=fs>EuQF(vL#BM-DXVMM1wy z*Nea41>Pm^%5ZqQ1(b78+dT%KXHtC1TUC9q3!VRyS#8A%>*|Q=;4=e=r~9s59EZ^VAfq{*ob_o;|a*Ddn zEs}!vIDXrZa|!Oxo+^B~*HeSkAKc+vapgu;hKchRd7UmKdcyqTv|kSr^m}yM>w6o@ zC{g~o+57?GK)*d+W>urYdGX}UIo)WUwV<&rts6y$NbJ|%0QWUsEt&?c4^eAL-hm38 zYNXit7B{>tgYJbNzUP0KkD-By4i zRgTl=wdbIVl*`F>ExBml;xM-#^D{JJTF1xGQh;RqUcS7eoR3C(c~-@5&PUfj&iF>> zXCVbs?Y`3JLL}ARtN8CpAyWKq)E6O;kGAkUI!f=5g_2k2NH7&=qupVWqLJI5Al1JV zCQsi&WMV!h@+>R|g?!cuJDvL&DW<-WSHAfOEzeqH{SlXkTm@B2MP>7l7aOJVb$l)g z;K{izIg*VyBq^$nDY@uOS*gB@^VtPRZ1Z5lnUpLf&2}%kaxx2LH4ko*-{ zw-1NrpnP;SW%b*?YYWhWB#K_)#(Z>RZSm992c9Ae^V~GGb9Kn(2HWTp;4jK4K|c^3 z1^G7}ur=t*K|cH68(u5QN5d*}rJS?X=vw5LAcwG4#GHI^+0=L^T9|ZlmhUM*36H6= z>_>7?K(Ck6`4!Jlgx99#u$~5Zf1X8eH*Xsn$;g*ZD=$F(@GTu;B?V}`ySB;V?k8xQ zXr!@VZ4C;mcl+$;(u7i9AD9$dmxpG1eAwFg3*mbL^&O(^o*@1m!~a+>RH4HX{?Q@o z4T#4+V$iLn3-O%`FgoWC`=VmHWiar*qV^1lQzk1$ zN&A1$blveleqG$i$lfHg6eSeda?8j{Hi;4~NrR-FD3MVT$}A-!g^Y}B**mjk6dFpX ztni-m_`QF9Kj+@_-1Xdh&i9VzKGkH4=Z8GqsRkl$HNc%H&`ul~PIOq`f^qNeK(hkU z*Jl}O{sZOQP}*oR4*X@`xUe0rD@loQ9`^^kq|Vy0@+{bKs{&KEyHKx4wv6XDz+Q59 z6buA{os&#b^}~JZ182|9`)-2zkH|b?fb$}MJhmDR^TYa)MCsN<;8_3(1g7oD$j+(JU`ibqS_Y$GJAAJ*QTfknQZ&28X z{>iRM+w26O`G}H}EQBiuw`E#_-lXAae%wcXCww6t_t{7OgiSbrJoYA9VkPjxkG~|F zZ$Q0z6qdWNg8t598L%M+=a=lma^C|cbIbMMdR||>kMcvPS7L$RkPJNkTtjZ#U%%OP9&4uW4vtvE*O2;mck+ZnJN*J%5;`~%sjgJw6D(>r9_cH}Ro z$E$_V?=~jOGoZhf%zxa9{`p*`&c5S-T))T~^z(Fw!^%+qfd5G;^mmT?=Z(;K@L_nnQTlE=?oU z(`>CBLw@ENI4Kbg@!?iU_V~R6$Di9drVw7*UI!n{LqEFvx=I`{)nmgs9ZF@Ao9dm_qLH1GLgdh6=Vb&;P&+}^bY z!xs)$>tnrC<-(|St^Ham)H-6=-Io{4AbjQ7kJNd%&B4pgqn<2(TPmhAaiseurq5_7 zDP{xct@=p})7v|ecMtVeUMN3~dRf|1RJ(ob`>}Z!$ifCj?8slHmeECEJ6#Aq|6UUC z?9Q}1_W+;hsveF5JUTrri{~ABg;E%hFa7Xe@pB#EgfD;LeL!`QKAS#hFTRx2uND~Y zXOWNVnnT+fZ{d42*S`4))2WVG_U$$FH~B4_M3HAn2_L$PeD{=zC5sMVlfRy72;l02 zA)Wl7w^dF{#}4H1wXeMd0Vn7W=V3W^Yrxg1fMd(PT*!p})?`=0hkRbQR6!yWo^$1i zDs+PJ;{UhH=REKiBc34MLU!m+t`BA=Ab$H%u~Kf(KX`KwzZ>X@?v8!x3gdHs!s^mD ze9)gRX7w#Vx+nhDX61vPV)}zqD?zU|ELB2<9uqC z>4-Dfjg+gKC*ZpQY5xMHml9CVH3dbFq`OGsIzG*taGq{cpxTct7vRq>A9i`cIjDn$ zd%0HMfpv5B27y;`UF6ud_#5LppgnEsO3d~`edwPD4Ro{0&4zNB)PiOSGt(^#HC$5;70RDFDazHbzBXNs|?Ar?8Q7}yMNN2#l zjeFwX+%Eo7B4=^UwSR3U(NJTytN8JfD5_s<8F)^nS(8n!mrn#)Yh)AmV_sF}iNz$KsI$K2auv~D zJz(Syr3NydqpteJh`BsUXX~N*r!r&L%zvXZ5}1 z@`z>jWL;LvOY-LLrfHr7uL%5w^rX;+a&pM*WL5sL95PbM%PxQOB`H(Cr=q&IfaGsb zQd!meimXlFr+8wljBJ(OzFE|ynw(zC5p`?2f&9MIYBG!6Y<6y^rUqg!M$VwW5+P0pK6>2bS--P(h}Rrytdu z){yWqlQ)O`T1mwCj;9GQ?~uN<%-kXh{J!J69<~eR z{6FXyL(XSUzK8(7amKncdP_N3nHA&X4f~G$Rg25s(XtF*y)riT5Y`bstTveh`FJt& zr6?Fzk2zeoNGJKJ~E5*rpcQLH@E13ecg7UiR8fi)p^@g zr3Z|2so3kHE8slC$Xxvs82={y8=nP&UeCtp#TC#_1`h6wb`Y+z>6fT2q?7JPQ)v(W zvewW_0sXb2{f>c4z!&niMjpfUY)dZ&-VgOtXz=11Ldq_RHnss zcfoz*kvk!uHEq}O(BCYGHT#JJ%CH?`M?cNYw72;c;8w98e8@|*7xVVw`4^q?J+ILZ zM2;J91pw+rwXVZ^(B5*D^{Rn3tv9TWYCWF^3ATKcfl>P_xoSW%f9RXdAi0weVEQ1I))azX5_z2U>^Xl1( zGRO54cPl{6r-yY>k5T9)8-{cBtujSfC0>0mq6gQGoyLGdoAN1tN#p5q2>s=ophvCP zZr4wIO}h;E_y((I2E6Zff2XzRSLIJQ=<)&jTn^cZ@9nSozX}gP7fzmM?w}X;y3rK* zgk!D3A1=W32;Na^!2ZW?_?!ScZdr|sf}VehX)Ct7v|`*Xe2*T7lic(HcOB^$I0r~; z*}~2Q{nlw`#R1GGJ+x^N-vg_clP9)EKTC~gB%p5?P2m*i)t=*X$8}xlxmB^*5Pqfd z7cUL;*P-2o*2lnKCN19LP=ay&P(XR>deGbQCM{|T^iu9G%Xk9sn|?>5%N@`gYb?q- z2IJ>+p`zJ5^k2P+pbriZpWJUCB@Gy@*m`~%^p33i=6D0fPn5}~BWEBz_b$N&FcsV?&BInTvT@Xt+cN;T7?mwDL?BSseRR6{Zh% zV?~ag46NTsCoNBxhjo{swJL|B??L}Bs=gI|u8Zsr2$elP2IsB|OKbDKHIhp@ch`hf z=L28Te}B?5p9pHa%Aaq~CjM9ZB<|F95ZWX|uC@A&B=U$Ny^pu8}zs2?AP8? z#w}zbvy$5z-J~;);$bi2*^k+UP1;*FrUUB0q;4g2r%e5zFf}j6-Hb3JO*asJLeR`Nz7jNu2 z9|+^xl}UJ~9_X#KTK>cZ(i15^xb^Hw@Pmi$ss=!M3V%(Llp#G28SaJ=SO?&w`H|FJ z416ZEti1wwc66vhuod`y^Iu6CLokkmvJxEmKrhR0@^4oz_?H;D8GlpocLx|w=Yii> zJ2|K+5B1&4t-9TiK)E=?w}ybfd_>cK6a8hZt6Kjwl#5g0_Wqd7z%OWfs?lG%HEbF1 z1U>$1mKVi$1CJk;=EiS=q-~6j9(8EhK2-?n&bkSCir=@VzwtgVrrVBi;W5l}^*$Ehysoh5(<1r-x68$w(cYHEEu5(a zJ?A&P6d%Z!6HP`vgUR_bxUPOsQS1iVdEuae+eM(~IKWJOpJrTh@)Y_t(UitVn4XMU za~Ap)Wv4;+V$d6>?>EDJuUnc8H*g+%BY&g_^|q<17@}Y7+WeaX{bl!-9Lj%wRXhY2 z_`v?xMVB;8x9)R39Ev`=p-xSx!_|s>`HX{l%^HcjQ%6{vUQ4XHZn?QVIa*En-seRu; zeHXeuCX*Axzc+VM=bKq;BJ@>2{uHD21=k;b?2RgVI+q24S3q@f#sa}9HpuSn0D^#UQG8# z`K$`^goIN~nycV_#av-gMIMs1kEReYXKS(z=Ih{6$sz{WB73kC`DyK%7eVO1zb!fk zD*(ow3cskIjeKY7z+ z>gZ2tn5PQgES-k>+|0{W83B}1^O5m|{_pPId)pM|=V8`XJ92nn91Px%(uZ;uDty|k z2I-xUWj%uXF$uAcD<1%w^KU)%P89YXVwu$sLOBNR1@Hv|Za+Qy<_zdNJ(Dhuf&80K zvD|kDe!%554>!buKV_^ zzMs%@xMKtJ^3FU91-D4xA>N9e+%8>k4$brKeVCsdU3_ES=>q(Ud1&VJ82HtF-C_qI z-S(4#lg~DG5xvuqZ{|6neapA|OM)GF?0)}|3d{?(T&kB;$%OBa8X`=t?FRdFnC`?o zus6vKDd#kSuS~BJJ|AiX_H%HJR07ze$Jg3z7=N~rSJ}!mPGAp`{}nv^4efPym&~PJ zc&_)<=D1Jhkni7tLRM9d7UwY>I`nCAEPbiX30vMdqpr%TC5&xR9D<7K2Gj9KraMmb3w|Du2VS~2Nc zQCG3QqLgGf>-95pmlJhKk9B!7<)mmOU7J`+1@X>|FWi5$lFV6f952{YNrDy>2WUhq zN%N#HI6!>up$|EMPiEm`9F@@vSl z62&`PxU0#-n|H2W_*F?Zav$8Iw7-H}4J!|Kj4g+I;QA+df7g-u8)w2+In#9kSbm68mB~^q)Z_8}Kr%Fuw7* zc^F zi*l?`x;j=ZTceN5%X{i-2B`V2wHi@~(u^Pg|AEEOB_{)xI@qPaLVBYmF z^dudOcNP{~o)7U=KFvPVP>mEQgSVE zdL583G1f$M7Te~8@56a6k@0WGqk!)RbNrFF0Q)FGAEOZ8M8;~E&vIzCk-)gpqvpW( zBRSP=eZk(GlchPn9mYHD@H6Ja!mT8u{6g_Z)pp`)C@i3V4elH1+VlG(*gxej^E(1z zy;JVOS%$Ycz=ynYy~|;Jud`$?_jh=n>3L#<0oVn@bk!?7V0VgKS{3j-jcwL!(M1SX z<@|Or9M(&84yBfSfOV1peU0b?fDV?4F3)VhA0KPm772VQS&2)g1J+l|n^rH|xCQ*3 z)6`A$w>)8YSae~Z#C_wM)-FhA(D;SPCa`NI8}vS(hw>#=agP3leU+g1sg9HIeT9C8 zvC>^w&s5Yhn=aM_-uKg}>IC?U6-Pe`N&=?H?Uz~({N>ngS~q$~KY@OfO$7YI(Ui+a z??8IC17G06CRl$@dQ<-t$|0V${jwIsD{Bo*bpn3dpU-j*^l~#2=huVY7jt@_Kaj50 zw{X+1z`x984OJgOc&wvB#tp!(Rp}gf|54DIhQlXepQQGsc#$v2+t{u@{R;6HeD9U? zfNX51ZN(1q+90P27D%rvMC14<$kra;ZutUwJ+!97?;2@d+}L0N@?_=>Hsmkwg*l&< zLU>CXrxNmu1NSB1fClj9QxS(n09#-Zf_`)6#Y|KkU{>94YQ2Q~>~%z5ApOYk3i@IH z*=r)+5Z^_=OApsO@+Ll9LqG1m>y`of-?FZ?iRhQN7=3`NqhZ~twrLIW32DU@;uwS6Tagdtq zPwnf3_>S74Ojplefjq5u^F``BwhuEs3zmbgg*g=Qo2_jJ@~zOl+eVS6)fY)qJX7l{ z<9AFqK=4)|>N)>z7eh3UI(BmdV36OgPk8=AYfe`#4P-J|)Sm?MQ0lc_>?aKIN3P!j z{_=92&9=W-AB%nB(h%;LT$kbjcx!{&?_wAydqQ}RWCKcVIdlj4BIC6LA6&mv;^_sV z3jFkh!f^~g*8brHp5Ldp#7#Im)R0(^bC7|%O#XW2=?m{j#rD6Zu z8_?*FdJO8kLRh~;)w^eLpGf%8`>UCNA=`|<>;_)*e)w%;1MtBe-h9qVU^mk2dQY4N zyA#ZjDwGh}PR1LH@9{#oto?;U3cwHhnb)*u0N>I(DajFF0sY*BWy%=r^U9dQtQZ*I zmyh2HEroJub7eil_v!tHi%tgYmSOh$`&uTjFK1C~S`7K~Zs;90gLvLdt6>Y!XZSFf=mWEVlYoV;ByAoKPz7DGRN_G;OwSfSl^6iVjU7tj$m1XP*rG`sms{{i!*H` zSTy0IEzI+NP6dzMErRx93fXCsUPJQVuj^u3C?d-OwSL6=gWXDa?;`C7`#S;C`a4D8 z9If65jt#c0gny4*HqS@_nXGsc^y>!nEA?%Hn}OHudAQ@*03XlMkjC0}n zqcer&X<;zm%`lCzqx}PV_w(OxJ>5>2pS-I1)Kft|y3D;Z&Z{KJY&8ZW2G#I=+!V{J zfLhW$@-IF9MgzG!HmRf7P)>}j`*YQ#D@or8>uWB+XXqEZLsrw(5l5YEbPtB>$)36X zrflGU8+7#>vc~I3qxo~1$BwVbe8KhJPM=27X~wOnLR(K>81H^rFxo+4JsG_ILHXsC zDjsn~H;|jb0-v`#)RF!35;J|REo4^T@Dk4N4S&+lr0aJO$u^gwQn;r;KI!$nkJGi} z#k=g8+Xq_6)1lnA4$B(I&Z73ua`6p>96p$NOrwRUhpsx+8wdRJu3CZU<#sqf(<(Vr zTu*lNosK?7+eBs$s%(8?*-F~K`^ZavXoLTYx>*~-_kljvdzA{lH;~QeE1H-H++*;Z zUt{EcE2$UJ@_U-xP6BV$_B^QryOSuR&NSFWcKjIq-g>Z^$i*#M?(AtLUN56hE{A=K z9+z^>f4e%!lkqE8`o1)htxA83rv{pchD%Rk$KE!=V7IV;5cVGwOk9FuPj(PLGj?`G z*KRUky!%XpTNf$$7Qe2_rGr==zj1tfAk0Go1Ec;x`(Dg_^fV&Bo6M)BBoCK#k?U@m zVWQm~L|~pR>hM%M;U5^e#;O44IL@uOdii@dIq)O=WX<0$I4}9rOK?Lc8Q*-5*B|CB zXxrC>Y$Ga?4TVN8TS!dUz|VtO4P@}kweMwt^`urkE$@~- ze2*#9_U2b?8%gN8`X|}5g><=^zKBb1A|K5C&UgAY6Z(rO4c6P*$?*zH-t``Bq~SqL z{$h6v*`2fdNYb+wa#ll4{nC|IVm6R+Z2h4+!mznB*aG-;oqzW4)RJnFmf2CcqN|Y{ z`kod1a!)JCOxt%(tEi3$W-0${a;YJkJR{x@>DLisr#XopNH@ufBhfmgjhy*oDRUyH zo;WSEUMMK5CsjG@dU0@%U{^(BOs;i1nRf8La~XI>{U;y(TmH>tQ0KDV`PHrP9i45I zo=!X5A7CFq3+rnwnszGT2Z5g%C=WXvhx0jiTGGa@w~>$)m-Zxb!F*Y)P+;dF;FDEX zHFpEw5@Buj6BKJDf<#`^VRJi4>uDY!z+ZJXdRp~@T`PWNlz$5BN^6)^$vQ%e080Xy9kuqp!4JN zrZun+_S|@_3D|GR)3i^$&w&5hPjhn<8(;^&LXZU<%9q8TNsZWdclF{?Mw;RMi4Dl5@1pXjs<6pV}c;2RhZQUV=*LdhXm2e%%ifKI9iAV#zP?{IsVeqih4{ zZ43U`iG1>~wc1PMrTt8a99B~q&wgi+J~OVf7EAAmScVa zdknu|{7TacCoz1G_1H>DKnvB`JDARoApHPL$Fsa70C~tr+&=1FfG^F)FV} z;}8B-e1d#QoW|ZC^;T{keT#DLDuZ*#_qHX)YGFPf9`{rCG!z@ZJBabTeZjeiiIdAH z{;0{WM)Ap`Z~s!V!3($s1LEc5Iu9dW+1pFW7n_GDd>%SW@l+uxQA+=-ff>bTy}iw- z@Sm5K?lm(Phvh$b-cd-3;uF$4XgMI^rF4J&r0qBdjnp1kM7H|w5 zWSiqap8>V-ch-QVsl$|>vp^@slh2&9O2TkinX(CNhy5Ng9w>{&HpL+RWRh{je(*g8 zFI0nd!#Yc9eKPzHTqh55!v&2;h+Tgo60uzcB-T*tm`)nuR6e6F%hV{nxhZNr^PA<+ zJmwRd1HXj=EIl|(l_QYjF;%|Pr&OQ;fQP(k<3(h;@|+3}_kBjyD@f6fYB%#dNoWB0 zzD$2~oiQ@hSJ}I1ga+(;?j;KDUh~(h7g!JSW6r z^fKzRc%IEf{(EZMes4VIX7jY*H>Nv%jr|&;yZ2soEO&Au=OV6qo^GlYeSu#HIr&(D1`vse)VdPe+P zZA(DbG_85-4|1Hu6OWZ($0eB87hpY8G&ZK;Jo2?ej+=o=RA)0c{x*loae;PJT5^!ejn9! z$m72_)f{Do^3!wdG*T9ac}#Hj#q+?!@0~Wj9}2wsYrj&=5%{i0SG!~-vnJf@G%<1D zD%j&+yRSZ)*Z}XvO7JEV)brt#Ypop2@4w{x=heYJrDFuI^(jcV`0E$-R=~A6p9}E( z#QiUaERs1q>1`6(6tH?W29 zesmx`&)reug#DIdi9YoDurB>llv_3y{6@QP65lO2-`c!PITFeP zG{zt z=o6f$$&l0feZQfdglgEs7m0xs`Y3^MSAD(rS_6un`rGL6f0jH7~Zvu>a&4BrIsMm&x zpZgg4;2i$M8Jf-MT_k3M+WWEbF49qTq~(QoJ1MCDAj}K>Z%dd&$$Rw<(#t9sv5l*f z{JXR2)xfS!GT3N*^O00LkuS0wXLe{OZcjQb-toiud3|H#Qy#3-jPJ=!pMdwC8d_op z_at8~zc7CrzNZ{akN2s9^8aq$TE`9VC7`FLO7bwQQzTeSIE{9bHLu1wt@rnkgAFT{ zvtoLP_H({RjNCm$5+)>9!@5aTuI!QF-(AF!@SGMg>n3ALksi|C-Q>t@Yd+Z4#~xEhD|5p-3G-}OZel?v`8m1Bwf15ssZa}vPG8qazTa>!Qy7Qy zJxYPUnI$`j8|}X|%`F|ofO~Fl6r306YCk;w5&D&$myum|>qYHjX3i0CGp)*NKjhjW8A6OZyW`#Ol{+sLmK(65}&{~ow+ z4)<}NlH72ryo(IV=cP*0caeYH(VyB(|#JrrN}O%Lq1 z)%d)jFz^okfO2}U2jVNWU$a8|y1m{b`@mj4S?8Ye7v{ww`bYiVL3s-F22;D?o;&-I z-{rI%z?Xj>ka^<P5&eHD>q5c;MGh4s~x61-pLpwYJAIu%F8XvrHPnzMr@^ zF&7W(xbog+Ssx*u-DT^lJHX>t23&WX1-shlSy8S5d|m9YChwQkus-9W{OAI_mmfdp zy7z!y@Zdq0)sUWa-L}Yds8>J%Q(Y9Sv-q~H)-{4~cWqgfMaaM4Ii3EhO|TBi*Icv` z?4g8wvbsKwUrRY5cX&>GndJpb&=*lx(a{6F&4L#-EG$-KD{K zy>9$oyn8tF*+U3-N{}+c^V`CfipNLbIUno#-rLX~BPzVneV|{uc&>8};`f-j4j^w$ zRO4aF1-^I*0N_BhuBa2DPAjb#ZLoe(HFZL5trSWqIhJOoSHPs%3gb^^=wJw zDvF1nT?zCV!gpSQ<#fQtUv?D6{HdaNcXi(|mG4+MBn$Bq@z6|wesDVlVr#+DeB)gq zT+0h`3)@mWPYDzU*P$1ZM zS>;7NcS7nIg?V4HsP<4lTu99`a=(R8;d|D@Gz0WgCt(@}_-fXN!p^@dV8R6FXqO?(KoBI;gM8$afks@R+JEuJ6mNWWKKh_*;}c9qrW5=c}1$UUryy$8101(9yIx!1JZBI6>>->-l^c)E;XH$FV91mX@Rj)JZyc{Q?`>1D9EFUV zseHFx-r9rnsH3N=6VT3xOC||nd}R5}HY`U|`Otlo>*_u15M}N?*@*KKr}I2iJx-Xu z>c;Shd(YpazUBs711!fss|0G_<$h(aavzlQ^cjhZj$pUMEFYfsfcUxWT3bHw59aOH zwg!N|XxkN) zPU%StSOMPgzp8@k9@*(mE7Sq+h`jlT?e^{p$1v(K&kAkCb(cK_O&Vy=om)j1u$<=w zB!6LhW^P?heHXNly}pE+ztYOGV7*F~@pCMP{8v0X$I{3O`!v5VKh*%g#H*BB_YcmS z+-6wpDg(Z}>$YgaH{jF1=w8Wmf`8q;X5IQ`*q^L_C0DWy%AI=sRXct+Hk`iJ#A`X& z*@B6O5uo=&;`bjuNMC1ub`Jempu=C`b&!7aEgf+KNdH%l{v7Uy@??LJL%(s1b&K2< z&=+{;cQFIzQM*5{P|gDX9y3_h5)a`i9u7OsK>fE1NlBoe?h5nb(#GWPAosRvKV-!9%ebRnerzxgw)GrL0={x5&o|^HtVjOQVjmxd z`Cq@tI{#JB?wtKsL+pV6`G@Xh#PRhhZ9!}d+V9b^{rzlE&JiVAZVz~_iN?!C2i=^gMs6la{X&I2!DO5Svc7WhZ&D=XgBQ2skkfzzfC9+hS= zwdV+o7j-NBy&=$FjVJbx!hESJk#9QmJk0ao`URTqh57Xp$Eo;rxGsD;_XqTkA*+44 zH(>qq1&^se@~qW8vaS|TKG9N76HUO)*Rng8L;EFFz4LQ~_oR5MuT>EGBd1n(%W8AU!l8a z&K-exNB?_kH=!N4sLF_ZRbf2XiokrhvowK8J9fH{dACNpWcJQ>AN_900qc z!&z|r`)A01<%9IzTW617f%hPozWXMwtF}Lz5!eXNOKe%5ZORYhhW7>YG2r(mafMZD zVBT`#@W8ieXcq@2|7d04%L1m47o35Q56%9)&S3=meV-Jg2n-!Gj{1KzXRn^+!E6`1MlTPp==%#l)phPwnZAA%lk4yCk5|Er|tJYAt?Ve z+x7dp5bk*~VCN9%WqeCz#(m`cYj1=iE{bZrt3!XDo>e*BY zSbRt2Y@Z1B%X^Du!1I6m*0Q=n{c4Z+o8mlxQCxm58uXs3?Ru*X{a9xc3;zyC*N^$) z0eOhGTFaWL1o?fsPs^zSsB=@!8Q0M-FBANv1nJCd?C*$#@YxfU+4w&1DMi}*0yerG z+qWOW!=g{NPeb}cLbv!u2c{O;>wc1EK7Vn`u`phTwDTKSd z(@o*V;$jCntM{eht<~$HL4A{oqC7L;cTkuYPU^KCk^S zawW#w)p6ZM{B`Y#5%O{4znlCKk97IM0yC^n1nNp+e8uC!4#b&N{dpK)@@df$<>|uc z52$CY;Ov2Nj!6f_yEd~Y>tlFk-HD%w%O{n95W_zCLsuEZp)L=KpR*0A?L+x$tk@pJ zx&S?jhaEW#pW%Xhz34l|+nv*dQc!-#y_VwbFLSb~bbRI1f#|}1$+jh)xVp}|9pz67 zp;S36zrUdPz3p`477Q2KUQMO%vonPg<=9_ds}YG$BE?5*CE&ATkeR2KQz-R?2N*W2 zoB9k={8>{7nhoS^I1P{|g_?!GD7}ZkR#9K*$`Z~gKrqNOZ9qo>$Nz1m&=6W56#JKy45wp>+^ha5?~}Zn!k> z7>3@3awASR0Db;@?mOR-yy&%rJKI^o zm(Ig$gK*BUcfMyKnkhfQ-aLU zx1|3Mc26)q@aj_f?fcj$S$=q_KEW{iq~d|~BD!`gwev%Hn9hK#*Xlvd13JX!-~nit zTOHJU%nttv6BbxE;qDJbWKqS59_$+!oTT(tOu_U7mF21J=Za9PKC3m zz~hk4*R_#Uc=;OvO4cmOy^rCU*XXGIyR4Z_JJ4>#D!Nkl^jsF4@mO2RDL$%{(4#Jex~!>`$SOYus=)9b9V8vQuZP+I}0iZ{Kr1k9MgAy+eVF3 zKO;73{N=a~Q~OKNGvm-fAfE@@gV0WN)qbSr9|6Q9k!v909>yj z(C-R}dBj+QAK`w^s}m04sVVZ4J>aj8HXb++uYu<$e_htm$8+{VS0qGCA)J=$ zUJ12M^_FcLz9;qsj$H=;-{*F!qF*#?zZit&)lEuJL-{+KNifc{8={z`u>GHl(8R<5 zayjj9t^)p}W!La~9{B8~o$UwwfOlr9E>7ZiJq;747HUwBPi#`(T%eqTN_Sa=p&Zw@ z=BJ*6@Ie`es!#~GRZ`PZhUetPbt7^Ao_Qm;3LWyGxj750_n~sPhgX3QJUzH6Gy&qX zc5oMs0ZL4=isl2V_bsY;fnL&b@!=^z8xh~Fcu&HE^QY_EKt6cA`=SA$%$)C9RhK zZ&J&M6Ow{*H*;LB!*;gO8(1|1@pCq{f<1tAV5E$6h2N9}&}AC~pS+_Vn*YS%Akr=7(}a_(Xr&73_z_S50;CeJ^{FIgGsO zb!D|0@|{X$rGKcm5Wnjv@*B&em&bDUOaF<2k@c*d#e=Wzs>5YurlC|;DxDUkWSuVXLmzD7T$GCSl+V6 z#y_~8k)D-3hrFkwZ}{34K!Np2T-c9dBrKAB053leGI9lcJw0>=``v=FlOQ7?hhM$y zUr4{>;~xdYT)G@tRtV<{Pw?RaG?ZB7Z3*~$bfYWsz?WgWIT+!+(ANrA;kt5SZfZkzw4@51+#A|IV~9I&RIF3S#Zv0lj&?OtS!(hdO( z-*w90A245b#eQ?ZhYykiI05Np$HTGTeiIZ`NB*kxqe`O)%F9ZhQ_ll(u~l?f4d7(+ z>JH?~d*4Je;Cp4%Fo?bhcx;2^!301r##J(kfUi3nY_Pvn%DF#5d(u-iGO!D<<~n?l z2gnlhCRQ3y>Du=+jQ4)=o%#=%!s$#07LZ>)FoGYgfqfW{k3l;d@40mU-sTk%@6jI3 zK6~C}1Zb{ddP^7Z+uLc%Pnm1KS%!9O#|rIyv~zchwfkrQ<8~k2gX4DXlmi3iC;6E6 z0NTT;FJEa<@1bk|h#ulU^}iT@^?HgT=F?0bQ2ud6-_;4!TYbXnEZTSTF@+Y4=hj*U zju_@Ob=~QR#V2&@vHo}3er90&kkpNz7=DwH0~StU9e?jc3&x8qs|Ux2`vMiz`Ir&c zzF#Qw*?)e8@x5H^l>d|bl6e5bIm}Kgqd!|qiopaxKRv)q`O)DqIK~6Aa{ludi2IgH z7-PIA$31bB|627@>*-1w*IZD3D{M*enRoPSuV6l+?j@`kF65a)@ta+?hbcayByPU} z!@r%W@j_fYchwS6N28pI7q5Lt@t!!R<&+=SjpTO5_(8Uf)H3F+oZTfzrKcIwN!3%S;uytq z*4Z*s{L4Smj7s-Zi5(Tsco5X#xd|6&M!>6HBb2PU?$%N{#9*2Q;e{hj6s9&mq~hHZ zVEO{#3cHs6<1SO(Po?kvq@Idrm0#lP`R|ugvUvI&5KNfwN%m6tzm*iC+Jix_ol1v{ zFX^dBBv9#W7mJ~u>o8s7cR~^TluD15@y|qgPWl_0ROE4 z04zt^3>XciK-{uy3Ehy!gM1HK7tsM~ix>lJ6!9bU2E>})rFMj1=>PX2HIBqed_d1Iu_@Z8p`SaINC8wiCvwU*+2pci8J8W=r@0We!eoR7kc z;Xa4|+AS4d6UcolmoO%32}R_W(!Ge&7l=3fuib?IlULwtfN<%MC49RZru`tZ3>i`3 zu54Hk*q=7X3c>o&nx*;jhs>q=`jz1efPVXUso!{Shv5XWhudGMF!&YLrT2VaaH$+F z@RvsnFIc}+&q>eAl-#m$slViH2NB{!FD&VE$}Y{L9=P*T;k9&2`KtamPkrIFq?fd3 zsa^UOV7d;^@A%^Wg!oA1B^WA4rD*5{OA-m#OqijcNK&zL=Ist?%e}ETh7mmjQi% z@J)%EDElY!Y?88bJpZ0k^9Q};Nvd8JuVCH)dLgB2Df_6|+f3P=HJ7$O!}2&Kt*7cE z`H+{=7j77&%AXiJ2|W_#cd>@lb1`p^i=)4b8@4@#yiJ3dtqOTio2^H#4B-66Yer81 zSHEDHMBcQ=xNiWT_n6V^!usyBzM_Qn>@VB<5B>U=BaX=!ZsmQJn*TU;?GHlzP?`Dd zxNg+J=L<77w7Sxpk-u{qTRazEq$B`f13UBLR2ORj4AhyqA0rs_P0JUsQ_Tqcx{4RWUJ>bV@I;B{? zV^xuNu)YVS66dr5&+90|4|idGJw_%M*s$n5nlm^tohZJL3qh(Ie+AH48J>J z$qDRV(7Ye^BR$U$X)!>~!^c-)d0#rLaKL_deR*F9mh+e#hcA{doS9At>-k=bw*z_j zq2{lR7;mY(@+_89yfU1+=TQ2=DGD#FNz23V&HYlp5f2S3gTa7(ih>{`%>SxlgaL+k zs7lJC>@x0UhVef}+20^9eR^x$LJ)9dhfyxJlhWXf;u*l@@2yf1*DD^pi|>77o9i`f zhoiS-6%7D;`aTUIZ?@n)4F{5;eRIlpVY}6Z?zoG1kNfK1??(NChl1^rNy( zsTh9wr0<4Uz{qav3zmTF@Xa~C2Ll6M3u!=mx_27e0VizF%cueF=>Om-3HUBNtO)yA zShU=AY;V3pwz|lJr$t`e!13YpFWnT=*W2(D7Eobcbo}i)EKkYML=x8bT50wZd_UJL zc6niWWX)V)!4KZsT3yOcDL>}gj_sA7Tfs*4H@BMt`22jX4#i`Q`?-KXL3tyGzG6OU zCM`WyfYnToVzGU*z1YA}0I!z*_zlxlbG5yQ`RGnY!jDWqmaTK9%A;jCit#5_KiY)p z-C#VJh3U;%gzMn*q5b{KQEzsQR}Y4(giTO>gIm^g8pBUMHe$zg&q@cY;qzYVDhn7c zx|0SxJNPYMT?@pN%X91)KgM{4@^gozcxO>hM&6FHTWUU6z`=sum$g#B_R?lrU_||8 z3NjI>7yByy48{xey+4jP{w6vU(JY+(3&ztLz%`zL)na-;1YlgX+@kyg=b7fu7(d&b zO!=pg>}`~N-JD!@y;$I(amUx>P?^1bBSiPsx%i&()M_f;!*+G9)bcwHQMLGg<%zyFCD)8DszFz|X z$N;yOA)bNV9mFv&=w^U-nxQ)a(nK$%!+dQi9j4zv3m{yO+mb?~(WU1C!OCN}_dBRI zAY<^7{%!+!T^J6h{So6~6e2c`EX5bGEy=f>meM)-A7AGAFTQo#QhW)_R`Iz<@=JP? zCzoVS`X!9V;zIl|PHzAcP48W@epp2$n!9bn#_Gx2<5tgaZ*3qZl~t_K7n{i9<_(Dn z<4xq~Tn+2L)eU5QRZsja_%71tUI)LeXEV{@(xR6tX(c9S4sM*<3il@n$CY?z){~b* zdpoTjwi3UGLt0e=z;{De9hdM0e^$Dk#)i{DsWe2kv8f)=#c#IId25-UH{*s<`8Pdf=Wt;|JF-zbCWw{OoONp9#&? zAIRZ9GS9_cbd&mRZplN9y@Z?5*Wv)2f3CB132T+7wQ zb%y&2Q}4pPp%R0R2`M$ijL|0S%q09j&r*oXz(`w{8*B&c94g|L}9FF286!tQQ- zv$?2**njmEyMMWrcn905cOA_sjeLD0Q~q31>6|=2!%L zG$}3fYyIcC(i@fo?Q37>65iC$d$hh56YI5mYopzdzWDu`y;DNutqby^nuo(_S&JB1B!;8l#<#A-EEtR4lXkxkOQYV+aBM{&W76OcV>Uv7Q<*hizK0{BFJw=tNB(bpTu7* zH58kC3-3qs$vEt0!7A(jelPnLK&MmL?}TRypxFSwgH%`%WZ-km81gBFWT)$eG!4t3 z*6B;kwC(xOtj}HP*X;smjf8|!9u&ZQ12YG*$AxhGFSU$hQZdv_w>a^ib`H!Id68DE zngcgQYr17m=fDZ;OV{QVb6^+G?({X1hu})z0i4Cp6P z6((+y4uyNI|D?Z9gSjI^@lK^#u%52EX5di<{G0POZ;0#-Y}vdSZW0v_IV>FQ|1*e$ zYvp-21xe5cm3B+dFu^idKm6)Xc3&BcX;ttr>#Bfq&(n8GFIPeKj_F5HzQyo~$N8$- zYsIij>-yUVPfB1rpgKN@mqE{B{Aagm1w7-LBEEDo2Tq2alU=pSfjS&-N8;*oAl*3Y zf(%tYgpj)p>3v>$j%CZ#Bm0i4?U{A;m61D|9-#=sVew>etSkI zs2U!U6jC+ts)x^z`IxZH6LNzHx*1E8zBz?JeKwO47cnz9$qbwGj9D zbmS+AC-}BIRm_H_8FHQwpMBs!@;bfYvgGp5D zDvL7hFlsC}$*{2l=KoQz?4)fb%}2I!mf6jawa!|a_ChO(Cv2a^=ll-lk+&Sx`q2(U z6h$7io@s=S6Q>no3UE@t!CI*66Ulq3RH95D&j_H&nk}HE71z3#DDY#HLcsAdJzLMx=iU!3)L^8q%O3kik`^ul#!ix6s3U$eGV zJ*$ul*ozC@nABjU!>!V;c08b^HFkK_@x({z$<25Al0w(?49&{e*gC=2;(H7f% zP;c1N>)-+@|Km`x9R6nrN^;8EM6ry(APzOw0n#|;mF#W&Ii&h$6)l-855m^np0Zw& zpY1cH=7x>$DEwXMvOc^?%KP*Fe%3uEx|=e|?_WG0}3xy{$@2g7h-(J|v=^)QT& z?0>$uHVn@N3V*g~9fpe@j00OwhT&4ez6J;52()0SVg37X1U_nrOdV(&frnokZ2qku zfj=iUyX9g>VBU;fQHl2`y#J*ni|y|y?Em~xVm@^YCRQ+89GV=1O-%Oo_r}JcTTq;t z73nzh$~;M~k8x;k#bnU3IRV}OzWnr}a1t&ZOs>T@C*gSRIc6i-33z+WRLlDKB;3i( zqww*WBIQ72BR2}CNxX=#{lh#nB(H-0$GXsAxZkUKGL>!w%KMl6RUjRY2_OL)j7Oky zkk{#V3&U{vP@=wP%m{QD;#lZ8Ito{u^d6siH3|jTqi=sRABED_(&~Tw8iA$Xe~?QI zjzQfx?d<#a$D!V<-_o1g<52tYsE$(eI5g^>?t6Z3oWxJcy!(B75`GaSpM4oP1>G!N z%w3L6L$@#FsDFD3&gKc_59CZijTK7|dEObwpIKOuYB2+=&oq4t&YXcFk&|wPuV$dX zd|97+@C>|jWM?4c$1voePQGSdISfm3984VRNnE=RJZhPT2jM_@vy>nyH%E5;{npMu zQaw5qxgFm=0=LdiP0ln8L%peEOiFAdPQ;_x^HZ{ea9T((`L^XaoI9(PKznwaU-%W<^|I8ah4LEvQMP^nC6TsLsTF99PjtxxWXU|OS>G?gbl*Gy*{1C z-wr@|&B8*Xcv64-BD?bc^Q>XvFTYSAT))> z-jNSTT=|oYXX;AFpnn-rM=LZ2Q`TN|Y!f4JE$rkOyJ-^l&zPvbJ2wa^Kcyt_(NDrW zB0e2}30S17^oqfP^tr=2^OU6jTVU{2#s5wZLwze|6@`F4i2dMvSC`Za55#Bcy~I94 z;Ud?4-P$hrHZzJRn!JnTVd)mMCd~^n!6zGXNj{WNsghFf{m)P^NZRPz?=CoWwCxNJ zX&(7Kf(>gv9DqLsZ~DC^^-t|6HvGLv^WGgs4;rVxAK^h~u}v?#Ag|)#XY&V#;m=`H-M!&K=mIWNFXMgC zZd0X`Rr@p4>xy~9U;L5euQo<~8XusJKytKO_Ir5Ru>OpJdONH$X3UNJ(gF`?rFOmZ zZ-!Dd$LoT)KET{t%J*+x?1Z@k0`0ruByL{5^wjG(())H2y*g)_VETdQonJaWz;ma1 zS+%u0VPy`DaMmcvZ|D(dD4o>|@oi6e*DnYP>r43R)^tIFW8lif=}yR|s;^+9(gvHW z>G#~Z2x!Jtv}1Ou9vZ#~5-IEY2wUcq*6(z7Lc!`hw<)3(8qdTnyJj`Q$b7pWmp;_M zV}0&h8l?K0{C*+(UDjsk?BXr!mQ6rwY08@|0*&xgS9DbbMI9XZcL5h6d7ti`@S-qk zC*bA+eSWw$f}T#a=Jhy9aP1!Zm$?wr0zsumwjzcSJcp+3O)GTu}B6*cQ z?$IhX)R6kVDUK7ql~Cl1%v*h)Vo1^Whu4WC8y-mHx#DJ*2Gbmt75-+`!pd9b@lyLW z(Ab{i=qHsbcWJNxd^5{x81bEQ+_EJZC$nv1mEcdUeLkNF=> z+$x7|S2J66V#?qHhS3U+_to$ktJTwjFBQ;CFPB+JtrY%RZ`L&+dBJxUK7aqST?j88 z>p$voHXqK&FW)j~&w?U1mhS%pui%8YeoCcwB8k^4cJ<1Zo31yIByK23ks|<4Ih(}8Wmcozbbxe&MWzf3h!nD+GDHQ*5 z)4Pba2vR>L9$sJOw>0Ij2q(K+)>_d8-88Bd0$}o|VRKJUz(P$XT zgkKBX_9S<*;Kd1Np9UftPKs!jBqk@pr%PvjWh7D{jVlZ6u1$k?R*w2A+{uLJOJij- z-SgqAm%3u~<7eaD@t^g70Lbz=aCfyyA583tU*%=HA;O!vE z=d%|Ipk0w#Ag5j-e7>?6K>e*4ir;>7D{Va&4$OEoD3iX2#(xi#fnYwA>%14BFj4@w zeSY#M-7A6$To(?67iB?4(UHq~#yODs5N~jIMIL+@#j|2Ux_%%2q8g|6T&OZAq;FJ_ z0R=5jOyW@$(K|3N;*mmJ(UcSXsjnGAg($h+& z3=T6}g*xe#LVfqH@nwZd2%26LQ;|Hkei!!QkE}Gn7AD)~Ow#clTvO7Bc~=TWVlC+3 z{i%SM8~L3Z{59~O$auILYc+J$5;W5&DuDBBu{YoUEP>$+`&izka%kEUGpSi#1!;VQ z{Z)8tVb?zYhMrsl>>Lt$bdL0#qlVU^QuveCWfi!R2*7s;5@zSX;`0lrKLi77F zWo!(6u<-(8wzy^u989fUza>@!CCbIU)@w*!ll$Ferdu7*<+twZMAH5}y0#Qqx9Rut z3p-?~*H5O%Gj7aqJ;bWz*L6c$6SJQ;k{x(b?jTNvv7aisH7b(c*u7SNb9)AtKi$pp z!&bAfarK8zi;uyK{LutSW`-fdnVMtL$}o54J+aZGA>Oi=iN2luIQxf~gz_~bo#5AoI8PT?z!4-5{R zmZ{{#N6Xe<4UEd*Zw?>)l>Leh%lYh>w0dH_vG-3sCl_dKwCerlKWQR_eY|y1_E)+J zrY3m2MBC>iHvjwSQ&aa-_)VRQGUQZ(SUykUEwz%Xct#NY?(!9F+^^>C+0Cpv$A~@uhN!UXtT1wZ!?)+J~kMFtG2heCUdOH6UM}Muf>_h&q{R8w$G1Y zSIuL%inmqpNI$khu$|;`s7mslK`u7-xJS+o0C>u=InV5~K z35*W^+78FK9?k8I#i=m3U~wD{b=Scq}>dn%jL*5JlXx$njM z-eVVy>2kK5=W(YIFPeUQ3&&r-UL_Nr$A$homvrmbXUvX*Pt3pnEvCNR-16M=Ad07) z!zW!?&{$-OaHY&NE;HZwBKg`dCM0|RTE5h0yiF!#IBanmQ}?*yD)#X#XyAMJWc}kh ze%@T|OYr16#v=VU?cu~v+^#)~!<%LYgK5rB3nb5>9*#p7eOvah<-36bC&u=1(wg#g z92*7r=W6CsPf#GL$GxG|V?sbpxyFxpPlKZ0BH6AR4B*;QvgPI%CUlzEy2HfJ0Ngd( z0~|cQV;dgkE2<;X2xxKEYgfyFe40BCeQF?D3Y!+0e4_}|!_`FSJ0Bo2Ws?=w{4*dk z#kzIUTL}5+Y`O-SN`nnU6?@{Z7W#N#z=(3%AE{(K5faH2K@-o96OSI92d{4OJV?(J zMeh1-T^_-XRfH>TCD1zbC(VbY27{{4Oc+zY2iyo_-)_y(@ZnF@I%cLJmlTA2h}LU6F?f z=k(u7JK)@NHWc1*MvK3S1`@{|zzZ|8n``Wef$BZ%rB&WG6UrW|Q zqg7^+-;*;?;N4jEylWBQLX+f;v8z9i$;$mYL#6bnO$T^o=)JfV1YJ^Wu>VWKoJjx1ws$@i%cFN7*8f^$pW+ zMhrz@D%``NI<^WmIoF6a;a_rBg-KVnrB_c)tT-YWy5rn?s8 zixdWO6la0EoI9OiM&(FhK;RuyX$tDG;3mq1dqJ3icJ|FHAHX-V`u!VXWk^fH^7XIu z44@nR@K@aXPVn)H>7fSq0o3AEqHKI;4E<{fb(C4c!Ij{fz5*lt;6x9#+MA4JbUj&i z--f>(E%FB)cXC?*_17&eNl;?&OCt9|WyCTX5Vx7L>YKWleK4xy$3WJY_A#kT0sJROmdcOG>|#Ovh&l<3`{5)Y}{k)2A-oXkrq7- z;J+8cmzFaUzzqT0ErDx}U{HY(wkvFDp5WV2+Vb22HizUF; z(r$X#nh9#C{`w_y_z?VJG}m$S_)nl`@?Aop{UdPcEx0C#cOf4Q<^P^+7$NP5qxXis zr-N5Vk-w`%8tBtCUy}J|fRZkV9pp=VibgjDwBNssMYcnH3RGM9s0()c2ImAJi~FZd z)RtpGXpa|fjdL)N*CgrU!DX z<=;=V%>b_d?#Lz96#$JD^CB6Cy7KN357pvWdot8^ZK0>U1N9D(l)#}+w22^D4Xw+ z)tQ0?KmE%utu2sNz(l#?`{$tHa3r%Vl_z5U7RhhgY=lG7(Zd(yJ8?sE$gv}2ppjB7;SJIpU$ zdtCx_R0jIZ@8^S*<4aL=?=8`ASAWaFb$wKo$Z_>Pw2o9{?V^@8_#8%Ybf8h5@@#IrJZky7n1&ZqOcgexN^u8AzS2`4sNuh}gbnPFgKr z0@ogeevvz<1Q=GU&rxw+MBBJ}NkQ)}UT>+d@RwEvh#gJTT(NgSv*+Y1?POIE_pOcX z>0wpy-uL_%tCT2Wx?ouBgDY?ohfiWBaw0>Q6Ds& z{OlKR#EV>G9g4GC*YUUHo71*$maq$93|7fs2k-~Xe`6D$=i`4jIa98wF#-L|gCl`~ zTezy1ytrQB1b)j^Ku=$I5c^%Y>P#D2h4+1w(jt%T!#|KS8~$Ua1tzSh+7G_N;<|j8 z=e&pTudjxdk6v!Y>SaWtlL(O$-XJlS}=QrQ?oFC)E)}L4{dpR%;x%G zp^xbg{3w~giF)BHXBs;3n@45dCLAxv=u3-uz6S+hIZfGQO-BoHfei)w8n5s8snys0 zTQggD@1oajm*YA3R_yEpi8r4xYh^yIM>zz3LU=YI*2^0od6>WDCw~t!neiy(@)p2) ze11@ON2}qPyzlqM+OK0;${OYFy}I}z;Yr7WAZr}`Zkg^ax`CBI?V5ug^mxsl;iH?0 z>bTsQ*l0Wb+ab;1wlG57`^Du~z5xn4zE0N`@FfnRl`eqAm%W>`a+YRBDcZ;iWwUszlH`)xW z$9tpO@_7iJN&9x~^TBA`LYrm$5Y)%W$=P#`DRE=g4JRvkf1bqUnf~2Wy?+!tq8viq z^?h94nB8?&;DILY$*XjK-i8;uBHPhzqf3F+*?XiGj?m#6uZlOWW|Lt;r^V7(#I>-K zs=u-areyKb;kc*rew*^Ua)B<+(X^OW%h9@rwX8VyW%AAo3JdJae$`cQ(Flu+{Qd23 z4~B;?w#zn~^I;B=)#cje7cj}OFISkgqVOl}m3{>o?$~%5-4*m_rIgR>eYla%|ZUw!%Z!QPXGo81DhXe)T){Cqe8tAP%5}hGO3g<~^Ko^Oqf^*CuZLyY!Rw>Q_v8=EiG(wn?1x z3Ug3K#vaZdw$)#Gf(bNUYCP4-+KpLoNQm%e{t>d0RR|As#&M98A589=dbVrI1m zBPf?&Uq1fdEM|OU`&xd~DsDey#P=^?4-1;j?Ng09irVo9pA;N9krbcU&y-DOq+=C$ zr+1eTjG7jUryCwc3~TFvM~)f9eYg|vqjd&Me{dFcetQ&Q+HbpPZt;VZmwm?z%p?)l zbT_r8|{ooV<13N(Fzo{r6%B$v7@c3t0-cod}$Iw zE)Alqyo~Nl%ObkbDe2ZTm%!A$pgBJ%0T_nf6^Z=1gpv<*a{xX`z?aF<)*z{jE~Gv1 z(e%;+`^D48EhYoen=mie&wS2+7|u*PZ{~s6Dpz{+27JJk%mckOj6Nu^?Nug-4+4j3 zrG1kow#ZB6!=xoDc!= zqkA0bC24X7z`KrR_x!m~Aky2*yttZ;=FhhmO&ql#t($JV_P%I}j<$cfCf8>Hx`OY0 z^E#4-#`|vj^owPHTg+}NZ5QK^XTKJk)ay{t;2ch0R}hN6*7@L*B{ksbY-;(OOb+-g z!oTx_%okARQ~HQii@flS8B?2I+Jz$Z` zK{nRhj6SzLuD+i*jiwG*_$D|Fqk7&mC7Ky@aIgA$Qe$mDI&t4YVqK#gIa`x|CXxLK z@m60`?gt!@Stp%m-jp6%AHU4m8X-pfF&!2Yi24u6v-0j_UH*w4Op{wx%T1tV-{M^F zUreO_*oUHLZw^5wg_fE2sby3!FiBNYzKH($BOw(XddOqE(;DwRggQPswCc4`6Q5t# z_3MnS0zt+LH9e%yr5D^&E2Ll}?j#BvJkrWaa9nU&8PgsIySAx@^2fe{o}{12s_MK% zm&lpP*OGf+Sa|xzz@8L*YDKJYMv6c?O3u4rlb7J;j<{&*i4pr0d4Nw$1Ky9SQsmva z0_nu=3e3^669H1j?`$h+;kh)qkLL_GLCkltPXnIq;G*^YtMkMFXiE=T`o7bH=rbeE zMV+N3)(zC+o0kp~o(G=y#tu*sZI$dCN;R8^Qk!{N#qa|v%6F4s93BU;c1&r4c2tn{ zNEP#&V~3&h*At?uX1gHr8~L_p=p0~pcgAnlQWSEgKCoO~Is+A8N@|w!VG=*)R{2~+ zIqF*mh zSFbiAlRl1i-ufjpmw0D*CZP>!{j{w2&>I45jc-zQvwFa{DEFbE*mp=R`+6o@Vj55% zy%$_wJ%I+q-*> zK&ZaE(ZHN;Q4~&7%#q+lT&wPae_V zL=%_@Hm$rttc9Df;2bsjQFoenGEbw@;QSML$DecYIzN7YmZ(w09kIU-M9$*t)gT5K z?fWi{n_?Ozb=6i!oZ3XHExT<@+SVXGz0*SFy}!vC+}lCvF$2r#rW1q@^=r*xq_2Lzg}FmDn|lo*Pon{`v|g{xrKhHmx2QA#L82X z8AzMliOlNpW5g$=PWdI+0I*lBdjtk-V4~-_$e6eVQ0Fo2W&tY};O&?=^ZC(F>`snG zt-vioaEIsk?EZZW+6x^mMc3`l+f>yq8FwTW> zqUVcNzdDXy1g=fmOpo**BkLxwEPhX4a7!kk#^aRw;%-6Beb~xVdrsumYX++5QnM$#O#NXHGiyDB}H6ru#HT3XRjgM!&Gf za}1gyiUeMn?{YXjvIn=F{bA%1+J`mL?b2D2{8wC3_bk0$ zFs~>k3B=f0j%?#sLAYP5{osG6(A;{qVErmR>ajLSyc@&^X6LT`iC-$m^;gdSN&nu0 zv;I{n)r-i$T&m1C1{uuo)yE4}cihu(qpaOoTgNfX$3a*0#!4lo{4V=n&TawDOM}MM zh&R~idpdnp@*r%akNRwG-6EdKDY1|voQBs-(RlUIRbqea&!!7F7va|vnRa^| zFw;XKMslWRccJ||!|}}(%d)AO8Bo{7s2*JI zyZOchr>+3@FWB|5m!raa;bxXtU}WNOb@CH@eI)i^47!bliL&q-jj>}}Zd2dy&l=R)qJMhtCg1mE- z(YWDFE{hnQNK9>j;)Bdi5bn~pRnbm%3zu-PsFb7~#!F~EsJcaez&(|`W15f2 zP2C4#@x^3j&v!>(;i8U3l((ljuoCTnbC2UOe4@~>^FXaCmZ)nkbLY4fek}CYkFY{> z9B(f%YwMK4e*F3^>P5$cNqzk0mI0-3`l{`Lzk9ba`cdt7Q8eM0mA7I1ozsfA*B_JT z52KIaj^3TCuL2}7%C7cBtMJ?S9*gsbRL6MyP)||NkM2uYl}7nUW4I9ZY-eygCs_cO zdLF2B&rt_wW;Y)`%awpp_lJ&NQ?~=4Vao)gm%YF4W@tn*%o_80v2Ec z1SzPJa93vb^pCum*n(jG-!F4D_+oTFw`gu1erxe#E2C*D-oOx>x^^uM(}?exdHXyE zk0pv$)!HjDc#lu|HRA`Y$fEq<#GPk&PGrkBqb6%CTn9;FO3}AZJxoRG5zDEBkOo_xCz@r`au-L>~ljsbOh6n z@mUOGp2P7c)$Hx%>li&#LjSNBErL@^^-?}_m`dTr)nJ!q%x?H(%eKNNtYTi!aDeo? z)+rHh@<=`atmm@i8a(*H(A(uhbp=!Sfu}BfLThn2z1~?39Ncu@2?kYB?}iPcC4y^b7Ma z(Lac5QGtR^zM~=+jv+pu9pNgmivUApDI%0M;DWr1Mb6VB;9Vf+q%=Pli1JtCbo(Wa zf&(gr!(H`2M1j@R6lML*9~^#{oO@jbg5BPS4k{NafOFgvIS6)-+On%QLrPStWBm~#$8o*TL;t&_Q+B~>&zOSKI}8XV{+-?9Wj z7fV=2Zl?gptgg0;ky?mq!J+j?)N>%)Y-h_z<%lNzf7-Id^r2K1mf?t!EbzwI1pDWg zg0h}FnvwfI0q+JsTvprdK?bx;o^<`?XiPm$PpKjUnameL#^zvu%s*+p{Xg)X;QBac(}B)C4o@zi`~Wmr`j_6M_M!Y?18|So55l@4sL=cq*s=@-1g^LiL5)WQ+a+;E!m&f8Xl>6jO>*{&uAq)CTa> zw_Ok=YOSWuN2b%k!+%R($jL0D2v@3SmQow&kj$@dPl`_v&&Ho=wE4(ECc2n4c}*EO zWE&_wb(o#N4*2#b=c;(H1V?O3Xh7lDrEJ& z7UX|H9Ma@{4!7RFK=6mJ)g8Y51NkyW=8I6Oz$qumFEwvih@t%C<3Wvjg!X0bj+npK z2+0gX#^D}G*hJ&!{(eA-&^dfe%jdK%5%%zWLCc616e}yea`=fJWWIB1;{~T7QEszV zwNZ47cy>roDJI(iR)13Ie6M*A+U8$A!m1zupGhw}H%hw@DG67%f^K_4fjl*%DEu*G zUfo@iQG7~NZhoK6cpOT6kqQW}`*wk7jonRguewAmKN=hLEyReHsGq?Oa)Jc=WQ}m; z69!_4gW=ie(;Ea~)t2Dvu1YZc2-xxr5hp_Ig+~>ZS%`ou|G?g}UDR+k>I_}8K0NRy zELOL`2>zY;%1zFp4S)Ez?a>y>z)&B7tDcqukfK?X<-=`u*gh|MLDIyO@aA#dr?NID zzC0CT^K`vRq%Ja+U2c#gHpmUqW7A4`UFqD!O6Tz2-!`@?QOL z&smRX$+91~Wq*Va3-ENyJ8_th3gSGu{EUmZeWOC=M%+KN?81ReGxvb?0d!j>?=W%k zo2sg@04o&u5SVrR^e-Uy>}Eb2>v7^(>dPt15n(v}CdBXSp(AigEUr=_ z@GKOW|JC)Z?JO*CkKxmlJ_79$>CK%xAt5mp6U<(Dg&6(fb(s5wBH=4jq46w-j2P2z ztc(650>>Mu`PEJt5bRg8e+Z>tf-@Rkt)3^f39`6wH(NaeqM}~duJt@5WQ~#s-?blr zYqtt6TXCgzE}-e&q0WaVTqUP+6ls$mz!5bb_Hp$a7B-@ z9f0&wTUh0G)A{kFQh(h3A$ z?B6>Ezoenkv)!r-*^WGf-Sk%6#c8O!kc!%8gLZ0#&XA{6B+`Q|oJ1%zaT7A{c~ zg2^+fmzD%WQ6|;R9DDu*#2b=oV*d9FGN+!KNEhivj$4eM{Jdkq?BUn$%sTNPfL%#F zw(K;zOp_4iqPqfIX|haNuXcll&!V2?VU^SIgfCvZeZHvq; zKxs1T_!aX}P_R1iZXuxvJi4KH8+S`W|89WJ{WCwX+lw+?PLWO^@uOJFVznjmICP%u zU(5~k<_Da%5;6r_&!{fTQ$0qu-g!WpN*b9^%*bo-S%BQ}T1K6-+K4TImP(iFCP)eH z=x;3w1s8Je(n?O4B7ehUCr=ICM|7BF)V!!I@M9V>P9mM(^*#oATlzG#&JfY`R5lJs z5z}RYY0fA}@6g_EZU_pNP;M3SF9plhzfAefI*}xC&DQc^Jn-Kf|1#^J0pyy{>V$U= z`rCOusOo|$@+@XoaH7@%gHcWqO$S&|Px~l!O+61<^H|E0q!0$#&ILB=g11n^m&&xB z-5V%SRq;^eVJQ&Zo$0Wp%!GmoMRS_4^XMY|O7q<>PJqAj(tmBK+TeT*qd;1XGI|~U zRXk|%A_#Y{&7+Gr4+>J{7KUWQkP>5^)+T-nbew-=utcK^w*Kr(BPU(N{G=#E$P<85 zH>AFO9xOt8p~?*+_Ro;b6Qh+B#>e36f$6)V3ifEwAjYOh$OH*nyYzXUzX-lfD-X$Q zZ)3A*F^DI97w@0yESlln#CVr(zO=j8iE{^0wmB#ZquR#-K8Z#Y;Gy!*uKf4kv7z|3 z&?7I`aXTBVOGM#6Y@GInBuA?N2nD)rvG4@C<`*mGa`Y3{-!7f`=Fu9K#okdCxA_~l zObA}a3{}BCQ&xc(CJCtH<&Vw6lPGdWTc$^t0=zK_EnVF^2x<~a{#{HpKsPOa@W{sK z0oS?NNW(kqDE;Ag-791~=*ZB!6Vr}j;Kc3mpUEXN_(xs-lazIRc%yyl6B_F(Z1KU- zRmOX-@y#UC)ObDv5A*uaXY8O+Wr?b!NH{6LNN zgLVB4jHANMJOXRM@8sABgwhyb0%lBigi|~)X}-H}uRIFCRW0OL)z@ROIg~)fEHQ|k z=zqC4_rnl7aa4^@>Aoj^!_{W8ZNM8_&nPJz80N*kDn7XySk{RjaiO)to`+(7#R`mu zHX-;~Wtvl4(@~g2nG7FOe>v`z`-J)?oWa(Nyv*p#3NZ$u?}Z|=ukotmzd~n5qOeEF zvk_L|Wf<2*Zax2)pV-W~b6$~IRhU>pB*z+44SulHAc6C6IrjAO@zFi+c1&ESicv0U z3M<>(kV#0K!p=Uv)GEm_fq(x_*V*xH7V9f?NZ77j!IckPGSGqS=+x96Exkq}zV|4w z$7-q+(}_9j#T8$K^YesfYybX=8|X1s+%V+<=XEWykjJywW|>ViMR5;q8T(2NuW7-~ zC(!A?@ZG{_LY6uX`}~Ld=y-KYl+c5)O_L&;$wNr2^)$22GiLBron1`sNX|q)A4p%k{Y;%cCuOX!>R*-ZHA!quuKT3^nXDg{MsGpt9>oeHFZQk4964#*&Tp8 zz4B%EO>e-wdv7TKD3sez)7UR@MS6~T0 zs64-3VI2+f9A!gKSyzAzk3X8dcpJJ?EfuP~Hv(z}W9qzl*FeK))PAB#H@HtJToU}C z51rn$6-}=l2h0?7Ts-uPNJQNH*V^6;Vk$XoHMQRXl)8S~@m$Xa8P3sb65U78&_wUI z$kb)@2&;@tc9{VcfoYw&qN}LzY80)8!9G}Ai+pk;rP!vxWsnV9whV^OPInaEayG{PqhnxOe9{biP0C1*|)}6h^(4-=iCLTVYE5R%U8>)kTzkmAoBD*g1_MUp{Ni5kKPjMeYAIh zFk75b8m`oWEhbY^r5%=pv-3*}x~O$|^YovJo~b($D>_jnA57ffAlqeXE(uq7ZgAYp zYWXSQb%F@x^bRA)4-dCeECs;q9G+Zn6(88_tEeJw97}|sn>#TumP!OBYD6DFE( zTF7my2)%Np2(8%?!r9d4p@?ueLAO0(e{MOH$dl~gI#B9QeDtqZ$^2_cd|5hmA~92m zICg$+`jPuXyq(;%;L2j~Tfzf`)F^tphp``(jfe)kU&!eeF_gJY^oy+-qVm zSCK(D+*SMd#x{(&+)>Qyd)gn41&Aomx`x4Vm6KsV>I#XT?N3qK^J&E7pxRzqqax8z z6zkV}A_?{+lWs4E}2@zNqJ(2X!TUQ}U7v zAmby`VsZ_PDBgM&dZ}CjE^DdZ@s-vfG9?XJ1$A`^6NW#hZGXuVE)I2dB0}OY#^`D~ zk#7fWnwuXz;jn@uhbBFZbS@Ed%Hz!?pY#d8!_mP!xM(qe#kgzWWy$cIj;il-}G`@odk7XZz+K9%Rdc-KF@YZ)^%gUc}me zjE8t3D$p0wED?a0i{uNt-mM|uq3zy>JG&^HlVmb7y-B#(pVNuv)gbhq)va8iISo%n z=&E;*aYI4=>Tof#Q0uFnSYK$m; zIDBc7;sKTn2V<`*&Pt{VH(?19hdffCaQN34*`8t!mnQm!l^jhrAVJ1@E`S@IX zq)!qwWglavyJ-dCr2#fndYfQlwWMe~CFk4i|m#U+6BGx|HC{esuH9 zU0xN(8DQF~t3G$O1&G_;Xv4@45-lFflvnwB5wB*#x^M}Jp=$i6`?LK7QgZP%*1R+T zRvU>gS6>UjfNn*LaFaRoi-L0TiN|B$AMu2&!*LOWa)01Yyt;wNR>g~|<00&NohEVY z&}o>?NMX0+dYrH(I~;QK0R;@c`|IGuDm}FS=5YF6t0H6<(ve8Ntqes8)dt~8Q9^B3 zmE-g%DgAO+E2JSuh$N*6nEGH*1zN}Fq>G9_A?~^P-SDIoaI@-O@9dcjkWkz4mV&1k zK}Yjh%Jm6SpJ%`>S)>;T2d!EZ;Vc zTOletqcSs786oSs?2%1Yva@CUjFgm>k`ao?CM#v{ab0#+C{$8JMySk;toM2Ug!?&; z=eW=N{GQ*>XL8>HD4yumto98 zZY?GnosCA!KE$6yj8c%+{@IPeb0Z+EjG2*fcoI!NX)~%L+^v#C2;W(^eFNz3n+htO zZ9wVw{VK-J5^|7SNh=-?Gw{%h^tKnB2x=@hR2CH_Mf6YK`^!p-0qxg52O5TcXx0DN znEo*v^zPjEQ)GA5K>^u#3WtO!YOK#*;wHUFm@i5*BU_??b@J#ZYC3ChqG`y{p2P$h zwy!eZvC#y>9DN^&!#3qZW?T=@Y6{BBYB>mXx(!~9DtO$?)(4EPrUy1v*HH}Lr*6$h z79cmR)8Q({sNeVL-NA-nls-L|Z>bysNCxZ`>-ND&hw z?c{c|<@uADrxgA)1Lxw_sPSd_<4iXC9YNokeT4<-#(4$MoxWX$ciwE^n0_D+$YxdE{MpXx-g90QRXGq_$SaJZ$@jiw=Tm@%QUCToKI6^j9+E0} zTsUkVa-tPq+OY*6nKS#&DT;w7#Ftb5unC|Yt`d%rx2J)aewb#d^rrmR%l{F+gIod6 z>E`2)>MTJ=tHTP#83j~T$Nz+xmIrWWd{U3w6$T;7k|CeVYULx}pEcc=DQym3VYU?c z{#?G$YKMk-Z9u+O`P^!D+P-}CSa9Jbs}6ayvGmrzOT*1g@fDtrZhn*B6rs{o7usqz zQx6d14f`v9r#d(|j`5@XH*HAw;`H0*7A@M2KZ|eW=O%3AGLq+;N52J{>rkBs?W;MT zN8pltIcM~bpX@)IX;aMyxSlP__j>3%>UC~5&ugeNX#h#!Iezhx!To>o9L-e3beBkw zL1)Fx9W6>wW42w^^X?3~r173rZ&4UXS;jtR@@4_`#+lJn9!$u=r8YO&j}vUaj+xdt zltJpO@|8z4W`6!2R(%V(iCn0C|q& zioVa6fR~B&KiT5*D7m#_g5ro6VETA{>gr_?V~ma1utx~_64xR$Ab*g_BWUpo*z z%Ht@zW~~Zjrzp9-9$iOGPPfxnH*SF1i-SWlTPh&fG>D_1La|{HM{W0@? zt&Z}{c{@Tnqrg6~r9ah(2{=blDIj|EEU1pW(A#p{5Xni)D;Ajf0kL&cIeYIMU@YWU zTvp}`{9Q?`3odw~+@uut-^{l`SS+hx_`@iaQL1DjYw-p}x&Jb8UvL3LnJZi`f)C;9b3p}D+F+wD z5u|f-_*+Je0G9SIuCf~m;M8r(I97MUJ+yta_8j{Ikh(WI$ML2Bh&Z1g-nd&1^eOv% zh4;$<4eJ!?Mp`*Ktvd5tuCf7K5BAun80$e=o5vqUYObMFQMV+Zy!EkyKO3zXdhk7QNJxw+%w*$tv|Wo59K1-3|3xYw*&iKvhGa6+H{MRxG@; z3K%B>S}MsKkYjgMoKEjIaA0U0s%JETTC+VL2o1~uk3h*Z6Ri!zcI?r=(`T7*ssFW$ zK{O*^M&6_Kdhrxu`FEgrqIn(Y^u6=1DLskDKHN5AUf{vUeJv+9Xo&Ei#(U;96MNvr z`D+0)e-6|M{k^-MLwswf&;4YCEEP!@YmUMOjB7t*c=48r$Q%8Z2H8$ zN98o`-mv+NUYo#iOP08gN;Ww4#cD3qq9Oj6nw=1OH4%D>dRh;K8sK)fM+1u_4g`M5 zu|;0$Kx}1scOv%A6L|Rw0nwnJhljtEerkHf54&!1%G!o|VXL43ZL*@%xb;P;lM7o6 zOs{|Y*v+^DH)u?Zk+0an?Hp^! z^d0>6UCAe2vM12as6aAmtQ@md{qa^9Xu%o7-){e#ZovHRl~?{gc?9bZJJxoUQgJ+& z&+nk}R-ETm!eafP1#4$+(-$L&v-4!_&UGU!(L+X^@?eH#-XzylVG4-eoK6-e4cI|fy{GKdB64sjwpG_^2u-r_BQWVQi z_cR@$OC$GYf9o|IOm=1<#YPHxqWK2r?P54uNdD_Lp~w3=5)wx!hQRKN4wqSlow2il zz|jb4b9@*SQR75X3(d=!X)e%KK*8mI?e?B&(D$+4jlkwpkhS@Q!O{y~{Db`7DZfPo z4XeKQ3^F!AJ1Sz=!-Qh!kYIX;H7yE?we;EWrYPVeBtouIr&=Lv$jUKt&t@1O;OJ)1 zT?V7?vi5$|O@T>2I^tt>LgBA_#F8Q95S}{y)amw$0xZ9v#-?tMf%GsB$*g)Dl3E(tzN-O$Ic0BhmqpqZY3H+ zHV$}apWE+dD;*Z@oFQ^1`-|$hk1H5pB`jOWd}fMW84Er-;l#;u8e-C;zbAt!;X9k0 z+2hYxafaH?gdmRzbRVm+AAu~bw|w!7esCX|dB6Dm z0iEhT(-*bW1>PsHxFzO?1B>5vN3Tb%AbeV6ia6{qXrIxhl_JSU{h!9?M(=c^O{V3$ zLY;#^HpHZfjf4ZYRhxQ}hOZ)Xe62G^>Nlu1KJBKi^cD3qMcJCkVRZ2h?JS4x3GBvq zR&BF|0Xvbg6xj_gfge-EMjT#4ApCTM?X34AinN|}+K#M5(>L6LS}Zt$_O&KGv&~!J z))!YjCwU)4>BQ5iyKMt5nXMkFl}tq0F~PTZpT0t#L3gjJ>4$nKMHp!a>3~<+2g|E87PWEvt-&b9?Xe*8W|%wi;0=yT=w1V)M~qMCM`f=Nce? zh4wj**&CF4C$e>A`e6OUt^H#oQfRI^)QNq82VCv_ucSYi z4P@C;e(+omMWGgs%Eq76fZNno`Kqr1XsQuoiC0oU<5%2FL#714r5_C;Bp19okFh|~v zzw1n+4S-vuhu`xYZp3COPP2XUDLDDuyY}`$G{D=8=Xe*K(WjE&XVGIapy|Qq|9FMX zfm!6-i=el=@>8i%)2?m%%}i}MnCvkzFp*GE{6R{G*t#9|4H(72DrL{^^GqT@<@oHd zJ87f&sY<_|Y}A3gU}D~?<`fq)Y~(x&TlD}~*4O%Pnil9LbH_5y|7=!~v>b1Hu-g1d zPpwiun+G_xv6#|#7=w`A$#n4e43KHf^w(lxMa@kevgi`_eJo0|b7O4v4jVdm) zl3qqB(atA~F#s2L?P`eqEYX@_yhBG?Fj$L!d9X}u1TOz|`LCQ!5xK9j^0ujo0%{e; zLlaR;uwx}l9xi(anD+@Po$9p*KLG96U9TIcIPIpPQLQKFlh1kGFB6KW-0w+nJ<&&b zT-suz?XJMUO^eRry(=Q+SNE#X4ghMe&+j^SB_V4uQ$b^nLNGnnVO^kU502PA$nP!J zN3>g-TO=)Z;7j60w6{wf3hMePkdWOBKw6iFg~$`YHmFv2>wypQ0$FoVQwo$&x;Uh@ z2e?lEHJaj3>KssVGs>KQ@K1KW-HK*Z)hd9W^whKNmUCkBC;k zRS$b+0~xhrb6-Q10So)ci3z>`(5YaWYU$1<#KX&bvg6na*df!eJMCBvhWlNtwYI~+ zE}PYHl85E!x6L)veyI=O_HZZ5_wrpJ_2zs9-y#FB3ikcx|54yq$l6 z?g=S4&sVOXDplTAatYLv%0 zaSSVM9V?k;*TD7_GkTO}17IsP?e^R7eWZJwneK}pJ^XT*|79y(0^6SZIx&0l68>_x zsi{#%4!>AcuhlrGi zsKkRad4%^=)gOH3d4wxmF6h?m`xJzgT8iJ7{TKwlsx7_mBr4&#Xmt_JVq^H`%Ikz! zQg__HOr1il9E`(q!zk_dB=GZ)XFH#9^TC1&~%6fN7Mj?TO7q!te*J z?L(aM_-k66jNzym%nmtN_9g&X)OPl)`*(Rf&rrBj;N+KSKe9qXWF^v7ne(_Zn?1mPznWb}D+@$e#XM!Qf@ z1+I>Axpn%W1?K|Cop+43IG!f;X5Otpcs9J?Usp#QCL%8|Q%h^b6tCLa%;{UPm*1ko zC$oD5Z{l3Wo9-uYef~ZL{d^rR4d+mn2yDepd$G(ca}C(=ec$cKwg^alce$9pGYZoa zznklLjd0c0wQ=veEx1dov5$tf8OP`6t_7WK!70*B>l(yuIPjt4fAhCn@T6-d*NO0U zJhR?9oZ{Gt9o%-#Z1uL`OLz0$rN_14`Khs+AfXjAd{;D9q3p!b;<|eaXS?vkIl-tT zmNrZ;ZK55h(}H6|qc>CsTJZvV*`M{b4lE)j+|~HB6Ei7_y#DaA7N40CyT?x1f)$zF z4>CwvacUM@8P{q%_GsOzA46T(=yP_f?|ZmsS|1-IfLnB#q6v>k_) z+J*j7=)`)yDN$0t`k@yYs~8DiFFf4;pbAO4VDWUkpGiO)y#3}_9?`!R*mdObR5*b{ z%cs6wyHW5CuG~H0^_9TKWA978(o^0J)g>x*b8On+ey+}4mE{3=S}{tujA#Hx?HhGm zzS;wQ4|#r?BzMBeTn~jI<_?07#n)2c!5~a{B3=w9`=G;_ISBw$}y?M(&tTooj{l zFJkY+MmEDIFY6lqeJF!QXZ@W5GLj*mmF&ML;$Ub_?Hl72(guZ$tBb{KTOcdTYjy_D zDtP%CV+Ofn4rDnmVa;w74=0rG556MspLXPt;=*DpoMhKeKV@4F^^df9lP~P`>KBx2Agt6e#O@Oflh%-F=)L{ABI$ z{Lcj{7F{a{2iMZ3do-cbvmZ>W#0juiqRL?2#G1hO+T&sRcH+=)uT*ncTc4 zOZX(4FFAZR2c~!s?HfFbhiBVWCm#peW6BZ1ORWNS_~xyn?-P>rAUx|(Qb)L%`?wov zEV_~n1?`S-Ecg3Dpscc_k$V$A4W(F@^)<&?EP=KR!sT!_k0*HVVm`scE@4TP7zSys zMOILC+2C%I@pso>o8Z_!hp%*u+Av=8$z3KDC7gcqKlL1DE?g`4nCyx%KfJ8>z$4y` z3YTfVh^6GPg_AW=C!^*0VY?)SWZ5-o%uV@MWl@I*8vaDa>HX|5_MMq3mNtYUmV7F_&Reu@0mur%oHLv@tjcpcan^n zH!*f7o0ewfR5`kw!4{!Pvbt_69BAWg{ z8w1TxV2eA#SiEcrjNP!*a6G+@{{9GZIhBE3r_0UU zbpN6Mw24Z-y62*q)$`3yNB#hp>v4ht2en9#m^WbbMlIT!w@IS8QU$KEv)nJ;PDa<9 zP2@OqH^9oX*EgcR4TJLs)a|*Bok(YEp2F)+Igl7k8=KY02m60-_dU%R0zYg@h8!81 zfmWxA@_tpR5K&PI-Iy+mbCE2^uuoPi!+Y}S`Q&cOR?;cR<_1M(3*6q3)80^B)( zp_%a|N+nbbNE{Q<>!d+*W%~di`lN+boY@#9&I`Y3_~nQu%ljVCwdI178wo__(@CgV zGKgMfOc{0u;BEGJLD`ZF0K=l3JKUP$|(Q<~=+l*2h^xJ_h;S8Mv z_}G@ApY&A?9f_gsU3~_gpU@%Bu5A0`n6irsuLCI%L0i);&@UyzIyRHqqxN*O+O4;z`$GUJ=$~sfjS8vFum=CY?YS6 z{08p>N`>d|Otv%8(d#GTe6y-Se^i$zcD z(y$96J-72G@EO=VXS46!A|E+~4-vu2=$euMsF02Ej)1Fy&(=A6m4_N0e z!4&X$Gf8sq%Loup5M#F1oJAA|LxcCZ5$Il65_>myABf&QT_bzC7X9YrDoL080^E+u zIjg>324UH0F1O!&03*lVF7nrPqh|3BZm*;}!FFNpmR!~Z_)EGyOK^f<>a)Y*zZJfL zf-lnTJY>_TB$b~1Lh&DP)$2*&JBcHBp)Kpp+2eHBovC=>m{m7;_E#LZ){di6gZxT4 z*Hv)I(%KbMvS9JA*$oOpq_|%C%6MsiHxe=9Na*g_LhS*iJl{oWA+4s!DzQx-2KIyu!OD17Ju&01nVhjxkLdQcfNHmU%*GqS&%Wa!~*=3fi+t~tWpcBc8E zIcLagDRH)S*y z&x~B3*5W>-_JQ3l^Xs6R3`E#N_uQFKF?% z;io6_&MK-@;}m5RYIc)WEI;Rabf&Zc$Fb}L# zq{mN|l-3Xw%-E)=0_AWcC3uuFFCUUB>O@GjhCxcJ?1KLy9kB4)iaTwE1wJ}dwUI&K zhx^_f?vOqxhHs9Obq&+S5xhx4?Puz3@$JIPZ*<6=u(tOWUrtOtyoCZ{N_eVZ@)74? zF~)4DBFbDVKH>liR&4do(|KdI+oy(t91vVtb6eIDY=C)FNAC=lyn)}~xyu6{@vuGF z$GC9RlCT#p;63ERkb^?E53)7E#~(OowztY5Qw{CYYv(c`$4wpnR|b#Z89J5So5!s% zul1nLW)vqJ>U13{pT7is8k@wZL-_GGDyA&{leCzgb*lBarz;+<|MAk!<2&*)-*6!+ zR)R-q$zLb5OJUW@xp(<*`Eby+`+iQWKA3^LRzxe=9@D$;ecFGn51T&SdwWce4i1X3 zR4xgq;ZmtjAJV04Vd0>S>FGgltf5U#+a08gCofYv$X_&tR!GC4rH&sfgvWZiM?Ho; z;Z^~eKP>Trrss2!cdpn=RChN@*c!%{KKMd4X$+wctb6Qvg@Ym;mExrnHz)6rx+}yGNc+KUn=2Q}6C&my_ zzU!OdZH(2$|L$MG7IM2+LPa=m(Z|aZ*Dr9wlMJ(n{MIonEdB7CxH1V2xRm>q@}?*j zsMh8SyRL+Pu@%)`zDx_9B-yRc1kyu}=wj2hWM=F}rXY9zlNk(+_PakzsJ%3C{Akgm zyog65Y>46m&%>x(Uc28ee~|WX;X=EM6F_2}{P=CpK|o7OCpeEGJP#ZG`bW>H=&9y(Eo(17Ta_(wyxyvoV)&&9g&&GY)P9!*b z_vyNu;VLMfN^yR57X#Z5)=RgqzDLykKg5qj^nsUeVijux&*0rE9U80uc93+2bLVH5 zKR`L!Zb0JoXY}mpRLP_1enjfY|5Hov2)-SCn61-AkNZhHBCoX1gVdw0HkL<+!FBT) zF@~fCwC8XC_#1cyE~P0+GLQx!wQnh0eCR367nv4L~)+cH*6yUFtVGfrwLvL38B2P`u!4UI_BBBHT!}5 zophNz9Qo&u?=#q`LErJ%?bQ5ELK$vzKu}2@Wi(> z{^-qXPb-fTIzTm(#`c(jJqj%Fb-nPw8wkgXWv#(@Bx5+?S)r5&Zc+ORPE)FbYbWR} zy($Rz^nBINjB1PkKfTW*ZT3eEOtM%713Zve4k1*YbdFF)*oNOLc$LhJw|cx7laE zAf2)-#nMZJ`8lxfcIJu`$XnO{ZsK(lkxNwiem81D!ekGU(o>cIr^>NtuC$k6xAx>_ zD_t7MnFt55!Br^iv&u}|vmrolb+nXPU>k^CG^2~VP!DF3{;njF<)BsSciA`0d{F;+ zHEz#e!{FeaZF^7JC_4iHtr=R&uqPHc~WsNojkxsy96K@E;aUpWT--OuT!JQBpK&fLsW_s-zQ zCU&-gBa)apLT}_aA&;6SzuF7^wXtrQSZGA79Ta!?Z&G>18=h4)gH5MfP4Lky|Lro{*=YR0~nG; z`*Wp?A9H$c)TJn^L;Ipj75rXCI6#W&Xj=SLD7iIabRZiFHJf9k%=k%(h{RnpP$XN*~N(U?owz7XX6&6;w53^OjOC{C=SyAg!Y#2YuKvfK;(_MAvJUG8?4EHl?el*%_yxyG zWEy!8Of^3Ya`_bsf5y59Gv0lT-BvEhL=$pg=Z!UMK=VGe5(+z__sAD&{pES!YhaG;|g&ypZfKVg*M!8b9_o^x*5}CKXaWbuE+NO<_&*T z*5kRi`i2PxHJF%7lZEFF5Eux<*-zJKyh@Y3WvB_dm0$(R8(Vu+voBX0-+npCsyXXfMEW-5V@tyDRX) z7y2qM;R?JvCUb%MaTR6|^!a1MRfEButm5L_JS-*lD$gnDH9lJTF<#lJ0t@@H3OZb^ z#O1+tXLy#X@HvIm^GXc}{xKc$>MB5RIBlyUfrKzW+5Vd6-ofza>C|6xIvA2o_p^Q= zMzGq{Cb~cbL3u@@58~y`kiN!R_FOK4Mt7AA0|{qy?}LcKEw~!tTm0hYv6TkM8hZCf zC0_&7p*@_;G^vMHKX3dy3+f>x%Q9U5Sp(Bk&1=Lj)W8|aj}fv?RWL{RQ0c$a3aIpe z_h-PZa@f61Vk7yg8vdIrsLZObf>}ZIc@*C&pj>uFag%2m3|JmUkEctZMYZC)yr&rM zv<8!P>oh^4I_I&8^>V1VZ4IZb(&5)E_c&eS2zdNe7WumxMDR=y>-;1<&)JV`>jt{j zF!Z#(2}jdQ$doNsS>E~#D%W3b+cT?&6#8EusTw!JDuM5Qn=*B9t?cV+;MEfN^HzuP z8RlI0llG=uQ)xM2Pju>lYPSN`d#_zR=T;4`Y2=psFP6bKnU6ny*DQo%?DA)YZkEE- zb$7Lx`ZrKb{8^>uW;r~iw)JsYrVMrmu#2fp7DA>-nzDr5hj4a&C!eFt8fRMfet#<9 zh@a$5OUzhYhXZ8cfHh7JCb`yxMg=EAZQknhPhWb#OmMg#$Ki=@22U+i*{j2-lu^~| z$O5kR|0kp)kP9gabVp7yC&29wcJh0SW;p9=`_1@WOU!LzK~M*2L!B=)qyi@jAv;aj zyxYfg=~f6Nx2(R??=-TbBh%$p10MV64BtDISoXXO5C=Z(7r z-*9S9{3{Fmawui(QiT!D%X+9o;%)#hIV^qP2?JP-?ue1(y|Y-`ep@?HoF7uHuy)d& zA;W!YV+)s9Y+yMP+i~7ae%LKFKpRIZh1VR4{wCUSL#m)0%UFd|1aHqN675!fIN9sJ z-m$6&i|zJSA5rk*IRVCxB@vuBB}rhMRE7sy@eg(z7#ZU@*$ukDo2qbex`>I$R}4z) zuXep_7Q-$?=Iv93+h|1nq}a0)CYa}8z_}DLR+#!l;^ehaF{pCuL2qCm55DN#^S0lJ z3CoryO5`xo;$Dfc=D*9w@HQ8}>aD?_Amx3ky2U~{P?01@Nu)o}wVuKGMxHZJOngOX z-IfH0UWpF%IysNpFKVigX)J-1={El$(vN83LVd@@bbe?iMU|%Bc^uv}d|-TWWDoJT zB)0V2_zDR5iQpE+JP3AcDA6S3#pE6AQdC>akd~49UT5_%BIVY5%#r&CJ*WxHWENTh zb!#H=6k{y-Ks!uaV~Yqj`f{u@Y%hW>;fJSb|NKUK*R>`(Ko6kTRGg<$oJDO1M+=7( zfLTj zVV-?4WXBA!EG}tg8ki#HFh`xEgx;Z$#kV4AvtVQ!B`W+$@ePpC|N6&h!x(%Nh^^+Q z)IsN4>e%P67=X_S9kKhry^+Jjk-M?a3qZ50UJ^%*0ifB8tR8JpzFF29_HxaPB|&O9Fm?0w3$wyPh& z)yhMW8&)--@0mN@W9?Kl(plNl@ca&;Cr02K-Ymq5lw9yVe3+dndOIHoZjYBiO zP~@Q!Kg96ID;sEC8af@ap9|vi1o}8@Z-BUq?fb?9r9hWbWSK)W7nzR)TL&D^1zj4) z8wrRk5U+ckT;W|GGO%y!Y)&r*(uWC25g-SdSS9o)A7lY$(tX_vvM<4MJ(9@Rm_*OD z`LX-dZ?Jpdylnvv5mM(aTpv6Rnkxtvrm*sca+r zH&yDBOB7J^i;|!JM=pH#oAZ6S7;a3kz3V)Y`3{;gKVGjXoQKcBRN3 zGd6Z0bn%Wc!7=&hz2J!^lQ_?HrZH_$4&Gl-_$NuJhR>fUVGZ46 zfx-bRD-UAt!_9`bZ{C06gc9@T{w&n-!))`8WVSY0TpFC=Z1_kM>RY)s9Y*_m@RT_RJ?%Z%{ z=}}F>Wf}ZwhkZ>mRuf9YJ0*)RZxH-MiT{ZR2SU+s=CZD&bwrs>w8;6Q7(4U@8@~%H z#}5~DTHjga6jIe|i~a=TA? z>4ZBB&>l8$S`NZR2@_vpv~scQmcAp&PY^`LD&>w>5E?BvazWEJgSXtu!NnQcvuLv7I)h&a=!yBSZ9}8gugV9;L z#Ue=VSpIzBPXRQ(AVMQn`UcWJ(ApU?c>_l^!ULxA3ZQ>iT!(_w3n;Ca{qXNt3beg> z?G2*NfvuN_`1B`U!Y;v6DzQ&0drv$EniQ?*~@n&<})JLrJ<9-f&&^U1HUuGH%8`CIsGzf2}TzsmbR2g3Qw4!YU*#Nb0=wcqSNRdFBHr1EFK zNVp&HW_wU69I~EPo-qvYg3qWlAE-B6fHlf=m1~|5-;2pCqq%hrmzg=!W-FhE>56W` zW>k{U@nOKxF|%{H_sFi`$Ok6;#Mx5viJB!o_3%hzGBKr7-<<`w(2jTc@tiuLBmw@+g&!HB`@9IB;6F7i>!Q&$TXb z<89iLbs1W@27fHE9i{pBze#N5@^ySR}y*k37xr5 z^B}Zn2tE2|n3eT+2JoL2;ymIq3hK|H6BjNtqAj&|%Dn|~gy)@0c=fXgtW_MDv{(8B zczBbBXH!0b{j86NIY+BeyxKQkv44K(le9#)V%jSpYkQMt@8xr(^CnsUozoy77O&fy zqke%-)2EY0{eF(rl4Aq`Z5B9C8GB~Y_ZC$fw~W3fVCKtfN`A6+2Z5*}kG{t|FOcd6 zMSw+MB)|--p||MXBlTa?np=y_Ksr3sP)#ceD4N~e+tbZNVY=jjT_TS`|#WJ(sa-tB=VcRL@eispjBpZTrxy;?w>xO~cukro({$T|pp z=0_a+R8x(0rs#rh($Zd1E}-);XYRNn3fhDc1IGS{BE8TIQez?-(5vYg7#L;(Ivz3* zD?0|GJLOZ5)*#q%6#;>v-xq_Haiq{z1YS9~XR>P6Nv18`CzGHKkf`%e?-Z{%A z0$Y)lw})f};J5twE8k?^Ba?96g_flp!0fp{24AHjiPL4XGFMW7bx#&{s?GzKi%Q;) z>rA7jNhRRue-D}5y}5feSQ9Ls;;1XT?hU3+Cd=~|q#?f(jO=}@&j4aP+9YyNjCf~K zkJz|o0_w7Vwb(NVwV%IXTKTUR-AW**h>%_b?_Qh`&C#kt6w#WFM2bZqjM|NHVCOk< zlDWQk`|%)Z9oADh^xpxk;XmdEON&5>nC{z~av#vQk?>-QqD9czUvmXcp1@YG==wWP zGQl@@`R{x1zek1jrb(+ZzMxaAzRZHKhjcctKUrja40E~9sb=jW%vt_-J;{mWqxez{OER(BgM zgjF1_X>h>zAr^fP4>>VeNIg%7ZA2nW{S^>t7 zr~Y9x0=MPcpNg0>lF;C7hr=luQY^(J;mY_z0*f@NRFzn$!Bu&xU@4-jIKwegLVd^; z|9;8(qc-L=uJHZox{@i4*WY=1EFaN=leG+Sx%*n!`+j)8_m@CSwDI2KFE)h>W_a)? zxi|i9PGrkD5rM_1U!hnzd;FB|`c2JeKKQ`c%h##U1Wx3r&-{C1hXa`wWzT+=!S|eQ z#E%*I!VZUwh+Khig8yb>H<*GBRs{&3&B^tGuTO7HwhJUciCp_TL`KQ*L8S18kXbIQ zH0Nc_*t&`D@(C*apbv&?4smDylgxqNw#<@ZH}fG~ikz$1$r4z=>6jrga|b_6j8PLT zxC^!E7t*qY3Lv@ogYQ`W|K3*azDcSwXk9KAstBX8f?%Y?tIaSR)%aXkWW^Qs3Geu& zT1P_7WJYJlkx1Aro>b1$n~sV1d&W}*o?{DmNASS)J_d#ldfzV-?n>mXRn3cCVMpJk z=xEOp>`A#aUq?}hd95^GRx74q+VYi|qQC@9tRW<~<`;`^mcJnyA+5o7!5?Oy%amh# zmyUG}&jKt&cPl{jV=kU88P#}nF&kSB=WM(WBjjt#Ph}cxD)AAsZ$@>GUt_hOabfQy zim+s34jkCe!G?MG4+qqRDk!|nP4?-Hf~GT{S(^!0&ffyHD!^9WAXa+PKqWn zypbOLp*_kR+Vv|h4&7)cH8A_ zpzzMa8bZ?^8dO&Fuue&1=h|~5%Pt&nvC6V+X7nsvCu$S_PD_uWD1_%HXOO!0LgF#D zIRKR0&rN8IpyHQZr|(_qLa>KVMds@fEYiV|NphW#H`vjU1yy|qBVDd9({sDf^*H%c zK?VJ&#y9_ldkOhb&^hOSd{@I^0je35D$hAhZKr;<5q|F~eJw>7IxDJn{rb1lv*MTb|1YDxcA>j(xA1eZqHf4*3$aNdZ~Y_m|ws zUZDl)lX5#H%HYh$wBltaSH#6__A#=`3m9g9?-HkQMIL=3idPI8QD=m&^eABlx@Sn{ z!mA|)GNo0-Hu!9j!V;1BIhS})*yZeU^~KV+NKpB=>- z0}g5e-cLvf0I5wW5!+wNNGIy;DPk5aP%rs5#y{K$jaGD4M0F&h#1oDN7bR-Z+Y>j0 zl&)0+&!uh~&9Bvn){NqZk8>%~Iv@M$!AD{^uKloOAmIh-O;%GmYW)&DYuLEELW)7i z=BY-~ooSSQ>+*a;Pc;ZAqd^pW&w%D#Ro9CC*Ql@5|A0uT9%ySQ#CZJfMe1^+PohQE z(U(5HQi=yg;3&J|>Z(No*iqJO^3N|scS8z^A_Inif|&EG2=`lHX-Dkc)tm8%Ve!#X zrk1DR^_z3YbPQe~J`Xm2N@EYObnhPHD$5dhsV03ser^}o=uT7j?k=PKJi~PrvvzQo zK8M?Nof%FJNW0v1mB9&2B>0^D5aRmz#3Go11ilj&3CW74$NX@5F#N6%EO9^~FNWm_ zepVgwe2wpji+XPV%>gw zmA^<&HHNe}_y|1C!B@h!&W&dRDV|(SUq|e>sWLAF{sJu7UZ(wFvq&cnB!AtX0Rd@@ z8M+DEfH?joV%!zLlH4ypvA@57FVsaYC4Jz*vl6KRZk$y*un4gs#X zX2#hjuTK`P^u^S8is)bs`!?y!aUg4oxqgh{i1Or+IgKF2Qdv{^M)Q zqr)UI@sYWEviQEk;i*734=DFNCxMOLA3Og_1hs_usYBjSuK$i4{4meubZT4+yZY#> zyZkeSud^kOv;Pi)LiBlCFTGAdzs?K6_Po4!$?LdNdx9(>%o#}8*tEyh()zJ%D|etn z=0`KFN8Xs5xG|}Qkb5wj{OD#Fc?s2dX>WXHFM(rxygv5`zQ;oP&J1uP4Clrrs+`}s z0V%|vOL}a*g4C41F8;Vg_`a>Val7D11&sOkBr5sS4SX-VqhIoOC~gqfjkL8V_yQ$# zXT@u(p=b&PGcKuwEhewe%gs2#oDAF8eaoBJE`siO==)o+jDGXqKc+hPmibw!5(X@BSXaJNmg-$@o`w3oMIi@Q=RK3hzFo`ypM5p*%@bMx1RO z99T*Cw>sJkRUh8@Jr{+crHzW^Z~hi2-eEQztkZ?(>t6YAhIU|^bDPNWOe@YO`TCnx zsR;|UcFpAzavilu?dfXPE-V)>&Xvv7fh}k^XnYD=FsTk{imyQ-%v#gdgi{Hitgy!iC4%0wqWYchgx0_97y;`4XRG5iY!Us*Z#|8@~*Q zitn8d#k!eaWB+hlz}$W24%tB)NONUd`s}+Rtj68ZSuCA_lRl(1Mb>!W8ae%nkxfGX z^zml}l~hgm)a8E+orgP?UmV75qLPs>1v3 zY*I>QG|V(mND9U8{Rf`wyw~+S@A;1V{@mHz4+2Z@#dB=-!=h<8f^o5EOxhm$S-E^P zCAWlr9)d-z{ASoW>(qRqNgno8XJVjU495!%9*>s8JfPkFfy-q=<7qyovGXSVa1QW0LRe;#xFF)to>*IM>e<-y6e*74SqLa;S+QDlYe9is4g zQ4sY07t%I(#?kw06&UnNefN6O3?97o=~5~ZhXq>O-|{T!@tKbz9(SewpruIHV;?W? zfJbGVG**%Ck;1W@PkLD-&XGa6&SPhGydgra9}xWw?94bLCFXg+dwp`*Flh~0GAKvW zEs5j&mqe%J&^V*3{ZYHPAa-Qf|RvKIzab*a2&q)bc3}B zxLj=x57;Y4(r(5FbiOU2T=72igpXG`0(H_L$$zE`_r3*Y>ED<$fZ$KtiLPrKm3en&7>c?IyqsY|IDC!Q03-YR& zekp727-Ff9c{lL01i1=iVb&MXbv1ep^8Cld=}11ohrg&KPuk=G z0R=^xykB=g=Ty()4H_|EXE>@R9dC;IE5>Zej@W@`Wkk1+N!O6R!(S%*eL}$I&|@$@T~g-889y+ z=-_eUBaR7wLZW}IMb3Qczl1@0msKf0anSuEh6t$TP67J*rLbwgFyW&VSyZ>W;*nO6jemX9_&k819h}}f#+{;pu1xi zHhbNEgX12VPQ98fAdmm^QI-~YY|P<1v?LY}d?_YkXEyple1$3R)Bai1Zz52*K|u>~ zCMcp7onxX` z2Q+)s=b3eSQNtTOpS!A~piAF~!+Gy3%DsBgWCl`WgZIK;Ij_c|=)p6xC$Bexo*dr% z+G~C2x%n-gEBi~p(3vp&QhXCQ&cu7}8t}oW7`K)^A1=&h*vHl^qykM;!rXH`-SAt- zzVZ9nx8aL!o0`ApB;a_>wXH{ba(L1A22DASI?O7LJC;a$9$ThLYDspg!+54f{Ucp;bP;>3-!r2g@M zihf;_0Y1)9Gkvha9mdc1aMQ`$f*L2vQdU~i@R7Rvt756m&>&22H;c0sx`(|L`pIYp zhb>v+sGnVen|JQmR^Rl;M&HCWb^LSTM_Pe}wS(=@ICM6%s7Vu6%2~)t&YZ&@1Fg+v z!IxmnnFkZM-bP{eOJp^P4)@@#A+~!P+X^Io5B>)YH8Ag*gA`e=5)>{i)qg?j13~q| z~blM=}kXp1bcugE8vY!f?}x)$M|lkbA*d6Vz36kURs-`#(|d^Z^$(&IO4neVsd~4KfTYy!fvK!@b=_ri6?( z=oL!-JYo?+>HEb7@jRVySvlR3g*y$Z2?jAqhBm;IZ)<0^Pj^6;dxb1-xe%=P^rjrX z+zI33R;pKLqcC*I=Q*Aqg2^Qx*F3#P%3(e{e?I2F4p^Dz6O5P<g4(tbH3Gw( zuwcO6ZqSQV-%XBQD)HYNS3Wq^CU!uED_3luj<&<3X6;xT zeo}rivr_7XVg$wLYSZRO`j*VYhdMtu5#eC5Nq}r1g8B1zUAE4*LuG!mO`3#u`0^vu z=voC4TDpwe*zvZ)3Z0eA@VH()uVB9AZ`p@+&TBYneD1@`te2Y3zVE}n2fV9B)B14W z=n3u>iEb=xu<538qz4dPv+aofe$-KJ|P?CYb3q3%Dh;yR9Fk%XAKd(n%Rmy)+?$` zs<&bHjntkM{Wg66gI-Svdp+)c@u-_ux)D45_r~?KEU8}GZ>Nbn*n%~6&;8-N*@81! z{ap?7`fyLDy@Akh4=z$%_MqPG!uL3P))bvPaQRM+de|o-&JmrYPf+W@2hVU1=OuRI z6XOoCLTeqEV(5eY{ZxblMo+0vM-%Z=5~T1I>6{kUSszt6I&d1O?hk83SSMumCYmAQ zl#z=Sn5)Wy~TW!M)#y=x|$hP3|Nt=MuzIrTJM!|gc zb_*sPeWg@{Nq9|OO8}X08a84-dsZ$qC68g{KmA zomFp~z~||6W>ROIaM-!bk}z!z>`!UzW#q342h58fSnl#-BCWQ+<`WSd9mu+?+hdIL zhI6;AMrC0$Kb1)_iy$oMlV$#Kj~^FYu1I_`wg&R{bp)$o)Zx41oJ~t*vM^zwkHV6U z9rK&0|9!ml8YG1OBp$6~Al(P$j5aYc&~l%QQsxgI?)Y+SaU*aGJ+`H93X`OQ9LE!Z z@YE*qo3x=}dnJP(t$DFD=rUvDKNid_K~%7$J!gK4eH97$sF$>gucH6LeL^1|6vJZP zjgGuSWUvuciC8YI13UK>x$vM3#48ERj{STG_Qt5D&R-;h((A_IMvw~ngml3n@{cIw zdEVslfo5cQNfZgrOoLNTGj7g_9)Tw~ce{jHYSB_){#)spDYU1#dRtF<6ja`Q-Mkq5 z1RbZ`eQ-4YAF|fBsw6A=g1Qf|WZAQhfCpajdQV^0BT-R$<3k)6k&kYo#}2E=M6-DN zA>9}#^{};-n0p9-Mmnv2MI$Qt^GjSTJ&o`PNo+D3o>??W^qH&?tu!G_UUEsK@J z^MycXolly|+YfXkNogcp3rB2?0}2=4`hizUhr3v&TY!3{TxHyqG{7hJ(K7f%6dDTG zE!9o-2l^N8X)v6z0S2OdZ`9wBqgp18^k@<%d5AmPm7kvmy%`X^e(SRmVC?zF@h{UF zsf@+%WZL{9zGsOrurDA7mEu0{m#FBG@{}CqEgn(8x~-em!EzjZ%@*n)C=L*J&luf! za^MZ&&CZIYGIO~*!-@`wn=HSk7?e(I&{-|oFT1V{5_sV!I%Htj4*nI4Y*RNzqX#9I9*j}sfiIgmrzSO@ zp!-(TyUC(GAZlvHZ%T6xq%mYa^XNGa3=?u&vrhz|Vb%C*4xSWH&N3%HW7&Xy?_7@A zcW(f%{Au5vSUv&XzxTYNIjjm|+MbA>w7rZ5u4Vqp+bIDzjgFdy?erj4!7A-&+HkaX zY+Wg6EF5sCwzi~M#Ukb+(YLNYg24diL4wf85HMmYJoM^58O-vr*m7Ywj9nC`lmhN> z!*<4*hfLoUFk9210oA@!xYu1`aQ^ETFizvH#U-(hX0PR+Z1mUx<&+~O#cR}f&t=_l zw@Uy&U;#}bZY4QR7sRPAKTFxY#lW-?g4g~+e=jHbgy@a+6S_UeD#;9lNH!PA*e#PwBi!1h%e zD3e~!O+7aQq{ln;!1LM!8=GX>KRZH&QOzrvNnuWCr|hXCWG;$} z=|%1;iK#;xbAcduP6I~wS`JhXvg0$(*?$9B$syaZ({iDvpFmH%!A693l1>yuL1H_h5%h2h8%4jXxVHA4N?)z?<=_JYQD-vmcI zQqoC`841UIBM0!=+nKPX;n11;y~dDHMIlmv{Q|zb{_<(Zt{3d+c{MeE-U|K^qCB{B zJq5oza-BAoT@!DxK3w**vx0a=Jco6rf-8LA#Ii_uiD|j?FK(Lw+>j~Lv}lRmI!;w zesIW3KZAcb>!2Q3*@Mhs8`TZl213wJsMPQqewz;c65YzH3**SSmY_Gd;JVdgHc# z@0bgIRr*cw(}iSwkl(c_T_+qCpE-7%^Hmm9P`OjEB;KJ_SqSxe8A?x!3ip{Zyz=(TH%USzCe?Mh{+CJTObTpQ zTFip4KPbB0IOB{@=D7qsQO?0QF8kuHelZ^IlAlN;1R!pa&n$EYoeagpP&?4tvZaN4z&J9*RhTwb-*d{Oy?75UPEG!CHA_gMh`_%JgPjp>(5H0W{!(=j&Rf zagVU`YX=Hj!hIZaI6c$Ay$U<}x37QVeS)vZkmXz%%g1!#jK7#RgYa1J^eN9Wb=W*> z+`sRdjyLaY(&t%4V_*79U2$s`aNt&vuvX_)*g@PDR=MT`6Ib!oWeO+UkXVxkD=)$Y z^6|*tUp{c(b;@3`OBtpPZ9O>j%>oOE-)Z$Aoiq7mrNYj$Li~E{$*A9XYpnCZ&+nk* zRXE2zn)9^b2p+xmyl|N`*LJI8e$~?)i5r9_m>%yt!R@P)1C#dhaB60EZcoS*Yf~)< z=JNyiQ+q=1c90w7_~Gqr->VKEbwtFRo6*LJ++{z%-eSO4;%pRNIJ&@ZJbfw2zvS_2 zMo+EtR=QXy?{<5kyc~RP@#c*EybQET`l-N^eIB=Rc6RcUo_{aty`XrU6clRtn@*i} z40hh7ym)X<9Gfe5T_JFa;YGT&d4o`E9O3F8`c07^_S-0(O=6XY(VVa+rR3FI4G_JiM#TKlUx_2#!yo*zwh&!N-dF@AoR-G`js#ZVNpT?(cT} zqllxn^tt{r^WhZ{t-)EwLr~*r_$4&?9XY%nJuh%!2i@tnc{O*1AGiBTQQ{3{uDBq8$G37Z^dt)nb z$xeJkZ#D!d9-dP>J^2O=6Q92SPFz8c?#NGhY;*$Su`-V(?>Zn8ecJq-Ngw+Bl*?pC z;SUns`VcTy`38K8dt529*#XKp%a5w?b|an0ei9R>1{l5@Y<;Wz7d_T4VU($z0I$XG zlb^nUz|r^at`#iZ$i+7DNb|pDaN*$3M(=N(An55R4=pLbXM5xABK-Cc>C93;7-0)S zdxBy1XD*h43D&AZi7dn5ZmrnYz>}ruz_j|kv>WM2YA*fTf7Y4cXQoer==m7r6&L+0 zoACu2zNVWpSCfQ}XZGHc^vVJ+imqJBDosSpvITzCX=gx4Y4Js)>=pn@Ki|{Re+X>E z0#1L(NJc1+q`Lj#3(ETyO@F1|1Xe8OJXRAOfY$uj&(eEEApIdj2Ju}Al42}op!5$0 zHK$6h$~5|b)_vtA|67lMFzpL-(edfAzCVQ!#b{ly4&lO^%3w;UMN zQ&CDykVGk&AF}YHRyu3%0Ic;|8n`L+(PwwN8zX!twIa-Z>lr;1c(Pk)49?}}S4^`<|ty&=#eujYVGN~jI>y=F(04jJdmPAP#v zilEN>9P)^6HI?(4RTuF<^HB0b_jiPzzz{`?^m!udy}*TA{hI`ff18KqNqK%^hF(*J z?bnE&Q{QjQvKA5I$z$xAwQ`6B^ixqqdOgJ6;G>*rxyyv(4eNd;JpzP<((S`+NArn6 zBUf*4DV7o%ZuH67{j4X(mftMlu=z^dm)#pX)OvyF!>_x;LVK4$mG2zA-(5s3^W)>+ zD{Uo^(X_ZM{d!L@%b`)aeftuzBTX-lqc(v^;;0-PW6UR*1YxiBubsr@AWyd{vL52# zE>C@&AtzvxKhxc}BZMBF>sjJelL6lscNX*4)X|+3YC!_JhUinL_$z*F5R)D;@EfGA z6CQ9t{ zi8ig&fIfpMN@_qJ6vvcB9txZw5Kp?vzpGgyYRGxSga!X3a2iYnv_>(Yr4trk|0T$v z@1vhOdS*L_o(2K;Wi37tydCJpM7TDIK-F@Yx`+i($M@+iW*i6nhhMoB(EA|%UrL9W z`TRi%ZB5z<@i4^n+qTK*t1oc7dT73ayA#l5xPLh8WCU)~+zhpQa|ZppA+;#UWDk^1 z1Yho6jzGiFUyO%_(?AK2;-pT%Pol__-fBSI3DO?J%>LeGWl){xP0uEx2BsIOi7knV z=%Bo5_$lN6(6>Lsm5QHFg6u*i8~;)r)X2r&k!NZSCcMUlb=7Wz`A60ZJs*^Ss!PIu z!KXD)6)$aY$m|)=e1sl%@w%hO-76<6Vy_`BGp=T-qDO#TyKU_B`3e;Lx6FtCX%0Bq zd(4n^U^1NerXNbjtgFZ%HLk}X5b10cm7)%TLO4*kwQYFP7r1RQP)eme4R z3^eA=p42aNM%R5ee>bo@frvslOqSycvg(s1^arYuX?`%TVahO|J-E*0<(Y325GORZLoynSm+_^=aW?~0xCFfl=-PukO=b{xN*OZPw6uKIRl@LvAot+O()d@pz7@wZsWWOp&rW0ehSdM{Xuq`ShiUR#kc`x<=oVxwTB=qlE9+n#>N z6^t1x*zvtkO&y zc~xEue!f&Z&2>c`Cv6En3_NF!zuT8G+%>U+A{pP8jf#6!+b`_J|V{K6XcN(s0IKC`R35SK`XMQYl#zI~7iNj|XS28p8RSDugYW%Ed($YAl zZV9W7S$kwXHizjvSz^>5AHcU8t87k+_u%Hv*`yMg+t77h|8hL-O-xliyY9ggi^If~ z`0D1PVdB#3l#rlssLlx-P6oL{!odSu#iTq(0ggP16Aa!sB7|AqEaxJgU8@tjg6*)- zk>hg1i5l3sr(P>T1HeMH--oU(8p8_O0=G9;lt}Mi6WZt%gyP-teImS+(8TD1r;*%G zpdotiJMqs^Op|qlIy}W3R`}M>jrg5`)97@`;S?FT%64w~Te}?o`=giMTMy!|W@I&u zw6U1x<)-jq&T(=BazOUYLY}=#v!p!R^Cm z&I@20EdS)~kt$Jp*ceUv6!_g?L|a}e|7jDL#R1#A$}QlM`<(|N4baC+Rl(dtY5q6|VNpf+~!QXpgRaHG9 zmgKyD4@_ub9|DVZ?0t2T-uFXHc_1zHJM;YZtyhY0vdF_cC-WQ*{Dm0w5`AIKpR<{x zPXpkI#qwvmUShDl?Df~_I!C--<}CHf!VPAK%o13l+~J1^&B_o%MR-`Y^w{wPGu-{b zEN;KY5I??SR(Lc}2=-{X=6yMVKpn+*#mQ*}$ivvOp)#$5 zU+T`wJ^Cz)XS}V3&M&Azdf(ZU4q7SrZsK*Z%rq6&JpWc;j35tRB?ZYo$E-FFp z+O%@3rV|kEM@{X|QD8>BiHjB`KarE+8FMbM2Nb;yguDAvaQyHXs7v_%B`_i_}K{=1Rh{*D~pSC|=Ukla85F`;(? z_CBG90V_H|qViZR*f);lI454tkxZRBcMvj&ACcSU{)S$jyO3i}_ZMx1J<1~AWX0?h z@_QV<%OGp_US{i<6j7o|@OKF~O}OOpVRH~L$@x`3xKV^8c~jx-$&1Tu7LoEP84qlI}d$*d(a`n0+#>NFooWT>IR8)fy5k*0 z(MJ{Lq2>)_xDWka%?ShFgdHqD={*LA?zg_uymblOf2W*Nm`AD~h4&1Xe!7E4&Qqdw z59LteWA=&^>sa*sLO-XgWB?M_enjJBYzKy4uu>hbA)vG8mSp6)_0f6@@u+&A0a)9K zI`YoxDu@^q))te}MyeZZw;!(vpbRnUyf2Qrpu4^*(xM<7TciMywJ;{pyHCcM?s z%NMP_M2xr{na;=PONeCXp87l(N+h@(6Q=WOBA!*7Uo?KrL|CzSW+NnPN)RZD^Nh80 zAYSrIl`cpKA(XDvZ}t1#B@9$l-L2)PBmOXdLicw~gOq2Z>vu2Ij6nN4_wS@=0I{Ch zdn&gujJVfuk7%-ZnDF{_*p;e#M+wufO{-bfAo0FOnTv$BFG11wTmt!KJhAtJ-tisr zDPp71=fvp9PXx(_YVS;ct`lY5a)tsT4}zZIO8T)D32^)f(xPCmBMN8zSWmNVCJ+QW z-X6E;A~HN!wmSD_nBX~-(^cn94&1P!rKrSx0)t~a*Y?_DVq3n?EZu*N1jMMtF6cf? zyn0Y7nC8VQkuk}Re8?!4m=M*kqVO@FFqwd_ay_je(t2Jjv)}3`*-3>06gOrGqy|bZ zr#*sLb@r5<_~B3@xaAT$qnu5!dTKG&XV*oX81Zv){?<%*hE(nU`*sSPr+ub}SkzHj z$4P5mUIXAj?=og^!U-`)-JX~cyo`j-9G|+x@`#9pdWe_7^m>WMJfe>&5cOgDC09@rDmf0$_f|i2lr)Jou{} zz4+Z@lVBFzpi(>ghq$hAYny9<3UH0H7F5pgBANI5-zx_A(f;4~KxGny^LWmI{%5;i z2+NA|_LO12iL)tuywO!$fcH|J{V@JRta!oopJ=@aicOO+W)}J( zCA$J}%If81zO-R*#bm^y^069lD`fR6ZIediWJZYxM^A%u50-Xq|4)2 zZ})#H4#Mcgok*AaM^sSl30tpnyVJncA%=tB&IS5YtYJ5{q z1i)g00iHhi=)#gL5CGf4=n*0)JMA5*jKANX0e9qOI}_h`eJp zkrM5NG9L6u#Oq%{?oXvw`)-YcA=#S-OS@x8^Mc~3mp`Gb#oz@;S@J4dKuDq2h4*#TG)K)SGI_v^F=&65!(-N8n3E4Zy zhmnI}Dv%o1KbJ9LddH4sCi>h~&WK`Gay#Si_j}Qcb9^`0^F{%0dAx%eV|iZOaMBEZ zj*E(_l{$f^EuSi}ZaLz;gQt>@6`0~}n)t((4np{FB@@4c*dm}!as4e!rVODzn@kWQ zzH+d9$m6037ijaFHA^Qko) zFqX+po;eTAk6p{PysnM;JvKTdiMqHbnUeZesVY88H_NDAeH4e>(MY{D^BsKqfHOy? z1>ljdnzThqv@ke+^)AaP0nD&Tr28W;jzwjiqd)M7;m*UCSJbL-Odn^}jB;0&RKE{hZ$I83MSr6hCmuK$H*A~HA zkx~x+`(hUzK z6}eMl!I0t*D+flX_Emek?*cpAdiP^vSAZ81zsM{f88`}Gp86MAcXbQ2p3Im|irGb! zSN8B7C0d+&r(&|&^AAX6f9+K0_XlL$u@lL6nE=?6H`90O7s`npPkvdnjXuvrkIh`r z!cmd-^VtvdFvYBQFnOp3POqE#MW-(Uy`~vH*HEd$iIB6l16fo!TizmB+KK`L;m(AN z1OZr`TF<^y`yYJvf@Q->`2>`p*<@PMWQYBS!ZaI~xZ&%Ljt56xu)st1NoiZx)=@$r zbe5<+gdfN=&942X#pfQ=ox1(*AYN|%a&VWVKlJ48!jB~XA$rT@DDs!j!SS8P!4ze` z(R|Fxz1*F@D1s?IB)xY6{4Qe&7c`=PKK)L)^y1{Obd3^3x)9)2aT5=vvMyW`omniA zV1~ovs;$3P+!{e^pfj{XEW1a*2 zmUpMtLArOJ)^;2NZkRaRQ|`))1t{qv{`=PpZZVpUfBZxa#ryBxcTL#<16*WDmaxcd{m)nF0iZ|_GczEO;S zd4YYS3 z6RU1}2qKm`)h?;0p?6Zef0HTvz?3-!&xTbfh*bY9Xv$vaW6Kj;Q3%?o)F;*XOz*#MDh1IoOQnur3@_#WWb zM5)1K5~a01z(nP=f$&ieaJT4cR|UZU@jcScJd%9`{E%Os6*;c~>Q?=S+CKUMqs8LR zBZZDA=Yq7M)Pyh!RO7Gu5)Xl+SML5J2Ld9yzZdc$Ary#D7bYu~I3QAZb!PreC1lF} z(JDz-6KHkM0Ny}#q{J4$OI=`ut~T~1InWF2NVl~)NA`gv&JKN_?wBo#`RP6w#9IS&4ST0p~Fjgn#T z5PGT5zix7x3Y|R4++}A#1w3(`X`kJ1qIW%^FVkBKsX2Bx73Xs!Bd5<16&H?xtR!uD zHa2o(e)HVvZ{E|ySOJp|16C5xVC7ak8sS793v$Bg_YZ@jlApe5!sLkRE3a(Q`B|c9 zwcYb>Dt@GxBF1w`V}sC_cJ@J|{v?5xuQ*uP@jcNJwvE(@4G^-n|2uNjiV;+>Y&T{K zy(3ufyicJ+V?>jV=PR=|&k1!YAE$#03keszOr8g`lOyhTo?30Iv&6CSx#nHRmxP$U zPev&rtwgPX?plwXr^Fl5@9#2JwG#RtOZ#EzMS_G(TbS0dHe#dCOh!V2GtoIZ=<##i zCPLV^9W4uQQR1)E-VBE!Wx`o!L4Cq;1ELr;n{H*BFQK&cKmGV_IpU40TpojJdulF* z%yD0{*$J+hmwOZLh!Cmy=^EDQbqSoOS-Q_Ic@X@f&if;_XYEx-?fDyxcG?dqdwdbp zXCx^8u%^;Fr$CgC&-JaYl^`+(B+!hCy=gyCF5Mj^ysReCM)CeE9|cj@x8h>+o;bnL zSfh;Lk0ddLC{C;U?TwoB-`7X(D2}&pSxb9Nw|!R=B#5QjToojGzZ42E=Q~Rn{-LGE z-{DVq%{#v4AeuqEoxsJ;Y*$2Ze|W@}@e~-SQbWW(h*_UYS%H9;1ZO|K>b*=a@D2XQS#rVPc^hZH>oz5J{-PWq3;G{I1s zp|nooYQS!El0zBMc2oPLe`YzsmVTS-k!mB6=edSS=-Uy3#_;jFZ|SwfKeuPy=kMkb z)1B^hmZje&eCn)_;SqNx+<5jx$F;AAD0k#k$5`B3f~wG5|I~Fs&}jU#dzg3%c{o8l zTxHQ4g%`l&rH>{49NS! zYDs>qGwRH`^>AsTg5V$W{*Y|aZ^Fp*)Z0|I1L(KFOjqib5U4e54m=X61tMS8pH%uj zMmQ%a;&@MagSZn;uKgy40+=M59#&A{N38dXuNpc@qS>H?khAnl#J``WMJycG2=&`m z?9s+#XzP7*yGw*1$dWmEvNA#nNp(5Rm0QH1U_S}NXPK$s^xmS-+`k-DaffvzGN=$N zU%1K<*gFWc1g+RJU%H?mu9y&uqojN@^Wp7sKOA*Z&SPBOy7fSiDb#_1|#6#U~ezI2dRHxccGjg*+&!x(e4i9 z#mJ<1?Ig8rIVcz!$Y))tKu>}REM3myK+;eDPu#a2P^gvhv+_VNdT%^GRFz;0h#P9Q zE#-g#pt)pDKO6~|FK~k|5+R7mS>j52&>fJ&epTU<0Vxk! zJN8ucN;^8_ZJ9vpnu^5zeTxTo(!eh*s@e6?yC{1<^L?6W1!&KV6L~Gs3xI4utjWSU zVlX{#KBK^h8=p=0cRRDd@c@m36T#bn@zRWBS~fdQ=##qD&i4u+X|C0Tq%Y{zr-SA0 zd%cKHwo+`dICk&NH2W zNUitcVSX;+tyWb@QGAK26*iqa5n0`pN4g-#lzg7*>^MI;`bGmuP z1X{YT|1#(62lS{@O5<9}I|SWXIR!2+qWzTgx33;OMON2kMRo+*(YL<$r93HX$mNUv z==AOH=uFD8w9PYeET+P_Q!2NM)a!hGOvB!xxfd0dMb8(&sf?suPxc?+`2j;!DvJ@Y z5C_MHLkB=kN@ltOWhH2|9LwY&WCB465xzf!Ow`(6{Cvo|3t+}gy1PQ1;L=m8sCyrC zz>c+2PnKv0dN&8Vz+5+?YH28p^L~f8X`{!V9+*JR9k&?~Zv&dH;!8@(>IQWMoDZKI zeF?tv7_6&%eMM&JW|zeKR#A?d(lGrhZ-25!){^&j9ThY}UXhFh9{08<;5 zF_ptVL2}O;l~nmAc)n#Zy71>Cc>Ftkx{$sR-9K@b>g_@iYM#4#UZwIOdU`bEB8TrA zG$15s|Ash<8ZIh)P5(52*t-u+CC_)EP@Uu_NT&~7XRkLR}0)jCa2@65?3tI#arxb^n9z}>qYZO=kauOrq+p#?-nU%X7SVf7;6V= zDm*J98$Jfa2FxUX?F@kr>bkf2j=n^{ZaKaAxLXBOrio8#Z+8Kymg!wax+Pl(@rco&$~3=HX)XCc#MP1l1up(H-` zjVH%QdU(oIxsLhMXHn;&*)IvTjUeHGK%L=lA8`F4*$tYJc=VT=K;20b3XJwbo4ePY zL3&}(SeZ}+up7{r@K(Hu7~SoEu;r^DvLmvq3CJ4gHXe$F4yI`JK`X7{LNJ;(s%>rY zmH~#U>rd%BjKFf?OuLeV4q{gBE<3?Whx8iG2M*f!0wm}5?%%+C-7F2Z`A8F%dwS?p1Kn8_AZ_mSNgpi&3N3VDB8n^J;BH_EdQn@=JY zWKcK~ZU;W-2VM;Kb3t~YMeBwqg#a~KO7bIB1>h00I!4|P(QoeB-v_16qgb&Ky=4MK z^LY#_jgLt4^tz)oUrsY2Gowul7HbxC$@Pdl(e4nk_E* z{Ngf^xmMY2WSr{8tBJWS|($(nc)(13=ht6j0onIu_6gf2eD$EW*GlLjpnl4B zijWCnoZEjTC;8tJs;+&2*Sl#!t~yxzYg^=18v2TORVhQrE3l8SnN6vtS^I=o z^T_0Cu>C)xCRGsk5xZgHernAy=lecFzN;ila>+Ad-Rr1TM-N}3tZC)9<@8m;lk+AS zidpjnR9b)U($8*UdeSXtcC{kHFbHT-Qf(rr4}Jb~BW)O{wM$bMH4_LV>D$*q(S#psnExfJnRs<=9wNmEs|Bh>~ZOB`cm#zFv$EkX<9D3gi~We*5wQNn?d)SAdSJAZlaQrf{JB{YwHh&Km&z*1-HXFc>KWT`xBu+x6=1@_KTN^HH z*LK@H)PWl*_}*Nj7{pTkC9Sj_eb~uH<AK@vpTMO%sqcBuP`_`0L zGtA|Vs_MR-1IMXlx;Rg#K^95xTuS;$IC4Bs_O{*|X#co~j>4DtKUdcs&-M5H6H%m+ z2H7)_G)Ph1N=C^@NajZxA}bNe7L^srmOaW=w!G|}Eupe^Rw$$KyZ64{-+z98Js;=Z zbI(2ZzV3LQ`&!_o=k62cpWlOQmgP+r|tW@7hAx;&YVYrVYR?Rol8(h6TU~8 z=X0>@+j~$l%0cDT{00Qe4Vj-vYzCQwU3Y)2wt}U5f9`OWH3Q$f2IuvHTfk=e*D{ft zTELl7rmtpZ-C%kDtn0(oPe8mW=6RQUJCJ#GDJ$9YBbd%TED%N01Z358PnLh}0Us{_ zX;~k82aQ?pV(Oi z7(~KPIs9z^`dr$J_xKyY^JAJt3n$tLp=x7MUA{iT_OI3nlawm(`{L0;HsMAfzoDtz z-nbDQSQS2^F4F?)(}DwJJ~RT$tu}o$u5}>mmcdx%i)z5(XP{@mR0)js%xN{Tegqr# z|5J6z)2+`Xs(}Ff0BqFXa_}X`Pw%@C z{9pFoz?%G*rNDBxil^040yyf9uapedfGeh{|7d?!f|bDJ?FmH$*m=^sPL{6}u-gE$ zc`gD-uqTXjHq?TKbod#gkt#5Aq~r1uCxq#IrC{9oI@`;dT99lz zNTsV@4PHBkSMR7O13TaO7>}{R`rjOLH{B24CobAN!^=T{B~6!^fs>`cgo(fZElV-z z@ynZwf!~Q=6nmomsxTM6S8}m!=Q#p=FudcD@D~1;{NQkY@>&sCV-Za;h|dF?Z6(Tf z)8&DLD^4et;rr2cLet{^!SB_tDO3NubgBsGzi!aj^ePY3TJ8xK;mHG%H0RuZaF&7` zJ4dyfsvp3u1A51)rwYN|6eF6ptUQo*hDu*gFBhz3bVN45_lUmA*04*ABYmT<}c8(}d;rdl0Rd@H=2C8$_2p`*FuQ18~rQ8)x%UftvJ-ytA3P zfYn<($(#p%|DGyD#>^=TJadecxW4NRxJobi-w(A!u*TgV{$qD8*!SZ&hqur>FuiDR zZ}%z#R9@NrsFsZ=ELxjErc_sXC>DX~&Vu6s=^? zT~TnVM>Q5~efgQGYBe342q`r!W_ttnvN&A@_F=%=(eje!Pfem{i7L=l--kH4SXD$D zkP3i#_sYcIM6h!?>eesEAP{`zRIY@QJ@M-AgA*sRgNW4f$)Y^zMDSfwc&X=VG@z2c zVteqRE0DOq4ea6ZC-h6G-<0=75*td!08`XSWn4^0)}(n&q(x}gE}e$YA?1| z#Kk*{nkBztiJ5%E(M&_=r)cW21&vS;tEcli^OF@Ai|AZ6@ z5g#97m{;paOm`IF|M%6u&?^~4&To$6mm6{kAJ&~xbutA+%HdsnUrU0B%4O3IL9;kQ zTKLeyxL+2L;=*d2C7n-5)^(N7$QKb8H}EqWtVa?R_r>&QHIfOV<#+ED*547ob43^% z6^n^q4gB?eE2VJ4jTQPFk0V0;Ol%sM(+Ib$yYg(>1;n%5FTQVQ%ZS2lpDr=}svtJ} z?HfLqpF}L?E-D;{|DRa7T^)X1qB5TTRB0vAJS3FmZ|(KPs-Br#xYHIr3GyneZ0VIx{kc!e(1 z%Q@E(<({usVn^zU@y!KS@1-;l+ipMkJ3P`zoNl-*I5N>hEY0&yr8G4WrP9yY#+sW5 zdACdUF87)VuE%5P%L=W8konv{>Ah_Pk#k_SL86Udn@e*k>1`&s_tLSKDz_56uYzY2 zTiS@?sr!P7Ywd(&@}Z}jg*yl%=8(c=_#XYe!&Wh#oi)U-?I*5D4?@2`#h&F+uOa-c zt%!Ws-%JW~VR<2S#IpKZ;!biMu`$my=c#)g!S*CAUMstnh&tz=%G+2&%$wGQwDv+i zay@j~Y_N&=cytq2!|^5}_4?Si^b*KxmWCrQKdvW^?`E$L2W>>p(Yp4+Lv2L5;rar# zV=J*(JnKK~&`ik7i>*vXHxa^RT^D;#bP(CY<`-`NYbTWMdEWxR+X(4{jK9InR-$kC z)YsLNX5v@C9mY*hs)={P-%nT_t|Yi3G#^iHDJ59@CZEWr<`Dz+pMGnwy(4_ie_*6) zt|2`2x46Z+R1xK8rd#>t%ZMvaSOm)(3kZ7oj>uKIT%y**y~X@dJ>fF?@JHdPS|TDW zaju=dl4yR#X+ssCnfB2sH)2ccH6xVBp53 zaX#e=!aXGJ5shal(Ua;JX&IA4JlU{D|0O7l*z<73XYj5#$e+{DrS1v^2llBm=>JUs zsegQDvs81y>e&}VJr@c<;`Z0N$Fd87`@nZk3+rGYU*F7gLMj1drTG>e*`5RF80zPJ z{R%+Uq?)jEa51n?ET~Bc_5)4D$9?##Vgc7tV&7zIHc)aKDDO%x1k#OVDWUMYXiehJ zHS@N>o1O~iJXN!zz(XbZgY#55;Mk7{j=QSGAZ7O2g;g&C+@#Mh2vijS_D$~=AMu0% z+t9{(L5pmVFCu+?Bm7=UbzHE`qv|ri72C*Pz)}QCX)e=&#t(pQXRDIz<1$d2IDKW; zXgTPknc&=fpb9WWa7V{D6@x+3hA)C2KL9Q@QAL-3Wx(gup`Wgm72s9U-2-y^@PEwg z^S0)dAHY=g&d?v+Wk5h*rT+E>_}}NYFZLhZt3Wor;`*nNYS0zl-T5qt0JqFjoXyXBmNKlmnc6q(#5UvXNKjc^5vr=~Wn2Gc6NCr|FJ2JmHA zr}ffG(951Aa;v5SxQH?FT@tPbet8#pS1#29{{IU1W?icT5>qTb!}2x2Y^3Pp@efrX z$ZGq8F zxR!fK#uJR>dkk$_yG@j>A9<0x)_ z+5~;=(Pj0g?}5Nf!SA`{Y%m<~ll$&?hr~AV@yK{V`^FTHPnPC`XW|OkzFSkl z%QK$a#QmXCP&Mo2uO<40r>L2dJ14%hM9{(sp^H}`kcyS70C-cn5M&d1z=Vr^Pcg7S@ zyY8Z$KKg*TwVT>=O=VJ^^xi(Z6**zqZ#2-=R&4ds)n)v*W9Zw)i ze7HZzs-_Ty&9!_SK1oEp^g(}Do($q{bin=5;B10cSS&sx@f~s6L37{ls`mu-hRyn= zx^IawL!~##^XY^eUBkcUve^W^aDro$)H_0*>OTbY z2v^N%qdYbEUhZXcmkU}2L}ht{<)(r{cs(>@w{W~8n9d6_EB<;}-j)$Egu-84_&rOG9Zz13nG_M5OYFt^h$lH5xPzEo!`qaI<3_ zY%i!Le$cgi_A4tRdU@V73xz^{WPEjRxN`;3`ziaaq)|1YP%oJ#MN>oEpY&Bu|5!?F zPzg9z^0XaldwPFEAf$D)L-2WyF-dm?cgWvU6~@Q=$qeKo|k@v}x-xvB{PDgCI-Vp!i+ zj=7=xwZ!h9f6i#_uOR|v1AZG-)DVkC8ut|b)DqY9T&~-*))C4#;u@Sf>xk;`$b|Zh zH3ZwB>l5d@bwpsOd(@O)Bhk%nKmN<{BXNB8!;KNWkAzb>b>z#n8iLQ6Rpe|}J@L(N zbI6ixGhwsZ=xwyvLAVS#+go{d6Z9^2IX&O&2s=K;6&~(dLNJ>TaKyC{*1=3dmmIo@ zq0PO!bLs|(cV>NgW_@EImxB2e{9pPDiv0fn<$s{aNffN2USDIZSBm$xSKBN9mb&z8g#6A~X%^e3N^GT$u{1MiSn zX+fd{#l9Y;{&+qzoxz2~AUzTfx|6v1Jc-QxByPJxV#G5NB^5}_BuI?eNTNYFiFSub zJXuHLE|*?BJ`UOTVEpI!1*7ymG97f0@{a?bak{J3492VUWck)k68|KV`tn1hK2>Kw z)~m`VKc<)nieINz-MA;#aQ*RkCx)|+sOjsdxCr-~33ulU0$JO;Ry zw0jYL46VWX4zh*Vj(@l;mKy`;%2ECupEm?T`J?KE2pMu7;QV0bo7lc?rVGZ{_KT4y ze}7&vw*RMX9otLIvn1P5#s;VO7?}RMg46j!-7(4p$-^aK45UmSOh?$wRJ4dtU@*$e z9O4VBbAw1;a~*|Cz!+fWc|DCV#gEww;j`)A3wI&Dw|v$moE@$zAV>I)EWtkGis*W;<2B3qn)T8rgvKavddTS>$3#l#)Vz{Cz;riPE$5jeaA4eP6ut_Jg?2BG!)T|GdwD!fyFws7 zq>HZ!hG?RkV; z+$Z?ab!X^oV?}b|hjtdExA1lU1%y8A$9WMBsAx$dJI*n}T1d}+&(TqYmA~k=VVOPm zKGGA>FrGsFWidSe23^np>Q9v-`Qte28B~w3<HHJpT2?H^HqMjYG3igxOYIxE}*QvtvC2Ih*e&o$;R@ zIlr&)MIiZdoFd#Z$H4AiDndxkZ(a9Bcqnr362iq?nNJ8e$F%F?d9Za~8A1(p8cCGy zTth>P@ZpAsB?$L9H%Q!q=-q335{U;x;@cQrm;5(}<8>tEc98Sxgf{@3q5&Nmfz=CnhOckyta)R7H3iU{wr836pPCuBjUReJa zmL>O-`&$wXxu0#Hh{fq6-ZwDDJ|g!)P%(n#H9m5`V!hab{Zz?P#_RU^`@T3oT!+*z zG$HqCiLT%`$j@UZAL4$n5Humz`}0${|3ukpa5*+7av!dFL+-CyjO2dkoB#rdgy>q_y9jEbqP9LV=|JwPC(vBPox>539Q}7oB(<$x0Mj59e|4+Y{qBlpuumG|? zSBjoB#gB1HJL=rXd};?0n<)KYNNN8VML*1r%>PIk&%Y?VUhXcLewT86N)<_YxRt!# zsrsZ0H*MVR|0wfFD4vwvvdRAam`BRR$4Sh8Pa?G-iBW+hU(JjpWrGbQ>dKJiAF-3X zJ!|n3u7~LlnJ@H*^h4tpDZhG2%1Z;2SdSr{lnF1=&i*!XUY@BX$L$s~GT*m}EWgM` z%9-BeeBDsciS0-y)MK2nBh#slk@jYsNPDlvhH*Y)oF1OnEeFVTLwal)r<*1c7=<58 z;rs`eBe1N0^gG5{&Ss1{YNX#<8)>i}UtKF+-=Zf;|Kz$pV!hjseq-z~*2d`fLmBJs z-&KO;f;e)0*|^^u%Toa_u)SX+QFy&|oQ}t``v-oUFUeGmWg%uqEa&toz|eOLyt@7a z%Pmx~*#5PNQoR0p@%yEr{JK23WQ1a+&v5yC&PA-(!fTAzXK_7FTz)b+x&`Si%DCbE zFUpY(`;o0ThW9sNnZtPB<+*$o+nrDk#Pv{ly~g<^u7Sm<{78axCPH&o>bD5#KSksE zChga7eT$`G*bn-zqF9ce{VIj_yC*^^AxK~F3oYgmCukS&e%K~@cp0V7){S%`{?nXy z0Pnv$Q!KE4u1w81%HPW(%7k!(u97n1g(`l%xPP>#i*bEydp6~0_Z_Ppx z&RH8_o?>wCT_2LA&K`9|NSCBCg#3EUWVZwHib)ZDHzc#&uib?5Q?}LzB6(-`qzS6; zSmZBmJ&1c#-IYU5bZw=jP*c%OB_GU z$P49T6Ea<{5Xr3W=vY5?eXT!HK5Yg=&jrhy%M+Z*DLR8TT z<+=e;l}6=8%f*{8B0=LoP+s_)n@uA4*GG-hh+_>GaH1wM1IFE zXl~;FJO<8p+)4=Qf#*@LA~#rmh2hcIXHj(%WwPiw}(} zkBS^=H;ARBy}YR0ucU$PXk5Q~rE81gptY}Ck1Iml?cCNU3-OG{SSlKq`PMW#&Jfu& z?$V)gd8%^Diynv;!>)!X-a90kwIBvjJ?Hb=LlEQM?4wD8xG$ffWEb>Tt#QNKT8Pxt z-A)BC{c~{O^mo_~lE3J@(Ky-_$@&k?r-yOhn$bAPV6uW#0_N8gte|nnpcYz!{Pg-& zkbv4JGA@tT75B%3>ZpA|R^s;Px@~hG)OUfnzJ=i%iU*S}DsrRva&HWS4JyyKoNbKs zikkDUpmE^N_xTl?Cs!?5snB)(_2;xGs+U9Yuqf(}w{w93^U%)~7x_a&5PPd)tslYk zq5oPpq4?J9&9_r%9HdxYn?ru4C++1y-2rU+Rl^9ti=YbDel z4lzPQsC@^`Vl9#Wl!RXm())1cvNJ-dtyY~Ve)96zS&Q^}kJ0Wx{%TehA4ls6T~gCV zR4!9t9>*h}%d@cG?1e43pHoWNv0u+8-7)UnN5)IjVZnG`0I#3o^rlgJybfPsBY8Mo z3U4KXRgY6Buklp!2UiDEx`7-JzvH6?h+aA5ON(@_Ua<{ad{hZ zzt>xi$LY>7B%k)$N$Q6`CC~e!!>F+zf0@r>WO!YL^@D9md(S+7VVQa=`yKK_=6nzC zzZP4vKc1c9Z-u-HWu}_<_`;9wp01QsM$R3NM$T#4&vo-oAs<&(A68 zoRs!zQ}h)mag+5r>Bkr)eT|~GnSvdZdZccX^_EfMg<6XKIZC{^P(}LZu0r~|U6qt) z&ybi&>Bqg>$@(_lCgWSUsNm~RsYBvgDv4#$q@4uHcn~os%dJrO|2iP$h(K~Y1Qe6! z4hpQKyyGC5|7Zg#M@y1&#w2+z;O0!)uN@`pqoE?(msd^Bvo0-KJbt7I@*JbkmgM1d zg4NjHfA&l`pMQHAM&LlkA^+0J>-J!VoX=;~$#M8-pcaqMJ6;q$Q!cYF=PXz1aE*PnT9R?LsL z3XF&oW~6Wv zraQa^HwK1lj^X;QS^MGhKKX~Tk5T&g=Q4brX7K!MIFhf?^$j9q+rj+^A(vn16vFK6 zx@NSG%>MAf=UC3G$sH)2f9cr^go>7oT?o^^?W96{qVix~1(IJr@+b=i}VLZZvQ~opz)mxp>vV^dsMH%XO2K5>%69qMf;d%a=}ql zo=$J>HR1C5u|r`)>#!}lR7oRVV=50#5>0Br9MJ@yfO0RC@Rk-Yu1VE z&GQ!bqW$tw*D{>Ske7))c#U|lP5Ki*l+Nw+rU~i2`08*5+3RH*_C|cnK*#hqI-frM z^wK2q!~Wa5b!68yL!OyjcWs|0%;%9YN!bta-$HZ=s-G?Q*I8r8n*|LP zxwb(4{5Z|yD2^}?x}%Nw1FugFm=g%vM z4t_ts)O~{cLE?c^V$j~9izUKNzhHbZnb;cxd9jmx^7aOZ)}ht$Jso4drhU<)nGo2cszAr z+Zfn0_Q}Gr1&(L-vjP&c@ErXHVUjil@B4(Ch+NEtu?mdLw&b$Y76A`T37q6 z`k>!q4Mq8EuwCkQaTQz;YffgxY#tc{?a%*a#0|i4F0uNNfaO9=toc5`d=Zt1+rF?} zBI8zLjm>cU(yQw0LVqJqoG_eihj@1>^#yF-w{jh(kevR5}hUHltBud<;q5g}Y zoQJSonVJCxEwDeRjjyolLqDw4Tt)9GjRQhcv%On!91MKEo#HAu4)*7KIH|A(`SG}b ztS{`R3MnO`5Y|t-`tj>d=ucIP@~kJsCf+!fA29uDe2fKvSgaO*h!>{oo)7OffqqOZ ziS!A>^fdO*PnBSLZ2XHV6^IY7Y~f6V*Z;K8Nah=uPu@$>8_qbfkgShw6Dc>4c z-biluebf&kze1-kK!3SiPD^#d{`tapz4I@#N>cQ zy{|2UN(=gV$7(b_5Xyo3j`^YZ!T#jjLli&kzWi?!(rf*BYl$qW5RtX}bhP0q9^fPz8-7W>fm6R~-_3F;Al5>$>rlror8Li%3T4>C|3Ku1dzhET7o3&#&F zY+8(HecJm|a16&s|E)biaZ3w*#&5JvtmuvXLioq3cMh#zp`RvqDMJj|`aKG@@ALJX zO0+K3Ge5&|jYz$n57O(Ke)SpIz1VozOb6om+^QKg{|?a~$NLm9_~|TKFE^Zju?wvS zeSWUA`A`-~89IpUnszf@FogKfO#Lc~(;Rva{6TibcKi!Lm~y5E^ZT4KB^>|kpAp6T zQ{Q4zEy`a>O8bit952NC-1%o=ct44cGspUt{oQ!qF%w9XL3%@MwfKI`*(C#veWeS* zDBaQ~mI}4cL^7HS?-Rly6R1C;oOXOc`91SXN~oO{YhIJ6eO}8edr&;h_st5Qe~I*% zZ$Fcskk4C7ke?kU{2YN_y68V@;-l6?>-!-b+D@7{asvD0_&g8 zaKrm?%Rw!yf8>M*-miy`Ud8+M{9|RTuMix9_s4h28?b%upb;G3{?m1fLw*~ckjMM+ zT*x(Ck6gwB%sWDFS7)Gh*4h?dLH??Ithk5tTOTB}BDB!5A$dfmDCQ-4`PLY@!vA30 z`jzC7E{{lF7aAjn{T%c2!ujX+lJUq_-Je)C*i6Ptug}tB*;|AW>-#kqVflwdCC2@F zoVeZ1cTeMUy^6jdd|e3v3#@iXBr?8h$sze?@(q%oW<`=bG}f{Z>)F(je9=gsjJwv;NZwk*L6(~^5yXCq zWRvMCtEB$;f8=?#$pV>v;)E@>*R@FA&)fQ&jEBzOB6;O_%{b0KCa;XI z!S*>9)3EH!N&1;eiC2^;{Jyu9^kyOpM4D?^RwhhY&b-s{@+1tH=1%E zK#yXlq?D{jGJ22ix)7OO^^C-8?@4}aP1TC+i2P2)*da{z!?Y{e4;t^u_I9?C z&SR^e0qZPCxPt$o!7|v3?4kh=`Ooea6RU(WOY1I7^*D#g zdJMhl<2+mepJFc}}C6E^gO@n{+A! zBUE{_j{ONJ3*tig;w?g_kY5q8T^wk==M>IKL~^fz5(l#19+i=W`1HoCu)SzKE`Z+? zKzz5&=qd*)ulJ=#6zRF{Q+|ia-}G({Mf>jCj|JSG5Je}S;(n-n_Qx67*?(bA46<_| zWmXC4t6rQ)y$aD>=>zV!_+9n4ke>CP&h6-YEbpX?J>tE!-*p7kAQtCb^hfJ`PA5wm z;=8Xb8fpw6-k6x1MCYN8UH|*i1ySX|2@S;a0~(5}^dTP1{Q4K^Yt0#mg+o;D`Iw>v zc|oe8W-;2QjVDdE@IcIb(aekZ5?x#RWk;BAp^#;w4td*EHbXmfPA9TZOO5tx<_GlW zP`hQnJ!MURSh-R)X9)Mxf81Yxia~jCFl8+pB3q@x;5LZ&Do--Mhp2w*Y|kO6w{K!p zqz=ks=Am0RLOdp|ru`XWUFf0pAFy7X#!a-ZVZEPyJw4F*@?AmZK6jYD*#y|zL%wBi z%6o4Z^66;7iVd2OSKZvPp9S%)vwS?Ks~`_EO5bOd3i-XUl1tYzxq0`nD5~6SDX>%(@p>V z&tww%FKV#K7V=s7b7wZ~wuO8};rFi8aoCUI2P3z@dg2cbN7=)8;fb&mS9=Z|ccM}n z&vM3r7yHirB9Pb0a9;lO9rC@hu0sbDV_-Z~b?D1n=OhpiG#ttwp9ajqevc0(!soT} z<@a(I!E;e3or|lF$3cc$B>yGO8SqYL*G}Gz3U zrPc}XUmOR2mBdG09UTYN?G|ExU&8xWXTCRmcmwtMrp3QL83%tnS9aKc83(%V(|>v1 zjRTL-5vi5*aUfMHwmB<%0`Okibm#bqNx*tGi)P7S0+e3vS37%d0*I79&9{}C2C4<; zmBK5g0B>B$(X<1T;QN%U{CVvOcuuYs(y(s=Om8#OuWXqHe+onLPe@FG=at{Zl6gp^$(jE`bX*Plhh{-FP7;bJg74lXv?Z*F%T2f_~mR#5!oZC6xq zP#eadx}N-ZxZrrddrY8kX&f{z>NQ*583$*o*EZ_I>jr;3;G1|D`juWTCirs{C|uaj z`TF}9D4!c$T2#&X#rt>3aFixiH=Dwo<$NOFh*JJjOclY-= zH^S?gP0W6kHeSPjNUp3TmBv4sdIYf^g|fdOPT+yOsC-ZE(IRh~E5p0nP(a zb*YbN{^qB)$+NvgDCLSuZE2hJ~%)WEQ$zELp4{ztp}GQ3YE=4LVi z>z!ItJ7t6V9aE}DzQR8zyFb*M{!IDU7R!82d)`^l~aOfEikm?3(>9MvdwP2qTB6q9Om1ys9B)%4tvG>DY|eR)YsAnzJ==r-Rb$hdZ^Ak#^-jY4dc5||FRt{ z9Yy&J2Q_~ow7w>e&;K-<*YSO(JG=Mb_-`Jmky_h?l)kywvw*>S1(=#;Ke&6sB z%s(eabFi$rLdHixyb$xp%|2W>y~&>B^X_kcVOhNC9mbPhlej(723s*YbddMeSOwN` z{@xT(Y`=5Q+$&Unz=9sGKeLPMhptBwxZiZQljq?bYfo^z`1&G44AQT>X@>b?NWB)e zC+)Z!mv40zACv1~FPDCH#MB6DA7eBGHpl71?4lW`*3EAn~ypKj~89Zc7H@VL-TuE73E z{3Oe(gpqN_%N>O{eT$hO))#7B#B#`C4~#piWU)V&Rg*F99ahEtuy-jF=btcP!zh(t zgs)Hb)O9?*TzbXvxpZ7oCGMa9{1_j*DBM>bPbi>uRyDub6V(HnA-j{!k6}%k3SRS0TP}N`VV0dhOAD_+Xg}msS zVAz9VWhh_T%!1Bs(-W;)z2N!d)vi-Z+u*r)#~+DkZFp|%ojNB}2hWN3>Fr#*4ePO1 zJY^sc^}^PLj;}V30hgf@mv%6ZgL76hT9VY`fcyEhG{Nxe!O<0v?Q5f$kEO$X|3W*@EG+NH(<;*@v;Yj*qvz1RZWy`%r}d1(c!8@WTI)NAe<8~0lr{ypHrWVCKwfi9bZRS?IE)jlBd_|~OaZ6jnZN() zzk?)>Z3ox=C&Bq+BY8It!2AhK(;&#NW#YO65C5G72V@oQKB$}q5hGzA6$PdN{7H^# zlHwHT(Xfq`+cXbmIJbH~W1a=Jk1g-hhHY2)0b$3t7)4f( zfb&5szpHabz-}Qmr#hVxz{ErCa;b9|Jk^#IDbE@P^QLBkB2**5{rJ_efj`5*ndWq< z^S5CTI>=yfPIwrwMt;g%%pL*^0!tPyL9kr7uK%dzFxZj3yD9F)FmQ@7t$H*z1V2vo zF_T??2*joSG+Wjg1tRu7{->%&0pHeJtVwBb{Je47%nR?Iv<^oVe23$Rt#9_y&rc(u zH}&YPbpBCL{8HhN^;I}d#(poYtiw3!N(l~Jz&KLKn+beEpKFnrS+re?Sh3%Adz(08Zut=-ZAM$ah4(RGMPt&2FsgCT6JoW;7LNb)ullRc;rvg&;j@J9Pwk=j~cd&zGb1YVVHz!zMKtWf_PDycp?eo6r-c5_d{U2oNhiBc?SDo z_-gkmYUdw;2kC+fg{{M~vt zm;tUQO`Em1RKqx?n_79O7N%e8b!I&X{l4<;C=+^KkWFH07_H|ww2h}7AzJ9yv7!BJ zN<{M{+OJAJC0QW3WAr^3?sLEYKK>FS zH;=b8(y!Wm`rK})H!j3?+Xni}?O@n<5T;LaIPxO9kvx8rp%DGgzH_&RXmY@114_^T ztiBuVn{|`H`1!06BTu~V--x?uh|>3pv@@dpP^Mqk63NS{N`VMvXeWfxKI(ArmpR%$ zzWdSR_~p~4Pj8Uj#szs_v@gCJ9l<;}Ji4bE$#1ziPu+m%EY61gGL@dWi0q_xE5@Mx zuUSsaBn)E6U0s0W=rh-Dq5i67b-9K75DdABpBLP4cog%;7c@qgCqLn0!hHSFH2K^{ zhD|2sGe^6Njw1UHH6k!iihgqzKkuO6W{%G(!Hzkc{*H000Md&o*bHCkh0ohM{7pdZ z{G8>5?fMdu_}owK2RnSF7RFcZX$>g4Bu2yb>Jhagx+KSUOXzp{P6LU*BAp# z&Xas{j(q4h zwUZChk)NFB_KhQqsCk3?vBSv(_k;hyE?n-*%^b`h_Y{k>p#F*wRK&8*f*|ITUaa<5 z-hO<%9NC$;%rT76)tVWn7pG`oewxqv8J}Ng{d|D$A6=CRJC5uLEau_*Y8)3jP`PC9 ztxgE5=$~k#{Pl-hgV8us|GtRhH~Cr}T(7}uwFARkcf1+_0EVsN5m8+{1 z!gg-I560)=y_0O5NYBcY!yNIdkE5OsQ2CM5fqn>0j_k$b;uF<3Tf_%n9^46Uk-%{& zdkV*Gh9|->KPI%BFrQbeV8`dx*2>yLXg%0}k`3SgoLCMCLgV55BpVM(XYkmxANe&l zb@%C6h=h0S24ugt=;Jno<#$q}(7d*=+b3}v;$vQ2TJ&7C&Y{*R#Amy&>E1{F-O#>~ zg6^}1j9BjygZTDsY@H^=UzzuVk$tUCzDrLaipt&Bkbo$j@^qUUTpym92KyGl^@87J zn<&b62{xHP=O@ulUJ9sQX4#a00f>^nDvb`ndao_}v0R68vbrxfT0c$|?-D`h4i9}k zU4IJK)lXl$4fWu9`Ay~KD?XUs{(8%od$1nn)BkZa!+g5TG54#mJ_}1Bx9K0S{nYh8 zDxseJb={k)P;a#`L*_QrQ@(m+s15GVo5arrr!2txi?6$dN?#&V#Syiy!*}`RfVA%=Z0|ubl~S-?cFh zuAf)M!Z~3*RJJZLL2zG)a3$=$Aus*1Nax+QbsT&PJ-FR}b{wo&SDjOzhVRp6={3wZ zL4IewvGx(%_qP1*mSlyzbgPf7zS1E$o^AU^ZQ*kpL9sFUQH3yG7~E1LLl61rKdET+ zp6A2s*MFr=jeu481C=bWy^%A)=B)5JjT^O%myYw|C zet2H0W|A8jdwU%8A6`w9h39~-JFER&-cEySG$%aYxc>m@tBFy{>f>OzDSX2Q7WiJI zElt*cS`)yw?!O~OQ43(D^2E0Xy>lSdj7eYc-6)_IynU^KWjC)86*_-BC8!NCw4;qTy?d&Rf0`}5#Ss&%Ai`y613*QJ-*JO|9&&mHm_ zm;rWiyi^@LGvI3yJxjgMJlOYnqu33Hc@S{=R)CE19GErcH;+-B1xDVqmYZQa*u^q4 zzFwaP3>LQf4NmjmzJTxbsLk^r_M&Z9f7~pnQkYt~=rId^o2uv>O&bQ5apF77oQA>e zYSlFASHocBx7*vM=^>D+s~9_VV+ick(c7`ZWf&N}R1&C`7zS)+_d~re4TIU@T{~@R zhJd)RdHm)RLm)+`!S{a85ctn$gM3ut5MbQ$N%OS-5a9H^>3Pa%2t2RIDXHrp1P{MC zglFmv0h7!B3K>O)z^2N-uDUyh0LT0Kibu_ZAnbR!lg!~k;IUDJy70;n;O(%`DP0)^ zO#h|P#V!m2qRHlIrpq8uNI%ZD&^G|b*A*RA$TwT$dYxN84}w0M#}b;YLm+tS`nyHW zQBXZu8u9leyx*j9P)|d12;3pELvj=b!CBdajRxNb!M*wm+f{T&fZTWLJ7#Z3!6dk~ zky?BRJg^8&cJvxfZL!(E8VrLYsncG0s{L*A50I3DP|LvncG^McwlPJ-Lu^Gl)ns$9^%p-yq|Ex2Cf zFV|)iK>j)KTY9k+u3z3G`&S;qbxG=|fY*1p4oGCY=o+@NZ`DKIq^4|w?uRvn9W|_kb{}jxw^0(VXEr}v zrBmVkl>^%}#J|Dkv^EmXznS4Vv`E@#g`aRe?R$26XbI}~cTIPEhH>+zEeSKa(2ukL zwHBLJxKHIq8GeWL-*WC=b%y5x{Q`>S4bU$-?;6_c5ZyH6%}+x8&b>NHXdk;Wa{nIU zpH)k0;VIBh{+xF>o*&QTu}A!PE0d+iC5W;o3od#J+MnJO>zEiqKX>PRv9yNm5|QQXNBd*hmkVX{5MO%iv_$(HyQk$? zDD?ARz53zmG$FlFN6~ z65996;$Ch=`{==d<6%A!Wh_5#M*FF<6x(~GXV1yzjd(+!kET1qmp{Y(L?Ip!HYz~n zXM1n-pyzasX=i&NUf@EjfuEyMN|GL0gZ@mr-}E~N(>-bY($KlJ;*gRJ+TZI3a(~{0 zSj{NTw+~|Ffm8CRf9Z-1#U3M!dOD2!-L9}EjQ0CJmO4WuE4?lN$lv`3b@4gda>)(M zpG<_g@Oj~7A2Au^Cvi#!-$!6CxPZ^s9yt8O{MFZy2lFJ!NnK&&KV6odBElS_pEr@+ z+>#3N-0?p>91p0?dg1qBOw9BHkzTZjvIw$I-6+g}^yfa&V}9M4MfX2REg9B&9K&9))`x>IBtQN6~usW9*K zD*lP}z;OnA{+Oxq-x|`3E#*i@dW$*Ru>G~+PPil7h2=n#{&Lcm#8!wjJf*75Ve+|v!U)O|Qqj7i+OgSKX z2lSbrqvr}b9?&R@L*(699VPS=a7AY!XJtu zzT5fn-4%#Y{rPI{5F>*g3!ylcEpp+?0f?C?%gi2de$Tz(C`3H6 za_ttEM9+JE8lE^K0oS8Y#vXMPKj-lXn>>f;`^IQU5F(FzkaZ>0vk*8g^#|JHC%2tv}A|oUrLRl(XND`4GgbG(DN>dYLLy|Bt!y9r zz9nltXYS|s{Plj#opa~ToqOk;_c^m!F`I@!oWtbpkAag@&@Ya^R5O8cFZFbNF@SOl zBlbjjgWLrweX1{G5Z`!be%}i8Y)Hr#vwG0S=aestg+SaT`w`RB1JJjwtXnmhL7wtp zkp|aocn>iuksc_o)t@_^sSWydsb9}5l;eN8_O%0(s4Nn zd%%wUK3}7M@E`cs!AGf*R^WerwEHg=BgEtM<-e6e{ZHq}$J-S_efy(_fy#Z2PoJ40yEuQD6R%0bb5;&$`$rxgMY5^M)iQLzyQPeMhprE!#Srt) zBCp`Sla2>!X-82d)&9f)C|^B?<1BX&@ZT9Jp}0RYNbl6%*=&fv(A%*F+_oA;wER|u zIuOr{^LFdj-9C=C=RXjBsJ{T?-$gs0I1Hmyy?tLwu0R~OSIE(=Vh*kN?${KP2ENBE z@Rj<&EE=Wbd#WEXj7%OiiuLUrM==xGwUMXh(ZcxCzqCwqNUGZU*&mTPST|W7%UB3J zIXN<{Uv37;SE)Sx%QcT~#qSPP-!_N-eveh)JUNf{ULhUqR-8c%Ma%t46!S>>?(vxE z!*giHb;rhQK-c_t-=`nXp|~9^t)CL+(4QTV(bQMx&~Z1@gswvnAGNT!tU^DB_GXD` z?Qx$)dAD74ml%M5Z47HY%IrfYOE+sNoO{uCs}zwxz+Y4;_H*!u4I)Qr!4X@^e)QOz z_QyO|AIjLGX;5p`i`1THir@C{N0<4k)y@qMpu}12UdF~=^l4>4_ndMcdUV-+Rl=ng ziSMGCc<9)NYC^Xtxo7mF+#sol$Sr-yfu2qLl|~<0>dmO_9_xj6h%CEQ*o(GHF25G> z??VlThh+co^dXBTsjLaQJ|xO_;0Q^g4;|LBe>Kw5i+W6it!_*9A$!Nt%Q8^U+SfIP z0z)KJ+Av1F4fu;ocrbbb|4rC^x$zO0FViOQ!u$*H!o?jWmuw_SNOy8b{td)?H+mvo zwL_epevj>PD$gjIl-1v{qog01r7x;~Z5cqv{@LdhIu9Xt*N9hHQNTwSPRVA1+?FMl z$35wN=o_cPy@-f@JvaVBmL0 z{!ROpmV@2YxI0=7dLZPaA~WrFi2s>LQCx#K>kt37wtWy6_18#sK3W3p;!~5y3Osh9 z^62|>P|s{C_0^}KC%)?XUZMd#)5Up@js^PNc{i#G8A$uJ$@f=+UOJg}`oJ{E?Qdum zu>f8ndDYCy9^}LaI25qnN5!wX9>TcE{#VPSM^F!e%{TRdP=7m)P_8VHJ9ad%+5@oL zNTH$!>OCE#8>k2V?=rJh!#yaMW&Qlihfr>Jy19@I=&5HJ!ckdJ&nsibHo_p!xZgWI z9j>$M8zl!rxjWsLO8>%h3(^ckG0$-i_{ogxd-;84v=?CW9-~sspRTwnZpZwE_g(5W z4nPVN;>QMGL=$6sITl@#*wvH7sU|tdOvCtFi zf8)C93apQ_bsYo#gZFGKZn^Lg(*1tkfA|4geV&$u1D+^2un)&Ee%7D*^b^X!}JMaIK`;6009 z8Iy4wL`dC&n8&W-P)@{|)?{MNWBVyJ()JhITSv9pKk9(4d3MA;Q&#c~fkfQrU_>hs z2lAzE$MVm1eJAGAvp=tUV+Lsj(}WcK{O+5U2k`Uj>eX*x`STiPd@lf_D{pNl?Dh_> zpSXRkd!@y3`w5MNmE-bq$EXP2qEmL8z+b4H&M{^3`JGK`l#Zmq$HwiZ3dIK>%6@Sk{hVPaph-wEMFeDlJ} zH{!XYhq`^SoIiiS9{fK2?A`<~OY5m2<}Gj-Hw57P!OLvK^FmUXhw%GS{nc;Bys0Yi z3k~r++Z7*-)S+Q_a6a24|1}(^3)I?s0=MUf-oRh@y$h{w?Zo+?zGq8edD-kwZW!tB zg$F(aywA@}@UPJR?L=HGT!;A-uGd<0yA3YKsM}Be0${y-+!SutsaIAan5P>kpWf#R zSXMeYc?z&Ys+WBn{>z^q68&($Q${>+2@hCi3IuVEfveX?i_^RR`v2xiRt zFYL-Fybn0@{jkL`z|$P}*rMTo{Iknm`w1Ymz%HL>a9w6eGzs$}-jQFCj{tkl?$d7s z+%t1=MIZXzb=Ry++)qYaSw7+Mg-?PmC7%K9t`_SXKtGOHv|FMAx&4`}Jwk9@+_tn% z3Cf=owM*xQdV7=(KKudcT2j5y7SIDSweF4i!}mKht5=ToNi$pi zH>?+4yQ@Bjav}^%%J&z7|HOCWPTMk!!^yilEP))CkVKvu=%G}{#CZnbDGu?pj6cC1 z(bqNz3)GLI2hz7#C4eV|8L#__fuFifeK@Hf^pJ*ptK?nK!`}Y|+mu{_?{Z?N#9OFO zszk}(xGxZ&>To<;X>?43APK8t#~&#u4G zn?(bHmz~XT&7zt+0i5cPPrbSIyD^k^o;x{oUF1vxK;)vKPfNPa9K_o2=#TFs~SI}UvSK^~GVo{e8&)iw^DYWeZbZb@a2L99knnuJr4tS7A^lQP_eP~tfk-fwy@G+k4!sa{r5yPKU zg=2sFklH{NUx!FP+UAe8C!gv^L)){56P^1JQ$*A^uE>6L*QdCxF9G6fylsl#Pxm9q zqpb0VE&5SAXSc)tr~PO(oZ(qA@Sjet3#7>=h;NmfRMtcNz8@D@kLBt|mDEZciG>EnfUy!_JF@)ZheU7%v?nk$#OY=Iz z`_bB7|9tmL{jgrCRvG?GO0dgJMau4dB;~lize@?>K$?J#WBHm^VD2 z!1#0t^ka-Fea6ZlvN=~i`a@|5?R|JmVyi0nd9Nm?#%V^82CMtO(>M+$et1F@;(KA& z_!Uk7f9ez+*$4)`@kQ&CW-I8&^2RKqZqR!l3e={SO29Ad-nB~jv9@yUr@>!5dfNOW z6X>V8Q6=vKpvSJ$RnZ;>UP#@#P@e=ma#7P)V+8oe%na9mH=x`;+Nl^CkeAAM8L0ak z{MX%eTchEbsP{$HRYdya?pd5*^lA9lpWP%aopgF(Av&+z_Vpss`~+z7Y|>@^W+5;-gz=X zdHZedc&-43xjJQ2!2Q3U#~NdM_F^kn7_R5du8(ZkUY^mh+=+RNt>U*XY=_ak`T=}> z*C*5S!GL+XExWNjO_DZ;E!?19$v?`meV-V$w88jWEteD9S>toA**N|-8oK`T7GS(& zHy5_s)*X!6SZ<8+R`eFYycb@kxE)>{<)_5)NsstwK`iGvBK!;6aX}3wEnz^Jio8}i zK%>(pO_)E9>YXCS0|yv9*m0a>yU$&Mzr>$^9)kJBk~&K%M)3zr#Qd^THYv8aT%N=t zVm*p{_HGNDpJrc3@Iq8~jEE=tJJ9UK?WvI?jBq_K&qRu2x$ubuV&B)$=(IJQX3l-} z+!V0lZ3;1u&f^FxBfd`Mr0j|BQ=p3_;*H^)ofViD@W0F<#?!AgeEf&oGxPdd43^72 z=(ZQ%7m=)^f_cNm$xPzCy>FD*V!1>;pCH`c^kN2U`1@b?^f-=r%J~u(Y0TffueD#r zJX7)Tsw8gbWn=AZ%=a7OPG5@xoT&Rx6xY++Tj({83&j|(m*eltZdTBU%jvqro+AwZ z1C6|1J&p%eUp!xP7cdx|Kg>Og)FI!RSHW)q@G8Cg z4N;J*WO~|x_rH4DGw|^T$dx{?F^quzsJA~-CrBmqF#egx#f3A5ZzzvSd;T*8 z!~wLwQF3(ofj{9NB3=pW3Qn1;cG7{L&Gcr({|4|h?QXs`D;W2%my9VDaD)GXsio-| z%)4s*ym(Fp=J9{n*>aN>-m6_T$>m(ZG^&%^aa5vY232_$yi!b`Mk7(JB~67ek1XYi z&=Vt=XY{TA&~4Tkbn=RPLd!GY4ffBPt{6`vRUNa4i!lCKQ{Cs8s5^$%#RjE$Aig7O z_$x06}UiZPUNq#p^jdoYb1f$=@B-*=~4`;o7Oci$w=ENQ{vALMivzyhF?PH2h4L|lAv9L(`9(zq{+~IfOfC2y z-n~lA`v-A~nX$5lLwSQ}{*jrZJc)$*Hgq-h{z6<%*;@1#@PLQc-ZsjCeE*VfzJvWB zDr7U-QgW4qsy~l5%lQwZ85@nGj9{-`tXeNl!Z`Yl@v6nYFdy%Xbd7~6KM7H=y1Q~8 zhIJlBtIUL z6rYz`KtDUD`%q_Q&nT)^)#3LAz9RVJIKK?ob=lp`PjI~Epmdiu1LhaC>$Ra=5Jx+C zqweP#*f*|us%Id#?fCbh|DeAg%QD$^5ag!DCNgQDULBs9;bYK0mx{Y?;(guB%;ajQ zKu<(4Zat|5<+5X5F@T9{8o{yGQYm|!hY^}?G!$uIF$;`UH zqXp6#N-izDAg94Fs(c9Kj6dHruY~JnTYW-5LL6-9>}5|JH>Y;$t0uwox1|?mh(elX zHGE(WrsD=^}gP(E@HnDdg=0AIPPNL zl3;`F$nZuLw>aP>Lrd5K7yP6L4cD=J>W%rkI6mU|OVp_ikbl{sX+Pj{94#&82aZY) zp56nLREn;{as?;M@66!*iJ;VjfFHz`*0G&mY<+hQ^CExqy_)8LCPA+Wdl@n7E7eC! zvHfGeahKRHkk6Cl9KIf2?ZuDf_5@ub*5BNc>9~U1Pwe?$0W42LDg4_FFhJn@Gu;05 zEv+)A0T1~zR=tDoX74%9faMr%OOtSWQFchD;Px7L-zlaAXu8rp+yrvF4y;aMJ`s1I z@Gow!q4p{@oNkQ&$&cTYEBQ*)GRRd&f2cNr^r)O?St!q1AJAF z;eU2MU{lo!{ZZFg%K8%6m5ZkYM5y8al$x2y+6r=QsmGj(LGJnE>~9}HZq9UXR~_)~ z2QDI<+dwW-DlNPP@>^@l46!^n+n;7LkaJ{AcgY3&mu=J`oej^;_n;6Vcu2RV1-8?E zga7?C2RTa1=gTi49nn(Sh2x0p&-mvHp&SAF(?S$*y`IO)^8(1#ybO<52TWw-?HYjo z&-VBH?iXM$eOZG0RKZ@#1V?Jzbp@Wn6#iSnbQrz(Nokl3dS`3Tr5PWv`)O`M4do!W zzuwk=?=5&<(aqBRV9&z?H7er4@4EQmb7508_ysTNd<4KRdhVD$5@`qPn3s84-`*ZZ z_m@d|d@$}`{^3iR48%e7w**lH8N`S#3MSSr3WvDx4TYzdu|pZZV%mu@p{LKi^Ct zMWdQG@_kciqHA$a5yc>S^7V7bCfgu#F9|;^IXZv_I;kAxrw7n&&6dsAFyDsfEzLDr znE%rA;5A3C<{+A28A;INg8AH`Dm*=#14y~3OgRPQR$OZ|Fn_+Y&hF<8v9E_g`b}t6N{GRZlZ_>(OFO?}`e*Rhm-q7%kEd~0^pZE{T z8}MKLaZX+o1$)W4H~*eE#1&RA2yuR22m5Sqlg$bC+$Hk-q8-Q;2F`}9Lx0=dqUzbq z3F|#lY*_4|Jgwm;XK-9W&hMDvdyv~XZeRWhC40Q(!>X zTHf>$9`8{-n#Rcp=xm;JBpT#g)|@5qJQxO=_fs7p7aXAT6Zi`CZsvM&I(c#QHzzi2Ql1zb#(;QP>LiwTapZ z9D(#GXZ>017qiGI1mN);C(~n6*dCponWn+-T^D=jDfa)|>AS74UC7qq3&(OdH@6Y{ z5-aRD-S-aCbjN3FF+Y%twj}mv&iBdi!S*D&d5{a2=WC%b<^p(pt+5r?PiyBNL2O4j zycEZ<|F2_yo(Ic`TRsrR_Hne}`YCK*u0EHO#%T#BvlW~c_~e#=-=iEg5c4q3#a#%+ z*N4xj5#tte34(iZJR<+4s2U!JFrX%nqrBOExf#oK>}`91G4aB(1ui!^-kVsLdoJ!6 zaevRlNMal%=kMK0ESKIYd;??k(kV}jdRTeyv?|1QCBr)&GjgtEvwoe9uDXe%OuSWt0v~V1O_i9BxzE9z*6g_UI zG+%xfNx-C>cf`I+aW`EV@OwR{kPpN0iNImI2wZNM9JL5;H<3yB|h(+abRoFZeC?<6lzG zkeNlc?Tr%ct>MYlrEmX)>NZ?;&>%|&yiFAZh}7)wk<=3$8#$2Q8W^OxRl`j`iaf&Y>@w;f1|ky`tj*gZ{})14_z6CiEE%w-AwM9 zZ~DNz#@#167NCAd5^Rq=2mRE$_5MdAxKGA;*1`~=AM3f~*k$7ku*Dx#S^)nYH za@EEVg+^bp=`rxfRvysK+o~T>-Gp)cO93NYzzg2)Kl0j$VjBIc^DAfuxp4oE9M!+@ ze@*^a&Atfzu|FZ)E_)LBFI;-7mNSEPjclGtO`Sra@6VP>#!jJww=4_S{H759#x0*S zC#R5!-oy<4LPCEE_NVGb!2K8f z%z2-ZPz~?77G^^d+ISyAauy+>WQVd4NoNvr6NwU~vn8Rbeoyu_1rjob@dXna5^9Ux zeL|;Y5Uo8Wala1&d+!zd?1l>o#VkdgT2LXOW1R;YZvTaO%PY$C))j-OM)Gb32k;!r zdeO{2DH1xt{Od?k8t|a!cBPMiZy7~0Hr;wKh`PLadU^QZ{x_}7Bx@3Sl^htB=`x5k z)TPwB*auO}zM&#Nh?iKh|Ga;Qo&@_|d&}ojkx&$!h|Ud0$S({?rg9xb{+b1$X|5zB zP8gF;-(%2Iy&FPDfCtSyk50&dew>(;>lNfZgo0!h?oU??Ba!DD zufu*r{H%0#v;=sH*Tz2XU(oMmv@YcS6&prn*0u7-&O$%7yST6o^iYkc!NMBotIcy? zj2?m?ap#!%&npnOP&iJpjS2V*<8u0(4)CF5V}o-D^n)_L616wzRf9TrH8Yq`BTvye zeIE4im7rtx`#?{LHQc?Y0(y)uRqOt3z}0_TJQnc&BuQfddGJFvXZ6{wAr8Z{O(G7@ zTmC@f8yN`Cf9oG@DGC10FKV6ht59E!jZlXxQ0~8$w+cr=um3r+TfHCjQ~-nT5RL=w zWcfs24f?g%hJ`~M%K5r!$i5Twcr2y!xCiL3sUu7^LtrPA??`;a_N8{mQiL(&+qD%k z?t$`N(D{B(h3nTUq&k-1{+6ejPaPp&xkcz)KH#BO$#dy0E=ET5{6xDqK%C z6*`31OJ{zgjd~5&&;B%Fz;<9+=j2&FK#2jLaw({%!w&N~9Oq%CIJ|`84tsCiE5iP2 zxa)HE1wcnj%Ib$uj%-wjWgVo&c=GyiIjwyadM5yXP->)Mf82Odx&-^%>p`8ohXDtx z|8nCvdUfb~K5Q@hE$_x)J3N(gTlF|#PYg@PQNVVq+#fjpalg#i9ot#?k*~yh_S1R$ z_;9@*tWZzlxchx>h9j6SrN5W?Y7NLX7iojz?~T%#1GrpGL8B`Cd{MsyV*c=V{o}Pb zzxS&OvHwW@%rB0|kbdO9K!xr6eaWhF%oD;i?-KiWiJkfth@Y>mnoaN*efE4}K8J~I zaRcTH8*Q}2e2e5v=XqRinms$QKJQ_%F0rnxXqAbWf7=&2(v9WW=#!K%I#H<;`z6r% zwvhSPW&kk{xZ0_Kn0MlI+K-qI?BY8_lvA^tnLsw7Tf}_Z{nsXm`ME;WQN+5oi5+aj zy0`*I@_8yJX-o;ZJ3|+U=dV|HKgG}0&6mu>|3ia);amJ(+3TB$`2UJJT_=ipWw(}` za26nC05=*7ftdfIxn^XEg|82(zjnkp^F;mwmj5j1VdDU(_}@)pU0H+~*AJW@ z|5TcoXKd8BooH{3-H&hL|EGgJJ2nw8`_+wdNkF3`@ehgty&SwY@OyZf>qjX-|0)tU z)4+VlW%g(>{=RjRR;wogJ4Rl3=|KOWInSJk#|@e3xic_Ne?ym@hk4|S^|}yTZ^2l( zam<_f3^Vibyik+d2{E|cY+XzbW1jpnek}mYPhKz7!~H^vsX<^K`kDCs`_J(EBAn{ihFxnyt6L@PiYg%8ha0i`?t>;DCMqFHrjb`A8L#UuCI!mxg8(UoKF6s${0 z&e$JUE)3&6k$J|kvQw}x@bL`!jv4e%j5$#j^zsKQ(%L-my`swwluxa|kFC6Y_fg~+ zdc^emxFgFf(&GOtTmtpE$^K6)=^OZSpHDXAKpdQN`Cp=fG5i<5INlgR+@{ewFzqtv zbxj8OjzXA+tmzp^iN}M2OnL2cH(*@kxP)%gDHuQd%v~G{?hKRgh~F@@ruOd<0sge=sm1?q5*ay}Z|S}Yap~@kYgynswt$Dkz=;M~`B^)Qf43qsi`nnY!mDQR&A$SJk*D(eBneHz>6yQ02c> z=BT7`v~=wKf|lPniuJ#CwerCvdfyYb&%R*-&Ftim6EKJJS+1W(A* z$@OP1$e1s2AO8@tJ-0(SpK%D4 z#l=2rWgSL47ao?^FASj#$N8C_9GIWcklwxJ#t_>5J5tpa=3(3ocIQYv2lK0*zF3SG z0UqTrzmPdJgf=B2SM!60(ClomahuK%Qhey!lO0Gx&AgYg5`9RB_FDS8RWTBZ@cF6X5*lT@}3z;Zk*sGA=BtPPI>Ts z(sq_^eX9rlb7}sSY|uBmTREKdV4sXbRB!GHd>BH#Zrw9f$G~1F-OFHK13S~k_e}=o zzx=hLq&dq++Kz<3B&rhcAe8V zR6x(l8hpdNH6%qQWe4aFx0dnVN$_{yyH8!vgY~0<>;iV?;FtciYY*pzacLpO+rNLo zd>E(sOB27r&%AYR#L5};WlChkZIM@Iww(w;#6u>7%~QJ_a_+kI9%L7(|9lxWO>pR7?lBQc2i>(#ORJ)jSx zzwVGZ4su6DO_iQPdPrce>F!U!qnk>rIl$gM)&6*_9G=r1OPhrK{k7gcSv9~nvxeV- zpuS5koQrt=^}R`<;Bt6R4Ke2rx{%-cCp-$r`exj@bSm~FR9SY^Q z9JSOQ0DSbSrWnUNZsb(%#&(b@FeZFAphZsks5;~q9OOPQ0_pT3m9KGt+HYH*$^a_s z|E|DxJX-yv7Bf7*?^8f2C!oShUsDaZ-Z3aMi0v`e*I{p5Pv+TjDm;&8mo5JlGe}eW z#AFx&(r@_}fa7|BE5(x7F8lIG>+k@M9r_-G%PCvcyNc_z>BRdF=Tmy;I$^%kYMLcL z3s|!<@D1~)MAxbk++HvDNt)q!;TI)+Da>PJ-})7V0Wu~(Ifi+sU`+#2ui#K~LChNz zRr>NV7V#Z32?e|>I#7?xyOPz$iut1+OJ^_6=MEt4!ThH`i)RY+k~G1GM=>u=5UVBP zS#fW5^l|?0#2zM$w&gP7`2E8?-%;ZGA1SC3alfH&yLE8>_AOtCb5VIIf=e(DIZdtG zjOE&fEDqrO(3hJ;JT9Aajt0NSx)_;HQvS3fc<0*{Rf1m@b9xcHa`XMU7<}KXW;~JK zRiIAfFV5^E(g&_e61+Ao$eQ5I)@9yn_&Qh11EM{4NoHB$bl>7mNBo_x$+r@` z{SK*hYO_1WjI z@c&z?Ai5Rbe?cIR*oU0+&oSaWzmpQSgV^8NTC}1X56F9XjM&G6zy7i^mcOq2G6jEk zNmUi%+_LrYhyeWGZ-1#w)K}2auO7=K*V%Xx^((1i!}W1*d_%NLYT0@+zWy~}-ye)S z?UZFPPRkuSgyl+x42g39qt}lS^WFcUHA8y19;(du6|Y-+k}AC+3Hnm(btjq!e*3|? zZRsWCyLz4cd=T)-VAthx!0@O4ZN+|SEmxLbH1NH61?NfpU3P6Px$Oa1EpR~K9H7_Z zKOR`Vzf(&(1IpJH;UmrgpRHWEkNXk*hxWbLzfAve))N7ax4WLlJU1$pwi&lWR`M-k zUySPx%#B!%$8|u$5U}{aqXu{${9N@`A5(b#;}$#FdEm3+kNS(pDqtMKTQSI-brkL1 zuI%go0OEPmF818;UOQFZ9)1D(Qd!377$xXAYnDbKF3|gujQzZ0yJ7#<)5~5oppTv1 z4t6O*{%;TQHVcs7J+QfT0@`C{XpGMg>`~lZ(~=o@evgiIlo`C2(*u*(9*~cX>ZY9l zdE2>&Kz6W0nT~XSIibFClbp^ofTLPxH}E-Y^4|*I!~ljgRT@`8e1S#crk$W5tbYo4 z6f8jr`d8(CYR026#1+Ob+X->eyzvVSFYZntmCr>^dzV2kAnMzVFducaBxr*r2n7)SZ7W=k>Kr_hMTors?h&()u~%H}o&-yy@FHyq+2iIR=!n$I9U!m%Ut>~)x@ zvhU;lM_}K|#8qSRz%K1;C@MSr2ij$YrgIGH>&(@2*U=2(y4QHZ@PGYh+A7-~>`}@Q zk7Or^!%TU8j&+q7MHds2!#H95%XLbneuvK_`nqe|#5T1F)P3I>rus}E1-_e8?Th1x z-PbX*{>V5oyr9L_c6$yk!zePhV#E89afkD}&hX-5N)nSNH#=WgkcKvuU9$ zcBAO}qLsUU=NS4Z)9XQXWdezmESeSYO`tdt?x^!!<47Uk&qS3g#7lk+KF~CUakg{m ze>onGqA#&@FAYn^kWa`-+KWHO(6D~Itj|BZ&eCUoj}Q2X8*>|J*WkZ7NV?gj4*PFh z?4^717XFt>YePxID0<3dAj=HvyM8%M7;l68 zsx~&ZDA+IUX+`-K711#?Zt8T16afFOmoGse&3g`S9@*@k(gAJ4JN=3ySeklop)nMZcIgPL>}h#|8Vb4 zm>Weqw^(xgNrCap2af&w7e~=4ej$bT>|=<%m2GTe1ooX?EWNzF5cVawPI~_Y>UrDt z%ZeWSZ~7tBk(Eb*Z_rM8z6~8lr7TK|YY65=sq$BdDMK7D(c*0WBE+Hiv?!x5fnAO) zazwqu5TD?<{vrYRwaDS0ktL%@%IN9Ytyf2p$o{IC^d|W4|GmH5ss{bvfOgLq73e2} zFu`!BXSB`YT7ej5i!g`Zi�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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000070.vtu b/previews/PR1697/tutorials/out/solution_000070.vtu new file mode 100644 index 0000000000000000000000000000000000000000..5559dd4939aebbb091cf0da79aa08feb3ace4d80 GIT binary patch literal 19148 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000080_celldata.vtu b/previews/PR1697/tutorials/out/solution_000080_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 JMIXfNKLG!)06_o% literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000090.vtu b/previews/PR1697/tutorials/out/solution_000090.vtu new file mode 100644 index 0000000000000000000000000000000000000000..244d423ca833aa56527c484c8a8b4dcfb68bc641 GIT binary patch literal 19175 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 PJ_4Ua#kYDW literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000090_celldata.vtu b/previews/PR1697/tutorials/out/solution_000090_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000100.vtu b/previews/PR1697/tutorials/out/solution_000100.vtu new file mode 100644 index 0000000000000000000000000000000000000000..89db45f786b681a17ccbee99ef70e4d512d8bc60 GIT binary patch literal 19213 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000110.vtu b/previews/PR1697/tutorials/out/solution_000110.vtu new file mode 100644 index 0000000000000000000000000000000000000000..8e839ba88bf24ac6d5a242e6808bed8e74ec4333 GIT binary patch literal 19188 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000110_celldata.vtu b/previews/PR1697/tutorials/out/solution_000110_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000120.vtu b/previews/PR1697/tutorials/out/solution_000120.vtu new file mode 100644 index 0000000000000000000000000000000000000000..9039479218d35e1e02b4fc2cffa8717587362633 GIT binary patch literal 19147 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000120_celldata.vtu b/previews/PR1697/tutorials/out/solution_000120_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000130.vtu b/previews/PR1697/tutorials/out/solution_000130.vtu new file mode 100644 index 0000000000000000000000000000000000000000..7790c1588964210e996a5f0739758db1bbb0ee5d GIT binary patch literal 19172 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 literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000140.vtu b/previews/PR1697/tutorials/out/solution_000140.vtu new file mode 100644 index 0000000000000000000000000000000000000000..1c95a1bf1653eb5da42c85138dfa566cbcd2d82b GIT binary patch literal 19171 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 GY-K)<$&riz literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000140_celldata.vtu b/previews/PR1697/tutorials/out/solution_000140_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 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 bKIETB&ZVOIcQ1R#;QmwDrr9kI=iq+;rP)JG literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000150.vtu b/previews/PR1697/tutorials/out/solution_000150.vtu new file mode 100644 index 0000000000000000000000000000000000000000..9a9f6c1de3dcd430779b2e990666b7f13a26e7b4 GIT binary patch literal 19176 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 ~*$<@>#a#xkb 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 Ro?%5YQoeDhlL~Y2zX27xEW-c* literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000160.vtu b/previews/PR1697/tutorials/out/solution_000160.vtu new file mode 100644 index 0000000000000000000000000000000000000000..31118c1d68679597627fb3672856d570d96d5a89 GIT binary patch literal 19165 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

?kHlJ3SgN zx3KPO-u2jRJ<%nmW*XJ$?>|Rf?so`)(_93<%N=N^#T0#aM&n!9A}+a`%bju*lb7tD zFHj;=-icjF|1T7#_dzB)No^|fke z2J%iyyY;UHEP;@C;XF}y@XQaogY4-?kC8Ulj{DUZ0+F>33mwVA74q}2vJOwYE$0>q zIVhQBc5>&XDBT0^46)y{s~Ed9_^+7)pP$tfsLtIDSLR4XXD?5>nbR;9vbdJ6Q?42|fo6_=EuW)-aAkWH zOrJTeQm5^DuE8s>y!AWLp|Hkgq~;^3|JYxKo*Gj`@OsD7v;SgX`$)RmYB!54 z%Z5GCf0I7i?Kr-J@F?f%Of?bV%}FiAw?`8Q?<{VOhU>F9aB0q$u|pJ;E$4D?m#(9FA}HN=b(Mu7!JO!X~#yT#c00My1!_U#$Ue;3!|lJ$fS8S zI*tnAU_SY(g(`&;ss@_tKx2Gz(Nql!1{zE3KN)ziP~Ih8e|?z4;t2(hdBXLKPPgVw zZ5%FT-#w70$HKMby!Vn35!%{!PFgaVhK1yT)^Eh0{8(^ASBlKf<^Z$hJ|`$tsie%e zRTDui$Y+1_VljL&{|I!l;&A1aTSFAlWny>q<#F42Jiq-pWA}6p9qC~!P1MB5khvf5 z$9J;#ukSi)5KJLZ#J8;`d~+|KUiX^Jjk-~r@g)-H`}`X@N~GV=V=AyUw+_G^vU)v}b|Kh6WKjY?M=z32z>} zkFXsf^J9L0sNtms1?|$B4iU-Ay>jCdUo{F{haQZ~ze9LFxP5`|B^q+^`tm9dMQFKD z+onFsAj&hpr-keziMv}~Ns;<#98JD5_p=zH+!bp(4m0RdippB1BZ7YQq(?2pKUJKU z&v~$f!n`9wzd}lgGlo5#CkS`{S$Tq0%%relo@e@}B+^gsRpARrKJ*t=wEIH# z!pJ(SdKUQ-&sqIdVyL}37Z>tCgt$9N=L^=+a4c?kwVU*5N`Zy-ToKXZU+3ym)ro)A zF->nIx=Hc~ANC=8NcYY3=xNp**y%6TdzbPkXtpiRCfptq`#!>u_>EmDwlmiauqbRT zO*8csBf@9asS*;$anphEAxmiN-1F2SmiS|1jW?3B2!C~^x~~;jQ1EIy8S6my-A9uS zzei-gKb39&vbK}O-s4>|*QfG0)NiMG^&*eLy^42A^mtfb=AJNpEF{0YeS3!F6B!t| zXoUF8&*#q6NRYYPX1=VTatZ~#pL;WQk^b1(nSEC~LczN^uE}(g2vNx~dVewuMx6|T z-aTZoGUM{{|M+FKv0>1I#5ts>Q{1o4!=73bqDJa=a(!z~#7_nRrq;`4jYQbXSZs-W|02$&g+H>7MCi5H(1W# zF80ipSFPIu6)O4d@A`y4(KORh- zb1vx;shi|DZfJKQctD06MAH_?x?yyTIXF*Fj|2Yj{>9wconOWP4hfobGJ<`JFlkIT!_ zC;3$9t$1cc{JZ|g%6DozTfNl{By2zuJ?JpUgx~e=b!Ud2KlKxPdhx4lZ^O0IxIH?j&mS8%76$kdp!M+C$wvU|={LdUD(w z;c9-{<-rX*gq_CUVSp+PFR${yv;GL4gzvh5?ZLcvyxbpvVfv1Dp)L>vTm>K_Ed}^H zr~!6!JBdmE#QBx<^VlzhpMf8Q>M)p{-|rH&+@N+p#oe)UKdJZ^>^~4sv_T=@pH$KS zUPma*-43Awu=DT$Lma>-4S_m3!oepIAVA^|i?YNol)wF-vi^7{mHfMg-|hLOz#a;L zfb9`3-Yy8g|Expu|EEJnK~d&kQvNrxU+Uri1&^$p%s)#04?M;vRVkbR|7`1zIr#5b z6#v1ZEb%`&sr2IDP2qQlKm0P%um4O{d*YGHxb01XO2&np9$-dB(BcrD57q<4M^cwbQq#ZBxx z1$XY0s0Mr^j&=DDmJE*5HRI%SY!?$Nm08g@W1u%7yhneXq7%@@Yl8OADqL2)w?F@Q zE}nlnA_&A%7h(|4Kc@_SqyT{Monf(!oJD;|->n%?Glku-oN4N^^@%oD;}jk`q(t#g z$2U{qnKtMec62i{?H^GGSQWWCU*fHdFmCMZ_^?CvFmd>HC6Q*M-U$nZ^-HN=&+i7g zbSvWBgKD!@!)M9WBj|`;+}n!1cSH}ZpiJvra7ickb}Ia52!vi2Ax6O>kmKX~q=Q_gb%07Cp6Dst?ZmN874|*`lfXAhH zdFM;*Q@#kcl-ukr7r|FznL6sH0&T5X2%r4THT=Y*@x+hgyYG-@BZ5e>-UJ-aLko1c z3a2OT)oKd$E>b+Hza3rhM=Nfd+(jLt-;};{B~ZlRKHo`F{DSg1Y`NPe zy{a@>KUnC(!o#E=-TFRozl=_(oFR9oBu1kqk;Q)ySa=GE6x}jk;M5qh!p+XyQwPgF z*A>yUQ2oS0eT+uL_EYc{P8-YdG})ZChsf@1be@wI{G`VI=;8#?&r zS@nZrX7n06Bdro9&YGMv4?;Bd-&=uaR@gQ4JFeS37jJCl2^hIb&r9B&8P%6Z88J_h zSogS_>uu*(30&s!8w;O+;_N_b;B#YoTuZBF%|Tai-P}SVg}NKoPh-XjAEF)gz0WA` zG`}5UdvX6XUVBamaxwde8F;F{rY?(;9|A94Uz%_7;vEUGFUyeU9Mhk*A%9np7aS59 zOWdkZx-vylcFT~SC+9h+ft0kBZc9(c;0nfsdHPP5`;Yg|k z!!Uyj(^p31szUt^&%9YqwtCiH8Mfy1Vb^nA-Cg~=Y6XWU%E=l>7%8u#zF*2;?q8n<9<;Cu9VEtxrNm+!WpxE zeD2n$HneO;+>*#Om^~RMUNvxzrv6acUM`w!Xvhz6=BvCfbFt-So*$_2sMIMU7=*X&;Ue;H9y$Ua8GIMqkTYk)zx(wa@xGBjsMHrRW!(m~Sd5>3N{6?Z9~!&5x52SuUG=das<{6=Fjgl<@N-tmeWxwDq>Dz066` z5==gZ7X_mjAmr{7@}xT1#+f*h%H2V2jkDW4sYy87T`<0{ZnP(d2&EV`b2{wgqHdT; ztX*~u@>Bwbl9TRL)Tvo6D6SeI!Bi-}LSR-Yd2F9jP@k!Xpk!TwGJ`aw&E&#=X6 zk_yB5aTyA&gz_)#P+#S1V>DM0W$xscDvmbMrA%ERR#RUz2n=jb{5(RIye!gM=#jM| z6;tXQp9bgsE)Z(flnutdzbU^(b$3u@+CJlAjIV*#v`zdqsZ>(%PZi7{!+7vvOMI|X|?2C85PifP%>DhS(-g-nXcibj{Qw7d@YeYC~s zrBDDBI5#kmb4*n|wA>di_oSrJu=JxzKOc9AL1n%(lvyEt(r$D8hU~OC&Z(8xV9J)?Kvu9mCWArYJ#G`cO3o278PWI*f}h* zw(W&Tfm~-e@XyY$ACEg*#&_v(Z^h5XZ?tA@CC|#UHc%J@>sUqX0^-9_ElR1)0?VTG zs|WE_7~S=}g@bs6`aD~cJf4472QM(A9WhDj@ek=r0de1X^wxn%65CQ9tP^k^P5@omvb~=1k>AcP@@yxM7ZGNHowo+QSt~9|a zUcSp@+(NyNp4!1VpOmx&6(McxE9rw7P*JCz%iIed;n@F z0Iv2?#%9*f!9weks5Inq0-WkTZUu%dHQCH0-)v~aR?SPNpm#R6WrcIJ^V@aqG*21d z;;hPZ0m&9DQ1&j*-;8ZNeEMOb>y8Dc{?T|_ih%zhI`Yg^58M=eccW$ee#^cQe(%m3 zOuBiI?LtUHI(e`?H~o=G0lGQNa3_5AHrTFC&oQSFQt1qCDl1%54&zHraPs! zwRX$TSfHZ>D#5wr8$ye@g4qLeekb2(uP!M+?LOZ?nS7-Np7OYI+_GAmy(G&vzLn#+ zTEc^?cchDfaET(y=2)FePFKVKQL)}6IxZKDiLGUJmP#OxoUZnXW^&}K^YvLuO3+B@ z4!{$#b6wCCBJx#Q1JYCeB!%Wu-VUBOqQl8=i(gq5*KFiBqDRuLiw(BPIgpovy0u5n z5*!%6Jdd?%siQ5 zXU?)sYwzm!s*rX;(w`^ETn<*7txZX+*|Ce;-=N!q*c!OQt`g}9#@^5PHZ%en2FgYa zw(HOsIU2V2lNZ` zHhQ?bRDMXYkD7?DR_u8gsj$8R*_qnjMi*LVWym9|gpe?`i%uMbH)hqeS}`*Xw}kGq z+Q#gWS33nbgz2b(Sg7*hc$+Bu2@iweLNe z`g8DCojDHs^qp7GN$g~H=jpyN63{25s81v}?A#QvslFf&ExPBsuq@{>X*dwHWtt%w zn;ay?Z&M!{{5hadg^vR+T5&2=g-hAjsc9IlZw_=ik4!`bDaA9$bd9HRmp0+@xh@`{ zECMo55h*oaWQZajuPjq%=3VeSGz@e>Y~~oNJYtb=ow-o2+=E+7{wj4Q&3Iw(eGM~_ z=}Bz%xvME2uKI`L3Je`S7ehr>V2%x<%!7$9kMx7Kly?sr;m1W&x?@hRmuP^=Yq}J1 zocBv~h4;==3^BZLMZgkNVXretlAl`*fw44y+1i*ig!spSeVC)$oj2g9VccbEGt60` zEuA&yzj}8{M(UG;wc15;rmC(5e>_^fHKe45c3bSRA4IeH?VEn7Ks+u<{$_H#-jJ3r zpYO1ucdi5oMS9N`A($w{KLCk(iF5^^(5>POlw(6&+Mo-~HFSku%|xAxB!^sj6wYr& zh`^P~Dlxk5L@XxUaYA`z1`5M}y82M>i#Hc6g?*BZ*HW%yrO1#x~`V0SzHX zqe<$V^aaq?y&y#_M(_LMCA(PJGlY+xVvi)ZwfcvL(BCYl5>=J0&URLh#_z0r3~cCC zQ`utXQoFLV#?*Yh<_^0eXfkUNNXf5aj|j#;fJomH-$_zs z9?uUrtj}j54ivv`1dTa1V9y9^Ot=p6);X`Ap9$pSI1`q|(|--McVW@3qHVxZ;aLiX zXa6FRDQygzx<<4`gBPcJ4lbD=JSXj6W_RYA0_i&5wepnyRFIO%h+rf(t}aje#hN#i zX4RV%TA(?uoKeh4ccvQqDrN|#JkJ~QkgGeOyfxKD=DN0BC&;Em}&q$xhe74|JIOGN1R2fsX+eV`xA{kh9x17DxHhZX;pn&W#TDD?0- zk#egx{aYqy4_#~KUQb=+Ww+}&HNz$JexSD`2nguA(Zna#ydmxbxh&r>+I%0n%VAyrzlOhGcqP3R{+kP zOb8E*F#-j%?yxvmzQjPL{R|E_Cj=YZwQxZkD}tXoM%WdKosqMbHZ>#e%YcG<0&#z7 z5;X?Bj6l;a#0#l}?Cvxl`9-nR6C80P(6eM8)CEsxPzoqXDyy%w9RPt=K-5_P~3R?zIVCrjFi zZeXG@7Lcx;!?HC=v)x_7lKW zhu(wdej!WQ$ErZcY=A~CMtT}FdWTqY@4)h!Gg50iiNg3V8Bi0xDrreOzB9o28+_;4 z{Id1efDVfrqxTMzGecE)#tjRu8ZI$eG^EY<#uH*P=AgrS^^MAg1JIeA~p@q!juM$3ur4Dh)md!!CJUC}I&#VlEDIFv#mY(^oSSs^Y# zA;nN3sZZfA_1kT99Ze7N@&0bD1)QH0qS}4w90RY|UJnB@F-x;2NK+b0u^399>yzTr zNQp~9r^hoP=$z;Yj@$&WD#3}I)q#)Ik%`rb`h|n=3rF@BV8s_slqQZWCSX|; zr*nf2VuOxcgH9B34*YVC%yQt1? zQ9fo#$poNqf~2A$P{2@9Hu+^qT!3F9hzPZwx32@gLblJgS3VJ~jL54DbFGY7u6&kS z8ER1(JyIE>R2f-a8B5xu#Lb!>yrlAd9`1{tShqm7eDjNH@p~e;M-e+&x(x`xW?yH#^)(iXPH&!q*do>>t=%wFonA> zzwM^;?CxPv9YRrU&QYBgqgwAredcYpvuw5p&PbE@Npbjii1kS(E~Y$YPkEM-5^BcY z{N!r;OSd-ql}4ttkCc{;UY1?wMnCC|c8HC(xsP_PT*brko6dSW*u=~li90C3fr4;J zc_L7PC<&r10!9`IMPe0ni!SS8W!j6BMT-EUSgE`skv!}**CM&)BJpLcDn}6?2Uaq* zh&{E0(xRBfqU792G1o{5vr-9dbumYE2~|KbTR;g92~I`@W2Azg4ToI}hhNZ!)3v}j zTi~YzVdn+mm$Kn!oM5a@aQb-|_dJ}54Njd5V^4-tn!;F2iTuJgHD-S%{o=2|Ci`Q5 zuYt*Y(^Bin$Z4V&{V5X9kgKeA1Ea}8GldB1 zPe6d+B}9LIo%rC4|25tK}7oG&`=e=g52hSRv7 z`DQ~yiZkJV0>{n%4ga5KV4dM=Gb#n!$MYaCj*rIcXPo?5Yt;9j$`j2022RxLS^i&6 zCj5#Jsy`V#1V14{2oPNE_RelTgeb=KD>U+tQ2v()MF?`-P6!pz&cSQHjjywZyAL5D zN)R$AoM@#r9&VoA4n984wyq9_`&}Kp4JTC94RFng^#y*d@9E(hXz$?ow-HPv3!VRI zH)%X>D?c0WzYm=EXQaPA{@o=cQN&Rtg{bCIMqzGaHdB*4J-|dJ}<)ikD$j#0D z(}BRaKOU~}1Q2Jb-2L$uOth@^S>!EN@6Lg}TbKC`?d5=m%{;L}TMiU` z{H|ew`!pGhBJF2#U{RXF39avJc=x5KXIg4`UkCF{xW1Ud5b+TAx#3G%#ew?bwuK@N)-Gj2U1NYlk7^Ze=vl1yGW zpxsE23x)(88CM9>^Om6A2ekifh&~vK{(^PuJG%1;a>vl-*m)-j^5A{rhGQ7#{>?jq z8whexzEO7((nOJ#&No+rgd>j|>IDh%=pycjx_Jb7jh>~zTuqQiAoOjQ3PE04m>ZG( zo&$%ShF#*EI56$BFD-s82X<|hm&l0Vz;IvH?fyy*_$RMj5sr1Cm|)$$GLQqRfn|p* zsyQ&rE$ORVAqV!<9NtJS=Robq`>PJEY#0mA+r@c~=X-xcLC<>vl-u&0K8`JUAjpKmUmX$0}t< zR$<&OZzYqS>>Z)mji znm_I%<;_cB4jZJl@7lMcn**l>cLbDTJ!s07Ij=uWkWQNVeDzlea@va6o$>G4u+@Ib zJ*8YWbSf}PL|kzHua+Vi#{A*xSRWzFcHKTlkZX9IqgmAinOI-_ zSpv_$`Lw1-G3GJzjW1)Yn+*lCBZ1 zu- ze$rVV4<yXTZ~K!4h6$6aV|BHd<6N3>Ckta~qnb(kEX{rM^zl9;P{)Nrl{ zUYrz_afS^|AAC6#nj9#RAQHR3aNt5iSl@Pxv)I7ep$zM2VAg>&F7&&{IB##u0S+uY zrAX`h$_9P4`F?IeY&ibx;Ki+87^n3L_uGAJ;MIvdQ<=+wfYNLb3&6bFomhY8C>y5x2n|V2!}Hj3 zLF@NR9C+&Y`v4z{1IE?C=K^uxa~DfwlszCwJw~#IQVPze?X9-o7ZT*6&{I0oeoM&w8~D_L#@D>J^($MiAu1_QzG}l>`}C zyLm9R4CBt@F0G0j7+B9^uoV3rD`Re4g8LmCT&Qh{^L=*w+i#(K94I^8 zVPa;_fx9|_9Gr++qQ6z5E-f%%6NZ#HB+WJ#N2e4oYo zE%lBPq?}Ih1UYuJh@Ix~V??YpQ>do^$vO!^r zLc9-Vb5;6!;XE&MZ~CHw_rxgIC%KXetQVahWo9@J|9VIN zPkx_xH(j7!;`m4Y{QUESf8re~$|a0H6r64F$B2)WI%E9j5WZCYRqxibbACnjkG!kY z|EJzn+~fKBzx_+b-{*4~i4W_afB(9CsxJEP<&%1&PP|h+@w?eCcmMF`-{(s$if??K zzn5#ojsI-;hokwoyMJfk-x>IK2L9j4K*2{T;refV01*}&-MIU~dbIRNFke4-y?R_B z&C?HS+%0+TaP@=0lg8Qah<-?TyX(_uP9JdH?e|%V_$^`inL&0R@bs>1+K77T9N)tk zs8{t`l#!0;V)RV60I^!*N>(%Kf6blWSc&?_Rq{fV5evx6_Cd&xTVgqXCF6n?DTtd-b(*_yt%SdbA32pL4IiF9zj~n8!LxH#@VsJZG8yo%9@hNo*Qg%*)Dy~Qm zS#>*{#C@F^b~g}5yd{tuq=P6mLrtLw(R1pQWBI68W!rPf5$!7aGH0$se@Evie%OiF zb15ofG3KN5j{Ln7C|_;S8@lrc;>{}o?C*Ubzo+hm8PbnyR-5~wT<;LOnTGyW%sBd1 z1?{axojin)mcDO1zYyueV{`Q+5rt-~i4;c6o}8K>fk=?q@r`J|j2U<`6X~pZfp%hu zArGd~6A>*+9GwHv&*Y`X8S1FlG+9*d1LCX3pyPEYuWS#RUyjJqlQOhIyinMGz!&pY zQ}WxhD5Rr%zssCM>|IB$o`$IXPN-iF{na&(#pI)(qPpS2R^&fW6H8Y>+#4%i+kyP~ z4;F+gA{|gNTUP-6Z56(#mWFiVn$(^+#HQ}fj{)ds@!_@W1(4>7lbiMdaV$W&=pgbP zYQ2M`(a#LKA^f@82SH_X3?+vbkzHuZQOeo<#IRXMC?SIX*I`nA@Y6BP8r*T z`kycBNLnDjXWqe+r_oO8fs=R?(s|ov4O4j#vzH~#bCAqAQdy43F$w&Q zf%a!4tG>pgKj(`_B>54wv^-tjB7Sx)H@<t(b$fwa>JDycqMspQtcJ4(+xD^zn8fzwT1IaXQjPkB#^|48XKLq!e&i2Z?4FExpMT23V8q<(25A&#^L!k6iSf&n$*<7(DVHm|hIY2M zZ;h@+Kc+fiQr{`R4SRBJQLY@8GPDNia{*g4QjrcnBDdxM;w?{Mp4sT9>Rh2~5Ymns zJLbqEh6Jxx>O}o#1`jgbo2>FfMr&dts5U=y@DTVx+-_q05{XC4QX=;naa6HdxS)!lpy`-jBsi(`tuu@JYaVXG|W=SdRJ^jbhj7 zA)j|{2Du9Tw)30l5*A4Zpp6~I~LVD6iDYc7;--`ri1|o*)a=#QuY#g}o%>t3VV_zbbf8J8BCO5=8 zT*XoSh@S5pH)*1uwxx5O8&Pjo>>($r&legd)2V)2J=4|E7v;OR%@}-#`g_lmW5yJI1Jv76!c#jR?PB&7D9=Rx1?9JOhKQ$>E4;;V zAJdJ?LpynKZWUabq<}P6w8oxAC@&U_b)x3P25vX0GW1j8uQDYW`Rtg5mfsQi(u^eX zQU7=4w%FZx9>e}wRvQsLih5IX@m}8&Q^v=^cqVmE+j0u^c1KvHQsE-tC_te+QnCD_w7Ym@ktcdYs6%g2ZQI(zEI@A>iLL61y(oN=;yim zvoA*wxA>F@=3so^^c$i!W4t?jOk2wl1D~bFQ1@4>chSp-IER^bVd`Rtd(zHq4@Y@p z*7aqFQSK(F7ERrYDLK_Y=iLE@-jNDiCp`062{rd#1=R7jqJHpD$c`K(Ie|1jiT&f=uswVB6 zgz`P4RpKM`#}Z7La})hV2yWjIigA9nUn)%HV^NXKD0RQD&sEyqjC6TR!YpsZiks=H z#E|by*SJC5a|{XXyCTRx$ZdL}mD;yV1m6+#cQEUH3#F&zzVP=^M9qB`xl}zT@cEBX z^)}-~l7$1>7Ztn-r`~H_;uW?xG0v21^pE z1Jt>NTpR17=Dw1-g4+=4E6IC%*CId4+RE(~@-4s2b)oto>Y9wpEToT@i0m6cvP>VU@=cr^OsPCaoBN3?A~rehuQWjU z#Z@;~4t+R>exw(j4;zj}oPIQN`W8f|td&M_RGw!I_fhk} z(|cip3u5rlbkPAk|8qT-*W0l_>YG0}h@#$S{$YkF^4T8i_^A8#_K!r>N$4j@PRJ<^ z&pFGv(&`xM8OXXyNFn-v@fBTw{%Q+ue5ynJc=?fy9}umzmP)=vOuJ)$?;z@Rw)*i= zbMO9Ha-}8uW9b#PbfR5c(zeX`NPjjv7@&dl?HjfJ0Z702e(`+#*Xhnsr$iR+asQ}5){O#;@``?<)xG?c0*zaQ7tsdJTP_1R`1trN67 zfSUJhPZxJtAzy_7Fn}o1BHb&3ab7jwl|LQn9Wi!KqEW9}ak#A&|j7YvyMs31x=Ms`qr<8qwos)e+c6ev>t zMH;?;ycub`_rckXXy@%Kc{2jf)mgoOUl`9xY2mHuH7GyrQ@MK>^;?7KcX|<3dnIJ3 zcT}6Gr*j8lAHOs`5>bGcd-EQ|#UAqa0OQwI+^^S#bb&yiD)k<@zRY$Tb?-8VF7*ea zpL`p)xMdXTm8MYlRq{G=I1K5{#m{-SAo^;{%@^~xqys$327fOp$bz0Xwb2DvbWqyohwCTi9DYRoZg`><6JUUR##5(b)IDo#m#5;7 z{NOC1BqQXXt?s=z8TH#AU6856^?0mb@MWQ1+^C$o2+D;I(bTB<)08MO?=j`4V{EB9 z+F$Ti3a9Shybf<&Y95-$FOFY_es0+w@;`|2c+PP0GDbh*4Kd|Yv2QCBmSwzTs_jIJL+u+U_+Se*A#E{6;$L+PmyyM-v?e>Dh+Y-_qgb(`|LR+h_pKWWR@R zqJfFYq&cy>X;5cmw&wEz8myf6NNe{Q8Z6nkNvt4`2G+{Y=OjF)LDi7AXiFOn0<%7K z9qplk;5Lg3S1o8DmGv z9plSl2DFEFYEECsfRP%#{w3XX@DUmlJrqHQ-Si{Mch}KjvG*s}v}Pvovn=y>#xNme z-%1HdRVI{*x~R-p&IB=~H|gRzOsM656q+`<7nX+VHqa5DT{XDCUBZM%jwOvP&P?#S zn7m=PJqz4*C$CId$%0RMeZ0#gSP=K*70(_c7C3=8Ji&9%D7VMsKdX)&Upu2zCfT{=!5_pbRzFpf3 zS3{c1qSTq-J)#sE`?v=TKXW@LEoH*dq^iu5XPEHX?`;09>Tc-r$+-Q{xCd?@ED?U% z(F3jJFRb3i^nii#!3J%MZb;wyzTl`b1Fkk0oLI!5!y%VS$3b@n$c7&3-1?OPAAGV; zUBkLatlQYewq*cOlz;y7v~EbgJ;%(givdrs-`qFtB^{bP0)D(6q(Qi;{R8Jl8q|({ zHK^H2hbw*^@`YG`86GTq4%SgZ*A=b0U35slxT0=NFb&Lix1YS)-UaQUxkKd}XrNeK zY^GdAhx@v!J;8z95U~EF(Aif#a7dt@ z^^({RU7+5!=J!iU$iMSg&tokEH0R&q?VQ#FS!?AM-*aNZR+G`+(mpeRZo<{o)Ib9f z=D>Cje;Oq9dN>+<>4GQ1W8JbMG}uraE;-GJ4wtIR_BL8|!>XMfle0~jaKV1@&iue$ z$TKUNpHJ%rmmN`dT`tS+$p5FYEPNrQ^9nG1)%(&0t8am&Wj zJ#a`*PjVos7ovSa%Jw+1z{}b~IR){-aVVKKEIht zE3W$53nn{6UU0Ye0AaND)SDaK;BZQ{$H0*R`dc1vq~p20x|%OH{H+V}inwR=w&1)t zlRs;1a}NxvD(|z!zF2*$o6wor3n3Sm#EC_B16TdLsi8Iu$hGL0cd`ZRDC*W%DLM_} zQ#*>jc6Gs)ZC2pC0rR!q<@(=?yrk&lZ+DwPr z0ynvfr zz}&)E-qeG0`za>}>u{-pq~wt=3^=44lSQ{=zzP{=V)#-zSSLRUIwpm4@$!Q&Ro`)b z<(P>5Hk%I0H3q?PIH$stTE-r0_JHV$(~E7;pVUjuYnKw3u-~ibcYRh5^b2(~)!TH# z?wyAU)NJUmN3*(FL68PFi!y4iDbS#WWnt{*MhBjwEo$c;GT`}|e6Fb zFiYjrTtPP$JYAzUP;;^u%pQN+Z@aw*qQiHsd67&9%^gpNwYX^@ocEhq0@lN$Xz2&_ zvUD&~?=H)}M~Ca|v6HIpzGZAr57^p1NGULKuS<=DOz*Wl)=UMxjqJ#RMXpmZa?1*=f(&#P&WhD8SF~A3}L6 z2Zuj0fq&xsOX;7-{)O;Q!9NIP-Q3JUf4QjO;B5X+OEH+cxL7$^TKx%#v$ZwQ>W_q%f#+`)NuGb9{Kx*EX8pbUL zWr2mWlarN&yPc<p>mNG*<$KD_-0M$kn<72?*C&we|6Csl{O3V(DS|mx*-o`q=b)tLBdXCMk*!Ko- zk1on2_Wph^XeWVjGZG9S?hMvUVBC?k3KV5Eu+)Nli>%+gm?uMxp6j%ge_!`&P+fvZAL~8erjx@ubeM*{t*8;`7=(4GG zcAMsxm8%#B*o}+zIf6S1Pr|m5WFxVm9yB*%lWLp@V`uzxY9ODD<1kv^Zzm^Q6?ZOV zV&(#y+s9Ekzf34um`o~W4Uf28%+dGfeK3Os8$Ztq)Xv^r=dViavXWk^d5KM`TyLco z9Kj!#@%kX?9-bBa_b4d=M#5KTRjN{t~PI zv&lpV?I**uFexfmNbX5G#;reha+T*nc=@2e#^}Tt@*A3;_#W-A`-EtDo;Z~d5`l4p zYv&6m!MCn21@BXI$={+!n(VJ%5E;*npS`~5>B8)ieEDt5i)?U%Ezjz_Y5ddrgKN~N zC-rgV%;e@{NsYnFjbTq;dX+=Lu?RSx5A-~m< z#TLT75Q7@O1WqK@yJoBHh-vZFV}4fp-8W#fHR6@Q>SN{GlZbt0d8?oE`g2|z>{H3l z8AGStgkNjKihh`~98ToAxW?he|O=h>SzO1UU9ix39y` zK;2UGvU`Mnk3=0DyQSJY8fBcghOUES0Cw-4et!%sXfp4fwmvui%H2Ca>$~&{mkw#X zAbP4CC2|irsWWJt`upf252WC!$k5BTuGkNQ_p3H8Wbo&k_J^^6&Yk@vWLbw=ko=ZS zU$A2I<La}EJK$w zi6r){pS>gTwc^Ee&E_+jt6|i6RwmNmrw#woVHH7WiB*%oEdm96M^8RYdQOZyCEsu` zKh~^c+<%5&g(l`_;aN$^Qy)JmtfriM47ph*hvlmH=vzCy zD9Zu?kFL8ar%$1pM4K#2!mS}71ZvSys&T|{OX#Uh^R4T-tfTCubQ7g(xQz*9cd4-x zL+=Nk$+|Uy#+6zqcra{LDENMnvMljL;N@Ip_8um&VV553f~AK7_oi3WDkyr!9)&Qb zthz0hJ%1ZS?`RVKD@|ww?1wVMBPi9jh6HcSTO_Kb!=9z;(R-{Smcpr?`SjlrP-W*3BW(ZaY|}wy8Xv z^24KX2i%)bV>Sts&){X~slY?=y*+v8vo8ie*z^rL2cTPDt#*q~47h6N_Sko9d&@F`G z+9h84b^I6Fx%>2ygsV4=-{{>~g@seTEB??d&v`)j?Xomi0ZJg!lW?7;paP5?AUvtE z>xmT}+dPs%N)vPojmf)zM^4YS$K76d65Y{aWz;HZuT7~}dwIxH38-nJor^&*H2nyU zwG(>t>C=1$6OY%+JG41^RaW9SDWP%{CH=PL;#kf%u)7|ZXD7VT$7M>>eAK-Ed1mT- zqPA4IfAF-H+O?ss|C{A1{l|E9a@zU2Hd5O3FVOeenXs^4T-99L((2maZi&9VB@zR6 zC9E#9lS#tl7#@5tEi%?uBT_Qg&<_* z3LB)$Y2NPEy15%`UPef#!6?blTgOg4ITZXZ$0K9Euu1EY6wwd`h|{_b8f(&bYkhlG zEbwtK-)r9RBv}fNU{w%VA+d2`*x6fBd#SfUcYvNhg8JItp zU95buSGG$Vj?}AR^U`Y4d23u6yDdsG@xX#|s(Y zVfW85MY9~@#N8V3XM><$G*B?doC_kio_$woFh$sf-ETj4LMJ`k8J*TW&rJi3*YdRW z!H>Dh0y1*YX?(hXq4RK2>+#c@Do3Zcf|ZKv^ts#j6+janICk(_p(^wy&S{-Xh%=^v zcrY)_JMj9YhiH{EGtSIR$rD=J+|g8+@aOtotsgx))ATg;nk^N!&V-`b>*iPIuZ1=Z zAT~dVALyS|TFWkp#uA4oLam`C9`u?I{Cyd*y0!)(SV(I*5a%dej7>M!I5f&^d$jkY zAGtkO`mgood8=`fL$hRhXCQK%&*y5V=A4{~>m6Z)5qQ&-{h9|2mg9(6>c^w2knlB=RzAf2J)V2znYlmKk;D zZwSHD;c4cT7iD-gg%VfLwc{4jm5e4YT;glf*>mj|df0EemHM{3x3+apAUzFsbtA-H zqF6Dkq&BdjtxVNgZU+#m+DDl@+It)K6Y-^ae@x9Vrz>#vS30xLY+4lR#sp9|P2*y4 zRd4YAL*JcRQBJl&joE&1cQ#Uh1r6?_PF31Ks1_{jb>HZ@8y0c7{z&;Whv0 zl7*X`375)-%=M`i4=_qq_Esir%!PY?C_8 z8zf493h=n%5<1is=(XRAMdiK9S3po=maTOn?e&Dq{iSru=BR1i&%a;9=VLA|o~Nn{ zpp%0bD7E!@gPgF?EOU5l+M`Lp&L5WmF31!hv)z%N)DAO`zrVn~b~4j+bbAHG-PQJt zpudp!?Vf2^*1YLV%Mr#Ttz0KN-zndV&$Le)PHy@^KF?=9HQjNKM9Pcj8A_ufT)SR) zR90j#$d|)dwks4fKmJ2xPHYMT+SevF@hM95{MZS$adVSaZBm#o;@`^V?Iite|)@d^n_ffdsW`~Jc1{nkvft|hf1e$PH|2h`9v*30y zJj0hGVfb^ZG7aN*z@pL)rA0O@*Ll5my?FG+)C!!}E4^llqbw9>gSWq{syvPJ&U^nz z*kxU727IlX&li^p=4UkR3JLh_TP;OT3FK^g9wJ38>21?L4^%hcwIT3N3I|Ih;0cbc zX43rVhg49LJ%k(j7CeWdyh+LDbPqZ{!YC*waz$wQ*|}epXiEhWi~QUo>XMv*oTe`F zqh@OF&sMe*Lh(Px72~{0cd=JTtcv1|c#(y09J^U}a}v%beS1^~UrXLT^a7u1HdIz@ z>?tsLQ%_Zp3x;i`g_%(7oY2{dd3R=oNQLFGDo#DGv%lwdjXORvcQY?kH3_>45OQ6YA8y?ppE+xXDW2A(+P>Cl z$44og9Ss2;v+Yu6knn6D?{xh*O{|DyP4hB=A5!3Vg}`F>PlPH4+ZB!GFV^igXxH*t zw8tOx2;j|3`ZCiVj!CUfN6ngDH`bi!%j8lbP>fxga`EF3j+3r&F@5n|6zKj||LR_^ zM9}(2&kd(aj?J@t#?3Zw}_{Dd)(>%II%U}ZN@)e&cjCNDbANrZcKq+lb z+q5ytw>$W8Ia!tpx61kF9ayY3NA)u3&^%5Eb+^ZrE0FI-VS0Wp?aXK+Nm|kveY9;k z0e0Nu*F7mCbxlYu!vZ_SACPNTBNqdlB(Fw0xj1@S{zM`j2^e#j`oVpG!YF0o9?;#{UqX9N zjy6GY2HigjyL74z(lnJ*iJWhKb|zE)#9>2 zXxm_2A*mdyq~yfN!MfYX@4gVa^d>&jkDmSPA|W_~R_ZwxC&4Yvei_{%aN7G{>8uvq z)enwtiKKX)Qk*kC4t1q|%1wUE~*v~Q0oHQ=TUv%w!$ z1B`?3-hD(&s)z-+Ks+!{tLL4iKDQ`BJkWA>_ntPKOET}X!z&6(;18AohmXQPx!B>Y zOvR@*37M^Nb59Q-FYNA&=j-(!XseO(22wcKYJ zCEl;WA&9R~l-2x;MQ8{`0oV)`T3{$ zE({B_aEy!vwldox$!NrtY18IxfN?Y;?VaJB+k+psYtDRJMvZg+PR{`mKarq7H7{P3`K4QeL%gvx@w5;wH#ay;B){uO-l2#cMxKJ%sl@VJrYbcJ;$H2i*d}Vz5W(t3y+@3apa5LDN^CWuXN;oxH&$ zfNk;5hl)uK4NlxvlMmrjhhUaM|2bKo?*r;|_TaS)wMn2+sQwbIxJKz;`48;0QBVjj+Pkbv!l{D8pBn9Ic@ za^kLy#TxI4<>bRxQ1D^#lQgf>wy%6yj=&~hSq)nM{=rDx)?eW!8Cg3^5YXS(ntZ63 zFzRc2282cI9hofpju^gPevkMnUFz={PAIa1N1pQmfPjs;4j-H1X&vIw|5nGXtt!5c z-!Ag}mgC&#^Cut)VG?%!orHf>n4sQxCkU2*=xkmU^yc2t4@%68$(&Jt3io(1Gsbj* zOfvo_?g3(9W!Aj=c;=g(691vw!h3w<4@3mUf`FfW-hU{ji==+Qz?M|+ z5m!0IB{7f2>4X*WO*L3W!_1E*ir(;61T4^uQUp`xJH*{>6v36cvbXXD=UTSn)Y6OLcxpcaW zG`gnx?mL@2I`5iWXYXdbjhBAoFuJa%U`?c8C8%J7jmrC#k332#En7@KiC90CYd!>7 zG;~Wen@}`9Q8ZmkG?^N zY*2KpiFK@mbZl^DExBf`sb_7Fg)JF{tqFy#US!mY8P*Cd)o?A`Dz-xHmwE#3%-Y^%oFjrAU7bZnlK^r%WDN#}S%p&OwplB*oGzY8sYgBU@WpkL~ zE#cFqkn|=c>O3bsAs=5NFMA@Nm=-Uy7N1b+xB7TrP!a&@Y_ez3X_f0gygl6VnX@Ib zyd~7WCHAN#BBLe5uq9@xC0L>*s;wmseuo0t)_wSf=KVFyJ8kXU(0}j@6g>#~%zB3$ zu+8(347u>i-n7f!(0}X(+~Ga#h-L4gm~1nf>=K*o;H++Qt?p8jo~a0sV;dsfff%W7kbP?-lE>y>})M2t`JKfiQ`Hn*sY31(zFz1SHm$|~kyUkl7Fmd0A6c#^AUa9Rv<>dM6!%J%1 zL1|}dZj)Z~c)VK*w)~rmACf2 zG|=(HAGNWGYxpNUDsv*XTGSoyOZ|PfkyFv&o)d0BzB<1KdtC>cYj)7=HSLr#j{rK7 zFg=2$^Xa_Fdlwlsz(HkzY}HD`^LEpgd6jmhrLl=GI%sPvUtNU zv7RdpWlAhppN~F+2)xi^ygk{J5G;AdpYfg+O_|&+>hhY6aPzR@+95K8=rI{WsIZ*nUTR z*622XiP+72SzHBifGEzY)dZxR?wHzH~6P8tEc^F{Nq4+IUi{A&1-`q+oR>QwUdedk;#at_+e~KO2YK;v{ zGl(&gTO0mFs=IZMF1xdEPar2X4GV=!vbfV3j=8^Fo5Oe+aDfKbaGh{7y|>C#;nFq% zCyn=FmU%c+VIa(;q(;#9=5vT%3s9k7gP8q(@&%5|%67`_Sj!d9KX|kd!og^)H6(Dy zW`repm0m9KCs~=D;{M?8u(211W{?2zm>3{uJb5fMwu~;Ct?iW2=Q^u7>p6czFyTX(Cngbgql@IsDx?+CQ zml_y#n>BT;65J}0!Ob;!`_<0ak<#<~6%J=TcD;S_^KK(WuK$J(Pq9ROIek6%(n7-w%-CtogJvP+dLU3O=5TjEI%H0t zhvndtJ!n8^;K|M`d-go9(k@CzX(l)JYPXasMwxWeEMu@Cu{SxT>O*`1L;QOI_}W?-v@% zT29wWo0p=sA6yPz1>Zh;F~@oFy%k%&P}zTmJovK?hUz5nHdWN*{aeuw%I(TVUN5c} zMz?}VMs#$V_6Mr3n}zUr~b zo+?k(lt`H*Ie+!)-S~1`d&?}_N4Y{VBd^N0f@*S7*-Qip8$EOdYZCKTw8;9P>bqbV zxx*_Te1XC~^HE>gQH?$9%pKYlE!OGICMUQdkLvSZ( zutYBs*t}#(=~CK?ecjOy*hQONIrk{{;mrmLTDqjD2nWY!i=?3Js{o#(C}_dYshZ69 z)U@Pm=8I;2$1w@|m8lMn7MB>dHN`-J+o@Z{J0TR;-yZ`^0Zs(ij10VFrtqas{s>V|645DavgK5Zl~&QzOjOA2b1t zA)_Z5+TlLU*Fd8K*KPYenJOC4w#AkLVB-OoXw)aC1DxAkh;cqe5 z_j2(FzWGaOdN6Q>5pCu?v;7zl57KLzOEm&f^2re+fOs$RxnEULY85XJ<+dvqJmAcN z>jge-P7`8(+#IYA))Jj>x(Zi2+2mcnz=vs&|`01B1h=xw)fjfoVLkcR@&j2 zsF#IB z+0$KX-lI2(qmt66t@GU9^j6%n@deHhIQ^k|j~Q2+RHDY61!t z$SQ+_{P;xwYL*t%ap_p*Dtwp~5a#XmEPF|CCg5RI6jgwtf4?exTh)#bRY&K_Aqj z3=w>Xfo%;#xL}<#`B!L z3og8D*DUt5Uairl|FJ#sT||eO>P4};<&R{(Gon*BF3v7VG4_x0gok&#&D+CsFUQa- z*1nS(+q_J{Q$tAR!$WCTFhQD%awksAL-5^Rz0y6P_&ifY7$>SS9(G7^ z!uV-Fm4vh4^WJh7RR)>s0O`ez>NxNIXK%_aubN5%xMj!TNE%JwNe;wia03CnjZ*GO138np80HQ62ho#(kT6!);sxa}$kUTJ}0Ekxzuu(+;!I*1S8{E?OM-m9d&#q9|ACGjLNH zDYKr9tIIpe4vk`(*ZY+;{gMs-Uf(UqZw}s0o4WOsK&|2<0lNwof8K{jj2Z<$wA}pc zq`dI^L}x5U3T?$ipRV3`A}iHS)U{>JjeEzhuW;@=z;UgA`<=h0y_RQ!4A^)VYCUE! z(o3EdNr?B+DS0Y=1&q8md7p3k^85+tC0x7PC?J;F-Rb%DMyhkOkThs zm&Db>RZ12roa|)D8R_f6ZiN76ubH0B0Y`z^z|JvH3Y6CDZJ6d>Mf@##J*eG92$qcLG;kI%VgC+Hp8uE4PZ2ZGK9KlcH|qc zBp$f3Kz?>}{qW}39AS;~#0^Uy^&?-#q*=!JA-xg-ELj~Tn`t=>gDF2rkZ8KB)iDF|sY?pxTW-6-MWC4s2(=XN^0~XLE^4AiF zZ&c6I-gyb9&z=O61W>gxIA+P-FVagDS zX|`C;VGe8!DxxyKyDt}HYU<;BT>&j^06SaUO5zb}gFNKcv;${7WD6wAW&hh!$7@-rXUS?M0J|M_WvYwGRMzkcTKl*-b`c4QdCb6)R ze{6uywT5k~6#uYZ@H{@MbMdet6wTF68SHw58-Dca2=PN?P5O!qUC#KAVEtI*xMQL{ zPK3|*zr}wgeD9NWmrg#`8hg{;ROoq>u)5hU>WQ;^Jz#IihRflO z`5Si}arNr>ci1wmdGaL6slKOO6zA~~bXXWDTMAs<%pSLBfsA4)nkcs&94F`A^AA)p zcG#or*81_@Z~U(RrT4^@0pumGJ0#jWL9L)Xop#eMZgs2r@jc{lobpb&H7=Fk`uBF& z)wZ@1Wp_hPh!fUVz+I~9!?~1UQoA}r5rpq%p-bIA_&R`c=NgUhB!E9JV7zKG@fBIo z(9>%e+e&Hq58TW$FZO#m_<7?Zg&b}~rJW>ND6uI-#RKGUJI9lxNYSx2EtfYpV5TGz zNJ@ss%@RyFns$zDj+>M(jrqr$6SF0Yl~NSocFQA(EU7Wt_$p?zC7XFBE&LtzR-^s zfYT3uJALS&s#`%jb<-ZIxS#N(-lvsxc~zcs*>dm>!?yK^qMB{OGmv{p=Q=t~}*8-?1=Yu!eFM+3be7;(KcOnf7FB zH-nZG%2m|mNhqplW`ot&eJF%ZT^2!)F zypT@z61G5h@chuUEGCMoWRxwuMKRDrH^%Kp_jc?i*)LuAw_lS_0ja4wbZC;|M6IqQ zp4-=x3GFr6rfsQ;h^ZExpgdInh_gu83umL@rlL-V1%v&gC=cVHA zBec+%&j&`H1S%xx!KoxCLPb8cwY4r#bX)tUjk$g@NKH<8`D;XxfoMJ97X6KQLe!rD zaDt!8G0dSAPCNt3Y5A#JdKSiB`?&!@&3xG%45xV`bRYrkuQvQV@}R91#5=rgqW3$SA~`d}z~`|4DPc zg*1zdJkT4i%Ep=N9&ja2XsX# z>QL~JA*?JiV9Fl2Asar zW8IeVpWkL#3PVut5n&g}W*7Snnnay84fJ>7dQw%L`My32WH+sSQ6}JO9v54pR2x9wQFBsu|h~>L4 zB~18}Enj>m)un79`p_oiy-?z&LkHs7Z_`y?37QZO{l<_g_f=&|`)a0NIlj6n)^c$x zG^KFD=@VXe<>%@U;f8$J1lDYps1GZ4co|pGZPLB)7aSy#afGJP74?_8!k`F+6e?PJ2QHMq2R+jxh`jYy})>&%)Rb$L~bIQhWCpPKtz% zreEgiNugKDfGPVMtMlIc6laT$TkbboyN8TKx?DgwTL7Ta%UJ#{Z)1BZ0X_Ru*6fe& zdy0cTC6)2~qfm~H;zllWlUn3@KzX^!B)oT_-;DeAmyK(-T8Uk&!{y|WgJpKLQYoOpLpS5NC2I~+1+g%TbZ zPCMf~uP!a$1qJxBeggO1(yydVxu1y{+}j=MH8si{*kdB9ZHvGuh3y}H`e$KT+j$Ba z$~*;#COl#M-|odIe+~P+GpSQRlEjN7gTLL?IjCQgPZqHyq4FDrDTlswOX82(d{a2} zHZ%d9KAkeQL<3zZNjWrQNF#Job@^(9oa4Z%hb-*o)-T7ktNyJ?}V@0YdaXF5x6>EHL zea+NWwIfzf^Y}wwtAWP(p^mlmru41GnG`l?*!^gv{{TNFt!`#guTyi@%Hz!HU}$f9 zQ7|1{|G>)LfaVy7<;bw3%L+i5G1JAf*DTg~j;DU7QjKx<{9eQ{DU00PcyyuQDAN1; ztaDK`K5MMv&B*aIx(e$E+aBtb8)U$ta=mFY*X)PTW`(pUMFWbZgEN%u^Xh|vs|sMB znb=JQ<6d*1w3Kfs*{#iowT31;rusvwJg#TG)B?r;jX<(r*aOTkzsZU|?%lO3J;ao; z0wS43a~do?d~Lyo<>_dbN}wfMwEe9|`FwaGT@ZD1iT$E4JZQk^#Nvm#^dL0HB($Bb zrBR#mZuN_uSm(1bAt+HR1NYkKH35Di<13+V`LmWG-ArI^-IrNIzS}ltv;9@f97v3q?dUrxwG|E6@~Ktu3c&vatg^D*M9$ zOL@Y-2S6sZLlN3vOvR_v-l99iT}W+5c=VCk8x21LQyBhm*I+f)&(CDq&X~GexnZlc zvEM6rxeXerc~95azQC&!+WbVG1r#K4B^N+l>CJUyF9xw5_li927f8;T)`k@1HZ7U< z(Bk59XAc{GxjkB|+)OLTKAd^Da)`HaF+^~AY&RXhx*!Ny3sE0-f7QK2k?#*Oi;!^; z#v3@RD;{n8TxVg8OFZu7&Zn}-7pEyzf2y`$l#p-QVi6!}VsXJdM0n8@vqQ&5&ta4n zBpF(UROCi>#x9X4e?clZA5#6I{}SZJ(`Cy2714*awKs;whQPU#52-wOv71F)*4#pK zZ>5{u`;LAL!f)>UY=K|cvKC`=jcSEpNCoEeuGp4+JDE#&Eo;!*sM~jqIh>K6z+mZ_ z^lFabA~x8+LP2QdDFFj!N$#R)nGho}U>sY@6cy~T8a7&DVVvpj?@W2F%V-}sJE-;Q zC^f<(6Rsn)jO-6CFQS*JE43Aw@x^;u;J_c+QiXlm>B^PRVpLo&{-tyA7z(Q9JN6WP z*0ynwvMe$lug)#()i$m#D0?;56jey%xezif!&^R_B`WzC3b@v zlni;S0^4S(90?V(0q+~B)B>qQFVx3mhq7bVQZ?G0R_pH2>~buJ7hKKE!{P^R4h8P~ zep8y+nA_4@;HoJ`<&eBk-^mW|jJ!~+OX$?!&JnjZkb$mjk;}oK*lO&&>O>y2vSUXHrx?y3f^sa!f<@WbNj@)g4GhazP4}3v6HH`+LJAD)a?=EKN#Jx`G%ZFWe-%pWiBvlu6Twt7K`XmEEi3feEoiFgq_b4aNcE%Q-BupNW0`Gp zPs5jicN#3VGzXpLF!+8CJ#289(V}#Tpl6h#x`}w)=n>ED`e`}9wZE{iQq4psAxe8l z6xNP+DUH4Dn-q%tt<0 z)v<(XW{0%y9CFbOy6%hsU0CwgB1hZ2e6pmkleGl06&Ba!^8juBaa3sXD6E=_(~U;lg2;aYo_ctIGOKO{Xo53$)&_>({vLQQPQQ~ z2jx`tNyQ~eM~Qwr**uJcI>Vz?{UFbf_L2a0FNjbd&|DQbJY|zCC$dzL6a@B!0yHFKXkrv8<)Q4QGJVt$JV3f4i&?vxn21PdNJ`3Mvx?R zOK)oT#QzRq0aovLe8US(3y9(T4Yz1ux#rwL_3z%hQeWSH<5=KJpJXQzc^5{6eb*v8 z+vpw*P(gT%p>#UU8!ingy{8c|bu<=e9ZQE9mjK+0qZhSIr}fFj$uT2w9FKB6-f=7o z<%(~s|F|gZ)Z23_cL*FH-@vFe)8tZA#oW7BQ<+RBy?oQQ=qf(eQxX1+@(MsRB2w&M z^}8cWWv|)i5hy(KyN;$8aTOp;uU3qKw!Qd$wN# ztcG$=-eeK5`&0kj)rKU~pTB6`qTGepZ^yIuv6r7w#1ua^@3{m?-BiCV1Srz@fCiJi z7rjD|=9=7T5{+QQ(*UkLNlo^!l~)02iyVCs+pokn!-3$|!(U<64@drM9_>uXV96#2 z+R7SAD*-baW3(WkPn|+( zmlT|Q5KUv;aAmR2te2UDp)xppV3I5-c(satQC*^*E`)L2{wQcswlxl%;WP>OMqNy0 z^ZD-1FY|UZ>JAFiaUVzUrfx;FAtS1%%X|sENhLZ8hrQ%e&fYp}1U`|ET^{+Q1*mFg zAt40zUhrkj%K0Dno*(4H0;OhZQ6Fg4Id6ylZE>M2BgEi1_3fMPW%fmH?cAXx)!$Q{$Xm z5a05sflAC&W>#^#iuwJfJG7QmGXc9ANQ{EkSm&2)5y3Cid)m59lVpX}i@NUP8s`u4 zmXdT`1K4)=-`@t#40kBhi6VU_fSqKCF$GR)_NRW^dOmGyh>|>{k>*pewfzwV6J>>9 z;DCdu>^>^8eou2;H4E0eoYeEy*TN%8DunieV^U#>jp@%zUV`eto|&NYqqYKes+3>x zdKx3+`4!%0 zo8ixprn0X<@h~YpDiAD9Jwmm{pbF>2+qQbI4b8_Ya*P%^jdLF zKfC!PG4j;rDeqe!Kffw0oWxXu$$=Zeb~s^c#XGwSSWe9&i~8ZQNp04gTHXXKq`Ti8 zGqPHhMAQviA;~0M)r+sB4lAHpH=}zWakpTXNcNhYVjvnp)KltGeMmx%N^c(xYSJcq z>*u5C6*idbGH2EMbNeYH>!h(U21E09v)ZJbgZ`Uj@?_@kFQRExJY}u~jNY>WTPhiE zMC;X@ZQduKyH3H#!Qu>ZL4_nosf^F1dOfBJ(HN+twyhrT%F*Zc4lSS5wXhHRsGX@* z`*JN%m3u&PJD@ZoQp60U0&1pDQO5Xi%>gkb_+ec??zQrZp# z7Le{*zd?Mysu!rIu)2?V`O{^?62Igcipo?jP@@ujH?r;5YV;T(H#Hw5qTaHGte$4P znkDg@$~x@cREyidKM&0iog| zF!@RAK8rcTNLbZM1tHJz27vrg!yIU>l1Ja+T9C8g({DE&e60*HAwmOUgtgWZ;Sz3` zGC8BU*5IUc@_A8)QO6$4Nj|Rgwzw}yh^P0K9O}tpx7a)_w*w!Zh5dL|@aE!3^xerd z7?j*THe=;n9E2TKjI6smZ|lOFmQZ|f)}QzOuD`MnwEaqC)?a7Y#9?`<@eitcyzuhJ%h^|+rf zNaeW?SD6KrNc7F^r>$c8*4-jcOuZs%3mV5-fT&Sb6>+#3LtyTy8>XikvhpXBsXXSF z^nQrbdVLaxX3;yPZ z&oK3|5T0n89NSY49b>}|a9o7CqQ-0@jN3o;#O3pjK9O#G(RTJpUSgsEd*G37JLGlE z6YZZz(8h7b89v<8$v7B&KZ@2T+TJZPq8!RQA20S?u-a@2EC6wxg@O|% z{8!&~qAPs@S~Z>#^fKE=MG5@0q4jq5di^Y9`nvSOmziy(G)w4rnPT8`lW5gK$&eJRW5hhjch{=x5;h~BHRaO#nsRBnDS?14pk4Yw{9(U zSS>%GtE!Kg&Vd-NeBAH3Y6-XQ54pLbV~TPPHmIu}P* zQ7=!aa`GC-ES_6(Pc&6WD?Wfxz0umiVee*x|!(NM-1pU@*L=A#dMO++gA zP5Hj|WB;X!t00qs@5m%A)&=4l{2~LDVcP4*{0wvCg_-rr8E2IKl@q(83X`~LPW;mw zku3Q%e~8YDiD2`%!rbHkCzJ+j`3Qyh-iWCJQkT-RZ!aVd3-IaDj>fr}6!g4lsnex2 zN=Mpr{~~&BY9Uj8uQ&FedsK4GOoNN8<1WIc<7ht60mXk{mIV66Kw|hgsa0n5+GY@Z)&Uv#5G= zQg#xg^SV{3I>{c4Sh*mF16Ch zR+B=&uJ^4D-ZTQ8JQfCcFvwb)88~ad7*c3d?-AMCtXo((C!XGY zSxSt?ppcF4-U(60@0yqTp2lYL4clgV6CYIfzW$?EfFC|xJ;oUnHr{!sYq3lS6PcSP zx?4qP{1W{`jrg*6JXlz~kAvKu%IBekv!Sap?nw|{UVfu;@l!to*Mc(v#&2odmaQ72 z$+_}k$pP~TqECY-%fD}?@Nw99X~9nc&Yd^DyoBVdk(^K|CHsi&&b++SL{Cvx<*SZ4 z(@+d7k6Ua(`qDf4YL*>?{Suw+7Gy5ABXG_chAWBv{lfa+)^rMg*@if8WAn24|mspzp2~qBZtzo8uC~ zSJf+@djl!N2L1DQE8*&z2>C|YJ^?aTxMd%6r11Q;+k*MZ?yJ4l|MM~|Lp%_f|`FfEQ}DTJN6>iF>p4oiJL>Ya<_u>a-J zMMuB0pmsKgC6oEpGIXJObG!(ZfvXi`WEof;%o%SepC-R3XyCO&!8<63!XH?qZ=&HDkRWgE&JsQ+75UkcxxU*W#hLI!|Hc0Cl?EK#Z8fwt z^jVCy8Fc?!FG5t>0Bbj&flhP$y9UyypA$_>hKbH{OKU6=NM8yJU1FY-b7@6{t6?sM zaJiHzwp&E_OQEE0Wxp7EW7K-wlsMeb-`1?dgjZ`>2X z*D33ii2{RqwW}e#1R7maCsYmuQMjICki-!FHk3uov6)R_ri9B&KGF9|6{nPl?+ijK zw5SVZV)WmPO)L4y;%bGeXZJ}Cx0Q9?vo;)xC0=af7P6RWf9V8LM96#X)pPWb5Yy_t zXCE-9QIr2{nitXA9*ZU)qmKe~Etei#Pxep?b>lmChREEL9e4h-fq{D*zeG&<^;@OI z-km>K#K!2m9w$E4tW8|KXdwr2w9DsU5t&!r(+1A#iXc>PmRaOX^fu+~f2YVi6l|*E zRS=y`=J{32cMBj_r>7xH_}`l|@a7otv-B!Q*+Pp4|_kppv=MloYyaD zQn!vH1_PQSEZSEWd*Fx|twos{6{!sV=5O_$TtTCyaj8j;4~3;0^y+>mXS(iDElcu! z5qfa4Q!JT>+~;b`PV)U?sBRc&P3l%HJEY$BmF%ze!O`;_IG9|PS2<7i!zqH(ABOW; z1eUiy^=~EIGj;uKb%PLBdZT7)|Dxbx7i=Cv_7v4Zb^m&ztLC+vPOKn$HhK0}Kn1B= zbYP^~JF;glwwPfQMtonsdsTlj;ZH(b)V;R-98!!{G_NCjU`9r+=WfCudH&@s_X#(5 s`-o>9CUy8fue9fC3LqdnFF|l{Wo~3;WJFozTfNl{By2zuJ?JpUgx~e=b!Ud2KlKxPdhx4lZ^O0IxIH?j&mS8%76$kdp!M+C$wvU|={LdUD(w z;c9-{<-rX*gq_CUVSp+PFR${yv;GL4gzvh5?ZLcvyxbpvVfv1Dp)L>vTm>K_Ed}^H zr~!6!JBdmE#QBx<^VlzhpMf8Q>M)p{-|rH&+@N+p#oe)UKdJZ^>^~4sv_T=@pH$KS zUPma*-43Awu=DT$Lma>-4S_m3!oepIAVA^|i?YNol)wF-vi^7{mHfMg-|hLOz#a;L zfb9`3-Yy8g|Expu|EEJnK~d&kQvNrxU+Uri1&^$p%s)#04?M;vRVkbR|7`1zIr#5b z6#v1ZEb%`&sr2IDP2qQlKm0P%um4O{d*YGHxb01XO2&np9$-dB(BcrD57q<4M^cwbQq#ZBxx z1$XY0s0Mr^j&=DDmJE*5HRI%SY!?$Nm08g@W1u%7yhneXq7%@@Yl8OADqL2)w?F@Q zE}nlnA_&A%7h(|4Kc@_SqyT{Monf(!oJD;|->n%?Glku-oN4N^^@%oD;}jk`q(t#g z$2U{qnKtMec62i{?H^GGSQWWCU*fHdFmCMZ_^?CvFmd>HC6Q*M-U$nZ^-HN=&+i7g zbSvWBgKD!@!)M9WBj|`;+}n!1cSH}ZpiJvra7ickb}Ia52!vi2Ax6O>kmKX~q=Q_gb%07Cp6Dst?ZmN874|*`lfXAhH zdFM;*Q@#kcl-ukr7r|FznL6sH0&T5X2%r4THT=Y*@x+hgyYG-@BZ5e>-UJ-aLko1c z3a2OT)oKd$E>b+Hza3rhM=Nfd+(jLt-;};{B~ZlRKHo`F{DSg1Y`NPe zy{a@>KUnC(!o#E=-TFRozl=_(oFR9oBu1kqk;Q)ySa=GE6x}jk;M5qh!p+XyQwPgF z*A>yUQ2oS0eT+uL_EYc{P8-YdG})ZChsf@1be@wI{G`VI=;8#?&r zS@nZrX7n06Bdro9&YGMv4?;Bd-&=uaR@gQ4JFeS37jJCl2^hIb&r9B&8P%6Z88J_h zSogS_>uu*(30&s!8w;O+;_N_b;B#YoTuZBF%|Tai-P}SVg}NKoPh-XjAEF)gz0WA` zG`}5UdvX6XUVBamaxwde8F;F{rY?(;9|A94Uz%_7;vEUGFUyeU9Mhk*A%9np7aS59 zOWdkZx-vylcFT~SC+9h+ft0kBZc9(c;0nfsdHPP5`;Yg|k z!!Uyj(^p31szUt^&%9YqwtCiH8Mfy1Vb^nA-Cg~=Y6XWU%E=l>7%8u#zF*2;?q8n<9<;Cu9VEtxrNm+!WpxE zeD2n$HneO;+>*#Om^~RMUNvxzrv6acUM`w!Xvhz6=BvCfbFt-So*$_2sMIMU7=*X&;Ue;H9y$Ua8GIMqkTYk)zx(wa@xGBjsMHrRW!(m~Sd5>3N{6?Z9~!&5x52SuUG=das<{6=Fjgl<@N-tmeWxwDq>Dz066` z5==gZ7X_mjAmr{7@}xT1#+f*h%H2V2jkDW4sYy87T`<0{ZnP(d2&EV`b2{wgqHdT; ztX*~u@>Bwbl9TRL)Tvo6D6SeI!Bi-}LSR-Yd2F9jP@k!Xpk!TwGJ`aw&E&#=X6 zk_yB5aTyA&gz_)#P+#S1V>DM0W$xscDvmbMrA%ERR#RUz2n=jb{5(RIye!gM=#jM| z6;tXQp9bgsE)Z(flnutdzbU^(b$3u@+CJlAjIV*#v`zdqsZ>(%PZi7{!+7vvOMI|X|?2C85PifP%>DhS(-g-nXcibj{Qw7d@YeYC~s zrBDDBI5#kmb4*n|wA>di_oSrJu=JxzKOc9AL1n%(lvyEt(r$D8hU~OC&Z(8xV9J)?Kvu9mCWArYJ#G`cO3o278PWI*f}h* zw(W&Tfm~-e@XyY$ACEg*#&_v(Z^h5XZ?tA@CC|#UHc%J@>sUqX0^-9_ElR1)0?VTG zs|WE_7~S=}g@bs6`aD~cJf4472QM(A9WhDj@ek=r0de1X^wxn%65CQ9tP^k^P5@omvb~=1k>AcP@@yxM7ZGNHowo+QSt~9|a zUcSp@+(NyNp4!1VpOmx&6(McxE9rw7P*JCz%iIed;n@F z0Iv2?#%9*f!9weks5Inq0-WkTZUu%dHQCH0-)v~aR?SPNpm#R6WrcIJ^V@aqG*21d z;;hPZ0m&9DQ1&j*-;8ZNeEMOb>y8Dc{?T|_ih%zhI`Yg^58M=eccW$ee#^cQe(%m3 zOuBiI?LtUHI(e`?H~o=G0lGQNa3_5AHrTFC&oQSFQt1qCDl1%54&zHraPs! zwRX$TSfHZ>D#5wr8$ye@g4qLeekb2(uP!M+?LOZ?nS7-Np7OYI+_GAmy(G&vzLn#+ zTEc^?cchDfaET(y=2)FePFKVKQL)}6IxZKDiLGUJmP#OxoUZnXW^&}K^YvLuO3+B@ z4!{$#b6wCCBJx#Q1JYCeB!%Wu-VUBOqQl8=i(gq5*KFiBqDRuLiw(BPIgpovy0u5n z5*!%6Jdd?%siQ5 zXU?)sYwzm!s*rX;(w`^ETn<*7txZX+*|Ce;-=N!q*c!OQt`g}9#@^5PHZ%en2FgYa zw(HOsIU2V2lNZ` zHhQ?bRDMXYkD7?DR_u8gsj$8R*_qnjMi*LVWym9|gpe?`i%uMbH)hqeS}`*Xw}kGq z+Q#gWS33nbgz2b(Sg7*hc$+Bu2@iweLNe z`g8DCojDHs^qp7GN$g~H=jpyN63{25s81v}?A#QvslFf&ExPBsuq@{>X*dwHWtt%w zn;ay?Z&M!{{5hadg^vR+T5&2=g-hAjsc9IlZw_=ik4!`bDaA9$bd9HRmp0+@xh@`{ zECMo55h*oaWQZajuPjq%=3VeSGz@e>Y~~oNJYtb=ow-o2+=E+7{wj4Q&3Iw(eGM~_ z=}Bz%xvME2uKI`L3Je`S7ehr>V2%x<%!7$9kMx7Kly?sr;m1W&x?@hRmuP^=Yq}J1 zocBv~h4;==3^BZLMZgkNVXretlAl`*fw44y+1i*ig!spSeVC)$oj2g9VccbEGt60` zEuA&yzj}8{M(UG;wc15;rmC(5e>_^fHKe45c3bSRA4IeH?VEn7Ks+u<{$_H#-jJ3r zpYO1ucdi5oMS9N`A($w{KLCk(iF5^^(5>POlw(6&+Mo-~HFSku%|xAxB!^sj6wYr& zh`^P~Dlxk5L@XxUaYA`z1`5M}y82M>i#Hc6g?*BZ*HW%yrO1#x~`V0SzHX zqe<$V^aaq?y&y#_M(_LMCA(PJGlY+xVvi)ZwfcvL(BCYl5>=J0&URLh#_z0r3~cCC zQ`utXQoFLV#?*Yh<_^0eXfkUNNXf5aj|j#;fJomH-$_zs z9?uUrtj}j54ivv`1dTa1V9y9^Ot=p6);X`Ap9$pSI1`q|(|--McVW@3qHVxZ;aLiX zXa6FRDQygzx<<4`gBPcJ4lbD=JSXj6W_RYA0_i&5wepnyRFIO%h+rf(t}aje#hN#i zX4RV%TA(?uoKeh4ccvQqDrN|#JkJ~QkgGeOyfxKD=DN0BC&;Em}&q$xhe74|JIOGN1R2fsX+eV`xA{kh9x17DxHhZX;pn&W#TDD?0- zk#egx{aYqy4_#~KUQb=+Ww+}&HNz$JexSD`2nguA(Zna#ydmxbxh&r>+I%0n%VAyrzlOhGcqP3R{+kP zOb8E*F#-j%?yxvmzQjPL{R|E_Cj=YZwQxZkD}tXoM%WdKosqMbHZ>#e%YcG<0&#z7 z5;X?Bj6l;a#0#l}?Cvxl`9-nR6C80P(6eM8)CEsxPzoqXDyy%w9RPt=K-5_P~3R?zIVCrjFi zZeXG@7Lcx;!?HC=v)x_7lKW zhu(wdej!WQ$ErZcY=A~CMtT}FdWTqY@4)h!Gg50iiNg3V8Bi0xDrreOzB9o28+_;4 z{Id1efDVfrqxTMzGecE)#tjRu8ZI$eG^EY<#uH*P=AgrS^^MAg1JIeA~p@q!juM$3ur4Dh)md!!CJUC}I&#VlEDIFv#mY(^oSSs^Y# zA;nN3sZZfA_1kT99Ze7N@&0bD1)QH0qS}4w90RY|UJnB@F-x;2NK+b0u^399>yzTr zNQp~9r^hoP=$z;Yj@$&WD#3}I)q#)Ik%`rb`h|n=3rF@BV8s_slqQZWCSX|; zr*nf2VuOxcgH9B34*YVC%yQt1? zQ9fo#$poNqf~2A$P{2@9Hu+^qT!3F9hzPZwx32@gLblJgS3VJ~jL54DbFGY7u6&kS z8ER1(JyIE>R2f-a8B5xu#Lb!>yrlAd9`1{tShqm7eDjNH@p~e;M-e+&x(x`xW?yH#^)(iXPH&!q*do>>t=%wFonA> zzwM^;?CxPv9YRrU&QYBgqgwAredcYpvuw5p&PbE@Npbjii1kS(E~Y$YPkEM-5^BcY z{N!r;OSd-ql}4ttkCc{;UY1?wMnCC|c8HC(xsP_PT*brko6dSW*u=~li90C3fr4;J zc_L7PC<&r10!9`IMPe0ni!SS8W!j6BMT-EUSgE`skv!}**CM&)BJpLcDn}6?2Uaq* zh&{E0(xRBfqU792G1o{5vr-9dbumYE2~|KbTR;g92~I`@W2Azg4ToI}hhNZ!)3v}j zTi~YzVdn+mm$Kn!oM5a@aQb-|_dJ}54Njd5V^4-tn!;F2iTuJgHD-S%{o=2|Ci`Q5 zuYt*Y(^Bin$Z4V&{V5X9kgK_>1h7`h%3}wh1A(bX&R%swp z(IBNVthFplhLR?0z1LIhz0Y~~Iq!#ezyA;C{C!xzb&dCRU-$1GmXmrLb%mzRnMzQ9 z{QSgZLiFd?i4V^B-y@}8nhANrZZZCaYaGMJF>lhZFI8T>Qy3>ibXU3FUtSC-|Dk`zy&r zUO__nr-GZ{B?Jk6g3HC)!P%1##kzi#M*dOC|5BkKL5{~wMMsRYard_La&UF=B*aAt zVlEmdw$cVyXEzTUPfrJ{gEl(e2W>obCR|r+#4#tv=l?ano9jV8Ya6@2tze>AnEcN; zzVW)veJnlxzVOLEEB*EHXPm%9oXtTSXB!umPb{9P~~8m6T| z$IUg~03wm<-5-Bq<7kDIg+B$oWNasSLj@!JynM^Tho*zm(|%&kSBlJJsGJ;)~?8ZoQtxfq{53$Xg_T!!&k-Oz{u@$ z9(7|J*d3$9)5Ye%o!R;HBE-Qb?puyZabTLp@9v8hall^buuGgg2c#DY38}B)z}IN~ zElam?fKz%|wtEi;tZ!JaO>yQxqmbFzxWgRa2`CAC6@vacbF7A~*l?Ae5Lw{FhLn|o zx=uc9n0HHleaJyJENZVjk?q9>^Ni!Cwj5@|mNVh0oNzWQ+8k)wS?iHcW4hm6oVsLuh`7l<8eI7_=$aja*?v zjQ(Sdp)+itxzxw54rN33f{i-)LDceUu~C3&iu%MSB{1$bK(gyJ6vpR^$CLXH<)~P z(;@WB39G3LC&+!09^i0^Am6F0Y|Fe$kT2HmwHtj%kX+oYtL*L&WaNj{;m^tmQg?LM z=39>mvc$9T-G+LCJS%^wvZ$6Ip9~wyNYoLek#O*%;~2kLnMY0|8}oTqNj!}u$i)oX zR@+R140-)X!?&0q-CP%Yh1(J2g3f-qE`NeFxU}Pt3f7n8T-UlM6z5}?;j-V5Aa91r zReYO4kW$J`m0UbHj^gR$O^XQfoaNQ;ExI^gdqM7f1VOgi@fFRIMx5JN+P0A(MJ~-# z*3%-$D3^uZuRe3&+>-WT=`ap3c}h(Ad^pg`Tp3SRb3kOWy8Re0L0(>Tn>$T_AS)Ma zR8}nGK-{zQp57YhZ;|W~jO%HX&a&8O!-kLdg?CNPXTz}-lejmay~|~9US|adiUW(( zW09Ad*|hCNcR4^jdLi~D82Kq#-qXR&fv4Y?0{g?*uvNEv+Z0DO4C%3QHZ~%^oGL=1 z4{~6IM(X-jv@usYUc1JIFD=R*Z!$S>D{(Y~dn-Xs@?7(x|1|DPk7V^%7YVZawR=uG z_R-2qbsys_2fClVuDJ1*4I`Jwf{U>)0-v%|#5>sV`75CkjD5`U559gF*M0DKWP{NI zf)r0nvuj1({N~x%QG)AYXufyF2=42BTEu_~?h`xX6DfKJ*Z`&Gofd)|nDODfor69> z9-rQKrvv#k&1HkLC6#BUd0KNJL2lFOl6k2^kfUToZy2uMs#itB$^slXdSRwO5Z2S5 zX@B(EZVp@zWh5AfAYbjY=K43_eDpaNew-!9wl{83RyG7_yXc7B@AC*UtCIN9TF!yD zw`;TKznmTc-Or=f^78M`!pK&K~`}zzt=v3yq)!I{RdpH zq*pKFb8-DTuRUIRKac}4OD%WIOlL#Rn7)QOo(~&o>ym`={L0QY@qb!EkaP7iJ%TP1 zWVCG2iT!~4((O^TG4lA~{-tY75Ut+lbJbUJpyj1~)%DdJs9v_2$1Il(sba3Ceb&eu z6^k!I7uaw`Wy>vFWPa>iNe{!8^wAzAj~`%z&|IIIvsjOyZ>fq^78~AF zzV__G`+&zQrb_+<8_LV*Q5krjjII6TOJIGM{3Gp7<2k9YaX_YJ#Ue*>4wRT{Z!Gg=!_#%oN?h^2*f_P}z&sU#4C=P=6}pf2 zqSxS(_!xp*y(>E|N`fH69C#*8E#W|>Q%-#nu7A5^gTF{9qD94<)tA_?Cv0kKF4ooO zWhIdCi34d1u5!s#5ah~XUb#bf9zTc_eA2Ir`|{bN!E=27>G|^4EBhb)KJjkKpkCtm zNB;c$^MiNd9V*HtfIk!*Eb+&Pr}+xT_|GAHsr;+nt%=gVs`^LXRV)6d-c^&v`}KeN zPsZQ(b0vun>z{xBx_&Az{_pjZdZSLfQ{C{p(XVv>@aNz6OC_9Ve4M|xtHzA~Z1{(( z`FFa1ci`V0_;&~X-|0YX!9`x>?*pK0`{V0Vu0hCgsgG)$JP1=_7AIOy8ibL~nRB+G zzHdRR#A{*@VrQ9KuR#3#vS4Z}X8=BUZHu3ca>^z`C|Z9 z4VB)~L-}M(^P8RMR~`4Mc?;s~4}02Ypg+G@{M`z~@NElgA0b|yZ(gz$^CoFoj|yYm z)eD!VEJJ_eFH&AE*r(3OucMimH!pCz^Fx%)rEWZVj`jv_o(EGg-fxeWA&K$qAFE9) zQ12Q#YF~i!sCGJUauw|cdNYz{BkC7wj8NkXDp|A^V|{zJRsSeOIXm}UJTIcGor~Ul z%(LdZjQD1>Piq!V`-ZZe&8%*HMDOMqR+kaC4SNJ_#5x<-^OdNf+!XO@^Z?4@+V}Pr zqO5tNBsL4NWUg$y5a#_EFo){sO#+RqMi^IbvQdt6S)8UG zYZR7xpuEd=&nJpMJseR|1?zL*t9$bs$~E(R7sw-)M+7u&L4Cy!70qt!uYd5{!<66P z@hG)Ioc|Rfn6VY**e;G^8v1`!Rq;E5Xcv?z#K!zmrmdIfVZXzgbUPYQ-wNRJ5cS{| z?0yktV(Gg@6mLSrHr&xc{h2Xqe>ubhlN5OCFt3{8Vc~6PKP6of%fUPfi57?4Q6DkY zBl$4u55*Nc6r$|6beB+mBatD8Q_-H4R?aJg^=%4HF7ZTp-Z7J{_K4REcokhSKXF9e zWIoC^9cdpsG0r~IyZSiF{9n(HQvEFxXg^BnEuvPWTu1+kyJ>R^5npa;zB>v1=6>a# zl}pvBBNFb180}KjFo5;tWHsBoLfJmx;MNh0-yq@rybZC*qHO`SpBl?6camsV<1vsM zLI3i7U$*oi)?a;@<%Rk;r*#JopkGVm)F%{g!%hz}sBw6QrXJ@;{W_0F(k+NYu3#y( zK1&({kB#CypU3)aDMG)CKQ=6(_`UxAPA7eoY4)@B->32?7C*g@a$~@lRxQf*3!7do z!uVOwHP2G~Y06o2F9q#;&pFmnJkww}ecz1pe5ZKmav;hf`J1}aFphO{a%Vc?)r-q` zq7YY(t@$j0_7@tqA?GpvbF6lnBg$KftcEFEz~1OwfY{(rs$GI8o61;OiGDk`CDlK} z_(H{#_5vtJyCfwqK)dwxYf^hqetYk`mKMsOn7LRRu_8rMZ5E=RnVbg?qLa|6!(xan zK{h`a=pRw8@gf27C9U&@4C?KBPuWpC_Aqr4kwtwWx38cdj`u`iSv%Fo0jZEr8K^Jd zFI|?2xFW@x?T`A)-=@T0N31;@`*{GdPq07j1ma|i$JtI$Tm)*<(lXbJp0LFpR5F{Ek1D2jPar z^7%Uvy=}*Gs95IfoXI5&_dAF6I`qWChhtJ;=2w}%t# zHuGX$o})wh&rycc)|HzO7nqyZQ@ozcy~%qH%B7qQeFi9>dQ7-Rpj^oIElWn+Y&kQ$ z6Y~Y_lKY;E^NUNq|JD!XJ@ZA2G|@ii#YfptjN9PIxc)oJ{>oA3sdLMQx!W`DAcD=#yftXo%DZj46Y)&trYmC@zsSk&4mH0Je!n>^%e^=(qrK|;zLIFn<7TSWs)ML9&(-xd`c1PP&8O-Yc{x=j2K8!-q_#*Qt|;lh zScu~=FEct7@IIJYqc~+V>LUssDQ!W2AUYl7P&R0ByOV$@DQ+CChyLp}%PLOi83euu zJcdV5j{277UxjwPU8^=PM)bY6%`J_i0jUOWKelZ-f>P2V!yhh zdLpH;e(fSJ_5k-FxHt`SUBEiBHRN)s^QkMS-riu}~@i}`?cnt9w} zmZ3ei_{~O&XT!D@IbRTk3?p=fasExO4rty(`@PWlY-%5R9~Vxf?p1*gQ4)C=pRY6D zZUv&zUM0B{^xN5OtS5!@e*b=w%1i94|H!+eER>&~s0s?kyd~AAVy9!gnIvyxC)PJt z>3NVLj`P0WbOUwHo=aBt*@StTrn2@dp~f=^`XYq!anB_Kf)OiIR!LCjimYYJr*-IG zz`uJ|G~z%&Nues{*)MKyKZ+P2pZ~xe^(G%z&Zh3;?H`!a>rqZwurPT#;?@G!MvBi> zTKn$HAYQ8BTN#Gqo|)68V}$beYlZ3!n8#RMTKpl#i@sTQ_aNdtM;>j8*PTlG>=yJ( z4pVDck8<^N^=^vSi|h?YsdwH=?W2p8F<+o`Lz6t_+2zSHh{yW#N|nSdQ16#rR_cL% zAGUksav`p@QCq(cQA^k+U@PY7KOPu*3-dnDZa;AbZ&H8`Q&IaltJE@JLh;j}XJ z<6avivIyltnO9ZU(0`AA{Qe-sNw?IuoGsIpKTIW){joeo=*hPXlFsT_45IlIee zQ}33X*Yj7*!11bt&lH|P-qq}IpdG_LyD8M#eM0@J9cIj@7$;FqI0>R27KZn|LDY;p z5q1{+GxpqnPNJXi0mi%pMD1{!GlGa~`ez2nA@m-hwzjMPHAe?vJ}x0?4PqPoZ8 zcN7nz+Ow8!LfmwJkRImHfpXQ!%GA|}{eBn3sXE`p*y_|Ex*zDc zQGt5KNZL_?s`GZq+b+~gE*NT{?)lwC#wL|mhjgue!EuzY78HdqW>^ypim)u9}E`1^Jh$`xpe4cu?kyaL3O%FNfAIH% z>8)tDs4JaTg7NRFTzj|TdE{YKuBCkM$bv-TnHsQYQIs7f{U?yZ~VD#b#SYw8M_hIWVQxi6`A z-2RL!lJ61woi(R5pndtlc(Z1#%dD|Zm3m)VlItv)INpucDQ(oaIp2NOE=9jR>K3Cx zh}9nY%G7(ZSy{d066T47n`8{ix}86SLa|VH zAQnR}+mg}?>z+)yEsy?sK0Dquo$H0)%$KTPPV0r@Lro)lBI#gv>*dMrlXNJ$ncvc$ zNe7WN7rHnNbf{?88x#6S2hE$yt187AP;vT$xS|FFEcgipM-v8IY2p&z?!bUsZnr}Y z_4L5ivnToaKK4MMQ-|V_FFo-2$uzqipL<|&RsQs@$ut<5qF)vwP6O$}J0->{G{{Sd zowCY|28ZoJ6g9kQAhGvri|au;=-uPAhQFclJ5d~PQV1iF<=Tks5diDMuG`yW4q>X)%L<2)=kNU2YO+R zp|-NFZ7=ZFr0C9n-3w(#oq`QJnJ^=Dx$3Q5Ob9S)d2cs>eNmBdH9Xr3BV(gccMh^Z zC2Ez0;(Qi7Tg($Z___~Hy*oQ!Y8eZ9E$8?Oce7y09{WV6-}+(K#t-$iUj2A(X?}7= zS)1W^`s<2*h$|5d+!@&qyT548l8x;L2i_Iwr^EU|-$!wubwocT*q!~Y!K5F2Z#;Rt zzL*8>smG4D+q0lr?84FVt1R#lon@-_nFTtG;qNIieZV8xm2i@q1vfiV-sbtRV9&KP z8anDMNDYrFt&!^kovm`q%*T4+L*3O-#^qkvve22wV?7hBs_I+LH8LT4H1}31^1&*^ z;=w~TCL}gVb6zo-&}^7@{dO4>W)@~8gvazknvMNXt{(#ujkVV68!_Pad;OH0Zwyc# z4Jy-0>IKiSnQg|%ufmK~vU1$L(8b+oQ}&1s!#{L5&K@+FliHjl+}Q)OX8V8I?MDNJ zxURCt)pY1As$vU|G2mvRiGeBhx!ZT`n`u87VEyh@>`hw+?38G5 zy*xvwpuY#ApA^;|Z=!+b*i*A|T?QCjx%F%=#^0NkR)2ma6XX+C`@J?~KwQ7QO4%Jc zbewfo6}?S^c%vgF7eDksb||D8Dr0=u!Zn}s=wOguu94=~i@zgR98P}6gq3`y7Oeq& zFrslo)y|gzbw@r{CpXhEzJf4Gr@^N?%=<69df-{m+zW<@G)M~`IdHR*0ro{n!?{!X z;DJn9G0lkuHpWwZ4f|LyD|u}p7xwYAC|AvwOAIh-5HL(0qk-SThmZL%k6J%R``Hlk zwQOkf=eAx*RjrSyab>|Bg`Ty$J^CTTb50{~bU#G+xHD^UUEHLEZ6UuG(m&S4^m);t zM1z*3hx<-3SEIntlny~+5>tXF^}&3RXBlmK`=KI)b;i!IAM}ozb_@2i;JJ~8(UCqT z>^S4x?^fLl)w`AEgzce2np;8wy}Jiy-@T~jB*1`e$!4BsC0M{;PYgN5^}}H5mmRuC zSP;^ccqu)&514h&%Fb&rVRRBltb@aVbv&2XNIay0!R8C13X^Cc<83mP)a`=I@8Mca@n6U5ZkPJ4~~S+QzbRtKIV+VVv!bX{nW!Z_AO z;67G}{JiEp^7Lx8vG{T2et22!(APM^g8gI&S9(1Y9Lvs~`;0uaU4Q<2KBA9zS=BJs zvo!j;O@0j>jG4dhuJ@t=_p|*Lf)o#@j7-zQbB1gA`{8o5tG*afDrGZZ=7M`OsQoTg zyg6-M0}~=mw^(0T#svE-)5Dz}F+i(WZ%|T<4*L2EO*we3*=gV2XC*}g(U;=3w^t$G z4@XD1TQR_A`jPN&$m8o$%hT6=VnO5AkF#5YS@76VWwqj}J}~zUexAVJ3+>fL#-0za`yHaprh_q(SIH@WFFqTICWh&wgN+ z-4~G(Wr69kB9)Wdd%^TV)TKAiXt3YaXsyVS2 z3S`8UFCAk-?d<0wLt9zUAlRwqjQmPEliP95ngw4EZ#>;()(hGfbPs3HY2dYPX~aHG z575RGJxS!NN1JXA4c8@5xb!}~oCa$LKF-{Jf&uJL$9I2B=>s4CZwd!~?+00x%jNT@ zvw&W9$y!bb@1wjvA*&g5xcuOOnV=^P;_TeGEL~~vG^tLdn|cpVe~%YAJ$ePaA@B{m&BYcrHgzNDoNJeWp V@^JN11M^hmOL)XAwl?zgKLA=7Fv9=< literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000180.vtu b/previews/PR1697/tutorials/out/solution_000180.vtu new file mode 100644 index 0000000000000000000000000000000000000000..6759ede9666adc72c655bac7fa4fbd29f7fd772c GIT binary patch literal 19180 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 ZaAj^}Wn@HQbYVUUJTF#MOGasIWj^xqge3p~ literal 0 HcmV?d00001 diff --git a/previews/PR1697/tutorials/out/solution_000180_celldata.vtu b/previews/PR1697/tutorials/out/solution_000180_celldata.vtu new file mode 100644 index 0000000000000000000000000000000000000000..e748b0dc7ba4d37111a83cbfbcb89db5c5dc65ce GIT binary patch literal 6739 zcmbVxc{tR4_diLpWJyT&k!)e?WEm2YB-yePV+k|NjGa*llQmmL+@?^3FxIR?23fLi zW#7gw8v9s&+V1E6KG$>ozTfNl{By2zuJ?JpUgx~e=b!Ud2KlKxPdhx4lZ^O0IxIH?j&mS8%76$kdp!M+C$wvU|={LdUD(w z;c9-{<-rX*gq_CUVSp+PFR${yv;GL4gzvh5?ZLcvyxbpvVfv1Dp)L>vTm>K_Ed}^H zr~!6!JBdmE#QBx<^VlzhpMf8Q>M)p{-|rH&+@N+p#oe)UKdJZ^>^~4sv_T=@pH$KS zUPma*-43Awu=DT$Lma>-4S_m3!oepIAVA^|i?YNol)wF-vi^7{mHfMg-|hLOz#a;L zfb9`3-Yy8g|Expu|EEJnK~d&kQvNrxU+Uri1&^$p%s)#04?M;vRVkbR|7`1zIr#5b z6#v1ZEb%`&sr2IDP2qQlKm0P%um4O{d*YGHxb01XO2&np9$-dB(BcrD57q<4M^cwbQq#ZBxx z1$XY0s0Mr^j&=DDmJE*5HRI%SY!?$Nm08g@W1u%7yhneXq7%@@Yl8OADqL2)w?F@Q zE}nlnA_&A%7h(|4Kc@_SqyT{Monf(!oJD;|->n%?Glku-oN4N^^@%oD;}jk`q(t#g z$2U{qnKtMec62i{?H^GGSQWWCU*fHdFmCMZ_^?CvFmd>HC6Q*M-U$nZ^-HN=&+i7g zbSvWBgKD!@!)M9WBj|`;+}n!1cSH}ZpiJvra7ickb}Ia52!vi2Ax6O>kmKX~q=Q_gb%07Cp6Dst?ZmN874|*`lfXAhH zdFM;*Q@#kcl-ukr7r|FznL6sH0&T5X2%r4THT=Y*@x+hgyYG-@BZ5e>-UJ-aLko1c z3a2OT)oKd$E>b+Hza3rhM=Nfd+(jLt-;};{B~ZlRKHo`F{DSg1Y`NPe zy{a@>KUnC(!o#E=-TFRozl=_(oFR9oBu1kqk;Q)ySa=GE6x}jk;M5qh!p+XyQwPgF z*A>yUQ2oS0eT+uL_EYc{P8-YdG})ZChsf@1be@wI{G`VI=;8#?&r zS@nZrX7n06Bdro9&YGMv4?;Bd-&=uaR@gQ4JFeS37jJCl2^hIb&r9B&8P%6Z88J_h zSogS_>uu*(30&s!8w;O+;_N_b;B#YoTuZBF%|Tai-P}SVg}NKoPh-XjAEF)gz0WA` zG`}5UdvX6XUVBamaxwde8F;F{rY?(;9|A94Uz%_7;vEUGFUyeU9Mhk*A%9np7aS59 zOWdkZx-vylcFT~SC+9h+ft0kBZc9(c;0nfsdHPP5`;Yg|k z!!Uyj(^p31szUt^&%9YqwtCiH8Mfy1Vb^nA-Cg~=Y6XWU%E=l>7%8u#zF*2;?q8n<9<;Cu9VEtxrNm+!WpxE zeD2n$HneO;+>*#Om^~RMUNvxzrv6acUM`w!Xvhz6=BvCfbFt-So*$_2sMIMU7=*X&;Ue;H9y$Ua8GIMqkTYk)zx(wa@xGBjsMHrRW!(m~Sd5>3N{6?Z9~!&5x52SuUG=das<{6=Fjgl<@N-tmeWxwDq>Dz066` z5==gZ7X_mjAmr{7@}xT1#+f*h%H2V2jkDW4sYy87T`<0{ZnP(d2&EV`b2{wgqHdT; ztX*~u@>Bwbl9TRL)Tvo6D6SeI!Bi-}LSR-Yd2F9jP@k!Xpk!TwGJ`aw&E&#=X6 zk_yB5aTyA&gz_)#P+#S1V>DM0W$xscDvmbMrA%ERR#RUz2n=jb{5(RIye!gM=#jM| z6;tXQp9bgsE)Z(flnutdzbU^(b$3u@+CJlAjIV*#v`zdqsZ>(%PZi7{!+7vvOMI|X|?2C85PifP%>DhS(-g-nXcibj{Qw7d@YeYC~s zrBDDBI5#kmb4*n|wA>di_oSrJu=JxzKOc9AL1n%(lvyEt(r$D8hU~OC&Z(8xV9J)?Kvu9mCWArYJ#G`cO3o278PWI*f}h* zw(W&Tfm~-e@XyY$ACEg*#&_v(Z^h5XZ?tA@CC|#UHc%J@>sUqX0^-9_ElR1)0?VTG zs|WE_7~S=}g@bs6`aD~cJf4472QM(A9WhDj@ek=r0de1X^wxn%65CQ9tP^k^P5@omvb~=1k>AcP@@yxM7ZGNHowo+QSt~9|a zUcSp@+(NyNp4!1VpOmx&6(McxE9rw7P*JCz%iIed;n@F z0Iv2?#%9*f!9weks5Inq0-WkTZUu%dHQCH0-)v~aR?SPNpm#R6WrcIJ^V@aqG*21d z;;hPZ0m&9DQ1&j*-;8ZNeEMOb>y8Dc{?T|_ih%zhI`Yg^58M=eccW$ee#^cQe(%m3 zOuBiI?LtUHI(e`?H~o=G0lGQNa3_5AHrTFC&oQSFQt1qCDl1%54&zHraPs! zwRX$TSfHZ>D#5wr8$ye@g4qLeekb2(uP!M+?LOZ?nS7-Np7OYI+_GAmy(G&vzLn#+ zTEc^?cchDfaET(y=2)FePFKVKQL)}6IxZKDiLGUJmP#OxoUZnXW^&}K^YvLuO3+B@ z4!{$#b6wCCBJx#Q1JYCeB!%Wu-VUBOqQl8=i(gq5*KFiBqDRuLiw(BPIgpovy0u5n z5*!%6Jdd?%siQ5 zXU?)sYwzm!s*rX;(w`^ETn<*7txZX+*|Ce;-=N!q*c!OQt`g}9#@^5PHZ%en2FgYa zw(HOsIU2V2lNZ` zHhQ?bRDMXYkD7?DR_u8gsj$8R*_qnjMi*LVWym9|gpe?`i%uMbH)hqeS}`*Xw}kGq z+Q#gWS33nbgz2b(Sg7*hc$+Bu2@iweLNe z`g8DCojDHs^qp7GN$g~H=jpyN63{25s81v}?A#QvslFf&ExPBsuq@{>X*dwHWtt%w zn;ay?Z&M!{{5hadg^vR+T5&2=g-hAjsc9IlZw_=ik4!`bDaA9$bd9HRmp0+@xh@`{ zECMo55h*oaWQZajuPjq%=3VeSGz@e>Y~~oNJYtb=ow-o2+=E+7{wj4Q&3Iw(eGM~_ z=}Bz%xvME2uKI`L3Je`S7ehr>V2%x<%!7$9kMx7Kly?sr;m1W&x?@hRmuP^=Yq}J1 zocBv~h4;==3^BZLMZgkNVXretlAl`*fw44y+1i*ig!spSeVC)$oj2g9VccbEGt60` zEuA&yzj}8{M(UG;wc15;rmC(5e>_^fHKe45c3bSRA4IeH?VEn7Ks+u<{$_H#-jJ3r zpYO1ucdi5oMS9N`A($w{KLCk(iF5^^(5>POlw(6&+Mo-~HFSku%|xAxB!^sj6wYr& zh`^P~Dlxk5L@XxUaYA`z1`5M}y82M>i#Hc6g?*BZ*HW%yrO1#x~`V0SzHX zqe<$V^aaq?y&y#_M(_LMCA(PJGlY+xVvi)ZwfcvL(BCYl5>=J0&URLh#_z0r3~cCC zQ`utXQoFLV#?*Yh<_^0eXfkUNNXf5aj|j#;fJomH-$_zs z9?uUrtj}j54ivv`1dTa1V9y9^Ot=p6);X`Ap9$pSI1`q|(|--McVW@3qHVxZ;aLiX zXa6FRDQygzx<<4`gBPcJ4lbD=JSXj6W_RYA0_i&5wepnyRFIO%h+rf(t}aje#hN#i zX4RV%TA(?uoKeh4ccvQqDrN|#JkJ~QkgGeOyfxKD=DN0BC&;Em}&q$xhe74|JIOGN1R2fsX+eV`xA{kh9x17DxHhZX;pn&W#TDD?0- zk#egx{aYqy4_#~KUQb=+Ww+}&HNz$JexSD`2nguA(Zna#ydmxbxh&r>+I%0n%VAyrzlOhGcqP3R{+kP zOb8E*F#-j%?yxvmzQjPL{R|E_Cj=YZwQxZkD}tXoM%WdKosqMbHZ>#e%YcG<0&#z7 z5;X?Bj6l;a#0#l}?Cvxl`9-nR6C80P(6eM8)CEsxPzoqXDyy%w9RPt=K-5_P~3R?zIVCrjFi zZeXG@7Lcx;!?HC=v)x_7lKW zhu(wdej!WQ$ErZcY=A~CMtT}FdWTqY@4)h!Gg50iiNg3V8Bi0xDrreOzB9o28+_;4 z{Id1efDVfrqxTMzGecE)#tjRu8ZI$eG^EY<#uH*P=AgrS^^MAg1JIeA~p@q!juM$3ur4Dh)md!!CJUC}I&#VlEDIFv#mY(^oSSs^Y# zA;nN3sZZfA_1kT99Ze7N@&0bD1)QH0qS}4w90RY|UJnB@F-x;2NK+b0u^399>yzTr zNQp~9r^hoP=$z;Yj@$&WD#3}I)q#)Ik%`rb`h|n=3rF@BV8s_slqQZWCSX|; zr*nf2VuOxcgH9B34*YVC%yQt1? zQ9fo#$poNqf~2A$P{2@9Hu+^qT!3F9hzPZwx32@gLblJgS3VJ~jL54DbFGY7u6&kS z8ER1(JyIE>R2f-a8B5xu#Lb!>yrlAd9`1{tShqm7eDjNH@p~e;M-e+&x(x`xW?yH#^)(iXPH&!q*do>>t=%wFonA> zzwM^;?CxPv9YRrU&QYBgqgwAredcYpvuw5p&PbE@Npbjii1kS(E~Y$YPkEM-5^BcY z{N!r;OSd-ql}4ttkCc{;UY1?wMnCC|c8HC(xsP_PT*brko6dSW*u=~li90C3fr4;J zc_L7PC<&r10!9`IMPe0ni!SS8W!j6BMT-EUSgE`skv!}**CM&)BJpLcDn}6?2Uaq* zh&{E0(xRBfqU792G1o{5vr-9dbumYE2~|KbTR;g92~I`@W2Azg4ToI}hhNZ!)3v}j zTi~YzVdn+mm$Kn!oM5a@aQb-|_dJ}54Njd5V^4-tn!;F2iTuJgHD-S%{o=2|Ci`Q5 zuYt*Y(^Bin$Z4V&{V5X9kgK + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/parabolic_terms/287083f9.svg b/previews/PR1697/tutorials/parabolic_terms/287083f9.svg new file mode 100644 index 00000000000..171755026b3 --- /dev/null +++ b/previews/PR1697/tutorials/parabolic_terms/287083f9.svg @@ -0,0 +1,731 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/parabolic_terms/index.html b/previews/PR1697/tutorials/parabolic_terms/index.html new file mode 100644 index 00000000000..ba16ea1a65c --- /dev/null +++ b/previews/PR1697/tutorials/parabolic_terms/index.html @@ -0,0 +1,130 @@ + +10 Parabolic terms · Trixi.jl

10: Parabolic terms

Experimental support for parabolic diffusion terms is available in Trixi.jl. This demo illustrates parabolic terms for the advection-diffusion equation.

using OrdinaryDiffEq
+using Trixi

Splitting a system into hyperbolic and parabolic parts.

For a mixed hyperbolic-parabolic system, we represent the hyperbolic and parabolic parts of the system separately. We first define the hyperbolic (advection) part of the advection-diffusion equation.

advection_velocity = (1.5, 1.0)
+equations_hyperbolic = LinearScalarAdvectionEquation2D(advection_velocity);

Next, we define the parabolic diffusion term. The constructor requires knowledge of equations_hyperbolic to be passed in because the LaplaceDiffusion2D applies diffusion to every variable of the hyperbolic system.

diffusivity = 5.0e-2
+equations_parabolic = LaplaceDiffusion2D(diffusivity, equations_hyperbolic);

Boundary conditions

As with the equations, we define boundary conditions separately for the hyperbolic and parabolic part of the system. For this example, we impose inflow BCs for the hyperbolic system (no condition is imposed on the outflow), and we impose Dirichlet boundary conditions for the parabolic equations. Both BoundaryConditionDirichlet and BoundaryConditionNeumann are defined for LaplaceDiffusion2D.

The hyperbolic and parabolic boundary conditions are assumed to be consistent with each other.

boundary_condition_zero_dirichlet = BoundaryConditionDirichlet((x, t, equations) -> SVector(0.0))
+
+boundary_conditions_hyperbolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),
+                                    y_neg = boundary_condition_zero_dirichlet,
+                                    y_pos = boundary_condition_do_nothing,
+                                    x_pos = boundary_condition_do_nothing)
+
+boundary_conditions_parabolic = (; x_neg = BoundaryConditionDirichlet((x, t, equations) -> SVector(1 + 0.5 * x[2])),
+                                   y_neg = boundary_condition_zero_dirichlet,
+                                   y_pos = boundary_condition_zero_dirichlet,
+                                   x_pos = boundary_condition_zero_dirichlet);

Defining the solver and mesh

The process of creating the DG solver and mesh is the same as for a purely hyperbolic system of equations.

solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
+coordinates_min = (-1.0, -1.0) # minimum coordinates (min(x), min(y))
+coordinates_max = ( 1.0,  1.0) # maximum coordinates (max(x), max(y))
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=4,
+                periodicity=false, n_cells_max=30_000) # set maximum capacity of tree data structure
+
+initial_condition = (x, t, equations) -> SVector(0.0);

Semidiscretizing and solving

To semidiscretize a hyperbolic-parabolic system, we create a SemidiscretizationHyperbolicParabolic. This differs from a SemidiscretizationHyperbolic in that we pass in a Tuple containing both the hyperbolic and parabolic equation, as well as a Tuple containing the hyperbolic and parabolic boundary conditions.

semi = SemidiscretizationHyperbolicParabolic(mesh,
+                                             (equations_hyperbolic, equations_parabolic),
+                                             initial_condition, solver;
+                                             boundary_conditions=(boundary_conditions_hyperbolic,
+                                                                  boundary_conditions_parabolic))
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolicParabolic                                                            │
+│ ═════════════════════════════════════                                                            │
+│ #spatial dimensions: ………………………… 2                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{2, Trixi.SerialTree{2}} with length 341                 │
+│ hyperbolic equations: ……………………… LinearScalarAdvectionEquation2D                                  │
+│ parabolic equations: ………………………… LaplaceDiffusion2D                                               │
+│ initial condition: ……………………………… #7                                                               │
+│ source terms: …………………………………………… nothing                                                          │
+│ solver: …………………………………………………………… DG                                                               │
+│ parabolic solver: ………………………………… ViscousFormulationBassiRebay1                                    │
+│ total #DOFs per field: …………………… 4096                                                             │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

The rest of the code is identical to the hyperbolic case. We create a system of ODEs through semidiscretize, defining callbacks, and then passing the system to OrdinaryDiffEq.jl.

tspan = (0.0, 1.5)
+ode = semidiscretize(semi, tspan)
+callbacks = CallbackSet(SummaryCallback())
+time_int_tol = 1.0e-6
+sol = solve(ode, RDPK3SpFSAL49(); abstol=time_int_tol, reltol=time_int_tol,
+            ode_default_options()..., callback=callbacks);

+████████╗██████╗ ██╗██╗  ██╗██╗
+╚══██╔══╝██╔══██╗██║╚██╗██╔╝██║
+   ██║   ██████╔╝██║ ╚███╔╝ ██║
+   ██║   ██╔══██╗██║ ██╔██╗ ██║
+   ██║   ██║  ██║██║██╔╝ ██╗██║
+   ╚═╝   ╚═╝  ╚═╝╚═╝╚═╝  ╚═╝╚═╝
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolicParabolic                                                            │
+│ ═════════════════════════════════════                                                            │
+│ #spatial dimensions: ………………………… 2                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{2, Trixi.SerialTree{2}} with length 341                 │
+│ hyperbolic equations: ……………………… LinearScalarAdvectionEquation2D                                  │
+│ parabolic equations: ………………………… LaplaceDiffusion2D                                               │
+│ initial condition: ……………………………… #7                                                               │
+│ source terms: …………………………………………… nothing                                                          │
+│ solver: …………………………………………………………… DG                                                               │
+│ parabolic solver: ………………………………… ViscousFormulationBassiRebay1                                    │
+│ total #DOFs per field: …………………… 4096                                                             │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{2, Trixi.SerialTree{2}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0, 0.0]                                                       │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (false, false)                                                   │
+│ current #cells: ……………………………………… 341                                                              │
+│ #leaf-cells: ……………………………………………… 256                                                              │
+│ maximum #cells: ……………………………………… 30000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation2D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Time integration                                                                                 │
+│ ════════════════                                                                                 │
+│ Start time: ………………………………………………… 0.0                                                              │
+│ Final time: ………………………………………………… 1.5                                                              │
+│ time integrator: …………………………………… RDPK3SpFSAL49                                                    │
+│ adaptive: ……………………………………………………… true                                                             │
+│ abstol: …………………………………………………………… 1.0e-6                                                           │
+│ reltol: …………………………………………………………… 1.0e-6                                                           │
+│ controller: ………………………………………………… PIDController(beta=[0.38, -0.18,…iter=default_dt_factor_limiter) │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘
+┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ Environment information                                                                          │
+│ ═══════════════════════                                                                          │
+│ #threads: ……………………………………………………… 1                                                                │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We can now visualize the solution, which develops a boundary layer at the outflow boundaries.

using Plots
+plot(sol)
Example block output

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/17dd5be8.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/17dd5be8.svg new file mode 100644 index 00000000000..9a90cf8dbfb --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/17dd5be8.svg @@ -0,0 +1,54 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/22fe8c96.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/22fe8c96.svg new file mode 100644 index 00000000000..3702fef69ac --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/22fe8c96.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/5ea0a2e7.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/5ea0a2e7.svg new file mode 100644 index 00000000000..a8ff51843cf --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/5ea0a2e7.svg @@ -0,0 +1,48 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/8f31c7f1.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/8f31c7f1.svg new file mode 100644 index 00000000000..d76cf56330b --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/8f31c7f1.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/ba041784.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/ba041784.svg new file mode 100644 index 00000000000..4b7931db3c8 --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/ba041784.svg @@ -0,0 +1,48 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/d998e897.svg b/previews/PR1697/tutorials/scalar_linear_advection_1d/d998e897.svg new file mode 100644 index 00000000000..10662e9eb3b --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/d998e897.svg @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/scalar_linear_advection_1d/index.html b/previews/PR1697/tutorials/scalar_linear_advection_1d/index.html new file mode 100644 index 00000000000..f8cf0cbba51 --- /dev/null +++ b/previews/PR1697/tutorials/scalar_linear_advection_1d/index.html @@ -0,0 +1,294 @@ + +1 Introduction to DG methods · Trixi.jl

1: Introduction to DG methods

This tutorial is about how to set up a simple way to approximate the solution of a hyperbolic partial differential equation. First, we will implement a basic and naive algorithm. Then, we will use predefined features from Trixi.jl to show how you can use Trixi.jl on your own.

We will implement the scalar linear advection equation in 1D with the advection velocity $1$.

\[u_t + u_x = 0,\; \text{for} \;t\in \mathbb{R}^+, x\in\Omega=[-1,1]\]

We define the domain $\Omega$ by setting the boundaries.

coordinates_min = -1.0 # minimum coordinate
+coordinates_max = 1.0  # maximum coordinate
1.0

We assume periodic boundaries and the following initial condition.

initial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)
initial_condition_sine_wave (generic function with 1 method)

The discontinuous Galerkin collocation spectral element method (DGSEM)

i. Discretization of the physical domain

To improve precision we want to approximate the solution on small parts of the physical domain. So, we split the domain $\Omega=[-1, 1]$ into elements $Q_l$ of length $dx$.

n_elements = 16 # number of elements
+
+dx = (coordinates_max - coordinates_min) / n_elements # length of one element
0.125

To make the calculation more efficient and storing less information, we transform each element $Q_l$ with center point $x_l$ to a reference element $E=[-1, 1]$

\[Q_l=\Big[x_l-\frac{dx}{2}, x_l+\frac{dx}{2}\Big] \underset{x(\xi)}{\overset{\xi(x)}{\rightleftarrows}} [-1, 1].\]

So, for every element the transformation from the reference domain to the physical domain is defined by

\[x(\xi) = x_l + \frac{dx}{2} \xi,\; \xi\in[-1, 1]\]

Therefore,

\[\begin{align*} +u &= u(x(\xi), t) \\ +u_x &= u_\xi \frac{d\xi}{dx} \\[3pt] +\frac{d\xi}{dx} &= (x_\xi)^{-1} = \frac{2}{dx} =: J^{-1}. \\ +\end{align*}\]

Here, $J$ is the Jacobian determinant of the transformation.

Using this transformation, we can transform our equation for each element $Q_l$.

\[\frac{dx}{2} u_t^{Q_l} + u_\xi^{Q_l} = 0 \text{, for }t\in\mathbb{R}^+,\; \xi\in[-1, 1]\]

Here, $u_t^{Q_l}$ and $u_\xi^{Q_l}$ denote the time and spatial derivatives of the solution on the element $Q_l$.

ii. Polynomial approach

Now, we want to approximate the solution in each element $Q_l$ by a polynomial of degree $N$. Since we transformed the equation, we can use the same polynomial approach for the reference coordinate $\xi\in[-1, 1]$ in every physical element $Q_l$. This saves a lot of resources by reducing the amount of calculations needed and storing less information.

For DGSEM we choose Lagrange basis functions $\{l_j\}_{j=0}^N$ as our polynomial basis of degree $N$ in $[-1, 1]$. The solution in element $Q_l$ can be approximated by

\[u(x(\xi), t)\big|_{Q_l} \approx u^{Q_l}(\xi, t) = \sum_{j=0}^N u_j^{Q_l}(t) l_j(\xi)\]

with $N+1$ coefficients $\{u_j^{Q_l}\}_{j=0}^N$. By construction the Lagrange basis has some useful advantages. This basis is defined by $N+1$ nodes, which fulfill a Kronecker property at the exact same nodes. Let $\{\xi_i\}_{i=0}^N$ be these nodes.

\[l_j(\xi_i) = \delta_{i,j} = +\begin{cases} +1, & \text{if } i=j \\ +0, & \text{else.} +\end{cases}\]

Because of this property, the polynomial coefficients are exact the values of $u^{Q_l}$ at the nodes

\[u^{Q_l}(\xi_i, t) = \sum_{j=0}^N u_j^{Q_l}(t) \underbrace{l_j(\xi_i)}_{=\delta_{ij}} = u_i^{Q_l}(t).\]

Next, we want to select the nodes $\{\xi_i\}_{i=0}^N$, which we use for the construction of the Lagrange polynomials. We choose the $N+1$ Gauss-Lobatto nodes, which are used for the Gaussian-Lobatto quadrature. These always contain the boundary points at $-1$ and $+1$ and are well suited as interpolation nodes. The corresponding weights will be referred to as $\{w_j\}_{j=0}^N$. In Trixi.jl the basis with Lagrange polynomials on Gauss-Lobatto nodes is already defined.

using Trixi
+polydeg = 3 #= polynomial degree = N =#
+basis = LobattoLegendreBasis(polydeg)
LobattoLegendreBasis{Float64} with polynomials of degree 3

The Gauss-Lobatto nodes are

nodes = basis.nodes
4-element SVector{4, Float64} with indices SOneTo(4):
+ -1.0
+ -0.4472135954999579
+  0.4472135954999579
+  1.0

with the corresponding weights

weights = basis.weights
4-element SVector{4, Float64} with indices SOneTo(4):
+ 0.16666666666666666
+ 0.8333333333333334
+ 0.8333333333333334
+ 0.16666666666666666

To illustrate how you can integrate using numerical quadrature with this Legendre-Gauss-Lobatto nodes, we give an example for $f(x)=x^3$. Since $f$ is of degree $3$, a polynomial interpolation with $N=3$ is exact. Therefore, the integral on $[-1, 1]$ can be calculated by

\[\begin{align*} +\int_{-1}^1 f(x) dx &= \int_{-1}^1 \Big( \sum_{j=0}^3 f(\xi_j)l_j(x) \Big) dx += \sum_{j=0}^3 f(\xi_j) \int_{-1}^1 l_j(x)dx \\ +&=: \sum_{j=0}^3 f(\xi_j) w_j += \sum_{j=0}^3 \xi_j^3 w_j +\end{align*}\]

Let's use our nodes and weights for $N=3$ and plug in

integral = sum(nodes.^3 .* weights)
0.0

Using this polynomial approach leads to the equation

\[\frac{dx}{2} \dot{u}^{Q_l}(\xi, t) + u^{Q_l}(\xi, t)' = 0\]

with $\dot{u}=\frac{\partial}{\partial t}u$ and $u'=\frac{\partial}{\partial x}u$. To approximate the solution, we need to get the polynomial coefficients $\{u_j^{Q_l}\}_{j=0}^N$ for every element $Q_l$.

After defining all nodes, we can implement the spatial coordinate $x$ and its initial value $u0$ for every node.

x = Matrix{Float64}(undef, length(nodes), n_elements)
+for element in 1:n_elements
+    x_l = coordinates_min + (element - 1) * dx + dx/2
+    for i in 1:length(nodes)
+        ξ = nodes[i] # nodes in [-1, 1]
+        x[i, element] = x_l + dx/2 * ξ
+    end
+end
+
+u0 = initial_condition_sine_wave.(x)
4×16 Matrix{Float64}:
+ 1.0       0.808658  0.646447  …  1.5      1.46194  1.35355  1.19134
+ 0.945837  0.759744  0.610228     1.49706  1.43849  1.31317  1.14018
+ 0.859825  0.686826  0.561506     1.47995  1.38977  1.24026  1.05416
+ 0.808658  0.646447  0.53806      1.46194  1.35355  1.19134  1.0

To have a look at the initial sinus curve, we plot it.

using Plots
+plot(vec(x), vec(u0), label="initial condition", legend=:topleft)
Example block output

iii. Variational formulation

After defining the equation and initial condition, we want to implement an algorithm to approximate the solution.

From now on, we only write $u$ instead of $u^{Q_l}$ for simplicity, but consider that all the following calculation only concern one element. Multiplying the new equation with the smooth Lagrange polynomials $\{l_i\}_{i=0}^N$ (test functions) and integrating over the reference element $E=[-1,1]$, we get the variational formulation of our transformed partial differential equation for $i=0,...,N$:

\[\begin{align*} +\int_{-1}^1 \Big( \frac{dx}{2} \dot{u}(\xi, t) + u'(\xi, t) \Big) l_i(\xi)d\xi + &= \underbrace{\frac{dx}{2} \int_{-1}^1 \dot{u}(\xi, t) l_i(\xi)d\xi}_{\text{Term I}} + \underbrace{\int_{-1}^1 u'(\xi, t) l_i(\xi)d\xi}_{\text{Term II}} = 0 +\end{align*}\]

We deal with the two terms separately. We write $\int_{-1, N}^1 \;\cdot\; d\xi$ for the approximation of the integral using numerical quadrature with $N+1$ basis points. We use the Gauss-Lobatto nodes again. The numerical scalar product $\langle\cdot, \cdot\rangle_N$ is defined by $\langle f, g\rangle_N := \int_{-1, N}^1 f(\xi) g(\xi) d\xi$.

Term I:

In the following calculation we approximate the integral numerically with quadrature on the Gauss-Lobatto nodes $\{\xi_i\}_{i=0}^N$ and then use the Kronecker property of the Lagrange polynomials. This approach of using the same nodes for the interpolation and quadrature is called collocation.

\[\begin{align*} +\frac{dx}{2} \int_{-1}^1 \dot{u}(\xi, t) l_i(\xi)d\xi +&\approx \frac{dx}{2} \int_{-1, N}^1 \dot{u}(\xi, t) l_i(\xi)d\xi \\ +&= \frac{dx}{2} \sum_{k=0}^N \underbrace{\dot{u}(\xi_k, t)}_{=\dot{u}_k(t)} \underbrace{l_i(\xi_k)}_{=\delta_{k,i}}w_k \\ +&= \frac{dx}{2} \dot{u}_i(t) w_i +\end{align*}\]

We define the Legendre-Gauss-Lobatto (LGL) mass matrix $M$ and by the Kronecker property follows:

\[M_{ij} = \langle l_j, l_i\rangle_N = \delta_{ij} w_j,\; i,j=0,...,N.\]

using LinearAlgebra
+M = diagm(weights)
4×4 StaticArraysCore.SMatrix{4, 4, Float64, 16} with indices SOneTo(4)×SOneTo(4):
+ 0.166667  0.0       0.0       0.0
+ 0.0       0.833333  0.0       0.0
+ 0.0       0.0       0.833333  0.0
+ 0.0       0.0       0.0       0.166667

Now, we can write the integral with this new matrix.

\[\frac{dx}{2} \int_{-1, N}^1 \dot{u}(\xi, t) \underline{l}(\xi)d\xi = \frac{dx}{2} M \underline{\dot{u}}(t),\]

where $\underline{\dot{u}} = (\dot{u}_0, ..., \dot{u}_N)^T$ and $\underline{l}$ respectively.

Note: Since the LGL quadrature with $N+1$ nodes is exact up to functions of degree $2N-1$ and $\dot{u}(\xi, t) l_i(\xi)$ is of degree $2N$, in general the following holds

\[\int_{-1}^1 \dot{u}(\xi, t) l_i(\xi) d\xi \neq \int_{-1, N}^1 \dot{u}(\xi, t) l_i(\xi) d\xi.\]

With an exact integration the mass matrix would be dense. Choosing numerical integrating and quadrature with the exact same nodes (collocation) leads to the sparse and diagonal mass matrix $M$. This is called mass lumping and has the big advantage of an easy invertation of the matrix.

Term II:

We use spatial partial integration for the second term:

\[\int_{-1}^1 u'(\xi, t) l_i(\xi) d\xi = [u l_i]_{-1}^1 - \int_{-1}^1 u l_i'd\xi\]

The resulting integral can be solved exactly with LGL quadrature since the polynomial is now of degree $2N-1$.

Again, we split the calculation in two steps.

Surface term

As mentioned before, we approximate the solution with a polynomial in every element. Therefore, in general the value of this approximation at the interfaces between two elements is not unique. To solve this problem we introduce the idea of the numerical flux $u^*$, which will give an exact value at the interfaces. One of many different approaches and definitions for the calculation of the numerical flux we will deal with in 4. Numerical flux.

\[[u l_i]_{-1}^1 = u^*\big|^1 l_i(+1) - u^*\big|_{-1} l_i(-1)\]

Since the Gauss-Lobatto nodes contain the element boundaries $-1$ and $+1$, we can use the Kronecker property of $l_i$ for the calculation of $l_i(-1)$ and $l_i(+1)$.

\[[u \underline{l}]_{-1}^1 = u^*\big|^1 \left(\begin{array}{c} 0 \\ \vdots \\ 0 \\ 1 \end{array}\right) +- u^*\big|_{-1} \left(\begin{array}{c} 1 \\ 0 \\ \vdots \\ 0\end{array}\right) += B \underline{u}^*(t)\]

with the boundary matrix

\[B = \begin{pmatrix} +-1 & 0 & \cdots & 0\\ +0 & 0 & \cdots & 0\\ +\vdots & \vdots & 0 & 0\\ +0 & \cdots & 0 & 1 +\end{pmatrix} +\qquad\text{and}\qquad +\underline{u}^*(t) = \left(\begin{array}{c} u^*\big|_{-1} \\ 0 \\ \vdots \\ 0 \\ u^*\big|^1\end{array}\right).\]

B = diagm([-1; zeros(polydeg - 1); 1])
4×4 Matrix{Float64}:
+ -1.0  0.0  0.0  0.0
+  0.0  0.0  0.0  0.0
+  0.0  0.0  0.0  0.0
+  0.0  0.0  0.0  1.0

Volume term

As mentioned before, the new integral can be solved exact since the function inside is of degree $2N-1$.

\[- \int_{-1}^1 u l_i'd\xi = - \int_{-1, N}^1 u l_i' d\xi += - \sum_{k=0}^N u(\xi_k, t) l_i'(\xi_k) w_k += - \sum_{k=0}^N u_k(t) D_{ki} w_k\]

where $D$ is the derivative matrix defined by $D_{ki} = l_i'(\xi_k)$ for $i,k=0,...,N$.

D = basis.derivative_matrix
4×4 Matrix{Float64}:
+ -3.0        4.04508  -1.54508   0.5
+ -0.809017   0.0       1.11803  -0.309017
+  0.309017  -1.11803   0.0       0.809017
+ -0.5        1.54508  -4.04508   3.0

To show why this matrix is called the derivative matrix, we go back to our example $f(x)=x^3$. We calculate the derivation of $f$ at the Gauss-Lobatto nodes $\{\xi_k\}_{k=0}^N$ with $N=8$.

\[f'|_{x=\xi_k} = \Big( \sum_{j=0}^8 f(\xi_j) l_j(x) \Big)'|_{x=\xi_k} = \sum_{j=0}^8 f(\xi_j) l_j'(\xi_k) += \sum_{j=0}^8 f(\xi_j) D_{kj}\]

for $k=0,...,N$ and therefore, $\underline{f}' = D \underline{f}$.

basis_N8 = LobattoLegendreBasis(8)
+plot(vec(x), x -> 3 * x^2, label="f'", lw=2)
+scatter!(basis_N8.nodes, basis_N8.derivative_matrix * basis_N8.nodes.^3, label="Df", lw=3)
Example block output

Combining the volume term for every $i=0,...,N$ results in

\[\int_{-1}^1 u \underline{l'} d\xi = - D^T M \underline{u}(t)\]

Putting all parts together we get the following equation for the element $Q_l$

\[\frac{dx}{2} M \underline{\dot{u}}(t) = - B \underline{u}^*(t) + D^T M \underline{u}(t)\]

or equivalent

\[\underline{\dot{u}}^{Q_l}(t) = \frac{2}{dx} \Big[ - M^{-1} B \underline{u}^{{Q_l}^*}(t) + M^{-1} D^T M \underline{u}^{Q_l}(t)\Big].\]

This is called the weak form of the DGSEM.

Note: For every element $Q_l$ we get a system of $N+1$ ordinary differential equations to calculate $N+1$ coefficients. Since the numerical flux $u^*$ is depending on extern values at the interfaces, the equation systems of adjacent elements are weakly linked.

iv. Numerical flux

As mentioned above, we still have to handle the problem of different values at the same point at the interfaces. This happens with the ideas of the numerical flux $f^*(u)=u^*$. The role of $f^*$ might seem minor in this simple example, but is important for more complicated problems. There are two values at the same spatial coordinate. Let's say we are looking at the interface between the elements $Q_l$ and $Q_{l+1}$, while both elements got $N+1$ nodes as defined before. We call the first value of the right element $u_R=u_0^{Q_{l+1}}$ and the last one of the left element $u_L=u_N^{Q_l}$. So, for the value of the numerical flux on that interface the following holds

\[u^* = u^*(u_L, u_R).\]

These values are interpreted as start values of a so-called Riemann problem. There are many different (approximate) Riemann solvers available and useful for different problems. We will use the local Lax-Friedrichs flux.

surface_flux = flux_lax_friedrichs
FluxLaxFriedrichs(max_abs_speed_naive)

The only missing ingredient is the flux calculation at the boundaries $-1$ and $+1$.

\[u^{{Q_{first}}^*}\big|_{-1} = u^{{Q_{first}}^*}\big|_{-1}(u^{bound}(-1), u_R) +\quad\text{and}\quad +u^{{Q_{last}}^*}\big|^1 = u^{{Q_{last}}^*}\big|^1(u_L, u^{bound}(1))\]

The boundaries are periodic, which means that the last value of the last element $u^{Q_{last}}_N$ is used as $u_L$ at the first interface and accordingly for the other boundary.

Now, we implement a function, that calculates $\underline{\dot{u}}^{Q_l}$ for the given matrices, $\underline{u}$ and $\underline{u}^*$.

function rhs!(du, u, x, t)
+    # Reset du and flux matrix
+    du .= zero(eltype(du))
+    flux_numerical = copy(du)
+
+    # Calculate interface and boundary fluxes, $u^* = (u^*|_{-1}, 0, ..., 0, u^*|^1)^T$
+    # Since we use the flux Lax-Friedrichs from Trixi.jl, we have to pass some extra arguments.
+    # Trixi.jl needs the equation we are dealing with and an additional `1`, that indicates the
+    # first coordinate direction.
+    equations = LinearScalarAdvectionEquation1D(1.0)
+    for element in 2:n_elements-1
+        # left interface
+        flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)
+        flux_numerical[end, element-1] = flux_numerical[1, element]
+        # right interface
+        flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)
+        flux_numerical[1, element+1] = flux_numerical[end, element]
+    end
+    # boundary flux
+    flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)
+    flux_numerical[end, end] = flux_numerical[1, 1]
+
+    # Calculate surface integrals, $- M^{-1} * B * u^*$
+    for element in 1:n_elements
+        du[:, element] -= (M \ B) * flux_numerical[:, element]
+    end
+
+    # Calculate volume integral, $+ M^{-1} * D^T * M * u$
+    for element in 1:n_elements
+        flux = u[:, element]
+        du[:, element] += (M \ transpose(D)) * M * flux
+    end
+
+    # Apply Jacobian from mapping to reference element
+    for element in 1:n_elements
+        du[:, element] *= 2 / dx
+    end
+
+    return nothing
+end
rhs! (generic function with 1 method)

Combining all definitions and the function that calculates the right-hand side, we define the ODE and solve it until t=2 with OrdinaryDiffEq's solve function and the Runge-Kutta method RDPK3SpFSAL49(), which is optimized for discontinuous Galerkin methods and hyperbolic PDEs. We set some common error tolerances abstol=1.0e-6, reltol=1.0e-6 and pass save_everystep=false to avoid saving intermediate solution vectors in memory.

using OrdinaryDiffEq
+tspan = (0.0, 2.0)
+ode = ODEProblem(rhs!, u0, tspan, x)
+
+sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)
+
+plot(vec(x), vec(sol.u[end]), label="solution at t=$(tspan[2])", legend=:topleft, lw=3)
Example block output

Alternative Implementation based on Trixi.jl

Now, we implement the same example. But this time, we directly use the functionality that Trixi.jl provides.

using Trixi, OrdinaryDiffEq, Plots

First, define the equation with a advection_velocity of 1.

advection_velocity = 1.0
+equations = LinearScalarAdvectionEquation1D(advection_velocity)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ LinearScalarAdvectionEquation1D                                                                  │
+│ ═══════════════════════════════                                                                  │
+│ #variables: ………………………………………………… 1                                                                │
+│ │ variable 1: …………………………………………… scalar                                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Then, create a DG solver with polynomial degree = 3 and (local) Lax-Friedrichs/Rusanov flux as surface flux. The implementation of the basis and the numerical flux is now already done.

solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We will now create a mesh with 16 elements for the physical domain [-1, 1] with periodic boundaries. We use Trixi.jl's standard mesh TreeMesh. Since it's limited to hypercube domains, we choose 2^4=16 elements. The mesh type supports AMR, that' why n_cells_max has to be set, even if we don't need AMR here.

coordinates_min = -1.0 # minimum coordinate
+coordinates_max = 1.0  # maximum coordinate
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=4, # number of elements = 2^4
+                n_cells_max=30_000) # set maximum capacity of tree data structure (only needed for AMR)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ TreeMesh{1, Trixi.SerialTree{1}}                                                                 │
+│ ════════════════════════════════                                                                 │
+│ center: …………………………………………………………… [0.0]                                                            │
+│ length: …………………………………………………………… 2.0                                                              │
+│ periodicity: ……………………………………………… (true,)                                                          │
+│ current #cells: ……………………………………… 31                                                               │
+│ #leaf-cells: ……………………………………………… 16                                                               │
+│ maximum #cells: ……………………………………… 30000                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

A semidiscretization collects data structures and functions for the spatial discretization. In Trixi.jl, an initial condition has the following parameter structure and is of the type SVector.

initial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ SemidiscretizationHyperbolic                                                                     │
+│ ════════════════════════════                                                                     │
+│ #spatial dimensions: ………………………… 1                                                                │
+│ mesh: ………………………………………………………………… TreeMesh{1, Trixi.SerialTree{1}} with length 31                  │
+│ equations: …………………………………………………… LinearScalarAdvectionEquation1D                                  │
+│ initial condition: ……………………………… initial_condition_sine_wave                                      │
+│ boundary conditions: ………………………… Trixi.BoundaryConditionPeriodic                                  │
+│ source terms: …………………………………………… nothing                                                          │
+│ solver: …………………………………………………………… DG                                                               │
+│ total #DOFs per field: …………………… 64                                                               │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Again, combining all definitions and the function that calculates the right-hand side, we define the ODE and solve it until t=2 with OrdinaryDiffEq's solve function and the Runge-Kutta method RDPK3SpFSAL49().

tspan = (0.0, 2.0)
+ode_trixi  = semidiscretize(semi, tspan)
+
+sol_trixi = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);

We add a plot of the new approximated solution to the one calculated before.

plot!(sol_trixi, label="solution at t=$(tspan[2]) with Trixi.jl", legend=:topleft, linestyle=:dash, lw=2)
Example block output

Summary of the code

To sum up, here is the complete code that we used.

Raw implementation

# basis: Legendre-Gauss-Lobatto
+using Trixi, LinearAlgebra, OrdinaryDiffEq, Plots
+polydeg = 3 #= polynomial degree =#
+basis = LobattoLegendreBasis(polydeg)
+nodes = basis.nodes # Gauss-Lobatto nodes in [-1, 1]
+D = basis.derivative_matrix
+M = diagm(basis.weights) # mass matrix
+B = diagm([-1; zeros(polydeg - 1); 1])
+
+# mesh
+coordinates_min = -1.0 # minimum coordinate
+coordinates_max = 1.0  # maximum coordinate
+n_elements      = 16   # number of elements
+
+dx = (coordinates_max - coordinates_min) / n_elements # length of one element
+
+x = Matrix{Float64}(undef, length(nodes), n_elements)
+for element in 1:n_elements
+    x_l = -1 + (element - 1) * dx + dx/2
+    for i in 1:length(nodes) # basis points in [-1, 1]
+        ξ = nodes[i]
+        x[i, element] = x_l + dx/2 * ξ
+    end
+end
+
+# initial condition
+initial_condition_sine_wave(x) = 1.0 + 0.5 * sin(pi * x)
+u0 = initial_condition_sine_wave.(x)
+
+plot(vec(x), vec(u0), label="initial condition", legend=:topleft)
+
+# flux Lax-Friedrichs
+surface_flux = flux_lax_friedrichs
+
+# rhs! method
+function rhs!(du, u, x, t)
+    # reset du
+    du .= zero(eltype(du))
+    flux_numerical = copy(du)
+
+    # calculate interface and boundary fluxes
+    equations = LinearScalarAdvectionEquation1D(1.0)
+    for element in 2:n_elements-1
+        # left interface
+        flux_numerical[1, element] = surface_flux(u[end, element-1], u[1, element], 1, equations)
+        flux_numerical[end, element-1] = flux_numerical[1, element]
+        # right interface
+        flux_numerical[end, element] = surface_flux(u[end, element], u[1, element+1], 1, equations)
+        flux_numerical[1, element+1] = flux_numerical[end, element]
+    end
+    # boundary flux
+    flux_numerical[1, 1] = surface_flux(u[end, end], u[1, 1], 1, equations)
+    flux_numerical[end, end] = flux_numerical[1, 1]
+
+    # calculate surface integrals
+    for element in 1:n_elements
+        du[:, element] -= (M \ B) * flux_numerical[:, element]
+    end
+
+    # calculate volume integral
+    for element in 1:n_elements
+        flux = u[:, element]
+        du[:, element] += (M \ transpose(D)) * M * flux
+    end
+
+    # apply Jacobian from mapping to reference element
+    for element in 1:n_elements
+        du[:, element] *= 2 / dx
+    end
+
+    return nothing
+end
+
+# create ODE problem
+tspan = (0.0, 2.0)
+ode = ODEProblem(rhs!, u0, tspan, x)
+
+# solve
+sol = solve(ode, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...)
+
+plot(vec(x), vec(sol.u[end]), label="solution at t=$(tspan[2])", legend=:topleft, lw=3)
Example block output

Alternative Implementation based on Trixi.jl

using Trixi, OrdinaryDiffEq, Plots
+
+# equation with a advection_velocity of `1`.
+advection_velocity = 1.0
+equations = LinearScalarAdvectionEquation1D(advection_velocity)
+
+# create DG solver with flux lax friedrichs and LGL basis
+solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
+
+# distretize domain with `TreeMesh`
+coordinates_min = -1.0 # minimum coordinate
+coordinates_max = 1.0 # maximum coordinate
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=4, # number of elements = 2^4
+                n_cells_max=30_000)
+
+# create initial condition and semidiscretization
+initial_condition_sine_wave(x, t, equations) = SVector(1.0 + 0.5 * sin(pi * sum(x - equations.advection_velocity * t)))
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition_sine_wave, solver)
+
+# solve
+tspan = (0.0, 2.0)
+ode_trixi  = semidiscretize(semi, tspan)
+sol_trixi  = solve(ode_trixi, RDPK3SpFSAL49(); abstol=1.0e-6, reltol=1.0e-6, ode_default_options()...);
+
+plot!(sol_trixi, label="solution at t=$(tspan[2]) with Trixi.jl", legend=:topleft, linestyle=:dash, lw=2)
Example block output

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/shock_capturing/ca991843.svg b/previews/PR1697/tutorials/shock_capturing/ca991843.svg new file mode 100644 index 00000000000..d4bcdcb13a1 --- /dev/null +++ b/previews/PR1697/tutorials/shock_capturing/ca991843.svg @@ -0,0 +1,4419 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/shock_capturing/index.html b/previews/PR1697/tutorials/shock_capturing/index.html new file mode 100644 index 00000000000..ad94edf6b3a --- /dev/null +++ b/previews/PR1697/tutorials/shock_capturing/index.html @@ -0,0 +1,113 @@ + +3 Shock capturing with flux differencing and stage limiter · Trixi.jl

3: Shock capturing with flux differencing and stage limiter

This tutorial contains a short summary of the idea of shock capturing for DGSEM with flux differencing and its implementation in Trixi.jl. In the second part, an implementation of a positivity preserving limiter is added to the simulation.

Shock capturing with flux differencing

The following rough explanation is on a very basic level. More information about an entropy stable shock-capturing strategy for DGSEM discretizations of advection dominated problems, such as the compressible Euler equations or the compressible Navier-Stokes equations, can be found in Hennemann et al. (2021). In Rueda-Ramírez et al. (2021) you find the extension to the systems with non-conservative terms, such as the compressible magnetohydrodynamics (MHD) equations.

The strategy for a shock-capturing method presented by Hennemann et al. is based on a hybrid blending of a high-order DG method with a low-order variant. The low-order subcell finite volume (FV) method is created directly with the Legendre-Gauss-Lobatto (LGL) nodes already used for the high-order DGSEM. Then, the final method is a convex combination with regulating indicator $\alpha$ of these two methods.

Since the surface integral is equal for both the DG and the subcell FV method, only the volume integral divides between the two methods.

This strategy for the volume integral is implemented in Trixi.jl under the name of VolumeIntegralShockCapturingHG with the three parameters of the indicator and the volume fluxes for the DG and the subcell FV method.

Note, that the DG method is based on the flux differencing formulation. Hence, you have to use a two-point flux, such as flux_ranocha, flux_shima_etal, flux_chandrashekar or flux_kennedy_gruber, for the DG volume flux. We would recommend to use the entropy conserving flux flux_ranocha by Ranocha (2018) for the compressible Euler equations.

volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;
+                                                 volume_flux_dg=volume_flux_dg,
+                                                 volume_flux_fv=volume_flux_fv)

We now focus on a choice of the shock capturing indicator indicator_sc. A possible indicator is $\alpha_{HG}$ presented by Hennemann et al. (p.10), which depends on the current approximation with modal coefficients $\{m_j\}_{j=0}^N$ of a given variable.

The indicator is calculated for every DG element by itself. First, we calculate a smooth $\alpha$ by

\[\alpha = \frac{1}{1+\exp(-\frac{-s}{\mathbb{T}}(\mathbb{E}-\mathbb{T}))}\]

with the total energy $\mathbb{E}=\max\big(\frac{m_N^2}{\sum_{j=0}^N m_j^2}, \frac{m_{N-1}^2}{\sum_{j=0}^{N-1} m_j^2}\big)$, threshold $\mathbb{T}= 0.5 * 10^{-1.8*(N+1)^{1/4}}$ and parameter $s=ln\big(\frac{1-0.0001}{0.0001}\big)\approx 9.21024$.

For computational efficiency, $\alpha_{min}$ is introduced and used for

\[\tilde{\alpha} = \begin{cases} +0, & \text{if } \alpha<\alpha_{min}\\ +\alpha, & \text{if } \alpha_{min}\leq \alpha \leq 1- \alpha_{min}\\ +1, & \text{if } 1-\alpha_{min}<\alpha. +\end{cases}\]

Moreover, the parameter $\alpha_{max}$ sets a maximal value for $\alpha$ by

\[\alpha = \min\{\tilde{\alpha}, \alpha_{max}\}.\]

This allows to control the maximal dissipation.

To remove numerical artifact the final indicator is smoothed with all the neighboring elements' indicators. This is activated with alpha_smooth=true.

\[\alpha_{HG} = \max_E \{ \alpha, 0.5 * \alpha_E\},\]

where $E$ are all elements sharing a face with the current element.

Furthermore, you can specify the variable used for the calculation. For instance you can choose density, pressure or both with density_pressure for the compressible Euler equations. For every equation there is also the option to use the first conservation variable with first.

This indicator is implemented in Trixi.jl and called IndicatorHennemannGassner with the parameters equations, basis, alpha_max, alpha_min, alpha_smooth and variable.

indicator_sc = IndicatorHennemannGassner(equations, basis,
+                                         alpha_max=0.5,
+                                         alpha_min=0.001,
+                                         alpha_smooth=true,
+                                         variable=variable)

Positivity preserving limiter

Some numerical solutions are physically meaningless, for instance negative values of pressure or density for the compressible Euler equations. This often results in crashed simulations since the calculation of numerical fluxes or stable time steps uses mathematical operations like roots or logarithms. One option to avoid these cases are a-posteriori positivity preserving limiters. Trixi.jl provides the fully-discrete positivity-preserving limiter of Zhang, Shu (2011).

It works the following way. For every passed (scalar) variable and for every DG element we calculate the minimal value $value_{min}$. If this value falls below the given threshold $\varepsilon$, the approximation is slightly adapted such that the minimal value of the relevant variable lies now above the threshold.

\[\underline{u}^{new} = \theta * \underline{u} + (1-\theta) * u_{mean}\]

where $\underline{u}$ are the collected pointwise evaluation coefficients in element $e$ and $u_{mean}$ the integral mean of the quantity in $e$. The new coefficients are a convex combination of these two values with factor

\[\theta = \frac{value_{mean} - \varepsilon}{value_{mean} - value_{min}},\]

where $value_{mean}$ is the relevant variable evaluated for the mean value $u_{mean}$.

The adapted approximation keeps the exact same mean value, but the relevant variable is now greater or equal the threshold $\varepsilon$ at every node in every element.

We specify the variables the way we did before for the shock capturing variables. For the compressible Euler equations density, pressure or the combined variable density_pressure are a reasonable choice.

You can implement the limiter in Trixi.jl using PositivityPreservingLimiterZhangShu with parameters threshold and variables.

stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=thresholds,
+                                                     variables=variables)

Then, the limiter is added to the time integration method in the solve function. For instance, like

CarpenterKennedy2N54(stage_limiter!, williamson_condition=false)

or

SSPRK43(stage_limiter!).

Simulation with shock capturing and positivity preserving

Now, we can run a simulation using the described methods of shock capturing and positivity preserving limiters. We want to give an example for the 2D compressible Euler equations.

using OrdinaryDiffEq, Trixi
+
+equations = CompressibleEulerEquations2D(1.4)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ CompressibleEulerEquations2D                                                                     │
+│ ════════════════════════════                                                                     │
+│ #variables: ………………………………………………… 4                                                                │
+│ │ variable 1: …………………………………………… rho                                                              │
+│ │ variable 2: …………………………………………… rho_v1                                                           │
+│ │ variable 3: …………………………………………… rho_v2                                                           │
+│ │ variable 4: …………………………………………… rho_e                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

As our initial condition we use the Sedov blast wave setup.

function initial_condition_sedov_blast_wave(x, t, equations::CompressibleEulerEquations2D)
+  # 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)
+
+  r0 = 0.21875 # = 3.5 * smallest dx (for domain length=4 and max-ref=6)
+  # r0 = 0.5 # = more reasonable setup
+  E = 1.0
+  p0_inner = 3 * (equations.gamma - 1) * E / (3 * pi * r0^2)
+  p0_outer = 1.0e-5 # = true Sedov setup
+  # p0_outer = 1.0e-3 # = more reasonable setup
+
+  # Calculate primitive variables
+  rho = 1.0
+  v1  = 0.0
+  v2  = 0.0
+  p   = r > r0 ? p0_outer : p0_inner
+
+  return prim2cons(SVector(rho, v1, v2, p), equations)
+end
+initial_condition = initial_condition_sedov_blast_wave
initial_condition_sedov_blast_wave (generic function with 1 method)
basis = LobattoLegendreBasis(3)
LobattoLegendreBasis{Float64} with polynomials of degree 3

We set the numerical fluxes and divide between the surface flux and the two volume fluxes for the DG and FV method. Here, we are using flux_lax_friedrichs and flux_ranocha.

surface_flux = flux_lax_friedrichs
+volume_flux  = flux_ranocha
flux_ranocha (generic function with 8 methods)

Now, we specify the shock capturing indicator $\alpha$.

We implement the described indicator of Hennemann, Gassner as explained above with parameters equations, basis, alpha_max, alpha_min, alpha_smooth and variable. Since density and pressure are the critical variables in this example, we use density_pressure = density * pressure = rho * p as indicator variable.

indicator_sc = IndicatorHennemannGassner(equations, basis,
+                                         alpha_max=0.5,
+                                         alpha_min=0.001,
+                                         alpha_smooth=true,
+                                         variable=density_pressure)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ IndicatorHennemannGassner                                                                        │
+│ ═════════════════════════                                                                        │
+│ indicator variable: …………………………… density_pressure                                                 │
+│ max. α: …………………………………………………………… 0.5                                                              │
+│ min. α: …………………………………………………………… 0.001                                                            │
+│ smooth α: ……………………………………………………… yes                                                              │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Now, we can use the defined fluxes and the indicator to implement the volume integral using shock capturing.

volume_integral = VolumeIntegralShockCapturingHG(indicator_sc;
+                                                 volume_flux_dg=volume_flux,
+                                                 volume_flux_fv=surface_flux)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ VolumeIntegralShockCapturingHG                                                                   │
+│ ══════════════════════════════                                                                   │
+│ volume flux DG: ……………………………………… flux_ranocha                                                     │
+│ volume flux FV: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ indicator: …………………………………………………… IndicatorHennemannGassner                                        │
+│ │ indicator variable: ……………………… density_pressure                                                 │
+│ │ max. α: ……………………………………………………… 0.5                                                              │
+│ │ min. α: ……………………………………………………… 0.001                                                            │
+│ │ smooth α: ………………………………………………… yes                                                              │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We finalize the discretization by implementing Trixi.jl's solver, mesh, semi and ode, while solver now has the extra parameter volume_integral.

solver = DGSEM(basis, surface_flux, volume_integral)
+
+coordinates_min = (-2.0, -2.0)
+coordinates_max = ( 2.0,  2.0)
+mesh = TreeMesh(coordinates_min, coordinates_max,
+                initial_refinement_level=6,
+                n_cells_max=10_000)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)
+
+tspan = (0.0, 1.0)
+ode = semidiscretize(semi, tspan);

We add some callbacks to get an solution analysis and use a CFL-based time step size calculation.

analysis_callback = AnalysisCallback(semi, interval=100)
+
+stepsize_callback = StepsizeCallback(cfl=0.8)
+
+callbacks = CallbackSet(analysis_callback, stepsize_callback);

We now run the simulation using the positivity preserving limiter of Zhang and Shu for the variables density and pressure.

stage_limiter! = PositivityPreservingLimiterZhangShu(thresholds=(5.0e-6, 5.0e-6),
+                                                     variables=(Trixi.density, pressure))
+
+sol = solve(ode, CarpenterKennedy2N54(stage_limiter!, 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);
+
+using Plots
+plot(sol)
Example block output

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/structured_mesh_mapping/52c207b4.svg b/previews/PR1697/tutorials/structured_mesh_mapping/52c207b4.svg new file mode 100644 index 00000000000..36d52fb3331 --- /dev/null +++ b/previews/PR1697/tutorials/structured_mesh_mapping/52c207b4.svg @@ -0,0 +1,5575 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/structured_mesh_mapping/63b0ba38.svg b/previews/PR1697/tutorials/structured_mesh_mapping/63b0ba38.svg new file mode 100644 index 00000000000..eb1dd13edfd --- /dev/null +++ b/previews/PR1697/tutorials/structured_mesh_mapping/63b0ba38.svg @@ -0,0 +1,9475 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/structured_mesh_mapping/bfa9c649.svg b/previews/PR1697/tutorials/structured_mesh_mapping/bfa9c649.svg new file mode 100644 index 00000000000..64b5341affa --- /dev/null +++ b/previews/PR1697/tutorials/structured_mesh_mapping/bfa9c649.svg @@ -0,0 +1,3800 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/previews/PR1697/tutorials/structured_mesh_mapping/index.html b/previews/PR1697/tutorials/structured_mesh_mapping/index.html new file mode 100644 index 00000000000..4863cf9ad0b --- /dev/null +++ b/previews/PR1697/tutorials/structured_mesh_mapping/index.html @@ -0,0 +1,198 @@ + +13 Structured mesh with curvilinear mapping · Trixi.jl

13: Structured mesh with curvilinear mapping

Here, we want to introduce another mesh type of Trixi.jl. More precisely, this tutorial is about the curved mesh type StructuredMesh supporting curved meshes.

Creating a curved mesh

There are two basic options to define a curved StructuredMesh in Trixi.jl. You can implement curves for the domain boundaries, or alternatively, set up directly the complete transformation mapping. We now present one short example each.

Mesh defined by domain boundary curves

Both examples are based on a semdiscretization of the 2D compressible Euler equations.

using OrdinaryDiffEq
+using Trixi
+
+equations = CompressibleEulerEquations2D(1.4)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ CompressibleEulerEquations2D                                                                     │
+│ ════════════════════════════                                                                     │
+│ #variables: ………………………………………………… 4                                                                │
+│ │ variable 1: …………………………………………… rho                                                              │
+│ │ variable 2: …………………………………………… rho_v1                                                           │
+│ │ variable 3: …………………………………………… rho_v2                                                           │
+│ │ variable 4: …………………………………………… rho_e                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We start with a pressure perturbation at (xs, 0.0) as initial condition.

function initial_condition_pressure_perturbation(x, t, equations::CompressibleEulerEquations2D)
+  xs = 1.5 # location of the initial disturbance on the x axis
+  w = 1/8 # half width
+  p = exp(-log(2) * ((x[1]-xs)^2 + x[2]^2)/w^2) + 1.0
+  v1 = 0.0
+  v2 = 0.0
+  rho = 1.0
+
+  return prim2cons(SVector(rho, v1, v2, p), equations)
+end
+initial_condition = initial_condition_pressure_perturbation
initial_condition_pressure_perturbation (generic function with 1 method)

Initialize every boundary as a boundary_condition_slip_wall.

boundary_conditions = boundary_condition_slip_wall
boundary_condition_slip_wall (generic function with 13 methods)

The approximation setup is an entropy-stable split-form DG method with polydeg=4. We are using the two fluxes flux_ranocha and flux_lax_friedrichs.

solver = DGSEM(polydeg=4, surface_flux=flux_lax_friedrichs,
+               volume_integral=VolumeIntegralFluxDifferencing(flux_ranocha))
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=4)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=4)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ volume integral: …………………………………… VolumeIntegralFluxDifferencing                                   │
+│ │ volume flux: ………………………………………… flux_ranocha                                                     │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We want to define a circular cylinder as physical domain. It contains an inner semicircle with radius r0 and an outer semicircle of radius r1.

The domain boundary curves with curve parameter in $[-1,1]$ are sorted as shown in the sketch. They always are orientated from negative to positive coordinate, such that the corners have to fit like this $f_1(+1) = f_4(-1)$, $f_3(+1) = f_2(-1)$, etc.

In our case we can define the domain boundary curves as follows:

r0 = 0.5 # inner radius
+r1 = 5.0 # outer radius
+f1(xi)  = SVector( r0 + 0.5 * (r1 - r0) * (xi + 1), 0.0) # right line
+f2(xi)  = SVector(-r0 - 0.5 * (r1 - r0) * (xi + 1), 0.0) # left line
+f3(eta) = SVector(r0 * cos(0.5 * pi * (eta + 1)), r0 * sin(0.5 * pi * (eta + 1))) # inner circle
+f4(eta) = SVector(r1 * cos(0.5 * pi * (eta + 1)), r1 * sin(0.5 * pi * (eta + 1))) # outer circle
f4 (generic function with 1 method)

We create a curved mesh with 16 x 16 elements. The defined domain boundary curves are passed as a tuple.

cells_per_dimension = (16, 16)
+mesh = StructuredMesh(cells_per_dimension, (f1, f2, f3, f4), periodicity=false)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ StructuredMesh{2, Float64}                                                                       │
+│ ══════════════════════════                                                                       │
+│ size: ………………………………………………………………… (16, 16)                                                         │
+│ mapping: …………………………………………………………                                                                  │
+│ │ line 1: ……………………………………………………… nothing
+nothing
+nothing
+nothing
+…ng = transfinite_mapping(faces) │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

Then, we define the simulation with endtime T=3 with semi, ode and callbacks.

semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver,
+                                    boundary_conditions=boundary_conditions)
+
+tspan = (0.0, 3.0)
+ode = semidiscretize(semi, tspan)
+
+analysis_interval = 100
+analysis_callback = AnalysisCallback(semi, interval=analysis_interval)
+
+alive_callback = AliveCallback(analysis_interval=analysis_interval)
+
+stepsize_callback = StepsizeCallback(cfl=0.9)
+
+callbacks = CallbackSet(analysis_callback,
+                        alive_callback,
+                        stepsize_callback);

Running 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);
+
+using Plots
+plot(sol)
Example block output
pd = PlotData2D(sol)
+plot(pd["p"])
+plot!(getmesh(pd))
Example block output

Mesh directly defined by the transformation mapping

As mentioned before, you can also define the domain for a StructuredMesh by directly setting up a transformation mapping. Here, we want to present a nice mapping, which is often used to test free-stream preservation. Exact free-stream preservation is a crucial property of any numerical method on curvilinear grids. The mapping is a reduced 2D version of the mapping described in Rueda-Ramírez et al. (2021), p.18.

using OrdinaryDiffEq
+using Trixi
+
+equations = CompressibleEulerEquations2D(1.4)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ CompressibleEulerEquations2D                                                                     │
+│ ════════════════════════════                                                                     │
+│ #variables: ………………………………………………… 4                                                                │
+│ │ variable 1: …………………………………………… rho                                                              │
+│ │ variable 2: …………………………………………… rho_v1                                                           │
+│ │ variable 3: …………………………………………… rho_v2                                                           │
+│ │ variable 4: …………………………………………… rho_e                                                            │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

As mentioned, this mapping is used for testing free-stream preservation. So, we use a constant initial condition.

initial_condition = initial_condition_constant
+
+solver = DGSEM(polydeg=3, surface_flux=flux_lax_friedrichs)
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
+│ DG{Float64}                                                                                      │
+│ ═══════════                                                                                      │
+│ basis: ……………………………………………………………… LobattoLegendreBasis{Float64}(polydeg=3)                         │
+│ mortar: …………………………………………………………… LobattoLegendreMortarL2{Float64}(polydeg=3)                      │
+│ surface integral: ………………………………… SurfaceIntegralWeakForm                                          │
+│ │ surface flux: ……………………………………… FluxLaxFriedrichs(max_abs_speed_naive)                           │
+│ volume integral: …………………………………… VolumeIntegralWeakForm                                           │
+└──────────────────────────────────────────────────────────────────────────────────────────────────┘

We define the transformation mapping with variables in $[-1, 1]$ as described in Rueda-Ramírez et al. (2021), p.18 (reduced to 2D):

function mapping(xi_, eta_)
+  # Transform input variables between -1 and 1 onto [0,3]
+  xi = 1.5 * xi_ + 1.5
+  eta = 1.5 * eta_ + 1.5
+
+  y = eta + 3/8 * (cos(1.5 * pi * (2 * xi - 3)/3) *
+                   cos(0.5 * pi * (2 * eta - 3)/3))
+
+  x = xi + 3/8 * (cos(0.5 * pi * (2 * xi - 3)/3) *
+                  cos(2 * pi * (2 * y - 3)/3))
+
+  return SVector(x, y)
+end
mapping (generic function with 1 method)

Instead of a tuple of boundary functions, the mesh now has the mapping as its parameter.

cells_per_dimension = (16, 16)
+mesh = StructuredMesh(cells_per_dimension, mapping)
+
+semi = SemidiscretizationHyperbolic(mesh, equations, initial_condition, solver)
+
+tspan = (0.0, 1.0)
+ode = semidiscretize(semi, tspan)
+
+analysis_callback = AnalysisCallback(semi, interval=250)
+
+stepsize_callback = StepsizeCallback(cfl=0.8)
+
+callbacks = CallbackSet(analysis_callback,
+                        stepsize_callback)
+
+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);

+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                  0                run time:       1.20000000e-06 s
+ Δt:             1.00000000e+00                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      0.00000000e+00 (0.000%)       time/DOF/rhs!:         NaN s
+                                               PID:                   Inf s
+ #DOFs per field:          4096                alloc'd memory:       2970.228 MiB
+ #elements:                 256
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       7.14879109e-17   1.26068516e-17   2.52137032e-17   1.28610275e-15
+ Linf error:     2.22044605e-16   2.77555756e-17   5.55111512e-17   3.55271368e-15
+ ∑∂S/∂U ⋅ Uₜ :   6.34652923e-17
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                250                run time:       2.43461519e-01 s
+ Δt:             2.33008558e-03                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      5.82521395e-01 (58.252%)      time/DOF/rhs!:  4.22928876e-08 s
+                                               PID:            4.73368778e-08 s
+ #DOFs per field:          4096                alloc'd memory:       2970.500 MiB
+ #elements:                 256
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       2.31290602e-15   1.94893683e-14   2.21188565e-14   1.44472757e-14
+ Linf error:     2.25375274e-14   2.07972528e-13   2.75501844e-13   2.25597319e-13
+ ∑∂S/∂U ⋅ Uₜ :  -1.82954114e-17
+────────────────────────────────────────────────────────────────────────────────────────────────────
+
+
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ Simulation running 'CompressibleEulerEquations2D' with DGSEM(polydeg=3)
+────────────────────────────────────────────────────────────────────────────────────────────────────
+ #timesteps:                430                run time:       4.19414890e-01 s
+ Δt:             3.93286656e-04                └── GC time:    0.00000000e+00 s (0.000%)
+ sim. time:      1.00000000e+00 (100.000%)     time/DOF/rhs!:  4.23783670e-08 s
+                                               PID:            4.75020234e-08 s
+ #DOFs per field:          4096                alloc'd memory:       2970.577 MiB
+ #elements:                 256
+
+ Variable:       rho              rho_v1           rho_v2           rho_e
+ L2 error:       3.20962510e-15   2.14179782e-14   2.83584627e-14   1.56066183e-14
+ Linf error:     2.53130850e-14   2.26790808e-13   3.36897177e-13   2.34479103e-13
+ ∑∂S/∂U ⋅ Uₜ :  -7.51023760e-17
+────────────────────────────────────────────────────────────────────────────────────────────────────

Now, we want to verify the free-stream preservation property and plot the mesh. For the verification, we calculate the absolute difference of the first conservation variable density u[1] and 1.0. To plot this error and the mesh, we are using the visualization feature ScalarPlotData2D, explained in visualization.

error_density = let u = Trixi.wrap_array(sol.u[end], semi)
+  abs.(u[1, :, :, :] .- 1.0) # density, x, y, elements
+end
+pd = ScalarPlotData2D(error_density, semi)
+
+using Plots
+plot(pd, title="Error in density")
+plot!(getmesh(pd))
Example block output

We observe that the errors in the variable density are at the level of machine accuracy. Moreover, the plot shows the mesh structure resulting from our transformation mapping.

Of course, you can also use other mappings as for instance shifts by $(x, y)$

mapping(xi, eta) = SVector(xi + x, eta + y)

or rotations with a rotation matrix $T$

mapping(xi, eta) = T * SVector(xi, eta).

For more curved mesh mappings, please have a look at some elixirs for StructuredMesh. For another curved mesh type, there is a tutorial about Trixi.jl's unstructured mesh type [UnstructuredMesh2D] and its use of the High-Order Hex-Quad Mesh (HOHQMesh) generator, created and developed by David Kopriva.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq", "Plots"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [91a5bcdd] Plots v1.39.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/time_stepping/index.html b/previews/PR1697/tutorials/time_stepping/index.html new file mode 100644 index 00000000000..f6683edfa9c --- /dev/null +++ b/previews/PR1697/tutorials/time_stepping/index.html @@ -0,0 +1,26 @@ + +15 Explicit time stepping · Trixi.jl

15: Explicit time stepping

For the time integration, Trixi.jl uses the package OrdinaryDiffEq.jl from the SciML ecosystem. The interface to this package is the solve(...) function. It always requires an ODE problem and a time integration algorithm as input parameters.

solve(ode, alg; kwargs...)

In Trixi.jl, the ODE problem is created by semidiscretize(semi, tspan) for a semidiscretization semi and the time span tspan. In particular, semidiscretize returns an ODEProblem used by OrdinaryDiffEq.jl.

OrdinaryDiffEq.jl provides many integration algorithms, which are summarized in the documentation. Particularly interesting for Trixi.jl are their strong stability preserving (SSP) methods and low-storage methods. There are some differences regarding the choice of the used time step.

Error-based adaptive step sizes

First, we treat time integration algorithms with adaptive step sizes, such as SSPRK43. It is used in some elixirs, like elixir_euler_colliding_flow.jl or elixir_euler_astro_jet_amr.jl.

Other error-based adaptive integration algorithms are for instance RDPK3SpFSAL35, RDPK3Sp35, RDPK3SpFSAL49, RDPK3Sp49, RDPK3SpFSAL510, RDPK3Sp510.

They already contain an error-based adaptive step size control and heuristics to guess a starting step size. If this heuristic fails in your case, you can specify an appropriately small initial step size as keyword argument dt=... of solve.

If you run Trixi in parallel with MPI you need to pass internalnorm=ode_norm and you should pass unstable_check=ode_unstable_check to enable MPI aware error-based adaptive step size control. These keyword arguments are also included in ode_default_options.

CFL-based step size control

The SciML ecosystem also provides time integration algorithms without adaptive time stepping on their own, such as CarpenterKennedy2N54. Moreover, you also can deactivate the automatic adaptivity of adaptive integration algorithms by passing adaptive=false in the solve function.

These algorithms require another way of setting the step size. You have to pass dt=... in the solve function. Without other settings, the simulation uses this fixed time step.

For hyperbolic PDEs, it is natural to use an adaptive CFL-based step size control. Here, the time step is proportional to a ratio of the local measure of mesh spacing $\Delta x_i$ for an element i and the maximum (local) wave speed $\lambda_{\max}$ related to the largest-magnitude eigenvalue of the flux Jacobian of the hyperbolic system.

\[\Delta t_n = \text{CFL} * \min_i \frac{\Delta x_i}{\lambda_{\max}(u_i^n)}\]

We compute $\Delta x_i$ by scaling the element size by a factor of $1/(N+1)$, cf. Gassner and Kopriva (2011), Section 5.

Trixi.jl provides such a CFL-based step size control. It is implemented as the callback StepsizeCallback.

stepsize_callback = StepsizeCallback(; cfl=1.0)

A suitable CFL number depends on many parameters such as the chosen grid, the integration algorithm and the polynomial degree of the spatial DG discretization. So, the optimal number for an example is mostly determined experimentally.

You can add this CFL-based step size control to your simulation like any other callback.

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

You can find simple examples with a CFL-based step size control for instance in the elixirs elixir_advection_basic.jl or elixir_euler_source_terms.jl.

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "OrdinaryDiffEq"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [1dea7af3] OrdinaryDiffEq v6.58.0
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/tutorials/upwind_fdsbp/index.html b/previews/PR1697/tutorials/upwind_fdsbp/index.html new file mode 100644 index 00000000000..52607afc6e8 --- /dev/null +++ b/previews/PR1697/tutorials/upwind_fdsbp/index.html @@ -0,0 +1,65 @@ + +7 Upwind FD SBP schemes · Trixi.jl

7: Upwind FD SBP schemes

General tensor product SBP methods are supported via the DGMulti solver in a reasonably complete way, see the previous tutorial. Nevertheless, there is also experimental support for SBP methods with other solver and mesh types.

The first step is to set up an SBP operator. A classical (central) SBP operator can be created as follows.

using Trixi
+D_SBP = derivative_operator(SummationByPartsOperators.MattssonNordström2004(),
+                            derivative_order=1, accuracy_order=2,
+                            xmin=0.0, xmax=1.0, N=11)
SBP first-derivative operator of order 2 on a grid in [0.0, 1.0] using 11 nodes 
+and coefficients of Mattsson, Nordström (2004) 
+  Summation by parts operators for finite difference approximations of second 
+    derivatives. 
+  Journal of Computational Physics 199, pp. 503-540.

Instead of prefixing the source of coefficients MattssonNordström2004(), you can also load the package SummationByPartsOperators.jl. Either way, this yields an object representing the operator efficiently. If you want to compare it to coefficients presented in the literature, you can convert it to a matrix.

Matrix(D_SBP)
11×11 Matrix{Float64}:
+ -10.0  10.0   0.0   0.0   0.0   0.0   0.0   0.0   0.0    0.0   0.0
+  -5.0   0.0   5.0   0.0   0.0   0.0   0.0   0.0   0.0    0.0   0.0
+   0.0  -5.0   0.0   5.0   0.0   0.0   0.0   0.0   0.0    0.0   0.0
+   0.0   0.0  -5.0   0.0   5.0   0.0   0.0   0.0   0.0    0.0   0.0
+   0.0   0.0   0.0  -5.0   0.0   5.0   0.0   0.0   0.0    0.0   0.0
+   0.0   0.0   0.0   0.0  -5.0   0.0   5.0   0.0   0.0    0.0   0.0
+   0.0   0.0   0.0   0.0   0.0  -5.0   0.0   5.0   0.0    0.0   0.0
+   0.0   0.0   0.0   0.0   0.0   0.0  -5.0   0.0   5.0    0.0   0.0
+   0.0   0.0   0.0   0.0   0.0   0.0   0.0  -5.0   0.0    5.0   0.0
+   0.0   0.0   0.0   0.0   0.0   0.0   0.0   0.0  -5.0    0.0   5.0
+   0.0   0.0   0.0   0.0   0.0   0.0   0.0   0.0   0.0  -10.0  10.0

Upwind SBP operators are a concept introduced in 2017 by Ken Mattsson. You can create them as follows.

D_upw = upwind_operators(SummationByPartsOperators.Mattsson2017,
+                         derivative_order=1, accuracy_order=2,
+                         xmin=0.0, xmax=1.0, N=11)
Upwind SBP first-derivative operators of order 2 on a grid in [0.0, 1.0] using 11 nodes 
+and coefficients of Mattsson2017

Upwind operators are derivative operators biased towards one direction. The "minus" variants has a bias towards the left side, i.e., it uses values from more nodes to the left than from the right to compute the discrete derivative approximation at a given node (in the interior of the domain). In matrix form, this means more non-zero entries are left from the diagonal.

Matrix(D_upw.minus)
11×11 Matrix{Float64}:
+ -10.0   10.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+ -10.0   10.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+   5.0  -20.0   15.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+   0.0    5.0  -20.0   15.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0    5.0  -20.0   15.0    0.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0    5.0  -20.0   15.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0    5.0  -20.0   15.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0    5.0  -20.0   15.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0    0.0    5.0  -20.0   15.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0    4.0  -16.0   10.0   2.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0   20.0  -50.0  30.0

Analogously, the "plus" variant has a bias towards the right side.

Matrix(D_upw.plus)
11×11 Matrix{Float64}:
+ -30.0   50.0  -20.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+  -2.0  -10.0   16.0   -4.0    0.0    0.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0  -15.0   20.0   -5.0    0.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0  -15.0   20.0   -5.0    0.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0  -15.0   20.0   -5.0    0.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0  -15.0   20.0   -5.0    0.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0    0.0  -15.0   20.0   -5.0    0.0   0.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0  -15.0   20.0   -5.0   0.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0  -15.0   20.0  -5.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0  -10.0  10.0
+   0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0    0.0  -10.0  10.0

For more information on upwind SBP operators, please refer to the documentation of SummationByPartsOperators.jl and references cited there.

The basic idea of upwind SBP schemes is to apply a flux vector splitting and use appropriate upwind operators for both parts of the flux. In 1D, this means to split the flux

\[f(u) = f^-(u) + f^+(u)\]

such that $f^-(u)$ is associated with left-going waves and $f^+(u)$ with right-going waves. Then, we apply upwind SBP operators $D^-, D^+$ with an appropriate upwind bias, resulting in

\[\partial_x f(u) \approx D^+ f^-(u) + D^- f^+(u)\]

Note that the established notations of upwind operators $D^\pm$ and flux splittings $f^\pm$ clash. The right-going waves from $f^+$ need an operator biased towards their upwind side, i.e., the left side. This upwind bias is provided by the operator $D^-$.

Many classical flux vector splittings have been developed for finite volume methods and are described in the book "Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction" of Eleuterio F. Toro (2009), DOI: 10.1007/b79761. One such a well-known splitting provided by Trixi.jl is splitting_steger_warming.

Trixi.jl comes with several example setups using upwind SBP methods with flux vector splitting, e.g.,

Package versions

These results were obtained using the following versions.

using InteractiveUtils
+versioninfo()
+
+using Pkg
+Pkg.status(["Trixi", "SummationByPartsOperators"],
+           mode=PKGMODE_MANIFEST)
Julia Version 1.9.3
+Commit bed2cd540a1 (2023-08-24 14:43 UTC)
+Build Info:
+  Official https://julialang.org/ release
+Platform Info:
+  OS: Linux (x86_64-linux-gnu)
+  CPU: 2 × Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
+  WORD_SIZE: 64
+  LIBM: libopenlibm
+  LLVM: libLLVM-14.0.6 (ORCJIT, skylake-avx512)
+  Threads: 1 on 2 virtual cores
+Environment:
+  JULIA_PKG_SERVER_REGISTRY_PREFERENCE = eager
+Status `~/work/Trixi.jl/Trixi.jl/docs/Manifest.toml`
+  [9f78cca6] SummationByPartsOperators v0.5.51
+  [a7f1ee26] Trixi v0.5.48-pre `~/work/Trixi.jl/Trixi.jl`

This page was generated using Literate.jl.

diff --git a/previews/PR1697/visualization/index.html b/previews/PR1697/visualization/index.html new file mode 100644 index 00000000000..455d3952ade --- /dev/null +++ b/previews/PR1697/visualization/index.html @@ -0,0 +1,91 @@ + +Visualization · Trixi.jl

Visualization

There are two possible approaches to visualize results from Trixi.jl: either directly from the REPL using Plots.jl or with ParaView/VisIt by postprocessing Trixi.jl's output files with Trixi2Vtk.

Plots.jl [experimental]

By far the easiest and most convenient plotting approach is to use the powerful Plots.jl package to directly visualize Trixi.jl's results from the REPL. In the following, you will find more information on a number of topics for how to use Plots.jl together with Trixi.jl:

  1. Getting started
  2. Customizing plot results via a PlotData2D object
  3. Plotting a 3D solution as a 2D plot
  4. Creating a 1D plot
  5. Plotting a 2D or 3D solutions as a 1D plot
  6. Visualizing results during a simulation
Note

Plotting via Plots.jl is still considered an experimental feature and might change in any future releases.

Getting started

After running a simulation with Trixi.jl in the REPL, load the Plots package with

julia> using Plots

To visualize the solution, execute

julia> plot(sol)

Here we assume that sol holds the return value of the solve(...) method (with type SciMLBase.ODESolution), which is the default variable name when you use one of the example elixirs. This will generate a grid layout with one subplot for each solution variable, convenient for getting an overview of the current solution:

plot-sol

You can save the resulting file as a PNG image file by calling savefig(...) with an output file name that ends in .png, e.g.,

julia> savefig("solution-overview.png")

In Trixi.jl, two plot types are available: 2D heatmap plots and 1D line plots. If you use plot(sol), Trixi.jl will automatically choose the plot type that fits the dimensions of the sol input: 2D/3D data will be visualized as a heatmap, 1D data as a line plot. For more fine-grained control over what to plot, you can create such an object yourself, which can either be a PlotData2D or a PlotData1D object. For further details on both of these see below:

Customizing plot results via a PlotData2D object

For more fine-grained control over what to plot, first create a PlotData2D object by executing

julia> pd = PlotData2D(sol)
+julia> pd = PlotData2D(u, semi)

where u is an array containing the solution and semi is the semidiscretization. For example, if PlotData2D(sol.u[2], semi) is specified, this will create a PlotData2D instance from the 2nd saved time-step. If PlotData2D(sol(0.5), semi) is specified, it will construct a PlotData2D instance using OrdinaryDiffEq.jl's interpolation to evaluate the solution at time t=0.5.

This takes the results generated by Trixi.jl and stores them in a data format that can be understood by the Plots package, and pd holds all data relevant for plotting sol. You can pass variable names as strings to pd using a dictionary-like syntax, e.g.,

julia> plot(pd["rho"])

This will create a single 2D heatmap plot of the variable rho:

plot-rho

The default plot type and style can be overridden by passing any additional arguments that are understood by the Plots package. For example, to change the color scheme and add names to the axes, modify the previous command to

julia> plot(pd["rho"], seriescolor = :heat, xguide="x", yguide="y")

to yield

plot-rho-modified

For more details on the various format options for plot, please consult the Plots documentation.

In addition, you can plot the mesh lines on top of the solution variables by calling the getmesh(...) function on the PlotData2D object

julia> plot!(getmesh(pd)) # here we use `plot!` with an `!` to add to the previous plot

which modifies the previous plot to

plot-rho-modified-mesh

By default, PlotData2D will convert the conserved variables to primitive variables, but this can be changed by passing an appropriate conversion function in the solution_variables keyword argument, similar to the behavior of the SaveSolutionCallback:

julia> pd = PlotData2D(sol; solution_variables=cons2cons) # Plot conservative variables

There are several other keyword arguments that influence how the solution data is processed for visualization with the Plots package. A detailed explanation can be found in the docstring of the PlotData2D constructor.

Another way to change the appearance of a plot is to convert the solution to a uniformly refined mesh before plotting. This can be helpful, e.g., when trying different settings for a simulation with adaptive mesh refinement, where one would like to ignore the mesh changes when comparing solutions. This is achieved with adapt_to_mesh_level, which uses the mesh adaptation routines to adapt the solution to a uniform grid. For example, the AMR solution from above could be preprocessed with

julia> pd = PlotData2D(adapt_to_mesh_level(sol, 4)...)

When plotted together with the mesh, this will yield the following visualization:

plot-rho-uniform-mesh

Plotting a user-defined scalar field

To plot a scalar quantity, one can call plot(ScalarPlotData2D(u, semi)), where u is an array of nodal values of the scalar field to plot. The layout of u should match the layout of the x and y nodal coordinates of the respective solver. For example, after running trixi_include(joinpath("examples", "unstructured_2d_dgsem", "elixir_euler_wall_bc.jl")), the following can be used to plot the function f(x, y) = x * y:

x = view(semi.cache.elements.node_coordinates, 1, :, :, :)
+y = view(semi.cache.elements.node_coordinates, 2, :, :, :)
+plot(ScalarPlotData2D(x .* y, semi))

This produces the following plot:

scalar-plotting-example

This routine can be used to visualize scalar quantities which depend on the solution, such as the norm of a velocity vector or two-dimensional vorticity. For example, we can visualize vorticity for a compressible version of the Brown-Minion vortex problem:

julia> using Trixi, Plots
+
+julia> redirect_stdout(devnull) do
+         # runs the elixir without any output from callbacks etc.
+         trixi_include(@__MODULE__,
+           joinpath(examples_dir(), "dgmulti_2d", "elixir_euler_brown_minion_vortex.jl"))
+       end
+[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.
+
+julia> function compute_vorticity(velocity, mesh, equations::CompressibleEulerEquations2D,
+                                  dg::DGMulti, cache)
+         rd = dg.basis
+         md = mesh.md
+         @unpack Dr, Ds = rd
+         @unpack rxJ, sxJ, ryJ, syJ, J = md
+         v1, v2 = velocity
+         dv1dy = ryJ .* (Dr * v1) + syJ .* (Ds * v1)
+         dv2dx = rxJ .* (Dr * v2) + sxJ .* (Ds * v2)
+         return dv2dx - dv1dy
+       end;
+
+julia> compute_vorticity(velocity, semi) =
+         compute_vorticity(velocity, Trixi.mesh_equations_solver_cache(semi)...);
+
+julia> function get_velocity(sol)
+         rho, rhou, rhov, E = StructArrays.components(sol.u[end])
+         v1 = rhou ./ rho
+         v2 = rhov ./ rho
+         return v1, v2
+       end;
+
+julia> vorticity = compute_vorticity(get_velocity(sol), semi);
+
+julia> plot(ScalarPlotData2D(vorticity, semi;
+            variable_name = "Vorticity at t = $(sol.prob.tspan[end])"))
+Plot{Plots.GRBackend() n=1}

This produces the following plot of vorticity.

vorticity-example

Since the mesh is fairly coarse, we observe numerical artifacts due to the low resolution. These errors vanish under mesh refinement; for example, doubling the mesh resolution by running

julia> trixi_include(joinpath(examples_dir(), "dgmulti_2d", "elixir_euler_BM_vortex.jl"), cells_per_dimension = 32)

yields the following plot of vorticity:

vorticity-example-refined

Note

When visualizing a scalar field, the plotted solution is reinterpolated using a high order polynomial approximation. Thus, small discrepancies may be observed when the underlying data is highly non-smooth or under-resolved.

ScalarPlotData2D objects can also be used with Makie through iplot. For example, the following code plots two surfaces:

julia> using Trixi, CairoMakie
+
+julia> redirect_stdout(devnull) do
+         # runs the elixir without any output from callbacks etc.
+         trixi_include(@__MODULE__,
+           joinpath(examples_dir(), "unstructured_2d_dgsem", "elixir_euler_wall_bc.jl"))
+       end
+[ Info: You just called `trixi_include`. Julia may now compile the code, please be patient.
+
+julia> x = view(semi.cache.elements.node_coordinates, 1, :, :, :); # extracts the node x coordinates
+
+julia> y = view(semi.cache.elements.node_coordinates, 2, :, :, :); # extracts the node y coordinates
+
+julia> fig_ax_plt = iplot(ScalarPlotData2D((@. 1 - .25*(x^2 + y^2)), semi), plot_mesh=true, colormap=:viridis);
+
+julia> fig_ax_plt2 = iplot!(fig_ax_plt, ScalarPlotData2D((@. .125*(x+y)), semi), plot_mesh=true, colormap=:blues)
+FigureAxisPlot()

This creates the following plot:

ScalarPlotData2D_example

Plotting a 3D solution as a 2D plot

It is possible to plot 2D slices from 3D simulation data using the TreeMesh with the same commands as above:

julia> plot(sol) # `sol` is from a 3D simulation

By default, plotting sol or creating a PlotData2D object from a 3D simulation will create a 2D slice of the solution in the xy-plane. You can customize this behavior by explicitly creating a PlotData2D object and passing appropriate keyword arguments:

  • slice specifies the plane which is being sliced and can be :xy, :xz, or :yz (default: :xy)
  • point specifies a three-dimensional point. The sliced plane is then created such that it lies on the point (default: (0.0, 0.0, 0.0)).

All other attributes for PlotData2D objects apply here as well.

For example, to plot the velocity field orthogonal to the yz-plane at different x-axis locations, you can execute

julia> trixi_include(joinpath(examples_dir(), "tree_3d_dgsem", "elixir_euler_taylor_green_vortex.jl"), tspan=(0.0, 1.0))
+[...]
+
+julia> plots = []
+Any[]
+
+julia> for x in range(0, stop=pi/2, length=6)
+         pd = PlotData2D(sol, slice=:yz, point=(x, 0.0, 0.0))
+         push!(plots, plot(pd["v1"], clims=(-1,1), title="x = "*string(round(x, digits=2))))
+       end
+
+julia> plot(plots..., layout=(2, 3), size=(750,350))

which results in a 2x3 grid of slices of the yz-plane:

plot-v1-0.0-to-0.5pi

Creating a 1D plot

When plotting a 1D solution with

julia> plot(sol) # `sol` is from a 1D simulation

Trixi.jl automatically creates a PlotData1D object and visualizes it as a line plot: 1d-plot

To customize your 1D plot, you can create a PlotData1D object manually as follows:

julia> pd = PlotData1D(sol)
+julia> pd = PlotData1D(u, semi)

The behavior is analogous to the PlotData2D behavior.

In a very similar fashion to PlotData2D, you can customize your plot:

  • plot(pd) creates the same plot as in plot(sol).
  • plot(pd["rho", "p"]) only plots specific variables. In this case rho and p.
  • plot!(getmesh(pd)) adds mesh lines after creating a plot.
  • Any attributes from Plots can be used, e.g., plot(pd, yguide=:temperature).
  • pd = PlotData1D(adapt_to_mesh_level(sol, 4)...) adapts the mesh before plotting (in this example to a mesh with refinement level 4).

You can also customize the PlotData1D object itself by passing attributes to the PlotData1D constructor:

  • solution_variables specifies the variables to be plotted.
  • nvisnodes sets the amount of nodes per element which the solution then is interpolated on.

Plotting a 2D or 3D solutions as a 1D plot

It is possible to extract a straight, axis-parallel line from a 2D or 3D solution and visualize it as a 1D plot. This is done by creating a PlotData1D object with a 2D/3D solution sol as input:

julia> pd = PlotData1D(sol)

The plot is then created with:

julia> plot(pd)

By default the x-axis is extracted, which can be changed with following attributes:

  • slice specifies the axis which is being extracted and can be :x, :y or :z (:z is only for 3D input and default is :x)
  • point specifies a two or three dimensional point. The sliced axis is then created in such a way, that it lies on the point. (default: (0.0, 0.0) or (0.0, 0.0, 0.0))

All other attributes for PlotData1D objects apply here as well.

In the following, is an example for a 2D simulation of the linear scalar advection equation. First, we have the regular 2D heatmap plot:

2d-plot-for-slice

From this, we can extract a line plot parallel to the y-axis going through the point (1.0, 0.0) with the following commands:

julia> pd = PlotData1D(sol, slice=:y, point=(1.0, 0.0))
+julia> plot(pd)

1d-plot-for-slice

This convenient method of slicing is limited to axis-parallel slices, but for 2D/3D solutions it is also possible to create a plot along any curve you want. To do so, you first need to create a list of 2D/3D points that define your curve. Then you can create a PlotData1D with the keyword argument curve set to your list.

Let's give an example of this with the basic advection equation from above by creating a plot along the circle marked in green:

2d-plot-along-circle

We can write a function like this, that outputs a list of points on a circle:

function circle(radius, center, n_points)
+    coordinates = zeros(2, n_points)
+    for i in 1:n_points
+        coordinates[:,i] = radius*[cospi(2*i/n_points), sinpi(2*i/n_points)] .+ center
+    end
+    return coordinates
+end

Then create and plot a PlotData1D object along a circle with radius one, center at (1,1), and 100 points:

pd = PlotData1D(sol, curve=circle(1.0, (1.0, 1.0), 100))
+plot(pd)

This gives you the following plot: 1d-plot-along-circle

Creating a plot like this has its downsides. For one, it is unclear what to put on the abscissa of the plot. By default, the arc length of the given curve is used. Also, with this way of plotting you lose the ability to use a mesh plot from getmesh.

Visualizing results during a simulation

To visualize solutions while a simulation is still running (also known as in-situ visualization), you can use the VisualizationCallback. It is created as a regular callback and accepts upon creation a number of keyword arguments that allow, e.g., to control the visualization interval, to specify the variables to plot, or to customize the plotting style.

During the simulation, the visualization callback creates and displays visualizations of the current solution in regular intervals. This can be useful to, e.g., monitor the validity of a long-running simulation or for illustrative purposes. An example for how to create a VisualizationCallback can be found in examples/tree_2d_dgsem/elixir_advection_amr_visualization.jl:

[...]
+
+# Enable in-situ visualization with a new plot generated every 20 time steps
+# and additional plotting options passed as keyword arguments
+visualization = VisualizationCallback(interval=20; clims=(0,1))
+
+[...]

The resulting output of the referenced elixir can be seen in the embedded video below:

+

Trixi2Vtk

Trixi2Vtk converts Trixi.jl's .h5 output files to VTK files, which can be read by ParaView, VisIt, and other visualization tools. It automatically interpolates solution data from the original quadrature node locations to equidistant visualization nodes at a higher resolution, to make up for the loss of accuracy from going from a high-order polynomial representation to a piecewise constant representation in VTK.

In the Julia REPL, first load the package Trixi2Vtk

julia> using Trixi2Vtk

To process an HDF5 file generated by Trixi.jl, execute

julia> trixi2vtk(joinpath("out", "solution_000000.h5"), output_directory="out")

This will create two unstructured VTK files in the out subdirectory that can be opened with ParaView or VisIt: solution_000000.vtu contains the discontinuous Galerkin solution data while solution_000000_celldata.vtu holds any cell-based values such as the current AMR indicator or the cell refinement level.

"solution_000000_scalar_mesh"

This allows you to generate VTK files for solution, restart and mesh files. By default, Trixi2Vtk generates .vtu (unstructured VTK) files for both cell/element data (e.g., cell ids, element ids) and node data (e.g., solution variables). This format visualizes each cell with the same number of nodes, independent of its size. Alternatively, you can provide format=:vti as a keyword argument to trixi2vtk, which causes Trixi2Vtk to generate .vti (image data VTK) files for the solution files, while still using .vtu files for cell-/element-based data. In .vti files, a uniform resolution is used throughout the entire domain, resulting in different number of visualization nodes for each element. This can be advantageous to create publication-quality images, but increases the file size.

If you want to convert multiple solution/restart files at once, you can just supply multiple input files as the positional arguments to trixi2vtk, e.g.,

julia> trixi2vtk("out/solution_000000.h5", "out/solution_000040.h5")

You may also use file globbing to select a range of files based on filename patterns, e.g.,

julia> trixi2vtk("out/solution_*.h5")

to convert all solution files in the out/ directory or

julia> trixi2vtk("out/restart_00[0-9]000.h5")

to convert every one-thousandth restart file (out/restart_000000.h5, out/restart_001000.h5 etc.).

When multiple solution/restart files are provided, Trixi2Vtk will also generate a .pvd file, which allows ParaView to read all .vtu/.vti files at once and which uses the time attribute in solution/restart files to inform ParaView about the solution time. A comprehensive list of all possible arguments for trixi2vtk can be found in the Trixi2Vtk.jl API.

Further information regarding the development of Trixi2Vtk can be found in the development section.

Makie.jl [experimental]

In addition to Plots.jl support, Trixi.jl includes visualization utilities through Makie.jl. Trixi.jl provides Makie-based visualization options both for heatmap-type plots (similar to the Plots.jl recipes) as well as for interactive surface plots. Support is currently limited to the UnstructuredMesh2D type.

Note

Plotting via Makie.jl is still considered an experimental feature and might change in any future releases.

A Makie plot can be created as follows: after running a simulation with Trixi.jl in the REPL, load a Makie backend (for example, GLMakie or CairoMakie).

julia> using GLMakie

To visualize the solution and mesh with a heatmap-type plot, simply run

julia> plot(sol)
Note

Both Makie.jl and Plots.jl export plot, so if you load both libraries, you will have to specify which plot function to call via Plots.plot or Makie.plot.

As with Plots.jl recipes, one can view individual solution components by creating a PlotData2D object and indexing into it with the desired variable name

julia> pd = PlotData2D(sol)
+julia> plot(pd["rho"])

Unlike the Plots.jl recipe, mesh plotting is controlled using the keyword argument plot_mesh = false, e.g.,

julia> plot(sol; plot_mesh=false)

The plot command also returns figure and axis handles, which can be used to edit plot titles or labels:

julia> fig, axes = plot(sol)
+julia> axes[1,1].title = "New title for subplot (1,1)"

Trixi.jl also supports interactive surface plots using iplot. After executing

julia> trixi_include(joinpath("examples", "unstructured_2d_dgsem", "elixir_euler_wall_bc.jl"))

we can run

julia> iplot(sol)

This will open up an interactive visualization window:

makie-example

The plot can be rotated (click and hold), zoomed in and out (scroll up and down), and panned (hold right click and drag). Two toggle buttons control whether mesh lines are visible on top of and below the solution.

Both plot and iplot use colormap = :inferno by default. A different colormap can be selected by providing an appropriate keyword argument. For example, plot(sol, colormap=:blues) and iplot(sol, colormap=:blues) produce the following figures:

makie-plot-example makie-iplot-example