上次写了一个语音识别的文章,但是那个模块是用串口进行通信的。这次要讲的是另一种识别与播报模块,这种模块相对于上次那种,功能更多,当然价格也更贵。这种识别模块与播报模块都是利用IIC进行传输的,所以本次利用了stm32f103c8t6控制板上面的两个IIC分别是PB6、PB7以及PB10、PB11。本文章主要实现的功能是:
根据说出的指令让识别模块识别到相应的词语后,做出相应的动作,并且利用播报模块说出对应动作是否完成。在这里我只是简单的控制led灯,当然你也可以控制其他东西,如家用电器等等。
其中语音识别模块有三种模式,循环模式:模块时刻处于语音识别状态;口令模式:当检测到口令时候进行语音识别;按键模式:当按下按键后处于语音识别模式,模块没有设置板载按键,通过主控板设置按键检测程序,检测到按键后通过 I2C 发送按键模式启动命令,该按键模式可以由自己定义任意的按键。
而语音模板模块支持任意中文、英文文本的合成,可以采用 GB2312、GBK、BIG5 和UNICODE 四种编码方式。每次合成的文本量最多可达 4K 字节。模块对文本进行分析,对常见的数字、号码、时间、日期、度量衡符号等格式的文本,芯片能够根据内置的文本匹配规则进行正确的识别和处理;对一般多音字也可以依据其语境正确判断读法;另外针对同时有中文和英文的文本,可实现中英文混读。支持多种控制命令如合成文本、停止合成、暂停合成、恢复合成、状态查询等。可设置对应字母的播报方式,如字母发音、单词发音等,还可以通过设置通过汉语拼音进行汉语播报。内置多个发音人物,可以通过设置选择对应的发音人进行语音播放,语音播报的语速、语调、音量等均可以设置。模块还有其他如数字符号等的特殊播报设置。
接下来分别给出两个模块的图片及链接
语音识别模块(本质是LD3320)
链接:语音识别模块
语音播报模块
链接:语音播报模块
本文章是以stm32为主来控制这两个模块,在文章最下面的资源中包含了microbit、arduino、树莓派、51、32、jetson nano等例程都有。
上面两个模块的接线也相对比较简单,具体如下:
语音识别模块 -----------语音合成播报模块
IIC1 ------------------------IIC2
VCC->单片机5V --------VCC->单片机5V
SCL->单片机PB6 ------SCL->单片机PB10
SDA->单片机PB7 ------SDA->单片机PB11
GND->单片机GND ----GND->单片机GND
下面附上效果视频:
stm32语音识别与播报智能控制led灯
接在再附上主程序:
#include "stm32f10x.h"
#include "bsp_i2c.h"
#include "bsp_usart1.h"
#include "led.h"
/*
语音识别模块 语音合成播报模块
IIC1 IIC2
VCC->单片机5V VCC->单片机5V
SCL->单片机PB6 SCL->单片机PB10
SDA->单片机PB7 SDA->单片机PB11
GND->单片机GND GND->单片机GND
*/
int main(void)
{
u8 result = 0xff;
LED_Init(); //初始化与LED连接的硬件接口
//I2C初始化
I2C_Bus_Init();
NVIC_Configuration();
USARTx_Config();
#if 1
I2C_ByteWrite(ASR_CLEAR_ADDR,0x40);//清除掉电保存区,录入前需要清除掉电保存区
LD3320_delay(150000);//flash擦除时间较长,需要较长的延时
I2C_ByteWrite(ASR_MODE_ADDR,0x01);//设置检测模式;
AsrAddWords(0,"xiao ya");
AsrAddWords(4,"kai deng");
AsrAddWords(5,"guan deng");
#endif
I2C_ByteWrite(ASR_REC_GAIN,0x45); //识别的灵敏
RGB_Set(255,255,255);
LD3320_delay(10000);//flash擦除时间较长,需要较长的延时
RGB_Set(0,0,0);
SetVolume(10);
SetReader(Reader_XiaoYan);
while(1)
{
I2C_BufferRead(ASR_RESULT,&result,1);
printf("result = %d\n",result);
if(result==0)
{
speech_text("[x1]sound204",GB2312);
while(GetChipStatus() != ChipStatus_Idle)
{
delay(50);
}
}
if(result==4)
{
GPIO_ResetBits(GPIOA,GPIO_Pin_1); //给PA1置0
speech_text("灯已经打开",GB2312);
while(GetChipStatus() != ChipStatus_Idle)
{
delay(50);
}
}
if(result==5)
{
GPIO_SetBits(GPIOA,GPIO_Pin_1); //给PA1置1
speech_text("灯已经关闭",GB2312);
while(GetChipStatus() != ChipStatus_Idle)
{
delay(50);
}
}
LD3320_delay(10000);
}
}
/*********************************************END OF FILE**********************/