Explore Fluids models#

This example demonstrates how to explore Ansys Fluent and Ansys CFX models employing the MeshInfo and ResultInfo.

Note

This example requires DPF 7.0 (ansys-dpf-server-2024-1-pre0) or above. For more information, see Compatibility.

Exploring an Ansys Fluent model#

The first part of the example demonstrates how you can explore an Ansys Fluent model. Import the result file and create a model.

import ansys.dpf.core as dpf
from ansys.dpf.core import examples

path = examples.download_fluent_axial_comp()["flprj"]
ds = dpf.DataSources(path)
model = dpf.Model(data_sources=ds)

Exploring the mesh#

Explore the mesh through the MeshInfo. The MeshInfo provides metadata information about the mesh. For fluid models, it is useful to know the cell and face zones, as well as the topological relationships between them. First get all the available information in the MeshInfo .

minfo = model.metadata.mesh_info
print(minfo)
DPF MeshInfo
------------------------------
with properties:
  num_cells             int
  num_nodes             int
  num_faces             int
  body_names            StringField
  body_cell_topology    PropertyField
  body_face_topology    PropertyField
  body_scoping          Scoping
  cell_zone_names       StringField
  cell_zone_scoping     Scoping
  face_zone_names       StringField
  cell_zone_elements    PropertyField
  face_zone_elements    PropertyField
  face_zone_scoping     Scoping
  zone_names            StringField
  num_elem_zone         PropertyField
  zone_scoping          Scoping
  splittable_by         StringField

Then, get the bodies and their names in the model with the “body_names” StringField, which provides a relationship between body IDs and names. In this model there are two bodies.

print(minfo.get_property("body_names"))
DPF String Field
  2 Body entities
  Data:2 elementary data

  Body
  IDs                   data
  ------------          ----------
  13                    fluid-rotor

  28                    fluid-stator

Each body is comprised of a set of cell zones. You can investigate the hierarchical relationship between bodies and cell zones through the “body_cell_topology” PropertyField, which provides a relationship between the body IDs and the cell zone IDs. In this case, each body is only comprised of one cell zone.

print(minfo.get_property("body_cell_topology"))
DPF Property Field
  2 entities
  Data: 1 components and 2 elementary data

  Body
  IDs                   data
  ------------          ----------
  13                    13

  28                    28

Similarly, each body is limited by a set of face zones (generally representing boundary conditions). You can investigate the hierarchical relationship between bodies and face zones through the “body_face_topology” PropertyField, which provides a relationship between the body IDs and the face zone IDs. In this case, each body is limited by several face zones.

print(minfo.get_property("body_face_topology"))
DPF Property Field
  2 entities
  Data: 1 components and 24 elementary data

  Body
  IDs                   data
  ------------          ----------
  13                    2
                        3
                        4
                        ...

  28                    15
                        16
                        17
                        ...

The cell and face zone IDs shown in the previous PropertyFields can be mapped to their names through the “body_zone_names” and “face_zone_names” PropertyField. As in this model there is a 1-1 correspondence between bodies and cell zones, they have the same names and IDs.

print(minfo.get_property("cell_zone_names"))
print(minfo.get_property("face_zone_names"))
DPF String Field
  2 zone entities
  Data:2 elementary data

  zone
  IDs                   data
  ------------          ----------
  13                    fluid-rotor

  28                    fluid-stator



DPF String Field
  24 zone entities
  Data:24 elementary data

  zone
  IDs                   data
  ------------          ----------
  2                     default-interior:0

  3                     rotor-hub

  4                     rotor-shroud

  ...

All zone names (regardless of them being cell or face zones) are exported to the “zone_names” StringField .

print(minfo.get_property("zone_names"))
DPF String Field
  26 zone entities
  Data:26 elementary data

  zone
  IDs                   data
  ------------          ----------
  13                    fluid-rotor

  2                     default-interior:0

  3                     rotor-hub

  ...

Helpers are provided to quickly get a map of zone ID to zone name.

