【问题标题】:Rotate covariance matrix旋转协方差矩阵
【发布时间】:2019-03-26 03:11:48
【问题描述】:

我正在生成 3D 高斯点云。我正在使用 scipy.stats.multivariate.normal() 函数,它以平均值和协方差矩阵作为参数。然后它可以使用 rvs() 方法提供随机样本。

接下来我想在 3D 中旋转云,而不是旋转每个点,我想旋转随机变量参数,然后重新生成点云。

我真的很难弄清楚这一点。旋转后,方差轴将不再与坐标系对齐。所以我想我想要的是沿三个任意正交轴表达方差。

感谢您的帮助。

最终编辑:谢谢,我得到了我需要的东西。下面是一个例子

cov = np.array([
   [ 3.89801357,  0.38668784,  1.47657614],
   [ 0.38668784,  0.87396495,  1.43575688],
   [ 1.47657614,  1.43575688, 15.09192414]])

rotation_matrix = np.array([
   [ 2.22044605e-16,  0.00000000e+00,  1.00000000e+00],
   [ 0.00000000e+00,  1.00000000e+00,  0.00000000e+00],
   [-1.00000000e+00,  0.00000000e+00,  2.22044605e-16]]) # 90 degrees around y axis

new_cov = rotation_matrix @ cov @ rotation_matrix.T # based on Warren and Paul's comments




rv = scipy.stats.multivariate_normal(mean=mean,cov=new_cov)

如果遇到错误

ValueError: the input matrix must be positive semidefinite

This 我发现有用的页面

【问题讨论】:

  • “所以我想我想要的是表达沿三个任意正交轴的方差。” 所以你已经知道轴,并且你知道你想要的方差每个轴?这是你的意见吗?
  • 是的。我有一个旋转矩阵,所以我可以计算新的 x,y,z 单位向量,我只是不知道如何正确修改协方差矩阵以将其绘制在原始坐标系中
  • 我不完全确定这是否是解决这个问题的最佳网站。这是一个很好的问题,它可能比计算更数学。如果其他人也有类似的想法,Cross Validated 可能是个问问题的好地方,但请等着看其他人先说什么。
  • 如果 Σ 是未旋转的协方差矩阵,R 是旋转矩阵,则旋转后的协方差应该是 RΣR⁻¹。 (David Z 是对的,这个问题在 stats 或 math stackexchange 网站上会更好。)
  • 顺便说一句,您可能知道,但以防万一:逆 R^-1 可以廉价地计算为 R^T。

标签: numpy scipy linear-algebra covariance covariance-matrix


【解决方案1】:

我用答案编辑了问题,但它又是

new_cov = rotation_matrix @ cov @ rotation_matrix.T

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-12-09
    • 1970-01-01
    • 1970-01-01
    • 2020-04-13
    • 2017-02-12
    • 2017-08-27
    • 1970-01-01
    相关资源
    最近更新 更多