提问人:OkheyOfficial 提问时间:7/23/2021 最后编辑:OkheyOfficial 更新时间:7/23/2021 访问量:2147
对三角形内的均匀随机点进行采样 [关闭]
Sample uniformly random points within a triangle [closed]
问:
我想知道如何在 python 中获取三角形内的随机向量,但这似乎比我预期的要困难。飞机的坐标类似于 [a, b], [x, y], [u, v](三个点):
答:
7赞
Mateen Ulhaq
7/23/2021
#1
let 和 be 向量定义一个以原点为中心的三角形。通过这种三角形点拾取方法,可以在由 和 定义的平行四边形中生成随机点。如果点在三角形之外,只需拒绝或反转 和 之间的对角线的点。u
v
u
v
u
v
import random
def uniform_triangle(u, v):
while True:
s = random.random()
t = random.random()
in_triangle = s + t <= 1
p = s * u + t * v if in_triangle else (1 - s) * u + (1 - t) * v
yield p
图生成方式:
from itertools import islice
import matplotlib.pyplot as plt
import numpy as np
triangle = np.array([
[1, 2],
[3, 8],
[7, 5],
])
it = uniform_triangle(
triangle[1] - triangle[0],
triangle[2] - triangle[0],
)
points = np.array(list(islice(it, 0, 1000)))
points += triangle[0]
fig, ax = plt.subplots()
ax.scatter(points[:, 0], points[:, 1], s=1)
fig.savefig("triangle.png", dpi=200)
评论
S, T