在SVD分解中,SAS / IML和R的结果不同

时间:2015-07-07 12:24:54

标签: r sas translate svd sas-iml

很快,我正在将一个R包翻译成IML语言,我完全在努力解决R和IML之间的SVD分解结果。

R代码:

s <- svd(MAT) 
s$v

SAS / IML代码:

call svd (U, D, V, MAT);
print V;

V在两侧包含来自SVD分解的右奇异向量的矩阵,但是在这里,请看一下R的这些结果:

             [,1]         [,2]         [,3]        [,4]        [,5]         [,6]         [,7]
[1,] -2.625059e-02  0.029572211 -0.006491235 0.015622547  0.01553215 -0.003882378  0.007250290
[2,] -4.762146e-06 -0.030403155 -0.016635218 0.024949110 -0.01238686  0.001334805  0.041902431
[3,] -8.460010e-02  0.025365547  0.006657322 0.020129575 -0.02312842  0.038366880  0.054249177
[4,] -1.368302e-02  0.029621706  0.005462163 0.017887163  0.02605000 -0.002546119 -0.001913554
[5,] -3.326751e-02  0.003552646  0.003634580 0.065277891 -0.01218518 -0.026305833  0.029209961
[6,] -1.451836e-02  0.089992653 -0.012355758 0.009777273 -0.07790069 -0.044679172 -0.028174261

这些来自SAS / IML:

            COL1      COL2      COL3      COL4      COL5      COL6      COL7      COL8      COL9

 ROW1   0.0262506 -0.029572 -0.006491 0.0156225 0.0155322 -0.003882  -0.00725  0.040721 -0.000566
 ROW2   4.7621E-6 0.0304032 -0.016635 0.0249491 -0.012387 0.0013348 -0.041902 0.0225321 0.0070566
 ROW3   0.0846001 -0.025366 0.0066573 0.0201296 -0.023128 0.0383669 -0.054249 0.0305745 -0.041534
 ROW4    0.013683 -0.029622 0.0054622 0.0178872   0.02605 -0.002546 0.0019136 0.0168932 0.0229999
 ROW5   0.0332675 -0.003553 0.0036346 0.0652779 -0.012185 -0.026306  -0.02921 -0.029533 0.0145009
 ROW6   0.0145184 -0.089993 -0.012356 0.0097773 -0.077901 -0.044679 0.0281743 -0.025475 -0.036881
 ROW7   -0.012385 0.0295035 0.0051056   -0.0007 0.0025335 -0.009391 -0.045927 -0.054661 -0.029963

这些数值与您所看到的相同,但它们的符号有时相同,有时也不同。我找不到任何理由为什么会这样,这让我疯狂。 有人可以给我一个解决方案,或至少一个提示或任何东西。 任何帮助将不胜感激,如果它不能解决这个问题。

非常感谢。

编辑:显而易见,发布的结果只是总矩阵的一部分。

1 个答案:

答案 0 :(得分:2)

简而言之,SVD分解并不是唯一的。

M的奇异向量是M`M的特征向量。特征向量不是唯一的。即使矩阵是满秩,特征向量也仅定义为符号:如果v是特征值lambda的矩阵A的特征向量,那么-v也是如此 A *( - v)= - (Av)= - (lambda v)= lambda(-v)。

不同的SVD(和特征值)算法可能导致不同的分解。只要M = UDV`,分解就是有效的。奇异值的D矩阵在软件包中基本相同,但U和V矩阵可能不同。

顺便提一下,如果您的矩阵不是满级,那么即使是&#34;唯一性也要签署&#34;打破了。 https://github.com/mitchellh/vagrant/issues/5260#issuecomment-72576686有两个非常不同的SVD的例子,用于相同的秩缺陷矩阵。