xugrid.Ugrid1d.refine_by_vertices#
- Ugrid1d.refine_by_vertices(vertices: ndarray, return_index: bool = False) Ugrid1d [source]#
Refine Ugrid1d with extra vertices to be inserted and returns new grid. Vertices need to be located on existing grid edges, if not, a ValueError will be returned.
- Parameters:
vertices (np.ndarray of floats) – Coordinates of vertices to be inserted in the grid. Must have shape (N, 2).
return_index (bool, optional) – If set to to True, the index of the new vertices in the grid will be returned. Defaults to False.
- Returns:
grid – Refined grid with new vertices.
- Return type:
Examples
Let’s first create a simple grid with 3 nodes and 2 edges:
>>> import numpy as np >>> import xugrid as xu >>> node_xy = np.array([[0.0, 0.0], [5.0, 5.0], [10.0, 5.0]]) >>> edge_nodes = np.array([[0, 1],[1, 2]]) >>> grid = xu.Ugrid1d(*node_xy.T, -1, edge_nodes)
Now refine the grid by adding new vertices:
>>> vertices = np.array([[2.0, 2.0], [7.0, 5.0]]) >>> new = grid.refine_by_vertices(vertices) >>> print(new.node_coordinates)
To return the indices of the inserted vertices:
>>> new, new_vertices_index = grid.refine_by_vertices(vertices, return_index=True) >>> print(new_vertices_index) >>> print(new.node_coordinates[new_vertices_index])