add second hydroponic system
This commit is contained in:
parent
95ceac3e80
commit
feeec8ffd4
5 changed files with 125 additions and 90 deletions
|
@ -170,10 +170,12 @@ void ec_loop(unsigned long loopmillis) {
|
|||
ec_adc_adjusted=mapf(ec_adc,0,ec_calib_adc,0,ec_reference_adc);
|
||||
if (probeselect==0) {
|
||||
ec=ec_getECfromADC(ec_adc_adjusted, ec_calibration_polynom_A, sizeof(ec_calibration_polynom_A), ec_calibration_linearize_below_adc_A, ec_calibration_linear_lowADC_A, ec_calibration_linear_lowEC_A);
|
||||
ec25=ec_calculateEC25(ec,tempC_reservoir_a);
|
||||
}else if (probeselect==1) {
|
||||
ec=ec_getECfromADC(ec_adc_adjusted, ec_calibration_polynom_B, sizeof(ec_calibration_polynom_B), ec_calibration_linearize_below_adc_B, ec_calibration_linear_lowADC_B, ec_calibration_linear_lowEC_B);
|
||||
ec25=ec_calculateEC25(ec,tempC_reservoir_b);
|
||||
}
|
||||
ec25=ec_calculateEC25(ec,tempC_reservoir);
|
||||
|
||||
//Serial.println("DEBUG: EC OK");
|
||||
}else{
|
||||
ec_calib_adc=EC_ADC_UNAVAILABLE;
|
||||
|
|
|
@ -1,44 +1,72 @@
|
|||
#ifndef _FLOW_H_
|
||||
#define _FLOW_H_
|
||||
|
||||
mqttValueTiming timing_flow;
|
||||
mqttValueTiming timing_flow_a;
|
||||
mqttValueTiming timing_flow_b;
|
||||
|
||||
#define FLOW_PIN 19
|
||||
uint16_t flow_counter=0; //maximum counts/s measured with Eden 128 Pump was 171
|
||||
void IRAM_ATTR isr_flow();
|
||||
unsigned long last_read_flow=0;
|
||||
#define FLOW_A_PIN 16
|
||||
#define FLOW_B_PIN 17
|
||||
uint16_t flow_a_counter=0; //maximum counts/s measured with Eden 128 Pump was 171
|
||||
uint16_t flow_b_counter=0; //maximum counts/s measured with Eden 128 Pump was 171
|
||||
void IRAM_ATTR isr_flow_a();
|
||||
void IRAM_ATTR isr_flow_b();
|
||||
unsigned long last_read_flow_a=0;
|
||||
unsigned long last_read_flow_b=0;
|
||||
#define READINTERVAL_FLOW 10000
|
||||
float flow_factor=7.5; //F=7.5*flowrate[L/min]
|
||||
float flow;
|
||||
float flow_a;
|
||||
float flow_b;
|
||||
|
||||
uint32_t flow_counter_sum=0;
|
||||
uint32_t flow_a_counter_sum=0;
|
||||
uint32_t flow_b_counter_sum=0;
|
||||
|
||||
|
||||
|
||||
void flow_setup() {
|
||||
|
||||
timing_flow.minchange=0.0;
|
||||
timing_flow.maxchange=0.3;
|
||||
timing_flow.mintime=10*000;
|
||||
timing_flow.maxtime=30*60*1000;
|
||||
timing_flow_a.minchange=0.0;
|
||||
timing_flow_a.maxchange=0.3;
|
||||
timing_flow_a.mintime=10*000;
|
||||
timing_flow_a.maxtime=30*60*1000;
|
||||
|
||||
pinMode(FLOW_PIN, INPUT_PULLUP);
|
||||
attachInterrupt(FLOW_PIN, isr_flow, CHANGE);
|
||||
timing_flow_b.minchange=0.0;
|
||||
timing_flow_b.maxchange=0.3;
|
||||
timing_flow_b.mintime=10*000;
|
||||
timing_flow_b.maxtime=30*60*1000;
|
||||
|
||||
pinMode(FLOW_A_PIN, INPUT_PULLUP);
|
||||
pinMode(FLOW_B_PIN, INPUT_PULLUP);
|
||||
attachInterrupt(FLOW_A_PIN, isr_flow_a, CHANGE);
|
||||
attachInterrupt(FLOW_B_PIN, isr_flow_b, CHANGE);
|
||||
}
|
||||
|
||||
void flow_loop(unsigned long loopmillis) {
|
||||
if (loopmillis>=last_read_flow+READINTERVAL_FLOW) {
|
||||
flow=flow_counter*1000.0/(loopmillis-last_read_flow)/2.0; //Frequency [Hz]
|
||||
flow/=flow_factor; //[L/min]
|
||||
if (loopmillis>=last_read_flow_a+READINTERVAL_FLOW) {
|
||||
flow_a=flow_a_counter*1000.0/(loopmillis-last_read_flow_a)/2.0; //Frequency [Hz]
|
||||
flow_a/=flow_factor; //[L/min]
|
||||
|
||||
flow_counter=0;
|
||||
last_read_flow=loopmillis;
|
||||
flow_a_counter=0;
|
||||
last_read_flow_a=loopmillis;
|
||||
}
|
||||
|
||||
if (loopmillis>=last_read_flow_b+READINTERVAL_FLOW) {
|
||||
flow_b=flow_b_counter*1000.0/(loopmillis-last_read_flow_b)/2.0; //Frequency [Hz]
|
||||
flow_b/=flow_factor; //[L/min]
|
||||
|
||||
flow_b_counter=0;
|
||||
last_read_flow_b=loopmillis;
|
||||
}
|
||||
}
|
||||
|
||||
void IRAM_ATTR isr_flow() {
|
||||
flow_counter++;
|
||||
flow_counter_sum++;
|
||||
void IRAM_ATTR isr_flow_a() {
|
||||
flow_a_counter++;
|
||||
flow_a_counter_sum++;
|
||||
}
|
||||
|
||||
|
||||
void IRAM_ATTR isr_flow_b() {
|
||||
flow_b_counter++;
|
||||
flow_b_counter_sum++;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -2,8 +2,8 @@
|
|||
#define _TEMPERATURE_H_
|
||||
|
||||
|
||||
mqttValueTiming timing_temperature_reservoir;
|
||||
mqttValueTiming timing_temperature_air;
|
||||
mqttValueTiming timing_temperature_reservoir_a;
|
||||
mqttValueTiming timing_temperature_reservoir_b;
|
||||
mqttValueTiming timing_temperature_case;
|
||||
|
||||
#include <OneWire.h>
|
||||
|
@ -28,17 +28,19 @@ DallasTemperature sensors(&oneWire);
|
|||
#define TEMPMEAN_SIZE 16
|
||||
uint16_t tempCmean_pos=0;
|
||||
// arrays to hold device addresses
|
||||
DeviceAddress thermometerReservoir={0x28,0xFF,0x30,0xBA,0x85,0x16,0x03,0xB5};
|
||||
float tempC_reservoir; //last reading
|
||||
float tempCmean_reservoir_array[TEMPMEAN_SIZE];
|
||||
float tempCmean_reservoir=DEVICE_DISCONNECTED_C;
|
||||
DeviceAddress thermometerReservoirA={0x28,0xFF,0x6F,0x19,0x72,0x16,0x05,0x44};
|
||||
float tempC_reservoir_a; //last reading
|
||||
float tempCmean_reservoir_a_array[TEMPMEAN_SIZE];
|
||||
float tempCmean_reservoir_a=DEVICE_DISCONNECTED_C;
|
||||
|
||||
|
||||
|
||||
DeviceAddress thermometerAir={0x28,0xFF,0x6C,0x1C,0x72,0x16,0x05,0x8B};
|
||||
float tempC_air; //last reading
|
||||
float tempCmean_air_array[TEMPMEAN_SIZE];
|
||||
float tempCmean_air=DEVICE_DISCONNECTED_C;
|
||||
//DeviceAddress thermometerAir={0x28,0xFF,0x6C,0x1C,0x72,0x16,0x05,0x8B};
|
||||
|
||||
DeviceAddress thermometerReservoirB={0x28,0xFF,0x30,0xBA,0x85,0x16,0x03,0xB5};
|
||||
float tempC_reservoir_b; //last reading
|
||||
float tempCmean_reservoir_b_array[TEMPMEAN_SIZE];
|
||||
float tempCmean_reservoir_b=DEVICE_DISCONNECTED_C;
|
||||
|
||||
DeviceAddress thermometerCase={0x10,0x7E,0x22,0x99,0x01,0x08,0x00,0xA4};
|
||||
float tempC_case; //last reading
|
||||
|
@ -49,15 +51,16 @@ float tempCmean_case=DEVICE_DISCONNECTED_C;
|
|||
|
||||
|
||||
void temperature_setup() {
|
||||
timing_temperature_reservoir.minchange=0.0;
|
||||
timing_temperature_reservoir.maxchange=0.5;
|
||||
timing_temperature_reservoir.mintime=2*1000;
|
||||
timing_temperature_reservoir.maxtime=60*60*1000;
|
||||
timing_temperature_reservoir_a.minchange=0.0;
|
||||
timing_temperature_reservoir_a.maxchange=0.5;
|
||||
timing_temperature_reservoir_a.mintime=2*1000;
|
||||
timing_temperature_reservoir_a.maxtime=60*60*1000;
|
||||
|
||||
timing_temperature_reservoir_b.minchange=0.0;
|
||||
timing_temperature_reservoir_b.maxchange=0.5;
|
||||
timing_temperature_reservoir_b.mintime=2*1000;
|
||||
timing_temperature_reservoir_b.maxtime=60*60*1000;
|
||||
|
||||
timing_temperature_air.minchange=0.0;
|
||||
timing_temperature_air.maxchange=0.5;
|
||||
timing_temperature_air.mintime=2*1000;
|
||||
timing_temperature_air.maxtime=60*60*1000;
|
||||
|
||||
timing_temperature_case.minchange=0.0;
|
||||
timing_temperature_case.maxchange=0.5;
|
||||
|
@ -66,8 +69,8 @@ void temperature_setup() {
|
|||
|
||||
//initialize mean array
|
||||
for (uint16_t i=0;i<TEMPMEAN_SIZE;i++) {
|
||||
tempCmean_reservoir_array[i]=-127;
|
||||
tempCmean_air_array[i]=-127;
|
||||
tempCmean_reservoir_a_array[i]=-127;
|
||||
tempCmean_reservoir_b_array[i]=-127;
|
||||
tempCmean_case_array[i]=-127;
|
||||
}
|
||||
|
||||
|
@ -104,8 +107,8 @@ void temperature_setup() {
|
|||
|
||||
}
|
||||
|
||||
sensors.setResolution(thermometerReservoir, TEMPERATURE_PRECISION);
|
||||
sensors.setResolution(thermometerAir, TEMPERATURE_PRECISION);
|
||||
sensors.setResolution(thermometerReservoirA, TEMPERATURE_PRECISION);
|
||||
sensors.setResolution(thermometerReservoirB, TEMPERATURE_PRECISION);
|
||||
sensors.setResolution(thermometerCase, TEMPERATURE_PRECISION);
|
||||
}
|
||||
|
||||
|
@ -127,33 +130,32 @@ void temperature_loop(unsigned long loopmillis) {
|
|||
flag_requestTemperatures=false;
|
||||
last_read_ds18b20=loopmillis;
|
||||
|
||||
tempC_reservoir = sensors.getTempC(thermometerReservoir);
|
||||
if (tempC_reservoir == DEVICE_DISCONNECTED_C)
|
||||
tempC_reservoir_a = sensors.getTempC(thermometerReservoirA);
|
||||
if (tempC_reservoir_a == DEVICE_DISCONNECTED_C)
|
||||
{
|
||||
Serial.print(" Error reading: "); printAddress(thermometerReservoir);
|
||||
Serial.print(" Error reading: "); printAddress(thermometerReservoirA);
|
||||
}else{
|
||||
tempCmean_reservoir_array[tempCmean_pos]=tempC_reservoir;
|
||||
if (isValueArrayOKf(tempCmean_reservoir_array,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)) {
|
||||
tempCmean_reservoir=getMeanf(tempCmean_reservoir_array,TEMPMEAN_SIZE);
|
||||
tempCmean_reservoir_a_array[tempCmean_pos]=tempC_reservoir_a;
|
||||
if (isValueArrayOKf(tempCmean_reservoir_a_array,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)) {
|
||||
tempCmean_reservoir_a=getMeanf(tempCmean_reservoir_a_array,TEMPMEAN_SIZE);
|
||||
}else{
|
||||
tempCmean_reservoir=DEVICE_DISCONNECTED_C;
|
||||
tempCmean_reservoir_a=DEVICE_DISCONNECTED_C;
|
||||
}
|
||||
}
|
||||
|
||||
/* temporarily disabled
|
||||
tempC_air = sensors.getTempC(thermometerAir);
|
||||
if (tempC_air == DEVICE_DISCONNECTED_C)
|
||||
|
||||
tempC_reservoir_b = sensors.getTempC(thermometerReservoirB);
|
||||
if (tempC_reservoir_b == DEVICE_DISCONNECTED_C)
|
||||
{
|
||||
Serial.print(" Error reading: "); printAddress(thermometerAir);
|
||||
Serial.print(" Error reading: "); printAddress(thermometerReservoirB);
|
||||
}else{
|
||||
tempCmean_air_array[tempCmean_pos]=tempC_air;
|
||||
if (isValueArrayOKf(tempCmean_air_array,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)) {
|
||||
tempCmean_air=getMeanf(tempCmean_air_array,TEMPMEAN_SIZE);
|
||||
tempCmean_reservoir_b_array[tempCmean_pos]=tempC_reservoir_b;
|
||||
if (isValueArrayOKf(tempCmean_reservoir_b_array,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)) {
|
||||
tempCmean_reservoir_b=getMeanf(tempCmean_reservoir_b_array,TEMPMEAN_SIZE);
|
||||
}else{
|
||||
tempCmean_air=DEVICE_DISCONNECTED_C;
|
||||
tempCmean_reservoir_b=DEVICE_DISCONNECTED_C;
|
||||
}
|
||||
}
|
||||
*/
|
||||
|
||||
tempC_case = sensors.getTempC(thermometerCase);
|
||||
if (tempC_case == DEVICE_DISCONNECTED_C)
|
||||
|
|
|
@ -64,7 +64,7 @@ void waterlevel_loop(unsigned long loopmillis) {
|
|||
|
||||
uint16_t distance=sensor.readRangeSingleMillimeters();
|
||||
|
||||
//Serial.print("Distance reading:"); Serial.println(distance);
|
||||
Serial.print("Distance reading:"); Serial.println(distance);
|
||||
|
||||
if (distance!=WATERLEVEL_UNAVAILABLE) { //successful
|
||||
waterlevelMean_array[waterlevelMean_array_pos]=distance;
|
||||
|
|
61
src/main.cpp
61
src/main.cpp
|
@ -40,7 +40,7 @@ ADS1115 ADS(0x48);
|
|||
#include "flow.h"
|
||||
|
||||
// ######## Soilmoisture
|
||||
#include "soilmoisture.h"
|
||||
//#include "soilmoisture.h"
|
||||
|
||||
|
||||
|
||||
|
@ -88,8 +88,10 @@ void setup() {
|
|||
Serial.println("Setup Flow");
|
||||
flow_setup();
|
||||
|
||||
/*
|
||||
Serial.println("Setup Soilmoisture");
|
||||
sm_setup();
|
||||
*/
|
||||
|
||||
Serial.println("Finished Setup");
|
||||
delay(200);
|
||||
|
@ -127,7 +129,7 @@ void loop() {
|
|||
|
||||
flow_loop(loopmillis);
|
||||
|
||||
sm_loop(loopmillis);
|
||||
//sm_loop(loopmillis);
|
||||
|
||||
|
||||
static bool getReading=false;
|
||||
|
@ -165,7 +167,8 @@ void loop() {
|
|||
getReading=false;
|
||||
digitalWrite(PIN_LED,LOW);
|
||||
Serial.print(loopmillis); Serial.print(",");
|
||||
Serial.print(tempCmean_reservoir); Serial.print(",");
|
||||
Serial.print(tempCmean_reservoir_a); Serial.print(",");
|
||||
Serial.print(tempCmean_reservoir_b); Serial.print(",");
|
||||
Serial.print(ec_calib_adc); Serial.print(",");
|
||||
Serial.print(ec_adc_A); Serial.print(",");
|
||||
Serial.print(ec_adc_adjusted_A); Serial.print(",");
|
||||
|
@ -178,13 +181,14 @@ void loop() {
|
|||
|
||||
last_check=loopmillis;
|
||||
|
||||
if (tempCmean_air==DEVICE_DISCONNECTED_C || tempCmean_reservoir==DEVICE_DISCONNECTED_C || tempCmean_case==DEVICE_DISCONNECTED_C) {
|
||||
if (tempCmean_reservoir_a==DEVICE_DISCONNECTED_C || tempCmean_reservoir_b==DEVICE_DISCONNECTED_C || tempCmean_case==DEVICE_DISCONNECTED_C) {
|
||||
valueError=true;
|
||||
}
|
||||
|
||||
/*
|
||||
if (sm_mean1==SM_DISCONNECTED || sm_mean2==SM_DISCONNECTED) {
|
||||
valueError=true;
|
||||
}
|
||||
}*/
|
||||
if (ec_A==EC_UNAVAILABLE || ec_B==EC_UNAVAILABLE){
|
||||
valueError=true;
|
||||
}
|
||||
|
@ -200,17 +204,19 @@ void loop() {
|
|||
Serial.println("_______________________");
|
||||
Serial.print(millis()/1000.0,2); Serial.println(":");
|
||||
|
||||
Serial.print("temperature reservoir,air = ");
|
||||
Serial.print(tempCmean_reservoir); Serial.print(","); Serial.print(tempCmean_air);
|
||||
Serial.print("temperature reservoir_a,reservoir_b = ");
|
||||
Serial.print(tempCmean_reservoir_a); Serial.print(","); Serial.print(tempCmean_reservoir_b);
|
||||
Serial.println();
|
||||
|
||||
|
||||
|
||||
/*
|
||||
Serial.print("sm_mean 1,2,3 = ");
|
||||
Serial.print(sm_mean1); Serial.print(",");
|
||||
Serial.print(sm_mean2); Serial.print(",");
|
||||
Serial.print(sm_mean3);
|
||||
Serial.println();
|
||||
*/
|
||||
|
||||
/*
|
||||
Serial.print("sm_mean 1,2,3 = ");
|
||||
|
@ -231,7 +237,8 @@ void loop() {
|
|||
//Serial.print(getMax(sm_mean3array,SM_SIZE)); Serial.println();
|
||||
*/
|
||||
|
||||
Serial.print("Flow = "); Serial.print(flow);
|
||||
Serial.print("Flow a= "); Serial.print(flow_a);
|
||||
Serial.print(", b= "); Serial.print(flow_b);
|
||||
Serial.println();
|
||||
|
||||
Serial.print("EC ec_calib_adc,ec_adc_A,ec_adc_adjusted_A = ");
|
||||
|
@ -274,15 +281,16 @@ void loop() {
|
|||
enableTiming=false;
|
||||
}
|
||||
|
||||
if (tempCmean_reservoir!=DEVICE_DISCONNECTED_C) {
|
||||
publishValueTimed("temperature/reservoir",tempCmean_reservoir,2,timing_temperature_reservoir,loopmillis);
|
||||
if (tempCmean_reservoir_a!=DEVICE_DISCONNECTED_C) {
|
||||
publishValueTimed("nft/temperature/reservoir",tempCmean_reservoir_a,2,timing_temperature_reservoir_a,loopmillis);
|
||||
}
|
||||
if (tempCmean_air!=DEVICE_DISCONNECTED_C) {
|
||||
publishValueTimed("temperature/air",tempCmean_air,2,timing_temperature_air,loopmillis);
|
||||
if (tempCmean_reservoir_b!=DEVICE_DISCONNECTED_C) {
|
||||
publishValueTimed("db/temperature/reservoir",tempCmean_reservoir_b,2,timing_temperature_reservoir_b,loopmillis);
|
||||
}
|
||||
if (tempCmean_case!=DEVICE_DISCONNECTED_C) {
|
||||
publishValueTimed("temperature/case",tempCmean_case,2,timing_temperature_case,loopmillis);
|
||||
publishValueTimed("case/temperature",tempCmean_case,2,timing_temperature_case,loopmillis);
|
||||
}
|
||||
/*
|
||||
if (sm_mean1!=SM_DISCONNECTED) {
|
||||
publishValueTimed("soilmoisture/sm1",sm_mean1,3,timing_soilmoisture_sm1,loopmillis);
|
||||
}
|
||||
|
@ -292,8 +300,10 @@ void loop() {
|
|||
if (sm_mean3!=SM_DISCONNECTED) {
|
||||
publishValueTimed("soilmoisture/sm3",sm_mean3,3,timing_soilmoisture_sm3,loopmillis);
|
||||
}
|
||||
*/
|
||||
|
||||
publishValueTimed("flow/flow",flow,2,timing_flow,loopmillis);
|
||||
publishValueTimed("nft/flow/flow",flow_a,2,timing_flow_a,loopmillis);
|
||||
publishValueTimed("db/flow/flow",flow_b,2,timing_flow_b,loopmillis);
|
||||
|
||||
if (waterlevel!=WATERLEVEL_UNAVAILABLE) {
|
||||
bool _published=publishValueTimed("waterlevel/height",waterlevel,2,timing_waterlevel,loopmillis);
|
||||
|
@ -312,28 +322,28 @@ void loop() {
|
|||
|
||||
//Probe A
|
||||
if (ec_adc_A!=0) {
|
||||
publishValue("ecA/adc",ec_adc_A,0);
|
||||
publishValue("nft/ec/adc",ec_adc_A,0);
|
||||
}
|
||||
|
||||
if (ec_adc_adjusted_A!=0) {
|
||||
publishValue("ecA/adcadjusted",ec_adc_adjusted_A,0);
|
||||
publishValue("nft/ec/adcadjusted",ec_adc_adjusted_A,0);
|
||||
}
|
||||
if (ec_A!=EC_UNAVAILABLE){
|
||||
publishValue("ecA/ec",ec_A,0);
|
||||
publishValue("ecA/sc",ec25_A,0);
|
||||
publishValue("nft/ec/ec",ec_A,0);
|
||||
publishValue("nft/ec/sc",ec25_A,0);
|
||||
}
|
||||
|
||||
//Probe B
|
||||
if (ec_adc_B!=0) {
|
||||
publishValue("ecB/adc",ec_adc_B,0);
|
||||
publishValue("nft/ec/adc",ec_adc_B,0);
|
||||
}
|
||||
|
||||
if (ec_adc_adjusted_B!=0) {
|
||||
publishValue("ecB/adcadjusted",ec_adc_adjusted_B,0);
|
||||
publishValue("db/ec/adcadjusted",ec_adc_adjusted_B,0);
|
||||
}
|
||||
if (ec_B!=EC_UNAVAILABLE){
|
||||
publishValue("ecB/ec",ec_B,0);
|
||||
publishValue("ecB/sc",ec25_B,0);
|
||||
publishValue("db/ec/ec",ec_B,0);
|
||||
publishValue("db/ec/sc",ec25_B,0);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -354,13 +364,6 @@ void loop() {
|
|||
}*/
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in a new issue