にこの状況を実装:は、これら2つのアレイを考えるnumpyの
E = [[16.461, 17.015, 14.676],
[15.775, 18.188, 14.459],
[14.489, 18.449, 14.756],
[14.171, 19.699, 14.406],
[14.933, 20.644, 13.839],
[16.233, 20.352, 13.555],
[16.984, 21.297, 12.994],
[16.683, 19.056, 13.875],
[17.918, 18.439, 13.718],
[17.734, 17.239, 14.207]]
S = [[0.213, 0.660, 1.287],
[0.250, 2.016, 1.509],
[0.016, 2.995, 0.619],
[0.142, 4.189, 1.194],
[0.451, 4.493, 2.459],
[0.681, 3.485, 3.329],
[0.990, 3.787, 4.592],
[0.579, 2.170, 2.844],
[0.747, 0.934, 3.454],
[0.520, 0.074, 2.491]]
の問題は、私は、次の式を使用して、SとEとの間の3×3共分散行列(C)を得るべきであると述べている:
C = (1/(n-1))[S'E - (1/10)S'i i'E]
ここでnは10であり、iは1だけからなるnx 1の列ベクトルである。 S 'およびi'はそれぞれ行列Sおよび列ベクトルiの転置行列である。
これまでのところ、私はi(とi ')とその式の実装の意味を理解していないので、Cを得ることができません。これまでnumpyを使用していました。
import numpy as np
tS = numpy.array(S).T
C = (1.0/9.0)*(np.dot(tS, E)-((1.0/10.0)*np.dot(tS, E))) #Here is where I lack the i and i' implementation.
私は式を理解して実装することに本当に感謝しています。出力は次のようになります。
C= [[0.2782, 0.2139, -0.1601],
[-1.4028, 1.9619, -0.2744],
[1.0443, 0.9712, -0.6610]]
ねえ!ありがとう。 =) –