Aumenta la productividad con el ecosistema de Keras

Rate this content
Bookmark

TensorFlow ha construido una sólida base para diversas aplicaciones de aprendizaje automático, sobre la cual el ecosistema de Keras puede realmente aumentar la productividad de los desarrolladores en la construcción de soluciones de aprendizaje automático. Keras tiene una API simple y arbitrariamente flexible para construir y entrenar modelos. Sin embargo, todavía necesitamos mucho trabajo manual para ajustar los hiperparámetros. Afortunadamente, con Keras Tuner, podemos automatizar el proceso de ajuste de hiperparámetros con modificaciones menores en el código para construir y entrenar los modelos. Para aumentar aún más la productividad, presentamos AutoKeras, que automatiza completamente el proceso de construcción de modelos, entrenamiento y ajuste de hiperparámetros. Reduce drásticamente la cantidad de conocimientos previos necesarios para utilizar el aprendizaje automático en algunas tareas comunes. Todo lo que necesitas es definir la tarea y proporcionar los datos de entrenamiento.

This talk has been presented at ML conf EU 2020, check out the latest edition of this Tech Conference.

FAQ

TensorFlow es una plataforma de código abierto para aprendizaje automático que proporciona una base sólida para construir y entrenar modelos de aprendizaje profundo. Keras, por otro lado, es una API de alto nivel que se construye sobre TensorFlow, simplificando muchas de las operaciones complejas y ofreciendo una forma más accesible para implementar soluciones de aprendizaje profundo.

Las características principales de TensorFlow destacadas incluyen manipulación de tensores, diferenciación automática, implementación versátil en diversas plataformas y rendimiento optimizado para operaciones con GPUs y TPUs.

Keras simplifica el proceso de modelado al permitir a los usuarios construir modelos a través de una interfaz de alto nivel, donde se pueden agregar capas secuenciales fácilmente sin tener que manejar las complejidades subyacentes de las operaciones matemáticas y la diferenciación automática.

Keras Tuner es una herramienta dentro del ecosistema de Keras diseñada para la sintonización automática de hiperparámetros. Permite a los usuarios optimizar configuraciones de modelos, como el número de unidades en una capa, mediante algoritmos de búsqueda avanzados para mejorar el rendimiento del modelo.

AutoKeras es una biblioteca de AutoML que simplifica aún más el uso de Keras y TensorFlow, permitiendo a los usuarios construir modelos de aprendizaje profundo con mínimos conocimientos técnicos previos. Está diseñado para reducir la curva de aprendizaje y hacer el aprendizaje automático más accesible para aplicaciones del mundo real.

Un modelo desarrollado con TensorFlow se puede implementar en una variedad de plataformas, incluyendo servidores con TensorFlow Extended, dispositivos de un solo chip como dispositivos Edge con TensorFlow Lite, y en páginas web usando TensorFlow.js.

AutoKeras soporta múltiples tareas como clasificación y regresión de imágenes, clasificación y regresión de datos estructurados, y está en proceso de incluir otras como detección de objetos y pronóstico de series temporales. También permite trabajar con datos de múltiples modelos y tareas simultáneamente.

Haifeng Jin
Haifeng Jin
30 min
02 Jul, 2021

Comments

Sign in or register to post your comment.
Video Summary and Transcription
Esta charla presenta el ecosistema de TensorFlow en Keras y destaca sus características, incluyendo manipulaciones de tensores, diferenciación automática e implementación. También se discute el flujo de trabajo y la automatización de la sintonización de hiperparámetros con Keras Tuner y AutoKeras. La charla enfatiza la simplicidad y productividad de usar AutoKeras, que admite diversas tareas y escenarios avanzados. También menciona los desafíos que enfrentan los principiantes y proporciona recursos para el aprendizaje. Por último, se menciona el uso de TensorFlow y Keras en el ámbito de la investigación y las opciones de personalización en AutoKeras, incluyendo la predicción de series temporales.

1. Introduction to TensorFlow in Keras Ecosystem

Short description:

