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


Python meshio.read方法代碼示例

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


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

示例1: get_cells

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def get_cells(self, indices=[]):
    """Return the cells (connectivities).

    Parameters
    ----------
    self : MeshVTK
        a MeshVTK object
    indices : list
        list of the points to extract (optional)

    Returns
    -------
    cells: list
        List of cell groups (type + array)
    """

    # Read mesh file with meshio (pyvista does not provide the correct cell format)
    mesh = read(self.path + "/" + self.name + "." + self.format)

    return mesh.cells 
開發者ID:Eomys,項目名稱:pyleecan,代碼行數:22,代碼來源:get_cells.py

示例2: plot_file_sizes

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def plot_file_sizes(names, file_sizes, mem_size):
    idx = numpy.argsort(file_sizes)
    file_sizes = [file_sizes[i] for i in idx]
    names = [names[i] for i in idx]

    ax = plt.gca()
    y_pos = numpy.arange(len(file_sizes))
    ax.barh(y_pos, file_sizes, align="center")
    #
    ylim = ax.get_ylim()
    plt.plot(
        [mem_size, mem_size], [-2, len(file_sizes) + 2], "C3", linewidth=2.0, zorder=0
    )
    ax.set_ylim(ylim)
    #
    ax.set_yticks(y_pos)
    ax.set_yticklabels(names)
    ax.invert_yaxis()  # labels read top-to-bottom
    ax.set_xlabel("file size [MB]")
    ax.set_title("file sizes")
    plt.grid()
    # plt.show()
    plt.savefig("filesizes.svg", transparent=True, bbox_inches="tight")
    plt.close() 
開發者ID:nschloe,項目名稱:meshio,代碼行數:26,代碼來源:performance.py

示例3: generate_mesh

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def generate_mesh(self, verbose=False):
        import meshio
        import os
        import subprocess
        import tempfile
        
        gmsh_executable = 'gmsh'
        
        handle, filename = tempfile.mkstemp(suffix='.geo')
        os.write(handle, self.get_code().encode())
        os.close(handle)

        handle, outname = tempfile.mkstemp(suffix='.msh')
        cmd = [gmsh_executable, '-2', filename, '-o', outname]
        try:
            out = subprocess.check_output(cmd, stderr=subprocess.STDOUT)
        except:
            out = os.system(" ".join(cmd))
        if verbose:
            print(out.decode())
        #points,cells = meshio.read(outname)
        mesh = meshio.read(outname)
        # ~ print(dir(mesh))
        #return points, cells
        return mesh.points, mesh.cells["triangle"] 
開發者ID:JorgeDeLosSantos,項目名稱:nusa,代碼行數:27,代碼來源:_mesh.py

示例4: read_legacy

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def read_legacy(filename):
    """Use VTK's legacy reader to read a file."""
    reader = vtk.vtkDataSetReader()
    reader.SetFileName(filename)
    # Ensure all data is fetched with poorly formatted legacy files
    reader.ReadAllScalarsOn()
    reader.ReadAllColorScalarsOn()
    reader.ReadAllNormalsOn()
    reader.ReadAllTCoordsOn()
    reader.ReadAllVectorsOn()
    # Perform the read
    reader.Update()
    output = reader.GetOutputDataObject(0)
    if output is None:
        raise RuntimeError('No output when using VTKs legacy reader')
    return pyvista.wrap(output) 
開發者ID:pyvista,項目名稱:pyvista,代碼行數:18,代碼來源:fileio.py

示例5: test_reference_file_readonly

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def test_reference_file_readonly(filename, ref_sum, ref_num_cells):
    this_dir = pathlib.Path(__file__).resolve().parent
    filename = this_dir / "meshes" / "msh" / filename

    mesh = meshio.read(filename)
    tol = 1.0e-2
    s = mesh.points.sum()
    assert abs(s - ref_sum) < tol * ref_sum
    assert {k: len(v) for k, v in mesh.cells_dict.items()} == ref_num_cells
    assert {
        k: len(v) for k, v in mesh.cell_data_dict["gmsh:physical"].items()
    } == ref_num_cells

    num_cells = {k: 0 for k in ref_num_cells}
    for vv in mesh.cell_sets_dict.values():
        for k, v in vv.items():
            num_cells[k] += len(v)
    assert num_cells == ref_num_cells 
開發者ID:nschloe,項目名稱:meshio,代碼行數:20,代碼來源:test_gmsh.py

示例6: test_convert

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def test_convert():
    input_mesh = helpers.tri_mesh
    infile = tempfile.NamedTemporaryFile().name
    meshio.write(infile, input_mesh, file_format="gmsh")

    outfile = tempfile.NamedTemporaryFile().name

    meshio._cli.convert(
        [infile, outfile, "--input-format", "gmsh", "--output-format", "vtk"]
    )

    mesh = meshio.read(outfile, file_format="vtk")

    atol = 1.0e-15
    assert numpy.allclose(input_mesh.points, mesh.points, atol=atol, rtol=0.0)

    for cells0, cells1 in zip(input_mesh.cells, mesh.cells):
        assert cells0.type == cells1.type
        assert numpy.allclose(cells0.data, cells1.data) 
開發者ID:nschloe,項目名稱:meshio,代碼行數:21,代碼來源:test_cli.py

