/**************************************************************************** * 文件名:AD_CAIYANG.C * 功能:使用AD采集电压显示在LCD * 说明:转自网络,本人验证通过 ****************************************************************************/ #include<STC12C5A60S2.H> #define uint unsigned int #define uchar unsigned char sbit CS=P2^0; //LCD12864串行通信片选 sbit SID=P2^1; //LCD12864串行通信数据口 sbit SCLK=P2^2; //LCD12864串行通信同步时钟信号 sbit PSB=P2^5; //LCD12864并/串选择:H并行 L串行 unsigned int temp1,sh1,ge1,n1,m1; unsigned char ad_result_data[10]; //AD转换高八位 unsigned char ad_result_low2[10]; //AD转换低八位 unsigned char ad_result_total[10]; //AD转换总十位 unsigned char ad_average_result; //AD转换十次的平均值 unsigned char Ain,Vin; unsigned char b,t,R; char tp=0; unsigned char code ma1[6]={0xb5,0xe7,0xd1,0xb9,0xa1,0xc3}; //电压: unsigned char code ma2[]={"."}; uchar code disp1[]={"提示: 按1 键进入"}; uchar code disp2[]={"功能选择界面. "}; unsigned char code num0[]={0xa3,0xb0}; unsigned char code num1[]={0xa3,0xb1}; unsigned char code num2[]={0xa3,0xb2}; unsigned char code num3[]={0xa3,0xb3}; unsigned char code num4[]={0xa3,0xb4}; unsigned char code num5[]={0xa3,0xb5}; unsigned char code num6[]={0xa3,0xb6}; unsigned char code num7[]={0xa3,0xb7}; unsigned char code num8[]={0xa3,0xb8}; unsigned char code num9[]={0xa3,0xb9}; //-------模块延时程序---------------------------- 1ms void delay1ms(uint delay1ms) //STC11F60XE,22.1184M,延时1ms { uint i,j; for(;delay1ms>0;delay1ms--) for(i=0;i<7;i++) for(j=0;j<210;j++); } void delay(uint delay) //STC11F60XE,22.1184M,延时170us { uint i,j; for(;delay>0;delay--) for(i=0;i<124;i++); for(j=0;j<124;j++); } /******************************************************* AD转换程序 *******************************************************/ void AD_initiate() //初始化函数 { ES=0; TMOD=0x21; //定时计数器方式控制寄存器,"自动重装,16位计数器". SCON=0x50; //串行控制寄存器,方便在串口助手那观察 TH1=0xfa; TL1=0xfa; TR1=1; } void ADC_Power_On() //AD转换电 { ADC_CONTR|=0x80; delay(5); //必要的延时 } void get_ad_result() //取AD结果函数,它是十位AD转换,每十次平均,最后取低八位作为AD采样数据 { uint i,q=0; for(i=0;i<10;i++) { tp=0; ADC_RES=0; //高八位数据清零,STC12C5A60S2 AD数据寄存名与STC12C54××系列不同 ADC_RESL=0; //低两位清零 ADC_CONTR|=0x08; //启动AD转换 while(!tp) //判断AD转换是否完成 { tp=0x10; tp&=ADC_CONTR; } ADC_CONTR&=0xe7; ad_average_result=ADC_RES; q=q+ad_average_result; } ad_average_result=q/10; //ad_average_result=ad_average_result*4*5000/1024; } /************************AD转换结束***********************/ void send_ad_result() //取AD结果函数发送到串口,方便调试 { SBUF=n1; while(TI==0) ; TI=0; delay1ms(100); //SBUF=R>>4; } //---------------------电压采样程序------------------------- void caiyangP10() //测电压 { P1M0|=0x01; //设P1_0为开漏模式 如: P1_0= #00000000B P1M1|=0x01; ADC_CONTR=0xe0; //设置P1.0为输入AD转换口 delay(2); get_ad_result(); //取转换数据 Vin=ad_average_result; R=Vin; } /*-----------写控制字到LCD12864------------*/ void write_cmd(uchar cmd) { uchar i; uchar i_data; i_data=0xf8; //命令控制字:11111000写指令 11111010写数据 11111100读状态 11111110读数据 CS=1; //片选置高,才能进行读写操作 SCLK=0; /*----------写命令控制字-----------------*/ for(i=0;i<8;i++) //循环八次,每次读取一位数据 { SID=(bit)(i_data&0x80); //bit表示取其最高位 SCLK=0; SCLK=1; //正跳变写入指令 i_data=i_data<<1; //左移一位 } /*---------------------------------------*/ /*----------写指令高四位-----------------*/ i_data=cmd; i_data=i_data&0xf0; //把低四位置0 for(i=0;i<8;i++) //循环八次,每次读取一位数据 { SID=(bit)(i_data&0x80); //bit表示取其最高位 SCLK=0; SCLK=1; //正跳变写入指令 i_data=i_data<<1; //左移一位 } /*---------------------------------------*/ /*----------写指令低四位-----------------*/ i_data=cmd; i_data=i_data<<4; //左移四位,把低四位的数据移到高四位,再把低四位置0 for(i=0;i<8;i++) //循环八次,每次读取一位数据 { SID=(bit)(i_data&0x80); //bit表示取其最高位 SCLK=0; SCLK=1; //正跳变写入指令 i_data=i_data<<1; //左移一位 } /*-----------------------------------------*/ CS=0; //把片选置低 delay1ms(5); //延时是因为没有进行忙检测,适当的延时可以不进行忙检测 } /*-----------------------------------------*/ /*------------写数据到LCD12864-------------*/ void write_dat(uchar dat) { uchar i; uchar i_data; i_data=0xfa; CS=1; for(i=0;i<8;i++) { SID=(bit)(i_data&0x80); SCLK=0; SCLK=1; i_data=i_data<<1; } i_data=dat; i_data=i_data&0xf0; for(i=0;i<8;i++) { SID=(bit)(i_data&0x80); SCLK=0; SCLK=1; i_data=i_data<<1; } i_data=dat; i_data=i_data<<4; for(i=0;i<8;i++) { SID=(bit)(i_data&0x80); SCLK=0; SCLK=1; i_data=i_data<<1; } CS=0; delay1ms(5); } /*-----------------------------------------*/ /*--------------显示坐标-------------------*/ void lcd_pos(uchar x,uchar y) //汉字显示坐标,x为哪一行,y为哪一列 { uchar pos; if(x==0) x=0x80; //第一行 else if(x==1) x=0x90; //第二行 else if(x==2) x=0x88; //第三行 else if(x==3) x=0x98; //第四行 pos=x+y; //显示哪一行(总共有4行)哪一竖(总共有8竖,每16列为1竖) write_cmd(pos); } /*-----------------------------------------*/ /*--------------显示8个汉字-------------------*/ void disp_hanzi(uchar code *chn) { uchar i; write_cmd(0x30); //基本指令操作方式 for(i=0;i<16;i++) //16列*8个汉字=128(刚好) write_dat(chn[i]); } /*-----------------------------------------*/ /*--------------显示数字-------------------*/ void disp_num(uchar code *chn) { uchar i; write_cmd(0x30); //基本指令操作方式 for(i=0;i<2;i++) //1个数字 write_dat(chn[i]); } void disp_number(uchar num) { switch(num) { case 0: disp_num(num0);break; case 1: disp_num(num1);break; case 2: disp_num(num2);break; case 3: disp_num(num3);break; case 4: disp_num(num4);break; case 5: disp_num(num5);break; case 6: disp_num(num6);break; case 7: disp_num(num7);break; case 8: disp_num(num8);break; case 9: disp_num(num9);break; default: break; } } /*----------- --LCD初始化------------------*/ void lcd_init() { PSB=0; write_cmd(0x30); //基本指令 write_cmd(0x02); //地址归位 write_cmd(0x06); //游标右移 write_cmd(0x0c); //整体显示 write_cmd(0x01); //清屏 } /*-----------------------------------------*/ void displayP10() { float ad1; //unsigned int temp1,sh1,ge1,n1,m1; //uchar code dis2[]={0x01,0x02,0x00}; //ad1=x*7.8125; //电压修正 uchar i; ad1=Vin*3.9608; //具体线性参数由输入电压值调整,该值的测量范围为0-10.00V,5V左右的测量比较准确, //两端的最大误差为70mv,其他一般在40mv以内 temp1=(int)ad1; sh1=temp1/1000; //十位 ge1=(temp1%1000)/100; //个位 n1=((temp1%1000)%100)/10; //小数点后一位 m1=((temp1%1000)%100)%10; //小数点后二位 //write_cmd(0x01); write_cmd(0x30); //基本指令操作方式 lcd_pos(0,0); for(i=0;i<6;i++) write_dat(ma1[i]); lcd_pos(0,3); disp_number(sh1); lcd_pos(0,4); disp_number(ge1); lcd_pos(0,5); for(i=0;i<2;i++) write_dat(ma2[i]); lcd_pos(0,6); disp_number(n1); lcd_pos(0,7); disp_number(m1); /*lcd_pos(2,0); disp_hanzi(disp1); lcd_pos(3,0); disp_hanzi(disp2);*/ } void main() { EA=1; AD_initiate(); //初始化 ADC_Power_On(); //开AD电源 //init(); lcd_init(); delay(10); while(1) { caiyangP10(); //测电压 send_ad_result(); //Vin=Vin*4007; displayP10(); delay(10); } }

