What is R?
- We will use R via RStudio in this course to analyse securities risk and returns, and construct and portfolios.
After installing the software, open RStudio
- It should look something like this.

Set the folder RStudio uses when not in a project
From “Preferences” set the default folder to your documents or other convenient folder.
I set mine to my Dropbox folder.
After you have set the folder, quit and reopen RStudio.

Make a “project” for this course
A project is a folder where you can keep data, code and documents together.
You can have several different projects and set R to start up differently for each project. Projects allow you to keep your files organised, and let you customise how R works.
If you use R for other classes, your seminar or other purposes, you can create other projects for those.
Each project will have a separate folder and files to save the data in your environment, your history of code executed in the console, and the way you have R configured.
Make a new project from the Projects menu at the top-right of the screen.

Click “New Directory” for your project

Select “New Project”

Give the project folder a name

Your desktop should look something like this

Set the “Project Options”
- Find the “Project Options” from the project menu at the top-right of your screen.

Set the three options to “Yes”
- This means your data and history of commands will be saved quen you quit and restored when you open your project the next time.

RStudio has four panes

Pane 2 is the console where you can enter and execute code.
Pane 3 contains the environment and history tabs. The environment shows all objects that are loaded for use (it is empty now). The history tab shows the code you have executed in the console.
Pane 4 contains a number of tabs showing your folders and files, plots you have drawn, packages, a help window.
Packages

Packages extend the functionality of R.
Packages contain functions, data and other objects. They are designed to perform certain types of data manipulation, analysis, estimation, visualisation, optimisation, document creation, etc.
Some packages are part of the default R installation, called “Base R,” and there are a huge number of additional packages available that allow you to do almost anything with R.
We will use several packages in this course.
There are two steps to using a package.
Install the package. This downloads the latest verson of the package from an R repository and saves it on your computer.
Load a package for use. When you want to use a package you must load it first with the library command.
To install a package, click the install button, type in the name of the package and hit install.
Install the following packages: AER, dynlm, fGarch, FinCal, kableExtra, MASS, reshape2, stargazer, tidyquant, tidyverse, wesanderson, xtable.
- Note that R is case-sensitive, thus upper- and lower-case letters are interpreted as being different.

- Alternatively, install the packages by running the following code in the console.
install.packages("AER", "dynlm", "fGarch", "FinCal", "kableExtra", "MASS", "reshape2", "stargazer", "tidyquant", "tidyverse", "wesanderson", "xtable", dependencies = TRUE)
Packages need only be installed on your computer once, but they should be updated from time to time.
When you wish to use a package, it must be loaded using the library command. For example, to load the AER package:
library(AER)
- Another way to load a package is to tick the box next to the package in the Packages tab. The packages tab shows you all packages that you have installed.

- If you get an error saying R cannot find a function when you are trying to execute code, it is almost always because you have either a) not loaded the package that contains the function, or b) mistyped the function.
Where are my files?
getwd()
setwd("/Users/Clinton/Dropbox/syncd_r_data/econometrics")
- If you your working directory is a folder on a network drive or on the cloud (like Dropbox or Google Drive) that is synced to your computer’s hard drive, you will be able to use it with RStudio on multiple computers.
Special HIDDEN R files in your working directory
- Here are the hidden files in my working directory shown in red and the project file which holds information about my project in blue.:

Rmarkdown and Notebooks
Rmarkdown allows dynamic documents to be created in R that contain written text, R code and output from the code.
I will ask you to do some assignments in an R Notebook using markdown.
- This guide for setting-up R and RStudio was made in an R Notebook. If you look at the top of the page you can see a button labelled “Code” which alows you to download the code I used to make this HTML file.
A markdown document is written in using coding called markdown, which is an easy-to-write plain text format that is related to TeX (or LaTeX).
A TeX installation is required to use Rmarkdown, such as MacTex (for Mac OS) http://www.tug.org/mactex/ or MiKTeX (cross-platform) https://miktex.org/download. If you use LaTeX to write documents, you will already have this. If not, the easiest way to get a TeX installation for markdown is via the TinyTeX package.
Install TinyTeX using the package called tinytex
- You have already installed the package called tinytex. Executing the code below in the console will download the TinyTeX files from the internet and install them on your computer so that you can make markdown documents.
tinytex::install_tinytex()
This will take some time to download.
Note that you do not need to do this if you use RStudio Cloud as TinyTeX is pre-installed.
When the installation has finished, restart RStudio.
Test your Rmarkdown environment

- The notebook already contains example text and R code that plots a simple chart.

- Run the code by pressing “Run All” from the “Run” menu.

