Двойной скользящий средний кроссовер ежемесячно

Я строю простую торговую стратегию, используя пересечение двойных скользящих средних ежемесячно. Я использую простую 2-месячную MA и 10-месячную MA. Если 2Ma пересекает 10Ma, то покупайте, если оно опускается ниже, а затем продавайте. Проблема в том, что моя кривая справедливости не верна. Чтобы получить месячные скользящие средние, я перевел дневные цены в месячные. Кажется, это хорошо работает при вычислении скользящих средних, но когда я применил сигналы к своим ценам в среде тестирования на истории, похоже, что он рассматривает дневные данные, поэтому сигналы не совпадают с датами.

Я получил это предупреждение:

> data$weight[] = ifelse(as.integer(SMA_2>SMA_10)==1,1,0)  #If price of SPY is above the SMA then buy
Warning message:
 In NextMethod(.Generic) :
 number of items to replace is not a multiple of replacement length

А потом:

> models$dmac2_10 = bt.run.share(data, trade.summary=T)
Error in which(tstart[, i]) : argument to 'which' is not logical
Called from: which(tstart[, i])
Browse[1]>

Вот код:

### Simple Dual Moving Average Crossover

#Load the required packages
load.packages('quantmod')
require(RCurl)
sit = getURLContent('https://github.com/systematicinvestor/SIT/raw/master/sit.gz', binary=TRUE, followlocation = TRUE, ssl.verifypeer = FALSE)
con = gzcon(rawConnection(sit, 'rb'))
source(con)
close(con)
data <- new.env()

# Load historical data and adjusts for splits and dividends
tickers = spl('^GSPC')
getSymbols(tickers, src = 'yahoo', from = '2000-01-01', env = data, auto.assign = T)
for(i in ls(data)) data[[i]] = adjustOHLC(data[[i]], use.Adjusted=T) 


#Sets backtesting environment and convert to monthly prices
bt.prep(data, align='remove.na', fill.gaps = T) 
prices = data$prices  
prices = prices[ endpoints(prices, on="months", k=1), ]


#Create a empty list for attaching the models to at a later stage
models = list()


#Calculate the moving averages- not considered: lag them one day to prevent lookback bias
SMA_2 <- SMA(prices,2)
SMA_10 <- SMA(prices,10)  


#Specify the weights to be used in the backtest
data$weight[] = NA #Zero out any weights from previous
data$weight[] = ifelse(as.integer(SMA_2>SMA_10)==1,1,0)  #If price of 2SMA is above the 10SMA then buy

#Call the function to run the backtest given the data, which contains the prices and weights.
#models$dmac2_10 = bt.run.share(data, trade.summary=T)
models$dmac2_10 = bt.run.share(data, clean.signal=T)


#Plot equity curve 
plot(models$dmac2_10$equity, main="Equity Curve")

Не уверен, что делаю что-то не так, но буду признателен за вашу помощь.

Спасибо марья

0 ответов

Другие вопросы по тегам