print(minfo.zones)
print(minfo.cell_zones)
print(minfo.face_zones)
{'13': 'fluid-rotor', '2': 'default-interior:0', '3': 'rotor-hub', '4': 'rotor-shroud', '5': 'rotor-inlet', '6': 'rotor-interface', '7': 'rotor-blade-1', '8': 'rotor-blade-2', '9': 'rotor-per-1-shadow', '10': 'rotor-per-1', '11': 'rotor-per-2-shadow', '12': 'rotor-per-2', '28': 'fluid-stator', '15': 'default-interior', '16': 'stator-hub', '17': 'stator-shroud', '18': 'stator-interface', '19': 'stator-outlet', '20': 'stator-blade-1', '21': 'stator-blade-2', '22': 'stator-blade-3', '23': 'stator-blade-4', '24': 'stator-per-2', '25': 'stator-per-2-shadow', '26': 'stator-per-1', '27': 'stator-per-1-shadow'}
{'13': 'fluid-rotor', '28': 'fluid-stator'}
{'2': 'default-interior:0', '3': 'rotor-hub', '4': 'rotor-shroud', '5': 'rotor-inlet', '6': 'rotor-interface', '7': 'rotor-blade-1', '8': 'rotor-blade-2', '9': 'rotor-per-1-shadow', '10': 'rotor-per-1', '11': 'rotor-per-2-shadow', '12': 'rotor-per-2', '15': 'default-interior', '16': 'stator-hub', '17': 'stator-shroud', '18': 'stator-interface', '19': 'stator-outlet', '20': 'stator-blade-1', '21': 'stator-blade-2', '22': 'stator-blade-3', '23': 'stator-blade-4', '24': 'stator-per-2', '25': 'stator-per-2-shadow', '26': 'stator-per-1', '27': 'stator-per-1-shadow'}

To facilitate the extraction of results, the body, cell and face zone Scoping are extracted. They can be used to scope results.

print(minfo.get_property("body_scoping"))
print(minfo.get_property("cell_zone_scoping"))
print(minfo.get_property("face_zone_scoping"))
DPF  Scoping:
  with Body location and 2 entities

DPF  Scoping:
  with zone location and 2 entities

DPF  Scoping:
  with zone location and 24 entities

Exploring the results#

Explore the available results in the model through the ResultInfo. This is a Fluent model whose native results are exported to either the centroid of the elements (like Enthalpy or RMS Temperature), the centroid of the faces (like the Mass Flow Rate) or the centroid of both elements and faces (like Static Pressure).

rinfo = model.metadata.result_info
print(rinfo)
Transient analysis
Unit system: SI: m, kg, N, s, V, A, K
Physics Type: Fluid
Available results:
     -  enthalpy: Elemental Enthalpy
     -  mass_flow_rate: Faces Mass Flow Rate
     -  static_pressure: ElementalAndFaces Static Pressure
     -  mean_static_pressure: Elemental Mean Static Pressure
     -  rms_static_pressure: Elemental Rms Static Pressure
     -  surface_heat_rate: Faces Surface Heat Rate
     -  density: ElementalAndFaces Density
     -  wall_shear_stress: Faces Wall Shear Stress
     -  temperature: ElementalAndFaces Temperature
     -  mean_temperature: ElementalAndFaces Mean Temperature
     -  rms_temperature: Elemental Rms Temperature
     -  velocity: ElementalAndFaces Velocity
     -  mean_velocity: Elemental Mean Velocity
     -  rms_velocity: Elemental Rms Velocity
Available qualifier labels:
     - zone: default-interior:0 (2), rotor-hub (3), rotor-shroud (4), rotor-inlet (5), rotor-interface (6), rotor-blade-1 (7), rotor-blade-2 (8), rotor-per-1-shadow (9), rotor-per-1 (10), rotor-per-2-shadow (11), rotor-per-2 (12), fluid-rotor (13), default-interior (15), stator-hub (16), stator-shroud (17), stator-interface (18), stator-outlet (19), stator-blade-1 (20), stator-blade-2 (21), stator-blade-3 (22), stator-blade-4 (23), stator-per-2 (24), stator-per-2-shadow (25), stator-per-1 (26), stator-per-1-shadow (27), fluid-stator (28)
     - phase: phase-1 (1)

Each result holds more detailed information while explored individually. Enthalpy is a scalar magnitude exported to the centroids of the elements (cells). Thus, it is available for the two cell zones of the model (13 and 28). In addition, the model only has one phase, and therefore the result can only be extracted for “phase-1”.

print(rinfo.available_results[0])
DPF Result
----------
enthalpy
Operator name: "H_S"
Number of components: 1
Dimensionality: scalar
Homogeneity: specific_energy
Units: J/kg
Location: Elemental
Available qualifier labels:
  - phase: phase-1 (1)
  - zone: fluid-rotor (13), fluid-stator (28)
Available qualifier combinations:
  {'phase': 1, 'zone': 13}
  {'phase': 1, 'zone': 28}

Static Pressure, however, is ElementalAndFaces, which means that it is exported at both the centroids of the cells and the centroids of the faces. Therefore, it is available for all the cell and face zones of the model.

