Skip to main content

Efficient Data Manipulation with Loop Functions in R: A Deep Dive into apply and mapply

The Beginner’s Guide to Loop Functions in R:

In addition to lapply and sapply, R also has apply and mapply, which are other loop functions that are commonly used for data manipulation and analysis. In this blog post, we'll explain what these functions are, how they work, and provide some practice material for beginners to intermediate level.


apply: 

Apply a Function to a Matrix or Array

apply is a loop function in R that applies a function to either rows or columns of a matrix or array. Here's the basic syntax:

apply(matrix/array, margin, function)

The matrix/array argument is the matrix or array you want to apply the function to, and the margin argument specifies whether you want to apply the function to rows or columns. margin = 1 applies the function to rows, while margin = 2 applies the function to columns. The function argument is the function you want to apply. For example, let's say we have a matrix of numbers and we want to apply the sum function to each row:

my_matrix <- matrix(c(1, 2, 3, 4, 5, 6), nrow = 2) 
apply(my_matrix, 1, sum)

This will return a vector of the sums of each row in my_matrix.

mapply: 

Apply a Function to Multiple Vectors

mapply is a loop function in R that applies a function to multiple vectors, where the function takes multiple arguments. Here's the basic syntax:

mapply(function, vector1, vector2, ...)

The function argument is the function you want to apply, and the vector1, vector2, etc. arguments are the vectors you want to apply the function to. For example, let's say we have two vectors of numbers and we want to apply the sum function to each corresponding pair of elements:

vector1 <- c(1, 2, 3) 
vector2 <- c(4, 5, 6) 
mapply(sum, vector1, vector2)

This will return a vector of the sums of each corresponding pair of elements in vector1 and vector2.

Practice Material

Here are some exercises to practice using apply and mapply:

  • Use apply to apply the mean function to each column of a matrix. For example, the matrix matrix(c(1, 2, 3, 4, 5, 6), nrow = 2) should return the vector c(2.5, 3.5, 4.5).
  • Use mapply to apply the sum function to each corresponding pair of elements in three vectors. For example, the vectors c(1, 2, 3), c(4, 5, 6), and c(7, 8, 9) should return the vector c(12, 15, 18).
  • Use apply to apply the sd function to each row of a matrix. For example, the matrix matrix(c(1, 2, 3, 4, 5, 6), nrow = 2) should return the vector c(1.5, 1.5).
  • For more practice you should start swirl's lessons in R Programming. Complete download process of swirl and R Programming is here, click on the link!
  • You can look in to the practice and reading material that is provided in the text book, click here to download the textbook.
  • Lecture slides can be downloaded from here. It would be great if you go through them too.

In conclusion, apply and mapply are loop functions in R that are used for data manipulation and analysis. apply applies a function to either rows or columns of a matrix or array, while mapply applies a function to multiple vectors, where the function takes multiple arguments. Both functions can be useful for simplifying code and performing operations on multiple elements at once. By understanding the basic syntax and usage of these functions, data analysts and programmers can greatly enhance their productivity and efficiency in R programming.

Comments

Popular posts from this blog

Introduction to R Markdown

The Beginner’s Guide to R Markdown! We’ve spent a lot of time getting R and R Studio working, learning about Functionalities of R Studio and R Packages - you are practically an expert at this! There is one major functionality of R/R Studio that we would be remiss to not include in your introduction to R -  Markdown! Functionalities in R Studio Introduction to R Packages What is R Markdown? R Markdown is a way of creating fully reproducible documents, in which both text and code can be combined. In fact, these lessons are written using R Markdown! That’s how we make things: bullets bold italics links or run inline r code And by the end of this lesson, you should be able to do each of those things too, and more! Despite these documents all starting as plain text, you can render them into HTML pages, or PDFs, or Word documents, or slides! The symbols you use to signal, for example,  bold  or  italics  is compatible with all of those formats. Wh...

What is Data? And What is Data Science Process?

The Beginner’s Guide to Data & Data Science Process About Data: In our First Video today we talked about Data and how the Cambridge English Dictionary and Wikipedia defines Data, then we looked on few forms of Data that are: Sequencing data   Population census data ( Here  is the US census website and  some tools to help you examine it , but if you aren’t from the US, I urge you to check out your home country’s census bureau (if available) and look at some of the data there!) Electronic medical records (EMR), other large databases Geographic information system (GIS) data (mapping) Image analysis and image extrapolation (A fun example you can play with is the  DeepDream software  that was originally designed to detect faces in an image, but has since moved on to more  artistic  pursuits.) Language and translations Website traffic Personal/Ad data (e.g.: Facebook, Netflix predictions, etc.) These data forms need a lot of preprocessin...

Introduction to Functions and Arguments in R Programming: Part 2

The Beginner’s Guide to Functions in R Programming: Functions are an essential part of programming, and they play a critical role in R programming. In R, a function is a set of instructions that perform a specific task. Functions in R can have several arguments, and their evaluation can be lazy or eager. In this blog post, we will explore functions in R, including their  "dot-dot-dot" or ellipsis  argument, lazy evaluation, and more . Ellipsis or "dot-dot-dot" Argument in R Functions The "dot-dot-dot" or ellipsis argument in R programming is a special argument that can be used in functions to represent a variable number of additional arguments that are not explicitly defined in the function. The ellipsis argument is represented by three dots ... and is typically used at the end of the function's argument list. When the function is called, any additional arguments provided by the user after the defined arguments are collected by the ellipsis argument an...