Cómo detectar y asignar dispositivos

En Android 10, la API de Neural Networks (NNAPI) presenta funciones que permiten que las apps y las bibliotecas del framework de aprendizaje automático obtengan información sobre los dispositivos disponibles y especifiquen en qué dispositivos ejecutar un modelo. Proporcionar información sobre los dispositivos disponibles permite a las apps obtener la versión exacta de los controladores que se encuentran en el dispositivo para evitar incompatibilidades conocidas. Al otorgar a las apps la capacidad de especificar cuáles dispositivos ejecutarán diferentes secciones de un modelo, las apps se pueden optimizar para el producto en el que se implementan.

Se requiere compatibilidad con la detección y asignación de dispositivos para las implementaciones de NN HAL 1.2.

Implementación

Para admitir las funciones de descubrimiento y asignación de dispositivos en NNAPI, implementa getType y getVersionString en IDevice.hal para permitir que el framework obtenga el tipo de dispositivo y la versión del controlador.

Para cada dispositivo, especifica el tipo como una de las siguientes categorías, como se especifica en DeviceType en types.hal.

  • OTHER: Un dispositivo que no pertenece a ninguna de las otras categorías, incluida una interfaz heterogénea, que es una sola interfaz IDevice que administra varios dispositivos, posiblemente de diferentes tipos. Un controlador con una interfaz heterogénea también debe exponer interfaces IDevice separadas que correspondan a dispositivos individuales para permitir que una aplicación elija entre esos dispositivos.
  • CPU: Es una CPU de un solo núcleo o multinúcleo.
  • GPU: Es una GPU que puede ejecutar modelos de NNAPI y acelerar APIs de gráficos, como OpenGL ES y Vulkan.
  • ACCELERATOR: Es una unidad de procesamiento neuronal (NPU) dedicada.

Implementa getVersionString en IDevice.hal para obtener la cadena de versión de la implementación del dispositivo. Este método debe mostrar una cadena legible por humanos. El formato de la cadena es específico del proveedor. La cadena de versión debe ser diferente para cada versión nueva de un controlador.

El nombre de la interfaz IDevice debe seguir el formato {VENDOR}-{DEVICE_NAME}.