Cómo detectar y asignar dispositivos

En Android 10, la API de redes neuronales (NNAPI) presenta funciones que permiten que las bibliotecas y apps de 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 que las apps obtengan la versión exacta de los controladores que se encuentran en el dispositivo para evitar incompatibilidades conocidas. Cuando se otorga a las apps la capacidad de especificar qué dispositivos ejecutarán diferentes secciones de un modelo, 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 detección 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: Es un dispositivo que no pertenece a ninguna de las otras categorías, incluida una interfaz heterogénea, que es una única 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 núcleo o de varios núcleos.
  • GPU: Es una GPU que puede ejecutar modelos de la NNAPI y acelerar las APIs de gráficos, como OpenGL ES y Vulkan.
  • ACCELERATOR: Es una unidad de procesamiento neuronal dedicado (NPU).

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}.