.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "auto_examples/howto_studies/plot_convergence_study_steady_state_diffusion.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code. .. rst-class:: sphx-glr-example-title .. _sphx_glr_auto_examples_howto_studies_plot_convergence_study_steady_state_diffusion.py: Convergence study (spatial refinement) ====================================== This example shows one possible implementation of how to do a convergence study. It uses the project file from the following benchmark with multiple discretizations to evaluate the accuracy of the numerical solutions. `ogs: elliptic neumann benchmark `_ Here is some theoretical background for the topic of grid convergence: `Nasa convergence reference `_ `More comprehensive reference `_ At least three meshes of increasing refinement are required for the convergence study. The three finest meshes are used to calculated the Richardson extrapolation. The third coarsest mesh will be used for the topology to evaluate the results. Its nodes should be shared by the finer meshes, otherwise interpolation will influence the results. With unstructured grids this can be achieved as well with refinement by splitting. The results to analyze are generated on the fly with the following code. If you are only interested in the convergence study, please skip to `Hydraulic pressure convergence`_. First, the required packages are imported and an output directory is created: .. GENERATED FROM PYTHON SOURCE LINES 34-55 .. code-block:: Python from pathlib import Path from tempfile import mkdtemp from IPython.display import HTML from ogs6py import ogs from ogstools import ( examples, meshlib, meshplotlib, msh2vtu, propertylib, workflow, ) from ogstools.studies import convergence meshplotlib.setup.reset() temp_dir = Path(mkdtemp(suffix="steady_state_diffusion")) report_name = str(temp_dir / "report.ipynb") result_paths = [] .. GENERATED FROM PYTHON SOURCE LINES 56-60 The meshes and their boundaries are generated easily via gmsh and :py:mod:`ogstools.msh2vtu`. Then we run the different simulations with increasingly fine spatial discretization via ogs6py and store the results for the convergence study. .. GENERATED FROM PYTHON SOURCE LINES 62-82 .. code-block:: Python refinements = 6 edge_cells = [2**i for i in range(refinements)] for n_edge_cells in edge_cells: msh_path = temp_dir / "square.msh" meshlib.gmsh_meshing.rect( n_edge_cells=n_edge_cells, structured_grid=True, out_name=msh_path ) msh2vtu.msh2vtu(filename=msh_path, output_path=temp_dir, log_level="ERROR") model = ogs.OGS( PROJECT_FILE=temp_dir / "default.prj", INPUT_FILE=examples.prj_steady_state_diffusion, ) prefix = "steady_state_diffusion_" + str(n_edge_cells) model.replace_text(prefix, ".//prefix") model.write_input() ogs_args = f"-m {temp_dir} -o {temp_dir}" model.run_model(write_logs=False, args=ogs_args) result_paths += [str(temp_dir / (prefix + ".pvd"))] .. rst-class:: sphx-glr-script-out .. code-block:: none OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.16755294799804688 s OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.16966700553894043 s OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.16870975494384766 s OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.17183709144592285 s OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.1815049648284912 s OGS finished with project file /tmp/tmpe0tqiu00steady_state_diffusion/default.prj. Execution took 0.17935800552368164 s .. GENERATED FROM PYTHON SOURCE LINES 83-84 Here we calculate the analytical solution on one of the meshes: .. GENERATED FROM PYTHON SOURCE LINES 86-94 .. code-block:: Python analytical_solution_path = temp_dir / "analytical_solution.vtu" solution = examples.analytical_diffusion( meshlib.MeshSeries(result_paths[-1]).read(0) ) meshplotlib.setup.show_element_edges = True fig = meshplotlib.plot(solution, propertylib.properties.hydraulic_height) solution.save(analytical_solution_path) .. image-sg:: /auto_examples/howto_studies/images/sphx_glr_plot_convergence_study_steady_state_diffusion_001.png :alt: plot convergence study steady state diffusion :srcset: /auto_examples/howto_studies/images/sphx_glr_plot_convergence_study_steady_state_diffusion_001.png :class: sphx-glr-single-img .. GENERATED FROM PYTHON SOURCE LINES 95-101 Hydraulic pressure convergence ------------------------------ The pressure field of this model is converging well. The convergence ratio is approximately 1 on the whole mesh and looking at the relative errors we see a quadratic convergence behavior. .. GENERATED FROM PYTHON SOURCE LINES 103-113 .. code-block:: Python convergence.run_convergence_study( output_name=report_name, mesh_paths=result_paths, property_name="hydraulic_height", timevalue=1, refinement_ratio=2.0, reference_solution_path=str(analytical_solution_path), ) HTML(workflow.jupyter_to_html(report_name, show_input=False)) .. raw:: html
report


.. GENERATED FROM PYTHON SOURCE LINES 114-128 Darcy velocity convergence -------------------------- For the velocity we some discrepancy of the convergence ratio in the bottom right corner. Thus we know, at these points the mesh isn't properly converging (at least for the velocity field). We see, that in the bottom right corner, the velocity magnitude seems to be steadily increasing, which is also reflected in the Richardson extrapolation, which shows an anomalous high value in this spot, hinting at a singularity there. This is explained by the notion in the benchmark's documentation of "incompatible boundary conditions imposed on the bottom right corner of the domain." Regardless of this, the benchmark gives a convergent solution for the pressure field. The code cells from the templated notebook are show here for transparency. .. GENERATED FROM PYTHON SOURCE LINES 130-139 .. code-block:: Python convergence.run_convergence_study( output_name=report_name, mesh_paths=result_paths, property_name="velocity", timevalue=1, refinement_ratio=2.0, ) HTML(workflow.jupyter_to_html(report_name, show_input=True)) .. raw:: html
report


.. rst-class:: sphx-glr-timing **Total running time of the script:** (0 minutes 24.679 seconds) .. _sphx_glr_download_auto_examples_howto_studies_plot_convergence_study_steady_state_diffusion.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: plot_convergence_study_steady_state_diffusion.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: plot_convergence_study_steady_state_diffusion.py `