5 Funciones básicas de R
En este capítulo se presentará lo que es una función y se mostrarán varias funciones básicas que son útiles para realizar diversas tareas.
5.1 ¿Qué es una función de R?
En la figura de abajo se muestra una ilustración de lo que es una función o máquina general. Hay unas entradas (inputs) que luego son procesadas dentro de la caja para generar unas salidas (outputs). Un ejemplo de una función o máquina muy común en nuestras casas es la licuadora. Si a una licuadora le ingresamos leche, fresas, azúcar y hielo, el resultado será un delicioso jugo de fresa.
Las funciones en R se caracterizan por un nombre corto y que dé una idea de lo que hace la función. Los elementos que pueden ingresar (inputs) a la función se llaman parámetros o argumentos y se ubican dentro de paréntesis, el cuerpo de la función se ubica dentro de llaves y es ahí donde se procesan los inputs para convertirlos en outputs, a continuación se muestra la estructura general de una función.
nombre_de_funcion(parametro1, parametro2, ...) {
tareas internas
tareas internas
tareas internas
salida
}
A continuación se presenta un ejemplo de cómo usar la función mean
para calcular un promedio usando los datos almacenados en un vector.
## [1] 2.775
5.2 Funciones básicas
Al instalar R por primera vez, se incluyen automáticamente un conjunto de paquetes básicos que son esenciales para su funcionamiento. Estos paquetes son:
base
: Este es el núcleo de R y contiene las funciones fundamentales necesarias para realizar cálculos y manipular datos.stats
: Proporciona funciones para realizar análisis estadísticos, incluyendo pruebas de hipótesis y modelos lineales.graphics
: Ofrece herramientas para crear gráficos y visualizaciones de datos.grDevices
: Permite la creación de dispositivos gráficos y la gestión de gráficos en R.utils
: Incluye funciones útiles para la manipulación de datos, gestión de archivos y otras tareas auxiliares.datasets
: Proporciona conjuntos de datos de ejemplo que se pueden utilizar para practicar y aprender R.
Por ejemplo, para ver todas las funciones del paquete base
se escribe el siguiente código en la consola y luego se da clic en el hiper-enlace index que aparezca.
Existen hojas de trucos (cheatsheets) con el listado de las funciones básicas más importantes, a continuación se muestran dos enlace en los cuales se pueden encontrar esas hoja de trucos.
- Cheatsheet del cran: https://cran.r-project.org/doc/contrib/Short-refcard.pdf
- Cheatsheets Posit: https://rstudio.github.io/cheatsheets/
5.3 Operadores binarios
En R se pueden hacer diversas operaciones usando operadores binarios como +
y como ^
, estos operadores son a su vez funciones.
A continuación el listado de los operadores binarios más comunes:
+
operador binario para sumar.-
operador binario para restar.*
operador binario para multiplicar./
operador binario para dividir.^
operador binario para potencia.%/%
operador binario para obtener el cociente en una división (número entero).%%
operador binario para obtener el residuo en una división.
A continuación se presentan ejemplos de cómo usar las anteriores funciones.
## [1] 10
a <- c(1, 3, 2)
b <- c(2, 0, 1) # a y b de la misma dimensión
a + b # Para sumar los vectores a y b miembro a miembro
## [1] 3 3 3
## [1] -1 3 1
## [1] 2 0 2
## [1] 0.5 Inf 2.0
## [1] 1 1 2
## [1] 2
## [1] 1
5.4 Pruebas lógicas
En R se puede verificar si un objeto cumple una condición dada, a continuación el listado de las pruebas usuales.
<
para saber si un número es menor que otro.>
para saber si un número es mayor que otro.==
para saber si un número es igual que otro.<=
para saber si un número es menor o igual que otro.>=
para saber si un número es mayor o igual que otro.
A continuación se presentan ejemplos de cómo usar las anteriores funciones.
## [1] TRUE
## [1] TRUE
## [1] FALSE TRUE TRUE
## [1] FALSE FALSE FALSE
Ejemplo
Crear un vector con los números de 1 a 17 y extrater los números que son mayores o iguales a 12.
Solución
Primero se crear el vector x
con los elementos del 1 al 17. La prueba lógica x >= 12
se usa para evaluar la condición, el resultado es un vector de 17 posiciones con valores de TRUE
o FALSE
dependiendo de si la condición se cumple o no. Este vector lógico se coloca dentro de x[ ]
para que al evaluar x[x >= 12]
sólo aparezcan los valores del vector original que SI cumplen la condición. El código necesario se muestra a continuación.
## [1] 12 13 14 15 16 17
Ejemplo
Retome el marco de datos mimarco
construído en la sección 2.4 y use una prueba lógica para extraer la información de las personas que tienen una edad superior o igual a 15 años.
Solución
Inicialmente vamos a construir nuevamente el objeto mimarco
de la sección 2.4 usando el siguiente código.
mimarco <- data.frame(edad = c(15, 19, 13, NA, 20),
deporte = c(TRUE, TRUE, NA, FALSE, TRUE),
comic_fav = c(NA, 'Superman', 'Batman', NA, 'Batman'))
mimarco # Para ver el contenido de mimarco
## edad deporte comic_fav
## 1 15 TRUE <NA>
## 2 19 TRUE Superman
## 3 13 NA Batman
## 4 NA FALSE <NA>
## 5 20 TRUE Batman
Para extraer de mimarco
la información de las personas que tienen una edad superior o igual a 15 años se coloca dentro de corchetes la condición mimarco$edad >= 15
, esto servirá para chequear cuáles de las edades del vector mimarco$ead
cumplen la condición. El resultado de evaluar mimarco$edad >= 15
será un vector lógico (TRUE
o FALSE
), que al ser colocado dentro de mimarco[,]
, entregará la información de las personas que cumplen la condición. A continuación el código para extraer la información solicitada.
## edad deporte comic_fav
## 1 15 TRUE <NA>
## 2 19 TRUE Superman
## NA NA NA <NA>
## 5 20 TRUE Batman
De la salida anterior se observa que 4 personas de las 5 cumplean la condición.
mimarco$edad >= 15
se debe ubicar antes de la coma para obtener todos individuos que cumplen con la condición.
5.5 Operadores lógicos
En R están disponibles los operadores lógicos negación, conjunción y disyunción. A continuación el listado de los operadores entre los elementos x
e y
.
A continuación se presentan ejemplos de cómo usar el símbolo de negación !
.
## [1] FALSE TRUE FALSE
## [1] TRUE FALSE FALSE TRUE FALSE
A continuación se presentan ejemplos de cómo aplicar la conjunción &
.
x <- c(5, 1.5, 2) # Se construyen dos vectores para la prueba
y <- c(4, 6, 3)
x < 4 # ¿Serán los elementos de x menores que 4?
## [1] FALSE TRUE TRUE
## [1] FALSE TRUE FALSE
## [1] FALSE TRUE FALSE
Ejemplo
Retome el marco de datos mimarco
construído en la sección 2.4 y use una prueba lógica para extraer la información de las personas que tienen una edad superior o igual a 15 años y que practican deporte.
Solución
Aquí interesa extraer la información de los individuos que cumplen dos condiciones simultáneamente, aquellos con edad \(\geq\) 15 y que SI practiquen deporte. El código necesario para obtener la información solicitada es el siguiente.
## edad deporte comic_fav
## 1 15 TRUE <NA>
## 2 19 TRUE Superman
## 5 20 TRUE Batman
De la anterior salida se observa que sólo 3 de las 5 personas cumplen ambas condiciones.
with
es útil porque nos permite realizar algún procedimiento en relación de un objeto, escribiendo menos y de una forma más natural.
Una forma alternativa para escribir lo anterior usando la función with
es la siguiente.
## edad deporte comic_fav
## 1 15 TRUE <NA>
## 2 19 TRUE Superman
## 5 20 TRUE Batman
Al usar with
sólo se tuvo que escribir el objeto mimarco
dos veces. Cuando hay muchas condiciones o cuando el objeto tiene un nombre largo es aconsejable usar with
.
5.6 Funciones sobre vectores
En R podemos destacar las siguientes funciones básicas sobre vectores numéricos.
min
: para obtener el mínimo de un vector.max
: para obtener el máximo de un vector.length
: para determinar la longitud de un vector.range
: para obtener el rango de valores de un vector, entrega el mínimo y máximo.sum
: entrega la suma de todos los elementos del vector.prod
: multiplica todos los elementos del vector.which.min
: nos entrega la posición en donde está el valor mínimo del vector.which.max
: nos da la posición del valor máximo del vector.rev
: invierte un vector.
Ejemplo
Construir en vector llamado myvec
con los siguientes elementos: 5, 3, 2, 1, 2, 0, NA, 0, 9, 6. Luego aplicar todas las funciones anteriores para verificar el funcionamiento de las mismas.
Solución
## [1] 5 3 2 1 2 0 NA 0 9 6
## [1] NA
## [1] 0
## [1] 9
## [1] 0 9
## [1] 28
## [1] 0
## [1] 6
## [1] 9
De las dos últimas líneas podemos destacar lo siguiente:
- NO es necesario usar
na.rm = TRUE
para remover elNA
dentro de las funcioneswhich.min
niwhich.max
. - El valor mínimo 0 aparece en las posiciones 6 y 8 pero la función
which.min
sólo entrega la posición del primer valor mínimo dentro del vector.
5.7 Funciones matemáticas
Otras funciones básicas muy utilizadas en estadística son: sin, cos, tan, asin, acos, atan, atan2, log, logb, log10, exp, sqrt, abs
. A continuación algunos ejemplos de las anteriores funciones.
Ejemplos de medidas trigonométricas
## [1] 0.000000e+00 1.000000e+00 1.224606e-16
## [1] 0.000000e+00 1.633124e+16 -1.224647e-16
Ejemplos de logaritmos
## [1] 4.60517
## [1] 2
## [1] 3
Ejemplos de exponencial
## [1] 2.718282
## [1] 7.389056
## [1] 2.718282 7.389056 20.085537
Ejemplos de raices
## [1] 7
## [1] 3
Ejemplos de valor absoluto
## [1] 2.5
## [1] 3.6
5.8 Función seq
En R podemos crear secuencias de números de una forma sencilla usando la función seq
, la estructura de esta función es:
Los argumentos de esta función son:
from
: valor de inicio de la secuencia.to
: valor de fin de la secuencia, no siempre se alcanza.by
: incremento de la secuencia.length.out
: longitud deseado de la secuencia.
Ejemplo
Construya las siguientes tres secuencias usando la función seq
.
- Once valores igualmente espaciados desde 0 hasta 1.
- Una secuencia de dos en dos comenzando en 1.
- Una secuencia desde 1 con un salto de \(\pi\) y sin pasar del número 9.
Solución
El código necesario para obtener las secuencias se muestra a continuación.
## [1] 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0
## [1] 1 3 5 7 9
## [1] 1.000000 4.141593 7.283185
:
que sirve para construir secuencias de uno en uno fácilmente.
Revise los siguientes ejemplos para entender el funcionamiento del operador :
.
## [1] 2 3 4 5 6 7 8
## [1] 3 2 1 0 -1 -2 -3 -4 -5
## [1] 3.141593 4.141593 5.141593
## [1] 6 5 4
5.9 Función rep
En R podemos crear repeticiones usando la función rep
, la estructura de esta función es:
Los argumentos de esta función son:
x
: vector con los elementos a repetir.times
: número de veces que el vectorx
se debe repetir.length.out
: longitud deseada para el vector resultante.each
: número de veces que cada elemento dex
se debe repetir.
Ejemplo
Construya las siguientes repeticiones usando la función rep
, no lo haga ingresando número por número.
- 1 2 3 4 1 2 3 4
- 1 1 2 2 3 3 4 4
- 1 1 2 3 3 4
- 1 1 2 2 3 3 4 4
Solución
La clave para construir una repetición es descrubir la semilla o elemento que se repite. Las instrucciones para obtener las repeticiones anteriores se muestra a continuación.
## [1] 1 2 3 4 1 2 3 4
## [1] 1 1 2 2 3 3 4 4
## [1] 1 1 2 3 3 4
## [1] 1 1 2 2 3 3 4 4
5.10 Funciones round
, ceiling
, floor
y trunc
Existen 4 funciones útiles para modificar u obtener información de un número, estas funciones son round
, ceiling
, floor
y trunc
.
round(x, digits)
: sirve para redondear un número según los dígitos indicados.ceiling(x)
: entrega el mínimo entero mayor o igual quex
.floor(x)
: entrega el máximo entero menor o igual quex
.trunc(x)
: entrega la parte entera de un númerox
.
Ejemplo
Aplique las funciones round
, ceiling
, floor
y trunc
a un valor positivo y a un valor negativo para inspeccionar los resultados.
Solución
A continuación el código de prueba para un número positivo cualquiera.
## [1] 5.349
## [1] 6
## [1] 5
## [1] 5
A continuación las pruebas con un número negativo cualquiera.
## [1] -4.266
## [1] -4
## [1] -5
## [1] -4
5.11 Funciones sort
y rank
Las funciones sort
y rank
son útiles para ordenar los elementos de un vector o para saber las posiciones que ocuarían los elementos de un vector al ser ordenado. La estructura de las dos funciones es la siguiente.
En el parámetro x
se ingresa el vector y el parámetro decreasing
sirva para indicar si el ordenamiento es de menor a mayor (por defecto es este) o de mayor a menor.
Ejemplo
Considere el vector x
que tiene los siguientes elementos: 2, 3, 6, 4, 9 y 5. Ordene el vector de menor a mayor, de mayor a menor y por último encuentre la posición que ocupan los elementos de x
si se ordenaran de menor a mayor.
Solución
## [1] 2 3 4 5 6 9
## [1] 9 6 5 4 3 2
## [1] 1 2 5 3 6 4
EJERCICIOS
Use funciones o procedimientos (varias líneas) de R para responder cada una de las siguientes preguntas.
¿Qué cantidad de dinero sobra al repartir 10000$ entre 3 personas? Hint: use el operador
%%
.¿Es el número 4560 divisible por 3? Hint: use los operadores binarios
%%
y==
.Construya un vector con los números enteros del 2 al 87. ¿Cuáles de esos números son divisibles por 7? Hint: use los operadores binarios
%%
y==
.Construya dos vectores, el primero con los números enteros desde 7 hasta 3, el segundo vector con los primeros cinco números positivos divisibles por 5. Sea A la condición de ser par en el primer vector. Sea B la condición de ser mayor que 10 en el segundo vector. ¿En cuál de las 5 posiciones se cumple A y B simultáneamente?
Consulte este enlace en el cual hay una anéctoda de Gauss niño. Use R para obtener el resultado de la suma solicitada por el profesor del niño Gauss.
Construya un vector con los siguientes elementos: 1, -4, 5, 9, -4. Escriba un procedimiento para extraer las posiciones donde está el valor mínimo en el vector. Hint: use las funciones
min
ywhich
.
A continuación construya los vectores solicitados pero sin escribir uno a uno los elementos, escriba el vector usando funciones de R. Use las funciones seq
o :
para obtener el resultado deseado.
Contruya el vector: \(1, 2, 3, \ldots, 19, 20\).
Contruya el vector: \(20, 19, \ldots , 2, 1\).
Contruya el vector: \(1, -2, 3, -4, 5, -6, \ldots, 19, -20\).
Contruya el vector: \(0.1^3, 0.2^1, 0.1^6, 0.2^4, . . . , 0.1^{36}, 0.2^{34}\).
Evaluar la siguiente suma \(\sum_{i=3}^{i=7}e^i\). Hint: use la función
sum
.Calcule las siguientes sumas \(\sum_{i=10}^{100}(i^3+4i^2)\) y \(\sum_{i=1}^{25}\left( \frac{2^i}{i} + \frac{3^i}{i^2} \right)\). Hint: use la función
sum
.Calcular \(8!\). Hint: use la función
prod
.Evaluar la siguiente productoria \(\prod_{i=1}^{i=10}\log\sqrt{i}\).
Construya un vector cualquiera e inviertalo, es decir, que el primer elemento quede de último, el segundo de penúltimo y así sucesivamente. Compare su resultado con el de la función
rev
.Encuentre con R las ocho “pintas” de ropa o combinaciones que se pueden hacer con el siguiente vestuario. Hint: use la función
expand.grid
.
- Encuentre la unión de los vectores (o conjuntos) siguientes usando R. Hint: use la función
union
.
- Suponga que se tienen los siguientes vectores A y B. ¿Cuál es el resultado de quitarle al vector A el vector B? Tenga en cuenta que el orden, a A se le quita B, no lo contrario. Hint: use la función
setdiff
.
- Abajo se tiene un vector con las edades de varias personas. Calcule la edad para la cual una persona se puede considerar que está en el grupo del 30% de las viejas. En otras palabras, queremos calcular el cuantil 0.30. Hint: use la función
quantile
.
- Use la función
sample
para sacar muestras de tres personas del siguiente vector:
Read the data set available in: https://raw.githubusercontent.com/fhernanb/datos/master/Paises.txt
Use a code to obtain the number of variables of the data set.
Use a code to obtain the number of countries in the data set.
Which is the country with the higher population?
Which is the country with the lowest literacy rate?
¿Qué valor de verdad tiene la siguiente afirmación? “Los resultados de la función
floor
ytrunc
son siempre los mismos”.
En R hay unas bases de datos incluídas, una de ellas es la base de datos llamada mtcars
. Para conocer las variables que están en mtcars
usted puede escribir en la consola ?mtcars
o también help(mtcars)
. De la base mtcars
obtenga bases de datos que cumplan las siguientes condiciones.
Autos que tengan un rendimiento menor a 18 millas por galón de combustible.
Autos que tengan 4 cilindros.
Autos que pesen más de 2500 libras y tengan transmisión manual.