Skip to content

Commit

Permalink
Last improvements to documentation for 0.3.0 (#316)
Browse files Browse the repository at this point in the history
* Fix Vale

* Fix Vale

* Bump to vimtor/[email protected]

* Fix Vale

* Fix docs artifact upload

* Update documentation

* Improve API documentation.

* Typo in examples/__init__.py
  • Loading branch information
PProfizi committed Mar 8, 2023
1 parent 6bd968c commit 305bcdd
Show file tree
Hide file tree
Showing 38 changed files with 297 additions and 184 deletions.
34 changes: 24 additions & 10 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,14 @@ on:
required: true
type: string
default: ''
generate_pdf:
description: "Whether to build the PDF doc"
type: string
default: 'True'
debug:
description: "Debug verbose mode"
type: string
default: 'True'
# Can be called manually
workflow_dispatch:
inputs:
Expand Down Expand Up @@ -60,6 +68,10 @@ on:
required: false
type: string
default: ''
generate_pdf:
description: "Whether to build the PDF doc"
type: string
default: 'True'

env:
PACKAGE_NAME: ansys-dpf-post
Expand Down Expand Up @@ -169,21 +181,23 @@ jobs:
- name: "Upload Documentation Build log"
uses: actions/[email protected]
with:
name: doc-${{inputs.PACKAGE_NAME}}-log
name: doc-${{env.PACKAGE_NAME}}-log
path: docs/*.txt
if: inputs.debug == 'false'
if: always()

- name: "Zip HTML Documentation"
uses: vimtor/action-zip@v1
uses: vimtor/action-zip@v1.1
with:
files: docs/build/html
dest: HTML-doc-${{inputs.PACKAGE_NAME}}.zip
dest: HTML-doc-${{env.PACKAGE_NAME}}.zip
if: always()

- name: "Upload HTML Documentation"
uses: actions/upload-artifact@v3
with:
name: HTML-doc-${{inputs.PACKAGE_NAME}}
path: HTML-doc-${{inputs.PACKAGE_NAME}}.zip
name: HTML-doc-${{env.PACKAGE_NAME}}
path: HTML-doc-${{env.PACKAGE_NAME}}.zip
if: always()

- name: "Find PDF Documentation"
shell: bash
Expand All @@ -197,18 +211,18 @@ jobs:
echo "Found PDF doc: ${files[0]}"
- name: "Zip PDF Documentation"
uses: vimtor/action-zip@v1
uses: vimtor/action-zip@v1.1
if: ${{ inputs.generate_pdf == 'true' }}
with:
files: docs/build/latex/${{ steps.pdf.outputs.PDF_file }}
dest: PDF-doc-${{inputs.PACKAGE_NAME}}.zip
dest: PDF-doc-${{env.PACKAGE_NAME}}.zip

- name: "Upload PDF Documentation"
uses: actions/[email protected]
if: inputs.generate_pdf == 'true'
with:
name: PDF-doc-${{inputs.PACKAGE_NAME}}
path: PDF-doc-${{inputs.PACKAGE_NAME}}.zip
name: PDF-doc-${{env.PACKAGE_NAME}}
path: PDF-doc-${{env.PACKAGE_NAME}}.zip

- name: "Kill all servers"
uses: pyansys/pydpf-actions/[email protected]
Expand Down
15 changes: 6 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# DPF-Post - Ansys Data Post-Processing Framework
# PyDPF-Post - Ansys Data Post-Processing Framework
[![PyAnsys](https://img.shields.io/badge/Py-Ansys-ffc107.svg?logo=)](https://docs.pyansys.com/)
[![Python](https://img.shields.io/pypi/pyversions/ansys-dpf-post?logo=pypi)](https://pypi.org/project/ansys-dpf-post/)
[![pypi](https://badge.fury.io/py/ansys-dpf-post.svg?logo=python&logoColor=white)](https://pypi.org/project/ansys-dpf-post)
Expand All @@ -17,15 +17,13 @@ be found by visiting [PyDPF-Core
GitHub](https://github.com/pyansys/pydpf-core). Use ``ansys-dpf-core`` for
building more advanced and customized workflows using Ansys DPF.


## Documentation

Visit the [DPF-Post Documentation](https://postdocs.pyansys.com) for a
Visit the [PyDPF-Post Documentation](https://postdocs.pyansys.com) for a
detailed description of the package, or see the [Examples
Gallery](https://postdocs.pyansys.com/examples/index.html) for more
detailed examples.


## Installation

Install this repository with:
Expand All @@ -42,11 +40,10 @@ cd pydpf-post
pip install . --user
```


## Brief Demo

Provided you have ANSYS 2023 R1 installed, a DPF server will start
automatically once you start using pyDPF-Post.
Provided you have ANSYS 2023 R1 installed, a DPF server starts
automatically once you start using PyDPF-Post.
Loading a simulation to extract and post-process results:

```pycon
Expand All @@ -56,6 +53,7 @@ Loading a simulation to extract and post-process results:
>>> displacement = simulation.displacement()
>>> print(displacement)
```
```pycon
results U
set_id 3
node comp
Expand All @@ -66,7 +64,7 @@ Loading a simulation to extract and post-process results:
Y 1.44e-03
Z 5.31e-06
...

```
```pycon
>>> displacement.plot()
```
Expand All @@ -89,7 +87,6 @@ tools:
```
![Example Stress plot Crankshaft](https://github.com/pyansys/dpf-post/raw/master/docs/source/images/crankshaft_stress.png)


## License

``PyDPF-Post`` is licensed under the MIT license. For more information, see the
Expand Down
8 changes: 5 additions & 3 deletions docs/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@
(
master_doc,
"PyDPF-Post.tex",
"PyAnsys DPF-Post Documentation",
"PyAnsys PyDPF-Post Documentation",
author,
"manual",
),
Expand All @@ -228,7 +228,9 @@

# One entry per manual page. List of tuples
# (source start file, name, description, authors, manual section).
man_pages = [(master_doc, "PyDPF-Post", "PyAnsys DPF-Post Documentation", [author], 1)]
man_pages = [
(master_doc, "PyDPF-Post", "PyAnsys PyDPF-Post Documentation", [author], 1)
]


# -- Options for Texinfo output ----------------------------------------------
Expand All @@ -240,7 +242,7 @@
(
master_doc,
"PyDPF-Post",
"PyAnsys DPF-Post Documentation",
"PyAnsys PyDPF-Post Documentation",
author,
"pyansys",
"",
Expand Down
4 changes: 2 additions & 2 deletions docs/source/contributing.rst
Original file line number Diff line number Diff line change
Expand Up @@ -25,13 +25,13 @@ development mode, run:
Post issues
-----------

Use the `PyDPF-Post Issues <https://github.com/pyansys/DPF-Post/issues>`_
Use the `PyDPF-Post Issues <https://github.com/pyansys/pydpf-post/issues>`_
page to submit questions, report bugs, and request new features.

To reach the PyAnsys support team, email `[email protected] <[email protected]>`_.

View documentation
------------------
Documentation for the latest stable release of PyDPF-Post is hosted at
`PyDPF Documentation <https://postdocs.pyansys.com/>_.
`PyDPF Documentation <https://post.docs.pyansys.com/>`_.

5 changes: 4 additions & 1 deletion docs/source/getting_started/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,11 @@ Getting started

To use the PyDPF-Post API, you must have PyDPF-Core installed. Because you need to
use a native DPF server, you must also have a local installation of Ansys 2021 R1
or later. For more information on getting a licensed copy of Ansys, visit the
or later or of the standalone DPF Server.
For more information on getting a licensed copy of Ansys, visit the
`Ansys website <https://www.ansys.com/>`_.
For more information on getting the standalone DPF Server, visit the
`PyDPF-Core documentation <https://dpf.docs.pyansys.com/dev/user_guide/getting_started_with_dpf_server.html>`_.


.. toctree::
Expand Down
6 changes: 3 additions & 3 deletions docs/source/getting_started/install.rst
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ and unzip it to the same local directory before running the preceding command ag
Install in development mode
---------------------------

If you want to edit and potentially contribute to DPF-Post,
If you want to edit and potentially contribute to PyDPF-Post,
clone the repository and install it using ``pip`` with the ``-e``
development flag:

Expand All @@ -66,5 +66,5 @@ Run the following Python code to verify your PyDPF-Post installation:
from ansys.dpf import post
from ansys.dpf.post import examples
solution = post.load_solution(examples.simple_bar)
print(solution)
simulation = post.load_simulation(examples.simple_bar)
print(simulation)
Binary file added docs/source/images/crankshaft_stress_xx.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
8 changes: 4 additions & 4 deletions docs/source/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,15 @@ The Python `ansys-dpf-post` package provides a high level, physics oriented API
Loading a simulation (defined by its result files) allows you to extract simulation metadata as well
as results and apply postprocessing operations on it.

This module leverages the PyDPF-Core project's ``ansys-dpf-core`` package and can
be found by visiting [PyDPF-Core GitHub](https://github.com/pyansys/pydpf-core).
This module leverages the PyDPF-Core project's ``ansys-dpf-core`` package which can
be found by visiting `PyDPF-Core GitHub <https://github.com/pyansys/pydpf-core>`_.
Use ``ansys-dpf-core`` for building more advanced and customized workflows using Ansys DPF.


Brief demo
~~~~~~~~~~

Provided you have ANSYS 2023 R1 installed, a DPF server will start
Provided you have Ansys 2023 R1 installed, a DPF server starts
automatically once you start using PyDPF-Post.
Loading a simulation for a MAPDL result file to extract and post-process results:

Expand Down Expand Up @@ -87,7 +87,7 @@ Key features

PyDPF-Post is based on DPF, whose data framework localizes loading and
postprocessing on the DPF server, enabling rapid postprocessing workflows
because they are written in C and FORTRAN. Because DPF-Post presents results
because they are written in C and FORTRAN. Because PyDPF-Post presents results
in a Pythonic manner, you can rapidly develop simple or complex postprocessing
scripts.

Expand Down
86 changes: 56 additions & 30 deletions docs/source/user_guide/accessing_file_metadata.rst
Original file line number Diff line number Diff line change
Expand Up @@ -4,67 +4,93 @@
Browse result metadata
**********************

In addition to the :class:`DpfSolution <ansys.dpf.post.dpf_solution.DpfSolution>`
In addition to the :class:`Simulation <ansys.dpf.post.simulation.Simulation>`
object being the entry point for browsing the contents of a result file, it provides
important metadata, such as the analysis type and the available results.

Here is how you browse result metadata:

.. code:: python
Instantiate the solution object
Instantiate the simulation object
>>> from ansys.dpf import post
>>> from ansys.dpf.post import examples
>>> solution = post.load_solution(examples.multishells_rst)
>>> simulation = post.load_simulation(examples.multishells_rst)
Browse result metadata
>>> result_info = solution.get_result_info()
>>> print(result_info)
>>> print(simulation)
Static Mechanical Simulation.
Data Sources
------------------------------
DPF DataSources:
Result files:
result key: rst and path: d:\ansysdev\sandbox\pydpf-core\src\ansys\dpf\core\examples\model_with_ns.rst
Secondary files:
DPF Model
------------------------------
Static analysis
Unit system: Metric (m, kg, N, s, V, A)
Physics Type: Mecanic
Unit system: MKS: m, kg, N, s, V, A, degC
Physics Type: Mechanical
Available results:
- displacement
- force
- stress
- volume
- energy_stiffness_matrix
- hourglass_energy
- thermal_dissipation_energy
- kinetic_energy
- co_energy
- incremental_energy
- strain
- temperature
DPF-Post supports four different analysis types:
- displacement: Nodal Displacement
- reaction_force: Nodal Force
- stress: ElementalNodal Stress
- elemental_volume: Elemental Volume
- stiffness_matrix_energy: Elemental Energy-stiffness matrix
- artificial_hourglass_energy: Elemental Hourglass Energy
- thermal_dissipation_energy: Elemental thermal dissipation energy
- kinetic_energy: Elemental Kinetic Energy
- co_energy: Elemental co-energy
- incremental_energy: Elemental incremental energy
- elastic_strain: ElementalNodal Strain
- structural_temperature: ElementalNodal Temperature
------------------------------
DPF Meshed Region:
7079 nodes
4220 elements
Unit: m
With solid (3D) elements, shell (2D) elements, shell (3D) elements
------------------------------
DPF Time/Freq Support:
Number of sets: 1
Cumulative Time (s) LoadStep Substep
1 1.000000 1 1
PyDPF-Post supports four different analysis types for mechanical results:

* Static analysis
* Modal analysis
* Harmonic analysis
* Transient analysis

The legacy Solution object also supports thermal and electrical results.

Mesh
----
From the ``Solution`` object, you can also access the mesh:
From the ``Simulation`` object, you can also access the mesh:

.. code:: python
Instantiate the solution object
Instantiate the simulation object
>>> from ansys.dpf import post
>>> from ansys.dpf.post import examples
>>> solution = post.load_solution(examples.multishells_rst)
>>> simulation = post.load_simulation(examples.multishells_rst)
Access the mesh
>>> mesh = solution.mesh
>>> mesh = simulation.mesh
>>> print(mesh)
Meshed Region
7079 nodes
4220 elements
Unit: m
DPF Mesh:
7079 nodes
4220 elements
Unit: m
With solid (3D) elements, shell (2D) elements, shell (3D) elements
Loading

0 comments on commit 305bcdd

Please sign in to comment.