-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRBasics.qmd
169 lines (109 loc) · 8.66 KB
/
RBasics.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
# Introduction to R and RStudio
```{r, include = FALSE}
knitr::opts_chunk$set(fig.width=6, fig.height=3.5, fig.align="center")
```
The following chapter will provide you with a hands on opportunity to familiarize yourself with RStudio. Learning RStudio is a big topic and we will not be able to cover everything, by the end of this session we hope that you will feel comfortable starting to use R on your own for working with Git and GitHub.
## Learning Objectives
- Navigate RStudio
- Use Posit Cloud (formerly RStudio Cloud)
## Why learn R?
- **R is free, open-source, and cross-platform.** Anyone can inspect the source code to see how R works. Because of this transparency, there is less chance for mistakes, and if you (or someone else) find some, you can report and fix bugs. Because R is open source and is supported by a large community of developers and users, there is a very large selection of third-party add-on packages which are freely available to extend R's native capabilities.
- **R code is great for reproducibility**. Reproducibility is when someone else (including your future self) can obtain the same results from the same dataset when using the same analysis. R integrates with other tools to generate manuscripts from your code. If you collect more data, or fix a mistake in your dataset, the figures and the statistical tests in your manuscript are updated automatically.
- **R relies on a series of written commands, not on remembering a succession of pointing and clicking.** If you want to redo your analysis because you collected more data, you don't have to remember which button you clicked in which order to obtain your results; you just have to run your script again.
- **R is interdisciplinary and extensible** With 10,000+ packages that can be installed to extend its capabilities, R provides a framework that allows you to combine statistical approaches from many scientific disciplines to best suit the analytical framework you need to analyze your data. For instance, R has packages for image analysis, GIS, time series, population genetics, and a lot more.
- **R works on data of all shapes and sizes.** The skills you learn with R scale easily with the size of your dataset. Whether your dataset has hundreds or millions of lines, it won't make much difference to you. R is designed for data analysis. It comes with special data structures and data types that make handling of missing data and statistical factors convenient. R can connect to spreadsheets, databases, and many other data formats, on your computer or on the web.
- **R produces high-quality graphics.** The plotting functionalities in R are endless, and allow you to adjust any aspect of your graph to convey most effectively the message from your data.
- **R has a large and welcoming community.** Thousands of people use R daily. Many of them are willing to help you through mailing lists and websites such as [Stack Overflow](https://stackoverflow.com/), or on the [RStudio community](https://community.rstudio.com/). Questions which are backed up with [short, reproducible code snippets](https://www.tidyverse.org/help/) are more likely to attract knowledgeable responses.
## Starting out in R
[R](https://cran.rstudio.com/) is both a programming language and an interactive environment for data exploration and statistics.[@R-base]
Working with R is primarily text-based. The basic mode of use for R is that the user provides commands in the R language and then R computes and displays the result.
### Downloading, Installing and Running R
**Download**\
R can be downloaded from [CRAN (The Comprehensive R Archive Network)](https://cran.rstudio.com/index.html) for Windows, Linux, or Mac.
**Install**\
Installation of R is like most software packages and you will be guided. Should you have any issues or need help you can refer to [R Installation and Administration](https://cran.r-project.org/doc/manuals/r-release/R-admin.html)
**Running**\
R can be launched from your software or applications launcher or When working at a command line on UNIX or Windows, the command `R` can be used for starting the main R program in the form `R`
You will see a console similar to this appear:
```{r echo=F}
knitr::include_graphics("images/console.png")
```
While it is possible to work solely through the console or using a command line interface, the ideal environment to work in R is RStudio.
### RStudio
[RStudio](https://www.rstudio.com/products/rstudio/download/) is a user interface for working with R. It is called an Integrated Development Environment (IDE): a piece of software that provides tools to make programming easier. RStudio acts as a sort of wrapper around the R language. You can use R without RStudio, but it's much more limiting. RStudio makes it easier to import datasets, create and write scripts, and makes using R much more effective. RStudio is also free and open source. To function correctly, RStudio needs R and therefore both need to be installed on your computer. For this training we'll be using a browser based version called [Posit Cloud](#sec-posit_cloud) (see directions in the Posit Cloud section below.
RStudio interface is conveniently organized into four divisions called "panes".
The Default Layout is:
- Top Left - **Source**: your scripts and documents
- Bottom Left - **Console**: what R would look and be like without RStudio
- Top Right - **Environment/History**: look here to see what you have done
- Bottom Right - **Files** and more: see the contents of the project/working directory here, like your Script.R file
```{r echo=F}
knitr::include_graphics("images/rstudio.png")
```
The placement of these panes and their content can be customized (see menu, Tools -\> Global Options -\> Pane Layout)
### Posit Cloud (formerly RStudio Cloud) {#sec-posit_cloud}
Posit Cloud is a web browser-based version of RStudio. It will allow you to use RStudio without needing to download anything to your computer. You can also easily share your R projects with others. To use Posit Cloud a user account is required. While we recommend downloading RStudio for routine R programming use, we will be using Posit Cloud for this training.
To access Posit Cloud
1. In a new browser window or tab create your account at <https://posit.cloud/plans/free>.
2. Log in with Goolge or GitHub or however you choose!
3. Create a new project.
4. Write amazing code!
## Using this book
**For these instructions code will appear in the gray box as follows:**
```
fake code
```
To run the code you can copy and paste the code and run it in your RStudio session console at the prompt `>` which looks like a greater than symbol.
```
> fake code
```
The code can also be added to an R Script to be run.
When the code is run in RStudio the console prints out results like so:
```
[1] Result
```
In this tutorial results from code will appear like so:
```
## [1] Result
```
## Working in the Console
The console is an interactive environment for RStudio, click on the "Console" pane, type `3 + 3` and press enter. R displays the result of the calculation.
```{r class.source = "source", class.output = "output"}
3 + 3
```
`+` is called an operator. R has the operators you would expect for for basic mathematics:
**Arithmetic operators**<br>
| operator | meaning |
|:---------|:-----------|
| \+ | plus |
| \- | minus |
| \* | times |
| / | divided by |
| \^ | exponent |
**Logical Operators**<br>
| operator | meaning |
|:---------|:-------------------------|
| == | exactly equal |
| != | not equal to |
| \< | less than |
| \<= | less than or equal to |
| \> | greater than |
| \>= | greater than or equal to |
| x\|y | x or y |
| x&y | x and y |
| !x | not x |
Spaces can be used to make code easier to read.
```{r}
2 * 2 == 4
```
You can also run commands in the consile for working with your computers filesystem.
```{r eval=FALSE}
getwd() # similar to UNIX PWD
```
## Working in the Terminal
The embedded Terminal in RStudio is a command-line interface within the IDE, allowing users to execute system commands and interact with the operating system directly.
- It shares the same working directory as the RStudio session and supports various commands for file management, package installation, and more.
- Integration into the IDE streamlines workflows by eliminating the need to switch between applications, enhancing productivity and enabling seamless interaction between R programming and system administration tasks.
```{r echo=F}
knitr::include_graphics("images/terminal_RStudio.png")
```