2025-05-10 10:19:10 +02:00

260 lines
6.1 KiB
C++

#include <Arduino.h>
#include <Adafruit_Sensor.h>
#include <DHT.h>
#include <DHT_U.h>
#include <HardwareSerial.h>
// -------------------------------------------------------------
// DHT PreConfiguration
#define DHTPIN 18 // Digital pin connected to the DHT sensor
//#define DHTPIN PB0
// Pin 15 can work but DHT must be disconnected during program upload.
#define DHTTYPE DHT22 // DHT 22 (AM2302), AM2321
// -------------------------------------------------------------
// Initialize DHT sensor.
// Note that older versions of this library took an optional third parameter to
// tweak the timings for faster processors. This parameter is no longer needed
// as the current DHT reading algorithm adjusts itself to work on faster procs.
DHT dht(DHTPIN, DHTTYPE);
// VARS
const int MD1200BAUDS = 38400; // From what I've read it is always 38400
//const int EPYSLEEPY = 600000; / 10 minutes
const int EPYSLEEPY = 300000; // 5 minutes
//const int EPYSLEEPY = 150000; // 2,5 minutes
HardwareSerial MDSerial(PA3, PA2); // Rx Tx
// declarations
int getTemp();
int setFanTrsh(int);
float dhtRead();
void setup() {
// Setup connection to MD1200
// MDSerial because we're using RX/TX pins
MDSerial.begin(MD1200BAUDS);
// Just debug
Serial.begin(9600);
dht.begin();
}
void loop() {
int fanPercnt = getTemp();
if (fanPercnt < 10) {
setFanTrsh(fanPercnt);
}
/*
check temperature and
set fan speed every X minutes
*/
delay(EPYSLEEPY);
}
// Get current temperature
int getTemp() {
int bp1 = 0;
int bp2 = 0;
int exp0 = 0;
int exp1 = 0;
int simm0 = 0;
int simm1 = 0;
String MD1200output;
MDSerial.println("_temp_rd");
// wait for MD1200 to answer
delay(30);
while (MDSerial.available()) {
MD1200output = MDSerial.readStringUntil('\n');
// Check backplane 1
if (MD1200output.startsWith("BP_1")) {
// check index number of =
int eq = MD1200output.indexOf('=');
// check index number of c
int c = MD1200output.indexOf('c');
// check if both exists
if (eq != -1 && c != -1) {
/*
take value between "= " and "c".
NOTICE that eq + 1 is there because in
"BP_1[2] = 25c" there is a space between = and 25.
*/
bp1 = MD1200output.substring(eq + 1, c).toInt();
}
}
// Check backplane 2
if (MD1200output.startsWith("BP_2")) {
int eq = MD1200output.indexOf('=');
int c = MD1200output.indexOf('c');
if (eq != -1 && c != -1) {
bp2 = MD1200output.substring(eq + 1, c).toInt();
}
}
// Uncomment if you want to also get temperature for expanders
/*
// Check expander 0
if (MD1200output.startsWith("EXP0")) {
int eq = MD1200output.indexOf('=');
int c = MD1200output.indexOf('c');
if (eq != -1 && c != -1) {
exp0 = MD1200output.substring(eq + 1, c).toInt();
}
}
// Check expander 1
if (MD1200output.startsWith("EXP1")) {
int eq = MD1200output.indexOf('=');
int c = MD1200output.indexOf('c');
if (eq != -1 && c != -1) {
exp1 = MD1200output.substring(eq + 1, c).toInt();
}
}
// Check controller 0
if (MD1200output.startsWith("SIM0")) {
int eq = MD1200output.indexOf('=');
int c = MD1200output.indexOf('c');
if (eq != -1 && c != -1) {
simm0 = MD1200output.substring(eq + 1, c).toInt();
}
}
// Check controller 1
if (MD1200output.startsWith("SIM1")) {
int eq = MD1200output.indexOf('=');
int c = MD1200output.indexOf('c');
if (eq != -1 && c != -1) {
simm1 = MD1200output.substring(eq + 1, c).toInt();
}
}
*/
// Stop when prompt returns
if (MD1200output.endsWith(">")) {
break;
}
}
// Do (BP_1 + BP_2) / 2 to get the average of backplane
if (bp1 != -1 && bp2 != -1) {
int bpAvg = (bp1 + bp2) / 2;
// define default
int outPrcntg = 21;
// check external sensor temp
int ownReadTemp = int(dhtRead());
// a
switch (bpAvg) {
case 23:
outPrcntg = 21;
break;
/*
Minimum is 21 (akhsually 20)
BUT
https://forums.servethehome.com/index.php?threads/fun-with-an-md1200-md1220-sc200-sc220.27487/
*/
case 25:
outPrcntg = 23;
break;
case 27:
outPrcntg = 24;
break;
case 29:
outPrcntg = 26;
break;
case 31:
outPrcntg = 27;
break;
case 33:
outPrcntg = 30;
break;
case 35:
outPrcntg = 34;
break;
case 37:
outPrcntg = 38;
break;
/*
I don't wan't to become deaf so max is 40.
*/
default:
return -1;
}
return outPrcntg;
} else {
return -1; // failed to read temp
}
/*
BP_1[2] - Back plane, maybe left
BP_2[3] - Back plane, maybe right
SIM0[0] - Controller A
SIM1[1] - Controller B
EXP0[4] - Expander 0
EXP1[5] - Expander 1
AVG - average of all sensors
*/
}
// take percentage as int and set it.
int setFanTrsh(int fanTrshInp) {
String outputStatement = "set_speed " + String(fanTrshInp);
Serial.println("Sending " + outputStatement + " to MD1200");
if (MDSerial.println(outputStatement)) {
return 1;
}
else {
return -1;
}
}
float dhtRead() {
// Reading temperature or humidity takes about 250 milliseconds!
// Sensor readings may also be up to 2 seconds 'old' (its a very slow sensor)
// float humidt = dht.readHumidity();
// Read temperature as Celsius (the default)
float tempr = dht.readTemperature();
// Read temperature as Fahrenheit (isFahrenheit = true)
// f = dht.readTemperature(true);
// Check if any reads failed and exit early (to try again).
// if (isnan(humidt) || isnan(tempr))
if (isnan(tempr))
{
Serial.println("Failed to read from DHT sensor!");
return -1;
}
else {
return tempr;
}
// Compute heat index in Fahrenheit (the default)
// hif = dht.computeHeatIndex(f, h);
// Compute heat index in Celsius (isFahreheit = false)
// hicc = dht.computeHeatIndex(tempr, humidt, false);
}