scipy.spatial.transform.

Slerp#

class scipy.spatial.transform.Slerp(times, rotations)#

旋转的球面线性插值。

连续旋转之间的插值是围绕一个固定轴以恒定角速度进行的 [1]。这确保了插值旋转沿着初始和最终方向之间的最短路径进行。

参数:
时间array_like, 形状 (N,)

已知旋转的次数。至少必须指定2次。

旋转 : 旋转 实例旋转实例

要执行插值的旋转。必须包含 N 个旋转。

方法

__call__(times)

插值旋转。

参见

Rotation

注释

Added in version 1.2.0.

参考文献

[1]

https://zh.wikipedia.org/wiki/球面线性插值#四元数球面线性插值

示例

>>> from scipy.spatial.transform import Rotation as R
>>> from scipy.spatial.transform import Slerp

设置固定关键帧旋转和时间:

>>> key_rots = R.random(5, random_state=2342345)
>>> key_times = [0, 1, 2, 3, 4]

创建插值器对象:

>>> slerp = Slerp(key_times, key_rots)

在给定的时间点插值旋转:

>>> times = [0, 0.5, 0.25, 1, 1.5, 2, 2.75, 3, 3.25, 3.60, 4]
>>> interp_rots = slerp(times)

以欧拉角表示的关键帧旋转:

>>> key_rots.as_euler('xyz', degrees=True)
array([[ 14.31443779, -27.50095894,  -3.7275787 ],
       [ -1.79924227, -24.69421529, 164.57701743],
       [146.15020772,  43.22849451, -31.34891088],
       [ 46.39959442,  11.62126073, -45.99719267],
       [-88.94647804, -49.64400082, -65.80546984]])

以欧拉角表示的内插旋转。这些旋转在关键帧时间范围的两端与关键帧旋转一致。

>>> interp_rots.as_euler('xyz', degrees=True)
array([[  14.31443779,  -27.50095894,   -3.7275787 ],
       [   4.74588574,  -32.44683966,   81.25139984],
       [  10.71094749,  -31.56690154,   38.06896408],
       [  -1.79924227,  -24.69421529,  164.57701743],
       [  11.72796022,   51.64207311, -171.7374683 ],
       [ 146.15020772,   43.22849451,  -31.34891088],
       [  68.10921869,   20.67625074,  -48.74886034],
       [  46.39959442,   11.62126073,  -45.99719267],
       [  12.35552615,    4.21525086,  -64.89288124],
       [ -30.08117143,  -19.90769513,  -78.98121326],
       [ -88.94647804,  -49.64400082,  -65.80546984]])