CursosEmpresasBlogLiveConfPrecios

Análisis de resultados

Clase 13 de 22 • Curso de Redes Neuronales en Keras y Scikit-Learn 2019

Contenido del curso

Apropiar conceptos fundamentales de las redes neuronales

  • 1
    ¿Qué es una red neuronal?

    ¿Qué es una red neuronal?

    05:35 min

Identificar los principales Frameworks usados en la industria para el desarrollo de Deep Learning

  • 2
    Frameworks de Deep Learning

    Frameworks de Deep Learning

    04:56 min

Comprender los modelos de representación de las redes neuronales artificiales usados en Deep Learning

  • 3
    Estructura de redes neuronales

    Estructura de redes neuronales

    14:26 min
  • 4
    Creando nuestra primer red neuronal

    Creando nuestra primer red neuronal

    11:06 min
  • 5
    Entrenando nuestra primera red neuronal

    Entrenando nuestra primera red neuronal

    06:08 min
  • 6
    Visualizando el proceso de entrenamiento

    Visualizando el proceso de entrenamiento

    05:19 min
  • 7
    Funciones de activación

    Funciones de activación

    04:51 min
  • 8
    Funciones de costo o pérdidas

    Funciones de costo o pérdidas

    07:16 min
  • 9
    Inicialización y Entrenamiento de RN

    Inicialización y Entrenamiento de RN

    07:53 min
  • 10
    Optimizadores en redes neuronales

    Optimizadores en redes neuronales

    05:43 min
  • 11
    Clasificación Binaria

    Clasificación Binaria

    09:43 min
  • 12
    Clasificación de potenciales clientes

    Clasificación de potenciales clientes

    08:46 min
  • 13
    Análisis de resultados

    Análisis de resultados

    Viendo ahora
  • 14
    Métricas de desempeño: regresión y clasificación

    Métricas de desempeño: regresión y clasificación

    09:26 min
  • 15
    Evaluando métricas de desempeño

    Evaluando métricas de desempeño

    09:26 min
  • 16
    Ajuste de redes neuronales: overfitting y regularización

    Ajuste de redes neuronales: overfitting y regularización

    02:38 min
  • 17
    Regularización

    Regularización

    05:52 min
  • 18
    Ajuste de redes neuronales: Hiper parámetros

    Ajuste de redes neuronales: Hiper parámetros

    08:36 min

Crear un modelo de regresión a partir de un caso de uso real

  • 19
    Introducción a las regresiones con Deep Learning: Planteamiento del problema

    Introducción a las regresiones con Deep Learning: Planteamiento del problema

    04:40 min
  • 20
    Solución del problema de regresión

    Solución del problema de regresión

    08:36 min
  • 21
    Ajustes finales al proyecto

    Ajustes finales al proyecto

    04:40 min

Cierre del curso

  • 22
    Cierre del curso

    Cierre del curso

    09:14 min
