跳转至

CI231X系列芯片语义ID说明


1. 概述

​CI231X系列芯片SDK 增加了语义ID的概念,为了方便开发者快速开发SDK,本文旨在对语义ID协议和使用进行说明。


2. 语义ID目的

2.1. 唯一性

​每个命令词的语义ID具有唯一性,方便多个产品之间交互。

2.2. 方便相同功能命令词处理

通常在具体产品应用中,同一个意思但是有不同的表述方式,例如“增大音量”、“声音大点”、“大声点”、“调高音量”等。开发者需要对这种逻辑进行专门的处理。在开发过程中,开发者可能随时增加或删除一些这类的词,此时代码维护起来就变的繁琐。命令词的语义ID很好的解决这个问题,只需要修改命令词EXCLE表和ASR模型,而不需要修改代码。


3. 语义ID协议详述

语义ID协议详述

图3-1 语义ID协议详述
  • 语义ID总共4个字节(32位bit),最高位:保留。

  • 第18位到30位:产品ID。最大支持8192种产品。例如:“空调打开”、“风扇打开”,通过空调(ID:0xAF)和风扇(ID:0x9D)的ID区别开来。产品ID具体定义在product_semantic.h文件的位置如下图所示:

产品ID位置

图3-2 产品ID位置

注意

产品ID里面包含了通用(ID:0x65),表示一些产品通用的指令,例如音量调节,播报控制等。

  • 第6位到第17位:功能ID。最大支持4096种功能。

例如:“大点声”和“小点声”属于不同的功能,两者的功能ID不一致。“大点声”和“增加音量”属于相同的功能,两者的功能ID是一致的,方便相同功能的命令词的处理。 功能ID具体定义在product_semantic.h文件的位置如下图:

功能ID位置

图3-3 功能ID位置
  • 第0位到第5位:表述ID。最大支持64种不同表述。

例如:“大声点”、“大点声”和“增大音量”这类词的功能都统一为增大音量,它们的产品ID和功能ID都是完全一致的,唯一不同的就是表述ID。表述ID是为了支持语义ID唯一性。如果开发者不考虑唯一性,可以忽略。


4. 语义ID具体说明

4.1. 语义ID函数

//获取产品ID

get_product_id_from_semantic_id(semantic_id);

//获取功能ID

get_function_id_from_semantic_id(semantic_id);

4.2. 语义ID文件

命令词语义ID由本公司提供,具有唯一性,开发者打包..\firmware\user_file\cmd_info[60000]xxx.xls命令词列表文件时,[60000]xxx.xls语义ID会自动生成。如下图所示:

命令词语义ID自动生成

图4-1 命令词语义ID自动生成

命令语义ID后续本公司逐渐完善,语义ID头文件路径:SDK\components\cmd_info\product_semantic.h。


5. 语义ID示例代码

5.1. 通用语义ID示例代码

#define  PRODUCT_GENERAL (0x65)  //通用(语义ID头文件已定义)
uint32_t semantic_id = 0x19419C4;   //最大音量语义ID(命令词Excle表)
//获取产品ID
if(PRODUCT_GENERAL==get_product_id_from_semantic_id(semantic_id))
{
    //获取功能ID
    switch(get_function_id_from_semantic_id(semantic_id))
    {

      case VOLUME_UP:            //增大音量
           break;
      case VOLUME_DOWN:          //减小音量
           break;
      case MAXIMUM_VOLUME:       //最大音量
           vol_set(VOLUME_MAX);
           break;
      case MEDIUM_VOLUME:        //中等音量
           vol_set(VOLUME_MID);
           break;
      case MINIMUM_VOLUME:       //最小音量
           vol_set(VOLUME_MIN);
           break;
      default:
           break;
    }
}

上述示例代码为产品的通用控制,多个产品可以使用上述同一份代码,加速代码开发。

5.2. 灯控语义ID示例代码

#define PRODUCT_LAMP_CONTROL (0x8D)   //灯控 (语义ID头文件已定义)
uint32_t semantic_id = 0x234DF84;   //最高亮度语义ID(命令词Excle表)
//获取产品ID
if(PRODUCT_LAMP_CONTROL==get_product_id_from_semantic_id(semantic_id))
{
    //获取功能ID
    switch(get_function_id_from_semantic_id(semantic_id))
    {
        case MAXIMUM_BRIGHTNESS_OF_LIGHT:  //灯光最高亮度
            break;
        case MODERATE_BRIGHTNESS:          //中等亮度
            break;
        case MINIMUM_BRIGHTNESS_OF_LIGHT:  //灯光最低亮度
            break;
        case TURN_UP_THE_LIGHT:            //灯光调亮一点
            break;
        case DIM_THE_LIGHT:                //灯光调暗一点
            break;
        case RED_MODE:                     //红色模式
            break;
        case GREEN_MODE:                   //绿色模式
            break;
        case BLUE_MODE:                    //蓝色模式
            break;
        case COLORFUL_MODE:                //彩色模式
            break;
        default:
            break;
    }
}

6. 自定义语义ID示例

6.1. 填写自定义语义ID

  • 开发者打包SDK\projects\sample_xxx\firmware\user_file\cmd_info[60000]xxx.xls命令词列表文件时,[60000]xxx.xls语义ID会自动生成,假如生成的默认语义ID如下图所示。

命令词语义ID

  • 自定义修改[60000]xxx.xls表格中语义ID如下图所示。

命令词语义ID

6.2. 使自定义语义ID有效

  • 打开[60000]xxx.xls同级目录下cmd_info.bat文件,原始内容如下。
if exist *.bin (del *.bin)

..\..\..\..\..\..\tools\cmd_info.exe --no-cmd-id-duplicate-check -c

if exist *.bin goto label_ok
echo cmd_info failed
..\..\..\..\..\..\tools\cmd_info_err.exe
goto end

:label_ok
echo cmd_info ok

:end
  • 修改cmd_info.bat文件第2行代码,去掉最后一个字符“-c”,保存并关闭文件。

注解

  1. 去掉cmd_info.bat文件第2行代码的“-c”字符,可以防止调用(合成分区bin文件.bat)时生成默认的语义ID,使得自定义语义ID有效。
  2. 用户可以试验不去掉“-c”字符的效果,即在调用(合成分区bin文件.bat)后,自定义语义ID会消失,转而变成默认的语义ID。

  • 回到SDK\projects\sample_xxx\firmware目录,双击(合成分区bin文件.bat)文件,程序运行完成后,再回看[60000]xxx.xls,自定义语义ID生成成功。

命令词语义ID

6.3. 验证结果

  • 用户可以在SDK\projects\sample_xxx\src\system_msg_deal.c文件中找到以下代码,获取语义ID验证结果。
void sys_deal_asr_msg(sys_msg_asr_data_t *asr_msg)
{
    cmd_handle_t cmd_handle;

    if(MSG_ASR_STATUS_GOOD_RESULT == asr_msg->asr_status && (ignore_asr_msg == 0))
    {
        /*省略部分代码*/

        cmd_handle = asr_msg->asr_cmd_handle;

        /*省略部分代码*/

        /*获取语义ID,根据打印验证结果*/    
        uint32_t semantic_id = cmd_info_get_semantic_id(cmd_handle);
        ci_loginfo(LOG_USER,"semantic_id:%08x\n",semantic_id);

        /*省略部分代码*/
    }

    /*省略部分代码*/
}