Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Retrieve mesh data in solution mode #3618

Merged
merged 7 commits into from
Jan 9, 2025
Merged

Conversation

mkundu1
Copy link
Contributor

@mkundu1 mkundu1 commented Jan 6, 2025

import pyvista as pv
import numpy as np
import ansys.fluent.core as pyfluent
from ansys.fluent.core.services.field_data import CellElementType

def convert_fluent_element_type_to_pv_cell_type(element_type):
    if element_type == CellElementType.TETRAHEDRON:
        return pv.CellType.TETRA
    if element_type == CellElementType.HEXAHEDRON:
        return pv.CellType.HEXAHEDRON
    # Add other element types
    raise ValueError(f"Unknown element type {element_type}")

solver = pyfluent.launch_fluent(processor_count=4)
solver.settings.file.read_case(file_name="d:/work/elbow.cas.h5")
mesh = solver.fields.field_data.get_mesh(zone_id=2)
points = np.array([(node.x, node.y, node.z) for node in mesh.nodes])
cells = np.array([[len(element.node_indices)] + element.node_indices for element in mesh.elements]).ravel()
cell_types = [convert_fluent_element_type_to_pv_cell_type(element.element_type) for element in mesh.elements]
grid = pv.UnstructuredGrid(cells, cell_types, points)
pv.plot(grid, show_edges=True)

image

@mkundu1 mkundu1 force-pushed the feat/solver-mesh-data branch from e7a9d1d to 3907f75 Compare January 7, 2025 18:15
@mkundu1 mkundu1 marked this pull request as ready for review January 7, 2025 18:21
@mkundu1 mkundu1 linked an issue Jan 7, 2025 that may be closed by this pull request
@mkundu1
Copy link
Contributor Author

mkundu1 commented Jan 7, 2025

I have noted down the future tasks for this feature: #3585 (comment)

@mkundu1 mkundu1 force-pushed the feat/solver-mesh-data branch from 15a5d17 to 90391a6 Compare January 8, 2025 19:46
@mkundu1
Copy link
Contributor Author

mkundu1 commented Jan 9, 2025

In the latest revision, I've restored the original element order coming from Fluent, so that we can correlete with the data retrieved via solution variable service. E.g., following is an example script for volumentric pressure plot:

import pyvista as pv
import numpy as np
import ansys.fluent.core as pyfluent
from ansys.fluent.core.services.field_data import CellElementType


def convert_fluent_element_type_to_pv_cell_type(element_type):
    if element_type == CellElementType.TETRAHEDRON:
        return pv.CellType.TETRA
    if element_type == CellElementType.HEXAHEDRON:
        return pv.CellType.HEXAHEDRON
    # Add other element types
    raise ValueError(f"Unknown element type {element_type}")


solver = pyfluent.launch_fluent(processor_count=4)
solver.settings.file.read_case_data(file_name="d:/work/elbow.cas.h5")
mesh = solver.fields.field_data.get_mesh(zone_id=2)
points = np.array([(node.x, node.y, node.z) for node in mesh.nodes])
cells = np.array([[len(element.node_indices)] + element.node_indices for element in mesh.elements]).ravel()
cell_types = [convert_fluent_element_type_to_pv_cell_type(element.element_type) for element in mesh.elements]
grid = pv.UnstructuredGrid(cells, cell_types, points)
pressure_data = solver.fields.solution_variable_data.get_data(solution_variable_name="SV_P", zone_names=["fluid"], domain_name="mixture")["fluid"]
grid.cell_data["pressure"] = pressure_data
grid.plot(scalars="pressure")

python_SxtvM61KiN

@mkundu1 mkundu1 merged commit 6918389 into main Jan 9, 2025
29 checks passed
@mkundu1 mkundu1 deleted the feat/solver-mesh-data branch January 9, 2025 18:34
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Fetch mesh data on-demand in solution mode
3 participants