當前位置: 首頁>>代碼示例>>Python>>正文


Python meshio.write_points_cells方法代碼示例

本文整理匯總了Python中meshio.write_points_cells方法的典型用法代碼示例。如果您正苦於以下問題:Python meshio.write_points_cells方法的具體用法?Python meshio.write_points_cells怎麽用?Python meshio.write_points_cells使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在meshio的用法示例。


在下文中一共展示了meshio.write_points_cells方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: save_srgb_gamut

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def save_srgb_gamut(self, filename, n=50, cut_000=False):
        import meshio
        import meshzoo

        points, cells = meshzoo.cube(nx=n, ny=n, nz=n)

        if cut_000:
            # cut off [0, 0, 0] to avoid division by 0 in the xyz conversion
            points = points[1:]
            cells = cells[~numpy.any(cells == 0, axis=1)]
            cells -= 1

        srgb_linear = SrgbLinear()
        pts = self.from_xyz100(srgb_linear.to_xyz100(points.T)).T
        assert pts.shape[1] == 3
        rgb = srgb_linear.to_srgb1(points)
        meshio.write_points_cells(
            filename, pts, {"tetra": cells}, point_data={"srgb": rgb}
        ) 
開發者ID:nschloe,項目名稱:colorio,代碼行數:21,代碼來源:_color_space.py

示例2: save_hdr_gamut

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def save_hdr_gamut(self, filename, n=50, cut_000=False):
        import meshio
        import meshzoo

        points, cells = meshzoo.cube(nx=n, ny=n, nz=n)

        if cut_000:
            # cut off [0, 0, 0] to avoid division by 0 in the xyz conversion
            points = points[1:]
            cells = cells[~numpy.any(cells == 0, axis=1)]
            cells -= 1

        hdr = HdrLinear()
        pts = self.from_xyz100(hdr.to_xyz100(points.T)).T
        rgb = hdr.to_hdr1(points)
        meshio.write_points_cells(
            filename, pts, {"tetra": cells}, point_data={"hdr-rgb": rgb}
        ) 
開發者ID:nschloe,項目名稱:colorio,代碼行數:20,代碼來源:_color_space.py

示例3: write

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def write(self, filename, point_data=None, cell_data=None, field_data=None):
        if self.node_coords.shape[1] == 2:
            n = len(self.node_coords)
            a = numpy.ascontiguousarray(
                numpy.column_stack([self.node_coords, numpy.zeros(n)])
            )
        else:
            a = self.node_coords

        if self.cells["nodes"].shape[1] == 3:
            cell_type = "triangle"
        else:
            assert (
                self.cells["nodes"].shape[1] == 4
            ), "Only triangles/tetrahedra supported"
            cell_type = "tetra"

        meshio.write_points_cells(
            filename,
            a,
            {cell_type: self.cells["nodes"]},
            point_data=point_data,
            cell_data=cell_data,
            field_data=field_data,
        ) 
開發者ID:nschloe,項目名稱:meshplex,代碼行數:27,代碼來源:base.py

示例4: circle_rotated

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def circle_rotated():
    pts, cells = circle_random()
    # <https://en.wikipedia.org/wiki/Rodrigues%27_rotation_formula>
    theta = numpy.pi / 4
    k = numpy.array([1.0, 0.0, 0.0])
    pts = (
        pts * numpy.cos(theta)
        + numpy.cross(k, pts) * numpy.sin(theta)
        + numpy.outer(numpy.einsum("ij,j->i", pts, k), k) * (1.0 - numpy.cos(theta))
    )
    meshio.write_points_cells("out.vtk", pts, {"triangle": cells})
    return pts, cells 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:14,代碼來源:meshes.py

示例5: save_cone_gamut

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def save_cone_gamut(self, filename, observer, max_Y):
        import meshio
        import pygmsh

        geom = pygmsh.built_in.Geometry()

        max_stepsize = 4.0e-2
        xy, _ = get_mono_outline_xy(observer, max_stepsize=max_stepsize)

        # append third component
        xy = numpy.column_stack([xy, numpy.full(xy.shape[0], 1.0e-5)])

        # Draw a cross.
        poly = geom.add_polygon(xy, lcar=max_stepsize)

        axis = [0, 0, max_Y]

        geom.extrude(poly, translation_axis=axis, point_on_axis=[0, 0, 0])

        mesh = pygmsh.generate_mesh(geom, verbose=False)
        # meshio.write(filename, mesh)

        pts = self.from_xyz100(_xyy_to_xyz100(mesh.points.T)).T
        meshio.write_points_cells(
            filename, pts, {"tetra": mesh.get_cells_type("tetra")}
        ) 
開發者ID:nschloe,項目名稱:colorio,代碼行數:28,代碼來源:_color_space.py

示例6: test

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def test(mesh):
    with tempfile.TemporaryDirectory() as temp_dir:
        filepath = os.path.join(temp_dir, "out.svg")
        meshio.write_points_cells(filepath, mesh.points, mesh.cells) 
開發者ID:nschloe,項目名稱:meshio,代碼行數:6,代碼來源:test_svg.py

示例7: generic_io

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def generic_io(filename):
    with tempfile.TemporaryDirectory() as temp_dir:
        filepath = os.path.join(temp_dir, filename)
        meshio.write_points_cells(filepath, tri_mesh.points, tri_mesh.cells)
        out_mesh = meshio.read(filepath)
        assert (abs(out_mesh.points - tri_mesh.points) < 1.0e-15).all()
        for c0, c1 in zip(tri_mesh.cells, out_mesh.cells):
            assert c0.type == c1.type
            assert (c0.data == c1.data).all() 
開發者ID:nschloe,項目名稱:meshio,代碼行數:11,代碼來源:helpers.py

