找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1726|回复: 6
收起左侧

简易电阻测试仪制作怎么做10M的量程单位 附单片机代码

[复制链接]
ID:1047409 发表于 2022-11-14 23:31 | 显示全部楼层 |阅读模式
/************************************
*********STC89C51**********
**********12MHz晶振********/
电路原理图如下:

原理图

原理图


单片机源程序如下:
  1. #include "reg51.h"
  2. #include
  3. #include
  4. #define uint8 unsigned char
  5. #define uint16 unsigned int
  6. #define uchar unsigned char
  7. #define uint unsigned int


  8. uint16 cnt2ms;        //10ms计数器
  9. uint8 cnt1s;        //1秒计数器

  10. //电阻--------------------------------
  11. #define        Z1 13700053.00
  12. #define        Z2 3685279.00


  13. float RZ=0;
  14. unsigned long   RX=0;
  15. unsigned long   RX2=0;
  16. unsigned long   RX3=0;
  17. unsigned long   RX4=0;
  18. unsigned long   RX5=0;
  19. unsigned long   RX6=0;
  20. unsigned long   RX7=0;
  21. unsigned long   RX8=0;
  22. unsigned long   RX9=0;

  23. uint8 KL=0;        //
  24. unsigned int Pulsecnt=0;        //脉冲个数
  25. unsigned int Pulsenum;        //脉冲个数
  26. uint8 start=0;        //
  27. uint16 Pulseme;        //10ms计数器
  28. uint16 Pulse;        //10ms计数器
  29. bit flag=0;
  30. uint8 CH=0;        //
  31. unsigned long x;
  32. void Init_Extint(void);
  33. void TimerInitProc();

  34. void Init_System(void);
  35. void Display(uint8 chose_dat, uint8 dat);
  36. void ShowDisp(uint8 tPulsenum, uint8 tPulsecnt, uint8 tcnt1s);
  37. void DelayMs(uint8 Ms);
  38. uint8 Pulse_FLAG=0;
  39. uint8 Pulse_5=0;
  40. /********************************按键*****************************************/
  41. ***it    K2=P1^4;                  //电阻档

  42. /********************************LCD液晶**************************************/
  43. #define LCD_Data P0           //LCD的数据口
  44. ***it    LCD_BF=LCD_Data^7;    //LCD忙信号位
  45. ***it    LCD_RS=P1^0;
  46. ***it    LCD_RW=P1^1;
  47. ***it    LCD_EN=P1^2;



  48. #define LCD_GO_HOME               0x02         //AC=0,光标、画面回HOME位

  49. //输入方式设置
  50. #define LCD_AC_AUTO_INCREMENT     0x06         //数据读、写操作后,AC自动增一
  51. #define LCD_AC_AUTO_DECREASE      0x04         //数据读、写操作后,AC自动减一
  52. #define LCD_MOVE_ENABLE           0x05         //数据读、写操作,画面平移
  53. #define LCD_MOVE_DISENABLE        0x04         //数据读、写操作,画面不动

  54. //设置显示、光标及闪烁开、关
  55. #define LCD_DISPLAY_ON            0x0C         //显示开
  56. #define LCD_DISPLAY_OFF           0x08         //显示关
  57. #define LCD_CURSOR_ON             0x0A         //光标显示
  58. #define LCD_CURSOR_OFF            0x08         //光标不显示
  59. #define LCD_CURSOR_BLINK_ON       0x09         //光标闪烁
  60. #define LCD_CURSOR_BLINK_OFF      0x08         //光标不闪烁

  61. //光标、画面移动,不影响DDRAM
  62. #define LCD_LEFT_MOVE             0x18         //LCD显示左移一位
  63. #define LCD_RIGHT_MOVE            0x1C         //LCD显示右移一位
  64. #define LCD_CURSOR_LEFT_MOVE      0x10         //光标左移一位
  65. #define LCD_CURSOR_RIGHT_MOVE     0x14         //光标右移一位

  66. //工作方式设置
  67. #define LCD_DISPLAY_DOUBLE_LINE   0x38         //两行显示
  68. #define LCD_DISPLAY_SINGLE_LINE   0x30         //单行显示
  69. /*定义子程序*/
  70. void LCD_ClrAll(void);              //清屏
  71. void Judge_LCD_busy(void);           //检测是否忙碌
  72. void LCD_Write(uchar WriteData);     //写控制字
  73. void LCD_write_data(uchar LCD_data); //写数据显示
  74. void LCD_cursor(uchar x);    //光标起始地址
  75. void LCD_printc(unsigned char lcd_data) ;  //输出一个字符
  76. void LCD_prints(unsigned char *lcd_string);//输出字符串



  77. /*LCD1602忙碌判断子程序*/
  78. void Judge_LCD_busy(void)   //判断LCD1602是否忙状态
  79. {
  80. while(1)
  81.   {
  82.    LCD_EN=0;
  83.    LCD_RS=0;
  84.    LCD_RW=1;
  85.    LCD_Data=0xff;
  86.    LCD_EN=1;   //EN 是 1—0 使能
  87.    if(!LCD_BF)break; //LCD_BF=1表示忙碌,需要等待。
  88.   }
  89.    LCD_EN=0;
  90. }
  91. /******LCD清屏***************/
  92. void LCD_ClrAll(void)
  93. {

  94. Judge_LCD_busy();   //判断是否忙碌
  95. LCD_RS=0;
  96. LCD_RW=0;
  97. LCD_Data=0x01;
  98. LCD_EN=1;
  99. LCD_EN=0;

  100. }
  101. /*******LCD写数据定义各种模式*********/
  102. void LCD_Write(uchar WriteData)   //写指令到LCD
  103. {
  104. Judge_LCD_busy();
  105. LCD_RS=0;
  106. LCD_RW=0;

  107. P0=WriteData; //把WriteData的数据送到数据口
  108. LCD_EN=1;
  109. LCD_EN=0;
  110. }
  111. /********LCD显示数据***********/
  112. void LCD_write_data(uchar LCD_data)      //输出一个字节数据到LCD
  113. {
  114. Judge_LCD_busy();
  115. LCD_RS=1;
  116. LCD_RW=0;

  117. P0=LCD_data;
  118. LCD_EN=1;
  119. LCD_EN=0;
  120. }
  121. /****光标位置的确定***/
  122. void LCD_cursor(uchar x)            //LCD光标定位到x处
  123. {
  124. LCD_Write(0x80+x);                       //第一行地址是0x80

  125. }
  126. /*输出一个字符*/
  127. void LCD_printc(unsigned char lcd_data)
  128. {
  129. LCD_write_data(lcd_data);
  130. }

  131. /*输出字符串*/
  132. void LCD_prints(unsigned char *lcd_string)
  133. {
  134. unsigned char i=0;
  135. while(lcd_string[i]!=0x00)
  136.   {
  137.    LCD_write_data(lcd_string[i]);
  138.    i++;
  139.   }
  140. }

  141. /*初始化程序*/
  142. void LCD_initial(void)                        //初始化LCD
  143. {
  144. LCD_Write(LCD_AC_AUTO_INCREMENT|LCD_MOVE_DISENABLE);
  145. LCD_Write(LCD_DISPLAY_ON|LCD_CURSOR_OFF);
  146. LCD_Write(LCD_DISPLAY_DOUBLE_LINE);
  147. LCD_ClrAll();

  148. }

  149. /****延时******/
  150. void delay_1ms(uint x)
  151. {
  152. uint j;
  153. uchar i;
  154. for(j=0;j<x;j++)
  155. {
  156. for(i=0;i<120;i++);
  157. }
  158. }
  159. void Key_SM(void){

  160.         if(K2==0){
  161.              delay_1ms(5);
  162.             if(K2==0){                  
  163.                 LCD_cursor(0x00);            
  164.                 LCD_prints("   MEASURE Rx   ");  
  165.                //----电阻档-------
  166.                 CH=1;//电阻档     

  167.                 while(K2==0){}
  168.                      }

  169.                 }
  170. }

  171. void  Value_to_ASCII(unsigned long value,uchar add)
  172. {
  173.     unsigned char temp[] = "0000.000K ";
  174.     temp[0] = value/1000000 + 0x30;//数值改成字符,液晶显示需要ASCII码
  175.     value = value%1000000;
  176.     temp[1] = value/100000 + 0x30;
  177.     value = value%100000;
  178.     temp[2] = value/10000 + 0x30;
  179.     value = value%10000;
  180.     temp[3] = value/1000 + 0x30;
  181.     value = value%1000;
  182.     temp[5] = value/100 + 0x30;
  183.     value = value%100;
  184.     temp[6] = value/10 + 0x30;
  185.     value = value%10;
  186.     temp[7] = value + 0x30;  

  187.     LCD_cursor(add);   //光标起始地址 ,第一行地址是0x00~0x0F,第二行地址是0x40~0x4f
  188.     LCD_prints(temp);
  189. }
  190. //--------------------主程序--------------------------------
  191. void main()
  192. {

  193.       TMOD=0x51;                 //设置定时器0,方式1:16位定时器
  194.       TH1=0;
  195.       TL1=0;
  196.       TH0=(65536-2000)/256; //设定定时周期
  197.       TL0=(65536-2000)%256;
  198.       TR0=1;
  199.       TR1=1;
  200.       ET1=1;
  201.       ET0=1;
  202.       EA=1;
  203. //----电阻档-------
  204.     LCD_initial();
  205.          delay_1ms(50);
  206.     LCD_initial();
  207.          delay_1ms(50);
  208.     LCD_cursor(0x00);

  209.     LCD_prints("   MEASURE Rx   ");
  210.     LCD_cursor(0x45);
  211.     CH=1;

  212.         while(1)
  213.         {

  214.      Key_SM();
  215.     if(flag==1){

  216.         flag=0;

  217.         x=Pulsenum*65536+TH1*256+TL1;//计算1s内的脉冲个数,频率=脉冲个数
  218. if(CH==1){

  219.         RZ=(Z1/x);//测量100到1000
  220.         RX=RZ-1000;
  221.         RX=RX>>1;

  222. if(RX>=1005){
  223.         RX=RX-1005;
  224.     }else{RX=0;}

  225.     if(x==0){RX=0;RX2=0;RX3=0;RX4=0;RX5=0;RX6=0;RX7=0;RX8=0;RX9=0;}
  226.   if(RX>1000000){RX=1000000; }

  227.               RX2=(RX+RX3+RX4+RX5+RX6+RX7+RX8+RX9)>>3;//求平均提高精度

  228. RX9=RX8;RX8=RX7;RX7=RX6;RX6=RX5;RX5=RX4;RX4=RX3;RX3=RX;
  229.               //保存上一次的阻值

  230.          Value_to_ASCII(RX2,0x44);//更新阻值显示



  231. }
  232.          cnt2ms=0;
  233.          Pulsenum=0;
  234.          TH1=0;
  235.          TL1=0;
  236.          TR1=1;

  237.     }
  238.       
  239.         }
  240. }
  241. /*******************************************************************************
  242. * 函 数 名: Exti0_interrupt
  243. * 函数功能: /T0引脚下降沿进入中断
  244. * 入口参数: 无
  245. * 返    回: 无
  246. *******************************************************************************/
  247. void T1_interrupt(void) interrupt 3 using 0
  248. {

  249.   Pulsenum++;        //保存测得脉搏值  
  250.       
  251. }
  252. /********************************************************************
  253. 函数功能:定时器/计数器1中断处理
  254. 入口参数:null
  255. 返    回:null
  256. 备    注:null
  257. ********************************************************************/
  258. void Timer0IntProc() interrupt 1 using 0 //2ms
  259. {
  260.   TH0=(65536-2000)/256;
  261.   TL0=(65536-2000)%256;
  262.     cnt2ms++;

  263.         if(cnt2ms==497)        //1s计时到
  264.         {

  265.         TR1=0;


  266.                 cnt2ms = 0;
  267.             
  268.         flag=1;
  269.         }

  270. }
