找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7997|回复: 13
打印 上一主题 下一主题
收起左侧

单片机+NTC3435热敏电阻的水温自动加热系统设计

  [复制链接]
跳转到指定楼层
楼主
【功能设计】
使用IAP15W4K58S4单片机、数码管和NTC3435热敏电阻、DC12V直流加热棒(带驱动板)组成一个自动加热系统。可以手动设定目标温度(30℃~90℃),设置步进1摄氏度。
请使用者仅用于参考学习,不要用于商业。
【使用流程描述】
1.上电程序会轮流显示设定温度和实际温度。配有指示灯表示当前所显示的是哪一个。
2.任意时刻按下增加或减少按键,程序进入设置模式,显示设定值并保持。后台加热仍然以原设置值为准。
3.当按下确定键且设定温度在有效范围内时,程序装载新设置值并进行自动调整,否则恢复原值。按下取消键也恢复原值。
4.降温操作通过被动散热进行,所以会比较慢。
5.后续需求有所变化,增加一个串口输出,传递设置值和实际值给远端单片机显示。
【主机参数设置】
0.MCU型号IAP15W4K58S4,频率11.0592MHz,下载程序时注意勾选“在程序区的结束处添加重要测试参数”。
1.ADC使用片内ADC,10位精度,使用内部基准源校正采集值。
2.PID部分借用他人程序,针对此设计做了调整
。参考程序来源已不可考,故不贴出。
3.NTC电阻采用B值3435防水型号,其查表程序为本人所写,详情请查阅对应C文件(移植很方便)。
4.串口设置9600 8N1。
【从机参数设置】
1.型号STC15W408AS,频率11.0592MHz。
2.从机使用IIC转并口的转接板连接LCD1602,极大地节约了IO口的使用。


这个小板原本为在Arduino上使用而设计的,但是既然遵守IIC协议,并且只是PCF8574芯片通信,那么51也可以才对。经过查找,在百度贴吧上找到了使用其驱动LCD1602的程序,并且重新排版编写使之清晰明了,工程中的LCD1602_IIC.c即为此转接板的驱动程序。

【实物快照】


显示部分会随着主机的显示进行更新

白天照的不清晰,数码管由于直连IO推挽方式驱动所以有些段选有残影。单片机PWM和加热部分之间使用MOS管驱动,供电12V。