Hola a todos. Estoy muy feliz de estar aquí en MLConf EU con ustedes y agradezco mucho la invitación. Mi presentación trata sobre aumentar la productividad con el ecosistema de Keras. Vamos a destacar cuatro características de TensorFlow. La primera es para manipulaciones de tensores. La segunda característica es sobre diferenciación automática. Otra característica importante de TensorFlow es sobre implementación. Se puede implementar en cualquier lugar para un modelo implementado con TensorFlow. TensorFlow realmente se trata de rendimiento y escalabilidad. Pero ¿cómo aprovechamos realmente el poder de TensorFlow?

Estoy muy feliz de estar aquí en MLConf EU con ustedes y agradezco mucho la invitación. Y mi presentación trata sobre aumentar la productividad con el ecosistema de Keras.

Entonces hay muchos miembros del ecosistema de Keras y el primero que vamos a presentar es TensorFlow. Creo que muchos de ustedes han oído hablar de él. Es una base muy poderosa para todas las soluciones de aprendizaje profundo construidas sobre ella. Pero hoy, vamos a destacar cuatro características para que vean cómo otros miembros del ecosistema de Keras dependen de estas características para construir algo más.

La primera, todos sabemos que es para manipulaciones de tensores. Como pueden ver, tenemos A y B como matrices de dos por dos aquí, y pueden hacer A más B o C o exponencial de D con ellas. Esto es compatible con TensorFlow, o una fuente de operaciones matemáticas en todos esos tensores. Y la segunda característica que queremos destacar es sobre diferenciación automática. Significa que pueden calcular los gradientes automáticamente sin calcular manualmente ninguna de las derivadas por su cuenta. Nuevamente, tenemos A y B como matrices, dos por dos. Y C está aquí, calculado en realidad a partir de A y B. Obtenemos C. Y ahora queremos calcular el gradiente de C con respecto a A. Y no tienen que hacer ninguna derivada por su cuenta, sino insertando estas líneas. Con gradient tape, watch A, pueden calcular automáticamente C, D, A, solo llamando a tape.gradientCA.

Otra característica importante de TensorFlow que es realmente utilizada por cualquier otra biblioteca en el ecosistema de Keras es sobre implementación. Se puede implementar en cualquier lugar para un modelo implementado con TensorFlow. Por ejemplo, se puede implementar en servidores con TensorFlow Extended. Y se puede implementar en dispositivos de un solo chip como dispositivos Edge con TensorFlow Lite, y también implementar en cualquier página web con tf.js. Y además, TensorFlow realmente se trata de rendimiento y escalabilidad. Se ejecuta en GPUs y TPUs para acelerar todas esas operaciones matemáticas en tensores. También se escala a múltiples servidores con múltiples GPUs y TPUs para hacer que el entrenamiento del modelo sea realmente rápido, y hacer que la predicción del modelo sea realmente rápida, y la implementación del modelo sea realmente rápida. Y eso es sobre TensorFlow. Es una misión muy poderosa para el ecosistema de Keras.

Pero ¿cómo aprovechamos realmente el poder de TensorFlow? Como vimos, la API de TensorFlow es muy de bajo nivel, consiste en muchas operaciones matemáticas. Realmente no quieres implementar muchas soluciones de aprendizaje profundo con todas esas operaciones matemáticas, porque cada solución de aprendizaje profundo puede involucrar cientos de esas operaciones matemáticas. No quieres escribir cada una de ellas en tu código por tu cuenta.

2. Keras: API de alto nivel para TensorFlow

Short description:

Keras se construye sobre TensorFlow y proporciona API de alto nivel que simplifican el aprendizaje profundo. Puedes agregar fácilmente capas a un modelo secuencial y especificar el número de neuronas y funciones de activación. Los cálculos de pérdida y los bucles de entrenamiento se manejan automáticamente. Keras admite una amplia gama de tareas, desde el uso estándar hasta técnicas avanzadas como GANs y capas personalizadas. Para escenarios más complejos, puedes escribir métricas y pérdidas personalizadas, o incluso implementar tus propios algoritmos de optimización utilizando la API de bajo nivel de TensorFlow.