print(rinfo.available_results[2])
DPF Result
----------
static_pressure
Operator name: "P_S"
Number of components: 1
Dimensionality: scalar
Homogeneity: pressure
Units: Pa
Location: ElementalAndFaces
Available qualifier labels:
  - phase: phase-1 (1)
  - zone: fluid-rotor (13), fluid-stator (28), rotor-hub (3), rotor-shroud (4), rotor-inlet (5), rotor-interface (6), rotor-blade-1 (7), rotor-blade-2 (8), rotor-per-1-shadow (9), rotor-per-1 (10), rotor-per-2-shadow (11), rotor-per-2 (12), stator-hub (16), stator-shroud (17), stator-interface (18), stator-outlet (19), stator-blade-1 (20), stator-blade-2 (21), stator-blade-3 (22), stator-blade-4 (23), stator-per-2 (24), stator-per-2-shadow (25), stator-per-1 (26), stator-per-1-shadow (27)
Available qualifier combinations:
  {'phase': 1, 'zone': 13}
  {'phase': 1, 'zone': 28}
  {'phase': 1, 'zone': 3}
  {'phase': 1, 'zone': 4}
  {'phase': 1, 'zone': 5}
  {'phase': 1, 'zone': 6}
  {'phase': 1, 'zone': 7}
  {'phase': 1, 'zone': 8}
  {'phase': 1, 'zone': 9}
  {'phase': 1, 'zone': 10}
  {'phase': 1, 'zone': 11}
  {'phase': 1, 'zone': 12}
  {'phase': 1, 'zone': 16}
  {'phase': 1, 'zone': 17}
  {'phase': 1, 'zone': 18}
  {'phase': 1, 'zone': 19}
  {'phase': 1, 'zone': 20}
  {'phase': 1, 'zone': 21}
  {'phase': 1, 'zone': 22}
  {'phase': 1, 'zone': 23}
  {'phase': 1, 'zone': 24}
  {'phase': 1, 'zone': 25}
  {'phase': 1, 'zone': 26}
  {'phase': 1, 'zone': 27}

Exploring an Ansys CFX model#

The second part of the example demonstrates how you can explore an Ansys CFX model. Import the result file and create a model.

path = examples.download_cfx_heating_coil()
ds = dpf.DataSources()
ds.set_result_file_path(path["cas"], "cas")
ds.add_file_path(path["dat"], "dat")
model = dpf.Model(data_sources=ds)

Exploring the mesh#

If once again we explore the MeshInfo, we can see that the same information is readily available.

minfo = model.metadata.mesh_info
print(minfo)
DPF MeshInfo
------------------------------
with properties:
  num_nodes             int
  num_cells             int
  body_names            StringField
  body_cell_topology    PropertyField
  num_faces             int
  body_face_topology    PropertyField
  body_scoping          Scoping
  cell_zone_names       StringField
  face_zone_names       StringField
  cell_zone_scoping     Scoping
  cell_zone_elements    PropertyField
  face_zone_elements    PropertyField
  face_zone_scoping     Scoping
  zone_names            StringField
  num_elem_zone         PropertyField
  zone_scoping          Scoping
  splittable_by         StringField

In this CFX model there are also two bodies.

print(minfo.get_property("body_names"))
DPF String Field
  2 Body entities
  Data:2 elementary data

  Body
  IDs                   data
  ------------          ----------
  1                     Default 1

  2                     heater

For this model, each body is conformed by several cell zones. In this general situation, the body ID corresponds to the highest cell zone ID of the one that comprises it.

print(minfo.get_property("body_cell_topology"))
DPF Property Field
  2 entities
  Data: 1 components and 6 elementary data

  Body
  IDs                   data
  ------------          ----------
  1                     3
                        4
                        5

  2                     6
                        7
                        8

You can also explore the face zone IDs in each body.

print(minfo.get_property("body_face_topology"))
DPF Property Field
  2 entities
  Data: 1 components and 16 elementary data

  Body
  IDs                   data
  ------------          ----------
  1                     9
                        10
                        11
                        ...

  2                     18
                        19
                        20
                        ...

The cell and face zone names are readily available.

print(minfo.get_property("cell_zone_names"))
print(minfo.get_property("face_zone_names"))
DPF String Field
  6 zone entities
  Data:6 elementary data

  zone
  IDs                   data
  ------------          ----------
  3                     ZN1/ES1

  4                     ZN1/ES2

  5                     ZN1/ES3

  ...


DPF String Field
  16 zone entities
  Data:16 elementary data

  zone
  IDs                   data
  ------------          ----------
  9                     outflow

  10                    Default

  11                    inflow

  ...

Exploring the results#

By exploring the ResultInfo we can see that all CFX variables are exported to the Nodes.

