【POCKET 51】用 pocket 51学51单片机 之四:pocket 51功能模块测试

系列文章【完善中】:
【POCKET 51】用 pocket 51学51单片机 之一:pocket 51诞生记
【POCKET 51】用 pocket 51学51单片机 之二:pocket 51的加工及焊接
【POCKET 51】用 pocket 51学51单片机 之三:pocket 51上电测试
【POCKET 51】用 pocket 51学51单片机 之四:pocket 51功能模块测试
【本设计已在立创开源平台开源】

1、LED灯测试

功能测试正常,代码见
【POCKET 51】用 pocket 51学51单片机 之三:pocket 51上电测试
中的内容。

2、数码管测试

V1.0版本数码管段码接反了,所以特殊生成了段码表进行测试
数码管测试代码:


#include "reg51.h"
#include "intrins.h"
sbit BEEP=P3^7;

sbit SEG1=P1^7;
sbit SEG2=P1^6;

unsigned char code SEG_code[]={ 
 
                0x03,  //"0"
                0x9F,  //"1"
                0x25,  //"2"
                0x0D,  //"3"
                0x99,  //"4"
                0x49,  //"5"
                0x41,  //"6"
                0x1F,  //"7"
                0x01,  //"8"
                0x09,  //"9"
                0x11,  //"A"
                0xC1,  //"B"
                0x63,  //"C"
                0x85,  //"D"
                0x61,  //"E"
                0x71,  //"F"
                0x91,  //"H"
                0xE3,  //"L"
                0x13,  //"n"
                0x83,  //"u"
                0x31,  //"P"
                0xC5,  //"o"
                0xFD,  //"-"
                0xFF,  //熄灭
                0xFF  //自定义
 
                         };	


void delay()
{
    int i, j;

    for (i=0; i<10; i++)
    for (j=0; j<500; j++);
}	
 	  
void main()
{  int i;

	BEEP=1;	 
	
    while (1)
    {	 

			 SEG1=0;
			 SEG2=1;
			 P0=SEG_code[3];
			 delay();
			 SEG1=1;
			 SEG2=0;
			 P0=SEG_code[9];
			 delay();

    }
}


测试结果正常
在这里插入图片描述

3、蜂鸣器测试

蜂鸣器采用了无源蜂鸣器,驱动时,需要采用脉冲进行驱动。
在这里插入图片描述
测试代码:


#include "reg51.h"
sbit BEEP=P3^7;	 
void delay()
{
    int i;	  
    for (i=0; i<100; i++);   
}	
 	  
void main()
{  int i;

	BEEP=1;	 
	
    while (1)
    {
			 BEEP=1;
			 delay();
			 BEEP=0;
			 delay();
    }
}

调整delay时间,可以发出不同音高。

4、按键功能测试

按下按键在数码管上显示键值,程序代码:

#include "reg51.h"
#include "intrins.h"
sbit BEEP=P3^7;

sbit SEG1=P1^7;
sbit SEG2=P1^6;

sbit keya=P3^2;
sbit keyb=P3^3;
sbit keyc=P3^4;
sbit keyd=P3^5;
unsigned char code SEG_code[]={ 0x03,0x9f,0x25,0x0d,0x99,0x49,0x41,0x1f,0x01,0x09,0x11,0xc1,0x63,0x85,0x61,0x71};

void delay()
{
    int i, j;

    for (i=0; i<10; i++)
    for (j=0; j<500; j++);
}	
 	  
void main()
{  int i,key=0;

	BEEP=1;	 
	
    while (1)
    {
		if(keya==0) key=1;
		if(keyb==0) key=2;
		if(keyc==0) key=3;
		if(keyd==0) key=4;	 

			 SEG1=0;
			 SEG2=1;
			 P0=SEG_code[key];
			 delay();


    }
}

运行结果:
按下B键
在这里插入图片描述
按下D键
在这里插入图片描述

5、WS2812多彩LED灯功能测试

【待完善】
由于手头没有示波器无法查看波形,暂时先不进行测试

6、串口测试

测试串口主要是进行晶振部分是否工作正常。测试代码使用了官方的UART例程

/*------------------------------------------------------------------*/
/* --- STC MCU Limited ---------------------------------------------*/
/* --- STC12C5Axx Series MCU UART (8-bit/9-bit)Demo ----------------*/
/* --- Mobile: (86)13922805190 -------------------------------------*/
/* --- Fax: 86-0513-55012956,55012947,55012969 ---------------------*/
/* --- Tel: 86-0513-55012928,55012929,55012966----------------------*/
/* --- Web: www.STCMCU.com -----------------------------------------*/
/* --- Web: www.GXWMCU.com -----------------------------------------*/
/* If you want to use the program or the program referenced in the  */
/* article, please specify in which data and procedures from STC    */
/*------------------------------------------------------------------*/

#include "reg51.h"
#include "intrins.h"

typedef unsigned char BYTE;
typedef unsigned int WORD;

#define FOSC 11059200L      //System frequency
#define BAUD 9600           //UART baudrate

/*Define UART parity mode*/
#define NONE_PARITY     0   //None parity
#define ODD_PARITY      1   //Odd parity
#define EVEN_PARITY     2   //Even parity
#define MARK_PARITY     3   //Mark parity
#define SPACE_PARITY    4   //Space parity

#define PARITYBIT EVEN_PARITY   //Testing even parity

