いくつかの資産のローリングウィンドウ(1日シフト)の共分散行列を計算しようとしています。
私のdfが次のようになっているとしましょう:
df <- data.frame(x = c(1.5,2.3,4.7,3,8.4), y =c(5.3,2.4,8.4,1.3,2.5),z=c(2.5,1.3,6.5,4.3,2.8),u=c(1.1,2.5,4.3,2.5,6.3))
出力は次のようになると思います:
cov(df[1:3,]) :
x y z u
x 2.773333 3.666667 4.053333 2.613333
y 3.666667 9.003333 7.846667 2.776667
z 4.053333 7.846667 7.413333 3.413333
u 2.613333 2.776667 3.413333 2.573333
cov(df[2:4,]) :
x y z u
x 1.523333 4.283333 3.053333 1.23
y 4.283333 14.603333 7.253333 3.93
z 3.053333 7.253333 6.813333 2.22
u 1.230000 3.930000 2.220000 1.08
cov(df[3:5,]) :
x y z u
x 7.6233333 -0.5466667 -3.008333 5.1633333
y -0.5466667 14.4433333 5.941667 0.9233333
z -3.0083333 5.9416667 3.463333 -1.5233333
u 5.1633333 0.9233333 -1.523333 3.6133333
しかし、データセットに多くの行があるため、すべてがループで作成されます...
for
ローリングウィンドウを1日シフトして、ローリングベースで共分散行列を計算する場合、可能なループはどのようになりますか?または、apply
家族の機能を使用する必要がありますか?上記のループの時系列オブジェクトを作成する場合、どの時系列クラスが望ましいでしょうか?今はパッケージ
as.timeSeries
から使用しています。fPortfolio
私は単にそれを得ることができません...
よろしくお願いします