【主机主程序】

  1. #include"STC15.H"        //单片机寄存器定义
  2. #include"Binary.H"        //提供二进制输入
  3. #include<intrins.h>        //提供_nop_函数
  4. #include"NTC3435.c"        //提供NTC查询表

  5. sbit Key_Add=P1^5;//设定值+
  6. sbit Key_Subtract=P1^6;//设定值-
  7. sbit Key_Submit=P1^7;//确定修改
  8. sbit Key_Cancel=P5^5;//取消修改

  9. sbit LED_Red=P3^6;//用于指示当前显示的温度为设定值
  10. sbit LED_Green=P3^7;//用于指示当前显示的温度为测得值

  11. sbit S1=P4^5;
  12. sbit S2=P4^2;
  13. sbit S3=P4^4;//数码管位选

  14. sbit PWM_FC=P1^0;//PWM输出引脚

  15. //初始化变量
  16. unsigned int code Voltage_BandGap_ROM _at_ 0xe7f7;//58K程序空间的MCU
  17. //全局变量表
  18. unsigned char smgduan[18]={0xfa,0x22,0xb9,0xab,0x63,0xcb,0xdb,0xa2,0xfb,0xeb,0xf3,0x5b,0x19,0x3b,0xd9,0xd1,0x01};
  19. unsigned char Display_Temperature_Act[3]={0,0,0};//温度测得值显示数组
  20. unsigned char Display_Temperature_Set[3]={0,0,0};//温度设定值显示数组
  21. int Temperature_Act=32;                        //温度测得值
  22. int Temperature_Set=40;                        //温度设定值
  23. int Shadow_Temperature_Set=40;        //温度设定值影子值
  24. unsigned int T0_Cnt_1=0;                //定时器0周期计数1:显示轮询
  25. unsigned int T0_Cnt_2=0;                //定时器0周期计数2:PID控制
  26. unsigned char T0_Cnt_3=0;                //定时器0周期计数3:串口发送
  27. bit En_Display_Standby=1;                //显示轮询有效标志位
  28. bit Do_T0_3=0;                                        //串口发送标志
  29. bit flag_display_mode=0;                //显示标志位
  30. bit Temperature_Set_Choose=0;//温度设置值数据来源选择,用于PID设置,该值为0时数据参考来自设置变量,该值为1时数据参考来源来自影子变量
  31. bit flag_Key_Add=0;                                //按键动作执行标志位
  32. bit flag_Key_Subtract=0;                //按键动作执行标志位
  33. bit flag_Key_Submit=0;                        //按键动作执行标志位
  34. bit flag_Key_Cancel=0;                        //按键动作执行标志位
  35. bit busy=0;//串口1发送状态
  36. //ADC测温相关变量
  37. unsigned int ADC_DATA;                        //读取到的ADC转换值
  38. unsigned int ADC_BandGap;                //读取的BandGap转换值
  39. float VCC_Voltage;                                //计算得到的VCC电压值,单位mV
  40. float NTC_Voltage;                                //计算得到的NTC分压电压值,单位mV
  41. float NTC_Temperature;                        //查表计算得到的NTC对应温度值,单位℃
  42. unsigned long NTC_R_Comp=0;                //待对比的电阻值,单位十倍欧姆
  43. bit flag_value_update=0;                //测得值更新标志位
  44. bit En_ADC_Value=0;                                //ADC转换值标志 0:无效 1:有效

  45. //移植PID部分时的全局变量
  46. int e ,e1 ,e2 ;//pid
  47. float uk ,uk1 ,duk ;//pid
  48. float Kp=10,Ki=12,Kd=1.5;//pid        10,12,1.5
  49. int out=0;
  50. unsigned int PWMTime=0;
  51. unsigned int cnt=0;
  52. /************************************************************
  53. 名称:基于NTC3435的水温自动加热系统设计
  54. 平台:IAP15W4K58S4 11.0592MHz 9600 8N1

  55. 编写注意:数码管连接在P2口,单片机推挽输出方式直驱

  56. 程序编写:凌净清河
  57. 硬件制作:凌净欣羽
  58. 文稿排版:凌净欣羽

  59. 发布日期:2019年8月7日(星期三)
  60. 声明:如您直接使用本例程或进行较大程度的借鉴,请注明程序出处,谢谢!
  61. 所属:新矿城学习基地#2019
  62. ************************************************************/
  63. void PWMOUT()                  
  64. {
  65.         if(cnt<PWMTime)         
  66.         {
  67.                 PWM_FC=1;
  68.         }
  69.         else
  70.         {
  71.                 PWM_FC=0;
  72.         }
  73.         if(cnt>1000)cnt=0;         
  74. }

  75. void PIDControl(void)
  76. {
  77.         if(Temperature_Set_Choose)
  78.         {
  79.                 e=Shadow_Temperature_Set-NTC_Temperature;
  80.         }
  81.         else
  82.         {
  83.                 e=Temperature_Set-NTC_Temperature;
  84.         }
  85.         duk=(Kp*(e-e1)+Ki*e+Kd*(e-2*e1+e2));
  86.         uk=uk1+duk;
  87.         if(uk>1200)
  88.         {
  89.                 uk=1000;
  90.         }
  91.         else if(uk<-1200)
  92.         {
  93.                 uk=0;
  94.         }
  95.         
  96.         out=(int)uk;
  97.         if(out>1000)
  98.         {
  99.                 out=1000;
  100.         }
  101.         else if(out<0)
  102.         {
  103.                 out=0;
  104.         }
  105.         PWMTime=out;
  106.         uk1=uk;
  107.         e2=e1;
  108.         e1=e;
  109. }

  110. void delay(unsigned int i)
  111. {
  112.         while(i--);
  113. }

  114. void SendData(unsigned char dat)//串口1发送一个字节数据
  115. {
  116.         while(busy);
  117.         busy=1;
  118.         SBUF=dat;
  119. }

  120. void Value_Send()//串口将数据发送出去,仅发送显示的部分
  121. {
  122.         SendData(0xC7);
  123.         delay(100);
  124.         SendData(Display_Temperature_Act[0]);
  125.         delay(100);
  126.         SendData(Display_Temperature_Act[1]);
  127.         delay(100);
  128.         SendData(Display_Temperature_Act[2]);
  129.         delay(100);
  130.         SendData(Display_Temperature_Set[0]);
  131.         delay(100);
  132.         SendData(Display_Temperature_Set[1]);
  133.         delay(100);
  134.         SendData(Display_Temperature_Set[2]);
  135.         delay(100);
  136.         SendData(0x7C);
  137. }

  138. void VCC_Voltage_Read()                                                //调用此函数更新电源电压值,存储在VCC_Voltage变量中,该函数改变ADC的设置
  139. {
  140.         P1ASF=B00000000;                                                //不设置P1ASF,以便上电读取BandGap电压的ADC转换值
  141.         ADC_CONTR=B10000000;                                        //开启ADC电源,设置转换速度540时钟周期,清空转换标志位,停止转换,模拟通道选择P1^0
  142.         ADC_RES=0;                                                                //清除结果寄存器
  143.         ADC_RESL=0;                                                                //清除结果寄存器
  144.         CLK_DIV&=B11011111;                                                //ADC_RES[7:0]存放高8位ADC结果,ADC_RES[1:0]存放低2位ADC结果
  145.         //PADC=1;                                                                //设置A/D转换中断优先级为最高
  146.         
  147.         ADC_CONTR|=0x08;                                                //开始转换
  148.         _nop_();
  149.         _nop_();
  150.         _nop_();
  151.         _nop_();                                                                //按照例程延时4个周期
  152.         while(!En_ADC_Value);                                        //等待转换结束
  153.         En_ADC_Value=0;                                                        //清除标志位
  154.         ADC_BandGap=ADC_DATA;                                        //保存BandGap的ADC转换值
  155.         VCC_Voltage=Voltage_BandGap_ROM*1023.0/(float)ADC_BandGap;//电源电压值计算
  156. }

  157. void NTC_Voltage_Read()                                                //调用此函数更新NTC电压值,存储在NTC_Voltage变量中,该函数改变ADC的设置
  158. {
  159.         P1ASF=B00001000;                                                //NTC接在P13
  160.         ADC_CONTR=B11100011;                                        //开启ADC电源,设置转换速度90时钟周期,清空转换标志位,停止转换,模拟通道选择P1^3
  161.         ADC_RES=0;                                                                //清除结果寄存器
  162.         ADC_RESL=0;                                                                //清除结果寄存器
  163.         CLK_DIV&=B11011111;                                                //ADC_RES[7:0]存放高8位ADC结果,ADC_RES[1:0]存放低2位ADC结果
  164.         //PADC=1;                                                                //设置A/D转换中断优先级为最高
  165.         
  166.         ADC_CONTR|=0x08;                                                //开始转换
  167.         _nop_();
  168.         _nop_();
  169.         _nop_();
  170.         _nop_();                                                                //按照例程延时4个周期
  171.         while(!En_ADC_Value);                                        //等待转换结束
  172.         En_ADC_Value=0;                                                        //清除标志位
  173.         NTC_Voltage=Voltage_BandGap_ROM*(float)ADC_DATA/(float)ADC_BandGap;//NTC分压电压计算
  174. }

  175. /*
  176. 数值显示处理函数,将温度变量的值判断合法范围并按位取出送给显示数组
  177. 温度变量值的合理更新由其更新函数负责
  178. 为提高效率,该函数只在变量更新时执行一次,不随数码管显示函数轮询刷新
  179. */
  180. void Data_Process()
  181. {
  182.         if(Temperature_Act>0&&Temperature_Act<100)
  183.         {
  184.                 Display_Temperature_Act[0]=Temperature_Act/10;
  185.                 Display_Temperature_Act[1]=Temperature_Act%10;
  186.                 Display_Temperature_Act[2]=12;
  187.         }
  188.         else
  189.         {
  190.                 if(Temperature_Act<0)
  191.                 {
  192.                         Temperature_Act*=(-1);//将值变为正数
  193.                         Display_Temperature_Act[0]=17;//显示负号
  194.                         Display_Temperature_Act[1]=Temperature_Act/10;
  195.                         Display_Temperature_Act[2]=Temperature_Act%10;
  196.                 }
  197.                 else//数值大于100℃
  198.                 {
  199.                         Display_Temperature_Act[0]=Temperature_Act/100;
  200.                         Display_Temperature_Act[1]=(Temperature_Act%100)/10;
  201.                         Display_Temperature_Act[2]=Temperature_Act%10;
  202.                 }
  203.         }
  204.         //由于设置值由设置函数保证合法性,此处不用判断,直接按位取出即可
  205.         Display_Temperature_Set[0]=Temperature_Set/10;
  206.         Display_Temperature_Set[1]=Temperature_Set%10;//温度设定值在30~90之间
  207.         Display_Temperature_Set[2]=12;
  208.         
  209. //                        Display_Temperature_Set[0]=PWMTime/100;
  210. //                        Display_Temperature_Set[1]=(PWMTime%100)/10;
  211. //                        Display_Temperature_Set[2]=PWMTime%10;
  212. //        if(PWMTime==0)Display_Temperature_Set[2]=15;
  213. }

  214. /*
  215. 数码管显示函数,用于刷新显示设定的和实际的温度值
  216. 同时刷新LED的指示显示
  217. 参数为布尔量,0:显示设定值 1:显示测得值
  218. */
  219. void smg_display(bit choose)
  220. {
  221.         unsigned char i;
  222.         for(i=0;i<3;i++)
  223.         {
  224.                 switch(i)
  225.                 {
  226.                         case 0:S1=0;S2=1;S3=1;break;
  227.                         case 1:S1=1;S2=0;S3=1;break;
  228.                         case 2:S1=1;S2=1;S3=0;break;
  229.                 }
  230.                 if(choose)
  231.                 {//测得值
  232.                         P2=smgduan[Display_Temperature_Act[i]];
  233.                 }
  234.                 else
  235.                 {//设定值
  236.                         P2=smgduan[Display_Temperature_Set[i]];
  237.                 }
  238.                 delay(100);
  239.                 P2=0x00;
  240.         }
  241.         
  242.         if(choose)//在不同模式下点亮相应的指示灯
  243.         {
  244.                 LED_Red=1;LED_Green=0;
  245.         }
  246.         else
  247.         {
  248.                 LED_Red=0;LED_Green=1;
  249.         }
  250. }

  251. void Timer0Init(void)                //5毫秒@11.0592MHz
  252. {
  253.         AUXR |= 0x80;                //定时器时钟1T模式
  254.         TMOD &= 0xF0;                //设置定时器模式
  255.         TL0 = 0x00;                //设置定时初值
  256.         TH0 = 0x28;                //设置定时初值
  257.         TF0 = 0;                //清除TF0标志
  258.         TR0 = 1;                //定时器0开始计时
  259. }

  260. void Timer1Init(void)                //10微秒@11.0592MHz
  261. {
  262.         AUXR |= 0x40;                //定时器时钟1T模式
  263.         TMOD &= 0x0F;                //设置定时器模式
  264.         TL1 = 0x91;                //设置定时初值
  265.         TH1 = 0xFF;                //设置定时初值
  266.         TF1 = 0;                //清除TF1标志
  267.         TR1 = 1;                //定时器1开始计时
  268. }

  269. void UartInit(void)                //9600bps@11.0592MHz
  270. {
  271.         SCON = 0x50;                //8???,?????
  272.         AUXR |= 0x01;                //??1?????2???????
  273.         AUXR |= 0x04;                //???2???Fosc,?1T
  274.         T2L = 0xE0;                //??????
  275.         T2H = 0xFE;                //??????
  276.         AUXR |= 0x10;                //?????2
  277. }

  278. void sys_init()
  279. {
  280.         P0M1=0x00;
  281.         P0M0=0x00;
  282.         P1M1=0x00;
  283.         P1M0=0x00;
  284.         P2M1=0x00;
  285.         P2M0=0xFF;//P2口推挽输出
  286.         P3M1=0x00;
  287.         P3M0=0x00;
  288.         P4M1=0x00;
  289.         P4M0=0x00;
  290.         P5M0=0x00;
  291.         P5M1=0x00;
  292.         P2=0x00;
  293.         LED_Red=0;
  294.         LED_Green=0;
  295.         Timer0Init();
  296.         Timer1Init();
  297.         UartInit();
  298.         EA=1;
  299.         ET0=1;
  300.         ET1=1;
  301.         ES=1;//开串口中断使能
  302.         EADC=1;//开ADC转换中断
  303.         VCC_Voltage_Read();//读取电源电压
  304.         Data_Process();
  305.         LED_Red=1;
  306.         LED_Green=1;
  307. }

  308. void main()
  309. {
  310.         sys_init();
  311.         while(1)
  312.         {
  313.                 smg_display(flag_display_mode);
  314.                 if(flag_value_update)
  315.                 {
  316.                         flag_value_update=0;
  317.                         NTC_Voltage_Read();//读取NTC的分压值(P13上的模拟电压)
  318.                         NTC_R_Comp=100000*NTC_Voltage/(VCC_Voltage-NTC_Voltage);//计算待对比的NTC阻值,单位十倍欧姆
  319.                         NTC_Temperature=NTC_103_3435_Compare(NTC_R_Comp);//查表计算NTC对应的温度值
  320.                         Temperature_Act=(char)NTC_Temperature;//取整
  321.                         Data_Process();
  322.                 }
  323.                 //***************************************************************************
  324.                 //此处添加PID调温的函数               
  325.                 //Temperature_Set_Choose为温度设置值数据来源选择标志位,用于PID设置。
  326.                 //该值为0时温度设置值来自变量Temperature_Set,该值为1时设置值来自影子变量Shadow_Temperature_Set
  327.                 //温度的设置值为int型数据,范围为30-90
  328.                 //实时温度可以来自以下两个变量:
  329.                 //Temperature_Act为int型变量,存储显示的测得值
  330.                 //NTC_Temperature为float型变量,存储每次转换完成后的查表得到的温度值
  331.                 PWMOUT();
  332.                 //***************************************************************************
  333.                 if(Do_T0_3)
  334.                 {
  335.                         Do_T0_3=0;
  336.                         Value_Send();//串口发送显示的值给另一个单片机(设计要求?
  337.                         
  338.                 }

  339.                 if((Key_Add==0&&(!flag_Key_Add)))
  340.                 {
  341.                         delay(3000);
  342.                         if(Key_Add==0)
  343.                         {
  344.                                 flag_Key_Add=1;
  345.                                 //按键执行内容
  346.                                 if(Temperature_Set_Choose==0)//当首次进入设置模式时
  347.                                 {
  348.                                         En_Display_Standby=0;//关闭中断中的显示轮询
  349.                                         Shadow_Temperature_Set=Temperature_Set;//备份之前的设置值
  350.                                         Temperature_Set_Choose=1;//切换PID数据来源
  351.                                         flag_display_mode=0;//切换到设定值显示
  352.                                 }
  353.                                 Temperature_Set++;//增加设置值
  354.                                 if(Temperature_Set>90)Temperature_Set=90;//设置上限
  355.                                 Data_Process();//更新显示
  356.                         }
  357.                 }
  358.                 if((Key_Subtract==0&&(!flag_Key_Subtract)))
  359.                 {
  360.                         delay(3000);
  361.                         if(Key_Subtract==0)
  362.                         {
  363.                                 flag_Key_Subtract=1;
  364.                                 //按键执行内容
  365.                                 if(Temperature_Set_Choose==0)//当首次进入设置模式时
  366.                                 {
  367.                                         En_Display_Standby=0;//关闭中断中的显示轮询
  368.                                         Shadow_Temperature_Set=Temperature_Set;//备份之前的设置值
  369.                                         Temperature_Set_Choose=1;//切换PID数据来源
  370.                                         flag_display_mode=0;//切换到设定值显示
  371.                                 }
  372.                                 Temperature_Set--;//减少设置值
  373.                                 if(Temperature_Set<30)Temperature_Set=30;//设置下限
  374.                                 Data_Process();//更新显示
  375.                         }
  376.                 }
  377.                 if((Key_Submit==0&&(!flag_Key_Submit)))
  378.                 {
  379.                         delay(3000);
  380.                         if(Key_Submit==0)
  381.                         {
  382.                                 flag_Key_Submit=1;
  383.                                 //按键执行内容
  384.                                 if(Temperature_Set_Choose)//确定键在设置模式时有效
  385.                                 {
  386.                                         En_Display_Standby=1;//开启中断中的显示轮询
  387.                                         Temperature_Set_Choose=0;//切换PID数据来源
  388.                                 }
  389.                         }
  390.                 }
  391.                 if((Key_Cancel==0&&(!flag_Key_Cancel)))
  392.                 {
  393.                         delay(3000);
  394.                         if(Key_Cancel==0)
  395.                         {
  396.                                 flag_Key_Cancel=1;
  397.                                 //按键执行内容
  398.                                 if(Temperature_Set_Choose)//取消键在设置模式时有效
  399.                                 {
  400.                                         Temperature_Set=Shadow_Temperature_Set;//还原之前的设置值
  401.                                         En_Display_Standby=1;//开启中断中的显示轮询
  402.                                         Temperature_Set_Choose=0;//切换PID数据来源
  403.                                 }
  404.                         }
  405.                 }
  406.                
  407.                 if(Key_Add)flag_Key_Add=0;
  408.                 if(Key_Subtract)flag_Key_Subtract=0;
  409.                 if(Key_Submit)flag_Key_Submit=0;
  410.                 if(Key_Cancel)flag_Key_Cancel=0;
  411.         }
  412. }

  413. void T0() interrupt 1
  414. {
  415.         if(T0_Cnt_1==400)
  416.         {
  417.                 T0_Cnt_1=0;
  418.                 if(En_Display_Standby)
  419.                 {
  420.                         flag_display_mode=!flag_display_mode;
  421.                 }
  422.                 flag_value_update=1;
  423.         }
  424.         else
  425.         {
  426.                 T0_Cnt_1++;
  427.         }
  428.         
  429.         if(T0_Cnt_2==10)
  430.         {
  431.                 T0_Cnt_2=0;
  432.                 PIDControl();
  433. //                PWMTime=PWMTime+100;
  434. //                if(PWMTime>1000)
  435. //                {
  436. //                        PWMTime=0;
  437. //                }
  438.         }
  439.         else
  440.         {
  441.                 T0_Cnt_2++;
  442.         }
  443.         
  444.         if(T0_Cnt_3==100)
  445.         {
  446.                 T0_Cnt_3=0;
  447.                 Do_T0_3=1;
  448.         }
  449.         else
  450.         {
  451.                 T0_Cnt_3++;
  452.         }
  453. }

  454. void T1() interrupt 3
  455. {
  456.         cnt++;
  457. }

  458. void UART() interrupt 4
  459. {
  460.         if(RI)
  461.         {
  462.                 RI=0;
  463.         }
  464.         if(TI)
  465.         {
  466.                 TI=0;//清除标志位
  467.                 busy=0;//上一数据发送完成
  468.         }
  469. }

  470. void ADC() interrupt 5                                                //AD中断服务函数
  471. {
  472.         ADC_CONTR&=!0x10;                                                //清除ADC中断标志,例程
  473.         ADC_DATA=(ADC_RES<<2)|ADC_RESL;                        //10位ADC结果拼接
  474.         En_ADC_Value=1;                                                        //ADC转换值有效标志
  475. }
  476.   