//两个文件 //main.c #include <REG51.H> #include <intrins.h> #define U8 unsigned char #define U16 unsigned int void DelayMs(U8 ms); void PWM_clock(U8 clock); void PWM_start(U8 module,U8 mode); // 延时子程序/ void DelayMs(U8 ms) //在11.0592M晶振下,stc10f系列(单周期指令)的ms级延时 { U16 i; while(ms--) { for(i = 0; i < 850; i++); } } 主函数入口 sfr CCON = 0xD8; //PCA控制寄存器 sfr CMOD = 0xD9; //PCA模式寄存器 sfr CCAPM0 = 0xDA; //PCA模块0模式寄存器 //模块0对应P1.3/CEX0/PCA0/PWM0(STC12C5A60S2系列) sfr CCAPM1 = 0xDB; //PCA模块1模式寄存器 //模块1对应P1.4/CEX1/PCA1/PWM1(STC12C5A60S2系列) sfr CL = 0xE9; //PCA 定时寄存器 低位 sfr CH = 0xF9; //PCA 定时寄存器 高位 sfr CCAP0L = 0xEA; //PCA模块0的 捕获寄存器 低位 sfr CCAP0H = 0xFA; //PCA模块0的 捕获寄存器 高位 sfr CCAP1L = 0xEB; //PCA模块1的 捕获寄存器 低位 sfr CCAP1H = 0xFB; //PCA模块1的 捕获寄存器 高位 sfr PCA_PWM0 = 0xF2; //PCA PWM 模式辅助寄存器0 sfr PCA_PWM1 = 0xF3; //PCA PWM 模式辅助寄存器1 sbit CF = 0xDF; //PCA计数溢出标志位 sbit CR = 0xDE; //PCA计数器 运行控制位 sbit CCF1 = 0xD9; //PCA模块1中断标志 sbit CCF0 = 0xD8; //PCA模块0中断标志 //* CCAPOH = CCAPOL = 0XC0; //模块0输出 占空因数为25% //* CCAPOH = CCAPOL = 0X80; //模块0输出 占空因数为50% //* CCAPOH = CCAPOL = 0X40; //模块0输出 占空因数为75% void PWM_clock(U8 clock); void PWM_start(U8 module,U8 mode); void PWM_clock(U8 clock) { CMOD |= (clock<<1); CL = 0x00; CH = 0x00; } void PWM_start(U8 module,U8 mode) { CCAP0L = 0XC0; CCAP0H = 0XC0; //模块0初始输出 占空因数为25% CCAP1L = 0XC0; CCAP1H = 0XC0; //模块1初始输出 占空因数为25% if(module==0) { switch(mode) { case 0: CCAPM0 = 0X42;break; //模块0设置为8位PWM输出,无中断 case 1: CCAPM0 = 0X53;break; //模块0设置为8位PWM输出,下降沿产生中断 case 2: CCAPM0 = 0X63;break; //模块0设置为8位PWM输出,上升沿产生中断 case 3: CCAPM0 = 0X73;break; //模块0设置为8位PWM输出,跳变沿产生中断 default: break; } } else if(module==1) { switch(mode) { case 0: CCAPM1 = 0X42;break; //模块1设置为8位PWM输出,无中断 case 1: CCAPM1 = 0X53;break; //模块1设置为8位PWM输出,下降沿产生中断 case 2: CCAPM1 = 0X63;break; //模块1设置为8位PWM输出,上升沿产生中断 case 3: CCAPM1 = 0X73;break; //模块1设置为8位PWM输出,跳变沿产生中断 default: break; } } else if(module==2) { switch(mode) { case 0: CCAPM0 = CCAPM1 = 0X42;break; //模块0和1设置为8位PWM输出,无中断 case 1: CCAPM0 = CCAPM1 = 0X53;break; //模块0和1设置为8位PWM输出,下降沿产生中断 case 2: CCAPM0 = CCAPM1 = 0X63;break; //模块0和1设置为8位PWM输出,上升沿产生中断 case 3: CCAPM0 = CCAPM1 = 0X73;break; //模块0和1设置为8位PWM输出,跳变沿产生中断 default: break; } } CR=1; //PCA计数器开始计数 } void PCA_Intrrpt(void) interrupt 7 { if(CCF0) CCF0=0; if(CCF1) CCF1=0; //软件清零 if(CF) CF=0; //软件清零 } void main() { TMOD|=0x02; /* timer 0 mode 2: 8-Bit reload */ TH0=0xff; TR0=1; PWM_clock(2); // PCA/PWM时钟源为 定时器0的溢出 PWM_start(0,0); // 模块0,设置为PWM输出,无中断,初始占空因素为25% while(1) { DelayMs(250); } } PwmDrive_12C5A.c #include <intrins.h> #define U8 unsigned char sfr CCON = 0xD8; //PCA控制寄存器 sfr CMOD = 0xD9; //PCA模式寄存器 sfr CCAPM0 = 0xDA; //PCA模块0模式寄存器 //模块0对应P1.3/CEX0/PCA0/PWM0(STC12C5A60S2系列) sfr CCAPM1 = 0xDB; //PCA模块1模式寄存器 //模块1对应P1.4/CEX1/PCA1/PWM1(STC12C5A60S2系列) sfr CL = 0xE9; //PCA 定时寄存器 低位 sfr CH = 0xF9; //PCA 定时寄存器 高位 sfr CCAP0L = 0xEA; //PCA模块0的 捕获寄存器 低位 sfr CCAP0H = 0xFA; //PCA模块0的 捕获寄存器 高位 sfr CCAP1L = 0xEB; //PCA模块1的 捕获寄存器 低位 sfr CCAP1H = 0xFB; //PCA模块1的 捕获寄存器 高位 sfr PCA_PWM0 = 0xF2; //PCA PWM 模式辅助寄存器0 sfr PCA_PWM1 = 0xF3; //PCA PWM 模式辅助寄存器1 sbit CF = 0xDF; //PCA计数溢出标志位 sbit CR = 0xDE; //PCA计数器 运行控制位 sbit CCF1 = 0xD9; //PCA模块1中断标志 sbit CCF0 = 0xD8; //PCA模块0中断标志 //* CCAPOH = CCAPOL = 0XC0; //模块0输出 占空因数为25% //* CCAPOH = CCAPOL = 0X80; //模块0输出 占空因数为50% //* CCAPOH = CCAPOL = 0X40; //模块0输出 占空因数为75% void PWM_clock(U8 clock); void PWM_start(U8 module,U8 mode); void PWM_clock(U8 clock) { CMOD |= (clock<<1); CL = 0x00; CH = 0x00; } void PWM_start(U8 module,U8 mode) { CCAP0L = 0XC0; CCAP0H = 0XC0; //模块0初始输出 占空因数为25% CCAP1L = 0XC0; CCAP1H = 0XC0; //模块1初始输出 占空因数为25% if(module==0) { switch(mode) { case 0: CCAPM0 = 0X42;break; //模块0设置为8位PWM输出,无中断 case 1: CCAPM0 = 0X53;break; //模块0设置为8位PWM输出,下降沿产生中断 case 2: CCAPM0 = 0X63;break; //模块0设置为8位PWM输出,上升沿产生中断 case 3: CCAPM0 = 0X73;break; //模块0设置为8位PWM输出,跳变沿产生中断 default: break; } } else if(module==1) { switch(mode) { case 0: CCAPM1 = 0X42;break; //模块1设置为8位PWM输出,无中断 case 1: CCAPM1 = 0X53;break; //模块1设置为8位PWM输出,下降沿产生中断 case 2: CCAPM1 = 0X63;break; //模块1设置为8位PWM输出,上升沿产生中断 case 3: CCAPM1 = 0X73;break; //模块1设置为8位PWM输出,跳变沿产生中断 default: break; } } else if(module==2) { switch(mode) { case 0: CCAPM0 = CCAPM1 = 0X42;break; //模块0和1设置为8位PWM输出,无中断 case 1: CCAPM0 = CCAPM1 = 0X53;break; //模块0和1设置为8位PWM输出,下降沿产生中断 case 2: CCAPM0 = CCAPM1 = 0X63;break; //模块0和1设置为8位PWM输出,上升沿产生中断 case 3: CCAPM0 = CCAPM1 = 0X73;break; //模块0和1设置为8位PWM输出,跳变沿产生中断 default: break; } } CR=1; //PCA计数器开始计数 } void PCA_Intrrpt(void) interrupt 7 { if(CCF0) CCF0=0; if(CCF1) CCF1=0; //软件清零 if(CF) CF=0; //软件清零 }

