class: center, middle, inverse, title-slide # Unidad 1.3
Representación gráfica ## Módulo 1 ### ### Daniel Enrique González Gómez
Universidad Javeriana Cali ### 2021-08-06 --- class: inverse <br/><br/><br/> # AGENDA <br/> ## 1. Presentación guía de aprendizaje 1.3 ## 2. Varios --- ## Introducción Una gráfica o una representación gráfica o un gráfico, es un tipo de representación de datos, generalmente cuantitativos, mediante recursos visuales (líneas, vectores, superficies o símbolos), para que se manifieste visualmente la relación matemática o correlación estadística que guardan entre sí. Wikipedia ## Paquetes de R para realizar graficos <img src="img/RStudio.jpeg" width="210"> <img src="img/ggplot2.png" width="200"> <img src="img/highcharter.png" width="200"> <img src="img/shiny.png" width="200"> <img src="img/plotly.png" width="200"> --- ### Gráficos variables cualitativas con R base [//]: <> (---------------------------------------------------------------------) .panelset[ .panel[.panel-name[Grafico de tortas] ```r cc=c(20, 10, 20, 20, 20, 20, 20, 20, 20, 30, 20, 20, 20, 10, 30, 20, 20, 30, 20, 30, 30, 20, 10, 30, 20, 20, 30, 30, 10, 20, 10, 20, 20, 20, 10, 20, 10, 20, 20, 30, 30, 30, 10, 30, 20, 20, 20, 20, 20, 20, 10, 20, 30, 30, 10, 10, 10, 20, 10, 20, 10, 30, 20, 10, 20, 30, 10, 30, 30, 30, 20, 30, 30, 30, 30, 30, 30, 20, 10, 30, 10, 20, 20, 10, 20, 20, 20, 20, 10, 20) labs=c("Ing. Mecánica","Ing. Civil ","Ing.Sistemas") pct=round(table(cc)/sum(table(cc))*100) labs=paste(labs, pct);labs=paste(labs, "%", sep = " ") t1=table(cc) pie(t1, labels=labs, main=" Distribución por carrera") ``` data:image/s3,"s3://crabby-images/273fe/273fe36690b938492afa177752cc6a6a1796504b" alt=""<!-- --> ] [//]: <> (---------------------------------------------------------------------) .panel[.panel-name[Diagrama de barras] ```r ev=table(rbinom(90,5,0.80)); barplot(ev, col=c("red","yellow","orange","green","blue"), main = "Evaluación proceso de inducción") ``` data:image/s3,"s3://crabby-images/5e6db/5e6db94bfcceea2011abe24c65a324ebee48d02b" alt=""<!-- --> ] .panel[.panel-name[Diag. de barras dos variables] ```r counts <- table(mtcars$vs, mtcars$gear); rownames(counts)=c("Montor en linea", "Motor en V") barplot(counts, main="Número de cambios adelante por Tipo de motor", xlab="Número de cambios adelante ",col=c("dodgerblue3","orange"), legend = rownames(counts)) ``` data:image/s3,"s3://crabby-images/b0991/b09918b12846a09cf3b49d7c71fc292eef9914ca" alt=""<!-- --> ] ] [//]: <> (---------------------------------------------------------------------) --- ### Graficas variables cuantitativas con R base .panelset[ .panel[.panel-name[Diag.de arbol] ```r nf=c(4.1, 2.7, 3.1, 3.2, 3.0, 3.2, 2.0, 2.4, 1.6, 3.2, 3.1, 2.6, 2.0, 2.4, 2.8, 3.3, 4.0, 3.4, 3.0, 3.1, 2.7, 2.7, 3.0, 3.8, 3.2, 2.2, 3.5, 3.5, 3.8, 3.5, 3.9, 4.2, 4.3, 3.9, 3.2, 3.5, 3.5, 3.7, 4.1, 3.7, 3.5, 3.6, 3.2, 3.1, 3.4, 3.0, 3.0, 3.0, 2.7, 1.7, 3.6, 2.1, 2.4, 3.0, 3.1, 2.5, 2.5, 3.6, 2.2, 2.4, 3.1, 3.3, 2.7, 3.7, 3.0, 2.7, 3.0, 3.2, 3.1, 2.4, 3.0, 2.7, 2.5, 3.0, 3.0, 3.0, 3.2, 3.1, 3.8, 4.1, 3.7, 3.5, 3.0, 3.7, 3.7, 4.1, 3.7, 3.9, 3.7, 2.0) stem(nf) ``` ``` ## ## The decimal point is at the | ## ## 1 | 67 ## 2 | 00012244444 ## 2 | 555677777778 ## 3 | 0000000000000011111111222222223344 ## 3 | 555555566677777777888999 ## 4 | 0111123 ``` ] .panel[.panel-name[Histograma] ```r h1=hist(nf, main = "Nota final matemáticas fundamentales", xlab = "nota", ylab="frecuencias absolutas", labels=TRUE, col="dodgerblue3", ylim = c(0,30)) abline(v=3,col="red") grid() ``` data:image/s3,"s3://crabby-images/93677/936771a2c287c72a524d49816e38f23a889246e4" alt=""<!-- --> ] .panel[.panel-name[Diag.de Densidad] ```r nf=c(4.1, 2.7, 3.1, 3.2, 3.0, 3.2, 2.0, 2.4, 1.6, 3.2, 3.1, 2.6, 2.0, 2.4, 2.8, 3.3, 4.0, 3.4, 3.0, 3.1, 2.7, 2.7, 3.0, 3.8, 3.2, 2.2, 3.5, 3.5, 3.8, 3.5, 3.9, 4.2, 4.3, 3.9, 3.2, 3.5, 3.5, 3.7, 4.1, 3.7, 3.5, 3.6, 3.2, 3.1, 3.4, 3.0, 3.0, 3.0, 2.7, 1.7, 3.6, 2.1, 2.4, 3.0, 3.1, 2.5, 2.5, 3.6, 2.2, 2.4, 3.1, 3.3, 2.7, 3.7, 3.0, 2.7, 3.0, 3.2, 3.1, 2.4, 3.0, 2.7, 2.5, 3.0, 3.0, 3.0, 3.2, 3.1, 3.8, 4.1, 3.7, 3.5, 3.0, 3.7, 3.7, 4.1, 3.7, 3.9, 3.7, 2.0) plot(density(nf), main="Distribución de las notas de matemátias fundamentales", col="dodgerblue3", lwd=5 ) ``` data:image/s3,"s3://crabby-images/8f575/8f575adb138e655ecacbcb12058efad1b3b5b60d" alt=""<!-- --> ] .panel[.panel-name[Diag.de Cajas] ```r nf=c(4.1, 2.7, 3.1, 3.2, 3.0, 3.2, 2.0, 2.4, 1.6, 3.2, 3.1, 2.6, 2.0, 2.4, 2.8, 3.3, 4.0, 3.4, 3.0, 3.1, 2.7, 2.7, 3.0, 3.8, 3.2, 2.2, 3.5, 3.5, 3.8, 3.5, 3.9, 4.2, 4.3, 3.9, 3.2, 3.5, 3.5, 3.7, 4.1, 3.7, 3.5, 3.6, 3.2, 3.1, 3.4, 3.0, 3.0, 3.0, 2.7, 1.7, 3.6, 2.1, 2.4, 3.0, 3.1, 2.5, 2.5, 3.6, 2.2, 2.4, 3.1, 3.3, 2.7, 3.7, 3.0, 2.7, 3.0, 3.2, 3.1, 2.4, 3.0, 2.7, 2.5, 3.0, 3.0, 3.0, 3.2, 3.1, 3.8, 4.1, 3.7, 3.5, 3.0, 3.7, 3.7, 4.1, 3.7, 3.9, 3.7, 2.0) boxplot(nf, main="Nota final matemáticas fundamentales",col="dodgerblue3") abline(h=3, col="red") ``` data:image/s3,"s3://crabby-images/9b582/9b582716f519ba463dc8715c852881c69988c3bf" alt=""<!-- --> ] .panel[.panel-name[Diag.de cajas~factor] ```r nf=c(4.1, 2.7, 3.1, 3.2, 3.0, 3.2, 2.0, 2.4, 1.6, 3.2, 3.1, 2.6, 2.0, 2.4, 2.8, 3.3, 4.0, 3.4, 3.0, 3.1, 2.7, 2.7, 3.0, 3.8, 3.2, 2.2, 3.5, 3.5, 3.8, 3.5, 3.9, 4.2, 4.3, 3.9, 3.2, 3.5, 3.5, 3.7, 4.1, 3.7, 3.5, 3.6, 3.2, 3.1, 3.4, 3.0, 3.0, 3.0, 2.7, 1.7, 3.6, 2.1, 2.4, 3.0, 3.1, 2.5, 2.5, 3.6, 2.2, 2.4, 3.1, 3.3, 2.7, 3.7, 3.0, 2.7, 3.0, 3.2, 3.1, 2.4, 3.0, 2.7, 2.5, 3.0, 3.0, 3.0, 3.2, 3.1, 3.8, 4.1, 3.7, 3.5, 3.0, 3.7, 3.7, 4.1, 3.7, 3.9, 3.7, 2.0) cc=c(20, 10, 20, 20, 20, 20, 20, 20, 20, 30, 20, 20, 20, 10, 30, 20, 20, 30, 20, 30, 30, 20, 10, 30, 20, 20, 30, 30, 10, 20, 10, 20, 20, 20, 10, 20, 10, 20, 20, 30, 30, 30, 10, 30, 20, 20, 20, 20, 20, 20, 10, 20, 30, 30, 10, 10, 10, 20, 10, 20, 10, 30, 20, 10, 20, 30, 10, 30, 30, 30, 20, 30, 30, 30, 30, 30, 30, 20, 10, 30, 10, 20, 20, 10, 20, 20, 20, 20, 10, 20) labs=c("Ing. Industrial","Administración ","Contaduría ") boxplot((nf~cc),main="Nota final matemáticas fundamentales por carrera", col="dodgerblue3"); abline(h=3, col="red"); abline(h=4, col="blue") ``` data:image/s3,"s3://crabby-images/59425/59425ff47729d2c67caaae527c9dfd3c2f3a6962" alt=""<!-- --> ] .panel[.panel-name[Diag.de Dispersiòn] ```r ed=round(rnorm(90,18,1),1) plot(ed,nf, main="Edad vs Nota final matemáticas fundamentales", ylim = c(0,5), xlab = "Edad", ylab = "Nota final",col="dodgerblue3",pch=19, las=1) grid() ``` data:image/s3,"s3://crabby-images/dba6a/dba6ae3c090705ecfc231b75ae16dc04146a4795" alt=""<!-- --> ] .panel[.panel-name[Series de tiempo] ```r plot(AirPassengers, main="Número de pasajeros por mes", col="dodgerblue3", lwd = 2) ``` data:image/s3,"s3://crabby-images/82268/8226842b4d44cd6fde0416090bdd031b506cfa62" alt=""<!-- --> ] .panel[.panel-name[Resumen] ```r x=rnorm(100,100,20) y=rnorm(100,100,25) z=rbinom(100,4,0.30) t=1:100 par(mfrow=c(1, 5)) pie(table(z)) barplot(table(z)) stem(x) hist(x) boxplot(x) plot(x,y) plot(t,y, type="l") plot(density(x)) ``` ] ] --- [//]: <> (---------------------------------------------------------------------) ### Gráficos con **ggplot2** .pull-left[ + **Data**: capa de los datos + **Aesthetics**: capa estetica (**aes**), definimos las variables a utilizar en el gráfico + **Geometries**: capa de geometrias, se define el tipo de gráfica a realizar + **Facets**: capa de facetas, permite detallar la gráfica por categorias + **Statistics**: capa de estadística, permite agregar modelos + **Coordinates**: capa de coordenadas, permite ajustar las escalas de los ejes + **Theme**: capas de características del gráfico que no dependen de los datos ] .pull-right[ data:image/s3,"s3://crabby-images/552d3/552d360568f5844cb6a96e7d93cc3ae184226d4d" alt="" ] **Gramática de los gráficos** --- .pull-left[ [Visualización de datos con ggplot2](https://rstudio.com/wp-content/uploads/2015/03/ggplot2-cheatsheet.pdf) ```r library(readr) library(ggplot2) clasificacion=read.csv("data/futbol.csv") ggplot(clasificacion, aes(x=off , y=def)) ``` data:image/s3,"s3://crabby-images/e9a8c/e9a8cdca7c512aad3f7890e68b407d72b0ee4b87" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/f159b/f159b122f78c568ced91f1221aea63d9d9839cfd" alt="" ] --- .pull-left[ ```r ggplot(clasificacion, aes(x=off , y=def))+ geom_point() ``` data:image/s3,"s3://crabby-images/aefe3/aefe313a9ca6dd8b24cca1644063449579290417" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/ff340/ff3405d2536a0ee0aca7b3fb324860581b96471f" alt="" ] --- .pull-left[ ```r ggplot(clasificacion, aes(x=off , y=def))+ geom_point() ``` data:image/s3,"s3://crabby-images/311f5/311f5413a8e45d1c208c32d0edff4a7142915cfd" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/0ff24/0ff24d27cf750ef5be30e28979d4641641cfa3d6" alt="" + geo_point() + geom_bar() geom_col() stat_count() + geom_boxplot() stat_boxplot() + geom_density() stat_density() + geom_histogram() + geom_violin() + ... ] --- .pull-left[ ```r ggplot(clasificacion, aes(x=off , y=def))+ geom_point()+ facet_wrap(~ confed) ``` data:image/s3,"s3://crabby-images/95e56/95e56aacbd1ecd7fd05f630a89978e54d19f0397" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/20ebb/20ebbc6ad3826c95db7fcc080abf2d4c94016054" alt="" ] --- .pull-left[ ```r ggplot(clasificacion, aes(x=off , y=def))+ geom_point()+ facet_wrap(~ confed)+ stat_smooth(method = "loess" , formula =y ~ x) ``` data:image/s3,"s3://crabby-images/a3127/a312796e82ac78ff3fad84e386692bc1d2ccd71d" alt=""<!-- --> ] .pull-right[ data:image/s3,"s3://crabby-images/906c1/906c18f0699f0d4405a4ea2d692b563a0279007f" alt="" ] --- .pull-left[ data:image/s3,"s3://crabby-images/a4e61/a4e61f9660299fb7fae2fbbc0e2bc2c3403260e3" alt="" ] .pull-right[ ```r ggplot(clasificacion, aes(x=off , y=def))+ geom_point()+ facet_wrap(~ confed)+ stat_smooth(method = "loess" , formula =y ~ x)+ coord_cartesian(ylim = c(0, 10)) ``` data:image/s3,"s3://crabby-images/707df/707df6a6518077fcdc3980da47b7e22b24916aee" alt=""<!-- --> ] --- ```r library(ggplot2) data=data.frame(grupo=c("A","B","E"),frecuencia=c(26,35,19)) ggplot(data, aes(x=grupo, y=frecuencia)) + geom_bar(stat="identity", fill="steelblue")+ geom_text(aes(label=grupo), vjust=1.6, color="white", size=3.5)+ theme_minimal() ``` data:image/s3,"s3://crabby-images/c3707/c3707d89fa6905b786e3f054ae9d905fe356706c" alt=""<!-- --> --- ```r library(ggplot2) ggplot(mtcars, aes(x=mpg, y=wt, colour = cyl)) + geom_point() ``` data:image/s3,"s3://crabby-images/dbdf5/dbdf516545a04e3fcd7c0aee6016f241d6c3e3e3" alt=""<!-- --> --- ```r data("iris") ggplot(iris, aes(Sepal.Length)) + geom_histogram(bins = 7,fill="#69b3a2", color="#e9ecef", alpha=0.9)+ theme_minimal() + labs(x = "Nota", y = "n") + ggtitle(" Promedio acumulado estudiantes de PyE 2021-1") ``` data:image/s3,"s3://crabby-images/b8faf/b8faff235f3720f37516281b581070764eb83f99" alt=""<!-- --> --- ```r library(ggplot2) ventas = read.csv("data/ventas.csv") ggplot(ventas, aes(x=Edad, y=Tipo_Cliente)) + geom_boxplot(fill="#313ae8", # color de relleno color="#bf6f2e", # color de lineas alpha=0.5)+ geom_point(color="#b431e8",alpha=0.9) ``` data:image/s3,"s3://crabby-images/e0b4c/e0b4c2aa3104fec7a13bf7f8a0efc72ec8079680" alt=""<!-- --> ```r # Colour picker ``` [Análisis de datos con R Cap,7 ggplot2](https://rafalab.github.io/dslibro/ggplot2.html)<br/> [ggplot2 resumen](https://rstudio.com/wp-content/uploads/2015/03/ggplot2-cheatsheet.pdf) --- ## Gráficos con highcharter <img src="img/highcharter.png" width="300"> https://jkunst.com/highcharter/ https://rstudio-pubs-static.s3.amazonaws.com/320413_6ab300527e8548b1a3cbd0d4c6200fcc.html --- ## Gráficos con plotly <img src="img/plotly.png" width="300"> https://plotly.com/r/ https://plotly-r.com/ --- ## Gráficos con Shiny <img src="img/shiny.png" width="300"> + [Genoma humano](https://shiny.rstudio.com/gallery/genome-browser.html) + [Paquetes de R](https://gallery.shinyapps.io/087-crandash/) + [Galeria](https://shiny.rstudio.com/gallery/) --- ### RMarkdown <img src="img/hex-rmarkdown.png" width="300"> [RMarkdown resumen](https://rstudio.com/wp-content/uploads/2015/02/rmarkdown-cheatsheet.pdf)<br/> [R flexdashboard - ejemplo](https://rpubs.com/joscani/flexdashboard_examples)<br/> [R flexdashboard - implementaciòn](https://geoprocesamiento-2020i.github.io/tutorial-flexdashboard/) --- class: inverse, center background-image: url("img/pujcali.jpeg") <br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/><br/> ### <p style="color:yellow"> Una imagen dice mas que mil palabras... </p> ##### <p style="color:yellow"> Daniel Enrique González Gómez </p> Imagen tomada de :https://javerianacali.edu.co/noticias/la-javeriana-bogota-y-cali-1-de-colombia