Importar la base de datos

El reconocimiento Óptico de Caractéres (OCR) es una tecnología utilizada para convertir diferentes tipos de documentos, como imágenes, documentos impresos o escaneados, fotografías de texto, archivos PDF o imagenes capturadas con una cámara, en datos editables y buscables.

Nota: en reconocimiento de placas de estacionamiento hasta se podría usar para hacer campañas segmentadas y dirigidas a los clientes. Se puede checar tipo de vehiculo con placas.

La Minería de Datos (TM) es el proceso de extraer información útil, patrones o conocimiento de textos no estructurado.

Consta de 3 estapas: 1.- Obtener Datos: El Reconocimiento Óptico de Caracteres (OCR), es la tecnología que permite convertir imágenes de texto en texto editable. También es conocido como extracción de texto en imágenees. 2.- Explorar datos: Representación gráfica y visual de los datos para su interpretación. análisis de sentimientos, la nube de palabras y el Topic Modelling. 3.- Análisis predictivo: Son las técnicas y modelos estadísticos para predecir resultados futuros. Los modelos más usados son el Random forest, Redes Neuronales y Regresiones.

Instalar paquetes y llamar librerías

#install.packages("tidyverse") # Manipulación de datos
library(tidyverse)
#install.packages("tesseract") # OCR
library(tesseract)
#install.packages("magick") # PNG
library(magick)
#install.packages("officer") # Office (Word)
library(officer)
#install.packages("pdftools") # PDF
library(pdftools)
#install.packages("purrr") # Para la función "map" para aplicar una función a cada elemento de un vector
library(purrr)
#install.packages("syuzhet") # Para análisis de sentimiento
library(syuzhet)
#install.packages("tm") # Para minería de texto
library(tm)
#install.packages("wordcloud") # Para nubes de palabras
library(wordcloud)
#install.packages("RColorBrewer") # Para colores
library(RColorBrewer)

De Imagen PNG a texto en Word

# Esto funciona en textos en ingles
imagen1 <- image_read("/Users/humbertocs/Desktop/Tec/Concentración IA/M2_Programacion R IA/OCR/imagen1.PNG")

texto1 <- ocr(imagen1)
texto1
## [1] "Linear regression with one variable x is also known as univariate linear regression\nor simple linear regression. Simple linear regression is used to predict a single\noutput from a single input. This is an example of supervised learning, which means\nthat the data is labeled, i.e., the output values are known in the training data. Let us\nfit a line through the data using simple linear regression as shown in Fig. 4.1.\n"
doc1 <- read_docx() # Crea un documento de word en blanco
doc1 <- doc1 %>% body_add_par(texto1)
print(doc1, target="texto1.docx") # Guarda el documento en la computadora

De Imagen PNG ESPAÑOL a texto en Word

imagen2 <- image_read("/Users/humbertocs/Desktop/Tec/Concentración IA/M2_Programacion R IA/OCR/imagen2.PNG")
# Esto funciona en textos en español o cualquier idioma (cambiar spa)

tesseract_download("spa")
## [1] "/Users/humbertocs/Library/Application Support/tesseract5/tessdata/spa.traineddata"
texto2 <- ocr(imagen2, engine = tesseract("spa"))
texto2
## [1] "Un importante, y quizá controversial, asunto político es el que se refiere al efecto del salario mínimo sobre\nlas tasas de desempleo en diversos grupos de trabajadores. Aunque este problema puede ser estudiado con\ndiversos tipos de datos (corte transversal, series de tiempo o datos de panel), suelen usarse las series de\ntiempo para observar los efectos agregados. En la tabla 1.3 se presenta un ejemplo de una base de datos\nde series de tiempo sobre tasas de desempleo y salarios mínimos.\n"
doc2 <- read_docx() # Crea un documento de word en blanco
doc2 <- doc2 %>% body_add_par(texto2)
print(doc2, target="texto2.docx") # Guarda el documento en la computadora

De PDF a texto en Word

# Esto funciona en textos en ingles
pdf_eso <- pdf_convert("/Users/humbertocs/Desktop/Tec/Concentración IA/M2_Programacion R IA/OCR/eso.pdf") %>% map(ocr)
## Converting page 1 to eso_1.png... done!
## Converting page 2 to eso_2.png... done!
### repetir analsisi anterior
imagen_eso1 <- image_read("/Users/humbertocs/Desktop/Tec/Concentración IA/M2_Programacion R IA/OCR/eso_1.png")


