Support for PZEM 004T Energy monitor

Moderators: grovkillen, Stuntteam, TD-er

Post Reply
Message
Author
reliable_bob
New user
Posts: 6
Joined: 15 Sep 2017, 20:50

Re: Support for PZEM 004T Energy monitor

#21 Post by reliable_bob » 19 Sep 2017, 18:20

Well, in general, the situation is as follows.
There is NodeMCU and PZEM-004T.
The system works, but only if you apply power to the PZEM after the NodeMCU boots up. Otherwise, NodeMCU simply does not load.
And further. Your code may have been created from an older version of the library. When using the new version of the library, an error occurs when compiling in Arduino IDE.

papperone
Normal user
Posts: 497
Joined: 04 Oct 2016, 23:16

Re: Support for PZEM 004T Energy monitor

#22 Post by papperone » 19 Sep 2017, 21:02

reliable_bob wrote: 19 Sep 2017, 18:20 Well, in general, the situation is as follows.
There is NodeMCU and PZEM-004T.
The system works, but only if you apply power to the PZEM after the NodeMCU boots up. Otherwise, NodeMCU simply does not load.
And further. Your code may have been created from an older version of the library. When using the new version of the library, an error occurs when compiling in Arduino IDE.
I'm using latest version as I forket the GIT of the library...
which errors did you get so I can try to help you figure it out?
if it's related to SoftwareSerial, indeed the Arduino IDE push you to install a "newer" version which is buggy, so you need to downgrate this specific library to previous (which is again the officially GITHUB supported) in order to compile correctly...
(sorry I forgot to mention this!!)

PS; in my configuration the node boots up perfectly despite I applyed 230VAC or not to PZEM, just the sensor is unresponsive and sluggish as I already explained!
My TINDIE Store where you can find all ESP8266 boards I manufacture --> https://www.tindie.com/stores/GiovanniCas/
My Wiki Project page with self-made PCB/devices --> https://www.letscontrolit.com/wiki/inde ... :Papperone

coldman
New user
Posts: 3
Joined: 16 Jan 2017, 13:44

Re: Support for PZEM 004T Energy monitor

#23 Post by coldman » 08 Oct 2017, 16:42

papperone wrote: 13 Sep 2017, 10:59 Plugin is in a kinda of working status, this sensor has some "features" which I try to adapt:

1) sensor library is quite messy and requests a manual update of the SoftwareSerial library for ESP8266 to v3.2.3
2) the module I do have fails all the readings if it's not connected to the main AC line
3) while it's ok to have V A and W to zero when no readings, the Energy reading (which is accumulated and saved on the flash memory of the module) shoudl be reported
4) to avoid point 3) issue I decided to check if the reading was OK and (only for the Energy) to retain old device value in order to always show the accumulated Wh
5) in case of no AC line to the module, the module reading are quite slower and thus serial-comm is used the ESP8266 become slugghish (so don't blame plugin but module!)
6) If you select wrong GPIOs you can experience an almost unusable ESP8266 (somehow SoftwareSerial setup to the wrong pins generate this unresponsivness)

below a current screenshot; I'm waiting the GitHub to be cleaned up after vacation (I see too many PU request pending) to avoid flooding with more requests.
Capture.JPG
Great job! Thanks.
but how to add those values to Domoticz?
if selected Dummy - Electric - only voltage

upd: also, not all values are often displayed
2017-10-08_20-10-37.png
2017-10-08_20-10-37.png (15.07 KiB) Viewed 1991896 times
2017-10-08_20-01-36.png
2017-10-08_20-01-36.png (15.04 KiB) Viewed 1991896 times
2017-10-08_20-00-31.png
2017-10-08_20-00-31.png (14.99 KiB) Viewed 1991896 times

Code: Select all

2017-10-08 19:30:16	216.00;1.99;0.00;985.00
2017-10-08 19:29:15	212.50;1.99;0.00;985.00
2017-10-08 19:28:16	215.20;0.00;0.00;985.00
2017-10-08 19:27:14	209.80;1.99;0.00;985.00
2017-10-08 19:26:13	210.50;1.94;0.00;978.00
2017-10-08 19:25:13	205.10;1.94;0.00;972.00
2017-10-08 19:24:13	211.40;1.99;0.00;965.00
2017-10-08 19:23:16	214.10;0.00;0.00;0.00
2017-10-08 18:56:02	205.80;1.95;0.00;726.00
2017-10-08 18:55:02	207.50;1.95;0.00;726.00
2017-10-08 18:54:01	203.70;1.94;0.00;726.00
2017-10-08 18:53:01	204.00;1.91;0.00;726.00
2017-10-08 18:52:02	208.90;0.00;0.00;726.00
2017-10-08 18:51:00	208.00;1.94;0.00;726.00
2017-10-08 18:49:58	207.10;1.97;370.00;726.00
2017-10-08 18:48:59	208.30;1.96;0.00;719.00
2017-10-08 18:48:00	216.00;0.00;0.00;712.00
2017-10-08 18:46:59	203.20;1.92;0.00;705.00
2017-10-08 18:46:00	203.30;1.95;0.00;638.00
2017-10-08 18:44:58	195.70;1.89;369.00;638.00
2017-10-08 18:43:59	201.60;1.89;0.00;638.00
2017-10-08 18:42:57	195.60;1.86;365.00;638.00
2017-10-08 18:41:56	193.10;1.90;359.00;638.00
2017-10-08 18:40:56	196.90;1.91;373.00;638.00
2017-10-08 18:39:57	209.30;1.99;0.00;638.00

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#24 Post by aleph0 » 08 Nov 2017, 10:03

Hi, and thanks for making this nice plugin !

As I had to do some searching to finally compile and install it, here is a all-in-one summary of what needs to be done :
1/ Install and configure platform.io according to the instructions here :
https://www.letscontrolit.com/wiki/inde ... Platformio
then
https://www.letscontrolit.com/wiki/inde ... platformio

