Chapter 5 Introduction to the RStudio Server
5.1 Introduction
Rstudio is a complete environment for working with the R language. Once you have got used to it you will find that it makes working with R far more productive than using the R console version. However the concepts involved in using RStudio will be completely new to most. The interface can seem very complex. RStudio provides an interface for working with R code, rather than an interface for running analyses directly. The code for conducting analyses will be provided for you in this course. You do not need to learn to write any Rcode yourself in order to produce graphics and run basic statistical analyses. You will also be able to reproduce more sophisticated quantitative and spatial analysis in RStudio by making minor adaptations to pre-built scripts.
5.2 Getting started with the RStudio server
The RStudio server version runs directly through any web browser. There is no need to install any software on your laptop, PC or tablet
Access to the server is through the following URL. This works both on and off campus.
http://r.bournemouth.ac.uk:8789/
5.2.1 Action: Log into the RStudio server
- Click on the URL in a browser. Use Firefox or Chrome.
- You will see a log in page.
- Log in using a username and the default password msc123
The usernames for this course have been set up to be your first name as shown in brightspace and surname initial, all in lower case.
veronicab elizabethe garethh minniej curtisl esmel ricardol robm ttomasn georgiap andrewr molliet anuro msc1 msc2 guest phd1
If your name is not in this list, or you want to change your user name let me know. Do not log in using someone else’s name!. If there is any abuse of this I will show users how to change to a secure password, but we will assume trust by default.
5.3 RStudio server concepts
Using a server can seem strange at first. The RStudio server is an integrated platform for doing the following …
- Saving and sharing data files
- Running analyses
- Compiling reports
- Connecting to data stores
- Sharing analyses with others.
Amongst many other potential uses. It is a very powerful tool that is freely available for all those with a log in to use it. The more advanced features can be used without any programming skills through sharing scripts. However you do need to become familiar with some new concepts in order to use these.
The RStudio server is ideal for collaborative work. You have been provided with a username and a password, as this also provides you with your own permanent space on the server for saving your own work and building up a portfolio of useful analyses. Only one person can be logged in at any one time under your username. However I can always log into your user space at any time in order to help correct your errors and to give you advice.
5.4 Finding your way around the interface
Once you are logged in you will see three sections of the interface by default. This will change to four sections when you begin using scripts in the interface.
Look carefully at the interface and learn to recognise the sections.
- The RConsole. This is showing up on the left hand side when you first log in. The console can be used for running R code interactively. There is a tab showing up labelled “terminal” as well. You won’t use this, as it is for more advanced programming.
- The environment, history and connections pane is at the top right of the screen. The environment tab is the one that is most used. This tab will show the data that is in the active workspace in R. The concept will only become clear after beginning to use R.
- The files, plots, packages, help and viewer tab at the bottom right. The files tab is the most important to understand at this stage. There will be no files in your home directory yet, nor will there be any folders.
A key concept to understand when using the server is that your home directory on the server is like a directory (folder) on your PC. So ,it is rather like the university H drive. However it is all “encapsulated” on the server which is also running R. So it is distinct from your H drive and not directly linked. In order to move data files and scripts into your home directory you must upload them. You will see buttons labelled New Folder, Upload, Delete, Rename and More. If you click on the More button you will also find an option to Export your files. The upload and the export buttons are frequently used to move files onto the server and to directly move files off the server. It is very important to be aware of this concept. Files saved on the server will always be available for use later. In contrast active analyses that take place in the server memory, as opposed to the server’s hard disk space, will be temporary and will be lost between sessions.
5.4.1 Using projects in RStudio
Just as we have seen previously in QGIS the use of projects is good practice. QGIS can be used without a project file, but if you do that you may find that you have to go through many steps to reload files and get back to where you left off. RStudio has a similar concept. We can use a project for each week’s work in R. Let’s start one called “intro”. Just as in QGIS each project should be associated with a single folder and all the work placed within this folder. The folder can be added when the project is first started.
5.4.2 Action: Form a new project and add a new folder
- Click on the file menu at the top left of the interface.
- Go to New Project
- You will see a window with three options to create a project. Choose the first option labelled New Directory
- The next window will show a range of advanced options. Ignore them and just select New Project
- You will now see a window with a prompt for the Directory name (and some other options). Type “intro” as the directory name.
- Click create project
- Look at the files pane in the bottom right corner. You will now see that after Home there is the word intro. You can also see a file called intro.Rproj in the folder.
- Click on home. You can see a folder called intro in your home directory. So .. you have created a new project and placed the project file within the folder. This is just like starting a project in QGIS.
- Click the folder again to open it.
5.4.3 Using the console
The R console in the bottom left of the screen allows you to run R code interactively. In this course you will not be using this very much, as we will use pre-built R code that avoids the need to code your own. However in order to use the code you do need to gain some intuitive idea of what is happening when you do.
5.4.4 Action: Make a data object (vector) in R
- Carefully type the following code into the console x<-rnorm(100). Make sure it is all lower case and typed exactly as shown.
- Press enter
- Look in the global environment window in the top right of the screen. You will see that a data object called “x” has been added.
5.5 Data abstraction and data visualisation
The action you have taken so far involves a concept that will be completely new to most of you. We can refer to it as data abstraction. Most of you will be familiar with data in the form of visible numbers, text, or even maps. However programmers (and mathematicians) think of data in the abstract. We have a data object (in this case a numerical vector) called x. It consists of 100 numbers. These numbers have been simulated by R from a normal distribution. However data analysts tend not to look directly at the numbers themselves. They are much more interested in patterns in the numbers and relationships between variables.
5.5.1 Action: Visualise the data using a simple histogram
- Type hist(x) carefully into the R console in the bottom left of the screen and press enter.
- Notice that the plots tab becomes visible in the bottom right. It shows a histogram of x.
So what has happened here?
- The first line of code (x<-rnorm(100) generated a vector of 100 numbers drawn from a normal distribution with a mean of zero and a standard deviation of 1. This vector of numbers was placed in the computer memory. All the numbers existed, but we did not look at them.
- We could see the vector was active in memory as it appeared in the Environment pane.
- We then investigated the properties of the data object by plotting a simple histogram.
These concepts will become clearer over time when using R. Notice that at this stage no data is actually saved as a file on the hard disk. It is present in the computer’s memory.
5.5.2 Action: Close the project
- Click on the project icon (marked intro) on the top right-hand side of the top menu bar.
- Go to “close project”
- You will be asked if you want to save the workspace.
- Click on save
- You will now return to a blank workspace.
- Click on the files tab at the bottom right and click on the intro folder
- Notice that the folder now contains an .Rhistory file, an .RData file and a file called intro.RProj.
This was a tiny R project, but we all have to start somewhere. Programmers often begin learning how to make the language they are learning send a “Hello World” message to the console. So this was the equivalent of “Hello R World”
Let’s go back to the project.
5.5.3 Action: Restore the project
- Click on project on the top right of the menu bar.
- You should see the word “Intro” in the window. If you had more projects then they would all be listed here. Note you could also use the open project option to go back to your project, but of course, at the moment you only have one project available.
- Click intro
- Go to the plots tab and notice that there is no histogram showing now.
- Click on the history tab in the top right panel.
- Notice that the code you wrote is shown there.
- Click on the console panel on the right to make it active.
- Press the up arrow on your keyboard once.
- Notice that the last command that you entered (hist(x)) is now shown in the console.
- Press enter.
- Notice that the histogram now shows in the plots menu.
So, what’s going on?. When you answered “yes” to save the workspace both the data and the history of the R commands were saved in the folder. So the whole “analysis” can be recreated at any time. This will all become clearer over time.
5.6 Working with markdown documents.
This course will concentrate on the use of markdown documents as a way of running R code. The advantages of using markdown are many.
- Embedded code can be either revealed to other users to show how the results were obtained or hidden to simply produce a report with embedded figures and statistics.
- Annotation of the results of an analysis can be embedded around the results to explain the key results.
- Very limited knowledge of the R language and syntax is necessary to adapt markdown documents in order to analyse your own data.
- With a little more knowledge and experience of R complex methods can be applied by altering markdown found on-line.
5.6.1 Action: Produce a default markdown document.
- Go to file on the top menu bar
- Choose “New file”
- Choose “R Markdown”
- You will now see a window in which you can type in a name for the title of your analysis. By default the name is “untitled”. Change that to something like “R demo”, or anything else you feel like.
- You will now see an untitled markdown document added to the top pane in RStudio. It is untitled, even though you’ve given it a title, as it is not saved as a document.
- Press the “knit” button on the top right pane.
- Now you are prompted to give the file itself a name. Call it whatever you want, maybe “R demo” again.
- After knitting the document you will be prompted to open a window to see it.
- Look at the document and understand what it consists of.
The steps above produce a default “demo” markdown document. Every time you start a new markdown Rstudio will start off with this one. When you use markdown for real you will either open a document ready for knitting or replace the default demo text with your own.
You should look at the logic of the document carefully. It consists of “chunks” of R code that produce output in the form of tables and figures embedded in text. The R code automatically produces output and adds it to the document after knitting. So if you have R code available that will run an analysis that you are interested in you don’t have to remember any other steps in order to run it. Simply ensure that the data that is being added to the analysis is appropriate for the type of analysis being run and you can obtain the same results with your own data. This will be the way R is used in this course.
5.6.2 Action: Clean out, rinse and repeat, for practice sake
- Close the project.
- Delete the whole folder in the files pane by selecting it and then choosing delete.
- Choose “clear project list” from the project menu at the top right.
- You are now back right where you started (apart from the .RHistory file in the home directory)
- Try all the above steps again to become familiar with the process before we begin more serious work. You will need to open a new project each week to keep all your work in good order and prevent confusion.
5.7 Conclusion
You should now be able to start a clean project in RStudio. The code to actually run the analyses will be provided for you. So there is no need to fully understand R code to complete the unit. You will not be expected to write any code yourself. However, as you progress with R you will begin to alter code and adapt it for your own purposes. With time you will be able to write code yourself to run analyses. The key to the process is to become familiar with the general concept of data abstraction and to gain a feel for the nature of the data that is used for statistical analysis.