应用数据向量化 (ArkTS)
场景介绍
在数字化向智能化演进的关键阶段,构建智慧化服务已成为应用开发者提升产品竞争力的必然选择。
当前,系统提供ArkData智慧数据平台(ArkData Intelligence Platform,AIP),提供端侧数据智慧化构建,使应用数据向量化,通过嵌入模型将非结构化的文本、图像等多模态数据,转换成具有语义的向量。
从API version 15开始,支持应用数据向量化。
基本概念
在智慧化数据构建过程中,涉及以下基本概念,请先了解相关含义。
向量化
向量化主要是指通过嵌入模型将高维非结构化数据(如文字、图像)映射为低维连续向量的嵌入技术。嵌入技术通过模型捕捉数据之间的语义关系,将抽象概念转化为可计算的数学表示,使计算机能够理解非结构化数据。目前,嵌入技术广泛应用于自然语言处理(语义搜索)、图像识别(特征提取)、推荐系统(用户/物品表征)等领域。
多模态嵌入模型
应用数据向量化,主要通过嵌入模型实现。当前支持多模态嵌入模型,能将文本和图像这两种不同数据模态转换到同一个向量空间,支持单模态(文搜文、图搜图)和跨模态(文搜图、图搜文)的语义表征能力。
文本分块
数据向量化时,文本数据长度受限,可通过AIP分块接口切分文本,高效实现数据向量化。
实现机制
应用可借助智慧数据平台能力,实现智慧化数据的构建,将应用数据转化为可计算的向量,相关能力均运行在应用进程内,数据不出应用,保证隐私安全。
运作机制
应用数据向量化,将应用原数据向量化并存储在向量数据库中。
约束限制
- 考虑到数据向量化处理的计算量和资源占用较大,当前仅支持在2in1设备上使用。
- 嵌入模型的推理过程可使用NPU加速。与NPU计算相比,纯CPU的计算在时延和功耗上都有较大差距,建议采用NPU加速。
- 模型推理单次可处理的文本长度上限为512个字符,支持中英文。
- 模型推理单次可处理的图像大小小于20MB。
接口说明
以下是智慧数据向量化功能的相关接口。更多接口及使用方式请见智慧数据平台。
| 接口名称 | 描述 |
|---|---|
| getTextEmbeddingModel(config: ModelConfig): Promise<TextEmbedding> | 获取文本嵌入模型。 |
| loadModel(): Promise<void> | 加载文本嵌入模型。 |
| splitText(text: string, config: SplitConfig): Promise<Array<string>> | 获取文本的分块。 |
| getEmbedding(text: string): Promise<Array<number>> | 获取给定文本的嵌入向量。 |
| getEmbedding(batchTexts: Array<string>): Promise<Array<Array<number>>> | 获取给定批次文本的嵌入向量。 |
| releaseModel(): Promise<void> | 释放文本嵌入模型。 |
| getImageEmbeddingModel(config: ModelConfig): Promise<ImageEmbedding> | 获取图像嵌入模型。 |
| loadModel(): Promise<void> | 加载图像嵌入模型。 |
| getEmbedding(image: Image): Promise<Array<number>> | 获取给定图像的嵌入向量。 |
| releaseModel(): Promise<void> | 释放图像嵌入模型。 |
文本向量化开发步骤
-
导入模块。
import { intelligence } from '@kit.ArkData';import { BusinessError } from '@kit.BasicServicesKit'; -
获取文本嵌入模型。
调用getTextEmbeddingModel方法,获取文本嵌入模型。示例代码如下所示:
let textConfig:intelligence.ModelConfig = {version:intelligence.ModelVersion.BASIC_MODEL,isNpuAvailable:false,cachePath:"/data"}let textEmbedding:intelligence.TextEmbedding;intelligence.getTextEmbeddingModel(textConfig).then((data:intelligence.TextEmbedding) => {console.info('Succeeded in getting TextModel');textEmbedding = data;// ...}).catch((err:BusinessError) => {console.error('Failed to get TextModel and code is ' + err.code);// ...}) -
加载文本嵌入模型。
调用loadModel方法,加载文本嵌入模型。示例代码如下所示:
textEmbedding.loadModel().then(() => {console.info('Succeeded in loading Model');// ...}).catch((err:BusinessError) => {console.error('Failed to load Model and code is ' + err.code);// ...}) -
获取文本的分块。当数据长度超过限定时,使用splitText()接口将其分块,然后再进行数据向量化。
调用splitText方法,获取文本的分块结果。示例代码如下所示:
let splitConfig:intelligence.SplitConfig = {size:10,overlapRatio:0.1}let splitText = 'text';intelligence.splitText(splitText, splitConfig).then((data:Array<string>) => {console.info('Succeeded in splitting Text');// ...}).catch((err:BusinessError) => {console.error('Failed to split Text and code is ' + err.code);// ...}) -
获取给定文本的嵌入向量。给定的文本数据可以是单个文本或文本集合。
调用getEmbedding方法,获取给定单个文本或文本集合的嵌入向量。示例代码如下所示:
let text = 'text';textEmbedding.getEmbedding(text).then((data:Array<number>) => {console.info('Succeeded in getting Embedding');// ...}).catch((err:BusinessError) => {console.error('Failed to get Embedding and code is ' + err.code);// ...})let batchTexts = ['text1','text2'];textEmbedding.getEmbedding(batchTexts).then((data:Array<Array<number>>) => {console.info('Succeeded in getting Embedding');// ...}).catch((err:BusinessError) => {console.error('Failed to get Embedding and code is ' + err.code);// ...}) -
释放文本嵌入模型。
调用releaseModel方法,释放文本嵌入模型。示例代码如下所示:
textEmbedding.releaseModel().then(() => {console.info('Succeeded in releasing Model');// ...}).catch((err:BusinessError) => {console.error('Failed to release Model and code is ' + err.code);// ...})
图像向量化开发步骤
-
导入模块。
import { intelligence } from '@kit.ArkData';import { BusinessError } from '@kit.BasicServicesKit'; -
获取图像嵌入模型。
调用getImageEmbeddingModel方法,获取图像嵌入模型。示例代码如下所示:
let imageConfig:intelligence.ModelConfig = {version:intelligence.ModelVersion.BASIC_MODEL,isNpuAvailable:false,cachePath:"/data"}let imageEmbedding:intelligence.ImageEmbedding;intelligence.getImageEmbeddingModel(imageConfig).then((data:intelligence.ImageEmbedding) => {console.info('Succeeded in getting ImageModel');imageEmbedding = data;// ...}).catch((err:BusinessError) => {console.error('Failed to get ImageModel and code is ' + err.code);// ...}) -
加载图像嵌入模型。
调用loadModel方法,加载图像嵌入模型。示例代码如下所示:
imageEmbedding.loadModel().then(() => {console.info('Succeeded in loading Model');// ...}).catch((err:BusinessError) => {console.error('Failed to load Model and code is ' + err.code);// ...}) -
获取给定图像的嵌入向量。
调用getEmbedding方法,获取给定图像的嵌入向量。示例代码如下所示:
let image = 'file://<packageName>/data/storage/el2/base/haps/entry/files/xxx.jpg';imageEmbedding.getEmbedding(image).then((data:Array<number>) => {console.info('Succeeded in getting Embedding');// ...}).catch((err:BusinessError) => {console.error('Failed to get Embedding and code is ' + err.code);// ...}) -
释放图像嵌入模型。
调用releaseModel方法,释放图像嵌入模型。示例代码如下所示:
imageEmbedding.releaseModel().then(() => {console.info('Succeeded in releasing Model');// ...}).catch((err:BusinessError) => {console.error('Failed to release Model and code is ' + err.code);// ...})