示例8: get_poisson_condition

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def get_poisson_condition(pts, cells):
    # Still can't initialize a mesh from points, cells
    filename = "mesh.xdmf"
    meshio.write_points_cells(filename, pts, {"triangle": cells})
    mesh = Mesh()
    with XDMFFile(filename) as f:
        f.read(mesh)

    # build Laplace matrix with Dirichlet boundary using dolfin
    V = FunctionSpace(mesh, "Lagrange", 1)

    u = TrialFunction(V)
    v = TestFunction(V)
    a = inner(grad(u), grad(v)) * dx
    u0 = Constant(0.0)
    bc = DirichletBC(V, u0, "on_boundary")
    f = Constant(1.0)
    L = f * v * dx

    A = assemble(a)
    b = assemble(L)
    bc.apply(A, b)

    # solve(A, x, b, "cg")
    solver = KrylovSolver("cg", "none")

    x = Function(V)
    x_vec = x.vector()
    num_steps = solver.solve(A, x_vec, b)

    # convert to scipy matrix
    A = as_backend_type(A).mat()
    ai, aj, av = A.getValuesCSR()
    A = scipy.sparse.csr_matrix(
        (av, aj, ai), shape=(A.getLocalSize()[0], A.getSize()[1])
    )

    # ev = eigvals(A.todense())
    ev_max = scipy.sparse.linalg.eigs(A, k=1, which="LM")[0][0]
    assert numpy.abs(ev_max.imag) < 1.0e-15
    ev_max = ev_max.real
    ev_min = scipy.sparse.linalg.eigs(A, k=1, which="SM")[0][0]
    assert numpy.abs(ev_min.imag) < 1.0e-15
    ev_min = ev_min.real
    cond = ev_max / ev_min

    # solve poisson system, count num steps
    # b = numpy.ones(A.shape[0])
    # out = pykry.gmres(A, b)
    # num_steps = len(out.resnorms)
    return cond, num_steps 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:53,代碼來源:compare-gmsh-quality.py

示例9: save_visible_gamut

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def save_visible_gamut(self, observer, illuminant, filename, cut_000=False):
        from scipy.spatial import ConvexHull
        import meshio

        lmbda, illu = illuminant
        values = []

        # Iterate over every possible illuminant input and store it in values
        n = len(lmbda)
        values = numpy.empty((n * (n - 1) + 2, 3))
        k = 0

        # No light
        data = numpy.zeros(n)
        values[k] = spectrum_to_xyz100((lmbda, illu * data), observer=observer)
        k += 1
        # frequency blocks
        for width in range(1, n):
            data = numpy.zeros(n)
            data[:width] = 1.0
            for _ in range(n):
                values[k] = spectrum_to_xyz100((lmbda, illu * data), observer=observer)
                k += 1
                data = numpy.roll(data, shift=1)
        # Full illuminant
        data = numpy.ones(len(lmbda))
        values[k] = spectrum_to_xyz100((lmbda, illu * data), observer=observer)
        k += 1

        # scale the values such that the Y-coordinate of the white point (last entry)
        # has value 100.
        values *= 100 / values[-1][1]

        cells = ConvexHull(values).simplices

        if cut_000:
            values = values[1:]
            cells = cells[~numpy.any(cells == 0, axis=1)]
            cells -= 1

        pts = self.from_xyz100(values.T).T

        meshio.write_points_cells(filename, pts, cells={"triangle": cells}) 
開發者ID:nschloe,項目名稱:colorio,代碼行數:45,代碼來源:_color_space.py

示例10: RequestData

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import write_points_cells [as 別名]
def RequestData(self, request, inInfoVec, outInfoVec):
        mesh = dsa.WrapDataObject(vtkUnstructuredGrid.GetData(inInfoVec[0]))

        # Read points
        points = np.asarray(mesh.GetPoints())

        # Read cells
        # Adapted from test/legacy_reader.py
        cell_conn = mesh.GetCells()
        cell_offsets = mesh.GetCellLocations()
        cell_types = mesh.GetCellTypes()
        cells_dict = {}
        for vtk_cell_type in np.unique(cell_types):
            offsets = cell_offsets[cell_types == vtk_cell_type]
            ncells = len(offsets)
            npoints = cell_conn[offsets[0]]
            array = np.empty((ncells, npoints), dtype=int)
            for i in range(npoints):
                array[:, i] = cell_conn[offsets + i + 1]
            cells_dict[vtk_to_meshio_type[vtk_cell_type]] = array
        cells = [meshio.CellBlock(key, cells_dict[key]) for key in cells_dict]

        # Read point and field data
        # Adapted from test/legacy_reader.py
        def _read_data(data):
            out = {}
            for i in range(data.VTKObject.GetNumberOfArrays()):
                name = data.VTKObject.GetArrayName(i)
                array = np.asarray(data.GetArray(i))
                out[name] = array
            return out

        point_data = _read_data(mesh.GetPointData())
        field_data = _read_data(mesh.GetFieldData())

        # Read cell data
        cell_data_flattened = _read_data(mesh.GetCellData())
        cell_data = {}
        for name, array in cell_data_flattened.items():
            cell_data[name] = []
            for cell_type in cells_dict:
                vtk_cell_type = meshio_to_vtk_type[cell_type]
                mask_cell_type = cell_types == vtk_cell_type
                cell_data[name].append(array[mask_cell_type])

        # Use meshio to write mesh
        meshio.write_points_cells(
            self._filename,
            points,
            cells,
            point_data=point_data,
            cell_data=cell_data,
            field_data=field_data,
        )
        return 1 
開發者ID:nschloe,項目名稱:meshio,代碼行數:57,代碼來源:paraview-meshio-plugin.py


注:本文中的meshio.write_points_cells方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。