Кванстрат с блестящей
Я загрузил веб-приложение, используя Quantstrat, чтобы блестяще с моего сервера. Однако, когда я публикую на shinyapps.io, это не работает. Кто-нибудь опубликовал / есть код, который мог бы помочь мне здесь? заранее спасибо
Это то, что происходит, когда я запускаю его со своего компьютера. Работает отлично.
Когда я публикую статью на shinyapps.io, это то, что происходит.
Я не уверен, что я делаю здесь неправильно. Я выложу код для тех из вас, кто заинтересован в помощи.
library(shiny)
library(devtools)
library(quantmod)
library(quantstrat)
library(TTR)
library(png)
library(dplyr)
ui <- fluidPage(
# Application title
titlePanel("Old Faithful Geyser Data"),
# Sidebar with a slider input for number of bins
sidebarLayout(
sidebarPanel(
sliderInput("bins",
"Number of bins:",
min = 1,
max = 50,
value = 30),
selectInput("sto", "choose the stock", choices = c("AAPL", "CAT"))
),
# Show a plot of the generated distribution
mainPanel(
plotOutput("plot")
)
)
)
server <- function(input, output) {
Sys.setenv(TZ = "UTC")
currency("USD")
#variables
init_date = "2010-01-01"
start_date = "2010-02-01"
end_date = Sys.Date()
tradesize = 10000
init_equity = 1000000
#chose the symbol
A = getSymbols("AMZN", from = start_date, to = end_date, index.class =
"POSIXct", adjust = F, auto.assign = F)
plot(Cl(A))
stock("A", currency = "USD", multiplier = 1)
portfolio.st = account.st = strategy.st = "jwrong.first"
rm.strat(portfolio.st)
rm.strat(account.st)
initPortf(name = portfolio.st, symbols = "A", initDate = init_date)
initAcct(name = account.st, portfolios = portfolio.st, initDate = init_date,
initEq = init_equity)
initOrders(portfolio = portfolio.st, symbols = "A", initDate = init_date)
strategy(name = strategy.st, store = T)
add.indicator(strategy = strategy.st,
name = "EMA",
arguments = list(x = quote(Cl(mktdata)),
n = 100),
label = "nFast")
add.indicator(strategy = strategy.st,
name = "EMA",
arguments = list(x = quote(Cl(mktdata)),
n = 200),
label = "nSlow")
add.signal(strategy = strategy.st,
name = "sigCrossover",
arguments = list(columns = c("nFast", "nSlow"),
relationship = "gt"),
label = "long")
add.signal(strategy = strategy.st,
name = "sigCrossover",
arguments = list(columns = c("nFast", "nSlow"),
relationship = "lt"),
label = "short")
add.rule(strategy = strategy.st,
name = "ruleSignal",
arguments = list(sigcol = "long",
sigval = T,
orderside = "long",
ordertype = "stoplimit",
orderqty = 100,
threshold = .000,
prefer = "High",
TxnFees = -10,
replace = F),
type = "enter",
label = "EnterLong")
add.rule(strategy = strategy.st,
name = "ruleSignal",
arguments = list(sigcol = "short",
sigval = T,
orderside = "short",
ordertype = "stoplimit",
orderqty = -100,
threshold = -.00,
prefer = "Low",
TxnFees = -10,
replace = F
),
type = "enter",
label = "EnterShort")
add.rule(strategy.st,
name = "ruleSignal",
arguments = list(sigcol = "short",
sigval = T,
orderside = "long",
ordertype = "market",
orderqty = "all",
TxnFees = -10,
replace = T),
type = "exit",
label = "Exit2Short")
add.rule(strategy.st,
name = "ruleSignal",
arguments = list(sigcol = "long",
sigval = T,
orderside = "short",
ordertype = "market",
orderqty = "all",
TxnFees = -5,
replace = T
),
type = "exit",
label = "Exit2Long")
results = applyStrategy(strategy.st,portfolios = portfolio.st)
updatePortf(portfolio.st)
updateAcct(account.st)
updateEndEq(account.st)
output$plot = renderPlot({
chart.Posn(portfolio.st, Symbol = "A",
TA = "add_EMA(n = 100, col = 3); add_EMA(n = 200, col = 4)")
})
}
# Run the application
shinyApp(ui = ui, server = server)