testAdc.lua 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. --[[
  2. 1. Air101,Air103 模块上的ADC0脚-PA1, 0~2.4v,不要超过范围使用!!!
  3. 2. Air101,Air103模块上的ADC1脚-PA4, 0~2.4v,不要超过范围使用!!!
  4. 3. Air103 模块上的ADC2脚-PA2, 0~2.4v,不要超过范围使用!!!
  5. 4. Air103 模块上的ADC3脚-PA3, 0~2.4v,不要超过范围使用!!!
  6. 5. Air101,Air103 adc.CH_CPU 为内部温度 ,adc.CH_VBAT为VBAT
  7. 6. Air105 adc参考电压是1.88V,所有通道一致,
  8. 7. Air105内部分压没有隔离措施,在开启内部分压后,量程有所变化,具体看寄存器手册,1~5分压后能测到3.6,6通道能接近5V,但是不能直接测5V,可以测4.2V 0通道是始终开启无法关闭分压。
  9. 8. Air780E内部ADC接口为12bits 外部直流分压为0-3.4V
  10. 9. Air780E内部具有2个ADC接口,ADC0 -- AIO3 ADC1 -- AIO4
  11. 10. 特殊通道, CPU内部温度Temp -- adc.CH_CPU 主供电脚电压 VBAT -- adc.CH_VBAT
  12. 11. 设置分压(adc.setRange)要在adc.open之前设置,否则无效!!
  13. ]]
  14. local testAdc = {}
  15. local rtos_bsp = rtos.bsp()
  16. function adc_pin() -- 根据不同开发板,设置ADC编号
  17. if rtos_bsp == "AIR101" then -- Air101开发板ADC编号
  18. return 0,1,255,255,adc.CH_CPU ,adc.CH_VBAT
  19. elseif rtos_bsp == "AIR103" then -- Air103开发板ADC编号
  20. return 0,1,2,3,adc.CH_CPU ,adc.CH_VBAT
  21. elseif rtos_bsp == "AIR105" then -- Air105开发板ADC编号
  22. -- 默认不开启分压,范围是0-1.8v精度高
  23. -- 设置分压要在adc.open之前设置,否则无效!!
  24. -- adc.setRange(adc.ADC_RANGE_3_6)
  25. return 0,5,6,255,255,255
  26. elseif rtos_bsp == "ESP32C3" then -- ESP32C3开发板ADC编号
  27. return 0,1,2,3,adc.CH_CPU , 255
  28. elseif rtos_bsp == "ESP32C2" then -- ESP32C2开发板ADC编号
  29. return 0,1,2,3,adc.CH_CPU , 255
  30. elseif rtos_bsp == "ESP32S3" then -- ESP32S3开发板ADC编号
  31. return 0,1,2,3,adc.CH_CPU , 255
  32. elseif rtos_bsp == "EC618" then --Air780E开发板ADC编号
  33. -- 默认不开启分压,范围是0-1.2v精度高
  34. -- 设置分压要在adc.open之前设置,否则无效!!
  35. -- adc.setRange(adc.ADC_RANGE_3_8)
  36. return 0,1,255,255,adc.CH_CPU ,adc.CH_VBAT
  37. elseif string.find(rtos_bsp,"EC718") then --Air780EP开发板ADC编号
  38. -- 默认不开启分压,范围是0-1.6v精度高
  39. -- 开启分压后,外部输入最大不可超过3.3V
  40. -- 设置分压要在adc.open之前设置,否则无效!!
  41. -- adc.setRange(adc.ADC_RANGE_MAX)
  42. return 0,1,255,255,adc.CH_CPU ,adc.CH_VBAT
  43. elseif string.find(rtos_bsp,"UIS") then
  44. return 0,1,255,255, adc.CH_CPU ,adc.CH_VBAT
  45. else
  46. log.info("main", "define ADC pin in main.lua")
  47. return 255,255,255,255, adc.CH_CPU ,adc.CH_VBAT
  48. end
  49. end
  50. local adc_pin_0,adc_pin_1,adc_pin_2,adc_pin_3,adc_pin_temp,adc_pin_vbat=adc_pin()
  51. function testAdc.dotest()
  52. if rtos_bsp == "AIR105" then
  53. adc.setRange(adc.ADC_RANGE_3_6) --开启的内部分压,可以把量程扩大
  54. end
  55. if adc_pin_0 and adc_pin_0 ~= 255 then adc.open(adc_pin_0) end
  56. if adc_pin_1 and adc_pin_1 ~= 255 then adc.open(adc_pin_1) end
  57. if adc_pin_2 and adc_pin_2 ~= 255 then adc.open(adc_pin_2) end
  58. if adc_pin_3 and adc_pin_3 ~= 255 then adc.open(adc_pin_3) end
  59. if adc_pin_temp and adc_pin_temp ~= 255 then adc.open(adc_pin_temp) end
  60. if adc_pin_vbat and adc_pin_vbat ~= 255 then adc.open(adc_pin_vbat) end
  61. if adc_pin_0 and adc_pin_0 ~= 255 and mcu and mcu.ticks then
  62. sys.wait(1000)
  63. log.info("开始读取ADC")
  64. local ms_start = mcu.ticks()
  65. for i = 1, 100, 1 do
  66. adc.get(adc_pin_0)
  67. end
  68. local ms_end = mcu.ticks()
  69. log.info("结束读取ADC")
  70. log.info("adc", "读取耗时", "100次", ms_end - ms_start, "ms", "单次", (ms_end - ms_start) // 100, "ms")
  71. end
  72. -- 下面是循环打印, 接地不打印0也是正常现象
  73. -- ADC的精度都不会太高, 若需要高精度ADC, 建议额外添加adc芯片
  74. while true do
  75. if adc_pin_0 and adc_pin_0 ~= 255 then
  76. log.debug("adc", "adc" .. tostring(adc_pin_0), adc.get(adc_pin_0)) -- 若adc.get报nil, 改成adc.read
  77. end
  78. if adc_pin_1 and adc_pin_1 ~= 255 then
  79. log.debug("adc", "adc" .. tostring(adc_pin_1), adc.get(adc_pin_1))
  80. end
  81. if adc_pin_2 and adc_pin_2 ~= 255 then
  82. log.debug("adc", "adc" .. tostring(adc_pin_2), adc.get(adc_pin_2))
  83. end
  84. if adc_pin_3 and adc_pin_3 ~= 255 then
  85. log.debug("adc", "adc" .. tostring(adc_pin_3), adc.get(adc_pin_3))
  86. end
  87. if adc_pin_temp and adc_pin_temp ~= 255 then
  88. log.debug("adc", "CPU TEMP", adc.get(adc_pin_temp), "单位0.001摄氏度")
  89. end
  90. if adc_pin_vbat and adc_pin_vbat ~= 255 then
  91. log.debug("adc", "VBAT", adc.get(adc_pin_vbat), "单位毫伏(mV)")
  92. end
  93. sys.wait(1000)
  94. end
  95. -- 若不再读取, 可关掉adc, 降低功耗, 非必须
  96. if adc_pin_0 and adc_pin_0 ~= 255 then adc.close(adc_pin_0) end
  97. if adc_pin_1 and adc_pin_1 ~= 255 then adc.close(adc_pin_1) end
  98. if adc_pin_2 and adc_pin_2 ~= 255 then adc.close(adc_pin_2) end
  99. if adc_pin_3 and adc_pin_3 ~= 255 then adc.close(adc_pin_3) end
  100. if adc_pin_temp and adc_pin_temp ~= 255 then adc.close(adc_pin_temp) end
  101. if adc_pin_vbat and adc_pin_vbat ~= 255 then adc.close(adc_pin_vbat) end
  102. end
  103. return testAdc