After you have run the code, you should see the plot appear.
Include your name as I have at the top of the Notebook.

- Save the file to your working directory.


- Open the HTML file with your browser. It should look like this:

- Well done! You have created a Notebook.
CRAN Task Views
CRAN Task Views provide information about packages that can be used with R. Packages extend the functionality of R. They provide routines for various types of data manipulation, mathematical and econometric models, optimisation methods, financial models and more. Packages are constantly being developed and updated by R users.
Three Task Views are useful this course:
R-Bloggers
R-Bloggers is a blog site containing many helpful posts on using R: http://www.r-bloggers.com/
The posts on the site show the wide variety of problems that coding in R can be applied to (not just finance). For example:
Search
Lots of information is posted online by R users including questions and answers.
If you are stuck, search for information that will help you answer your question.
rseek is a search engine for R: www.rseek.org
Using another search engine like Google:
RStudio Keyboard Shortcuts (for Mac)
- Code completion:
- Type part of the function you want and then press the Tab key.
- Also works for function arguments, that is press Tab when yo uare inside the brackets of a function.
- Also recalls object names.
- View a list of previous commands:
- Press Control (or Command) and the up arrow.
- View a list of previous commands that match a prefix:
- Type the prefix and press Control (orCommand) and the up arrow.
- Enter a line of code from an R script to the console:
- Enter a line of code from history to and R script:
© Copyright Clinton Watkins 2021
References
Andrecut, M. 2010.
“Portfolio Optimization in R.” Cornell University, arXiv:1307.0450 [q-fin.PM].
https://doi.org/10.1201/b17178.
Bennett, Mark J., and Dirk L. Hugen. 2016.
Financial analytics with R : building a laptop laboratory for data science. Cambridge University Press.
https://op.lib.kobe-u.ac.jp/opac/opac_link/bibid/2002211471.
Cowpertwait, Paul S. P., and Andrew V. Metcalfe. 2009.
Introductory Time Series with R. Springer.
https://doi.org/10.1007/978-0-387-88698-5.
Kleiber, Christian, and Achim Zeileis. 2008.
Applied Econometrics with R. 1st ed. New York: Springer US.
https://doi.org/10.1007/978-0-387-77318-6.
Matloff, Norman. 2011.
The Art of R Programming: A Tour of Statistical Software Design. No Starch Press.
https://www.nostarch.com/artofr.htm.
Tsay, Ruey S. 2010. Analysis of financial time series. Wiley.
———. 2014. Multivariate time series analysis : with R and financial applications. Wiley.
Venables, W. N., D. M. Smith, and R Core Team. 2019.
“An Introduction to R.” https://doi.org/10.1201/9781420035025.ch1.
---
title: "Portfolio Management [ECN347]"
subtitle: "A Guide to Setting-up R and RStudio"
author: <br> Clinton Watkins
output: html_notebook
bibliography: ../../../../../../bibtex/PortfolioManagement.bib
---

<style type="text/css">
h1.title {
  font-size: 24pt;
  color: darkblue;
}

h3.subtitle {
  font-size: 24pt;
  color: darkblue;
}

h2 {
  font-size: 18pt;
}

body, td {
   font-size: 11pt;
}
code.r{
  font-size: 9pt;
}
pre {
  font-size: 9pt
}
</style>

```{r, include=F}
rm(list = ls())
```

<br>

----

## What is R?

<p>

- __R__ is an opensource powerful programming language suited to mathematical and statistical computing, analysis and graphics. 

    - Download R from here: https://www.r-project.org/ 
    
<p>

- __RStudio__ provides a convenient interface for using R. Both R and RStudio are free.

    - Download RStudio (free Desktop Open Source Edition) from here: https://www.rstudio.com/  
    - __RStudio Cloud__ provides R and RStudio via a web browser. You can make a free account but the amount of time you can use the service for free is limited. This may be a good option if you have difficulties setting up the software on your own computer. Remember to copy any files you make from RStudio Cloud to your own computer so that you do not risk losing your work. RStudio Cloud can be found here: https://rstudio.cloud/

<p>

- We will use R via RStudio in this course to analyse securities risk and returns, and construct and portfolios.

<!-- You are welcome to bring your own notebook computer to the lab sessions if you wish. You will been to connect to the internet. -->

----

## After installing the software, open RStudio

<p>

- It should look something like this.

<p>

![](assets/p1.png)

----

### Set the folder RStudio uses when not in a project

<p>

- From "Preferences" set the default folder to your documents or other convenient folder. 

- I set mine to my Dropbox folder.