2/ Download the source tree from here :
https://github.com/letscontrolit/ESPEas ... .0.0-dev12 (or later version as there are being developed

3/ Download the plugin source from here and copy it in the main source
https://github.com/papperone/ESPEasyPlu ... M-004T.ino

4/ Download PZEM004T library from here and copy it in the lib subdirectory of the main source
https://github.com/olehs/PZEM004T

5/ Download SofwareSerial library in version 3.2.3 from here and copy it in the lib subdirectory of the main source
https://github.com/plerup/espsoftwarese ... /tag/3.2.3

6/ Update the library.json file that came from the softwareserial library with the following content :

Code: Select all

{
    "name": "EspSoftwareSerial",
    "version": "3.2.3",
    "keywords": [
      "serial", "io", "softwareserial"
    ],
    "description": "Implementation of the Arduino software serial for ESP8266.",
    "repository":
    {
        "type": "git",
        "url": "https://github.com/plerup/espsoftwareserial"
    },
    "frameworks": "arduino",
    "platforms": "espressif8266"
}
(version was missing and platforms mispelled :( )

After that, I was able to compile espeasy with the plugin and send it to the esp via OTA :)

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#25 Post by aleph0 » 08 Nov 2017, 10:13

Some remarks/comments about the plugin itself :

- RX and TX indications on the device page are somewhat confusing as there are referring to the pins on the esp side, so they have to be reversed compared to the pzem side. I changed the text in the version below to make it clearer
- I added some more debugging lines to make it easier to follow-up what's going on
- I noticed pzem answers in 2s when 220V is applied to the module and in 12s when no power is applied. So don't use polling time faster than 15s ; I dunno if there is a way to block that on the web page or at least to display it somewhere.

Now some problems I dunno how to fix by myself (yet ;) ) as I'm a noob is espeasy programming !
- pzem initialisation is done at boot of the esp only, so any further changes in the GPIO pins are not taken in consideration. IMHO It should be done after any config change
- I made some experiments with two modules on the same esp, as I'm trying to build a 3 phase power analyser and the plugin does not handle this correctly : Only the first one is initialised correctly and both readings are made from the 1st one. Help would be very appreciated to remove this limitation

Thanks again from this great plugin :)

Code: Select all

//#######################################################################################################
//################### Plugin 171 PZEM-004T AC Current and Voltage measurement sensor ####################
//#######################################################################################################
//
// This plugin is interfacing with PZEM-004T Sesor with softserial communication as the sensor
// has an UART pinout (TX/RX/VCC/GND)
//

#ifdef PLUGIN_BUILD_TESTING

#include <SoftwareSerial.h>
#include <PZEM004T.h>
PZEM004T *Plugin_171_pzem;
IPAddress pzemIP(192,168,1,1);    // required by the library but not used (dummy value)

#define PLUGIN_171
#define PLUGIN_ID_171        171
#define PLUGIN_171_DEBUG     true   //activate extra log info in the debug
#define PLUGIN_NAME_171       "Voltage & Current (AC) - PZEM-004T [TESTING]"
#define PLUGIN_VALUENAME1_171 "Voltage (V)"
#define PLUGIN_VALUENAME2_171 "Current (A)"
#define PLUGIN_VALUENAME3_171 "Power (W)"
#define PLUGIN_VALUENAME4_171 "Energy (Wh)"

// local parameter for this plugin
#define PZEM_MAX_ATTEMPT      3