texto2 <- ocr(imagen_eso1, engine = tesseract("spa"))
texto2
## [1] "L DESPUÉS DE LA INUNDACIÓN (1957)\nEl terror, que no terminaría por otros veintiocho años —si es que terminó alguna vez—,\ncomenzó, hasta donde sé o puedo contar, con un barco hecho de una hoja de un diario\nque flotaba a lo largo del arroyo de una calle anegada de lluvia.\nEl barquito cabeceó, se ladeó, volvió a enderezarse en medio de traicioneros remolinos y\ncontinuó su marcha por Witcham Street hacia el semáforo que marcaba la intersección\nde ésta y Jackson. Las tres lentes verticales a los lados del semáforo estaban a oscuras y\ntambién todas las casas, en aquella tarde de otoño de 1957. Llovía sin cesar desde hacía\nya una semana y dos dias atrás habían llegado también los vientos, Desde entonces, la\nmayor parte de Derry había quedado sin corriente eléctrica y aún seguia asi.\nUn chiquillo de impermeable amarillo y botas rojas seguía alegremente al barco de\npapel. La lluvia no había cesado, pero al fin estaba amainando. Golpeteaba sobre la\ncapucha amarilla del impermeable sonando a los oídos del niño como lluvia sobre el\ntejado de un cobertizo.. un sonido reconfortante, casi acogedor. El niño del impermeable\namarillo era George Denbrough. Tenía seis años. William, su hermano, a quien casi todos\nlos niños de la escuela primaria de Derry (y hasta los maestros, aunque jamás habrían\nusado el apodo frente a él) conocian como Bill el Tartaja. estaba en su casa pasando los\nrestos de una gripe bastante seria. En ese otoño de 1957, ocho meses antes de que\n'comenzasen realmente los horrores y veintiocho años antes del desenlace final, Bill el\nTartaja tenía diez años.\nEra Bill quien había hecho el barquito junto al cual corría George. Lo había hecho sentado.\n'en su cama, con la espalda apoyada en un montón de almohadas, mientras la madre.\ntocaba Para Elisa en el piano de la sala y la lluvia barría incansablemente la ventana de su\ndormitorio.\nA untercio de manzana, camino de la intersección y del semáforo apagado, Witcham\nStreet estaba cerrada al tráfico por varios toneles de brea y cuatro caballetes color\nnaranja. En cada uno de esos caballetes se leia: AYUNTAMIENTO DE DERRY -\nDEPARTAMENTO DE OBRAS PÚBLICAS. Tras ellos, la lluvia habia desbordado\nalcantarillas atascadas con ramas, piedras y cúmulos de pegajosas hojas otoñales. El\nagua había ido picando el pavimento al principio, arrancado luego grandes trozos\ncodiciosos: todo esto, hacia el tercer día de las lluvias. Hacia el mediodía de la cuarta\njornada, grandes trozos de pavimento eran arrastrados por la intersección de Jackson y\nWitcham como témpanos de hielo en miniatura. Muchos habitantes de Derry habían\nempezado por entonces a hacer chistes nerviosos sobre el Arca, El Departamento de\nObras Públicas se las había arreglado para mantener abierta Jackson Street, pero\nWitcham estaba intransitable desde las barreras hasta el centro mismo de la ciudad.\nTodos estaban de acuerdo, sin embargo, en que lo peor había pasado. El río Kenduskeag\nhabía crecido casi hasta sus márgenes en los eriales y hasta muy pocos centimetros por\ndebajo de los muros de cemento del canal que constreñía su paso por el centro de la\nciudad. En esos momentos, un grupo de hombres —entre ellos Zack Denbrough, el padre\nde George y de Bill — estaba retirando los sacos de arena que habían lanzado el día\nanterior con aterrorizada prisa. Un día antes, la inundación y sus costosos daños habían\nparecido casi inevitables. Bien sabía Dios que ya había ocurrido anteriormente —la\n"
doc2 <- read_docx() # Crea un documento de word en blanco
doc2 <- doc2 %>% body_add_par(texto2)
print(doc2, target="texto2.docx") # Guarda el documento en la computadora