Entonces, por eso vamos a pasar al segundo miembro del ecosistema de Keras, un aprendizaje profundo radicalmente productivo. Para este, en realidad se ha construido sobre TensorFlow y envuelve las API de bajo nivel de TensorFlow en las API de alto nivel, que son realmente simples de usar.

Aquí podemos ver un ejemplo muy simple de código. Simplemente inicializamos un modelo secuencial, que es un tipo de modelo que vamos a implementar en Keras. Y simplemente puedes seguir agregando esas capas al modelo secuencial. Aquí, agregamos una capa densa con 32 neuronas, o unidades, y una función de activación igual a Relu, y otra capa densa a eso. Entonces tenemos un modelo con dos capas densas.

Es muy simple de implementar y realmente no te importa qué operaciones matemáticas están detrás de esas capas densas, aunque en realidad son multiplicaciones de matrices y sumas, pero realmente no necesitas escribirlas tú mismo. Simplemente usas la capa densa y especificas el número de unidades. Y además, no necesitas calcular la pérdida por tu cuenta. Simplemente la pasas como una cadena, entropía cruzada categórica. No haces ningún cálculo, solo una cadena.

Esta pérdida es en realidad para la tarea de clasificación. Y el modelo compensa, simplemente pasas los datos de entrenamiento. No necesitas escribir ningún bucle por tu cuenta, como iterar 20 épocas. Solo pasas los datos y especificas la época como 20. Y luego comienzas a hacer las predicciones con los datos de prueba. Es realmente simple de aprender.

Pero a pesar de la simplicidad, es capaz de muchas cosas. Es capaz de todo lo que admite la API de bajo nivel de TensorFlow. Y solo necesitas aprender lo que necesitas. No queremos que el usuario aprenda todo de antemano, eso es una curva de aprendizaje bastante grande. Comienzan con un ejemplo simple como el que acabamos de mostrar como uso estándar. Puedes usar la API secuencial, API de función y construir y capas.

Pero si apuntas a algo más, por ejemplo, quieres usar TensorBoard y detención temprana o guardar el modelo en el disco con puntos de control mientras los entrenas, simplemente puedes pasar un montón de funciones de devolución de llamada al modelo. Es realmente simple de hacer. Pero si quieres algo aún más, como el modelo GAN o el aprendizaje del currículo, y luego necesitas escribir algunas capas personalizadas o métricas y pérdidas personalizadas, también es muy fácil de implementar simplemente extendiendo las clases base en Keras.

Pero hay casos de uso aún más difíciles, como aprender a aprender o si quieres implementar un nuevo tipo de algoritmo de optimización, en ese caso, tendrás que escribir tu propio bucle de entrenamiento con las operaciones de cinta de gradiente. Y con eso, obtienes total libertad para usar cualquier cosa admitida por TensorFlow en Keras. Así es la lógica del diseño de la API de Keras.

QnA

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