boolean Plugin_171(byte function, struct EventStruct *event, String& string)
{
  boolean success = false;

  switch (function)
  {
    case PLUGIN_DEVICE_ADD:
      {
        Device[++deviceCount].Number = PLUGIN_ID_171;
        Device[deviceCount].Type = DEVICE_TYPE_DUAL;
        Device[deviceCount].VType = SENSOR_TYPE_QUAD;
        Device[deviceCount].Ports = 0;
        Device[deviceCount].PullUpOption = false;
        Device[deviceCount].InverseLogicOption = false;
        Device[deviceCount].FormulaOption = true;
        Device[deviceCount].ValueCount = 4;
        Device[deviceCount].SendDataOption = true;
        Device[deviceCount].TimerOption = true;
        Device[deviceCount].GlobalSyncOption = false;
        break;
      }

    case PLUGIN_GET_DEVICENAME:
      {
        string = F(PLUGIN_NAME_171);
        break;
      }

    case PLUGIN_GET_DEVICEVALUENAMES:
      {
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[0], PSTR(PLUGIN_VALUENAME1_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[1], PSTR(PLUGIN_VALUENAME2_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[2], PSTR(PLUGIN_VALUENAME3_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[3], PSTR(PLUGIN_VALUENAME4_171));
        break;
      }

    case PLUGIN_WEBFORM_LOAD:
      {
        addFormNote(string, F("SoftSerial: 1st=to TX-Pin, 2nd=to RX-Pin"));
        success = true;
        break;
      }

    case PLUGIN_WEBFORM_SAVE:
      {
        success = true;
        break;
      }

    case PLUGIN_READ:
      {
        if (PLUGIN_171_DEBUG) {
          String log = F("PZEM004T: Reading started.");
          addLog(LOG_LEVEL_INFO, log);
        }
    		float pzVoltage = Plugin171_ReadVoltage();
    		float pzCurrent = Plugin171_ReadCurrent();
    		float pzPower   = Plugin171_ReadPower();
    		float pzEnergy  = Plugin171_ReadEnergy();
        //-------------------------------------------------------------------
        // readings can be ZERO if there's no AC input on the module.
        // in this case V A and W are reported correctly as ZERO but
        // the accumulated Energy paramenter will not be saved so to
        // preserve previous value
        //-------------------------------------------------------------------
        UserVar[event->BaseVarIndex]     = pzVoltage;
        UserVar[event->BaseVarIndex + 1] = pzCurrent;
        UserVar[event->BaseVarIndex + 2] = pzPower;
        if (pzEnergy>=0)  UserVar[event->BaseVarIndex + 3] = pzEnergy;
        if (PLUGIN_171_DEBUG) {
          String log = F("PZEM004T: Voltage="); log += pzVoltage; log += F(" V");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Current="); log += pzCurrent; log += F(" A");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Power="); log += pzPower; log += F(" W");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Energy="); log += pzEnergy; log += F(" Wh");
          addLog(LOG_LEVEL_INFO, log);
        }
        success = true;
        break;
      }

    case PLUGIN_INIT:
      {
        if (!Plugin_171_pzem)
        {
          int pzemRXpin = Settings.TaskDevicePin1[event->TaskIndex];
          int pzemTXpin = Settings.TaskDevicePin2[event->TaskIndex];
          Plugin_171_pzem = new PZEM004T(pzemRXpin, pzemTXpin);
          if (PLUGIN_171_DEBUG) {
            String log = F("PZEM004T: Object Initialized");
            log += F(" - RX-Pin="); log += pzemRXpin;
            log += F(" - TX-Pin="); log += pzemTXpin;
            addLog(LOG_LEVEL_INFO, log);
          }
		      Plugin_171_pzem->setAddress(pzemIP);  // This initializes the PZEM004T library using a (useless) fake IP address
          if (PLUGIN_171_DEBUG) {
            String log = F("PZEM004T: setup address (dummy)");
            log += F(" - "); log += pzemIP;
            addLog(LOG_LEVEL_INFO, log);
          }
        }
        success = true;
        break;
      }

  }
  return success;
}

//************************************//
//***** reading values functions *****//
//************************************//

// NOTE: readings are attempted only PZEM_AMX_ATTEMPT times

float Plugin171_ReadVoltage() {
  int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->voltage(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
	return reading;
}

float Plugin171_ReadCurrent() {
	int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->current(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
  return reading;
}

float Plugin171_ReadPower() {
  int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->power(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
  return reading;
}

float Plugin171_ReadEnergy() {
	int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->energy(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
	return reading;
}
#endif

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#26 Post by aleph0 » 08 Nov 2017, 10:27

coldman wrote: 08 Oct 2017, 16:42 but how to add those values to Domoticz?
if selected Dummy - Electric - only voltage
I didn't find a clean way to get the values, but a workaroud : In domoticz I defined a dummy of type "3 phase Ampers" and I gave the idx of it to pzem plugin in espeasy. Then I used the following code in domoticz to read from the 3ph amp dummy and dispatch the infos in "real" devices :

Code: Select all

local dev_HC= "Heures creuses EDF"
local dev_pzem="pzem L1" 
local dev_V="Tension L1"
local dev_A="Amp L1"
local dev_W="Power L1"

--------------------------------------------------------------------------------
--                     Function library                              --
--------------------------------------------------------------------------------
function UpdateDev(device,nvalue,svalues)
    --Met à jour un device numérique Domoticz
    commandArray[#commandArray+1] = {['UpdateDevice'] = otherdevices_idx[device]..'|'..tostring(nvalue)..'|'..tostring(svalues)}
end

function UpdateP1(device,HC,conso,prod,freq)
    -- Met à jour le P1 smart counter
    -- device : nom du compteur
    -- HC     : "On" si heures creuses, "Off" si heures pleines
    -- conso  : consommation instantannée
    -- prod   : production instantannée
    -- freq   : frequence d'exécution du script (en minutes) 
    
    local u1, u2, p1, p2
    local dbg=0
    
    u1, u2, p1, p2 = string.match(otherdevices_svalues[device],"(.-);(.-);(.-);(.-);.*")
    
    -- Utile pour les compteurs nouvellement crées
    u1=u1 or 0
    u2=u2 or 0
    p1=p1 or 0
    p2=p2 or 0

    if dbg == 1 then
        print("Mise à jour de "..tostring(device))
        print("u1 "..tostring(u1))
        print("u2 "..tostring(u2))
        print("p1 "..tostring(p1))
        print("p2 "..tostring(p2))
        print("conso "..tostring(conso))
        print("prod "..tostring(prod))
    end

    if otherdevices[HC] == 'Off' then
        -- svalue=USAGE1;USAGE2;RETURN1;RETURN2;CONS;PROD
        commandArray[#commandArray+1] = {['UpdateDevice'] = otherdevices_idx[device]..'|0|'..tostring(u1+conso*freq/60)..';'..tostring(u2)..';'..tostring(p1+prod*freq/60)..';'..tostring(p2)..';'..tostring(conso)..';'..tostring(prod)}
    else
        commandArray[#commandArray+1] = {['UpdateDevice'] = otherdevices_idx[device]..'|0|'..tostring(u1)..';'..tostring(u2+conso*freq/60)..';'..tostring(p1)..';'..tostring(p2+prod*freq/60)..';'..tostring(conso)..';'..tostring(prod)}
    end
end

function pzem_read(pzem,HC,dev_V,dev_A,dev_W,freq)
    --[[read information from a pzem in a 3ph amp device
    and dispatch voltage, current and power measures in corresponding devices
    Input :
    pzem : type 3PH Amp
    HC : switch "On"=Happy hours
    
    Output :
    dev_V : type Tension
    dev_A : type Ampers
    dev_W : P1 smart counter
    freq : measure frequency of the pzem, in minutes. Must match the delay parameter of the esp
    ]]--

    local val_V,val_A,val_W,val_Wh

    val_V,val_A,val_W,val_Wh=string.match(otherdevices_svalues[pzem],"(.-);(.-);(.-);(.-)")
    UpdateDev(dev_V,0,val_V)
    UpdateDev(dev_A,0,val_A)
    UpdateP1(dev_W,HC,val_W,0,1)
end

commandArray = {}

if devicechanged[dev_pzem] then pzem_read(dev_pzem,dev_HC,dev_V,dev_A,dev_W,1) end

return commandArray

Hope it helps !
Last edited by aleph0 on 08 Nov 2017, 13:36, edited 1 time in total.

papperone
Normal user
Posts: 497
Joined: 04 Oct 2016, 23:16

Re: Support for PZEM 004T Energy monitor

#27 Post by papperone » 08 Nov 2017, 12:30

thanks for your feedback...
at the moment the plugin is not build to allow multiple sensors connected to single ESP8266; no having more than one I can't test it :(

about PIN naming it's just a matter of convention, as for me I believe it's more relevant to map the pin function of ESP8266 (same when you connect an FTDI interface to program ESP8266 module, you need to link RX to TX and viceversa)...
I'm open to suggestion here, if the majority thinks it's better to reverse the naming so RX means on PZEM and not on ESP8266 we can submit such pull-request on github! :mrgreen:
My TINDIE Store where you can find all ESP8266 boards I manufacture --> https://www.tindie.com/stores/GiovanniCas/
My Wiki Project page with self-made PCB/devices --> https://www.letscontrolit.com/wiki/inde ... :Papperone

ut1545
Normal user
Posts: 32
Joined: 22 Mar 2016, 20:56

Re: Support for PZEM 004T Energy monitor

#28 Post by ut1545 » 10 Nov 2017, 20:23

Hello all,

Just a few words about PZEM 004T:

I have implement one PZEM connected to a ESP-12F and running a very simple custom sketch. It is installed at very beginning of the incoming electrical line so, it should measure the same as the meter of electrical provider. After 11 months comparing the two meters, I can say that it is very precise: around 0,45% difference!!!

So, in my opinion, it is a very good device in order to measure electrical consumption. I will be next two months on travel but I will try to migrate my sketch to ESP Easy + PZEM plugin. I will post any relevant information if it can help....

Also, let me thank all of you for your efforts in create this ESP Plugin. Great job !!!!

Regards,

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#29 Post by aleph0 » 14 Nov 2017, 21:56

papperone wrote: 08 Nov 2017, 12:30 at the moment the plugin is not build to allow multiple sensors connected to single ESP8266; no having more than one I can't test it :(
Could you give me some hints of what should be done to allow that ? I'd try to implement it and contribute back as I can test it ;)

papperone
Normal user
Posts: 497
Joined: 04 Oct 2016, 23:16

Re: Support for PZEM 004T Energy monitor

#30 Post by papperone » 15 Nov 2017, 06:55

Well if you are not familiar with the structure of ESPEasy won't be that simple :(
I ned as well to make other pluging (for my personal needs) able to use multiple devices and still no time to devote to programming this...
My TINDIE Store where you can find all ESP8266 boards I manufacture --> https://www.tindie.com/stores/GiovanniCas/
My Wiki Project page with self-made PCB/devices --> https://www.letscontrolit.com/wiki/inde ... :Papperone

Germil
New user
Posts: 1
Joined: 15 Nov 2017, 21:29

Re: Support for PZEM 004T Energy monitor

#31 Post by Germil » 15 Nov 2017, 21:38

Hello, im New in forum and If that can help, Ill be glad.
https://github.com/apreb/eNode

TD-er
Core team member
Posts: 8739
Joined: 01 Sep 2017, 22:13
Location: the Netherlands
Contact:

Re: Support for PZEM 004T Energy monitor

#32 Post by TD-er » 17 Nov 2017, 15:11

Germil wrote: 15 Nov 2017, 21:38 Hello, im New in forum and If that can help, Ill be glad.
https://github.com/apreb/eNode
Hmm, that looks like a nice project to read about :)

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#33 Post by aleph0 » 19 Nov 2017, 18:13

Hi all,

here is a fix for the problem of parameters being taken into account only at boot. Now things can be changed on the fly by re-doing initialisation at every "submit" of the form :

Code: Select all

//#######################################################################################################
//################### Plugin 171 PZEM-004T AC Current and Voltage measurement sensor ####################
//#######################################################################################################
//
// This plugin is interfacing with PZEM-004T Sesor with softserial communication as the sensor
// has an UART pinout (TX/RX/VCC/GND)
//

#ifdef PLUGIN_BUILD_TESTING

#include <SoftwareSerial.h>
#include <PZEM004T.h>
PZEM004T *Plugin_171_pzem;
IPAddress pzemIP(192,168,1,1);    // required by the library but not used (dummy value)

boolean Plugin_171_init = false;

#define PLUGIN_171
#define PLUGIN_ID_171        171
#define PLUGIN_171_DEBUG     true   //activate extra log info in the debug
#define PLUGIN_NAME_171       "Voltage & Current (AC) - PZEM-004T [TESTING]"
#define PLUGIN_VALUENAME1_171 "Voltage (V)"
#define PLUGIN_VALUENAME2_171 "Current (A)"
#define PLUGIN_VALUENAME3_171 "Power (W)"
#define PLUGIN_VALUENAME4_171 "Energy (Wh)"

// local parameter for this plugin
#define PZEM_MAX_ATTEMPT      3

boolean Plugin_171(byte function, struct EventStruct *event, String& string)
{
  boolean success = false;

  switch (function)
  {
    case PLUGIN_DEVICE_ADD:
      {
        Device[++deviceCount].Number = PLUGIN_ID_171;
        Device[deviceCount].Type = DEVICE_TYPE_DUAL;
        Device[deviceCount].VType = SENSOR_TYPE_QUAD;
        Device[deviceCount].Ports = 0;
        Device[deviceCount].PullUpOption = false;
        Device[deviceCount].InverseLogicOption = false;
        Device[deviceCount].FormulaOption = true;
        Device[deviceCount].ValueCount = 4;
        Device[deviceCount].SendDataOption = true;
        Device[deviceCount].TimerOption = true;
        Device[deviceCount].GlobalSyncOption = false;
        break;
      }

    case PLUGIN_GET_DEVICENAME:
      {
        string = F(PLUGIN_NAME_171);
        break;
      }

    case PLUGIN_GET_DEVICEVALUENAMES:
      {
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[0], PSTR(PLUGIN_VALUENAME1_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[1], PSTR(PLUGIN_VALUENAME2_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[2], PSTR(PLUGIN_VALUENAME3_171));
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[3], PSTR(PLUGIN_VALUENAME4_171));
        break;
      }

    case PLUGIN_WEBFORM_LOAD:
      {
        addFormNote(string, F("SoftSerial: 1st=to TX-Pin, 2nd=to RX-Pin"));
        success = true;
        break;
      }

    case PLUGIN_WEBFORM_SAVE:
      {
        Plugin_171_init = false;
        success = true;
        break;
      }

    case PLUGIN_READ:
      {
        if (PLUGIN_171_DEBUG) {
          String log = F("PZEM004T: Reading started.");
          addLog(LOG_LEVEL_INFO, log);
        }
    		float pzVoltage = Plugin171_ReadVoltage();
    		float pzCurrent = Plugin171_ReadCurrent();
    		float pzPower   = Plugin171_ReadPower();
    		float pzEnergy  = Plugin171_ReadEnergy();
        //-------------------------------------------------------------------
        // readings can be ZERO if there's no AC input on the module.
        // in this case V A and W are reported correctly as ZERO but
        // the accumulated Energy paramenter will not be saved so to
        // preserve previous value
        //-------------------------------------------------------------------
        UserVar[event->BaseVarIndex]     = pzVoltage;
        UserVar[event->BaseVarIndex + 1] = pzCurrent;
        UserVar[event->BaseVarIndex + 2] = pzPower;
        if (pzEnergy>=0)  UserVar[event->BaseVarIndex + 3] = pzEnergy;
        if (PLUGIN_171_DEBUG) {
          String log = F("PZEM004T: Voltage="); log += pzVoltage; log += F(" V");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Current="); log += pzCurrent; log += F(" A");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Power="); log += pzPower; log += F(" W");
          addLog(LOG_LEVEL_INFO, log);
          log = F("PZEM004T: Energy="); log += pzEnergy; log += F(" Wh");
          addLog(LOG_LEVEL_INFO, log);
        }
        success = true;
        break;
      }

    case PLUGIN_INIT:
      {
        if (!Plugin_171_init)
        {
          int pzemRXpin = Settings.TaskDevicePin1[event->TaskIndex];
          int pzemTXpin = Settings.TaskDevicePin2[event->TaskIndex];
          Plugin_171_pzem = new PZEM004T(pzemRXpin, pzemTXpin);
          if (PLUGIN_171_DEBUG) {
            String log = F("PZEM004T: Object Initialized");
            log += F(" - RX-Pin="); log += pzemRXpin;
            log += F(" - TX-Pin="); log += pzemTXpin;
            addLog(LOG_LEVEL_INFO, log);
          }
		      Plugin_171_pzem->setAddress(pzemIP);  // This initializes the PZEM004T library using a (useless) fake IP address
          if (PLUGIN_171_DEBUG) {
            String log = F("PZEM004T: setup address (dummy)");
            log += F(" - "); log += pzemIP;
            addLog(LOG_LEVEL_INFO, log);
          }
        }
        Plugin_171_init = true;
        success = true;
        break;
      }

  }
  return success;
}

//************************************//
//***** reading values functions *****//
//************************************//

// NOTE: readings are attempted only PZEM_AMX_ATTEMPT times

float Plugin171_ReadVoltage() {
  int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->voltage(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
  if (PLUGIN_171_DEBUG) {
    String log = F("Voltage try :"); log += counter;
    addLog(LOG_LEVEL_DEBUG, log);
  }
	return reading;
}

float Plugin171_ReadCurrent() {
	int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->current(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
  if (PLUGIN_171_DEBUG) {
    String log = F("Current try :"); log += counter;
    addLog(LOG_LEVEL_DEBUG, log);
  }
  return reading;
}

float Plugin171_ReadPower() {
  int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->power(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (reading == -1) reading = 0;
  if (PLUGIN_171_DEBUG) {
    String log = F("Power try :"); log += counter;
    addLog(LOG_LEVEL_DEBUG, log);
  }
  return reading;
}

float Plugin171_ReadEnergy() {
	int counter = 0;
	float reading = -1.0;
	do {
		reading = Plugin_171_pzem->energy(pzemIP);
		wdt_reset();
		counter++;
	} while (counter < PZEM_MAX_ATTEMPT && reading < 0.0);
  if (PLUGIN_171_DEBUG) {
    String log = F("Energy try :"); log += counter;
    addLog(LOG_LEVEL_DEBUG, log);
  }
	return reading;
}
#endif
Sorry, I don't know how to use git to make pull requests :( this will come also, please bear with my learning curve ;)

I also found a workaround to have several modules using the "port" feature of espeasy but it's a bit ugly ; if anybody have urgent need of many module I can publish, if not I'll wait to find a better solution !

F-rank
New user
Posts: 5
Joined: 05 Dec 2017, 22:02

Re: Support for PZEM 004T Energy monitor

#34 Post by F-rank » 05 Dec 2017, 22:16

Hi,

Great plugin!
All values show correctly in the web interface that runs on the esp.
At first, some values weren't Always displayed.
I solved that by using another power supply for the 5v supply for the pzem004t.
Maybe some other users can solve their problems reading the values knowing that.

Now, I can add the pzem to Domoticz without problems, only one value is displayed.. The voltage. Other then that, nothing shows.
I was wondering if it would be possible to choose an IDX for each value of the sensor?
I don't know if that is possible at all in esp-easy?

It would help me out a lot.
Since I'm not a die hard coder, I can't do it myself...

Hope someone can help!

Keep up the good work!
\
Best regards,
Frank.

papperone
Normal user
Posts: 497
Joined: 04 Oct 2016, 23:16

Re: Support for PZEM 004T Energy monitor

#35 Post by papperone » 06 Dec 2017, 01:02

aleph0 wrote: 19 Nov 2017, 18:13 Hi all,

here is a fix for the problem of parameters being taken into account only at boot. Now things can be changed on the fly by re-doing initialisation at every "submit" of the form :

[ CODE ]

Sorry, I don't know how to use git to make pull requests :( this will come also, please bear with my learning curve ;)

I also found a workaround to have several modules using the "port" feature of espeasy but it's a bit ugly ; if anybody have urgent need of many module I can publish, if not I'll wait to find a better solution !
Sorry for late reply but I missed your post; you are right about the bug on save changin parameter, it's enough to destroy the object so it will be recreated on the init (no need of the boolean flag), I will submit this bug-fix asap.
Can you please explain better what you mean with "port feature of espeasy" so I can implement the multiple sensor support? (you can share your code even via PM and I can incorporate with my plugin and publish it on GitHub to be tested)
My TINDIE Store where you can find all ESP8266 boards I manufacture --> https://www.tindie.com/stores/GiovanniCas/
My Wiki Project page with self-made PCB/devices --> https://www.letscontrolit.com/wiki/inde ... :Papperone

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#36 Post by sega2177 » 06 Dec 2017, 04:08

Hello aleph0, could you put the compiled firmware with the plugin PZET-004?

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#37 Post by aleph0 » 06 Dec 2017, 13:15

sega2177 wrote: 06 Dec 2017, 04:08 Hello aleph0, could you put the compiled firmware with the plugin PZET-004?
Please find attached the version for 4Gb flash with all the "Testing" plugins enabled, including the PZEM-004T with my last modifications to handle two modules. Use "port" to select the module : port 0 for first module and port 1 for second module. Remember each module will take up to 12s to answer in case there is no voltage on the main terminal, so don't poll faster then 15s*the number of modules

Feedback is welcome !
Attachments
ESPEasy-2.0.0-dev12_test_4096.bin.zip
(401.93 KiB) Downloaded 7598 times

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#38 Post by aleph0 » 06 Dec 2017, 13:18

F-rank wrote: 05 Dec 2017, 22:16 Now, I can add the pzem to Domoticz without problems, only one value is displayed.. The voltage. Other then that, nothing shows.
Have a look here for a workaround viewtopic.php?p=20595#p20595

F-rank
New user
Posts: 5
Joined: 05 Dec 2017, 22:02

Re: Support for PZEM 004T Energy monitor

#39 Post by F-rank » 06 Dec 2017, 13:41

Ok thanks,

I must have overlooked that...
I never used code in domoticz before. How do I use it?
I googled and looked in the wiki pages. But can't find an answer to it?

Maybe I'm not looking at the right places?

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#40 Post by sega2177 » 06 Dec 2017, 15:40

Thank you very much, everything turned out, but as with many, only the voltage in domoticz is output, you gave an example above how to prescribe, so that this does not happen-I did not understand which folder I should throw it in?

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#41 Post by sega2177 » 06 Dec 2017, 19:36

I figured out the numeric values, but when I open the log, it's empty (((

F-rank
New user
Posts: 5
Joined: 05 Dec 2017, 22:02

Re: Support for PZEM 004T Energy monitor

#42 Post by F-rank » 07 Dec 2017, 00:36

I have put the code in the file device.Lua?
Don't know for sure if this is the correct file? Or how to do this correctly.
I do get four separate values now, as shown in the picture below.
But indeed the log stays empty.

Hope you can help me out here.
At least I want to log Voltage and Current.
So I hope this will be possible with my setup

Many thanks for all the help.

Image

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#43 Post by aleph0 » 07 Dec 2017, 07:20

Hi!

Regarding domoticz code, you have two choices :
- either you copy it in the domoticz/script/lua folder with a name ending by _device.lua eg pzem_device.lua
- either you go to the tools menu->more-> events, create a new "lua" "device" script named as you want and replace the default content by the code I posted

You also need to edit the first lines of the script starting by local dev,_... to match the name of your own devices

Btw, it's normal for the dummy pzem log to be empty as we overload the object. You'll get the log from the devices managed by the script

Hope it helps !

F-rank
New user
Posts: 5
Joined: 05 Dec 2017, 22:02

Re: Support for PZEM 004T Energy monitor

#44 Post by F-rank » 07 Dec 2017, 07:48

Thanks a lot!

I will look into that after work.
I have been looking for some setting regarding lua scripts as I thought I had to look in thst way. But didn't find any...
Now... I may have overlooked it, but can it be a specific version when it was introduced?
If i click update, It says it's the latest.

Thanks again!

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#45 Post by sega2177 » 07 Dec 2017, 10:17

it is not entirely clear what to prescribe after dev, could you describe in more detail, since I'm new to this and I'm hard at programming, thank you in advance

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#46 Post by aleph0 » 07 Dec 2017, 10:32

I can understand :). This issue is now purely related to domoticz and not espeasy. So far, espeasy is doing the job correctly :) If it's ok for you all, I'll open a thread on the domoticz forum and upload a detailed tutorial over there. It'll be this week-end as I have no time for this during the week ; I'll post the link here when I'm done with it

F-rank
New user
Posts: 5
Joined: 05 Dec 2017, 22:02

Re: Support for PZEM 004T Energy monitor

#47 Post by F-rank » 07 Dec 2017, 10:47

That would be great!

Thanks!

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#48 Post by sega2177 » 07 Dec 2017, 11:36

we will wait, thank you

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#49 Post by aleph0 » 09 Dec 2017, 22:32

Hi All !

Here is the link to topic on the domoticz forum on how to retreive the pzem values :
https://www.domoticz.com/forum/viewtopi ... 14&t=20820

Please note that in that post, I updated the domoticz script compared to the one I posted here previously to fix a few bugs, and for more accurate measurements

Feedback is welcome !

sega2177
New user
Posts: 6
Joined: 06 Dec 2017, 03:39

Re: Support for PZEM 004T Energy monitor

#50 Post by sega2177 » 10 Dec 2017, 11:50

Hi, I did everything as you do, but in the device tab, the values ​​are shown, and when you switch to auxiliary values ​​by zero, what else could it be? It is not entirely clear what values ​​to write when assigning a variable? Same as you on the screen or others?

gajotnt
Normal user
Posts: 13
Joined: 22 Feb 2017, 15:07
Location: Portugal
Contact:

Re: Support for PZEM 004T Energy monitor

#51 Post by gajotnt » 12 Dec 2017, 17:10

Is it possible to have this FW for 1mb ROM?

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#52 Post by ruben_ramos » 12 Dec 2017, 17:12

Hi aleph0,
Can you tell me how connect pzem 004t to esp (my is a Wemos D1 mini)?
TX to GPIO 14 and RX to GPIO 12? only that? Directly without any resistance?

Thanks

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#53 Post by aleph0 » 12 Dec 2017, 20:18

@ruben : yes, I connected them directly without resistor to a wemos d1 mini. Pzem is powered with 5v, I read somewhere the wemos can handle 5v on the gpio pins, I wanted to test. So far it's working fine, but it's only ~20 days of continuous power up. We will see if it last :-)

@gajotnt : I'll try to compile for 1Mb and tell you what. Will be on weekend !

gajotnt
Normal user
Posts: 13
Joined: 22 Feb 2017, 15:07
Location: Portugal
Contact:

Re: Support for PZEM 004T Energy monitor

#54 Post by gajotnt » 12 Dec 2017, 20:31

aleph0 wrote: 12 Dec 2017, 20:18 @ruben : yes, I connected them directly without resistor to a wemos d1 mini. Pzem is powered with 5v, I read somewhere the wemos can handle 5v on the gpio pins, I wanted to test. So far it's working fine, but it's only ~20 days of continuous power up. We will see if it last :-)

@gajotnt : I'll try to compile for 1Mb and tell you what. Will be on weekend !
Thanks :)

@Ruben_Ramos, bom ver um Tuga :)

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#55 Post by ruben_ramos » 12 Dec 2017, 22:12

I think have something wrong..
Give me values -1
Image

my connections are:
Image


thanks for help :D
Last edited by ruben_ramos on 12 Dec 2017, 22:20, edited 2 times in total.

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#56 Post by ruben_ramos » 12 Dec 2017, 22:13

gajotnt wrote: 12 Dec 2017, 20:31 Thanks :)

@Ruben_Ramos, bom ver um Tuga :)
Yeap :D, tem de ser...

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#57 Post by aleph0 » 14 Dec 2017, 16:38

ruben_ramos wrote: 12 Dec 2017, 22:12 I think have something wrong..
Give me values -1
Image

my connections are:
Image


thanks for help :D
You have inverted the pins on the white connector. Look carefully on the PCB, the pins are identified with numbers and meaning

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#58 Post by ruben_ramos » 14 Dec 2017, 17:03

i have noticed that, and changed, but without success.. continue the same, give me -1.
How to know if pzem its working good? or its damaged?

giruchile
New user
Posts: 5
Joined: 17 Dec 2017, 19:45

Re: Support for PZEM 004T Energy monitor

#59 Post by giruchile » 17 Dec 2017, 20:02

Hello,

I have a wemos connected to a pzem running a few months ago, this sends the information to a PC with domoticz who keeps track of these variables.
esp 1.JPG
esp 1.JPG (44.79 KiB) Viewed 1038297 times
esp 2.JPG
esp 2.JPG (41.91 KiB) Viewed 1038297 times
esp3.JPG
esp3.JPG (46.7 KiB) Viewed 1038297 times
esp4.JPG
esp4.JPG (49.68 KiB) Viewed 1038297 times

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#60 Post by ruben_ramos » 18 Dec 2017, 10:48

giruchile can you show how you had connected pzem to wemos?

giruchile
New user
Posts: 5
Joined: 17 Dec 2017, 19:45

Re: Support for PZEM 004T Energy monitor

#61 Post by giruchile » 18 Dec 2017, 13:09

Hello,
for the connection I did it directly, but with 3.3v and I put a resistance in parallel within the pzem, the idea is that the optocoupler is running with 3.3v and not with 5v as it comes originally.
Now I'm not at home, I can barely get a picture of the change I made.

ruben_ramos
New user
Posts: 8
Joined: 09 Jan 2017, 12:35
Location: Portugal

Re: Support for PZEM 004T Energy monitor

#62 Post by ruben_ramos » 18 Dec 2017, 13:40

I appreciate that!
Thanks,

giruchile
New user
Posts: 5
Joined: 17 Dec 2017, 19:45

Re: Support for PZEM 004T Energy monitor

#63 Post by giruchile » 20 Dec 2017, 16:56

20171220_125303.jpg
20171220_125303.jpg (2.12 MiB) Viewed 1039705 times

Aliki
Normal user
Posts: 10
Joined: 26 Jun 2017, 12:25

Re: Support for PZEM 004T Energy monitor

#64 Post by Aliki » 20 Dec 2017, 21:49

Hi. giruchile, could you put the compiled firmware with the plugin PZET-004 ?

papperone
Normal user
Posts: 497
Joined: 04 Oct 2016, 23:16

Re: Support for PZEM 004T Energy monitor

#65 Post by papperone » 21 Dec 2017, 07:18

It seems the plugin of giruchile is a different one from the oen I uploaded to the GitHub; it would be great to keep just one plugin per device to avoid duplication and confusion...
I don't mind even to remove mine if the other is better but I'd like as I wrote to make sure users won't get confused with this...
My TINDIE Store where you can find all ESP8266 boards I manufacture --> https://www.tindie.com/stores/GiovanniCas/
My Wiki Project page with self-made PCB/devices --> https://www.letscontrolit.com/wiki/inde ... :Papperone

giruchile
New user
Posts: 5
Joined: 17 Dec 2017, 19:45

Re: Support for PZEM 004T Energy monitor

#66 Post by giruchile » 23 Dec 2017, 21:48

I actually copied codes from several sides until it worked. it is a very crude and imperfect programming.

I attach the code I use if someone wants to use it and better if they fix it, use it with espeasy 1.4 and mega espaesy.

_P099_PZEM.ino

Code: Select all

//#######################################################################################################
//#################################### Plugin 099: PZEM-004T ############################################
//#######################################################################################################

#define PLUGIN_099
#define PLUGIN_ID_099         99
#define PLUGIN_NAME_099       "PZEM-004T"
#define PLUGIN_VALUENAME1_099 ""


boolean Plugin_099(byte function, struct EventStruct *event, String& string)
{
  boolean success = false;

  switch (function)
  {

    case PLUGIN_DEVICE_ADD:
      {
        Device[++deviceCount].Number = PLUGIN_ID_099;
        Device[deviceCount].VType = SENSOR_TYPE_SINGLE;
        Device[deviceCount].ValueCount = 1;
        Device[deviceCount].SendDataOption = true;
        Device[deviceCount].TimerOption = true;
        Device[deviceCount].FormulaOption = true;
        break;
      }

    case PLUGIN_GET_DEVICENAME:
      {
        string = F(PLUGIN_NAME_099);
        break;
      }

    case PLUGIN_GET_DEVICEVALUENAMES:
      {
        strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[0], PSTR(PLUGIN_VALUENAME1_099));
        break;
      }

    case PLUGIN_WEBFORM_LOAD:
      {
        byte choice = Settings.TaskDevicePluginConfig[event->TaskIndex][0];
        String options[4];
        options[0] = F("Voltaje");
        options[1] = F("Corriente");
        options[2] = F("Potencia");
        options[3] = F("Energia");
        int optionValues[4];
        optionValues[0] = 0;
        optionValues[1] = 1;
        optionValues[2] = 2;
        optionValues[3] = 3;
        string += F("<TR><TD>Indicator:<TD><select name='plugin_099'>");
        for (byte x = 0; x < 4; x++)
        {
          string += F("<option value='");
          string += optionValues[x];
          string += "'";
          if (choice == optionValues[x])
            string += F(" selected");
          string += ">";
          string += options[x];
          string += F("</option>");
        }
        string += F("</select>");

        success = true;
        break;
      }

    case PLUGIN_WEBFORM_SAVE:
      {
        String plugin1 = WebServer.arg("plugin_099");
        Settings.TaskDevicePluginConfig[event->TaskIndex][0] = plugin1.toInt();
        success = true;
        break;
      }
      
    case PLUGIN_READ:
      {
        float value = 0;
        float cont = 0;
        switch(Settings.TaskDevicePluginConfig[event->TaskIndex][0])
        {
          case 0: //Voltaje
          {
            value = pzem.voltage(ip);
            while(value < 0 ){
              cont++;
              if (cont == 3) {
                 return success;
              }
              value = pzem.voltage(ip); 
              String log = F("PZEM : ERROR LECTURA VOLTAJE");
              addLog(LOG_LEVEL_ERROR,log);
              }
            break;
          }
          case 1: //Corriente
          {
            value = pzem.current(ip);
            while(value < 0){
              cont++;
              if (cont == 3) {
                 return success;
              }
              value = pzem.current(ip); 
              String log = F("PZEM : ERROR LECTURA CORRIENTE");
              addLog(LOG_LEVEL_ERROR,log);
              }
            break;
          }
          case 2: //Potencia
          {
            value = pzem.power(ip);
            while(value < 0){
              cont++;
              if (cont == 3) {
                 return success;
              }
              value = pzem.power(ip); 
              String log = F("PZEM : ERROR LECTURA POWER");
              addLog(LOG_LEVEL_ERROR,log);
              }
            break;
          }
          case 3: //Energia
          {
            value = pzem.energy(ip);
            while(value < 0){
              cont++;
              if (cont == 3) {
                 return success;
              }
              value = pzem.energy(ip);
              String log = F("PZEM : ERROR LECTURA ENERGIA");
              addLog(LOG_LEVEL_ERROR,log); 
              }
            break;
          }
        }
     
        UserVar[event->BaseVarIndex] = value;
        String log = F("PZEM : ");
        log += value;
        addLog(LOG_LEVEL_INFO,log);
        success = true;
        break;
      }
  }
  return success;
}
in ESPEasy.ino add

