2

我正在用 R 对交易策略进行回测。目前这是我的代码。- MergedSet$FXCloseRate 包含某个货币对的收盘价 - MergedSet$RiskMA 是某个风险指数的移动平均线 - 其余部分应该很清楚 目前这个公式在超过 11,000 个条目时并不是很快。为什么?数据帧是否太慢?我在哪里可以优化?

############
# STRATEGY #
############
#Null out trades and position
MergedSet$Trade <- 0
MergedSet$Position<-0
MergedSet$DailyReturn<-0
MergedSet$CumulativeReturn<-0
MergedSet$Investment<-0
MergedSet$CumulativeReturn[1:MAPeriod] <- 1
MergedSet$Investment[1:MAPeriod] <- InitialInvestment


#Strategy
n<-nrow(MergedSet)
for(i in seq(MAPeriod+1,n)){
  #Updating the position
  if(MergedSet$RiskMA[i] <= ParamDwn && MergedSet$RiskMA[i-1] > ParamDwn){
    #sell signal, so short if no or long position active otherwise do nothing
    if(MergedSet$Position[i-1] == 0 || MergedSet$Position[i-1] == 1){
      MergedSet$Position[i] = -1
      MergedSet$Trade[i] = 1
    }
  } else if(MergedSet$RiskMA[i] >= ParamUp && MergedSet$RiskMA[i-1] < ParamUp){
    #buy signal, go long if no or short position active, otherwise do nothing
    if(MergedSet$Position[i-1] == 0 || MergedSet$Position[i-1] == -1){
      MergedSet$Position[i] = 1
      MergedSet$Trade[i] = 1
    }
  } else {
    MergedSet$Position[i] = MergedSet$Position[i-1]
  }

  #Return calculation
  if(MergedSet$Position[i] == 1){
    #long
    MergedSet$DailyReturn[i] = MergedSet$FXCloseRate[i]/MergedSet$FXCloseRate[i-1]-1
  } else if(MergedSet$Position[i] == -1){
    #short
    MergedSet$DailyReturn[i] = MergedSet$FXCloseRate[i-1]/MergedSet$FXCloseRate[i]-1
  }
}
4

0 回答 0