TensorFlow.js 101: Aprendizaje automático en el navegador y más allá
ML conf EU 2020ML conf EU 2020
41 min
TensorFlow.js 101: Aprendizaje automático en el navegador y más allá
TensorFlow.js enables machine learning in the browser and beyond, with features like face mesh, body segmentation, and pose estimation. It offers JavaScript prototyping and transfer learning capabilities, as well as the ability to recognize custom objects using the Image Project feature. TensorFlow.js can be used with Cloud AutoML for training custom vision models and provides performance benefits in both JavaScript and Python development. It offers interactivity, reach, scale, and performance, and encourages community engagement and collaboration between the JavaScript and machine learning communities.
Construye un Sistema Solar 3D con Reconocimiento de Manos y Three.js
JSNation 2022JSNation 2022
36 min
Construye un Sistema Solar 3D con Reconocimiento de Manos y Three.js
Top Content
This Talk explores the use of TypeScript, 3JS, hand recognition, and TensorFlow.js to create 3D experiences on the web. It covers topics such as rendering 3D objects, adding lights and objects, hand tracking, and creating interactive gestures. The speaker demonstrates how to build a cube and a bouncy box, move objects with flick gestures, and create a solar system with stars and planets. The Talk also discusses the possibilities of using hand gestures for web navigation and controlling websites, as well as the performance limits of these technologies.
Uso de MediaPipe para Crear Aplicaciones de Aprendizaje Automático Multiplataforma con React
React Advanced 2021React Advanced 2021
21 min
Uso de MediaPipe para Crear Aplicaciones de Aprendizaje Automático Multiplataforma con React
Top Content
MediaPipe is a cross-platform framework that helps build perception pipelines using machine learning models. It offers ready-to-use solutions for various applications, such as selfie segmentation, face mesh, object detection, hand tracking, and more. MediaPipe can be integrated with React using NPM modules provided by the MediaPipe team. The demonstration showcases the implementation of face mesh and selfie segmentation solutions. MediaPipe enables the creation of amazing applications without needing to understand the underlying computer vision or machine learning processes.
TensorFlow.js 101: Aprendizaje automático en el navegador y más allá
JSNation Live 2021JSNation Live 2021
39 min
TensorFlow.js 101: Aprendizaje automático en el navegador y más allá
JavaScript with TensorFlow.js allows for machine learning in various environments, enabling the creation of applications like augmented reality and sentiment analysis. TensorFlow.js offers pre-trained models for object detection, body segmentation, and face landmark detection. It also allows for 3D rendering and the combination of machine learning with WebGL. The integration of WebRTC and WebXR enables teleportation and enhanced communication. TensorFlow.js supports transfer learning through Teachable Machine and Cloud AutoML, and provides flexibility and performance benefits in the browser and Node.js environments.
Observabilidad con diagnostics_channel y AsyncLocalStorage
Node Congress 2023Node Congress 2023
21 min
Observabilidad con diagnostics_channel y AsyncLocalStorage
Observability with Diagnostics Channel and async local storage allows for high-performance event tracking and propagation of values through calls, callbacks, and promise continuations. Tracing involves five events and separate channels for each event, capturing errors and return values. The span object in async local storage stores data about the current execution and is reported to the tracer when the end is triggered.

Workshops on related topic