- After you have set the folder, quit and reopen RStudio.

<p>

![](assets/p2.png)

----

## Make a "project" for this course

<p>

- A project is a folder where you can keep data, code and documents together.

- You can have several different projects and set R to start up differently for each project. Projects allow you to keep your files organised, and let you customise how R works. 

- If you use R for other classes, your seminar or other purposes, you can create other projects for those. 

- Each project will have a separate folder and files to save the data in your environment, your history of code executed in the console, and the way you have R configured.

- Make a new project from the Projects menu at the top-right of the screen.

<p>

![](assets/p3.png)

----

## Click "New Directory" for your project

<p>

![](assets/p4.png)

----

## Select "New Project"

<p>

![](assets/p5.png)

----

## Give the project folder a name

<p>

- I use the name "portfoliomngt".

- Click "Create Project".

<p>

![](assets/p6.png)

----

## Your desktop should look something like this

<p>

![](assets/p7.png)

<!-- <br> -->

<!-- - Use the following code to check that your R session is operating in your project folder. -->

<!-- <p> -->

<!-- ```{r, eval=FALSE} -->
<!-- getwd() -->
<!-- ``` -->

----

## Set the "Project Options"

<p>

- Find the "Project Options" from the project menu at the top-right of your screen.

<p>

![](assets/p8.png)

----

## Set the three options to "Yes"

<p>

- This means your data and history of commands will be saved quen you quit and restored when you open your project the next time.

<p>

![](assets/p9.png)

----

## RStudio has four panes

<p>

![](assets/p10.png)

<p>

- Pane 1 is the source pane where you can open and work on various types of code files or documents. You also display objects in the source pane. 

    - R is an object oriented language which means everything is an object with certain attributes, e.g. a matrix of data or a function that transforms data.
    
    - Objects can interact with each other to change their attributes, or create other objects.
    
    - Some important types of objects are: vectors, lists, arrays, matrices, tables, data frames, functions.

<p>

- Pane 2 is the console where you can enter and execute code.

- Pane 3 contains the environment and history tabs. The environment shows all objects that are loaded for use (it is empty now). The history tab shows the code you have executed in the console. 

- Pane 4 contains a number of tabs showing your folders and files, plots you have drawn, packages, a help window.

----

## Packages

<p>

![](assets/p11.png)

<p>

- Packages extend the functionality of R.

- Packages contain functions, data and other objects. They are designed to perform certain types of data manipulation, analysis, estimation, visualisation, optimisation, document creation, etc. 

- Some packages are part of the default R installation, called "Base R", and there are a huge number of additional packages available that allow you to do almost anything with R.

- We will use several packages in this course.

- There are two steps to using a package.

    1. Install the package. This downloads the latest verson of the package from an R repository and saves it on your computer.

    2. Load a package for use. When you want to use a package you must load it first with the library command. 

<p>

- To install a package, click the install button, type in the name of the package and hit install.

- Install the following packages: AER, dynlm, fGarch, FinCal, kableExtra, MASS, reshape2, stargazer, tidyquant, tidyverse, wesanderson, xtable.

    - Note that R is case-sensitive, thus upper- and lower-case letters are interpreted as being different.

<p>

![](assets/p12.png)

<p>

- Alternatively, install the packages by running the following code in the console.

<p>

```{r, eval=FALSE}
install.packages("AER", "dynlm", "fGarch", "FinCal", "kableExtra", "MASS", "reshape2", "stargazer", "tidyquant", "tidyverse", "wesanderson", "xtable", dependencies = TRUE)
```

<p>

- Installation of packages will take some time. Our list of packages will require several additional packages, callede dependencies, to be downloaded.

    - If you are asked _"Do you want to install from sources the packages which need compilation? (Yes/no/cancel)"_ during package installation, you can answer "n".

    - If an installation results in a message like _"Installation of package X had non-zero exit status"_ the package was not installed. Try again. If you still have a problem, contact me.
    
    - A message like _"The downloaded source packages are in 'folder location'"_ means the packages were successfully installed.
    
<p>

- Packages need only be installed on your computer once, but they should be updated from time to time. 

- When you wish to use a package, it must be loaded using the library command. For example, to load the AER package:

<p>

```{r, eval=FALSE}
library(AER)
```

<p>

- Another way to load a package is to tick the box next to the package in the Packages tab. The packages tab shows you all packages that you have installed.

<p>

![](assets/p13.png)

<p>

- If you get an error saying R cannot find a function when you are trying to execute code, it is almost always because you have either a) __not loaded the package__ that contains the function, or b) __mistyped the function__.

