Skip to main content

"Python utilities for zCFD users"

Project description

zutil

PyPI version fury.io

Python utilities for zCFD users

zutil is a comprehensive Python toolkit designed to work with zCFD CFD simulation results and provide powerful pre- and post-processing capabilities. This library offers streamlined workflows for data analysis, visualization, wind energy modeling, acoustic analysis, and geometric transformations.

Installation

Install zutil from PyPI:

pip install zutil

Note: This library is compatible with Paraview 6.0+

Package Structure

zutil is organized into several specialized modules:

  • plot - Advanced plotting and visualization tools for zCFD results
  • post - Post-processing utilities using Paraview integration
  • fileutils - File I/O operations and result data access
  • analysis - Analysis tools including acoustic analysis
  • transform - Geometric transformation utilities
  • zWind - Wind energy modeling and turbine analysis

Quick Start

Loading zCFD Results

The fundamental function for accessing zCFD simulation data:

from zutil.fileutils import get_zcfd_result

# Load a zCFD case result
result = get_zcfd_result('my_case.py')

# Access case parameters
params = result.parameters

# Get report data
report = result.report
print(report.header_list)  # Available data columns

Plotting Report Files

Create professional plots from zCFD report files:

from zutil.plot import Report
import matplotlib.pyplot as plt

# Load and plot residuals
report = Report('my_case.py')
report.plot_residuals()
plt.show()

# Plot specific variables
report.plot_report_array('Cd')
plt.show()

Module Documentation

Plotting

The zutil.plot module provides comprehensive plotting capabilities:

from zutil.plot import Report, zCFD_Plots

# Individual case plotting
report = Report('case.py')
report.plot_residuals()
report.plot_forces()
report.plot_linear_solve_performance()

# Multi-case plotting (handles overset cases automatically)
plots = zCFD_Plots('case.py')
plots.plot_residuals()
plots.plot_forces()

Key Features:

  • Residual convergence plots
  • Force and moment coefficient plotting
  • Linear solver performance analysis
  • Acoustic analysis visualization
  • Professional styling with zCFD branding

Post-Processing

The zutil.post module integrates with Paraview for advanced post-processing:

Note: This module requires pvpython to be installed. The easiest way to get this is to use a distribution of zCFD.

from zutil import post

# Access case parameters
params = post.get_case_parameters('case.py')

# Calculate forces on walls
force = post.calc_force_wall('wall_name', 'case.py')

# Extract surface pressure profiles
cp_data = post.cp_profile_wall_from_file('wall_name', 'case.py')

# Generate Paraview visualizations with zCFD branding
post.vtk_logo_stamp()

Key Features:

  • Force and moment calculations
  • Surface pressure and friction analysis
  • Paraview visualization utilities
  • Progress tracking for batch operations

File Utilities

The zutil.fileutils module handles all file I/O operations:

from zutil.fileutils import get_zcfd_result, zCFD_Result

# Load case data
result = get_zcfd_result('case.py')

# Access report data directly
report_data = result.report.get_array('Cd')

# Get case status
success = result.report.get_case_success()

Key Features:

  • Seamless access to zCFD case data
  • Report file parsing and analysis
  • Parameter extraction from control files
  • CSV data handling utilities

Analysis Tools

The zutil.analysis module includes acoustic and other analysis capabilities:

from zutil.analysis.acoustic import calculate_PSD
from zutil.plot import plot_PSD, plot_thirdoctave

# Perform acoustic analysis
psd_data = calculate_PSD(time_series_data, sample_rate)

# Create acoustic plots
plot_PSD(psd_data, frequencies)
plot_thirdoctave(psd_data, frequencies)

Key Features:

  • Power spectral density (PSD) analysis
  • Third-octave band analysis
  • Acoustic visualization tools
  • Signal processing utilities

Geometric Transformations

The zutil.transform module provides coordinate and geometric operations:

from zutil.transform import transform
from zutil import vector_from_angle, rotate_vector

# Coordinate transformations
transformed_points = transform.apply_rotation(points, rotation_matrix)

# Vector operations
wind_vector = vector_from_angle(wind_direction, wind_speed)
rotated_vector = rotate_vector(vector, axis, angle)

Key Features:

  • Coordinate system transformations
  • Vector mathematics utilities
  • Rotation and translation operations
  • Unit conversions

Wind Energy Modeling

The zutil.zWind module provides specialized wind energy tools:

from zutil.zWind import zTurbine

# Define wind turbine properties
turbine = zTurbine(name='NREL_5MW', centre=[0, 0, 90])

Key Features:

  • Wind turbine modeling (zTurbine)
  • Actuator disc implementations (zActuatorDisc)
  • Blade element momentum theory (zBem)
  • Turbine controllers (zController)

Requirements

  • Python 3.9+
  • NumPy
  • Pandas
  • Matplotlib
  • IPython/Jupyter support
  • PyYAML
  • Paraview (for post-processing features)

Documentation

For comprehensive documentation, tutorials, and examples:

Support

License

zutil is released under the MIT License. See LICENSE file for details.


Developed by Zenotech Ltd

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

zutil-2025.11.13331.12.tar.gz (197.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

zutil-2025.11.13331.12-py3-none-any.whl (216.5 kB view details)

Uploaded Python 3

File details

Details for the file zutil-2025.11.13331.12.tar.gz.

File metadata

  • Download URL: zutil-2025.11.13331.12.tar.gz
  • Upload date:
  • Size: 197.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for zutil-2025.11.13331.12.tar.gz
Algorithm Hash digest
SHA256 f113174f340b8d417aaff8cedf50d5cb36512d5db5001298eb55076028990432
MD5 2e0bfc685cc249ea40a9a78f12fe4ed6
BLAKE2b-256 e35dfa3ccba01ceded6def0d3c2c02407a8d7df436774472a0593429ea2f3f3a

See more details on using hashes here.

Provenance

The following attestation bundles were made for zutil-2025.11.13331.12.tar.gz:

Publisher: python-publish.yml on zCFD/zutil

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file zutil-2025.11.13331.12-py3-none-any.whl.

File metadata

File hashes

Hashes for zutil-2025.11.13331.12-py3-none-any.whl
Algorithm Hash digest
SHA256 79a83db452f7ded201754546913e2515aae36821ca09179263930cbee9228dae
MD5 2f731152bbbdaf2565961c032bdc2685
BLAKE2b-256 16b8641e120b74062ac95dbb7fa235eeb6e5013b4b3075033653e54898f3fa15

See more details on using hashes here.

Provenance

The following attestation bundles were made for zutil-2025.11.13331.12-py3-none-any.whl:

Publisher: python-publish.yml on zCFD/zutil

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page