Top Qs
Línea de tiempo
Chat
Contexto

Creación de atributos

De Wikipedia, la enciclopedia libre

Remove ads

La creación de atributos, ingeniería de atributos, extracción de atributos o descubrimiento de atributos es el proceso de utilizar el conocimiento del dominio para extraer atributos (rasgos, propiedades, atributos) de los datos brutos.[1] La motivación es utilizar estos atributos adicionales para mejorar la calidad de los resultados de un proceso de aprendizaje automático, en comparación con el suministro de sólo los datos brutos al proceso de aprendizaje automático.

Remove ads

Proceso

El proceso de ingeniería de atributos es:[2]

  • Lluvia de ideas o pruebas de atributos[3]
  • Decidir qué atributos crear
  • Crear atributos
  • Probar el impacto de los atributos identificados en la tarea
  • Mejorar los atributos si es necesario
  • Repetir

Funciones típicas de ingeniería

La siguiente lista[4] ofrece algunas formas típicas de diseñar funciones útiles:

Remove ads

Relevancia

Los atributos varían en importancia.[8] Incluso atributos relativamente insignificantes pueden contribuir a un modelo. La selección de atributos puede reducir el número de atributos para evitar que un modelo se vuelva demasiado específico para el conjunto de datos de formación (sobreajuste).[9]

Explosión

La explosión de atributos se produce cuando el número de atributos identificados crece de forma inadecuada. Las causas más comunes son:

  • Plantillas de atributos : aplicación de plantillas de atributos en lugar de codificar atributos nuevos.
  • Combinaciones de atributos: combinaciones que no pueden representarse mediante un sistema lineal.

La explosión de atributos puede limitarse mediante técnicas como la regularización, los métodos de kernel y la selección de atributos.[10]

Automatización

Resumir
Contexto

La automatización de la ingeniería de atributos es un tema de investigación que se remonta a la década de 1990.[11] El software de aprendizaje automático que incorpora la ingeniería de atributos automatizada está disponible comercialmente desde 2016.[12] La literatura académica relacionada puede dividirse en dos tipos:

  • El aprendizaje de árboles de decisión multirrelacional (en inglés: multi-relational decision tree learning, MRDTL) utiliza un algoritmo supervisado que es similar a un árbol de decisión.
  • Deep Feature Synthesis utiliza métodos más simples.

Aprendizaje de árboles de decisión multirrelacional (MRDTL)

MRDTL genera atributos en forma de consultas SQL añadiendo sucesivamente cláusulas a las consultas. [Por ejemplo, el algoritmo puede empezar con

SELECT COUNT(*) FROM ATOM t1 LEFT JOIN MOLECULE t2 ON t1.mol_id = t2.mol_id GROUP BY t1.mol_id

A continuación, la consulta puede refinarse sucesivamente añadiendo condiciones, como "WHERE t1.charge <= -0.392".

Sin embargo, la mayoría de los estudios MRDTL basan sus implementaciones en bases de datos relacionales, lo que da lugar a muchas operaciones redundantes. Estas redundancias pueden reducirse utilizando técnicas como la propagación de id de tupla.[13][14] La eficiencia puede aumentarse utilizando actualizaciones incrementales, que eliminan las redundancias.[15]

Implementaciones de código abierto

Existen varias bibliotecas y herramientas de código abierto que automatizan la ingeniería de atributos en datos relacionales y series temporales:

  • featuretools es una biblioteca de Python para transformar series temporales y datos relacionales en matrices de atributos para el aprendizaje automático.[16][17][18]
  • OneBM o One-Button Machine combina transformaciones de atributos y selección de atributos en datos relacionales con técnicas de selección de atributos.[19]

[OneBM] ayuda a los científicos de datos a reducir el tiempo de exploración de datos permitiéndoles probar y errar muchas ideas en poco tiempo. Por otro lado, permite a los no expertos, que no están familiarizados con la ciencia de datos, extraer rápidamente valor de sus datos con poco esfuerzo, tiempo y coste.[20]

  • getML community es una herramienta de código abierto para la ingeniería automatizada de atributos en series temporales y datos relacionales.[21][22] Está implementada en C/C++ con una interfaz en Python.[22] Se ha demostrado que es al menos 60 veces más rápida que tsflex, tsfresh, tsfel, featuretools o kats.[23]
  • tsfresh es una biblioteca de Python para la extracción de atributos de datos de series temporales.[24] Evalúa la calidad de las atributos mediante pruebas de hipótesis.[25]
  • tsflex es una biblioteca Python de código abierto para la extracción de atributos a partir de datos de series temporales.[26] A pesar de estar escrita al 100% en Python, ha demostrado ser más rápida y eficiente en memoria que tsfresh, seglearn o tsfel.[27]
  • seglearn es una extensión para datos multivariantes y secuenciales de series temporales de la biblioteca scikit-learn de Python.[28]
  • tsfel es un paquete de Python para la extracción de atributos de datos de series temporales.[29]
  • kats es un conjunto de herramientas de Python para analizar datos de series temporales.[30]

Síntesis profunda de atributos

El algoritmo de síntesis profunda de rasgos (en inglés: deep feature synthesis, DFS) venció a 615 de 906 equipos humanos en una competición.[31][32]

Remove ads

Almacenes de atributos

El almacén de atributos es donde se almacenan y organizan los atributos con el propósito explícito de que se utilicen para formar modelos (por parte de los científicos de datos) o para realizar predicciones (por parte de las aplicaciones que tienen un modelo formado). Se trata de una ubicación central en la que se pueden crear o actualizar grupos de atributos creados a partir de múltiples fuentes de datos diferentes, o crear y actualizar nuevos conjuntos de datos a partir de esos grupos de atributos para formar modelos o para su uso en aplicaciones que no desean calcular los atributos, sino simplemente recuperarlos cuando las necesitan para hacer predicciones.[33]

Un almacén de atributos incluye la capacidad de almacenar el código utilizado para generar atributos, aplicar el código a los datos sin procesar y servir esos atributos a los modelos que lo soliciten. Entre las funciones útiles se incluyen el control de versiones y las políticas que rigen las circunstancias en las que se pueden utilizar las funciones.[34]

Los almacenes de atributos pueden ser herramientas de software independientes o estar integrados en plataformas de aprendizaje automático.

Remove ads

Alternativas

La ingeniería de atributos puede ser un proceso largo y propenso a errores, ya que requiere conocimientos especializados y a menudo implica ensayo y error.[35][36] Los algoritmos de aprendizaje profundo pueden utilizarse para procesar un gran conjunto de datos en bruto sin tener que recurrir a la creación de atributos.[37] Sin embargo, es importante tener en cuenta que los algoritmos de aprendizaje profundo siguen requiriendo un preprocesamiento y una limpieza minuciosos de los datos de entrada.[38] Además, elegir la arquitectura, los hiperparámetros y el algoritmo de optimización adecuados para una red neuronal profunda puede ser un proceso difícil e iterativo.[39]

Remove ads

Véase también

Referencias

Lectura adicional

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads