久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 8731|回復: 13
收起左側

單片機+NTC3435熱敏電阻的水溫自動加熱系統設計

  [復制鏈接]
ID:362076 發表于 2019-8-7 13:41 | 顯示全部樓層 |閱讀模式
【功能設計】
使用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口的使用。
PCF8574.png

這個小板原本為在Arduino上使用而設計的,但是既然遵守IIC協議,并且只是PCF8574芯片通信,那么51也可以才對。經過查找,在百度貼吧上找到了使用其驅動LCD1602的程序,并且重新排版編寫使之清晰明了,工程中的LCD1602_IIC.c即為此轉接板的驅動程序。

【實物快照】

IMG_20190807_133513.jpg
顯示部分會隨著主機的顯示進行更新
IMG_20190807_133510.jpg
白天照的不清晰,數碼管由于直連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, 下載次數: 222)
回復

使用道具 舉報

ID:328014 發表于 2019-8-8 02:23 | 顯示全部樓層
好資料,51黑有你更精彩!!!
回復

使用道具 舉報

ID:386381 發表于 2019-8-8 13:49 來自手機 | 顯示全部樓層
謝謝樓主分享
回復

使用道具 舉報

ID:484435 發表于 2019-8-8 19:15 | 顯示全部樓層
謝謝分享
回復

使用道具 舉報

ID:97678 發表于 2019-12-2 17:45 | 顯示全部樓層
能不能把完整的資料發給我?尤其是PID程序。可以把溫度范圍放大到0~30度
回復

使用道具 舉報

ID:231727 發表于 2019-12-17 17:28 | 顯示全部樓層
PID控制的部分還么有完成嗎?
回復

使用道具 舉報

ID:362076 發表于 2019-12-18 10:15 | 顯示全部樓層
yuri_su 發表于 2019-12-17 17:28
PID控制的部分還么有完成嗎?

程序是可用的,由于是師兄的畢設,所以PID部分只對照示波器測試了具體表現可以達到比較好的預期,理論層面上沒有做精確分析和計算
回復

使用道具 舉報

ID:36172 發表于 2020-2-16 10:49 | 顯示全部樓層
想問你一個問題,關于熱敏電阻的溫度與阻值之間的關系,好像你的不對呀,有點差距,還有就是你的NTC接電源還是接地(是采用上拉電阻還是下拉電阻)
回復

使用道具 舉報

ID:362076 發表于 2020-2-17 09:08 | 顯示全部樓層
weq12345 發表于 2020-2-16 10:49
想問你一個問題,關于熱敏電阻的溫度與阻值之間的關系,好像你的不對呀,有點差距,還有就是你的NTC接電源 ...

呃,太久了不記得當初怎么連的了,應該是VCC-10K-NTC-GND吧..
回復

使用道具 舉報

ID:502881 發表于 2020-3-25 13:53 | 顯示全部樓層
想問你一個問題,關于熱敏電阻的溫度與阻值之間的關系,好像你的不對呀,有點差距,還有就是你的NTC接電源還是接地(是采用上拉電阻還是下拉電阻)
回復

使用道具 舉報

ID:362076 發表于 2020-3-26 09:37 | 顯示全部樓層
山外青衫 發表于 2020-3-25 13:53
想問你一個問題,關于熱敏電阻的溫度與阻值之間的關系,好像你的不對呀,有點差距,還有就是你的NTC接電源 ...

NTC是接地的,VCC-10K-NTC-GND。
有不對的地方請見諒哈,我承認自己學藝不精~
回復

使用道具 舉報

ID:1023572 發表于 2023-8-15 09:02 | 顯示全部樓層
牛X,向樓主看齊
回復

使用道具 舉報

ID:1023572 發表于 2023-8-15 09:09 | 顯示全部樓層
凌凈清河 發表于 2020-3-26 09:37
NTC是接地的,VCC-10K-NTC-GND。
有不對的地方請見諒哈,我承認自己學藝不精~

有沒串一個電阻到ADC呢?
回復

使用道具 舉報

ID:1052053 發表于 2023-10-11 09:45 | 顯示全部樓層
AndyYeung 發表于 2023-8-15 09:09
有沒串一個電阻到ADC呢?

一般是不用串的吧,
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品久久九九 | 日本免费在线看 | aa级毛片毛片免费观看久 | 国产精品久久久久久久久免费樱桃 | 91色视频在线观看 | 美女视频黄的 | 超碰97免费在线 | 9久久婷婷国产综合精品性色 | 国产夜恋视频在线观看 | 亚洲欧美国产视频 | 日产精品久久久一区二区福利 | 91精品中文字幕一区二区三区 | 男人的天堂一级片 | 国产激情视频在线观看 | 日本一区二区三区在线观看 | 欧洲成人| 亚洲欧美精品在线观看 | www.887色视频免费 | 国产精品日日做人人爱 | 久久久久久综合 | 中文字幕在线视频免费视频 | 性色网站 | www.国产精 | 国产一区二区视频免费在线观看 | 日韩不卡在线 | 91观看| 欧美三区在线观看 | 中文字幕精品一区 | 日韩视频免费看 | 国产一区在线免费观看 | av免费网站在线观看 | 亚洲v日韩v综合v精品v | 亚洲国产成人av好男人在线观看 | 日本福利视频 | 亚洲精品99 | 精品久久久久久久人人人人传媒 | 国产成人免费视频 | 久久中文视频 | 日韩中文字幕在线免费 | 伊人操| 国产精品亚洲精品日韩已方 |