remove range switching
This commit is contained in:
parent
69affa4de4
commit
390aaeaeb7
3 changed files with 53 additions and 136 deletions
|
@ -1,39 +0,0 @@
|
||||||
|
|
||||||
This directory is intended for project header files.
|
|
||||||
|
|
||||||
A header file is a file containing C declarations and macro definitions
|
|
||||||
to be shared between several project source files. You request the use of a
|
|
||||||
header file in your project source file (C, C++, etc) located in `src` folder
|
|
||||||
by including it, with the C preprocessing directive `#include'.
|
|
||||||
|
|
||||||
```src/main.c
|
|
||||||
|
|
||||||
#include "header.h"
|
|
||||||
|
|
||||||
int main (void)
|
|
||||||
{
|
|
||||||
...
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Including a header file produces the same results as copying the header file
|
|
||||||
into each source file that needs it. Such copying would be time-consuming
|
|
||||||
and error-prone. With a header file, the related declarations appear
|
|
||||||
in only one place. If they need to be changed, they can be changed in one
|
|
||||||
place, and programs that include the header file will automatically use the
|
|
||||||
new version when next recompiled. The header file eliminates the labor of
|
|
||||||
finding and changing all the copies as well as the risk that a failure to
|
|
||||||
find one copy will result in inconsistencies within a program.
|
|
||||||
|
|
||||||
In C, the usual convention is to give header files names that end with `.h'.
|
|
||||||
It is most portable to use only letters, digits, dashes, and underscores in
|
|
||||||
header file names, and at most one dot.
|
|
||||||
|
|
||||||
Read more about using header files in official GCC documentation:
|
|
||||||
|
|
||||||
* Include Syntax
|
|
||||||
* Include Operation
|
|
||||||
* Once-Only Headers
|
|
||||||
* Computed Includes
|
|
||||||
|
|
||||||
https://gcc.gnu.org/onlinedocs/cpp/Header-Files.html
|
|
60
include/ec.h
60
include/ec.h
|
@ -8,8 +8,6 @@ float ecEC_ADS_CHANNEL_mean=0;
|
||||||
bool ec_flag_measurement_available=false;
|
bool ec_flag_measurement_available=false;
|
||||||
|
|
||||||
#define EC_PIN_RELAY_PROBE 27
|
#define EC_PIN_RELAY_PROBE 27
|
||||||
#define EC_PIN_RELAY_RANGEMSB 25
|
|
||||||
#define EC_PIN_RELAY_RANGELSB 26
|
|
||||||
|
|
||||||
|
|
||||||
//#define EC_PIN_ADC 4
|
//#define EC_PIN_ADC 4
|
||||||
|
@ -20,11 +18,8 @@ bool ec_flag_measurement_available=false;
|
||||||
#define EC_FREQUENCY 5000
|
#define EC_FREQUENCY 5000
|
||||||
|
|
||||||
#define EC_ARRAY_SIZE 64
|
#define EC_ARRAY_SIZE 64
|
||||||
uint16_t ec_array_range00[EC_ARRAY_SIZE]; //00=NC,NC = highest value
|
uint16_t ec_array[EC_ARRAY_SIZE];
|
||||||
uint16_t ec_array_range01[EC_ARRAY_SIZE];
|
uint16_t ec_array_pos=EC_ARRAY_SIZE;
|
||||||
uint16_t ec_array_range10[EC_ARRAY_SIZE];
|
|
||||||
uint16_t ec_array_range11[EC_ARRAY_SIZE]; //11= NO,NO = lowest value
|
|
||||||
uint16_t ec_array_pos=EC_ARRAY_SIZE*4;
|
|
||||||
unsigned long last_measurement_ec=0;
|
unsigned long last_measurement_ec=0;
|
||||||
#define EC_MEASUREMENT_INTERVAL 10000 //complete filtered measurement every x ms
|
#define EC_MEASUREMENT_INTERVAL 10000 //complete filtered measurement every x ms
|
||||||
//One filtered measurement takes EC_READ_INTERVAL*EC_ARRAY_SIZE*4
|
//One filtered measurement takes EC_READ_INTERVAL*EC_ARRAY_SIZE*4
|
||||||
|
@ -40,11 +35,7 @@ enum ECState{IDLE,MEASURE};
|
||||||
|
|
||||||
ECState ecstate=IDLE;
|
ECState ecstate=IDLE;
|
||||||
|
|
||||||
float adc_range00;
|
float ec_adc;
|
||||||
float adc_range01;
|
|
||||||
float adc_range10;
|
|
||||||
float adc_range11;
|
|
||||||
|
|
||||||
|
|
||||||
bool ec_measurementReady();
|
bool ec_measurementReady();
|
||||||
void ec_startMeasurement();
|
void ec_startMeasurement();
|
||||||
|
@ -60,8 +51,6 @@ void ec_setup() {
|
||||||
ledcWrite(EC_PWM_CH, 127); //50% duty cycle
|
ledcWrite(EC_PWM_CH, 127); //50% duty cycle
|
||||||
|
|
||||||
pinMode(EC_PIN_RELAY_PROBE,OUTPUT); //LOW=Calibration/idle, HIGH=Probe connected
|
pinMode(EC_PIN_RELAY_PROBE,OUTPUT); //LOW=Calibration/idle, HIGH=Probe connected
|
||||||
pinMode(EC_PIN_RELAY_RANGELSB,OUTPUT); //LOW=NC, HIGH=NO
|
|
||||||
pinMode(EC_PIN_RELAY_RANGEMSB,OUTPUT); //LOW=NC, HIGH=NO
|
|
||||||
ec_releaseRelay();
|
ec_releaseRelay();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -77,6 +66,7 @@ void ec_loop(unsigned long loopmillis) {
|
||||||
last_measurement_ec=loopmillis;
|
last_measurement_ec=loopmillis;
|
||||||
ec_startMeasurement();
|
ec_startMeasurement();
|
||||||
ec_connectProbe(true);
|
ec_connectProbe(true);
|
||||||
|
Serial.println("Measuring EC");
|
||||||
ecstate=MEASURE;
|
ecstate=MEASURE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -84,14 +74,10 @@ void ec_loop(unsigned long loopmillis) {
|
||||||
case MEASURE:
|
case MEASURE:
|
||||||
if (ec_measurementReady()) {
|
if (ec_measurementReady()) {
|
||||||
ec_releaseRelay();
|
ec_releaseRelay();
|
||||||
adc_range00=getMean(ec_array_range00,EC_ARRAY_SIZE); //good for low conductivity/high resistance
|
Serial.println("Finished EC");
|
||||||
adc_range01=getMean(ec_array_range01,EC_ARRAY_SIZE);
|
ec_adc=getMean(ec_array,EC_ARRAY_SIZE);
|
||||||
adc_range10=getMean(ec_array_range10,EC_ARRAY_SIZE);
|
|
||||||
adc_range11=getMean(ec_array_range11,EC_ARRAY_SIZE); //good for high conductivity/low resistance
|
|
||||||
|
|
||||||
|
|
||||||
//ec_mean=0; //TODO select right range of all readings
|
|
||||||
|
|
||||||
ec_flag_measurement_available=true;
|
ec_flag_measurement_available=true;
|
||||||
|
|
||||||
|
|
||||||
|
@ -106,36 +92,21 @@ void ec_loop(unsigned long loopmillis) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (loopmillis>last_read_ec+EC_READ_INTERVAL && ec_array_pos/4<EC_ARRAY_SIZE) { //take reading into array if measurement running
|
if (loopmillis>last_read_ec+EC_READ_INTERVAL && ec_array_pos<EC_ARRAY_SIZE) { //take reading into array if measurement running
|
||||||
last_read_ec=loopmillis;
|
last_read_ec=loopmillis;
|
||||||
|
|
||||||
//flag_print= ec_array_pos==EC_ARRAY_SIZE;
|
//flag_print= ec_array_pos==EC_ARRAY_SIZE;
|
||||||
//ec_array_pos%=EC_ARRAY_SIZE;
|
//ec_array_pos%=EC_ARRAY_SIZE;
|
||||||
|
|
||||||
ec_setRange(ec_array_pos/EC_ARRAY_SIZE);
|
|
||||||
|
|
||||||
|
|
||||||
if (loopmillis>ec_last_change_relay+EC_RELAY_SWITCH_SETTLETIME) { //values have settled
|
if (loopmillis>ec_last_change_relay+EC_RELAY_SWITCH_SETTLETIME) { //values have settled
|
||||||
//uint16_t value=analogRead(EC_PIN_ADC);
|
//uint16_t value=analogRead(EC_PIN_ADC);
|
||||||
|
|
||||||
uint16_t value = ADS.readADC(EC_ADS_CHANNEL);
|
uint16_t value = ADS.readADC(EC_ADS_CHANNEL);
|
||||||
switch (ec_array_pos/EC_ARRAY_SIZE){ //low range
|
|
||||||
case 0:
|
|
||||||
ec_array_range00[ec_array_pos%EC_ARRAY_SIZE]=value;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 1:
|
ec_array[ec_array_pos]=value;
|
||||||
ec_array_range01[ec_array_pos%EC_ARRAY_SIZE]=value;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 2:
|
|
||||||
ec_array_range10[ec_array_pos%EC_ARRAY_SIZE]=value;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 3:
|
|
||||||
ec_array_range11[ec_array_pos%EC_ARRAY_SIZE]=value;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ec_array_pos++;
|
ec_array_pos++;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -151,24 +122,13 @@ void ec_startMeasurement() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ec_measurementReady(){
|
bool ec_measurementReady(){
|
||||||
if (ec_array_pos/EC_ARRAY_SIZE>=4) { //reached end of both arrays
|
if (ec_array_pos>=EC_ARRAY_SIZE) { //reached end of both arrays
|
||||||
return true;
|
return true;
|
||||||
}else{
|
}else{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ec_setRange(uint8_t range) {
|
|
||||||
//range low means low resistor value -> NO -> relay High
|
|
||||||
|
|
||||||
uint8_t crange=digitalRead(EC_PIN_RELAY_RANGELSB)+2*digitalRead(EC_PIN_RELAY_RANGEMSB);
|
|
||||||
|
|
||||||
if (crange!=range) { //write only if different
|
|
||||||
digitalWrite(EC_PIN_RELAY_RANGELSB,range%2);
|
|
||||||
digitalWrite(EC_PIN_RELAY_RANGEMSB,range/2);
|
|
||||||
ec_last_change_relay=millis();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void ec_connectProbe(bool relay) {
|
void ec_connectProbe(bool relay) {
|
||||||
bool val=digitalRead(EC_PIN_RELAY_PROBE);
|
bool val=digitalRead(EC_PIN_RELAY_PROBE);
|
||||||
|
@ -180,8 +140,6 @@ void ec_connectProbe(bool relay) {
|
||||||
|
|
||||||
void ec_releaseRelay() {
|
void ec_releaseRelay() {
|
||||||
digitalWrite(EC_PIN_RELAY_PROBE,LOW);
|
digitalWrite(EC_PIN_RELAY_PROBE,LOW);
|
||||||
digitalWrite(EC_PIN_RELAY_RANGEMSB,LOW);
|
|
||||||
digitalWrite(EC_PIN_RELAY_RANGELSB,LOW);
|
|
||||||
ec_last_change_relay=millis();
|
ec_last_change_relay=millis();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
86
src/main.cpp
86
src/main.cpp
|
@ -61,7 +61,7 @@ void setup() {
|
||||||
//Serial.println("Setup finished");
|
//Serial.println("Setup finished");
|
||||||
delay(200);
|
delay(200);
|
||||||
|
|
||||||
Serial.println("time,tempReservoir,EC00,EC01,EC10,EC11");
|
Serial.println("time,tempReservoir,EC");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,58 +95,56 @@ void loop() {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (loopmillis>last_print+10000 && loopmillis>60000) {
|
if (loopmillis>last_print+2000) {
|
||||||
//if (ec_flag_measurement_available && getReading) {
|
//if (ec_flag_measurement_available && getReading) {
|
||||||
last_print=loopmillis;
|
if (ec_flag_measurement_available) {
|
||||||
getReading=false;
|
last_print=loopmillis;
|
||||||
ec_flag_measurement_available=false;
|
getReading=false;
|
||||||
digitalWrite(PIN_LED,LOW);
|
ec_flag_measurement_available=false;
|
||||||
|
digitalWrite(PIN_LED,LOW);
|
||||||
|
|
||||||
|
|
||||||
Serial.print(millis()/1000.0,2); Serial.print(",");
|
Serial.print(millis()/1000.0,2); Serial.print(",");
|
||||||
Serial.print(getMeanf(tempCmean_reservoir,TEMPMEAN_SIZE)); Serial.print(",");
|
Serial.print(getMeanf(tempCmean_reservoir,TEMPMEAN_SIZE)); Serial.print(",");
|
||||||
//Serial.print(getMean(sm_mean,SM_SIZE)); Serial.print(",");
|
//Serial.print(getMean(sm_mean,SM_SIZE)); Serial.print(",");
|
||||||
|
|
||||||
Serial.print(adc_range00); Serial.print(",");
|
Serial.print(ec_adc);
|
||||||
Serial.print(adc_range01); Serial.print(",");
|
Serial.println();
|
||||||
Serial.print(adc_range10); Serial.print(",");
|
|
||||||
Serial.print(adc_range11);
|
|
||||||
Serial.println();
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
|
|
||||||
if (isValueArrayOKf(tempCmean_reservoir,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)){
|
if (isValueArrayOKf(tempCmean_reservoir,TEMPMEAN_SIZE,DEVICE_DISCONNECTED_C)){
|
||||||
Serial.print("\t Treservoir="); Serial.print(getMeanf(tempCmean_reservoir,TEMPMEAN_SIZE)); Serial.print("\t Tair="); Serial.print(getMeanf(tempCmean_air,TEMPMEAN_SIZE));
|
Serial.print("\t Treservoir="); Serial.print(getMeanf(tempCmean_reservoir,TEMPMEAN_SIZE)); Serial.print("\t Tair="); Serial.print(getMeanf(tempCmean_air,TEMPMEAN_SIZE));
|
||||||
}else{
|
}else{
|
||||||
Serial.print("\t waiting for temperature");
|
Serial.print("\t waiting for temperature");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (isValueArrayOKf(waterlevelMean,WATERLEVELMEAN_SIZE,-1.0)){
|
||||||
|
float _max=getMaxf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
||||||
|
float _min=getMinf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
||||||
|
|
||||||
|
float _filteredWaterlevel=getFilteredf(waterlevelMean,WATERLEVELMEAN_SIZE,8);
|
||||||
|
float _meanWaterlevel=getMeanf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
||||||
|
|
||||||
|
|
||||||
|
Serial.print("\t Dist="); Serial.print(_filteredWaterlevel); Serial.print("mm"); Serial.print("(+- "); Serial.print((_max-_min)/2.0); Serial.print(")"); Serial.print(" [mean="); Serial.print(_meanWaterlevel); Serial.print("]");
|
||||||
|
|
||||||
|
}else{
|
||||||
|
Serial.print("\t waiting for distance");
|
||||||
|
}
|
||||||
|
|
||||||
|
Serial.print("\t Flow="); Serial.print(flow,2);
|
||||||
|
Serial.print("\t Flowsum="); Serial.print(flow_counter_sum);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Serial.println();
|
||||||
|
*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (isValueArrayOKf(waterlevelMean,WATERLEVELMEAN_SIZE,-1.0)){
|
|
||||||
float _max=getMaxf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
|
||||||
float _min=getMinf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
|
||||||
|
|
||||||
float _filteredWaterlevel=getFilteredf(waterlevelMean,WATERLEVELMEAN_SIZE,8);
|
|
||||||
float _meanWaterlevel=getMeanf(waterlevelMean,WATERLEVELMEAN_SIZE);
|
|
||||||
|
|
||||||
|
|
||||||
Serial.print("\t Dist="); Serial.print(_filteredWaterlevel); Serial.print("mm"); Serial.print("(+- "); Serial.print((_max-_min)/2.0); Serial.print(")"); Serial.print(" [mean="); Serial.print(_meanWaterlevel); Serial.print("]");
|
|
||||||
|
|
||||||
}else{
|
|
||||||
Serial.print("\t waiting for distance");
|
|
||||||
}
|
|
||||||
|
|
||||||
Serial.print("\t Flow="); Serial.print(flow,2);
|
|
||||||
Serial.print("\t Flowsum="); Serial.print(flow_counter_sum);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Serial.println();
|
|
||||||
*/
|
|
||||||
|
|
||||||
//}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue