2020-06-24 17:36:32 +01:00
|
|
|
#include <Arduino.h>
|
|
|
|
#include "WiFi.h"
|
2020-06-24 19:06:09 +01:00
|
|
|
#include "WiFiMulti.h"
|
|
|
|
#include "src/InfluxDB-Client-for-Arduino/src/InfluxDbClient.h"
|
2020-08-19 18:17:31 +01:00
|
|
|
#include "src/PZEM-004T-v30/PZEM004Tv30.h"
|
2020-06-24 17:36:32 +01:00
|
|
|
#include "config.h"
|
|
|
|
|
2020-06-24 19:06:09 +01:00
|
|
|
WiFiMulti WiFiMulti;
|
|
|
|
InfluxDBClient client(INFLUXDB_URL, INFLUXDB_DB_NAME);
|
2020-08-19 18:17:31 +01:00
|
|
|
PZEM004Tv30 pzem(&Serial2);
|
2020-06-24 17:36:32 +01:00
|
|
|
|
2020-06-24 19:06:09 +01:00
|
|
|
// Data point
|
|
|
|
Point sensor("solar_status");
|
|
|
|
|
2020-08-19 18:10:35 +01:00
|
|
|
void ConnectToWiFiMulti() {
|
2020-06-24 17:36:32 +01:00
|
|
|
WiFi.mode(WIFI_STA);
|
2020-06-24 19:06:09 +01:00
|
|
|
WiFiMulti.addAP(SSID, WiFiPassword);
|
|
|
|
Serial.println("Connecting Wifi...");
|
2020-08-19 18:10:35 +01:00
|
|
|
while (WiFiMulti.run() != WL_CONNECTED) {
|
2020-06-24 19:06:09 +01:00
|
|
|
delay(100);
|
2020-06-24 17:36:32 +01:00
|
|
|
}
|
2020-06-24 19:06:09 +01:00
|
|
|
Serial.println("");
|
|
|
|
Serial.println("WiFi connected");
|
|
|
|
Serial.println("IP address: ");
|
2020-06-24 17:36:32 +01:00
|
|
|
Serial.println(WiFi.localIP());
|
|
|
|
}
|
|
|
|
|
2020-08-19 18:10:35 +01:00
|
|
|
void ConnectToInflux() {
|
2020-06-24 19:06:09 +01:00
|
|
|
// Add constant tags - only once
|
|
|
|
sensor.addTag("Phase", "Solar 1");
|
|
|
|
|
|
|
|
// Check server connection
|
|
|
|
if (client.validateConnection()) {
|
|
|
|
Serial.print("Connected to InfluxDB: ");
|
|
|
|
Serial.println(client.getServerUrl());
|
|
|
|
} else {
|
|
|
|
Serial.print("InfluxDB connection failed: ");
|
|
|
|
Serial.println(client.getLastErrorMessage());
|
2020-06-24 17:36:32 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void setup() {
|
|
|
|
Serial.begin(115200);
|
2020-06-24 19:06:09 +01:00
|
|
|
ConnectToWiFiMulti();
|
2020-06-24 17:36:32 +01:00
|
|
|
ConnectToInflux();
|
2020-08-19 18:17:31 +01:00
|
|
|
// Add constant tags - only once
|
|
|
|
sensor.addTag("device", "ESP32-Solar");
|
2020-06-24 17:36:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
void loop() {
|
2020-08-19 18:17:31 +01:00
|
|
|
float voltage = pzem.voltage();
|
|
|
|
if(!isnan(voltage)){
|
|
|
|
Serial.print("Voltage: "); Serial.print(voltage); Serial.println("V");
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading voltage");
|
|
|
|
}
|
|
|
|
|
|
|
|
float current = pzem.current();
|
|
|
|
if(!isnan(current)){
|
|
|
|
Serial.print("Current: "); Serial.print(current); Serial.println("A");
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading current");
|
|
|
|
}
|
|
|
|
|
|
|
|
float power = pzem.power();
|
|
|
|
if(!isnan(power)){
|
|
|
|
Serial.print("Power: "); Serial.print(power); Serial.println("W");
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading power");
|
|
|
|
}
|
|
|
|
|
|
|
|
float energy = pzem.energy();
|
|
|
|
if(!isnan(energy)){
|
|
|
|
Serial.print("Energy: "); Serial.print(energy,3); Serial.println("kWh");
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading energy");
|
|
|
|
}
|
|
|
|
|
|
|
|
float frequency = pzem.frequency();
|
|
|
|
if(!isnan(frequency)){
|
|
|
|
Serial.print("Frequency: "); Serial.print(frequency, 1); Serial.println("Hz");
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading frequency");
|
|
|
|
}
|
|
|
|
|
|
|
|
float pf = pzem.pf();
|
|
|
|
if(!isnan(pf)){
|
|
|
|
Serial.print("PF: "); Serial.println(pf);
|
|
|
|
} else {
|
|
|
|
Serial.println("Error reading power factor");
|
|
|
|
}
|
2020-06-24 17:36:32 +01:00
|
|
|
|
2020-08-19 18:17:31 +01:00
|
|
|
Serial.println();
|
|
|
|
delay(2000);
|
2020-06-24 17:36:32 +01:00
|
|
|
}
|