【雷龙科技】使用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转串口模块连接上语音模块测试,接线非常简单

USB转TTL模块语音模块
5V/3.3VVCC
GNDGND
TXDRX
RXDTX

说出唤醒词,看到串口返回了我们定义的数据
再说一下关键词,发现也都能返回对应的数据
等待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 <<<<<<<<<<*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值