---------------------------------------------------------------------------------------------------------------------------

今天下午把STC12C5A60S2的ADC转换函数写了,查询法只要检查ADC_FLAG是否为1,再进行相关程序就行了。下面这个是用中断法。这是STC技术手册上提供的中断号,直接在PDF上复制过来的,显示顺序乱了,自己可以在中断寄存器 那一节可以看到

?void Int0_Routine(void) interrupt 0;
void LVD_Routine(void) interrupt 6;
void ADC_Routine(void) interrupt 5;
void PCA_Routine(void) interrupt 7;
void Timer0_Routine(void) interrupt 1;
void Int1_Routine(void) interrupt 2;
void Timer1_Routine(void) interrupt 3;
void UART_Routine(void) interrupt 4;
void UART2_Routine(void) interrupt 8;
void SPI_Routine(void) interrupt 9;

STC12C5A60AD/S2系列带A/D转换的单片机的A/D转换口在P1口(P1.7-P1.0),有8路10位高速A/D转
换器,速度可达到250KHz(25 万次/ 秒)。8 路电压输入型A/D,可做温度检测、电池电压检测、按键扫描、
频谱检测等。上电复位后P1 口为弱上拉型I/O 口,用户可以通过软件设置将8 路中的任何一路设置为A/D
转换,不需作为A/D 使用的口可继续作为I/O 口使用。

