pyvista.PointSet.threshold#

PointSet.threshold(value=None, scalars=None, invert=False, continuous=False, preference='cell', all_scalars=False, component_mode='all', component=0, method='upper', progress_bar=False)[source]#

Apply a vtkThreshold filter to the input dataset.

This filter will apply a vtkThreshold filter to the input dataset and return the resulting object. This extracts cells where the scalar value in each cell satisfies the threshold criterion. If scalars is None, the input’s active scalars array is used.

Warning

Thresholding is inherently a cell operation, even though it can use associated point data for determining whether to keep a cell. In other words, whether or not a given point is included after thresholding depends on whether that point is part of a cell that is kept after thresholding.

Please also note the default preference choice for CELL data over POINT data. This is contrary to most other places in PyVista’s API where the preference typically defaults to POINT data. We chose to prefer CELL data here so that if thresholding by a named array that exists for both the POINT and CELL data, this filter will default to the CELL data array while performing the CELL-wise operation.

Parameters:
valuefloat | sequence[float], optional

Single value or (min, max) to be used for the data threshold. If a sequence, then length must be 2. If no value is specified, the non-NaN data range will be used to remove any NaN values. Please reference the method parameter for how single values are handled.

scalarsstr, optional

Name of scalars to threshold on. Defaults to currently active scalars.

invertbool, default: False

Invert the threshold results. That is, cells that would have been in the output with this option off are excluded, while cells that would have been excluded from the output are included.

continuousbool, default: False

When True, the continuous interval [minimum cell scalar, maximum cell scalar] will be used to intersect the threshold bound, rather than the set of discrete scalar values from the vertices.

preferencestr, default: ‘cell’

When scalars is specified, this is the preferred array type to search for in the dataset. Must be either 'point' or 'cell'. Throughout PyVista, the preference is typically 'point' but since the threshold filter is a cell-wise operation, we prefer cell data for thresholding operations.

all_scalarsbool, default: False

If using scalars from point data, all points in a cell must satisfy the threshold when this value is True. When False, any point of the cell with a scalar value satisfying the threshold criterion will extract the cell. Has no effect when using cell data.

component_mode{‘selected’, ‘all’, ‘any’}

The method to satisfy the criteria for the threshold of multicomponent scalars. ‘selected’ (default) uses only the component. ‘all’ requires all components to meet criteria. ‘any’ is when any component satisfies the criteria.

componentint, default: 0

When using component_mode='selected', this sets which component to threshold on.

methodstr, default: ‘upper’

Set the threshold method for single-values, defining which threshold bounds to use. If the value is a range, this parameter will be ignored, extracting data between the two values. For single values, 'lower' will extract data lower than the value. 'upper' will extract data larger than the value.

progress_barbool, default: False

Display a progress bar to indicate progress.

Returns:
pyvista.UnstructuredGrid

Dataset containing geometry that meets the threshold requirements.

Examples

>>> import pyvista as pv
>>> import numpy as np
>>> volume = np.zeros([10, 10, 10])
>>> volume[:3] = 1
>>> vol = pv.wrap(volume)
>>> threshed = vol.threshold(0.1)
>>> threshed
UnstructuredGrid (...)
  N Cells:    243
  N Points:   400
  X Bounds:   0.000e+00, 3.000e+00
  Y Bounds:   0.000e+00, 9.000e+00
  Z Bounds:   0.000e+00, 9.000e+00
  N Arrays:   1

Apply the threshold filter to Perlin noise. First generate the structured grid.

>>> import pyvista as pv
>>> noise = pv.perlin_noise(0.1, (1, 1, 1), (0, 0, 0))
>>> grid = pv.sample_function(
...     noise, [0, 1.0, -0, 1.0, 0, 1.0], dim=(20, 20, 20)
... )
>>> grid.plot(
...     cmap='gist_earth_r',
...     show_scalar_bar=True,
...     show_edges=False,
... )
../../../_images/pyvista-PointSet-threshold-1_00_00.png

Next, apply the threshold.

>>> import pyvista as pv
>>> noise = pv.perlin_noise(0.1, (1, 1, 1), (0, 0, 0))
>>> grid = pv.sample_function(
...     noise, [0, 1.0, -0, 1.0, 0, 1.0], dim=(20, 20, 20)
... )
>>> threshed = grid.threshold(value=0.02)
>>> threshed.plot(
...     cmap='gist_earth_r',
...     show_scalar_bar=False,
...     show_edges=True,
... )
../../../_images/pyvista-PointSet-threshold-1_01_00.png

See Using Common Filters for more examples using this filter.