"Python utilities for zCFD users"
Project description
zutil
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:
- Full Documentation: https://docs.zenotech.com/
- zCFD Solver: Download a free trial at https://zcfd.zenotech.com
Support
- Issues: Report bugs and feature requests via the Issues tab
- Email: For technical support contact admin@zenotech.com
License
zutil is released under the MIT License. See LICENSE file for details.
Developed by Zenotech Ltd
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f113174f340b8d417aaff8cedf50d5cb36512d5db5001298eb55076028990432
|
|
| MD5 |
2e0bfc685cc249ea40a9a78f12fe4ed6
|
|
| BLAKE2b-256 |
e35dfa3ccba01ceded6def0d3c2c02407a8d7df436774472a0593429ea2f3f3a
|
Provenance
The following attestation bundles were made for zutil-2025.11.13331.12.tar.gz:
Publisher:
python-publish.yml on zCFD/zutil
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zutil-2025.11.13331.12.tar.gz -
Subject digest:
f113174f340b8d417aaff8cedf50d5cb36512d5db5001298eb55076028990432 - Sigstore transparency entry: 748751746
- Sigstore integration time:
-
Permalink:
zCFD/zutil@00946f1cccae7a8ba2523ce0e0f83a5eba44badc -
Branch / Tag:
refs/tags/v2025.11.13331.12 - Owner: https://github.com/zCFD
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@00946f1cccae7a8ba2523ce0e0f83a5eba44badc -
Trigger Event:
release
-
Statement type:
File details
Details for the file zutil-2025.11.13331.12-py3-none-any.whl.
File metadata
- Download URL: zutil-2025.11.13331.12-py3-none-any.whl
- Upload date:
- Size: 216.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
79a83db452f7ded201754546913e2515aae36821ca09179263930cbee9228dae
|
|
| MD5 |
2f731152bbbdaf2565961c032bdc2685
|
|
| BLAKE2b-256 |
16b8641e120b74062ac95dbb7fa235eeb6e5013b4b3075033653e54898f3fa15
|
Provenance
The following attestation bundles were made for zutil-2025.11.13331.12-py3-none-any.whl:
Publisher:
python-publish.yml on zCFD/zutil
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zutil-2025.11.13331.12-py3-none-any.whl -
Subject digest:
79a83db452f7ded201754546913e2515aae36821ca09179263930cbee9228dae - Sigstore transparency entry: 748751751
- Sigstore integration time:
-
Permalink:
zCFD/zutil@00946f1cccae7a8ba2523ce0e0f83a5eba44badc -
Branch / Tag:
refs/tags/v2025.11.13331.12 - Owner: https://github.com/zCFD
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@00946f1cccae7a8ba2523ce0e0f83a5eba44badc -
Trigger Event:
release
-
Statement type: