.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "auto_examples/howto_logparser/plot_logparser_intro.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_logparser_plot_logparser_intro.py: Introduction ============ This simple example demonstrates how to analyze the OGS (OpenGeoSys) log output to extract performance information regarding various computational parts of OGS. Here we utilize the project file from the benchmark titled: `OGS: Constant viscosity (Hydro-Thermal) `_ .. GENERATED FROM PYTHON SOURCE LINES 17-20 Complete example ================ For detailed explanation see all sections below. .. GENERATED FROM PYTHON SOURCE LINES 20-37 .. code-block:: Python import pandas as pd from ogstools.logparser import ( fill_ogs_context, parse_file, time_step_vs_iterations, ) from ogstools.logparser.examples import ( const_viscosity_thermal_convection_log, ) records = parse_file(const_viscosity_thermal_convection_log) df_records = pd.DataFrame(records) df_log = fill_ogs_context(df_records) df_ts_it = time_step_vs_iterations(df_log) df_ts_it .. raw:: html
iteration_number
time_step
0 1
1 2
2 1
3 1
4 1
5 3
6 1
7 1
8 1
9 2
10 2
11 2
12 4
13 1
14 4
15 1
16 4
17 4
18 5
19 5
20 7
21 7
22 8
23 9
24 17
25 23
26 20


.. GENERATED FROM PYTHON SOURCE LINES 41-59 The log file ------------- Running `ogs` in the command line outputs the logs into the console output. With `tee `_ in Linux and Mac and `Tee-Object `_ in Windows Powershell the log gets directed into a file and into the console. * **Linux/Mac**: ``ogs | tee `` * **Windows**: ``ogs | Tee-Object -FilePath `` For first step we recommend to use either **`ogs -l info`** or `ogs - l debug`. Make sure the log file does not contain `ANSI escape (e.g.color) code `_. You can remove it with: ``cat ogs.log | sed 's/\x1b\[[0-9;]*m//g' > ogs.log`` .. GENERATED FROM PYTHON SOURCE LINES 62-70 Parsing steps ------------- The functions :py:mod:`ogstools.logparser.parse_file` and :py:mod:`ogstools.logparser.fill_ogs_context` are explained in :ref:`sphx_glr_auto_examples_howto_logparser_plot_logparser_advanced.py`. All predefined analyses need the result of fill_ogs_context. Here `const_viscosity_thermal_convection_log` is string representing the location of the ogs log file. .. GENERATED FROM PYTHON SOURCE LINES 70-71 .. code-block:: Python print(const_viscosity_thermal_convection_log) .. rst-class:: sphx-glr-script-out .. code-block:: none /builds/ogs/tools/ogstools/ogstools/logparser/examples/ConstViscosityThermalConvection.log .. GENERATED FROM PYTHON SOURCE LINES 72-76 .. code-block:: Python records = parse_file(const_viscosity_thermal_convection_log) df_records = pd.DataFrame(records) df_log = fill_ogs_context(df_records) .. GENERATED FROM PYTHON SOURCE LINES 77-89 Use predefined analyses ----------------------- :py:mod:`ogstools.logparser.time_step_vs_iterations` is one of many predefined analyses. All possibilities are shown here: :ref:`sphx_glr_auto_examples_howto_logparser_plot_logparser_analyses.py`. Here we are interested in every time step of the simulation and how many iterations have been needed. The predefined analyses only work with logs from `ogs` run with level `info` or finer (`debug`), like `ogs -l info` or `ogs - l debug`. (see `OGS Developer Guide - log and debug output `_ .. GENERATED FROM PYTHON SOURCE LINES 89-96 .. code-block:: Python df_ts_it = time_step_vs_iterations(df_log) # The result is a pandas.DataFrame. You may manipulate the dataframe to your # needs with pandas functionality. pd.set_option("display.max_rows", 8) # for visualization only df_ts_it .. raw:: html
iteration_number
time_step
0 1
1 2
2 1
3 1
... ...
23 9
24 17
25 23
26 20

27 rows × 1 columns



.. GENERATED FROM PYTHON SOURCE LINES 97-102 Pandas to plot -------------- You can directly use `plot` ` `_ from pandas. .. GENERATED FROM PYTHON SOURCE LINES 102-103 .. code-block:: Python df_ts_it.plot(grid=True) .. image-sg:: /auto_examples/howto_logparser/images/sphx_glr_plot_logparser_intro_001.png :alt: plot logparser intro :srcset: /auto_examples/howto_logparser/images/sphx_glr_plot_logparser_intro_001.png :class: sphx-glr-single-img .. rst-class:: sphx-glr-script-out .. code-block:: none .. rst-class:: sphx-glr-timing **Total running time of the script:** (0 minutes 0.125 seconds) .. _sphx_glr_download_auto_examples_howto_logparser_plot_logparser_intro.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: plot_logparser_intro.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: plot_logparser_intro.py `