Análisis de Emociones y Sentimientos

texto <- pdf_eso
texto_palabras <- get_tokens(texto)
emociones <- get_nrc_sentiment(texto_palabras, language = "spanish")
# Alegría, tristeza, ira, miedo, sorpresa, asco, anticipación, confianza
barplot(colSums(prop.table(emociones[,1:8])))

sentimientos <- (emociones$negative*-1)+emociones$positive
simple_plot(sentimientos)

# Nube de Palabras

palabras <- texto_palabras
palabras <- removeWords(palabras, c(stopwords("spanish")))
wordcloud(words=palabras, min.freq=2, rot.per=0, random.order=FALSE)
## Warning in tm_map.SimpleCorpus(corpus, tm::removePunctuation): transformation
## drops documents
## Warning in tm_map.SimpleCorpus(corpus, function(x) tm::removeWords(x,
## tm::stopwords())): transformation drops documents

LS0tCnRpdGxlOiAiT0NSIgphdXRob3I6ICJIdW1iZXJ0byBDb3J0w6lzIFNhbGRhw7FhIgpkYXRlOiAiMjAyNS0wOC0yMCIKb3V0cHV0OiAKICBodG1sX2RvY3VtZW50OgogICAgdG9jOiBUUlVFCiAgICB0b2NfZmxvYXQ6IFRSVUUKICAgIGNvZGVfZG93bmxvYWQ6IFRSVUUKICAgIHRoZW1lOiBzaW1wbGV4CiAgCi0tLQoKYGBge3Igc2V0dXAsIGluY2x1ZGU9RkFMU0V9CmtuaXRyOjpvcHRzX2NodW5rJHNldChlY2hvID0gVFJVRSkKYGBgCiFbXShodHRwczovL2Jsb2dnZXIuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2ltZy9iL1IyOXZaMnhsL0FWdlhzRWlaRFdUc3dJSElpemFyMTFtcUZCbWpnWUlMLVA0XzdyNzNNM1ZYbEhsbUU1bmRVVlRaUUItajFyMGRDc244LUNxdWctdlU3RVFfd1YtY1JsMmppeWUycDdSelhzRll6ZWNNYUxESGlVd0FjMXNUUHBzMlZRZzlxQTNBZ1pwak9xb2pucmhqeTZSNU1kYldvb0trdy10QmRIbmdFVEIyeHg4aEdLSGpyUVdQS1ZoMkNIelpoM1pvdlF1V3BOWjEvczQwMC90dW1ibHJfbWxoN3lzcGUyaDFycDB2a2pvMV80MDAuZ2lmKQoKIyA8c3BhbiBzdHlsZT0iY29sb3I6YmxhY2s7Ij4gSW1wb3J0YXIgbGEgYmFzZSBkZSBkYXRvcyA8L3NwYW4+CkVsICoqcmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3TDqXJlcyAoT0NSKSoqIGVzIHVuYSB0ZWNub2xvZ8OtYSB1dGlsaXphZGEgcGFyYSBjb252ZXJ0aXIgZGlmZXJlbnRlcyB0aXBvcyBkZSBkb2N1bWVudG9zLCBjb21vIGltw6FnZW5lcywgZG9jdW1lbnRvcyBpbXByZXNvcyBvIGVzY2FuZWFkb3MsIGZvdG9ncmFmw61hcyBkZSB0ZXh0bywgYXJjaGl2b3MgUERGIG8gaW1hZ2VuZXMgY2FwdHVyYWRhcyBjb24gdW5hIGPDoW1hcmEsIGVuIGRhdG9zIGVkaXRhYmxlcyB5IGJ1c2NhYmxlcy4KCk5vdGE6IGVuIHJlY29ub2NpbWllbnRvIGRlIHBsYWNhcyBkZSBlc3RhY2lvbmFtaWVudG8gaGFzdGEgc2UgcG9kcsOtYSB1c2FyIHBhcmEgaGFjZXIgY2FtcGHDsWFzIHNlZ21lbnRhZGFzIHkgZGlyaWdpZGFzIGEgbG9zIGNsaWVudGVzLiBTZSBwdWVkZSBjaGVjYXIgdGlwbyBkZSB2ZWhpY3VsbyBjb24gcGxhY2FzLgoKTGEgKipNaW5lcsOtYSBkZSBEYXRvcyAoVE0pKiogZXMgZWwgcHJvY2VzbyBkZSBleHRyYWVyIGluZm9ybWFjacOzbiDDunRpbCwgcGF0cm9uZXMgbyBjb25vY2ltaWVudG8gZGUgdGV4dG9zIG5vIGVzdHJ1Y3R1cmFkby4KCkNvbnN0YSBkZSAzIGVzdGFwYXM6CjEuLSAqKk9idGVuZXIgRGF0b3MqKjogRWwgUmVjb25vY2ltaWVudG8gw5NwdGljbyBkZSBDYXJhY3RlcmVzIChPQ1IpLCBlcyBsYSB0ZWNub2xvZ8OtYSBxdWUgcGVybWl0ZSBjb252ZXJ0aXIgaW3DoWdlbmVzIGRlIHRleHRvIGVuIHRleHRvIGVkaXRhYmxlLiBUYW1iacOpbiBlcyBjb25vY2lkbyBjb21vIGV4dHJhY2Npw7NuIGRlIHRleHRvIGVuIGltw6FnZW5lZXMuCjIuLSAqKkV4cGxvcmFyIGRhdG9zKio6IFJlcHJlc2VudGFjacOzbiBncsOhZmljYSB5IHZpc3VhbCBkZSBsb3MgZGF0b3MgcGFyYSBzdSBpbnRlcnByZXRhY2nDs24uIGFuw6FsaXNpcyBkZSBzZW50aW1pZW50b3MsIGxhIG51YmUgZGUgcGFsYWJyYXMgeSBlbCAqVG9waWMgTW9kZWxsaW5nKi4gCjMuLSAqKkFuw6FsaXNpcyBwcmVkaWN0aXZvKio6IFNvbiBsYXMgdMOpY25pY2FzIHkgbW9kZWxvcyBlc3RhZMOtc3RpY29zIHBhcmEgcHJlZGVjaXIgcmVzdWx0YWRvcyBmdXR1cm9zLiBMb3MgbW9kZWxvcyBtw6FzIHVzYWRvcyBzb24gZWwgKlJhbmRvbSBmb3Jlc3QsIFJlZGVzIE5ldXJvbmFsZXMgeSBSZWdyZXNpb25lcyouCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpibGFjazsiPiBJbnN0YWxhciBwYXF1ZXRlcyB5IGxsYW1hciBsaWJyZXLDrWFzIDwvc3Bhbj4KCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0UsIHBhZ2VkLnByaW50PUZBTFNFfQojaW5zdGFsbC5wYWNrYWdlcygidGlkeXZlcnNlIikgIyBNYW5pcHVsYWNpw7NuIGRlIGRhdG9zCmxpYnJhcnkodGlkeXZlcnNlKQojaW5zdGFsbC5wYWNrYWdlcygidGVzc2VyYWN0IikgIyBPQ1IKbGlicmFyeSh0ZXNzZXJhY3QpCiNpbnN0YWxsLnBhY2thZ2VzKCJtYWdpY2siKSAjIFBORwpsaWJyYXJ5KG1hZ2ljaykKI2luc3RhbGwucGFja2FnZXMoIm9mZmljZXIiKSAjIE9mZmljZSAoV29yZCkKbGlicmFyeShvZmZpY2VyKQojaW5zdGFsbC5wYWNrYWdlcygicGRmdG9vbHMiKSAjIFBERgpsaWJyYXJ5KHBkZnRvb2xzKQojaW5zdGFsbC5wYWNrYWdlcygicHVycnIiKSAjIFBhcmEgbGEgZnVuY2nDs24gIm1hcCIgcGFyYSBhcGxpY2FyIHVuYSBmdW5jacOzbiBhIGNhZGEgZWxlbWVudG8gZGUgdW4gdmVjdG9yCmxpYnJhcnkocHVycnIpCiNpbnN0YWxsLnBhY2thZ2VzKCJzeXV6aGV0IikgIyBQYXJhIGFuw6FsaXNpcyBkZSBzZW50aW1pZW50bwpsaWJyYXJ5KHN5dXpoZXQpCiNpbnN0YWxsLnBhY2thZ2VzKCJ0bSIpICMgUGFyYSBtaW5lcsOtYSBkZSB0ZXh0bwpsaWJyYXJ5KHRtKQojaW5zdGFsbC5wYWNrYWdlcygid29yZGNsb3VkIikgIyBQYXJhIG51YmVzIGRlIHBhbGFicmFzCmxpYnJhcnkod29yZGNsb3VkKQojaW5zdGFsbC5wYWNrYWdlcygiUkNvbG9yQnJld2VyIikgIyBQYXJhIGNvbG9yZXMKbGlicmFyeShSQ29sb3JCcmV3ZXIpCgpgYGAKIyA8c3BhbiBzdHlsZT0iY29sb3I6YmxhY2s7Ij4gRGUgSW1hZ2VuIFBORyBhIHRleHRvIGVuIFdvcmQgPC9zcGFuPgoKCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0UsIHBhZ2VkLnByaW50PUZBTFNFfQojIEVzdG8gZnVuY2lvbmEgZW4gdGV4dG9zIGVuIGluZ2xlcwppbWFnZW4xIDwtIGltYWdlX3JlYWQoIi9Vc2Vycy9odW1iZXJ0b2NzL0Rlc2t0b3AvVGVjL0NvbmNlbnRyYWNpw7NuIElBL00yX1Byb2dyYW1hY2lvbiBSIElBL09DUi9pbWFnZW4xLlBORyIpCgp0ZXh0bzEgPC0gb2NyKGltYWdlbjEpCnRleHRvMQpkb2MxIDwtIHJlYWRfZG9jeCgpICMgQ3JlYSB1biBkb2N1bWVudG8gZGUgd29yZCBlbiBibGFuY28KZG9jMSA8LSBkb2MxICU+JSBib2R5X2FkZF9wYXIodGV4dG8xKQpwcmludChkb2MxLCB0YXJnZXQ9InRleHRvMS5kb2N4IikgIyBHdWFyZGEgZWwgZG9jdW1lbnRvIGVuIGxhIGNvbXB1dGFkb3JhCgpgYGAKIyA8c3BhbiBzdHlsZT0iY29sb3I6YmxhY2s7Ij4gRGUgSW1hZ2VuIFBORyBFU1BBw5FPTCBhIHRleHRvIGVuIFdvcmQgPC9zcGFuPgoKYGBge3IgbWVzc2FnZT1GQUxTRSwgd2FybmluZz1GQUxTRSwgcGFnZWQucHJpbnQ9RkFMU0V9CmltYWdlbjIgPC0gaW1hZ2VfcmVhZCgiL1VzZXJzL2h1bWJlcnRvY3MvRGVza3RvcC9UZWMvQ29uY2VudHJhY2nDs24gSUEvTTJfUHJvZ3JhbWFjaW9uIFIgSUEvT0NSL2ltYWdlbjIuUE5HIikKIyBFc3RvIGZ1bmNpb25hIGVuIHRleHRvcyBlbiBlc3Bhw7FvbCBvIGN1YWxxdWllciBpZGlvbWEgKGNhbWJpYXIgc3BhKQoKdGVzc2VyYWN0X2Rvd25sb2FkKCJzcGEiKQoKdGV4dG8yIDwtIG9jcihpbWFnZW4yLCBlbmdpbmUgPSB0ZXNzZXJhY3QoInNwYSIpKQp0ZXh0bzIKZG9jMiA8LSByZWFkX2RvY3goKSAjIENyZWEgdW4gZG9jdW1lbnRvIGRlIHdvcmQgZW4gYmxhbmNvCmRvYzIgPC0gZG9jMiAlPiUgYm9keV9hZGRfcGFyKHRleHRvMikKcHJpbnQoZG9jMiwgdGFyZ2V0PSJ0ZXh0bzIuZG9jeCIpICMgR3VhcmRhIGVsIGRvY3VtZW50byBlbiBsYSBjb21wdXRhZG9yYQoKYGBgCgojIDxzcGFuIHN0eWxlPSJjb2xvcjpibGFjazsiPiBEZSBQREYgYSB0ZXh0byBlbiBXb3JkIDwvc3Bhbj4KCmBgYHtyIG1lc3NhZ2U9RkFMU0UsIHdhcm5pbmc9RkFMU0UsIHBhZ2VkLnByaW50PUZBTFNFfQojIEVzdG8gZnVuY2lvbmEgZW4gdGV4dG9zIGVuIGluZ2xlcwpwZGZfZXNvIDwtIHBkZl9jb252ZXJ0KCIvVXNlcnMvaHVtYmVydG9jcy9EZXNrdG9wL1RlYy9Db25jZW50cmFjacOzbiBJQS9NMl9Qcm9ncmFtYWNpb24gUiBJQS9PQ1IvZXNvLnBkZiIpICU+JSBtYXAob2NyKQoKIyMjIHJlcGV0aXIgYW5hbHNpc2kgYW50ZXJpb3IKaW1hZ2VuX2VzbzEgPC0gaW1hZ2VfcmVhZCgiL1VzZXJzL2h1bWJlcnRvY3MvRGVza3RvcC9UZWMvQ29uY2VudHJhY2nDs24gSUEvTTJfUHJvZ3JhbWFjaW9uIFIgSUEvT0NSL2Vzb18xLnBuZyIpCgoKdGV4dG8yIDwtIG9jcihpbWFnZW5fZXNvMSwgZW5naW5lID0gdGVzc2VyYWN0KCJzcGEiKSkKdGV4dG8yCmRvYzIgPC0gcmVhZF9kb2N4KCkgIyBDcmVhIHVuIGRvY3VtZW50byBkZSB3b3JkIGVuIGJsYW5jbwpkb2MyIDwtIGRvYzIgJT4lIGJvZHlfYWRkX3Bhcih0ZXh0bzIpCnByaW50KGRvYzIsIHRhcmdldD0idGV4dG8yLmRvY3giKSAjIEd1YXJkYSBlbCBkb2N1bWVudG8gZW4gbGEgY29tcHV0YWRvcmEKCgoKYGBgCgoKIyA8c3BhbiBzdHlsZT0iY29sb3I6YmxhY2s7Ij4gQW7DoWxpc2lzIGRlIEVtb2Npb25lcyB5IFNlbnRpbWllbnRvcyA8L3NwYW4+CgpgYGB7ciBtZXNzYWdlPUZBTFNFLCB3YXJuaW5nPUZBTFNFLCBwYWdlZC5wcmludD1GQUxTRX0KCnRleHRvIDwtIHBkZl9lc28KdGV4dG9fcGFsYWJyYXMgPC0gZ2V0X3Rva2Vucyh0ZXh0bykKZW1vY2lvbmVzIDwtIGdldF9ucmNfc2VudGltZW50KHRleHRvX3BhbGFicmFzLCBsYW5ndWFnZSA9ICJzcGFuaXNoIikKIyBBbGVncsOtYSwgdHJpc3RlemEsIGlyYSwgbWllZG8sIHNvcnByZXNhLCBhc2NvLCBhbnRpY2lwYWNpw7NuLCBjb25maWFuemEKYmFycGxvdChjb2xTdW1zKHByb3AudGFibGUoZW1vY2lvbmVzWywxOjhdKSkpCnNlbnRpbWllbnRvcyA8LSAoZW1vY2lvbmVzJG5lZ2F0aXZlKi0xKStlbW9jaW9uZXMkcG9zaXRpdmUKc2ltcGxlX3Bsb3Qoc2VudGltaWVudG9zKQpgYGAKIyA8c3BhbiBzdHlsZT0iY29sb3I6cmVkIj4gTnViZSBkZSBQYWxhYnJhcyA8L3NwYW4+CmBgYHtyfQpwYWxhYnJhcyA8LSB0ZXh0b19wYWxhYnJhcwpwYWxhYnJhcyA8LSByZW1vdmVXb3JkcyhwYWxhYnJhcywgYyhzdG9wd29yZHMoInNwYW5pc2giKSkpCndvcmRjbG91ZCh3b3Jkcz1wYWxhYnJhcywgbWluLmZyZXE9Miwgcm90LnBlcj0wLCByYW5kb20ub3JkZXI9RkFMU0UpCgpgYGAKCgoK