复制代码

【程序下载】
基于NTC3435的水温自动加热系统设计 凌净清河.zip (103.38 KB, 下载次数: 221)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏7 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:328014 发表于 2019-8-8 02:23 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

板凳
ID:386381 发表于 2019-8-8 13:49 来自手机 | 只看该作者
谢谢楼主分享
回复

使用道具 举报

地板
ID:484435 发表于 2019-8-8 19:15 | 只看该作者
谢谢分享
回复

使用道具 举报

5#
ID:97678 发表于 2019-12-2 17:45 | 只看该作者
能不能把完整的资料发给我?尤其是PID程序。可以把温度范围放大到0~30度
回复

使用道具 举报

6#
ID:231727 发表于 2019-12-17 17:28 | 只看该作者
PID控制的部分还么有完成吗?
回复

使用道具 举报

7#
ID:362076 发表于 2019-12-18 10:15 | 只看该作者
yuri_su 发表于 2019-12-17 17:28
PID控制的部分还么有完成吗?

程序是可用的,由于是师兄的毕设,所以PID部分只对照示波器测试了具体表现可以达到比较好的预期,理论层面上没有做精确分析和计算
回复

使用道具 举报

8#
ID:36172 发表于 2020-2-16 10:49 | 只看该作者
想问你一个问题,关于热敏电阻的温度与阻值之间的关系,好像你的不对呀,有点差距,还有就是你的NTC接电源还是接地(是采用上拉电阻还是下拉电阻)
回复