示例7: test_reference_file

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def test_reference_file(filename):
    this_dir = pathlib.Path(__file__).resolve().parent
    filename = this_dir / "meshes" / "nastran" / filename

    mesh = meshio.read(filename)

    # points
    assert numpy.isclose(mesh.points.sum(), 16.5316866)

    # cells
    ref_num_cells = {
        "line": 241,
        "triangle": 171,
        "quad": 721,
        "pyramid": 1180,
        "tetra": 5309,
    }
    assert {k: v.sum() for k, v in mesh.cells} == ref_num_cells 
開發者ID:nschloe,項目名稱:meshio,代碼行數:20,代碼來源:test_nastran.py

示例8: _pyramid_volume

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def _pyramid_volume(cell):
    """
    Evaluate pyramid volume by splitting it into
    two tetrahedra
    """
    tet0 = cell[[0, 1, 3, 4]]
    tet1 = cell[[1, 2, 3, 4]]

    vol = 0.0
    vol += _tet_volume(tet0)
    vol += _tet_volume(tet1)
    return vol


# ugrid node ordering is the same for all elements except the pyramids. In order to make
# sure we got it right read a cube split into pyramids and evaluate its volume 
開發者ID:nschloe,項目名稱:meshio,代碼行數:18,代碼來源:test_ugrid.py

示例9: read

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def read(filename):
    """Reads an unstructured mesh into meshplex format.

    :param filenames: The files to read from.
    :type filenames: str
    :returns mesh{2,3}d: The mesh data.
    """
    mesh = meshio.read(filename)

    # make sure to include the used nodes only
    tetra = mesh.get_cells_type("tetra")
    if len(tetra) > 0:
        points, cells = _sanitize(mesh.points, tetra)
        return MeshTetra(points, cells)

    tri = mesh.get_cells_type("triangle")
    assert len(tri) > 0
    points, cells = _sanitize(mesh.points, tri)
    return MeshTri(points, cells) 
開發者ID:nschloe,項目名稱:meshplex,代碼行數:21,代碼來源:reader.py

示例10: get_mesh

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def get_mesh(self, indices=[]):
    """Return the pyvista mesh object (or submesh).

    Parameters
    ----------
    self : MeshVTK
        a MeshVTK object
    indices : list
        list of the points to extract (optional)

    Returns
    -------
    mesh : pyvista.core.pointset.UnstructuredGrid
        a pyvista UnstructuredGrid object
    """

    # Already available => Return
    if self.mesh is not None:
        return self.mesh

    # Read mesh file
    else:
        if self.format != "vtk":
            # Write vtk files with meshio
            mesh = read(self.path + "/" + self.name + "." + self.format)
            mesh.write(self.path + "/" + self.name + ".vtk")

        # Read .vtk file with pyvista
        mesh = pv.read(self.path + "/" + self.name + ".vtk")

        # Extract submesh
        if indices != []:
            mesh = mesh.extract_points(indices)

        if self.is_pyvista_mesh:
            self.mesh = mesh

        return mesh 
開發者ID:Eomys,項目名稱:pyleecan,代碼行數:40,代碼來源:get_mesh.py

示例11: info

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def info(argv=None):
    parser = _get_parser()
    args = parser.parse_args(argv)

    mesh = meshio.read(args.input_file)

    cells = mesh.get_cells_type("triangle")

    print("Number of points: {}".format(mesh.points.shape[0]))
    print("Number of elements:")
    for cell_type, value in mesh.cells:
        print("  {}: {}".format(cell_type, value.shape[0]))

    mesh = MeshTri(mesh.points, cells)
    print_stats(mesh) 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:17,代碼來源:info.py

示例12: pacman

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def pacman():
    this_dir = os.path.dirname(os.path.realpath(__file__))
    mesh = meshio.read(os.path.join(this_dir, "meshes", "pacman.vtk"))
    return mesh.points[:, :2], mesh.get_cells_type("triangle") 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:6,代碼來源:meshes.py

示例13: circle_gmsh

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def circle_gmsh():
    this_dir = os.path.dirname(os.path.realpath(__file__))
    mesh = meshio.read(os.path.join(this_dir, "meshes", "circle.vtk"))
    c = mesh.get_cells_type("triangle")
    return mesh.points[:, :2], c 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:7,代碼來源:meshes.py

示例14: circle_gmsh2

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def circle_gmsh2():
    # import pygmsh
    # geom = pygmsh.built_in.Geometry()
    # target_edge_length = 2 * numpy.pi / _compute_num_boundary_points(num_points)
    # geom.add_circle(
    #     [0.0, 0.0, 0.0], 1.0, lcar=target_edge_length, num_sections=4, compound=True
    # )
    # mesh = pygmsh.generate_mesh(geom, remove_lower_dim_cells=True, verbose=False)
    # mesh.write("out.vtk")

    this_dir = os.path.dirname(os.path.realpath(__file__))
    mesh = meshio.read(os.path.join(this_dir, "meshes", "circle-small.vtk"))
    c = mesh.get_cells_type("triangle")
    return mesh.points[:, :2], c 
開發者ID:nschloe,項目名稱:optimesh,代碼行數:16,代碼來源:meshes.py

示例15: generate_mesh_from_file

# 需要導入模塊: import meshio [as 別名]
# 或者: from meshio import read [as 別名]
def generate_mesh_from_file(self,filename):
        mesh = meshio.read(filename)
        self.nc = mesh.points
        self.x, self.y = self.nc[:,0], self.nc[:,1]
        self.ec = mesh.cells["triangle"]
        return mesh.points, mesh.cells["triangle"] 
開發者ID:JorgeDeLosSantos,項目名稱:nusa,代碼行數:8,代碼來源:mesh.py


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