Receive data from your GreenEye Monitor in Python.
This module provides a layered API for parsing individual packets (greeneye.packets), processing streams of packets (greeneye.streams), or monitoring the current state reported by one or more monitors (greeneye.monitor). It's an API intended to be integrated with other systems; it does not itself provide those integrations or any sort of data storage. If you're looking for something like that, check out btmon.py.
Features include: * Parsing for all binary packet formats * Receive data from multiple monitors * Computes rate-of-change (Watts, pulses/sec) in addition to reporting total values
See dump_packets.py for a simple usage example.
Your GEM must be set to send binary format packets (formats that begin with Bin, e.g. Bin32 NET) to the IP address of the computer on which you're running this software. Your GEM configuration manual is the canonical source for how to do this, but here are the steps as of this writing:
- Navigate to your GEM's web UI (http://<GEM IP>:8000)
- Click "Enter Setup Mode"
- Click the "Packet Send" tab
- Set the "Primary (Com1) Packet Format" to one of the "Bin" formats. I recommend:
- Bin32 ABS if you have a 32-channel GEM with no channels set for net metering
- Bin32 NET if you have a 32-channel GEM and some channels are set for net metering
- Bin48 ABS if you have a 48-channel GEM with no channels set for net metering
- Bin48 NET if you have a 48-channel GEM and some channels are set for net metering
- Set the "Packet Send Interval" if you want something other than the default
- Click "Save"
- Click the "Network" tab
- Enter the IP address of the computer on which you'll be running this software, and the port of your choice
- Click "Save"
- Click "Return" when it becomes available
- Click "Exit Setup Mode"