StackShareStackShare
Follow on
StackShare

Discover and share technology stacks from companies around the world.

Follow on

© 2025 StackShare. All rights reserved.

Product

  • Stacks
  • Tools
  • Feed

Company

  • About
  • Contact

Legal

  • Privacy Policy
  • Terms of Service
  1. Stackups
  2. Application & Data
  3. Languages
  4. Languages
  5. Erlang vs R

Erlang vs R

OverviewDecisionsComparisonAlternatives

Overview

Erlang
Erlang
Stacks1.4K
Followers749
Votes345
GitHub Stars11.9K
Forks3.0K
R Language
R Language
Stacks3.9K
Followers1.9K
Votes418

Erlang vs R: What are the differences?

Introduction

In this article, we will discuss the key differences between Erlang and R. Both Erlang and R are programming languages used in different domains. While Erlang is primarily used for developing scalable and fault-tolerant distributed systems, R is a language focused on statistical computing and graphics.

  1. Concurrency and Fault-Tolerance: One of the major differences between Erlang and R is in their support for concurrency and fault-tolerance. Erlang was designed from the ground up to handle concurrent and distributed systems, making it highly efficient in handling multiple processes and nodes. On the other hand, R lacks built-in support for concurrency and fault-tolerance, which can limit its scalability in distributed environments.

  2. Functional Programming Paradigm: Erlang is a functional programming language, which means it relies heavily on immutable data and functions without side effects. This makes it easier to reason about the behavior of the program and leads to highly reliable and maintainable code. In contrast, while R does support functional programming concepts, it also allows for imperative and object-oriented programming styles, giving developers more flexibility but potentially introducing complexity and bugs.

  3. Built-in Concurrency Constructs: Erlang provides built-in concurrency constructs like processes, message passing, and selective receives, which make it easy to write concurrent and distributed applications. These constructs are crucial for creating fault-tolerant and highly available systems. In contrast, R lacks such built-in constructs, which can make it more challenging to write concurrent programs and handle distributed computations.

  4. Statistical Computing and Analysis: R is well-known for its rich set of libraries and tools for statistical computing, analysis, and data visualization. It provides a wide range of statistical models, machine learning algorithms, and data manipulation functions. This makes R an ideal choice for data scientists and statisticians working on data-intensive projects. On the other hand, Erlang does not have extensive built-in support for statistical computing and analysis. While it is possible to use external libraries, Erlang's primary focus is on building scalable and fault-tolerant systems rather than statistical analysis.

  5. Concurrency Granularity: In Erlang, lightweight processes are used to achieve concurrency, where each process can handle millions of processes efficiently. This fine-grained concurrency allows for the efficient utilization of system resources and enables high scalability. In contrast, R mainly relies on multi-threading to achieve concurrency, but it has limitations due to the Global Interpreter Lock (GIL) in the underlying implementation, which can restrict the scalability of concurrent programs.

  6. Community and Industry Use: The communities and industry use cases of Erlang and R differ significantly. Erlang has gained popularity for its use in building highly scalable and fault-tolerant systems, particularly in the telecom industry. It has been widely adopted by companies like Ericsson and WhatsApp, where the focus is on handling massive concurrent loads. On the other hand, R has a strong presence in the domain of data science and statistical analysis. It is heavily used by researchers, statisticians, and organizations working with large datasets for analysis and visualization.

Summary

In summary, Erlang excels in concurrency, fault-tolerance, and building distributed systems, whereas R is renowned for statistical computing, analysis, and data visualization.

Share your Stack

Help developers discover the tools you use. Get visibility for your team's tech choices and contribute to the community's knowledge.

View Docs
CLI (Node.js)
or
Manual

Advice on Erlang, R Language

Samuel
Samuel

Oct 11, 2021

Decided

MACHINE LEARNING

Python is the default go-to for machine learning. It has a wide variety of useful packages such as pandas and numpy to aid with ML, as well as deep-learning frameworks. Furthermore, it is more production-friendly compared to other ML languages such as R.

Pytorch is a deep-learning framework that is both flexible and fast compared to Tensorflow + Keras. It is also well documented and has a large community to answer lingering questions.

158k views158k
Comments
Mohiuddin
Mohiuddin

Mar 7, 2022

Needs advice

Extract the daily COVID-19 confirmed cases for City1, City2, and City3 from all the cities. Normalize the daily COVID-19 confirmed cases for the three cities using their respective populations. The 2019 mid-year estimated population figures for City1, City2, and City3 are 100,000, 200,000, and 300,000 respectively.

