Description of A simple Trading Strategy
The simple strategy follows that given a list of stocks, we want download is’s associated data in terms of open and closing prices from an API such as Yahoo Finance. Afterwards we would want to find those stocks has closed at 70 day high (i.e. the last closing price to be the #highest over the past 70 days), and over this period the 50-day MA always #stays above the 100-day MA.
start<-as.Date("2010-01-10")
end<-Sys.Date()
simple_strategy= function(start_date,end_date,tickers){
library(tidyquant)
library(zoo)
library(furrr)
library(tidyverse)
start<-as.Date(start_date)
end <-as.Date(end_date)
p <- tidyquant::tq_get(tickers , get = "stock.prices", from = start,
to =end)
p= na.omit(p)
#p <-quantmod:: getSymbols("AMZ", from = start,
# to = end, warnings = FALSE, src = 'yahoo',
# auto.assign = TRUE)
#p= get(p)
#p=na.approx(p)
prices <- p %>%
tidyquant::tq_mutate(select = close, mutate_fun = SMA, n = 100) %>%
dplyr::rename(SMA100 = SMA) %>%
tidyquant::tq_mutate(select = close, mutate_fun = SMA, n = 50) %>%
dplyr::rename(SMA50 = SMA)
prices<-
prices%>% dplyr::mutate(rolling70= c(rep(NA,69),rollmax(close, 70)))
df=
prices %>% dplyr::filter(close==rolling70)%>%
dplyr::filter(SMA50>SMA100)
return(df)
}
# for a single stock ,we can run the strategy function below which returns a dataframe which meets the strategy conditions
tickers <- c("GOOGL")
re=simple_strategy(start,end,tickers)
#For multiple stocks we can take advantage of functional programming where we can repeat the function for many stock indicators using a parallel version of the map function of the purrr package. The parallel version of the purrr package is the furrr package.
ticker= c("FB", "AAPL", "MSFT","GOOGL","TSLA","AMZ")
result =furrr::future_map_dfr(ticker,
function(x) simple_strategy(start_date=start,
end_date=end,
tickers=x))
#Equivalently, uisng a for loop
#result= list()
#for( i in 1:length(ticker)){
#result[[i]] = simple_strategy(start,end,ticker[i])
#}
result %>% head()%>%
kable(escape = F, align = "c") %>%
kable_styling(c("striped", "condensed"), full_width = F)
symbol
|
date
|
open
|
high
|
low
|
close
|
volume
|
adjusted
|
SMA100
|
SMA50
|
rolling70
|
FB
|
2012-12-13
|
27.59
|
28.75
|
27.43
|
28.24
|
81051600
|
28.24
|
21.9831
|
22.7988
|
28.24
|
FB
|
2013-01-04
|
28.01
|
28.93
|
27.83
|
28.76
|
72715400
|
28.76
|
22.4882
|
24.7086
|
28.76
|
FB
|
2013-01-07
|
28.69
|
29.79
|
28.65
|
29.42
|
83781800
|
29.42
|
22.5643
|
24.9106
|
29.42
|
FB
|
2013-01-09
|
29.67
|
30.60
|
29.49
|
30.59
|
104787700
|
30.59
|
22.7410
|
25.2490
|
30.59
|
FB
|
2013-01-10
|
30.60
|
31.45
|
30.28
|
31.30
|
95316400
|
31.30
|
22.8420
|
25.4238
|
31.30
|
FB
|
2013-01-11
|
31.28
|
31.96
|
31.10
|
31.72
|
89598000
|
31.72
|
22.9605
|
25.6194
|
31.72
|
library(viridis)
library(scales)
#start <- end - weeks(24)
start<-as.Date("2010-01-10")
end<-Sys.Date()
ticker= c("FB", "AAPL", "MSFT","GOOGL")
p1 <- tidyquant::tq_get(ticker,
get = "stock.prices",
from = start,
to =end) %>%
#filter(date >= start - days(2 * 20)) %>%
ggplot(aes(x = date, y = close,
open = open, high = high, low = low, close = close,
group = symbol)) +
geom_barchart( colour_up = "#FDE725FF",
colour_down = "#440154FF",
fill_up = "#FDE725FF",
fill_down = "#440154FF") +
geom_bbands(ma_fun = SMA, sd = 2, n = 50, linetype = 5,color_ma = "#55C667FF") +
labs(title = "50 Day Simple Moving Average of Several Stocks ",
subtitle = "BBands with SMA Applied",
y = "Closing Price", x = "") +
coord_x_date(xlim = c(start, end)) +
facet_wrap(~ symbol, ncol = 2, scales = "free_y") +
#scale_color_viridis_d(option="D") +
scale_x_date(labels = date_format("%d-%m-%Y"),date_breaks = "2 year") +
theme(axis.text.x=element_text(angle=45, hjust=1)) +
labs(caption = "www.restsanalytics.com")
p1

#(gg <- ggplotly(p1, tooltip = "symbol"))
#gg=highlight(gg, "plotly_hover")
#htmlwidgets::saveWidget(as_widget(gg), "p1.html")
#gg
ticker= c("FB", "AAPL", "MSFT","GOOGL")
p2 <- tidyquant::tq_get(ticker,
get = "stock.prices",
from = start,
to =end) %>%
#filter(date >= start - days(2 * 20)) %>%
ggplot(aes(x = date, y = close,
open = open, high = high, low = low, close = close,
group = symbol)) +
geom_barchart( colour_up = "#FDE725FF",
colour_down = "#440154FF",
fill_up = "#FDE725FF",
fill_down = "#440154FF") +
geom_bbands(ma_fun = SMA, sd = 2, n = 100, linetype = 5,color_ma = "#55C667FF") +
labs(title = "100 Day Simple Moving Average of Several Stocks ",
subtitle = "BBands with SMA Applied",
y = "Closing Price", x = "") +
coord_x_date(xlim = c(start, end)) +
facet_wrap(~ symbol, ncol = 2, scales = "free_y") +
#scale_color_viridis_d(option="D") +
scale_x_date(labels = date_format("%d-%m-%Y"),date_breaks = "2 year") +
theme(axis.text.x=element_text(angle=45, hjust=1)) +
labs(caption = "www.restsanalytics.com")
#gg <- ggplotly(p2, tooltip = "symbol")
#gg=highlight(gg, "plotly_hover")
#htmlwidgets::saveWidget(as_widget(gg), "p2.html")
p2

---
title: Simple Trading Strategy
subtitle: 
output:
  html_document:
    keep_md: true
    toc_float: true
    #theme: flatly
    toc: true # table of content true
    toc_depth: 3  # upto three depths of headings (specified by #, ## and ###)
    number_sections: true  ## if you want number sections at each table header
    theme: united  # many options for theme, this one is my favorite.
    code_download: true
author: Nana Boateng
Time: '`r Sys.time()`'
date: "`r format(Sys.time(), '%B %d, %Y')`"
params:
  series: '2'
tags: Trading strategy,Stocks, Quantitative Finance, Asset Return, tidyquant,quantmod 
  
---



```{r setup, include=FALSE}
knitr::opts_chunk$set(
                  echo       = TRUE,
                  eval       = TRUE,
                  warning    = FALSE,
                  message    = FALSE,
                  dpi        = 300,
                  fig.align  = "center")
```



```{r}
library(ggplot2)
library(plotly)
library(rvest)
library(pbapply)
library(TTR)
library(dygraphs)
library(lubridate)
library(tidyquant)
library(timetk)
library(htmlwidgets)
library(kableExtra)
options(dplyr.print_max = 1e9)
pacman::p_load(dygraphs,DT,tidyverse,janitor,ggthemes,scales,ggpubr,viridis)

theme_set(theme_pubclean())

```











#### Description of  A simple Trading Strategy

The simple strategy follows that given a list of stocks, we want download is's associated data in terms of open and closing prices from an API such as Yahoo Finance. Afterwards we would want to find those stocks  has closed at 70 day high (i.e. the last closing price to be the #highest over the past 70 days), and over this period the 50-day MA always #stays above the 100-day MA.




```{r}

start<-as.Date("2010-01-10")
end<-Sys.Date()




simple_strategy= function(start_date,end_date,tickers){

library(tidyquant) 
library(zoo)  
library(furrr) 
library(tidyverse)  
  


start<-as.Date(start_date)
end <-as.Date(end_date)

p  <- tidyquant::tq_get(tickers , get = "stock.prices", from = start,
           to =end)


p= na.omit(p)
#p <-quantmod:: getSymbols("AMZ", from = start,
#            to = end, warnings = FALSE, src = 'yahoo',
#           auto.assign = TRUE)
#p= get(p)

#p=na.approx(p)



prices <-  p %>%
    tidyquant::tq_mutate(select = close, mutate_fun = SMA, n = 100) %>%
    dplyr::rename(SMA100 = SMA) %>%
    tidyquant::tq_mutate(select = close, mutate_fun = SMA, n = 50) %>%
    dplyr::rename(SMA50 = SMA)


prices<-
   prices%>% dplyr::mutate(rolling70= c(rep(NA,69),rollmax(close, 70)))


df=
prices %>% dplyr::filter(close==rolling70)%>%
      dplyr::filter(SMA50>SMA100)

 
 return(df) 
  
}





# for a single stock ,we can run the strategy function below which returns a dataframe which meets the strategy conditions
tickers <- c("GOOGL")
re=simple_strategy(start,end,tickers)




#For multiple  stocks we can take advantage of functional programming where we can repeat the function for many stock indicators using a parallel version of the map function of the purrr package. The parallel version of the purrr package is the furrr package.
ticker= c("FB", "AAPL", "MSFT","GOOGL","TSLA","AMZ")

result =furrr::future_map_dfr(ticker,
                      function(x) simple_strategy(start_date=start,
                                      end_date=end,
                                      tickers=x))


#Equivalently, uisng a for loop
#result= list()
#for( i in 1:length(ticker)){
#result[[i]]  = simple_strategy(start,end,ticker[i])
#}



result %>%  head()%>%
  kable(escape = F, align = "c") %>%
  kable_styling(c("striped", "condensed"), full_width = F)
  

```




```{r}
library(viridis)
library(scales)

#start <- end - weeks(24)


start<-as.Date("2010-01-10")
end<-Sys.Date()


ticker= c("FB", "AAPL", "MSFT","GOOGL")

 p1 <- tidyquant::tq_get(ticker, 
                        get = "stock.prices", 
                        from = start,
                         to =end) %>%
    #filter(date >= start - days(2 * 20)) %>%
    ggplot(aes(x = date, y = close, 
               open = open, high = high, low = low, close = close, 
               group = symbol)) +
    geom_barchart( colour_up = "#FDE725FF",
  colour_down = "#440154FF",
  fill_up = "#FDE725FF",
  fill_down = "#440154FF") +
    geom_bbands(ma_fun = SMA, sd = 2, n = 50, linetype = 5,color_ma = "#55C667FF") +
    labs(title = "50 Day Simple Moving Average of Several Stocks ", 
         subtitle = "BBands with SMA Applied", 
         y = "Closing Price", x = "") + 
   
    coord_x_date(xlim = c(start, end)) +
    facet_wrap(~ symbol, ncol = 2, scales = "free_y") +
  
    #scale_color_viridis_d(option="D") +
  
  scale_x_date(labels = date_format("%d-%m-%Y"),date_breaks = "2 year") +
  theme(axis.text.x=element_text(angle=45, hjust=1)) +
   labs(caption = "www.restsanalytics.com")

    
p1
#(gg <- ggplotly(p1, tooltip = "symbol"))
#gg=highlight(gg, "plotly_hover")
#htmlwidgets::saveWidget(as_widget(gg), "p1.html")
#gg

```




```{r}


ticker= c("FB", "AAPL", "MSFT","GOOGL")

p2 <-  tidyquant::tq_get(ticker, 
                        get = "stock.prices", 
                        from = start,
                         to =end) %>%
    #filter(date >= start - days(2 * 20)) %>%
    ggplot(aes(x = date, y = close, 
               open = open, high = high, low = low, close = close, 
               group = symbol)) +
    geom_barchart( colour_up = "#FDE725FF",
  colour_down = "#440154FF",
  fill_up = "#FDE725FF",
  fill_down = "#440154FF") +
    geom_bbands(ma_fun = SMA, sd = 2, n = 100, linetype = 5,color_ma = "#55C667FF") +
    labs(title = "100 Day Simple Moving Average of Several Stocks ", 
         subtitle = "BBands with SMA Applied", 
         y = "Closing Price", x = "") + 
   
    coord_x_date(xlim = c(start, end)) +
    facet_wrap(~ symbol, ncol = 2, scales = "free_y") +
  
    #scale_color_viridis_d(option="D") +
  
  scale_x_date(labels = date_format("%d-%m-%Y"),date_breaks = "2 year") +
  theme(axis.text.x=element_text(angle=45, hjust=1)) +
   labs(caption = "www.restsanalytics.com")

#gg <- ggplotly(p2, tooltip = "symbol")

#gg=highlight(gg, "plotly_hover")

#htmlwidgets::saveWidget(as_widget(gg), "p2.html")

p2
   
   
```