具体寄存器设置见STC的datasheet.

注:此函数只是读取寄存器中的值,没有进行电压的转换

#include <reg52.h> #include <lcm12864.h> #include <intrins.h> sfr P1ASF = 0x9D; sfr ADC_CONTR = 0xbc; sfr ADC_RES = 0xbd; sfr ADC_RESL = 0xbe; sfr AUXR1 = 0xa2; sbit EADC = IE^5; #define ADC_Power_On_Speed_Channel_0 0x88 unsigned int val; void ADC_Routine() interrupt 5 //ADC中断函数 { ADC_CONTR &= 0xef;//清楚转换结束标志位 _nop_(); _nop_();_nop_();_nop_();_nop_();_nop_(); val = ADC_RES*256 + ADC_RESL; //读取转换数据 } void main() { Init_12864Word(); LCM12864_wr_String(1,1,"ADC 测试 "); EA = 1; //开总中断 EADC = 1; //开ADC中断 while(1) { P1ASF = 0x01; //设置P1.0口位模拟功能 //设置控制寄存器,10001000B,开ADC电源,转换速度控制00,模拟通道选择000(P1.0),开始转换 ADC_CONTR = ADC_Power_On_Speed_Channel_0; _nop_(); _nop_();_nop_();_nop_();_nop_();_nop_(); AUXR1 = 0x04; //数据格式设置 LCM12864_wr_Cmd(0x88); //液晶显示 LCM12864_wr_Byte(val/10000+0x30); LCM12864_wr_Byte(val%10000/1000+0x30); LCM12864_wr_Byte(val%1000/100+0x30); LCM12864_wr_Byte(val%100/10+0x30); LCM12864_wr_Byte(val%10+0x30); } }

