Skip to main content

Mastering R Basics: Understanding Objects, Data Types (Vectors and Lists), and Coercion

The Beginner’s Guide R Objects and Data Types: "Vectors and Lists"

R is a programming language that is widely used for data analysis and statistical computing. It has a powerful set of data structures, including vectors, lists, and data frames, that allow users to work with data in a flexible and efficient way.


R Objects

Everything in R is an object, which means that it has a type, a value, and possibly some attributes. There are many different types of objects in R, including numbers, strings, and logical values, as well as more complex objects like functions and data frames.

Numbers

In R, there are two types of numbers: integers and doubles. Integers are whole numbers, while doubles are numbers with decimal places. When you create a number in R, it is automatically assigned a type based on its format. For example, if you type x <- 5, R will create an integer object, while if you type y <- 5.0, R will create a double object.

Attributes

Objects in R can have attributes, which are additional pieces of information that describe the object. For example, a vector might have an attribute that specifies its length, or a data frame might have an attribute that specifies the names of its columns. You can access an object's attributes using the attributes() function.

Data Types: Vectors and Lists

Vectors and lists are two of the most commonly used data types in R. Vectors are a basic data structure in R that allow you to store multiple values of the same type. For example, you might create a vector of integers like this:

x <- c(1, 2, 3, 4, 5)

Lists are a more complex data type in R that allow you to store multiple values of different types. For example, you might create a list like this:

my_list <- list(name = "John", age = 25, hobbies = c("reading", "swimming", "hiking"))

Data Coercion

Data coercion is the process of changing the type of an object in R. For example, you might need to coerce a character string to a numeric value in order to perform a calculation. You can use the as. functions to coerce data from one type to another. For example, to coerce a character string to a numeric value, you would use the as.numeric() function:

x <- "10" 
y <- as.numeric(x)

This would create a numeric object y with the value 10.
More on these topics have already been covered in the lecture.

Practice Material

Here are a few practice exercises to help beginners get started with R:

  • Create a vector of even numbers from 2 to 20.
  • Create a list with the following information about yourself: name, age, height, favorite color.
  • Create a vector of five numeric values and then coerce it to a character string.
  • Create a data frame with the following information about three people: name, age, height, weight.

  • Create a vector of the numbers 1 to 10 and then extract the values that are greater than 5.
  • For more practice you should start swirl's second, third and fourth lesson on  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. 

I hope this blog post has been helpful in introducing R objects, numbers, attributes, data types, and data coercion. Good luck with your R programming journey!

Comments

Popular posts from this blog

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...

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:...

Optimization Example of Lexical Scoping in R: Exploring optim, optimize, and nlm Functions

The Beginner’s Guide to Optimization Example of Lexical Scoping in R: When it comes to optimization in R, lexical scoping can be a useful tool for optimizing complex functions that involve multiple variables. In this blog post, we will explore how lexical scoping can be used to optimize a function using the NLL (negative log-likelihood) function , and how the optim, optimize, and nlm functions can be used to perform optimization in R. Optimizing the NLL Function using Lexical Scoping The NLL function is a common function used in optimization problems. It is defined as the negative log of the likelihood function, which is used to estimate the parameters of a statistical model. In R, the NLL function can be defined using lexical scoping, which allows us to pass arguments to the function and access variables from within the function. Here is an example of how to define the NLL function using lexical scoping in R: nll <- function(data, parameters) {   # Define local variables ...