sbit bit9 = P2^2;           //P2.2 show UART data bit9
bit busy;

void SendData(BYTE dat);
void SendString(char *s);

void main()
{
#if (PARITYBIT == NONE_PARITY)
    SCON = 0x50;            //8-bit variable UART
#elif (PARITYBIT == ODD_PARITY) || (PARITYBIT == EVEN_PARITY) || (PARITYBIT == MARK_PARITY)
    SCON = 0xda;            //9-bit variable UART, parity bit initial to 1
#elif (PARITYBIT == SPACE_PARITY)
    SCON = 0xd2;            //9-bit variable UART, parity bit initial to 0
#endif

    TMOD = 0x20;            //Set Timer1 as 8-bit auto reload mode
    TH1 = TL1 = -(FOSC/12/32/BAUD); //Set auto-reload vaule
    TR1 = 1;                //Timer1 start run
    ES = 1;                 //Enable UART interrupt
    EA = 1;                 //Open master interrupt switch

    SendString("STC12C5A60S2\r\nUart Test !\r\n");
    while(1);
}

/*----------------------------
UART interrupt service routine
----------------------------*/
void Uart_Isr() interrupt 4 using 1
{
    if (RI)
    {
        RI = 0;             //Clear receive interrupt flag
        P0 = SBUF;          //P0 show UART data
        bit9 = RB8;         //P2.2 show parity bit
    }
    if (TI)
    {
        TI = 0;             //Clear transmit interrupt flag
        busy = 0;           //Clear transmit busy flag
    }
}

/*----------------------------
Send a byte data to UART
Input: dat (data to be sent)
Output:None
----------------------------*/
void SendData(BYTE dat)
{
    while (busy);           //Wait for the completion of the previous data is sent
    ACC = dat;              //Calculate the even parity bit P (PSW.0)
    if (P)                  //Set the parity bit according to P
    {
#if (PARITYBIT == ODD_PARITY)
        TB8 = 0;            //Set parity bit to 0
#elif (PARITYBIT == EVEN_PARITY)
        TB8 = 1;            //Set parity bit to 1
#endif
    }
    else
    {
#if (PARITYBIT == ODD_PARITY)
        TB8 = 1;            //Set parity bit to 1
#elif (PARITYBIT == EVEN_PARITY)
        TB8 = 0;            //Set parity bit to 0
#endif
    }
    busy = 1;
    SBUF = ACC;             //Send data to UART buffer
}

/*----------------------------
Send a string to UART
Input: s (address of string)
Output:None
----------------------------*/
void SendString(char *s)
{
    while (*s)              //Check the end of the string
    {
        SendData(*s++);     //Send current char and increment string ptr
    }
}


烧录后工作正常,运行效果:
在这里插入图片描述

7、外接PAD焊盘功能测试

测试了P1.2端口(丝印误写为P2.2),采用了简单的闪灯程序,外部直接接一个LED灯到GND管脚。
测试程序如下:

#include "reg51.h"
            
sfr P4SW = 0xBB;
sbit P12=P1^2;

void delay()
{
    int i, j;

    for (i=0; i<1000; i++)
    for (j=0; j<500; j++);
}	  	  
void main()
{
    P4SW = 0x70;
    while (1)
    {	 
        P12 = 1;
        delay();
        P12 = 0;	 
        delay();
    }
}

测试结果,闪灯正常:
在这里插入图片描···述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
pocketsphinx是一个开源的语音识别引擎,可以用于嵌入式设备和桌面应用程序。以下是pocketsphinx的使用教程: 1. 下载pocketsphinx-0.7.tar.gz文件并解压缩。 2. 下载中文语言模型文件tdt_sc_8k和拼音读音字典xxxx.dic,放置于pocketsphinx*** 下载英文语言模型文件hub4wsj_sc_8k和英文读音字典xxxx.dic,放置于pocketsphinx-0.7\model\hmm\en_US和pocketsphinx-0.7\model\lm\en_US目录下。 4. 安装SWIG和Python,并将pocketsphinx-0.7\swig目录添加到系统路径中。 5. 在Python中导入pocketsphinx模块,并使用以下代码进行语音识别: ``` import pocketsphinx as ps import pyaudio # 创建语音识别器 config = ps.Decoder.default_config() config.set_string('-hmm', 'pocketsphinx-0.7/model/hmm/zh/tdt_sc_8k') config.set_string('-lm', 'pocketsphinx-0.7/model/lm/zh_CN/xxxx.dic') config.set_string('-dict', 'pocketsphinx-0.7/model/lm/zh_CN/xxxx.dic') decoder = ps.Decoder(config) # 开始录音并进行语音识别 p = pyaudio.PyAudio() stream = p.open(format=pyaudio.paInt16, channels=1, rate=16000, input=True, frames_per_buffer=1024) stream.start_stream() in_speech_bf = False decoder.start_utt() while True: buf = stream.read(1024) if buf: decoder.process_raw(buf, False, False) if decoder.get_in_speech() != in_speech_bf: in_speech_bf = decoder.get_in_speech() if not in_speech_bf: decoder.end_utt() print('识别结果:', decoder.hyp().hypstr) decoder.start_utt() else: break decoder.end_utt() # 关闭录音流 stream.stop_stream() stream.close() p.terminate() ``` 相关问题: 1. pocketsphinx支持哪些语言? 2. 如何优化pocketsphinx的识别准确率? 3. pocketsphinx适用于哪些场景?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值