1- # PyDPF-Post - Ansys Data PostProcessing Framework
1+ # PyDPF-Post
22[ ![ PyAnsys] ( https://img.shields.io/badge/Py-Ansys-ffc107.svg?logo= )] ( https://docs.pyansys.com/ )
33[ ![ Python] ( https://img.shields.io/pypi/pyversions/ansys-dpf-post?logo=pypi )] ( https://pypi.org/project/ansys-dpf-post/ )
44[ ![ pypi] ( https://badge.fury.io/py/ansys-dpf-post.svg?logo=python&logoColor=white )] ( https://pypi.org/project/ansys-dpf-post )
55[ ![ MIT] ( https://img.shields.io/badge/License-MIT-yellow.svg )] ( https://opensource.org/licenses/MIT )
66
7- Ansys Data Processing Framework (DPF) provides numerical simulation
8- users and engineers with a toolbox for accessing and transforming simulation
9- data. With DPF, you can perform complex preprocessing or postprocessing of
10- large amounts of simulation data within a simulation workflow.
7+ PyDPF-Post is part of the Ansys Data Processing Framework (DPF), which provides reusable operators
8+ that let you access and transform simulation data coming from different Ansys and third-party
9+ result files.
1110
12- The Python ` ansys-dpf-post ` package provides a high-level, physics-oriented
13- API for postprocessing. Loading a simulation (defined by its results files)
14- allows you to extract simulation metadata and results and then apply
15- postprocessing operations on them.
11+ PyDPF-Post leverages [ PyDPF-Core] ( https://github.com/ansys/pydpf-core ) , a package for building more
12+ advanced and customized workflows using Ansys DPF. After loading a simulation's result file in PyDPF-Post,
13+ you can extract simulation metadata and results and then apply postprocessing operations on them.
1614
17- The latest version of DPF supports Ansys solver results files for:
15+ PyDPF-Core is physics-agnostic and operator-oriented. It is a direct exposure of the DPF features and
16+ objects with a few helpers. It is not restricted to postprocessing.
1817
19- - Mechanical APDL (` .rst ` , ` .mode ` , ` .rfrq ` , ` .rdsp ` )
20- - LS-DYNA (` .d3plot ` , ` .binout ` )
21- - Fluent (` .cas/dat.h5 ` , ` .flprj ` )
22- - CFX (` .cas/dat.cff ` , ` .flprj ` , ` .res ` )
23-
24- For more information on file support, see the [ main page] ( https://dpf.docs.pyansys.com/version/stable/index.html )
25- in the PyDPF-Core documentation.
26-
27- PyDPF-Post leverages the PyDPF-Core project's `` ansys-dpf-core `` package, which is
28- available at [ PyDPF-Core GitHub] ( https://github.com/ansys/pydpf-core ) .
29- Use the `` ansys-dpf-core `` package for building more advanced and customized workflows
30- using Ansys DPF.
18+ PyDPF-Post on the other hand provides a high-level, physics-oriented API for postprocessing. It has a
19+ more Pythonic and user-friendly API dedicated to postprocessing, with new objects meant to provide a specific
20+ interface for each type of physics and analysis (such as mechanics static versus transient versus fluids).
21+ Most importantly, there is no need to manipulate operators or workflows.
3122
3223## Documentation and issues
3324
3425Documentation for the latest stable release of PyPDF-Post is hosted at
3526[ PyDPF-Post documentation] ( https://post.docs.pyansys.com/version/stable/ ) .
3627
37- In the upper right corner of the documentation's title bar, there is an option for switching from
38- viewing the documentation for the latest stable release to viewing the documentation for the
39- development version or previously released versions.
28+ The PyDPF-Post documentation has five sections:
29+
30+ - [ Getting started] ( https://post.docs.pyansys.com/version/stable/getting_started/index.html ) : Learn how to
31+ install PyDPF-Post in user mode and quickly begin using it.
32+ - [ User guide] ( https://post.docs.pyansys.com/version/stable/user_guide/index.html ) : Understand key concepts
33+ for using PyDPF-Post.
34+ - [ API reference] ( https://post.docs.pyansys.com/version/stable/api/index.html ) : Understand how to use
35+ Python to interact programmatically with PyDPF-Post.
36+ - [ Examples] ( https://post.docs.pyansys.com/version/stable/examples/index.html ) : Explore examples
37+ that show how to use PyDPF-Post to perform nay different types of operations.
38+ - [ Contribute] ( https://post.docs.pyansys.com/version/stable/contributing.html ) : Learn how to
39+ contribute to the PyDPF-Post codebase or documentation.
40+
41+ In the upper right corner of the documentation's title bar, there is an option
42+ for switching from viewing the documentation for the latest stable release
43+ to viewing the documentation for the development version or previously
44+ released versions.
4045
4146You can also [ view] ( https://cheatsheets.docs.pyansys.com/pydpf-post_cheat_sheet.png ) or
4247[ download] ( https://cheatsheets.docs.pyansys.com/pydpf-post_cheat_sheet.pdf ) the
@@ -45,82 +50,8 @@ for using PyDPF-Post.
4550
4651On the [ PyDPF-Post Issues] ( https://github.com/ansys/pydpf-post/issues ) page,
4752you can create issues to report bugs and request new features. On the
48- [ PyDPF-Post Discussions] ( https://github.com/ansys/pydpf-post/discussions ) page or the [ Discussions] ( https://discuss.ansys.com/ )
49- page on the Ansys Developer portal, you can post questions, share ideas, and get community feedback.
53+ [ PyDPF-Post Discussions] ( https://github.com/ansys/pydpf-post/discussions ) page or
54+ the [ Discussions] ( https://discuss.ansys.com/ ) page on the Ansys Developer portal,
55+ you can post questions, share ideas, and get community feedback.
5056
5157To reach the project support team, email
[ [email protected] ] ( mailto:[email protected] ) .
52-
53- ## Installation
54-
55- To install this package, run this command:
56-
57- ```
58- pip install ansys-dpf-post
59- ```
60-
61- You can also clone and install this package with these commands:
62-
63- ```
64- git clone https://github.com/ansys/pydpf-post
65- cd pydpf-post
66- pip install . --user
67- ```
68-
69- ## Brief demo
70-
71- Provided you have Ansys 2023 R1 or later installed, a DPF server automatically starts
72- once you start using PyDPF-Post.
73-
74- To load a simulation for a MAPDL result file to extract and
75- postprocess results, use this code:
76-
77- ``` pycon
78- >>> from ansys.dpf import post
79- >>> from ansys.dpf.post import examples
80- >>> simulation = post.load_simulation(examples.download_crankshaft())
81- >>> displacement = simulation.displacement()
82- >>> print (displacement)
83- ```
84- ``` pycon
85- results U (m)
86- set_ids 3
87- node_ids components
88- 4872 X -3.4137e-05
89- Y 1.5417e-03
90- Z -2.6398e-06
91- 9005 X -5.5625e-05
92- Y 1.4448e-03
93- Z 5.3134e-06
94- ... ... ...
95- ```
96- ``` pycon
97- >>> displacement.plot()
98- ```
99- ![ Example Displacement plot Crankshaft] ( https://github.com/ansys/pydpf-post/raw/master/docs/source/images/crankshaft_disp.png )
100- ``` pycon
101- >>> stress_eqv = simulation.stress_eqv_von_mises_nodal()
102- >>> stress_eqv.plot()
103- ```
104- ![ Example Stress plot Crankshaft] ( https://github.com/ansys/pydpf-post/raw/master/docs/source/images/crankshaft_stress.png )
105-
106- To run PyDPF-Post with Ansys 2021 R1 through 2022 R2, use this code to
107- start the legacy PyDPF-Post tools:
108-
109- ``` pycon
110- >>> from ansys.dpf import post
111- >>> from ansys.dpf.post import examples
112- >>> solution = post.load_solution(examples.download_crankshaft())
113- >>> stress = solution.stress()
114- >>> stress.eqv.plot_contour(show_edges = False )
115- ```
116- ![ Example Stress plot Crankshaft] ( https://github.com/ansys/pydpf-post/raw/master/docs/source/images/crankshaft_stress.png )
117-
118- ## License and acknowledgements
119-
120- PyDPF-Post is licensed under the MIT license. For more information, see the
121- [ LICENSE] ( https://github.com/ansys/pydpf-post/raw/master/LICENSE ) file.
122-
123- PyDPF-Post makes no commercial claim over Ansys whatsoever. This library
124- extends the functionality of Ansys DPF by adding a Python interface
125- to DPF without changing the core behavior or license of the original
126- software.
0 commit comments