Over Serial Configuration - Sketch 2.8: Difference between revisions

From lechacal
Jump to navigation Jump to search
 
(One intermediate revision by the same user not shown)
Line 3: Line 3:


This page covers version '''2.8.x''' of the sketch.. See appropriate documentation for other version.<br>
This page covers version '''2.8.x''' of the sketch.. See appropriate documentation for other version.<br>
'''Version 2.8.0 is under testing status at present time.'''


RPICT board using Atmega microcontrollers can be configured over serial using a utility written in python. This involves boards RPICT7V1 RPICT4V3 version 2 and RPICT8.
RPICT board using Atmega microcontrollers can be configured over serial using a utility written in python. This involves boards RPICT7V1 RPICT4V3 version 2 and RPICT8.
Line 169: Line 168:




'''nodeid''' Only used in emoncms format. Will set the node id.
'''nodeid''' Will set the node id.


'''polling''' Number of milliseconds between each data to be sent to the raspberrypi.
'''polling''' Number of milliseconds between each data to be sent to the raspberrypi.
Line 179: Line 178:
'''phasecal''' Phase Calibration value times 100 (*100). Adjust the phase between Voltage and Current. Typically set to 120.
'''phasecal''' Phase Calibration value times 100 (*100). Adjust the phase between Voltage and Current. Typically set to 120.


'''vest''' Voltage to compute estimated power. Usually 240V or 110V. Only applies for channel type number 5 (estimated power). Must be present even is not used. Set vest=1 to obtain output as ampere instead of watts. Set vest=1000 to get milliampere.  <small>Former sketches were computing real power only if this parameter was set to 0. This is no longer the case here.</small>
'''vest''' Voltage to compute estimated power. Usually 240V or 110V. Only applies for channel type number 5 (estimated power). Must be present even if not used. Set vest=1 to obtain output as ampere instead of watts. Set vest=1000 to get milliampere.  <small>Former sketches were computing real power only if this parameter was set to 0. This is no longer the case here.</small>


'''Nnode''' Number of Current/Voltage pair to compute.
'''Nnode''' Number of Current/Voltage pair to compute.

Latest revision as of 21:28, 1 February 2019

Overview

This page covers version 2.8.x of the sketch.. See appropriate documentation for other version.

RPICT board using Atmega microcontrollers can be configured over serial using a utility written in python. This involves boards RPICT7V1 RPICT4V3 version 2 and RPICT8.

Current version allows changes of

  • Output format (csv or Emonhub)
  • Nodeid (for Emonhub format)
  • Polling (polling interval of data)
  • Ical (current calibration value)
  • Vcal (Voltage calibration value)
  • Phasecal
  • Vest (estimated voltage for power estimate)


What's new

Version 2.8 brings the following improvements.

  • Higher accuracy using much more efficient communications with the ADC.
  • Phasecal can now be configured over serial.
  • Dropped the Vest=0 for using estimated power. This is now done by setting a Voltage pin to 127 to indicate that Vest should be used instead of physical voltage sensor.
  • Fixed bug with PowerFactor that output negative numbers.

Limitations

Maximum Channels

Sketch 2.8 allows up to 28 calculation nodes to be computed and 64 output channels. A calculation node being a CT/Voltage pair that provides Irms, Vrms, RealPower etc.
To compute up to 40 calculation nodes use the noOSC sketch. noOSC Sketch v1.1
The sketcch will have to be edited to your needs and uploaded to the arduino microcontroller.

Minimum Polling

Take into consideration that each reading of Current/Voltage pair take approximately 0.2 seconds to complete. Therefore it makes sense not to poll data more often that it can complete a full scan cycle. Hence we should respect

polling < 0.2 * Nnode

Nnode is the Number of CV pairs.

Preliminaries

python serial should be install for the utility to run.

$ sudo apt-get install python-serial

RPICT Configuration tool

The configuration tool can be downloaded directly from the raspberrypi:

$ wget lechacal.com/RPICT/tools/lcl-rpict-config.py.zip
$ unzip lcl-rpict-config.py.zip

Reading current configuration

Using the configurator without option only read the configuration stored in the board.

$ ./lcl-rpict-config.py

