所以,我有一个键的二面角图。y 轴仅从 0 到 360,x 轴是帧(想想时间步长)。如果值高于 360,我需要绘图“循环”回零,并绘制两点之间的最短距离(如果需要越过图形的边缘并“循环”返回而不是穿过图形)。
d3 的图看起来不错,但实际上需要跳过图的边缘而不是越过它。
d5 的情节有一个严重的问题,对于一个小的旋转有一个巨大的跳跃只是因为它恰好在零度以下。
我希望这两个图都朝向底部(朝向零)绘制并重新出现在图的顶部,从而有效地选择数据点之间的最短距离。我不希望涉及翻译绘图以删除这些伪影的解决方案(它有效,我已经做到了,但是您会丢失有关角度真实值的信息)。可以绘制“低于零”的解决方案(因此 y 轴从 300 到 360|0 到 200 到 300)也很棒。使用其他库的解决方案非常好。如果需要,我可以提供数据集。
我试图找到类似的解决方案无济于事。关于周期性边界的问题使用 numpy 数据集掩码来隐藏某些跳跃,但它们具有连续的功能(我的是“跳跃”)。
谢谢你的帮助,我真的很感激。
数据集(使它们比图表上的小一点,只保留跳过):
D3:
x = [41.0, 43.0, 45.0, 47.0, 49.0, 51.0, 53.0, 55.0, 57.0, 59.0, 61.0, 63.0, 65.0, 67.0, 69.0, 71.0, 73.0, 75.0, 77.0, 79.0, 81.0, 83.0, 85.0, 87.0, 89.0, 91.0, 93.0, 95.0, 97.0, 99.0, 101.0, 103.0, 105.0, 107.0, 109.0, 111.0, 113.0, 115.0, 117.0, 119.0, 121.0, 123.0, 125.0, 127.0, 129.0, 131.0, 133.0, 135.0, 137.0, 139.0, 141.0, 143.0, 145.0, 147.0, 149.0, 151.0, 153.0, 155.0, 157.0, 159.0]
y = [45.6501, 37.4855, 40.4035, 51.4948, 55.8648, 48.9723, 60.4494, 42.7136, 20.6929, 36.7847, 44.4601, 54.04, 52.4895, 45.1991, 46.8203, 44.5827, 65.8803, 53.5398, 69.5158, 46.5372, 37.1557, 43.9031, 39.9325, 35.5248, 34.3531, 57.8377, 37.9208, 26.6508, 27.2333, 49.3798, 47.8627, 54.2795, 50.0892, 40.9849, 37.4014, 300.7947, 299.4254, 288.5113, 313.2906, 319.0095, 291.0726, 308.075, 298.451, 311.1485, 320.4832, 303.9229, 310.4584, 325.6287, 307.7328, 301.5581, 308.7813, 308.6791, 305.1343, 307.5148, 334.6374, 310.476, 315.6943, 326.0586, 298.6766, 305.6225]
最小工作示例:
import matplotlib.pyplot as plt
fig, ax = plt.subplots()
ax.plot(x, y, linewidth = 1.2, label = 'd3')
ax.set_yticks([t for t in range(0,390,30)])
ax.set_xticks([t for t in range(50,200,50)])
ax.legend(loc='lower right',prop={'size': 14})
plt.show()