ALGO_Temperature_ATY.h 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /**
  2. * @file ALGO_Temperature_ATY.h
  3. *
  4. * @param Project ALGO_Algorithm_ATY_LIB
  5. *
  6. * @author ATY
  7. *
  8. * @copyright
  9. * - Copyright 2017 - 2023 MZ-ATY
  10. * - This code follows:
  11. * - MZ-ATY Various Contents Joint Statement -
  12. * <a href="https://mengze.top/MZ-ATY_VCJS">
  13. * https://mengze.top/MZ-ATY_VCJS</a>
  14. * - CC 4.0 BY-NC-SA -
  15. * <a href="https://creativecommons.org/licenses/by-nc-sa/4.0/">
  16. * https://creativecommons.org/licenses/by-nc-sa/4.0/</a>
  17. * - Your use will be deemed to have accepted the terms of this statement.
  18. *
  19. * @brief Familiar functions of NTC or others temperature calc
  20. *
  21. * @version
  22. * - 1_01_230107 > ATY
  23. * -# Preliminary version, first Release
  24. ********************************************************************************
  25. */
  26. #ifndef __ALGO_Temperature_ATY_H
  27. #define __ALGO_Temperature_ATY_H
  28. #include "INCLUDE_ATY.h"
  29. #include "ALGO_AlgorithmBase_ATY.h"
  30. /******************************* For user *************************************/
  31. // #define __DEBUG_ALGO_Temperature_ATY
  32. /******************************************************************************/
  33. #define ALGO_TEMP_Kelvin_T0 0 // K
  34. #define ALGO_TEMP_Celsius_C0 0 // C
  35. #define ALGO_TEMP_Fahrenheit_F0 0 // F
  36. #define ALGO_TEMP_TtoC(T) ((T) - 273.15)
  37. #define ALGO_TEMP_CtoT(C) ((C) + 273.15)
  38. #define ALGO_TEMP_CtoF(C) ((C) * 1.8 + 32)
  39. #define ALGO_TEMP_FtoC(F) (((F) - 32 ) / 1.8)
  40. #define ALGO_TEMP_FtoT(F) (ALGO_TEMP_CtoT(ALGO_TEMP_FtoC((F))))
  41. #define ALGO_TEMP_TtoF(T) (ALGO_TEMP_CtoF(ALGO_TEMP_TtoC((T))))
  42. /**
  43. * @brief Calculate resistance from ADC voltage, NTC down(pull up)
  44. * @param vADC ADC voltage in mV
  45. * @param vRef NTC ref voltage in mV
  46. * @param rRefK ref resistance in kOhm
  47. */
  48. #define ALGO_VoltageToResDown(vADC, vRef, rRefK) \
  49. (((float)rRefK * (float)vADC) / ((float)vRef - (float)vADC))
  50. /**
  51. * @brief Calculate resistance from ADC voltage, NTC up(pull down)
  52. * @param vADC ADC voltage in mV
  53. * @param vRef NTC ref voltage in mV
  54. * @param rRefK ref resistance in kOhm
  55. */
  56. #define ALGO_VoltageToResUp(vADC, vRef, rRefK) \
  57. (((float)rRefK * ((float)vRef - (float)vADC)) / (float)vADC)
  58. float ALGO_ResToKelvinTemp(float Rntc, float R25, float B);
  59. float ALGO_VolToKelvinTemp(float vADC, float vRef, float rRefK, float R25, float B, uint8_t rRefPos);
  60. #endif /* __ALGO_Temperature_ATY_H */
  61. /******************************** End Of File *********************************/