Introduction
R is a programming language and software environment for statistical computing and graphics. It is widely used among statisticians and data scientists for developing statistical software, data analysis, and data visualization. Statisticians Ross Ihaka and Robert Gentleman created it in the early 1990s at the University of Auckland, New Zealand. It is an open-source language, meaning that anyone can contribute to its development and use it for free.
One of the strengths of R is its large and active community of users who have developed a vast collection of packages. These packages are pre-written R code that can be easily downloaded and extend the functionality of R and make it possible to perform a wide variety of statistical analyses and data visualization tasks.
R Development Environment
Several development environments are available for programming in R, each with its features and capabilities. The choice of environment depends on your needs and preferences, so it is worth exploring different options to see which works best for you. Some of the available options are listed below.
1. Integrated Development Environment (IDE)
An Integrated Development Environment (IDE) is software designed to make coding easier and more efficient. It usually comes with an integrated version control system. An IDE could be specifically designed for one programming language or have multi-language support. Using multiple languages usually needs additional installations of packages/extensions on top of the IDE. In addition to the software running locally on your computer, there are web-based options.
A. Universal IDEs
Universal or multi-language IDEs are highly customizable, multi-platform text editors that can be used for coding in multiple programming languages. A universal IDE can be a good choice if you work with multiple programming languages and prefer a single development environment for your projects. Some popular universal IDEs are:
- Visual Studio Code (VSCode): VSCode is an open-source code editor that can be used for R programming by installing the R extension. It provides features such as code highlighting, code completion, and debugging.
…from the tutorial - Microsoft R Open: This is a distribution of R that includes a development environment from Microsoft. Microsoft R Open ⤴ is now retired.
- Atom: Now archived, Atom ⤴ is one of the most liked IDEs out there. Plenty of packages are available to extend the functionality, including support of programming languages such as R.
- Eclipse: Eclipse is a popular open-source Java-based IDE that can be used for R programming through the StatET plugin. It provides features such as code highlighting, debugging, and visualization tools. Check out the Eclipse website ⤴ for information about related IDEs.
- Architect: is an IDE designed for data scientists. It has an R console integrated within it and supports multiple languages as it is based on Eclipse. Get Architect from the website ⤴.
B. R-Dedicated IDEs
- RStudio: is a popular open-source IDE specifically designed for R programming. It has a user-friendly interface with features such as code highlighting, code completion, debugging, and visualization tools. Both new and experienced R users widely use RStudio.
…about RStudio: integrated environment for R and . - Tinn-R: is an open-source IDE with GUI for R programming and environment that provides a customizable interface for editing, running, and debugging R code. Check the Tinn-R website ⤴ to download and for more information.
C. Web-based IDEs
- Jupyter Notebook: is a web-based IDE that allows users to create and share documents that contain live code, equations, visualizations, and narrative text. Learn more about the Jupyter Lab from the tutorial in this workbook.
- RStudio Cloud: RStudio Cloud is a free, web-based version of the RStudio IDE that provides a complete environment for coding in R. You can write, run, and share your R code from anywhere with an internet connection. RStudio Cloud is now known as Posit Cloud ⤴.
2. Online Coding Platforms
Several online platforms provide an easy way to start coding in R without having to install anything on your local computer. They are especially useful for collaborating with others and as an alternative to installing software on your machine. However, they may have processing power, storage, and memory limitations. Some online platforms for R are:
- Google Colab ⤴: is a free Jupyter Notebook environment that allows you to code in R and other programming languages. You can write, run, share R code with others, and have access to powerful GPUs and TPUs.
- Kaggle Kernels ⤴: Formally Scripts, Kaggle Kernels is a free, web-based multi-language platform. It provides a Jupyter Notebook-style environment and is well-suited for data science and machine learning projects.
3. Text Editors
Text editors are limited in terms of functionality and user-friendliness compared to IDEs. You can use text editors to write your code and then use a console/R environment to run the code. Text editors that can be used for R programming:
Nano | Vim | Notepad++ | Gedit | Kate | Sublime Text |
Nano and Vim are Unix text editors and are good options if you are working on an HPC cluster. Learn more about nano
and vim
from the tutorial in this workbook.
Some basic development environments for programming in R along with the text editors:
- Base R: is the standard R environment included with the installation of R software. It provides a simple console for entering commands, viewing results, and running code written using a text editor.
- R Commander: R Commander is a graphical user interface (GUI) for R. It is especially useful for novice R users and also comes with the standard R installation.
Getting started with R
You will need to install the R software on your computer to use R. This can be done easily by downloading it from the Comprehensive R Archive Network (CRAN), the official repository for R packages and software. You will also need a text editor or an IDE of your choice to write and edit code. I recommend using RStudio or RStudio Cloud. Check out for more details about getting started in R and installing R libraries. Also, check the tutorial if you are not familiar with RStudio interface.
What can you do using R?
Here are a few examples of the things that you can do with R:
- Data Manipulation: reading, cleaning, and manipulating data from different sources
- Data Visualization through plots, charts, e.g., Boxplots or Complex Heatmaps
- Statistical Analysis
- Data Modeling
- Machine Learning
Simple R Code
To perform a simple arithmetic calculation, you can enter the following into the console:
> 2 + 2
##If you press enter, you will get the following output
[1] 4
In this example, the output is the result of the calculation 2 + 2
, which is 4.
In addition to basic arithmetic operations, R also has a variety of functions that can be used to perform more complex statistical analyses.
For example, you can use the mean()
function to calculate the mean of a set of numbers:
> a1 <- c(1, 2, 3, 4, 5)
> mean(a1)
[1] 3
In this example, the mean()
function calculates the mean of the a1
numeric vector, which contains the numbers 1, 2, 3, 4, and 5. The mean of these values is 3.
R also has powerful capabilities for visualizing data.
For example, you can use the plot()
function to create a scatterplot:
> plot(1:20)
With its powerful statistical and data visualization capabilities, R is a valuable tool for anyone working with data.