scipy.spatial.transform.
Slerp#
- class scipy.spatial.transform.Slerp(times, rotations)#
旋轉的球面線性插值。
連續旋轉之間的插值是透過繞固定軸以恆定角速度旋轉來執行的 [1]。這確保了插值旋轉遵循初始和最終方向之間的最短路徑。
- 參數:
- timesarray_like,形狀 (N,)
已知旋轉的時間。必須指定至少 2 個時間。
- rotations
Rotation
實例 執行插值的旋轉。必須包含 N 個旋轉。
另請參閱
註解
在 1.2.0 版本中新增。
參考文獻
範例
>>> 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]])
方法
__call__
(times)插值旋轉。