random#
- classmethod Rotation.random(cls, num=None, rng=None)#
生成均匀分布的旋转。
- 参数:
- numint 或 None,可选
要生成的随机旋转的数目。如果为 None(默认),则生成单个旋转。
- rng{None, int,
numpy.random.Generator
}, 可选 如果通过关键字传递 rng,则将
numpy.random.Generator
以外的类型传递给numpy.random.default_rng
以实例化Generator
。如果 rng 已经是一个Generator
实例,则使用提供的实例。指定 rng 以实现可重复的函数行为。如果此参数通过位置传递,或者 random_state 通过关键字传递,则应用参数 random_state 的旧行为
如果 random_state 为 None(或
numpy.random
),则使用numpy.random.RandomState
单例。如果 random_state 是一个 int,则使用一个新的
RandomState
实例,并以 random_state 作为种子。如果 random_state 已经是一个
Generator
或RandomState
实例,则使用该实例。
在版本 1.15.0 中更改:作为从使用
numpy.random.RandomState
到numpy.random.Generator
的 SPEC-007 过渡的一部分,此关键字已从 random_state 更改为 rng。在过渡期间,两个关键字将继续工作,但一次只能指定一个。在过渡期结束后,使用 random_state 关键字的函数调用将发出警告。上面概述了 random_state 和 rng 的行为,但新代码中应仅使用 rng 关键字。
- 返回:
- random_rotation
Rotation
实例 如果 num 为 None,则包含单个旋转。否则包含 num 个旋转的堆栈。
- random_rotation
注释
此函数经过优化,可以有效地采样三维随机旋转矩阵。对于生成更高维度的随机旋转矩阵,请参阅
scipy.stats.special_ortho_group
。示例
>>> from scipy.spatial.transform import Rotation as R
采样单个旋转
>>> R.random().as_euler('zxy', degrees=True) array([-110.5976185 , 55.32758512, 76.3289269 ]) # random
采样旋转堆栈
>>> R.random(5).as_euler('zxy', degrees=True) array([[-110.5976185 , 55.32758512, 76.3289269 ], # random [ -91.59132005, -14.3629884 , -93.91933182], [ 25.23835501, 45.02035145, -121.67867086], [ -51.51414184, -15.29022692, -172.46870023], [ -81.63376847, -27.39521579, 2.60408416]])