芯片解密|单片机解密|IC解密|芯片破解|芯片复制| PCB抄板|软件开发

飞芯科技-芯片解密|单片机解密|IC解密|芯片破解|芯片复制| PCB抄板|软件开发

STC8H8L64U单片机使用NTC采集转换温度程序IC解密

IC解密单片机源程序如下:

  1. 单片机解密
  2. 单片机解密/*初始化时先把要ADC转换的引脚设置为高阻输入.

  3. 单片机解密过采样提升N位分辨率:进行2的2N次方转换,累加值右移N位,提升N位分辨率

  4. 12位ADC,采样4次数值累加后除以2,结果便为13位过采样ADC数值.

  5. 同理12位ADC,采样16次数值累加以后除以4,结果便为14位过采样ADC数值.

  6. 程序提供了两种软件防抖的方式供参考选用:
  7. 1. 使用冒泡排序,去掉最高值、最低值,求中间平均值(不需要的话屏蔽 BUBBLE_SORT 定义)
  8. 2. 采样累加,求平均值(不需要的话可将 SUM_LENGTH 定义值改为 1 )
  9. ******************************************/

  10. #include <ADC.h>
  11. #include <delay.h>
  12. #include "TFT.h"

  13. #define BUBBLE_SORT     //设置使用冒泡排序,去掉最高值、最低值,求中间平均值(不需要的话屏蔽此行)

  14. #define SUM_LENGTH        16        /* 平均值采样次数 最大值16(不需要的话可将定义值改为 1 )*/

  15. /*************        本地常量声明        **************/

  16. #define        ADC_SPEED        15                /* 0~15, ADC转换时间(CPU时钟数) = (n+1)*32  ADCCFG */
  17. #define        RES_FMT                (1<<5)        //1右移5位即为00100000,这个位设置为1  /* ADC结果格式 0: 左对齐, ADC_RES: D11 D10 D9 D8 D7 D6 D5 D4, ADC_RESL: D3 D2 D1 D0 0 0 0 0 */
  18.                                                         /* ADCCFG      1: 右对齐, ADC_RES: 0 0 0 0 D11 D10 D9 D8, ADC_RESL: D7 D6 D5 D4 D3 D2 D1 D0 */


  19. #ifdef BUBBLE_SORT  //使用冒泡排序,去掉最高值、最低值,求中间平均值
  20. u16 ADC_Buffer[16];
  21. #endif

  22. /**********************************************/
  23. void ADCINIT()
  24. {
  25.         ADCTIM = 0x3f;  //设置通道选择时间、保持时间、采样时间
  26.         ADCCFG = RES_FMT + ADC_SPEED;
  27.         //ADC模块电源打开后,需等待1ms,MCU内部ADC电源稳定后再进行AD转换
  28.         ADC_CONTR = 0x80;        //ADC on + channel
  29. }

  30. /******************** 计算温度 *********************/
  31. /*传统的NTC检测温度,需要根据规格书去查表对应温度的电阻值,每更换一种NTC就需要重新移植NTC对应的温度电压表。
  32. 对于严格要求温度的精确度的产品建议查表进行
  33. 对于可容忍正负1摄氏度的产品建议查用算法进行计算,这样就不需要在更换NTC后进行温度表的重新抄写移植。
  34. NTC热敏电阻的计算公式为:
  35. Rt = R EXP(B(1/T1-1/T2))
  36. 其中:
  37. T1:单位为开尔文温度,T1=当前摄氏度+273.15
  38. T2:单位为开尔文温度,T2=25+273.15
  39. Rt:即为NTC在T1温度下的电阻值(这个可以通过2.5V电压串联一个10K电阻和10KNTC,通过计算流过电阻的电流和NTC上的分压计算而出)
  40. R:热敏电阻在T2常温下的标称阻值。100K的热敏电阻25℃的值为100K(即R=100K)。此值可以查表NTC规格书
  41. B:是热敏电阻的参数,NTC的规格书会标出
  42. EXP:举个例子EXP(2),即为无理数e的2次方

  43. 当前已知NTC电阻值,求此时的温度,将公式进行换算得
  44. T1 =1/(ln(Rt/R)/B+1/T2)
  45. 所求摄氏度为
  46. C= T1-273.15                     
  47. */

  48. #define Vref     2.5

  49. float BSP_Get_Temperature(float vadc)
  50. {
  51.     float temp,r,x;
  52.           float Rp=10000.0;                 //10K,25度时的阻值          
  53.           float T2 = (273.15+25.0);   //T2,25度时的开尔文温度
  54.           float Bx = 3435.0;                //B值
  55.           float Ka = 273.15;        //开尔文温度
  56.                 r=vadc/((Vref-vadc)/10000);//此处是为了计算NTC的电阻,NTC是通过2.5V电压串联一个10K电阻和10KNTC,通过计算流过电阻的电流和NTC上的分压计算而出
  57.                 temp=1/(log(r/Rp)/Bx+(1/T2));
  58.                 if(temp<Ka)
  59.                 {
  60.                         x=Ka-temp;
  61.                         Display_Digit_16x24(0, 74, GREEN, BLACK,10);
  62.                 }
  63.                 else
  64.                 {
  65.                         x=temp-Ka;
  66.                         Display_Digit_16x24(0, 74, BLACK, BLACK,15);
  67.                 }
  68.                 return x;
  69. }


  70. #ifdef BUBBLE_SORT  //使用冒泡排序
  71. //========================================================================
  72. // 函数: void DataSwap(u16* data1, u16* data2)
  73. // 描述: 数据交换函数。
  74. // 参数: data1,data2 要交换的数据.
  75. // 返回: none.
  76. // 版本: VER1.0
  77. // 日期: 2021-9-27
  78. // 备注:
  79. //========================================================================
  80. void DataSwap(u16* data1, u16* data2)
  81. {
  82.         u16 temp;
  83.         temp = *data1;
  84.         *data1 = *data2;
  85.         *data2 = temp;
  86. }

  87. //========================================================================
  88. // 函数: void BubbleSort(u16* pDataArry, u8 DataNum)
  89. // 描述: 冒泡排序函数。
  90. // 参数: pDataArry需要排序的数组,DataNum需要排序的数据个数.



联系方式

地址:石家庄市新华区民族路77号华强广场D座2009
电话:0311-88816616/87087811
手机:13315190088
传真:0311-67901001
联系人:张工
网址:www.feixindz.com
邮箱:feixindz@163.com
微信:xinpianjiemi
QQ:527263666/568069805

在线客服
热线电话

企业微信