rinfo = model.metadata.result_info
print(rinfo)
Static analysis
Unit system: SI: m, kg, N, s, V, A, K
Physics Type: Fluid
Available results:
     -  specific_heat: Nodal Specific Heat
     -  epsilon: Nodal Epsilon
     -  enthalpy: Nodal Enthalpy
     -  turbulent_kinetic_energy: Nodal Turbulent Kinetic Energy
     -  thermal_conductivity: Nodal Thermal Conductivity
     -  dynamic_viscosity: Nodal Dynamic Viscosity
     -  turbulent_viscosity: Nodal Turbulent Viscosity
     -  static_pressure: Nodal Static Pressure
     -  total_pressure: Nodal Total Pressure
     -  density: Nodal Density
     -  entropy: Nodal Entropy
     -  temperature: Nodal Temperature
     -  total_temperature: Nodal Total Temperature
     -  velocity: Nodal Velocity
Available qualifier labels:
     - zone: outflow (9), Default (10), inflow (11), Solid 2.8 1 (12), Solid 2.7 1 (13), Solid 2.6 1 (14), Solid 2.5 1 (15), Solid 2.4 1 (16), Solid 2.3 1 (17), Default 1 (1), Default (18), Solid 2.3 (19), Solid 2.4 (20), Solid 2.5 (21), Solid 2.6 (22), Solid 2.7 (23), Solid 2.8 (24), heater (2)
     - phase: <Mixture> (1), Water at 25 C (2), Copper (3)

However, in this model there are two distinct phases. To understand the phases at the model, you can explore the qualifiers of the ResultInfo. Thus, results could potentially be scoped on “zone” and “phase”, with the ID and name of each phase shown below.

labels = rinfo.available_qualifier_labels
print(labels)
phase_names = rinfo.qualifier_label_support(labels[1]).string_field_support_by_property("names")
print(phase_names)
['zone', 'phase']
DPF String Field
  3  entities
  Data:3 elementary data

  IDs                   data
  ------------          ----------
  1                     <Mixture>

  2                     Water at 25 C

  3                     Copper

Each result holds more detailed information while explored individually. Static Pressure is only available for phase 1 (“<Mixture>”), and several cell and face zones.

print(rinfo.available_results[7])
DPF Result
----------
static_pressure
Operator name: "P_S"
Number of components: 1
Dimensionality: scalar
Homogeneity: pressure
Units: Pa
Location: Nodal
Available qualifier labels:
  - phase: <Mixture> (1)
  - zone: Default 1 (1), outflow (9), Default (10), inflow (11), Solid 2.8 1 (12), Solid 2.7 1 (13), Solid 2.6 1 (14), Solid 2.5 1 (15), Solid 2.4 1 (16), Solid 2.3 1 (17)
Available qualifier combinations:
  {'phase': 1, 'zone': 1}
  {'phase': 1, 'zone': 9}
  {'phase': 1, 'zone': 10}
  {'phase': 1, 'zone': 11}
  {'phase': 1, 'zone': 12}
  {'phase': 1, 'zone': 13}
  {'phase': 1, 'zone': 14}
  {'phase': 1, 'zone': 15}
  {'phase': 1, 'zone': 16}
  {'phase': 1, 'zone': 17}

Thermal conductivity, however, exists for phases 2 and 3 (“Copper” and “Water at 25 C”, respectively), and several face and cell zones.

print(rinfo.available_results[4])
DPF Result
----------
thermal_conductivity
Operator name: "KT"
Number of components: 1
Dimensionality: scalar
Homogeneity: conductivity
Units: W*m^-1*K^-1
Location: Nodal
Available qualifier labels:
  - phase: Water at 25 C (2), Copper (3)
  - zone: Default 1 (1), outflow (9), Default (10), inflow (11), Solid 2.8 1 (12), Solid 2.7 1 (13), Solid 2.6 1 (14), Solid 2.5 1 (15), Solid 2.4 1 (16), Solid 2.3 1 (17), heater (2), Default (18), Solid 2.3 (19), Solid 2.4 (20), Solid 2.5 (21), Solid 2.6 (22), Solid 2.7 (23), Solid 2.8 (24)
Available qualifier combinations:
  {'phase': 2, 'zone': 1}
  {'phase': 2, 'zone': 9}
  {'phase': 2, 'zone': 10}
  {'phase': 2, 'zone': 11}
  {'phase': 2, 'zone': 12}
  {'phase': 2, 'zone': 13}
  {'phase': 2, 'zone': 14}
  {'phase': 2, 'zone': 15}
  {'phase': 2, 'zone': 16}
  {'phase': 2, 'zone': 17}
  {'phase': 3, 'zone': 2}
  {'phase': 3, 'zone': 18}
  {'phase': 3, 'zone': 19}
  {'phase': 3, 'zone': 20}
  {'phase': 3, 'zone': 21}
  {'phase': 3, 'zone': 22}
  {'phase': 3, 'zone': 23}
  {'phase': 3, 'zone': 24}

Total running time of the script: (0 minutes 8.070 seconds)

Gallery generated by Sphinx-Gallery