This yields

# RPICT Configuration Utility
# Read only
# Now reset RPICT hardware

Once the board has received the reset the configuration will be shown.How to reset the board.

# 
# Structure: 0xb3
# Format: 3
# NodeId: 11
# Polling: 5000
# KCAL:   1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  560.  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311
# PHASECAL: 120
# VEST: 0.000000
# Nnode: 7
# Nchan: 15


Note. Every time the configuration is read from the board it stores a config file in /tmp/rpict.config.

Modify the configuration

To change the values the configurator must be fed with a file containing the new values. We will use the example of a RPICT7V1. Such file looks as below.

[main]
format = 3
nodeid = 11
polling = 5000
kcal = 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 561.6 83.33 83.33 83.33 83.33 83.33 83.33 83.33
phasecal = 120
vest = 0
Nnode = 7
Nchan = 15
HWSCT = 8 7 6 5 4 3 2 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWMCPSCT = 10 10 10 10 10 10 10 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWVOL = 1 1 1 1 1 1 1 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWMCPVOL = 10 10 10 10 10 10 10 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
CHTYPE = 1 1 1 1 1 1 1 4 4 4 4 4 4 4 3 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
CHID = 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255


Online configurator. To help you generating the file above there is an online form available.


We save this in a file called for example rpict7v1.conf. Then we can now start the configurator with the -w option.

$ ./lcl-rpict-config.py -w rpict7v1.conf

Once reset the configurator will read the old config then write the new config and display the newly stored one again.

# RPICT Configuration Utility
# Configuration will be overwritten (Ctrl C to cancel)
# Now reset RPICT hardware
# 
# Configuration in memory:
# 
# Structure: 0xb3
# Format: 3
# NodeId: 11
# Polling: 5000
# KCAL:   1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  561.599975586  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311
# PHASECAL: 120
# VEST: 0.000000
# Nnode: 7
# Nchan: 15
# Complete configuration in /tmp/rpict.conf
# 
# Writing configuration with file B3/rpict7v1.conf
# 
# Configuration in memory:
# 
# Structure: 0xb3
# Format: 3
# NodeId: 11
# Polling: 5000
# KCAL:   1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  1.0  561.599975586  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311  83.3300018311
# PHASECAL: 120
# VEST: 240.000000
# Nnode: 7
# Nchan: 15
# Complete configuration in /tmp/rpict.conf
#

The configuration file

The configuration file fed in the utility must have the format below:

[main]
format = 3
nodeid = 11
polling = 5000
kcal = 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 561.6 83.33 83.33 83.33 83.33 83.33 83.33 83.33
phasecal = 120
vest = 240.
Nnode = 7
Nchan = 15
HWSCT = 8 7 6 5 4 3 2 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWMCPSCT = 10 10 10 10 10 10 10 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWVOL = 1 1 1 1 1 1 1 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
HWMCPVOL = 10 10 10 10 10 10 10 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
CHTYPE = 1 1 1 1 1 1 1 4 4 4 4 4 4 4 3 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255
CHID = 0 1 2 3 4 5 6 0 1 2 3 4 5 6 0 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255 255


format indicate which format output will be used. Must be an integer number.
0 - CSV
1 - Emoncms
2 - Emoncms as float (must have datatype f setup in emonhub config)
3 - Emonhub (recommended over options 1 or 2)


nodeid Will set the node id.

polling Number of milliseconds between each data to be sent to the raspberrypi.

kcal Current or Voltage calibration coefficient. Formerly Ical or Vcal. Must be contain 5 times 8 values. The first 8 values are for slave1. The second 8 values are for slave2 etc. The last 8 values are for the master board. Each values inside a block of 8 must be in the same order as in Table 1 below. The example above shows for a rpict7v1 vcal=545 then all ical=83.33.

phasecal Phase Calibration value times 100 (*100). Adjust the phase between Voltage and Current. Typically set to 120.

vest Voltage to compute estimated power. Usually 240V or 110V. Only applies for channel type number 5 (estimated power). Must be present even if not used. Set vest=1 to obtain output as ampere instead of watts. Set vest=1000 to get milliampere. Former sketches were computing real power only if this parameter was set to 0. This is no longer the case here.

