美文网首页
Delaunay 三角形生成

Delaunay 三角形生成

作者: 一只大南瓜 | 来源:发表于2019-04-18 19:48 被阅读0次

    目前在做的一件事情生成Delaunay 三角网。网上代码如下

    from scipy.spatial import Delaunay
    import numpy as np
    import matplotlib.pyplot as plt
    
    # Triangle Settings
    width = 100
    height = 100
    pointNumber = 100
    points = np.zeros((pointNumber, 2))
    points[:, 0] = np.random.randint(0, width, pointNumber)
    points[:, 1] = np.random.randint(0, height, pointNumber)
    
    # Use scipy.spatial.Delaunay for Triangulation
    tri = Delaunay(points)
    
    # Plot Delaunay triangle with color filled
    center = np.sum(points[tri.simplices], axis=1)/3.0
    color = np.array([(x - width/2)**2 + (y - height/2)**2 for x, y in center])
    plt.figure(figsize=(7, 3))
    plt.tripcolor(points[:, 0], points[:, 1], tri.simplices.copy(), facecolors=color, edgecolors='k')
    
    
    # Delete ticks, axis and background
    plt.tick_params(labelbottom='off', labelleft='off', left='off', right='off',
                    bottom='off', top='off')
    ax = plt.gca()
    ax.spines['right'].set_color('none')
    ax.spines['bottom'].set_color('none')
    ax.spines['left'].set_color('none')
    ax.spines['top'].set_color('none')
    
    plt.show()
    

    生成的效果如图:


    image.png

    但是上面生成的三角网内部有色彩填充,这在这个任务中是不需要的所以有了以下改进

    from scipy.spatial import Delaunay
    import numpy as np
    import matplotlib.pyplot as plt
    
    # Triangle Settings
    width = 100
    height = 100
    pointNumber = 100
    points = np.zeros((pointNumber, 2))
    points[:, 0] = np.random.randint(0, width, pointNumber)
    points[:, 1] = np.random.randint(0, height, pointNumber)
    
    # Use scipy.spatial.Delaunay for Triangulation
    tri = Delaunay(points)
    
    # Plot Delaunay triangle with color filled
    center = np.sum(points[tri.simplices], axis=1)/3.0
    plt.figure(figsize=(7, 3))
    plt.triplot(points[:, 0], points[:, 1], tri.simplices.copy())
    
    
    # Delete ticks, axis and background
    plt.tick_params(labelbottom='off', labelleft='off', left='off', right='off',
                    bottom='off', top='off')
    ax = plt.gca()
    ax.spines['right'].set_color('none')
    ax.spines['bottom'].set_color('none')
    ax.spines['left'].set_color('none')
    ax.spines['top'].set_color('none')
    
    plt.show()
    
    

    效果如下图:


    image.png

    相关文章

      网友评论

          本文标题:Delaunay 三角形生成

          本文链接:https://www.haomeiwen.com/subject/avytgqtx.html