Simple MACD strategy
MACD may be used in many ways, this will demonstrate a trend indicator.
traditionally, when the MACD signal crosses zero, this indicated a establishment of a positive trend
we’ll buy on positive treshold crossover of the ‘signal’ column, and sell on negative threshold crossover
add rules
entry
add.rule(strat.st,name=‘ruleSignal’, arguments = list(sigcol=“signal.gt.zero”, sigval=TRUE, orderqty=100, ordertype=‘market’, orderside=‘long’, threshold=NULL), type=‘enter’, label=‘enter’, storefun=FALSE )
#alternatives for risk stops: # simple stoplimit order, with threshold multiplier #add.rule(strat.st,name=‘ruleSignal’, arguments = list(sigcol=“signal.gt.zero”,sigval=TRUE, orderqty=‘all’, ordertype=‘stoplimit’, orderside=‘long’, threshold=-.05,tmult=TRUE, orderset=‘exit2’),type=‘chain’, parent=‘enter’, label=‘risk’,storefun=FALSE) # alternately, use a trailing order, also with a threshold multiplier #add.rule(strat.st,name=‘ruleSignal’, arguments = list(sigcol=“signal.gt.zero”,sigval=TRUE, orderqty=‘all’, ordertype=‘stoptrailing’, orderside=‘long’, threshold=-1,tmult=FALSE, orderset=‘exit2’), type=‘chain’, parent=‘enter’, label=‘trailingexit’)
exit
add.rule(strat.st,name=‘ruleSignal’, arguments = list(sigcol=“signal.lt.zero”, sigval=TRUE, orderqty=‘all’, ordertype=‘market’, orderside=‘long’, threshold=NULL, orderset=‘exit2’), type=‘exit’, label=‘exit’ )
#end rules ####
getSymbols(stock.str,from=startDate, to=‘2014-06-01’, src=‘yahoo’) start_t<-Sys.time() out<-applyStrategy(strat.st , portfolios=portfolio.st,parameters=list(nFast=fastMA, nSlow=slowMA, nSig=signalMA,maType=maType),verbose=TRUE) end_t<-Sys.time() print(end_t-start_t)
start_t<-Sys.time() updatePortf(Portfolio=portfolio.st,Dates=paste(‘::’,as.Date(Sys.time()),sep=’’)) end_t<-Sys.time() print(“trade blotter portfolio update:”) print(end_t-start_t)
chart.Posn(Portfolio=portfolio.st,Symbol=stock.str) plot(add_MACD(fast=fastMA, slow=slowMA, signal=signalMA,maType=“EMA”))
#look at the order book obook<-getOrderBook(‘macd’)
set tz as it was before the demo
Sys.setenv(TZ=oldtz)