Note
Go to the end to download the full example code.
Points to Tube
This example will demonstrate how to to build a tube from a set of points in vtkPolyData.
Takes points from a vtkPolyData object and constructs a line of those points then builds a polygonal tube around that line with some specified radius and number of sides.
import numpy as np
# sphinx_gallery_thumbnail_number = 2
import pyvista
from PVGeo.filters import PointsToTube
def path(y):
"""Equation: x = a(y-h)^2 + k"""
a = -110.0 / 160.0**2
x = a * y**2 + 110.0
return x, y
x, y = path(np.arange(0.0, 200.0, 25.0))
zo = np.linspace(9.0, 11.0, num=len(y))
points = pyvista.PolyData(np.c_[x, y, zo])
points.plot(point_size=10)
data:image/s3,"s3://crabby-images/c3747/c374708b853da2e03485f8e8b9fbf77d0be185d1" alt="points to tube"
# Use the filter: here is vtkPolyData containing the tube
tube = PointsToTube(nearestNbr=True).apply(points)
tube.plot(color=True)
data:image/s3,"s3://crabby-images/e4aab/e4aabd63c1c3fe19fcf3af0f7eb565a7b10452b9" alt="points to tube"
Total running time of the script: (0 minutes 0.354 seconds)