使用道具 举报

9#
ID:362076 发表于 2020-2-17 09:08 | 只看该作者
weq12345 发表于 2020-2-16 10:49
想问你一个问题,关于热敏电阻的温度与阻值之间的关系,好像你的不对呀,有点差距,还有就是你的NTC接电源 ...

呃,太久了不记得当初怎么连的了,应该是VCC-10K-NTC-GND吧..
回复

使用道具 举报

10#
ID:502881 发表于 2020-3-25 13:53 | 只看该作者
想问你一个问题,关于热敏电阻的温度与阻值之间的关系,好像你的不对呀,有点差距,还有就是你的NTC接电源还是接地(是采用上拉电阻还是下拉电阻)
回复

使用道具 举报

11#
ID:362076 发表于 2020-3-26 09:37 | 只看该作者
山外青衫 发表于 2020-3-25 13:53
想问你一个问题,关于热敏电阻的温度与阻值之间的关系,好像你的不对呀,有点差距,还有就是你的NTC接电源 ...

NTC是接地的,VCC-10K-NTC-GND。
有不对的地方请见谅哈,我承认自己学艺不精~
回复

使用道具 举报

12#
ID:1023572 发表于 2023-8-15 09:02 | 只看该作者
牛X,向楼主看齐
回复

使用道具 举报

13#
ID:1023572 发表于 2023-8-15 09:09 | 只看该作者
凌净清河 发表于 2020-3-26 09:37
NTC是接地的,VCC-10K-NTC-GND。
有不对的地方请见谅哈,我承认自己学艺不精~

有没串一个电阻到ADC呢?
回复

使用道具 举报

14#
ID:1052053 发表于 2023-10-11 09:45 | 只看该作者
AndyYeung 发表于 2023-8-15 09:09
有没串一个电阻到ADC呢?

一般是不用串的吧,
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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