Code: Select all

#include <PZEM004T.h>
I did not put all the values in the same device because I caused problems when integrating it in Domotics

dcjona
New user
Posts: 7
Joined: 13 Dec 2017, 14:05

Re: Support for PZEM 004T Energy monitor

#67 Post by dcjona » 12 Jan 2018, 08:19

hello
no chance for me i tried but still 0...

i tried to plug to D5 and D6 on the wemos D& mini and also D3 and D4 but still the same ...
swap RX and TX done too

Voltage (V):233
Current (A): 0
Power (W): 0
Energy (Wh):45

any help please ?

lolo
New user
Posts: 1
Joined: 12 Jan 2018, 18:44

Re: Support for PZEM 004T Energy monitor

#68 Post by lolo » 12 Jan 2018, 19:11

Hola.

Estoy usando el sistema de aleph0, funcionando perfectamente, he conectado la alimentación de 5V. desde el ESP8266, en VIN y GND, en VIN hay 5V,

Hi.

I am using the aleph0 system, working perfectly, I have connected the 5V power. from ESP8266, in VIN and GND, in VIN there are 5V,

Image

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#69 Post by aleph0 » 13 Jan 2018, 21:55

dcjona wrote: 12 Jan 2018, 08:19 hello
no chance for me i tried but still 0...

i tried to plug to D5 and D6 on the wemos D& mini and also D3 and D4 but still the same ...
swap RX and TX done too

Voltage (V):233
Current (A): 0
Power (W): 0
Energy (Wh):45

any help please ?
As you get voltage value, it means the module communicates with the ESP. But you don't get current, thus no power : Check your CT

aleph0
Normal user
Posts: 21
Joined: 08 Nov 2017, 09:28

Re: Support for PZEM 004T Energy monitor

#70 Post by aleph0 » 13 Jan 2018, 21:56

lolo wrote: 12 Jan 2018, 19:11 I am using the aleph0 system, working perfectly
Thanks :)

Post Reply

Who is online

Users browsing this forum: Bing [Bot] and 77 guests