Isosurface Output#
Isosurface Output in Flow360 lets you visualize flow field variables on surfaces of constant value within the computational domain. This is particularly useful for identifying and analyzing coherent structures like vortices, shock waves, or temperature contours.
Available Options#
Option |
Description |
Applicable |
|---|---|---|
Output fields |
Flow variables to include in the output |
always |
Output format |
Format for saving isosurface data |
always |
Save interval |
When to save outputs |
always |
Frequency |
How often to save outputs |
when Save interval is |
Frequency offset |
Time step at which to start the output animation |
when Save interval is |
Isosurfaces |
Define one or more isosurfaces |
always |
Global Time Stepping in Child Cases#
When working with child cases (cases forked from a parent simulation), it’s important to understand that the Frequency and Frequency offset parameters refer to the global time step, which is transferred from the parent case.
Example: If the parent case finished at time_step=174, the child case will start from time_step=175. If Frequency=100 is set in the child case, the output will be saved at global time steps 200 (25 time steps into the child simulation), 300 (125 time steps into the child simulation), etc. Frequency offset also refers to the global time step, meaning that if in the previously mentioned child case, Frequency offset=50 was set (with Frequency=100), the output would be saved at global time steps 250 (75 time steps into the child simulation), 350 (175 time steps into the child simulation), etc.
Detailed Descriptions#
Output fields#
Select the flow variables to include in the isosurface output.
Default: None
Example:
Mach, pressure, velocity
Note: See detailed field descriptions below. Only select fields you need to analyze.
Output format#
The file format used to save the isosurface output data.
Default:
paraviewExample:
bothOptions:
paraviewtecplotboth
Notes:
Choose the format that best suits your post-processing workflow.
Select
paraviewfor.vtuformat,tecplotfor.pltformat, orbothto save in both formats.
Save interval#
Choose the points in the simulation where the results are saved.
Default:
Save at endOptions:
Save at endCustom(only available whenTime steppingisUnsteady)
Notes:
Choose
Save at endto save only the final results of the simulation.Choose
Customto save the results in given intervals.
Frequency#
How often to save outputs, in number of physical time steps.
Default:
-1(only at the end of simulation)Example:
100— saves output every 100 physical time steps.Standalone case: If you start a simulation from
time_step=0withfrequency=100, outputs are saved at time steps 100, 200, 300, etc.Parent-child case: If the parent finished at
time_step=174, the child starts fromtime_step=175. Withfrequency=100in the child, outputs are saved at global time steps 200 (25 steps into child), 300 (125 steps into child), 400 (225 steps into child), etc.
Notes:
Higher frequencies provide better temporal resolution but increase storage requirements.
Important for child cases - this parameter refers to the global time step (see Global Time Stepping).
This setting is only applicable for unsteady cases.
Frequency offset#
The time step at which to start the output animation.
Default:
0(beginning of simulation)Example:
1000— withfrequency=100, outputs are saved at time steps 1000, 1100, 1200, etc.Standalone case: If you start a simulation from
time_step=0withfrequency=100andfrequency_offset=1000, outputs are saved at time steps 1000, 1100, 1200, etc.Parent-child case: If the parent finished at
time_step=174, the child starts fromtime_step=175. Withfrequency=100andfrequency_offset=200in the child, outputs are saved at global time steps 200 (25 steps into child), 300 (125 steps into child), 400 (225 steps into child), etc.
Notes:
Useful when you want to skip initial transient flow development.
Important for child cases - this parameter refers to the global time step (see Global Time Stepping).
This setting is only applicable for unsteady cases.
Assigned isosurfaces#
Define one or more isosurfaces by specifying a field variable and iso-value.
Default: None
Definition parameters:
Name: A unique identifier for the isosurface
Field: The flow variable used to define the isosurface
Iso-value: The constant value of the field variable that defines the isosurface
Example:
qcriterion = 0.001
Available Isosurface Fields#
Isosurfaces can be defined based on the following field variables:
p- Pressure (non-dimensional)rho- Density (non-dimensional)Mach- Mach number (non-dimensional)qcriterion- Q criterion (for vortex identification) (non-dimensional)s- Entropy (non-dimensional)T- Temperature (non-dimensional)Cp- Coefficient of pressure (non-dimensional)Cpt- Total pressure coefficient (non-dimensional)mut- Turbulent viscosity (non-dimensional)nuHat- Spalart-Almaras variable (non-dimensional)vorticityMagnitude- Vorticity Magnitude (non-dimensional)
Available Output Fields#
Variables from Available Output Fields and the following specific variables
💡 Tips
Common Isosurface Applications
Vortex Identification: Q-criterion isosurfaces (typically positive values)
This is one of the most common applications of isosurfaces in Flow360
The default isosurface value for auto-generated Q-criterion is
RefMach² / (all walls' bounding box length)²For aircraft simulations: try
Mach² / WingSpan²For rotor flows: try
TipMach² / RotorDiameter²Use smaller values to reveal more vortical structures, larger values for only the strongest vortices
Shock Wave Visualization:
Use Mach number or pressure gradient isosurfaces
For transonic flows, a Mach number around 1.0 can help locate shock waves
Pressure gradient isosurfaces can provide cleaner shock visualization
Temperature Contours:
Temperature isosurfaces are useful for thermal analysis
Multiple isosurface values can show temperature stratification
Separation Regions:
Skin friction or velocity isosurfaces can help identify separation regions
Near-zero velocity isosurfaces can indicate recirculation zones
Performance Considerations
Isosurfaces are computationally efficient compared to volume outputs
The number and complexity of isosurfaces affect computational and visualization performance
Try to limit the number of isosurfaces in a single output
For complex flows, consider using multiple isosurface values to capture different flow features
If visualization software is struggling with large isosurfaces, consider:
Simplifying the isosurface by increasing the iso-value
Using multiple isosurface outputs with different frequency settings
Reducing the number of output fields on the isosurface
❓ Frequently Asked Questions
How do I choose the right iso-value for Q-criterion visualization?
Start with a value based on the flow characteristics:
For aircraft: Try
Mach² / WingSpan²For rotors: Try
TipMach² / RotorDiameter²Decrease the value if you want to see more vortical structures
Increase the value if you want to focus only on strongest vortices
Experiment with different values, starting with orders of magnitude (0.1, 0.01, 0.001)
Which isosurface fields are best for different flow features?
Different fields highlight different aspects of the flow:
Vortices:
qcriterion(positive values) orvorticityMagnitudeShock waves:
Mach(around 1.0) orpressuregradientsThermal features:
T(temperature)Separation and recirculation:
velocity_magnitude(near zero)Turbulence regions:
mut(turbulent viscosity)
Can I create multiple isosurfaces with different fields in a single output?
Yes! You can define multiple isosurfaces in a single isosurface output:
Each with different fields (e.g., one for
qcriterion, one forMach)Each with different iso-values
All sharing the same output fields and frequency settings This approach is more efficient than creating multiple separate isosurface outputs.
Why are my isosurfaces flickering in animations?
Isosurface flickering can occur due to:
Unsteady flows where structures evolve rapidly
Iso-values too close to background noise levels
Insufficient temporal resolution (increase output frequency)
Consider time-averaging for statistical visualization of unsteady features
How large are isosurface output files typically?
File sizes for isosurfaces are generally much smaller than volume outputs:
Size depends on the complexity of the isosurface (how many triangles are needed to represent it)
More complex flow features and lower iso-values typically generate larger files
Each output field adds data to every point on the isosurface
For a typical simulation, isosurface files might be 10-100 MB per timestep (compared to GB for volume outputs)
Why is my isosurface broken or incomplete?
Broken isosurfaces might occur because:
The iso-value is too high, breaking continuous structures
The feature doesn’t exist in parts of the domain
Flow features are evolving (especially in unsteady simulations)
Output frequency may be too low to capture continuous evolution
🐍 Python Example Usage
# Example of configuring isosurface output using Flow360 Python API
import flow360 as fl
from flow360 import u
# Define multiple isosurfaces with different fields and values
isosurface_output = fl.IsosurfaceOutput(
name="Flow Structures",
output_format="paraview",
isosurfaces=[
fl.Isosurface(
name="Vortex_Cores",
iso_value=0.001,
field="qcriterion",
),
fl.Isosurface(
name="Shock_Wave",
iso_value=1.0,
field="Mach",
),
fl.Isosurface(
name="Hot_Region",
iso_value=1.2,
field="T",
),
],
output_fields=["velocity", "pressure", "Mach"],
frequency=100, # Save every 100 time steps
frequency_offset=0, # Start at the beginning of simulation
)
# Add isosurface output to simulation parameters
simulation_params = fl.SimulationParams(
# ... other simulation parameters ...
outputs=[isosurface_output]
)