----

## Where are my files?

<p>

- The working directory is where R will look for your files and save files.

- Show your current working directory:

<p>

```{r, eval=FALSE}
getwd()
```
 
 <p>
 
- The working directory is set by your project.
 
- If you want to change your working directory temporarily you can set it to another path. Here is an example for my folders:

```{r,eval=FALSE}
setwd("/Users/Clinton/Dropbox/syncd_r_data/econometrics")
```

- If you your working directory is a folder on a network drive or on the cloud (like Dropbox or Google Drive) that is synced to your computer's hard drive, you will be able to use it with RStudio on multiple computers.

----  

## Special HIDDEN R files in your working directory  

<p>

- RStudio uses three important hidden files. You can see them in the RStudio files pane but usually not in your operating system.

    - __.RData__ holds the objects that are loaded in your environment.

    - __.RHistory__ holds the history of the code you have executed in the console.

    - __.Rprofile__ holds specific set-up information for the project you are working in.

<p>

- Here are the hidden files in my working directory shown in red and the project file which holds information about my project in blue.:

<p>

![](assets/p14.png)

----

## Using the ".Rprofile" file to configure an R session

<p>

- The .Rprofile file executes code as R starts up. You can use this file to automatically load the packages you will need to use for this course and to set some R options. Thus .Rprofile allows you to customise the start-up of R.

    - Remember that the packages must already be installed on your computer to be loaded by the .Rprofile file.
    
<p>

- Here is the code you will need in your .Rprofile file for this course.

```{r, eval=FALSE}
# Portfolio Management .Rprofile file

# Auto-load packages:
library(AER)
library(broom)
library(data.table)
library(dynlm)
library(fBasics)
library(fGarch)
library(FinCal)
library(ggplot2)
library(kableExtra)
library(magrittr)
library(MASS)
library(matrixStats)
library(quadprog)
library(quantmod)
library(RColorBrewer)
library(reshape2)
library(rmarkdown)
library(stargazer)
library(timeSeries)
library(tseries)
library(wesanderson)
library(xtable)
library(xts)
library(tidyquant)
library(tidyverse)

# Set some of R options:
options(prompt="R> ", scipen=999, digits=4, width=80)
```

<p>

- To make your .Rprofile file, follow these steps.

- Create a new R Script file.
    
<p>

![](assets/p15.png)

<p>

- Your R Script file is shown below. An R Script file is a text file that you can save code in.

<p>

![](assets/p16.png)

<p>

- Copy all of the code from the Portfolio Management .Rprofile file above and paste it into your R Script file. 

<p>

![](assets/p17.png)

<p>

- Save the R Script file in your working directory (your project directory). The file name does not matter for now.

<p>

![](assets/p18.png)
<p>

![](assets/p19.png)

<p>

- Rename the file as ".Rprofile".

<p>

![](assets/p20.png)
<p>

![](assets/p21.png)
<p>

- You should now have your .Rprofile file in your working directory. If you restart RStudio, your packages should load automatically.

- You may edit the .Rprofile file to add library commands for additional packages you might want to load when R starts up.

----

## Rmarkdown and Notebooks

<p>

- __Rmarkdown__ allows dynamic documents to be created in R that contain written text, R code and output from the code. 

- I will ask you to do some assignments in an R Notebook using markdown. 

    - This guide for setting-up R and RStudio was made in an R Notebook. If you look at the top of the page you can see a button labelled "Code" which alows you to download the code I used to make this HTML file.
    
<p>

- A markdown document is written in using coding called markdown, which is an easy-to-write plain text format that is related to TeX (or LaTeX).

- A TeX installation is required to use Rmarkdown, such as MacTex (for Mac OS) http://www.tug.org/mactex/ or MiKTeX (cross-platform) https://miktex.org/download. If you use LaTeX to write documents, you will already have this. If not, the easiest way to get a TeX installation for markdown is via the TinyTeX package.

----

## Install TinyTeX using the package called tinytex

<p>

- You have already installed the package called tinytex. Executing the code below in the console will download the TinyTeX files from the internet and install them on your computer so that you can make markdown documents. 

<p>

```{r, eval=F, message=FALSE}
tinytex::install_tinytex()
```

<p>

- This will take some time to download.

- Note that you do not need to do this if you use RStudio Cloud as TinyTeX is pre-installed.

- When the installation has finished, restart RStudio.

----

## Test your Rmarkdown environment

- Run through a simple test to see if you can make an R Notebook, as follows.

- Open a new R Notebook.

<p>

![](assets/p22.png)

<p>

