From 7bcea6aa44780574460391040f83711226524383 Mon Sep 17 00:00:00 2001 From: Jasen Mackie Date: Sat, 7 Mar 2020 20:56:15 +0000 Subject: [PATCH] Update stoptrailing order price logic, update test assertion See #116 --- R/ruleOrderProc.R | 75 +++++++++---------- .../testthat/test_demo_maCross_stoptrailing.R | 2 +- 2 files changed, 35 insertions(+), 42 deletions(-) diff --git a/R/ruleOrderProc.R b/R/ruleOrderProc.R index 358bdc1..50b9d1f 100644 --- a/R/ruleOrderProc.R +++ b/R/ruleOrderProc.R @@ -354,52 +354,45 @@ ruleOrderProc <- function(portfolio, symbol, mktdata, timestamp=NULL, ordertype= if(order.side == 'long' && as.numeric(Lo(mktdataTimestamp)[,1]) < orderPrice || order.side == 'short' && as.numeric(Hi(mktdataTimestamp)[,1]) > orderPrice) { - txnprice <- ifelse(orderPrice %in% c(Lo(mktdataTimestamp)[,1],Hi(mktdataTimestamp)[,1]), orderPrice, Op(mktdataTimestamp)[,1]) + if (order.side == 'long') { + txnprice <- ifelse(orderPrice < Op(mktdataTimestamp)[,1], orderPrice, Op(mktdataTimestamp)[,1]) # assume we can unwind long position at the open price if open price < order price + } else if (order.side == 'short') { + txnprice <- ifelse(orderPrice > Op(mktdataTimestamp)[,1], orderPrice, Op(mktdataTimestamp)[,1]) # assume we can unwind short position at the open price if open price > order price + } ordersubset[ii,"Order.Price"] <- txnprice txntime <- timestamp - } - else - { - # do we need to change the trailing stop? - - order.threshold <- as.numeric(ordersubset[ii, "Order.Threshold"]) - - if(order.side == 'long') - new.order.price <- max(orderPrice, as.numeric(Hi(mktdataTimestamp)[,1]) + order.threshold) - if(order.side == 'short') - new.order.price <- min(orderPrice, as.numeric(Lo(mktdataTimestamp)[,1]) + order.threshold) - - if(new.order.price != orderPrice) - { - # adjust trailing stop + } else { # do we need to change the trailing stop? + order.threshold <- as.numeric(ordersubset[ii, "Order.Threshold"]) - order.qty <- ordersubset[ii, "Order.Qty"] # if orderQty='all' we must recover it - - neworder<-addOrder(portfolio=portfolio, - symbol=symbol, - timestamp=timestamp, - qty=order.qty, - price=new.order.price - order.threshold, - ordertype=orderType, - side=order.side, - threshold=order.threshold, - status="open", - replace=FALSE, return=TRUE, - orderset=ordersubset[ii,"Order.Set"], - label=ordersubset[ii,"Rule"], - ...=..., TxnFees=txnfees) - - ordersubset<-rbind(ordersubset, neworder) - - ordersubset[ii,"Order.Status"]<-'replaced' - ordersubset[ii,"Order.StatusTime"]<-format(timestamp, "%Y-%m-%d %H:%M:%S") - - next() + if(order.side == 'long') + new.order.price <- max(orderPrice, as.numeric(Hi(mktdataTimestamp)[,1]) + order.threshold) + if(order.side == 'short') + new.order.price <- min(orderPrice, as.numeric(Lo(mktdataTimestamp)[,1]) + order.threshold) + if(new.order.price != orderPrice) { # adjust trailing stop + order.qty <- ordersubset[ii, "Order.Qty"] # if orderQty='all' we must recover it + neworder<-addOrder(portfolio=portfolio, + symbol=symbol, + timestamp=timestamp, + qty=order.qty, + price=new.order.price - order.threshold, + ordertype=orderType, + side=order.side, + threshold=order.threshold, + status="open", + replace=FALSE, return=TRUE, + orderset=ordersubset[ii,"Order.Set"], + label=ordersubset[ii,"Rule"], + ...=..., TxnFees=txnfees) + ordersubset<-rbind(ordersubset, neworder) + + ordersubset[ii,"Order.Status"]<-'replaced' + ordersubset[ii,"Order.StatusTime"]<-format(timestamp, "%Y-%m-%d %H:%M:%S") + + next() + } } } - } - - } # end stoptrailing + }# end stoptrailing ) if(!is.null(txnprice) && !isTRUE(is.na(txnprice))) diff --git a/tests/testthat/test_demo_maCross_stoptrailing.R b/tests/testthat/test_demo_maCross_stoptrailing.R index 3104eb0..1c496a9 100644 --- a/tests/testthat/test_demo_maCross_stoptrailing.R +++ b/tests/testthat/test_demo_maCross_stoptrailing.R @@ -10,7 +10,7 @@ devAskNewPage(ask = FALSE) # dont prompt for new page, mainly for R CMD check source(paste0(path.package("quantstrat"),"/demo/maCross_stoptrailing.R")) # source demo test_that("End.Equity equals 7809", { - expect_equal(round(tradeStats('Port.Luxor','AAPL')$End.Equity), 7809) + expect_equal(round(tradeStats('Port.Luxor','AAPL')$End.Equity), 2771) }) test_that("num txns equals 11", { # note we pad the start with zeros