2 回答
TA贡献2065条经验 获得超14个赞
如果您总是只想旋转 90 度并且始终保持相同的方向(因此rot90
没有任何其他参数),您可以使用以下公式:
idx2 = np.array([[n.shape[0]-1-x[1], x[0]] for x in idx])
假设idx
是您的索引数组 (2, 3866) 和n
您想要索引的网格 (522, 476)。它只是使用单次旋转对元素的作用的知识,即将第一维切换到第二维,并使第二维从末尾开始计算为第一维。
TA贡献1845条经验 获得超8个赞
您可以定义一个旋转函数:
def rotate(origin, point, angle):
"""
Rotate a point counterclockwise by a given angle around a given origin.
The angle should be given in radians.
"""
ox, oy = origin
px, py = point
qx = ox + math.cos(angle) * (px - ox) - math.sin(angle) * (py - oy)
qy = oy + math.sin(angle) * (px - ox) + math.cos(angle) * (py - oy)
return qx, qy
然后将此函数应用于轨迹的所有 (X,Y) 点。
origin = tuple(0, 0)
newTrajectory = []
for i in range(0:len(trajectory[0])):
p = tuple(trajectory[i][0], trajectory[i][1])
newP = rotate(origin, p, math.pi/2)
row = [newP[0], newP[1]]
newTrajectory.append(row)
最好的事物
添加回答
举报