- The notebook already contains example text and R code that plots a simple chart.

<p>

![](assets/p23.png)

<p>

- Run the code by pressing "Run All" from the "Run" menu.

<p>

![](assets/p24.png)

<p>

- After you have run the code, you  should see the plot appear.

- Include your name as I have at the top of the Notebook.

<p>

![](assets/p25.png)

<p>

- Save the file to your working directory. 

<p>

![](assets/p26.png)

<p>

- You should see two files appear. 

    - Your code is in the file with the extension ".Rmd".
    
    - Your HTML R Notebook has the extension ".nb.html". 
    
    <p>

![](assets/p27.png)

<p>

- Open the HTML file with your browser. It should look like this:

<p>

![](assets/p28.png)

<p>

- Well done! You have created a Notebook.

----

## Information on Rmarkdown and TinyTeX

- Information on Rmarkdown can be found at https://rmarkdown.rstudio.com/ and a useful guide is at https://bookdown.org/yihui/rmarkdown/ and https://bookdown.org/yihui/rmarkdown-cookbook/ and https://bookdown.org/yihui/rmarkdown/. Easy and helpful video lessons can be found at https://rmarkdown.rstudio.com/lesson-1.html.

- Reference material for TinyTeX is at https://yihui.name/tinytex/.

----

## Resources for R

<p>

- There are many guides to using R available online, both documents and videos. 

- A comprehensive introduction is available on AIMS @Venables2019 and at https://cran.r-project.org/doc/manuals/r-release/R-intro.pdf. 

- Other R documentation and guides for various applications contributed by R users can be found here: https://cran.r-project.org/other-docs.html#english.

- My TA at Kobe University produced the following guides, available at [Massimiliano's R Page on GitHub](https://github.com/massimilianoj/R_beginners).

    - R for Beginners  
    - R Markdown: Notes for Editing  
    - LaTeX: Editing for Mathematics  

----

## CRAN Task Views

<p>

- CRAN Task Views provide information about packages that can be used with R. Packages extend the functionality of R. They provide routines for various types of data manipulation, mathematical and econometric models, optimisation methods, financial models and more. Packages are constantly being developed and updated by R users.

- Three Task Views are useful this course:  

    - Empirical finance: https://cran.r-project.org/web/views/Finance.html 

    - Econometrics: https://cran.r-project.org/web/views/Econometrics.html  

    - Time series: https://cran.r-project.org/web/views/TimeSeries.html  
 
----

## Books on R

<p>

- Many books have been published on using R, programming with R, and using R for finance.

    - Finance: @Bennett2016, @Andrecut2010, @Tsay2010, @Tsay2014

    - Econometrics: @Kleiber2008, @Hornik2009
    
    - Coding: @Matloff2011

----

## R-Bloggers  

<p>

- R-Bloggers is a blog site containing many helpful posts on using R: http://www.r-bloggers.com/  

- The posts on the site show the wide variety of problems that coding in R can be applied to (not just finance). For example:

    - https://www.r-bloggers.com/who-wrote-that-anonymous-nyt-op-ed-text-similarity-analyses-with-r/

    - https://www.r-bloggers.com/how-to-build-animated-bar-plots-using-r/

<p>

- A good introduction to learning R: https://www.r-bloggers.com/how-to-learn-r-2/

----

## Search  

<p>

- Lots of information is posted online by R users including questions and answers.  

- If you are stuck, search for information that will help you answer your question. 

- rseek is a search engine for R: www.rseek.org

- Using another search engine like Google:  

    - "filetype:R regression –rebol"  

    - "CRAN regression"   

----

## RStudio Keyboard Shortcuts (for Mac)

<p>

- Code completion:
    - Type part of the function you want and then press the Tab key.  
    - Also works for function arguments, that is press Tab when yo uare inside the brackets of a function.  
    - Also recalls object names.

<p>

- Press F1 (or fn+F1) for help on a function. 
  
- Retrieve previous commands:  
    - Press the up or down arrows to scroll through your code history.
  
<p>

- View a list of previous commands:  
    - Press Control (or Command) and the up arrow.

<p>

- View a list of previous commands that match a prefix:  
    - Type the prefix and press Control (orCommand) and the up arrow. 

<p>

- Enter a line of code from an R script to the console:
    - Command and enter.

<p>

- Enter a line of code from history to and R script:
    - Shift and enter.

<p>

- More:  
    - Tools -> Keyboard Shortcuts Help  
    - https://support.rstudio.com/hc/en-us/articles/200711853  
    
----

<p>

 © Copyright Clinton Watkins 2021
 
----

## References

<p>
