Android 上的机器学习套件模型安装路径

机器学习套件的所有功能都利用 Google 训练的机器学习模型(称为 基础模型)。本指南仅适用于基本模型。点击此处 获取有关自定义模型的指南。

您可以通过以下三种方式之一安装 ML Kit API 中的模型:

  1. 未捆绑:通过 Google Play 服务下载和管理模型。
  2. 捆绑式:模型在构建时静态关联到您的应用。
  3. 动态下载:系统会按需下载模型。

每个 API 支持的安装路径

下表展示了各个 ML Kit 功能支持的模型安装路径:

未分类显示 捆绑 动态下载
文字识别 v2
人脸检测
人脸网格检测
姿势检测
自拍分割
条形码扫描
为图片加标签
对象检测和跟踪
数字手写识别
文件扫描器
主题细分
Google 扫码器
语言识别
翻译
智能回复
实体提取

API 特定的指南显示了适用于指定 API。

安装选项之间的主要区别

未捆绑 捆绑 动态下载
模型存储在何处? 位于 Google Play 服务中,不会计入此应用使用的存储空间 保存在应用专属存储空间中 安装后 在模型下载后保存在应用专属存储空间
模型大小如何影响应用大小? 不计入应用大小 直接影响应用大小 不会增加应用大小,但会增加应用专属存储空间
模型何时更新? 有新版本发布时自动更新 需要更新应用才能更新模型 需要更新应用才能更新模型
模型何时下载? 模型必须先下载,然后才能使用 应用安装时包含所有模型和功能,因此可立即使用 必须使用 RemoteModelManager API
模型何时会从设备中移除? 只有在所有依赖于该模型的应用都被卸载后,Google Play 服务才会从存储空间中移除该模型 当应用被卸载时,模型会从应用专用存储空间中移除 卸载应用后,系统会从应用专用存储空间中移除下载的模型

如何在捆绑销售和未捆绑之间进行选择

如果某个 API 同时支持捆绑和非捆绑安装选项,则:

  • 如果您有以下需求,请使用套装选项:

    • 在应用安装后立即提供完整的功能功能
    • 应用安装后在无网络连接的情况下功能的运作情况
  • 如果您有以下需要优先处理的事项,请使用“不捆绑”选项:

    • 缩减应用大小
    • Google Play 服务自动更新模型

如何下载模型

使用未捆绑的模型选项时,您可以指定要将模型下载到设备的方式:

  • 如需启用安装时模型下载功能,您可以在 应用的 AndroidManifest.xml 文件。例如,以下代码段展示了如何配置应用,使之在从 Play 商店安装后自动下载条形码扫描模型:

    <application ...>
          ...
          <meta-data
              android:name="com.google.mlkit.vision.DEPENDENCIES"
              android:value="barcode" >
          <!-- To use multiple models: android:value="barcode,model2,model3" -->
    </application>
    
  • 您可以通过 Google Play 服务 ModuleInstallClient API 请求明确下载

  • 如果您未启用在安装时下载模型的选项或未请求显式下载,系统将在您首次运行该功能时下载模型。下载完成之前,推理请求将失败。

如何更新模型

要在使用捆绑模型或动态下载的模型时更新模型,请执行以下操作: 模型选项:

  1. 更新应用的 Gradle 文件以使用最新的机器学习套件功能客户端 库。

    dependencies {
      implementation 'com.google.mlkit:barcode-scanning: 17.3.0' // The latest version number of the API
    }
    
  2. 重新构建您的应用。

为何某些 API 提供动态下载的模型

某些 ML Kit API 包含太多的模型选项,无法打包。例如,数字手写识别支持 300 多种语言,但在安装过程中,并不一定需要将每种语言都添加到该功能中。为此,我们提供了第三种安装选项,即在安装后按需下载模型。目前,只有数字手写识别翻译实体提取支持此选项。