复制代码

回复

使用道具 举报

ID:819198 发表于 2022-11-15 08:29 | 显示全部楼层
好像这种电路是用555产生脉冲,然后测量频率或脉宽,然后计算得到阻值。
回复

使用道具 举报

ID:123289 发表于 2022-11-15 09:06 | 显示全部楼层
先不忙程序。
你打算如何测量呢?
先给出测量方案,再按方案定程序。
回复

使用道具 举报

ID:1047409 发表于 2022-11-15 20:39 | 显示全部楼层
yzwzfyz 发表于 2022-11-15 09:06
先不忙程序。
你打算如何测量呢?
先给出测量方案,再按方案定程序。

如果设计图里不改变,在用代码做测量
回复

使用道具 举报

ID:1047409 发表于 2022-11-15 20:40 | 显示全部楼层
rz12345 发表于 2022-11-15 08:29
好像这种电路是用555产生脉冲,然后测量频率或脉宽,然后计算得到阻值。

但是1M以上有点难
回复

使用道具 举报

ID:123289 发表于 2022-11-16 11:11 | 显示全部楼层
方法:
买几个标准(已知)阻值的电阻,对之进行测量,记录下测试结果:A1,A2,A3,......
实际测量时,如果遇到A1,A2,A3,......这几个值时,你就会想到那几个标准电阻了。
回复

使用道具 举报

ID:1047409 发表于 2022-11-17 17:51 | 显示全部楼层
yzwzfyz 发表于 2022-11-16 11:11
方法:
买几个标准(已知)阻值的电阻,对之进行测量,记录下测试结果:A1,A2,A3,......
实际测量时,如 ...

哈哈哈谢谢,但是看不懂
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表