Tomar examen

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads

      Comentarios

        Luis Fernando Úbeda Camacho

        Luis Fernando Úbeda Camacho

        student•
        hace 6 años

        Voy a facilitar un código más simple para la transformación de las variables categóricas

        1. Hago un dataframe solo de variables categóricas selecciono todas las variables categóricas.
        categorical = consolidado[consolidado.columns[consolidado.dtypes==object].tolist()]
        1. Paso todo el dataset categórico por pd.get_dummies() para que transforme todas las variables y tengamos un dataset de variables dummy.
        mask = pd.get_dummies(categorical)
        1. Elimino del dataset original las variables categóricas que hemos convertido a dummies.
        columns = categorical.columns.tolist() consolidado.drop(columns, axis=1, inplace=True)
        1. Finalmente concateno el dataset original con que contiene todas las variables categóricas transformadas.
        df = pd.concat([consolidado, mask],axis=1)
          David Martínez Jiménez

          David Martínez Jiménez

          student•
          hace 6 años

          bro eres un Crack!

          Alan Vazquez

          Alan Vazquez

          student•
          hace 6 años

          Para simplificar la seleccion de un tipo especifico de columnas puedes usar select_dtypes

          # Selecciona todas las columnas que no sean tipo numerico ( int | float ) df.select_dtypes(exclude='number').columns # Solo columnas tipo objeto df.select_dtypes(include='object') df.select_dtypes(include=['int64', 'categorical', 'date'])
        María José Medina

        María José Medina

        student•
        hace 5 años

        En el minuto 10:58, una forma más simple de evaluar la cantidad de valores distintos (con Pandas) es:

        objects_list = list(types[types.values == 'object'].index) consolidado[objects_list].nunique()

        La última línea de código da como resultado la lista de valores distintos de cada columna.

        fecha_actividad 411 char_1 2 char_2 3 date 1196 char_3 43 char_4 25 char_5 9 char_6 7 char_7 25 char_8 8 char_9 9 dtype: int64

        De igual manera, una forma más simple de hacer el one hot encoding para 'char_6' sería:

        mask = pd.get_dummies('char_6'+'_'+consolidado.char_6)

        Sin embargo, no está de más saber como realizar esto usando Scikit-Learn, que a final de cuentas es de lo que se trata el curso.

          María José Medina

          María José Medina

          student•
          hace 5 años

          Teniendo en cuenta lo anterior, se puede construir la función de one hot encoding así:

          # copia del df consolidado para hacer pruebas mi_consolidado = consolidado.copy(deep=True) #Se define función que captura el dataframe y la columna para retornar un dataframe luego de OHE def OneHotEncoding_df(df, columna): OHE_df = pd.get_dummies(columna+'_'+df[columna]) return OHE_df #Se obtiene las columnas a las que se va a realizar OHE objects_list = list(types[types.values == 'object'].index) #Se realiza OHE para cada categoría for category in objects_list: mask = OneHotEncoding_df(mi_consolidado, category) print(f'column {category} transformed!') mi_consolidado.drop(category, axis=1, inplace=True) mi_consolidado = pd.concat([mi_consolidado, mask], axis=1) print(f"Tamaño final del dataset transformado: {mi_consolidado.shape}")

          Al final, el tamaño del dataset será de (2197291, 178). Esa columna extra es de la variable objetivo 'outcome'. Por lo que el paso final seria eliminar outcome del dataframe.

          mi_consolidado.drop('outcome', axis=1, inplace=True)
          FELIX  DAVID CORDOVA GARCIA

          FELIX DAVID CORDOVA GARCIA

          student•
          hace 5 años

          Maravilloso mariajose, muchas gracias por todos tus aportes en todos los cursos de machine learning :3

        Geraldine León

        Geraldine León

        student•
        hace 5 años

        Por qué no podemos simplemente aplicar un slice en vez de un encoder? Los features tienen como valor 'type 1', 'type 7', etc, si le aplicamos un slice start=5, solo nos quedaría '1' y '7' por ejemplo y son valores numéricos... Sería lo mismo que hicimos con los features como 'group'. Alguna razón para cambiar de estrategia o es solo didáctico para aprender diferentes maneras de transformar variables categóricas a numéricas?

          Diego Alejandro Lesmes

          Diego Alejandro Lesmes

          student•
          hace 5 años

          x2

        Rodrigo Urquizo Yepez

        Rodrigo Urquizo Yepez

        student•
        hace 6 años

        No siempre en tus valores los datos de tipo string van a estar al inicio, pueden estar al final o incluso mezclados con lo que la funcion slice no siempre seria util, encontre una manera mas eficaz a mi parecer de hacer esto,usando el metodo apply y ejecutando una funcion que te retorna solo los enteros.Lo mejor es que esta funcion se puede reutulizar para cualquier columna.

        def only_numbers(objecto): output = "" for x in list(objecto): try: if type(int(x)) == int: output += x except ValueError: pass return int(output) consolid["people_id"] = consolid["people_id"].apply(only_numbers)```
          Alan Vazquez

          Alan Vazquez

          student•
          hace 6 años

          Yo lo hice con expresiones regulares

          columns_del_txt = ['activity_id', 'char_10_activity', 'group_1'] df[columns_del_txt] = df[columns_del_txt].applymap( lambda x: re.findall(r'(\d+$)', x)[0]).astype('int64', copy=False)
        David fernando Pinzon suarez

        David fernando Pinzon suarez

        student•
        hace 6 años

        ¿Por que se necesita crear multiples columnas y no simplemente se deja una sola ( la creada por el encoder)?

          Alberto Perdomo

          Alberto Perdomo

          student•
          hace 6 años

          Porque cada columna creada equivale a un valor de la variable categorica de la original. Lo que se hizo en el video se conoce como feature engeneering o ingeniería de caracteristicas. Su objetivo es el de crear caracteristicas artificiales basadas en las originales para que estas proporcionen una mayor abstracción de la información a ser analisada por el algoritmo.

          Sergio Rubiano

          Sergio Rubiano

          student•
          hace 6 años

          Si, lo que se realizo fue la fase de feature ingineer en cierto aspecto, por que en si tampoco se esta evaluando si todas las features son relevantes en nuestro modelo. Pero para el ejercicio supongo que esta bien

        Javier Guevara

        Javier Guevara

        student•
        hace 5 años

        El comando Series.dt.week fue retirado, ahora se recomienda usar

        consolidado['semana'] = consolidado['date_y'].dt.isocalendar().week
          FELIX  DAVID CORDOVA GARCIA

          FELIX DAVID CORDOVA GARCIA

          student•
          hace 5 años

          Luego de eso para que tengan 47 int64 y 9 object como se observa en el minuto 07:26 se le debe de poner en consolidado['semana'] = consolidado['date_y'].dt.isocalendar().week.astype(int) ,lo mismo con el de fecha_de_actividad

        Jorge Osuna

        Jorge Osuna

        student•
        hace 5 años

        Usa este codigo si te aparece en error al ejecutar el codigo del minuto 2:00, si te aparece que no lee tipo_actividad como string u object.

        consolidado['tipo_actividad'] = consolidado['tipo_actividad'].astype(str)
        johan Stever Rodriguez Molina

        johan Stever Rodriguez Molina

        student•
        hace 6 años

        Una manera de hallar los días es usar "lambdas".

        consolidado['date'] = consolidado['date'].apply(lambda x: x.day)
          Alan Vazquez

          Alan Vazquez

          student•
          hace 6 años

          O con una funcion que obtenga los atributos de manera dinamica

          def split_date(dataframe, column='date', sufix='', times=('day', 'weekday', 'week', 'month', 'year', 'quarter')): series_time = pd.to_datetime(dataframe[column]) dataframe.drop(columns=[column], inplace=True) for time in times: dataframe[time + sufix] = getattr(series_time.dt, time) split_date(df) split_date(df, 'date_activity', '_activity') display(df.dtypes.value_counts())
        Arturo Baduna

        Arturo Baduna

        student•
        hace 6 años

        por que de str no pasamos a entero directamente??????

          Alan Vazquez

          Alan Vazquez

          student•
          hace 6 años

          Tambien puedes hacer una funcion para eliminar el texto

          columns_del_txt = ['activity_id', 'char_10_activity', 'group_1'] df[columns_del_txt] = df[columns_del_txt].applymap( lambda x: re.findall(r'(\d+$)', x)[0]).astype('int64', copy=False)
          Arturo Baduna

          Arturo Baduna

          student•
          hace 6 años

          Muy bien, muy interesante

        Christian Quispe Bonilla

        Christian Quispe Bonilla

        student•
        hace 6 años

        Gracias por la función de transformación de variables categóricas a números enteros

        FELIX  DAVID CORDOVA GARCIA

        FELIX DAVID CORDOVA GARCIA

        student•
        hace 4 años

        Para seleccionar los datos categoricos es mas sencillo usar: consolidado.select_dtypes(include="object")

        y si queremos todos menos los categoricos usamos

        consolidado.select_dtypes(exclude="object")

        FELIX  DAVID CORDOVA GARCIA

        FELIX DAVID CORDOVA GARCIA

        student•
        hace 4 años

        Es mas sencillo hacer: consolidado.activity_id.str[4:] y asi para cada uno de los valores de tipo categorico

        FELIX  DAVID CORDOVA GARCIA

        FELIX DAVID CORDOVA GARCIA

        student•
        hace 5 años

        Para los que quieren evitarse el codigo de profesor en el minuto 2 ,pueden usar lambda y split así:

        lambda.PNG

        Julián Andrés Santos Méndez

        Julián Andrés Santos Méndez

        student•
        hace 6 años

        ¿Hay alguna razón por la cual se quieran todos los features como enteros?

          Alexander carpio mamani

          Alexander carpio mamani

          student•
          hace 5 años

          porque los modelos de machine learning trabajan con valores numericos.

        Alan Vazquez

        Alan Vazquez

        student•
        hace 6 años

        Les comparto el mi notebook de la transformacion de datos, antes de empezar tranforme los archivos de csv a parquet. Una manera sencilla de hacerlo puede ser primero importando el csv con pandas y exportarlos como parquet

        df = pd.read_csv(file) df.to_parquet(file.parquet)

        https://drive.google.com/file/d/13k7TQh8de0SfL8q3IGGBTychg6mvMFmp/view?usp=sharing

        Brayan Leonardo Velasquez Gutierrez

        Brayan Leonardo Velasquez Gutierrez

        student•
        hace 5 años

        A que se debe que aparezca este error?

        ![](

        errordate.PNG

          FELIX  DAVID CORDOVA GARCIA

          FELIX DAVID CORDOVA GARCIA

          student•
          hace 5 años

          debes ver los valores que son de ese tipo y poner astype(int), tmb me salio lo mismo y tuve problemas