----------------------------------------------------------------------------------------------------------------

STC单片机内置ADC的使用方法

STC系列单片机中的STC89LE516AD/X2提供了8路8位精度的高速A/D转换器,位于P1口上,从而省去了片外ADC的麻烦。这8路ADC为电压输入型,可做按键扫描,电池电压检测,频谱检测等。ADC转换过程需要17个机器周期。通过对相关功能寄存器的适当配置,就可以控制其工作。下面就对相关功能寄存器进行介绍。

A/D转换寄存器总表:

寄存器

地址

名称

7

6

5

4

3

2

1

0

初始初

P1_ADC_EN

97H

允许P1.x

成为A/D口

P17

P16

P15

P14

P13

P12

P11

P10

0000

0000

ADC_

CONTR

C5H

A/D转换

控制寄存器

ADC_FLAG

ADC_START

CHS2

CHS1

CHS0

xxx0

0000

ADC_DATA

C6H

A/D转换

结果寄存器

0000

0000

(1)       P1_ADC_EN:特殊功能寄存器

P1.x作为A/D转换输入通道来用允许特殊功能寄存器。相应位为“1”时,对应的P1.x口作为A/D转换使用,内部上拉电阻自动断开。

(2)       ADC_CONTR:特殊功能寄存器

CHS2/CHS1/CHS0是模拟输入通道选择,CHS2/CHS1/CHS0的取值如下表所示:

