45 lines
1.5 KiB
C
45 lines
1.5 KiB
C
#include <stdio.h>
|
|
#include <stdint.h>
|
|
#include <time.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include "ADC_Temp.h"
|
|
|
|
|
|
// value 0..4095 - Это диапазон АЦП, Нужно проверить крайние значения и смоделировать таблицы
|
|
|
|
|
|
extern adc_temp_lookup fast_lookup[TABLE_SIZE_LOOKUP];
|
|
|
|
int main() {
|
|
|
|
init_fast_lookup_table(ALG_STEINHART, NTC_TYPE_INCAR, 3300.0f);
|
|
|
|
// for (int i = 0; i < TABLE_SIZE_LOOKUP; ++i) {
|
|
// printf("{%u,%d}, \n", fast_lookup[i].adc_value, fast_lookup[i].temp_c);
|
|
// }
|
|
|
|
|
|
|
|
//uint16_t value = 4095 / 2; // Должно быть 25 градусов. Это середина диапазона АЦП
|
|
uint16_t value = 1980;
|
|
|
|
// float T_ALG_LINEAR = get_temperature_from_adc(value, ALG_LINEAR);
|
|
//float T_ALG_STEINHART = get_temperature_from_adc(value, ALG_STEINHART);
|
|
float T_ALG_STEINHART = get_temperature_fast(value);
|
|
float T_ALG_STEINHART_1 = get_resistance_fast(value);
|
|
|
|
// float T_ALG_STEINHART_FULL = get_temperature_from_adc(value, ALG_STEINHART_FULL);
|
|
// float T_FAST = get_temperature_fast(value);
|
|
// float T_ATERLUX = calc_temperature(value);
|
|
|
|
// printf("T_ALG_LINEAR = %f \n", T_ALG_LINEAR);
|
|
printf("T_ALG_STEINHART = %f %f\n", T_ALG_STEINHART, T_ALG_STEINHART_1);
|
|
// printf("T_ALG_STEINHART_FULL = %f \n", T_ALG_STEINHART_FULL);
|
|
|
|
// printf("T_FAST = %f \n", T_FAST / 10);
|
|
// printf("T_ATERLUX = %f \n", T_ATERLUX / 10);
|
|
|
|
|
|
return 0;
|
|
} |