#include <math.h>
#include <LiquidCrystal.h>
#define NTC1 A0
#define NTC2 A1
#define NTC3 A2
template<int samplesNum>
class AverageFilter
{
public:
AverageFilter(int pin)
{
pinIn = pin;
}
int operator()()
{
sum -= samples[curIndex];
samples[curIndex] = analogRead(pinIn);
sum += samples[curIndex];
curIndex = (curIndex + 1) % samplesNum;
return sum/samplesNum;
}
private:
int pinIn;
double sum = 0;
double samples[samplesNum]{};
int curIndex = 0;
};
LiquidCrystal lcd(13, 12, 11, 10, 9, 8);
AverageFilter<10> filter1(NTC1);
AverageFilter<10> filter2(NTC2);
AverageFilter<10> filter3(NTC3);
void process()
{
const float BETA = 3950;
int analogValue1 = filter1();
int analogValue2 = filter2();
int analogValue3 = filter3();
//пересчет в градусы
float celsius1 = 1 / (log(1 / (1023. / analogValue1 - 1)) / BETA + 1.0 / 298.15) - 273.15;
float celsius2 = 1 / (log(1 / (1023. / analogValue2 - 1)) / BETA + 1.0 / 298.15) - 273.15;
float celsius3 = 1 / (log(1 / (1023. / analogValue3 - 1)) / BETA + 1.0 / 298.15) - 273.15;
//расчет минимального, максимального, среднего значений
int minVal = round(min(celsius1, min(celsius2, celsius3)));
int maxVal = round(max(celsius1, max(celsius2, celsius3)));
int avgVal = round((celsius1 + celsius2 + celsius3)/3);
//преобразование в char и вывод на дисплей
const int kSize = 4;
char bufer[kSize];
lcd.setCursor(0,1);
dtostrf(minVal, -1, 0, bufer);
print(bufer, kSize);
lcd.setCursor(5,1);
dtostrf(avgVal, -1, 0, bufer);
print(bufer, kSize);
lcd.setCursor(10,1);
dtostrf(maxVal, -1, 0, bufer);
print(bufer, kSize);
}
//вспомогательная функция печати на дисплей, чтобы не выполнять clear каждый новый цикл (защита от мерцания)
void print(char *bufer, int size)
{
bool endString = false;
for(int i = 0; i < size; ++i)
{
if (bufer[i] == '\0')
{
endString = true;
}
if(endString)
{
lcd.print(" ");
}
else
{
lcd.print(bufer[i]);
}
}
}
void setup()
{
pinMode(NTC1, INPUT);
pinMode(NTC2, INPUT);
pinMode(NTC3, INPUT);
analogReference(DEFAULT);
lcd.begin(16, 2, LCD_5x8DOTS);
lcd.clear();
lcd.print("MIN AVG MAX");
}
void loop()
{
process();
delay(100);
}
uno:A5.2
uno:A4.2
uno:AREF
uno:GND.1
uno:13
uno:12
uno:11
uno:10
uno:9
uno:8
uno:7
uno:6
uno:5
uno:4
uno:3
uno:2
uno:1
uno:0
uno:IOREF
uno:RESET
uno:3.3V
uno:5V
uno:GND.2
uno:GND.3
uno:VIN
uno:A0
uno:A1
uno:A2
uno:A3
uno:A4
uno:A5
lcd1:VSS
lcd1:VDD
lcd1:V0
lcd1:RS
lcd1:RW
lcd1:E
lcd1:D0
lcd1:D1
lcd1:D2
lcd1:D3
lcd1:D4
lcd1:D5
lcd1:D6
lcd1:D7
lcd1:A
lcd1:K
r1:1
r1:2
ntc1:GND
ntc1:VCC
ntc1:OUT
ntc2:GND
ntc2:VCC
ntc2:OUT
ntc3:GND
ntc3:VCC
ntc3:OUT