df <- read.csv ("coronavirus.csv", header = TRUE ) library(dplyr) df %>% group_by(City.name) %>% summarise(Sum = sum(Daily.cases))

Cant select multiple variables from dplyr::Groupby. Can anyone help me with the right code along with the second part of the question as I am not able to find solution as well.

3.15k views3.15k
Comments

Detailed Comparison

Erlang
Erlang
R Language
R Language

Some of Erlang's uses are in telecoms, banking, e-commerce, computer telephony and instant messaging. Erlang's runtime system has built-in support for concurrency, distribution and fault tolerance. OTP is set of Erlang libraries and design principles providing middle-ware to develop these systems.

R provides a wide variety of statistical (linear and nonlinear modelling, classical statistical tests, time-series analysis, classification, clustering, ...) and graphical techniques, and is highly extensible.

Statistics
GitHub Stars
11.9K
GitHub Stars
-
GitHub Forks
3.0K
GitHub Forks
-
Stacks
1.4K
Stacks
3.9K
Followers
749
Followers
1.9K
Votes
345
Votes
418
Pros & Cons
Pros
  • 62
    Concurrency Support
  • 62
    Real time, distributed applications
  • 58
    Fault tolerance
  • 36
    Soft real-time
  • 32
    Open source
Cons
  • 1
    Languange is not popular demand
Pros
  • 86
    Data analysis
  • 64
    Graphics and data visualization
  • 55
    Free
  • 45
    Great community
  • 38
    Flexible statistical analysis toolkit
Cons
  • 6
    Very messy syntax
  • 4
    Tables must fit in RAM
  • 3
    Arrays indices start with 1
  • 2
    No push command for vectors/lists
  • 2
    Messy syntax for string concatenation

What are some alternatives to Erlang, R Language?

JavaScript

JavaScript

JavaScript is most known as the scripting language for Web pages, but used in many non-browser environments as well such as node.js or Apache CouchDB. It is a prototype-based, multi-paradigm scripting language that is dynamic,and supports object-oriented, imperative, and functional programming styles.

Python

Python

Python is a general purpose programming language created by Guido Van Rossum. Python is most praised for its elegant syntax and readable code, if you are just beginning your programming career python suits you best.

PHP

PHP

Fast, flexible and pragmatic, PHP powers everything from your blog to the most popular websites in the world.

Ruby

Ruby

Ruby is a language of careful balance. Its creator, Yukihiro “Matz” Matsumoto, blended parts of his favorite languages (Perl, Smalltalk, Eiffel, Ada, and Lisp) to form a new language that balanced functional programming with imperative programming.

Java

Java

Java is a programming language and computing platform first released by Sun Microsystems in 1995. There are lots of applications and websites that will not work unless you have Java installed, and more are created every day. Java is fast, secure, and reliable. From laptops to datacenters, game consoles to scientific supercomputers, cell phones to the Internet, Java is everywhere!

Golang

Golang

Go is expressive, concise, clean, and efficient. Its concurrency mechanisms make it easy to write programs that get the most out of multicore and networked machines, while its novel type system enables flexible and modular program construction. Go compiles quickly to machine code yet has the convenience of garbage collection and the power of run-time reflection. It's a fast, statically typed, compiled language that feels like a dynamically typed, interpreted language.

HTML5

HTML5

HTML5 is a core technology markup language of the Internet used for structuring and presenting content for the World Wide Web. As of October 2014 this is the final and complete fifth revision of the HTML standard of the World Wide Web Consortium (W3C). The previous version, HTML 4, was standardised in 1997.

C#

C#

C# (pronounced "See Sharp") is a simple, modern, object-oriented, and type-safe programming language. C# has its roots in the C family of languages and will be immediately familiar to C, C++, Java, and JavaScript programmers.

Scala

Scala

Scala is an acronym for “Scalable Language”. This means that Scala grows with you. You can play with it by typing one-line expressions and observing the results. But you can also rely on it for large mission critical systems, as many companies, including Twitter, LinkedIn, or Intel do. To some, Scala feels like a scripting language. Its syntax is concise and low ceremony; its types get out of the way because the compiler can infer them.

Elixir

Elixir

Elixir leverages the Erlang VM, known for running low-latency, distributed and fault-tolerant systems, while also being successfully used in web development and the embedded software domain.

Related Comparisons

Bootstrap
Materialize

Bootstrap vs Materialize

Laravel
Django

Django vs Laravel vs Node.js

Bootstrap
Foundation

Bootstrap vs Foundation vs Material UI

Node.js
Spring Boot

Node.js vs Spring-Boot

Liquibase
Flyway

Flyway vs Liquibase