Config cleanup

- dropped esp8266 compatibility
This commit is contained in:
Martin Bauer 2020-06-21 13:50:02 +02:00
parent f3f378a54a
commit 4fd7d8cf33
5 changed files with 52 additions and 58 deletions

View File

@ -1,17 +1,17 @@
#include "HX711.h" #include "HX711.h"
#include "ConfigHardware.h" #include "SwimTrackerConfig.h"
#include <cstdint> #include <cstdint>
template <int DIVIDER = 128>
template<int DIVIDER=128>
class Scale class Scale
{ {
public: public:
bool measure(uint16_t & measurementOut) { bool measure(uint16_t &measurementOut)
{
if (hx711_.is_ready()) if (hx711_.is_ready())
{ {
long value = hx711_.read_average(CONFIG_MEASUREMENT_AVG_COUNT) - offset_; long value = hx711_.read_average(CONFIG_MEASUREMENT_AVG_COUNT) - offset_;
if(value < 0) if (value < 0)
measurementOut = (int16_t)(-value / DIVIDER); measurementOut = (int16_t)(-value / DIVIDER);
else else
measurementOut = 0; measurementOut = 0;
@ -21,13 +21,17 @@ public:
return false; return false;
} }
void begin(uint32_t pinDOUT, uint32_t pinSCK) { void begin(uint32_t pinDOUT, uint32_t pinSCK)
{
hx711_.begin(pinDOUT, pinSCK); hx711_.begin(pinDOUT, pinSCK);
}; };
void tare(uint32_t numMeasurementsToAverage=50) { void tare(uint32_t numMeasurementsToAverage = 50)
{
offset_ = hx711_.read_average(numMeasurementsToAverage); offset_ = hx711_.read_average(numMeasurementsToAverage);
} }
long &offset() const { return offset_; }
private: private:
HX711 hx711_; HX711 hx711_;

View File

@ -1,33 +0,0 @@
#pragma once
#include <cstdint>
//#define _HW_V_20
// HX711 load cell
#ifdef PLATFORM_ESP32
#ifdef _HW_V_20
const int CONFIG_SCALE_DOUT_PIN = 23;
const int CONFIG_SCALE_SCK_PIN = 22;
#else
const int CONFIG_SCALE_DOUT_PIN = 22;
const int CONFIG_SCALE_SCK_PIN = 23;
#endif
#else
const int CONFIG_SCALE_DOUT_PIN = D2;
const int CONFIG_SCALE_SCK_PIN = D3;
#endif
const uint8_t CONFIG_MEASUREMENT_AVG_COUNT = 1; // number of measurements in normal phase
const uint8_t CONFIG_TARE_AVG_COUNT = 6; // number of measurements in tare-phase (to find 0 )
const int CONFIG_MEASURE_DELAY = 100; // interval in ms between measurements
//const int CONFIG_VALUE_DIVIDER = 8; // uint32 measurements are divided by this factor, before stored in uint16_t
const int CONFIG_VALUE_DIVIDER = 128; // uint32 measurements are divided by this factor, before stored in uint16_t
const uint32_t CONFIG_SESSION_CHUNK_SIZE = 1024; //1024*8 - 16 * sizeof(uint32_t);
const uint32_t CONFIG_SESSION_MAX_LENGTH_HOURS = 1;
const uint32_t CONFIG_SESSION_MAX_SIZE = CONFIG_SESSION_MAX_LENGTH_HOURS * 3600 * (1000 / CONFIG_MEASURE_DELAY) * sizeof(uint16_t);
const char *CONFIG_DATA_PATH = "/dat";

View File

@ -1,5 +0,0 @@
const char *CONFIG_WIFI_SSID = "WLAN";
const char *CONFIG_WIFI_PASSWORD = "Bau3rWLAN";
const char* CONFIG_HOSTNAME = "smartswim";

View File

@ -0,0 +1,39 @@
#pragma once
#include <cstdint>
// ------------------------------------------ WiFi ---------------------------------------------------------------------------------
const char *CONFIG_WIFI_SSID = "WLAN";
const char *CONFIG_WIFI_PASSWORD = "Bau3rWLAN";
const char *CONFIG_HOSTNAME = "smartswim";
// ------------------------------------- Hardware & Measurement Settings ------------------------------------------------------------
// Uncomment for Version 2.0 where load cell is connected differently
//#define _HW_V_20
const uint8_t CONFIG_MEASUREMENT_AVG_COUNT = 1; // number of measurements in normal phase
const uint8_t CONFIG_TARE_AVG_COUNT = 10; // number of measurements in tare-phase (to find 0 )
const int CONFIG_MEASURE_DELAY = 100; // interval in ms between measurements
const int CONFIG_VALUE_DIVIDER = 128; // uint32 measurements are divided by this factor, before stored in uint16_t
const uint32_t CONFIG_SESSION_MAX_LENGTH_HOURS = 3; // maximum length of one session
const char *CONFIG_DATA_PATH = "/dat"; // folder in SPIFFS file system to store measurement data
using MeasurementT = uint16_t; // data type for one measurement
// ------------------------------------- Derived Settings -----------------------------------------------------------------------------
const uint32_t CONFIG_SESSION_MAX_SIZE = CONFIG_SESSION_MAX_LENGTH_HOURS * 3600 * (1000 / CONFIG_MEASURE_DELAY) * sizeof(uint16_t);
static_assert(CONFIG_SESSION_MAX_SIZE < 1024 * 1024, "Measurement data takes more than 1MiB space");
// HX711 load cell
#ifdef _HW_V_20
const int CONFIG_SCALE_DOUT_PIN = 23;
const int CONFIG_SCALE_SCK_PIN = 22;
#else
const int CONFIG_SCALE_DOUT_PIN = 22;
const int CONFIG_SCALE_SCK_PIN = 23;
#endif

View File

@ -1,14 +1,9 @@
// Arduino & ESP headers // Arduino & ESP headers
#include "Dtypes.h" #include "Dtypes.h"
#include "SwimTrackerConfig.h"
#ifdef PLATFORM_ESP32
#include <WiFi.h> #include <WiFi.h>
#else
#include <ESP8266WiFi.h>
#include <ESPAsyncTCP.h>
#endif
//#include <ESPAsyncWebServer.h>
#include <WiFiUdp.h> // for NTP #include <WiFiUdp.h> // for NTP
#include <NTPClient.h> // for NTP #include <NTPClient.h> // for NTP
@ -19,18 +14,12 @@
#include "SpiffsStorage.h" #include "SpiffsStorage.h"
#include "DeviceInfoLog.h" #include "DeviceInfoLog.h"
#include "SimpleMeasurementSession.h" #include "SimpleMeasurementSession.h"
// Configuration
#include "ConfigWifi.h"
#include "ConfigHardware.h"
#include "EspHttp.h" #include "EspHttp.h"
#include "WebDAV.h" #include "WebDAV.h"
WiFiUDP ntpUDP; WiFiUDP ntpUDP;
NTPClient timeClient(ntpUDP, "pool.ntp.org"); NTPClient timeClient(ntpUDP, "pool.ntp.org");
//typedef MeasurementSession<uint16_t, SpiffsStorageReader, SpiffsStorageWriter, CONFIG_SESSION_CHUNK_SIZE> Session_T;
using Session_T = SimpleMeasurementSession<uint16_t, CONFIG_SESSION_MAX_SIZE>; using Session_T = SimpleMeasurementSession<uint16_t, CONFIG_SESSION_MAX_SIZE>;
template <typename Session_T> template <typename Session_T>
@ -94,7 +83,7 @@ public:
else else
{ {
const long skipped = (cycleDuration / CONFIG_MEASURE_DELAY); const long skipped = (cycleDuration / CONFIG_MEASURE_DELAY);
//Serial.printf("Warning: measurements skipped: %d, cycleDuration %d", skipped, cycleDuration); Serial.printf("Warning: measurements skipped: %ld, cycleDuration %ld", skipped, cycleDuration);
for (int i = 0; i < skipped; ++i) for (int i = 0; i < skipped; ++i)
session.addPoint(measurement); session.addPoint(measurement);