【雷龙发展】使用YT2228语音芯片做一台智能台灯
最近打算做个语音的项目,找到了深圳雷龙发展的YT2228这款语音模块,写出来安利一下
一、模块介绍
模块简介
YT2228 是根据智能语音交互市场需求及思必驰算法的发展方向定义
开发的 “芯片+算法”人工智能人机语音交互解决方案,具有高性能、低
功耗等特点。
硬件参数概述
1. 处理器
架构: 32位处理器,支持硬件浮点运算单元(FPU)。
运行频率: 240MHz。
存储: 内置2MB闪存(FLASH)。
中断系统: 提供64个中断向量,支持4级中断优先级。
2. 外设功能
USB: 支持USB1.1标准。
定时器: 配备4个多功能16位定时器,支持捕获和PWM模式。
PWM发生器: 提供3个16位PWM发生器,适用于驱动电机。
SPI接口: 具有2个SPI接口。
GPIO: 所有GPIO引脚均支持外部中断功能。
3. 音频功能
DAC(数模转换器): 两通道16位DAC,信噪比(SNR)≥95dB。
ADC(模数转换器): 单通道16位ADC,信噪比(SNR)≥90dB。
采样率: 支持8KHz、11.025KHz、16KHz、22.05KHz、24KHz、32KHz、44.1KHz、48KHz的音频采样率。
4. 蓝牙功能
标准: 符合蓝牙V5.1 + BR + EDR + BLE规范。
传输功耗: 满足Class1、Class2和Class3的传输功耗需求。
调制方式: 支持GFSK和π/4 DQPSK调制方式。
发射功率: 最大+6dBm。
接收器灵敏度: 支持高灵敏度接收。
5. 电源管理
供电电压:
VBAT供电电压范围为3.0V至5.5V。
VDDIO电压可输出50mA,电压范围为2.2V至3.6V。
功耗: 模组功耗为50mA。
6. 封装
封装类型: 提供VSSOP28(0.635)和QSOP28封装。
7. 温度范围
工作温度: -40℃至+85℃。
存储温度: -65℃至+150℃。
8. 应用领域
智能家电: 适用于生活电器、厨房家电等。
智能卫浴、智能照明、智能家居。
智能玩具。
空调伴侣。
二、模块定制
与厂家交流之后,将需要用到的词条发给厂家让厂家定制完成即可
使用USB转串口模块连接上语音模块测试,接线非常简单
说出唤醒词,看到串口返回了我们定义的数据
再说一下关键词,发现也都能返回对应的数据
等待10s后,语音模块正常播放了结束语,串口也接收到了结束数据,模块进入待机模式
再发送一些预设的命令,发现模块也正确的接收到并播报了
三、应用
LSYT201B的使用非常简单,完全不需要了解任何语音识别有关的技术或是算法,只需一个串口便可以使用。首先通过用户手册查看模块的串口通讯协议
将串口配置成相对应的模式,并且配置接受中断
void MX_USART2_UART_Init(void)
{
/* USER CODE BEGIN USART2_Init 0 */
/* USER CODE END USART2_Init 0 */
/* USER CODE BEGIN USART2_Init 1 */
/* USER CODE END USART2_Init 1 */
huart2.Instance = USART2;
huart2.Init.BaudRate = 9600;
huart2.Init.WordLength = UART_WORDLENGTH_8B;
huart2.Init.StopBits = UART_STOPBITS_1;
huart2.Init.Parity = UART_PARITY_NONE;
huart2.Init.Mode = UART_MODE_TX_RX;
huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
huart2.Init.OverSampling = UART_OVERSAMPLING_16;
if (HAL_UART_Init(&huart2) != HAL_OK)
{
Error_Handler();
}
/* USER CODE BEGIN USART2_Init 2 */
/* USER CODE END USART2_Init 2 */
}
裸机主循环代码:
/* USER CODE BEGIN Header */
/**
******************************************************************************
* @file : main.c
* @brief : Main program body
******************************************************************************
* @attention
*
* Copyright (c) 2024 STMicroelectronics.
* All rights reserved.
*
* This software is licensed under terms that can be found in the LICENSE file
* in the root directory of this software component.
* If no LICENSE file comes with this software, it is provided AS-IS.
*
******************************************************************************
*/
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "usart.h"
#include "gpio.h"
/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "YT2228/bsp_yt.h"
#include "LED/bsp_led.h"
/* USER CODE END Includes */
/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */
/* USER CODE END PTD */
/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
/* USER CODE END PD */
/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */
uint8_t Data = 0;
/* USER CODE END PM */
/* Private variables ---------------------------------------------------------*/
/* USER CODE BEGIN PV */
/* USER CODE END PV */
/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
/* USER CODE BEGIN PFP */
/* USER CODE END PFP */
/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */
/* USER CODE END 0 */
/**
* @brief The application entry point.
* @retval int
*/
int main(void)
{
/* USER CODE BEGIN 1 */
/* USER CODE END 1 */
/* MCU Configuration--------------------------------------------------------*/
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
HAL_Init();
/* USER CODE BEGIN Init */
/* USER CODE END Init */
/* Configure the system clock */
SystemClock_Config();
/* USER CODE BEGIN SysInit */
/* USER CODE END SysInit */
/* Initialize all configured peripherals */
MX_GPIO_Init();
MX_USART1_UART_Init();
MX_USART2_UART_Init();
/* USER CODE BEGIN 2 */
HAL_UARTEx_ReceiveToIdle_IT(&huart2, LSYT_RXbuffur, LSYT_DataSize - 1);
/* USER CODE END 2 */
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1)
{
/* USER CODE END WHILE */
if (YT2228_Analysis(Data) == SUCCESS)
{
A_flag = 0;
switch (Data)
{
case 0:
break;
case 1:
break;
case 2:
LED_OFF();
break;
case 3:
LED_ON();
break;
case 4:
COMPUTER_OFF();
break;
case 5:
COMPUTER_ON();
break;
case 6:
LED_OFF();
break;
case 7:
LED_ON();
break;
default:
break;
}
}
/* USER CODE BEGIN 3 */
}
/* USER CODE END 3 */
}
/**
* @brief System Clock Configuration
* @retval None
*/
void SystemClock_Config(void)
{
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
/** Initializes the RCC Oscillators according to the specified parameters
* in the RCC_OscInitTypeDef structure.
*/
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
RCC_OscInitStruct.HSEState = RCC_HSE_ON;
RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
Error_Handler();
}
/** Initializes the CPU, AHB and APB buses clocks
*/
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
{
Error_Handler();
}
}
/* USER CODE BEGIN 4 */
/* USER CODE END 4 */
/**
* @brief This function is executed in case of error occurrence.
* @retval None
*/
void Error_Handler(void)
{
/* USER CODE BEGIN Error_Handler_Debug */
/* User can add his own implementation to report the HAL error return state */
__disable_irq();
while (1)
{
}
/* USER CODE END Error_Handler_Debug */
}
#ifdef USE_FULL_ASSERT
/**
* @brief Reports the name of the source file and the source line number
* where the assert_param error has occurred.
* @param file: pointer to the source file name
* @param line: assert_param error line source number
* @retval None
*/
void assert_failed(uint8_t *file, uint32_t line)
{
/* USER CODE BEGIN 6 */
/* User can add his own implementation to report the file name and line number,
ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
/* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */
语音模块用户代码:
/**-----------------------------------------------------------------------------
* (C) Copyright 2024, PSYM. All Rights Reserved
* ------------------------------------------------------------------------------
* File name : bsp_yt.c
* Description :
* Author : PSYM
* ------------------------------------------------------------------------------
* Update note:
* ----------- ----------- -------------------------------------------------
* Date Author Note
* ----------- ----------- -------------------------------------------------
* 2024-08-27, PSYM
*
*/
/* ------------------------------- 包含头文件 -------------------------------- */
#include "bsp_yt.h"
#include "usart.h"
/* ------------------------------ 私有宏定义 --------------------------------- */
/* None. */
/* ----------------------------- 私有类型定义 -------------------------------- */
/* None. */
/* ------------------------------- 扩展变量 ---------------------------------- */
// 定义数据数组
uint8_t Host_RXbuffur[Host_DataSize] = {0};
uint8_t LSYT_RXbuffur[LSYT_DataSize] = {0};
int A_flag = 0;
/* ------------------------------- 私有变量 ---------------------------------- */
int DataSize = LSYT_DataSize;
/* ------------------------------ 私有函数原型 -------------------------------- */
/* None. */
/* --------------------------------- 函数体 ---------------------------------- */
// 向模块发送命令
HAL_StatusTypeDef YT2228_SendCMD(uint8_t Data)
{
HAL_StatusTypeDef uart_state = HAL_UART_STATE_RESET;
switch (Data)
{
case 0x00:
uart_state = HAL_UART_Transmit(&huart2, LSYT_CMD[0], 6, 10);
break;
case 0x01:
uart_state = HAL_UART_Transmit(&huart2, LSYT_CMD[1], 6, 10);
break;
default:
return uart_state;
}
return uart_state;
}
// 解析模块数据
ErrorStatus YT2228_Analysis(uint8_t *result)
{
if (A_flag == 0)
{
return ERROR;
}
A_flag = 0;
// 判断数据是否有效
if (LSYT_RXbuffur[0] != 0xFE)
{
return ERROR;
}
if (LSYT_RXbuffur[1] == 0x04 && LSYT_RXbuffur[2] == 0x00)
{
switch (LSYT_RXbuffur[3])
{
case 0x00:
switch (LSYT_RXbuffur[4])
{
case 0x00:
*result = 0;
break;
case 0x01:
*result = 1;
break;
default:
break;
}
break;
case 0x01:
switch (LSYT_RXbuffur[4])
{
case 0x00:
*result = 2;
break;
case 0x01:
*result = 3;
break;
default:
break;
}
break;
case 0x02:
switch (LSYT_RXbuffur[4])
{
case 0x00:
*result = 4;
break;
case 0x01:
*result = 5;
break;
default:
break;
}
break;
case 0x03:
switch (LSYT_RXbuffur[4])
{
case 0x00:
*result = 6;
break;
case 0x01:
*result = 7;
break;
default:
break;
}
break;
default:
break;
}
return ERROR;
}
return SUCCESS;
}
void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size)
{
if (huart->Instance == USART2)
{
if (huart == &huart2)
{
A_flag = 1;
HAL_UARTEx_ReceiveToIdle_IT(&huart2, LSYT_RXbuffur, LSYT_DataSize - 1); // 再次开启空闲中断
}
}
}
/*>>>>>>>>>> (C) COPYRIGHT PSYM <<<<<< >>>>>> END OF FILE <<<<<<<<<<*/
/**-----------------------------------------------------------------------------
* (C) Copyright 2024, PSYM. All Rights Reserved
* ------------------------------------------------------------------------------
* File name : bsp_yt.h
* Description :
* Author : PSYM
* ------------------------------------------------------------------------------
* Update note:
* ----------- ----------- -------------------------------------------------
* Date Author Note
* ----------- ----------- -------------------------------------------------
* 2024-08-27, PSYM
*
*/
#ifndef __BSP_YT_H__
#define __BSP_YT_H__
/* --------------------------------- 包含头文件 --------------------------------- */
#include "main.h"
/* ----------------------------------- 宏定义 ----------------------------------- */
#define Host_DataSize 512
#define LSYT_DataSize 8
/* ---------------------------------- 类型定义 ---------------------------------- */
/* None. */
/* ---------------------------------- 扩展变量 ---------------------------------- */
extern uint8_t Host_RXbuffur[Host_DataSize];
extern uint8_t LSYT_RXbuffur[LSYT_DataSize];
extern int A_flag;
uint8_t LSYT_CMD[][6] = {
{0xFE, 0x04, 0x01, 0x01, 0x04, 0xFD}, // 语音:在呢
{0xFE, 0x04, 0x01, 0x02, 0x05, 0xFD}, // 语音:有需要再叫我
};
/* ---------------------------------- 函数声明 ---------------------------------- */
HAL_StatusTypeDef YT2228_SendCMD(uint8_t Data);
uint8_t YT2228_Analysis(uint8_t *result);
#endif /* bsp_yt_H */
/*>>>>>>>>>> (C) COPYRIGHT PSYM <<<<<< >>>>>> END OF FILE <<<<<<<<<<*/
————————————————
【本文转载自CSDN,作者:菩萨野蛮】