File: logo.py

package info (click to toggle)
python-meshio 7.0.0-really-5.3.5-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,952 kB
  • sloc: python: 14,908; makefile: 19
file content (92 lines) | stat: -rw-r--r-- 2,673 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
import numpy as np
import optimesh
import pygmsh

import meshio

# def _old_logo()
#     with pygmsh.occ.Geometry() as geom:
#         characteristic_length_min = 0.5
#         characteristic_length_max = 0.5
#
#         container = geom.add_rectangle([0.0, 0.0, 0.0], 10.0, 10.0)
#
#         letter_i = geom.add_rectangle([2.0, 2.0, 0.0], 1.0, 4.5)
#         i_dot = geom.add_disk([2.5, 7.5, 0.0], 0.6)
#
#         disk1 = geom.add_disk([6.25, 4.5, 0.0], 2.5)
#         disk2 = geom.add_disk([6.25, 4.5, 0.0], 1.5)
#         letter_o = geom.boolean_difference([disk1], [disk2])
#
#         geom.boolean_difference([container], [letter_i, i_dot, letter_o])
#
#         mesh = pygmsh.generate_mesh(geom)
#
#     X, cells = mesh.points, mesh.cells
#     X, cells = optimesh.cvt.lloyd.quasi_newton_uniform_lloyd(
#         X, cells["triangle"], 1.0e-3, 1000
#     )
#     return X, cells


def create_logo2(y=0.0):
    with pygmsh.geo.Geometry() as geom:
        mesh_size = 0.15

        arrow1 = geom.add_polygon(
            [
                [0.10, 0.70 - y, 0.0],
                [0.35, 0.60 - y, 0.0],
                [0.35, 0.65 - y, 0.0],
                [0.80, 0.65 - y, 0.0],
                [0.80, 0.75 - y, 0.0],
                [0.35, 0.75 - y, 0.0],
                [0.35, 0.80 - y, 0.0],
            ],
            mesh_size=mesh_size,
            make_surface=False,
        )

        arrow2 = geom.add_polygon(
            [
                [0.90, 0.30 + y, 0.0],
                [0.65, 0.40 + y, 0.0],
                [0.65, 0.35 + y, 0.0],
                [0.20, 0.35 + y, 0.0],
                [0.20, 0.25 + y, 0.0],
                [0.65, 0.25 + y, 0.0],
                [0.65, 0.20 + y, 0.0],
            ],
            mesh_size=mesh_size,
            make_surface=False,
        )

        geom.add_polygon(
            [[0.0, 0.0, 0.0], [1.0, 0.0, 0.0], [1.0, 1.0, 0.0], [0.0, 1.0, 0.0]],
            mesh_size=mesh_size,
            holes=[arrow1, arrow2],
        )

        mesh = geom.generate_mesh()
    # return mesh.points, mesh.cells["triangle"]
    X = mesh.points
    cells = mesh.get_cells_type("triangle")

    # np.bincount doesn't work with uint
    # <https://github.com/numpy/numpy/issues/17760>
    cells = cells.astype(int)

    X, cells = optimesh.cvt.quasi_newton_uniform_full(
        X, cells, 1.0e-10, 100, verbose=True
    )
    return X, cells


if __name__ == "__main__":
    X, cells = create_logo2(y=0.08)

    mesh = meshio.Mesh(X, {"triangle": cells})
    meshio.svg.write("logo.svg", mesh, image_width=300)

    X = np.column_stack([X, np.zeros_like(X[:, 0])])
    meshio.Mesh(X, {"triangle": cells}).write("logo.vtk")