CHS2

CHS1

CHS0

模拟输入通道选择

0

0

0

选择P1.0为A/D输入

0

0

1

选择P1.1为A/D输入

0

1

0

选择P1.2为A/D输入

0

1

1

选择P1.3为A/D输入

1

0

0

选择P1.4为A/D输入

1

0

1

选择P1.5为A/D输入

1

1

0

选择P1.6为A/D输入

1

1

1

选择P1.7为A/D输入

ADC_START是模拟/数字转换(ADC)启动控制位,设置为1时,开始转换。

ADC_FLAG是模拟/数字转换结束标志位,当A/D转换完成后,ADC_FLAG=1。

(3)       ADC_DATA: A/D转换结果特殊功能寄存器

模拟/数字转换结果计算公式为 结果=256×Vin/Vcc

Vin是模拟输入通道输入电压,Vcc为单片机实际工作电压,用单片机工作电压作为模拟参考电压。

//STC_ADC.h: sfr P1_ADC_EN=0x97; sfr ADC_CONTR=0xc5; sfr ADC_DATA=0xc6; int GetAD(unsigned char channel)//channel为要取的通道号(0~7) { unsigned char AD_finished=0; ADC_DATA=0; ADC_CONTR=channel; ADC_CONTR|=0x08; while(!AD_finished) AD_finished=(ADC_CONTR&0x10); ADC_CONTR&=0xF7; return (ADC_DATA); } void AD_Init(unsigned char ADin)// ADC 初始化,ADin为八位2进制数,分别对应AD7~0,置1代表打开此路 { P1=P1|ADin;//要设置为A/D转换的P1.x口,先设为高 P1_ADC_EN=ADin; }

_main.c: #include <reg51.h> #include <stc_adc.h> /* ------------------------------------------------- 此程序用以说明STC单片机ADC的使用方法 ------------------------------------------------- */ void delay(unsigned time) { while(time--); } void main() { AD_Init(0x63);//0110,0011,要设置为A/D转换的P1.x口,先设置为高 //0110,0011,P1的P1.0,P1.1,P1.5,P1.6设置为A/D转换输入脚 //断开P1.0,P1.1,P1.5,P1.6内部上拉电阻 while(1) { P2=GetAD(0); delay(10000); P2=GetAD(1); delay(10000); P2=GetAD(5); delay(10000); P2=GetAD(6); delay(10000); } }