Nnode Number of Current/Voltage pair to compute.

Nchan Number of channels (or fields) to output.

HWSCT Pin configuration of a current input. Only first Nnode are relevant.

HWMCPSCT Master or slave identifier for current input. Only first Nnode are relevant.

HWVOL Pin configuration of a voltage input. Only first Nnode are relevant.

HWMCPVOL Master or slave identifier for voltage input. Only first Nnode are relevant.

CHTYPE Type of channel to output. See table below.

CHID Identified from which combination node defined with HWSCT the channel should be output. 0 being the first node.

The 255 in the configuration file are just place holders.

Current/Voltage pairs (formerly called Combination nodes)

Current/Voltage pairs are small programs in the microcontroller that computes power given a current/voltage couple.

Four given parameters must be provided. They are the pin numbers where to find the current and voltage and also which slave (or master) is to be used.

For example if

HWSCT = 8 
HWMCPSCT = 6 
HWVOL = 1 
HWMCPVOL = 10

will use current ct1 (8) on slave 1 (6) computed against voltage1 (1) on master board (10).

The tables below gives all pin assignment:

Table 1: current_pin voltage_pin
Pin number
HWSCT/HWVOL
RPICT7V1 RPICT8 RPICT4V3
1 V1 CT8 V3
2 CT7 CT7 V2
3 CT6 CT6 V1
4 CT5 CT5 nc
5 CT4 CT4 CT4
6 CT3 CT3 CT3
7 CT2 CT2 CT2
8 CT1 CT1 CT1
127 Vest Vest Vest
    • Vest is estimated Voltage. If the pin is set to 127 the CV pair will compute only against Vest and not measured Voltage.


Table 2: slave master pins
Pin number
HWMCPSCT/HWMCPVOL
Board type
10 Master
6 Slave 1
7 Slave 2
8 Slave 3
9 Slave 4

Channels

We are refering as a channel here a data stream to be sent out. For example Vrms and Realpower derived from a same sensor will be two different channels.

These are configured with two numbers. The first one is the CV pair id defined above. Note the first combination id is zero (0). The second number identifies the type of channel. For example:

CHTYPE = 3 
CHID = 0

Uses voltage/current CV pair id 0. Channel type 3 which is Vrms (as the table below describes).


The table below shows the convention being used:

code Channel Type Description
0 None
1 Real Power Real Power in Watts
2 Apparent Power Apparent Power in Watts. This is Irms*Vrms
3 Vrms Rms Voltage in Volts
4 Irms Rms current in milliAmps
5 Estimated Power Estimated Power in Watts. This is Irms*Vest.
6 Power Factor Power Factor (no units). This is RealPower/ApparentPower.
7 Temperature Temperature (Celsius). Only for RPIZCT.

Restore Default Config

If things go wrong it is possible to reinstate default configuration as shown below.

RPICT7V1

$ wget lechacal.com/RPICT/config/B3/rpict7v1.conf
$ ./lcl-rpict-config.py -w rpict7v1.conf

RPICT8

$ wget lechacal.com/RPICT/config/B3/rpict8.conf
$ ./lcl-rpict-config.py -w rpict8.conf

RPICT4V3

$ wget lechacal.com/RPICT/config/B3/rpict4v3.conf
$ ./lcl-rpict-config.py -w rpict4v3.conf

Some stacked configuration

RPICT7V1 + RPICT8

A very common setup stacking one RPICT7V1 as master with one RPICT8 as slave. Offering one voltage to compute against 15 CT. Config given for the 100A rating. Output is

  • Voltage RMS
  • Real Power 1 to 7 master
  • Real Power 1 to 8 slave
$ wget lechacal.com/RPICT/config/B3/stack_ct7v1_ct8.conf
$ ./lcl-rpict-config.py -w stack_ct7v1_ct8.conf

How to reset the board

Use a small jumper to link the reset pin with the ground. This can be found on the 6x2 pins ISP connector. This is the stacking connector at the top. The two most left pins are the one to connect together (see picture).

Make contact with the two pins then remove the jumper. This will reset the board. Do not keep the pins connected. Just make a very brief contact.