import numpy as np
import pyvista as pv

def save_vtu(filename, coords, U, fields=None):
    """
    Save a VTU file with given coordinates and velocity field using pyvista.
    coords: (N,2) or (N,3) array
    U: (N,2) or (N,3) array
    fields: dict of additional fields (optional)
    """
    points = np.array(coords)
    if points.shape[1] == 2:
        points = np.hstack([points, np.zeros((points.shape[0], 1))])
    # Create a PolyData object with points only (vertex cells)
    pdata = pv.PolyData(points)
    pdata["U"] = np.array(U)
    if fields:
        for k, v in fields.items():
            pdata[k] = np.array(v)
    pdata.save(filename)