Aprovechando LLMs para Construir Experiencias de IA Intuitivas con JavaScript
JSNation 2024JSNation 2024
108 min
Aprovechando LLMs para Construir Experiencias de IA Intuitivas con JavaScript
Featured Workshop
Roy Derks
Shivay Lamba
2 authors
Hoy en día, todos los desarrolladores están utilizando LLMs en diferentes formas y variantes, desde ChatGPT hasta asistentes de código como GitHub CoPilot. Siguiendo esto, muchos productos han introducido capacidades de IA integradas, y en este masterclass haremos que los LLMs sean comprensibles para los desarrolladores web. Y nos adentraremos en la codificación de tu propia aplicación impulsada por IA. No se necesita experiencia previa en trabajar con LLMs o aprendizaje automático. En su lugar, utilizaremos tecnologías web como JavaScript, React que ya conoces y amas, al mismo tiempo que aprendemos sobre algunas nuevas bibliotecas como OpenAI, Transformers.js
¿Pueden los LLM aprender? Personalicemos un LLM para chatear con tus propios datos
C3 Dev Festival 2024C3 Dev Festival 2024
48 min
¿Pueden los LLM aprender? Personalicemos un LLM para chatear con tus propios datos
WorkshopFree
Andreia Ocanoaia
Andreia Ocanoaia
Sientes las limitaciones de los LLMs? Pueden ser creativos, pero a veces carecen de precisión o se basan en información desactualizada. En esta masterclass, desglosaremos el proceso de construir y desplegar fácilmente un sistema de Generación con Recuperación Mejorada. Este enfoque te permite aprovechar el poder de los LLMs con el beneficio adicional de precisión factual e información actualizada.
Deja que la IA sea tu Documentación
JSNation 2024JSNation 2024
69 min
Deja que la IA sea tu Documentación
Workshop
Jesse Hall
Jesse Hall
Únete a nuestro masterclass dinámico para crear un portal de documentación impulsado por IA. Aprende a integrar ChatGPT de OpenAI con Next.js 14, Tailwind CSS y tecnología de vanguardia para ofrecer soluciones de código e resúmenes instantáneos. Esta sesión práctica te equipará con el conocimiento para revolucionar la forma en que los usuarios interactúan con la documentación, convirtiendo las búsquedas tediosas en descubrimientos eficientes e inteligentes.
Aspectos destacados:
- Experiencia práctica en la creación de un sitio de documentación impulsado por IA.- Comprensión de la integración de la IA en las experiencias de usuario.- Habilidades prácticas con las últimas tecnologías de desarrollo web.- Estrategias para implementar y mantener recursos de documentación inteligente.
Tabla de contenidos:- Introducción a la IA en la documentación- Configuración del entorno- Construcción de la estructura de documentación- Integración de ChatGPT para documentación interactiva
Introducción a la IA para Desarrolladores de JavaScript con Tensorflow.js
JSNation Live 2021JSNation Live 2021
81 min
Introducción a la IA para Desarrolladores de JavaScript con Tensorflow.js
Workshop
Chris Achard
Chris Achard
¿Has querido explorar la IA, pero no has querido aprender Python para hacerlo? ¡Tensorflow.js te permite usar IA y aprendizaje profundo en javascript, sin necesidad de Python!
Veremos las diferentes tareas que la IA puede ayudar a resolver y cómo usar Tensorflow.js para resolverlas. No necesitas saber nada de IA para empezar, comenzaremos desde lo básico, pero aún así podremos ver algunas demos interesantes, porque Tensorflow.js tiene muchas funcionalidades y modelos preconstruidos que puedes usar en el servidor o en el navegador.
Después de este masterclass, deberías ser capaz de configurar y ejecutar modelos preconstruidos de Tensorflow.js, o comenzar a escribir y entrenar tus propios modelos con tus propios datos.
Prácticas con TensorFlow.js
ML conf EU 2020ML conf EU 2020
160 min
Prácticas con TensorFlow.js
Workshop
Jason Mayes
Jason Mayes
Ven y descubre nuestro masterclass que te guiará a través de 3 recorridos comunes al usar TensorFlow.js. Comenzaremos demostrando cómo usar uno de nuestros modelos predefinidos, clases de JS muy fáciles de usar para trabajar rápidamente con ML. Luego veremos cómo volver a entrenar uno de estos modelos en minutos utilizando el aprendizaje por transferencia en el navegador a través de Teachable Machine y cómo se puede usar en tu propio sitio web personalizado. Finalmente, terminaremos con un hola mundo escribiendo tu propio código de modelo desde cero para hacer una regresión lineal simple y predecir los precios ficticios de las casas en función de sus metros cuadrados.
La Guía del Autoestopista de la Galaxia de Ingeniería de Aprendizaje Automático
ML conf EU 2020ML conf EU 2020
112 min
La Guía del Autoestopista de la Galaxia de Ingeniería de Aprendizaje Automático
Workshop
Alyona Galyeva
Alyona Galyeva
¿Eres un Ingeniero de Software al que se le asignó la tarea de implementar un modelo de aprendizaje automático o aprendizaje profundo por primera vez en tu vida? ¿Te preguntas qué pasos seguir y cómo se diferencia el software impulsado por IA del software tradicional? Entonces este es el masterclass adecuado al que asistir.
Internet ofrece miles de artículos y cursos gratuitos que muestran lo fácil que es entrenar e implementar un modelo de IA simple. Al mismo tiempo, en la realidad es difícil integrar un modelo real en la infraestructura actual, depurarlo, probarlo, implementarlo y monitorearlo correctamente. En este masterclass, te guiaré a través de este proceso compartiendo consejos, trucos y herramientas de código abierto favoritas que te facilitarán mucho la vida. Así que al final del masterclass, sabrás por dónde empezar tu viaje de implementación, qué herramientas utilizar y qué preguntas hacer.