STC12CA560S2 ADC/PWM相关例程相关推荐

  1. FMD辉芒微FT61F133A-RB SOP16 ADC/PWM型单片机MCU

    FMD辉芒微FT61F133A-RB SOP16 ADC/PWM型单片机MCU 产品简介 : FT61F13X是一款精简指令集的A/D型8位单片机,其内部集成了一个RAM数据存储器和一个非易失型数据E ...

  2. STC15系列PWM相关功能寄存器介绍

    STC15系列PWM相关功能寄存器介绍 ✨以下数据来源于stc15手册.

  3. 基于mdm9206 threadx_os的adc操作相关API介绍

    大家好,今天小白给大家介绍一下,关于mdm9206 threadx_os的adc操作相关的API,希望能和大家一起交流学习. 1 ADC简介 模数转换器(ADC)允许对模拟信号进行采样和数字表示. S ...

  4. FMD辉芒微原厂FT61F133A-RB SOP16 ADC/PWM型单片机MCU

    FMD辉芒微原厂FT61F133A-RB SOP16 ADC/PWM型单片机MCU 产品简介 : FT61F13X泛海微是一款精简指令集的A/D型8位单片机,其内部集成了一个RAM数据存储器和一个非易 ...

  5. FMD辉芒微原厂FT61F135-TRB SOP20 ADC/PWM型单片机MCU

    FMD辉芒微原厂FT61F135-TRB  SOP20 ADC/PWM型单片机MCU FT61F13X 产品简介 : FT61F13X是一款精简指令集的A/D型8位单片机,其内部集成了一个RAM数据存 ...

  6. MSP430F5529LP 2022电赛学习准备及相关例程

    写在前面: 写下这篇东西的目的首先是希望自己以后忘记MSP430如何使用的时候,能够在看到这篇记录之后能够迅速想起.其次,也希望能够为其他同学或者有需要的人提供一点帮助,话不多说,下面开始正文. 目录 ...

  7. 应广单片机adc_应广PMC232系列单片机 12位ADC PWM LCD 双核心8位MCU

    PMC232系列 台湾应广 一级代理 现货批发 长期供应 带12位ADC.采用FPPATM技术.双核心8位单片机 PMC232为P232的升级版,内部基准电压更准,节省TL431. 工作电压更宽,功耗 ...

  8. AD7606系列ADC的相关内容

    AD7606特性及功能简介 AD7606/AD7606-6/AD7606-4[4]为 16 位同步采样模数数据采集系统(DAS),分别有 8. 6. 4 个采集通道.片上集成模拟输入箝位保护.二阶抗混 ...

  9. TMS28027输出PWM波例程解析

    PWM波模块由Time-Base(时基).Counter-Compare(计数器比较).Action-Qualifier(波形发生器).Dead-Band(死区设置).Trip-Zone(错误处理). ...

最新文章

  1. 算法设计与分析第2章 递归与分治策略
  2. SQL Server 2008高可用性系列:数据库快照
  3. 神经网络学习笔记-02-循环神经网络
  4. 哈希表(散列查找)(c/c++)
  5. 网易云信联手长沙银行,远程视频银行系统助力数字化转型
  6. 连麦互动直播方案全实践1:什么是连麦互动直播?
  7. python爬虫获取小说根据正文调用函数传入章节地址列表_python爬虫之小说章节获取,聊斋志异小说完整版...
  8. 我建了这个-现在呢? 如何在DigitalOcean Droplet上部署React App。
  9. linux 'stack'未声明(在此函数内第一次使用,c - 错误:未声明“ asm”(此函数中的首次使用) - 堆栈内存溢出...
  10. 如何快速入手 Shell 脚本编程
  11. Yii Framework2.0开发教程(8)输入验证
  12. Windows以下系统蓝屏cmd一句话命令
  13. js混淆还原工具_JavaScript(JS) 压缩 / 混淆 / 格式化 批处理工具
  14. qq服务器正在升级维护中,建议您稍后再尝试打开.谢谢!,用友通维护锦集
  15. 利用python从网络上爬取图片_我用Python爬取了妹子网100G的套图
  16. 关于微博营销推广案例
  17. Go sqlx 框架使用下划线命名法处理结构体字段
  18. DBA的职场生涯应如何选择?
  19. 今日学习在线编程题:小码哥的手下
  20. 短信网关接口开发技术

热门文章

  1. 项目经理必知的项目管理“铁三角”
  2. 云计算、大数据和人工智能的关系
  3. COSCon'20 Track J 女性半边天分论坛介绍
  4. 曙光5000a超级计算机性能,曙光5000A 超级计算机的Linpack 测试
  5. 屏蔽 Alt+F4 和 Escape 键
  6. 网络安全应急演练学习笔记第一篇之总则、分类及方法、组织机构
  7. Java调用打印机打印PDF文档的两种方法
  8. 用户手册——机房收费系统
  9. 绘图库Matplotlib | Python技能树征题
  10. 致微信:我们什么时候重新定义群聊?