ZigBee automatic feeder for fish based on the TI CC2530.
The purpose of the fish feeding project is:
- to monitor the battery so that a low battery is noticed immediately;
- to control the feeding time and therefore quantity through the smarthome system.
In this project I modified my automatic feeder (JUWEL Product nr. 89000). Other feeders can be modified instead, if they:
- have sufficent room for a custom PCB (4cm x 2.5cm);
- use one or two AA/AAA batteries as power supply;
- have accessible contacts for: voltage supply (Vcc and 0V), trigger on/off, trigger feeding-process and optional a status LED.
For the building process you will need:
- a custom PCB (bought or selfmade);
- the components listed in the BOM;
- Solder paste + hot air gun (for SMD), solder wire + solder station (for TH-wires);
- an automatic feeder which meets the requirements listed in Feeder requirements;
- a smarthome system with ZigBee support (and preferably the possibility to integrate own devices).
First have a look at the available space for an extra PCB in your feeder. Once you got measurements on how big the PCB can be, search for the following contacts:
- ON/OFF trigger (e.g. high side of the button)
- Feeder trigger (e.g. high side of the button)
- Optional: Negative pin of a LED we can pull to 0V for status indication You will have to solder a cable onto those, so be sure it is doable before ordering a PCB. If it is not, you will propably have to replace the default feeder PCB.
Note: The current feeder software pulls the trigger and the LED down to the 0V rail on activation. If you need a pull up to the 3.3V rail, the current PCB design has to be modified.
Important note: If your Feeder uses batteries with a combined voltage of more than 3.6 V you will have to use a voltage divider before Pin 0.7 of the CC2530 as it could otherwise destroy your chip. Please also note that the power supply used here is not be the best choice for input voltages > 3.3V. It is designed to step up and not to step down the battery voltage.
You can of course replace the default feeder circutry with your own. For my project I decided not to to that, as the default circuit already implements the motor control nicely. Also in the case of the JUWEL feeder there is enough space available. If you decide to replace the default circutry, it would be awesome if we could publish the gerber files in this project for others to use.
After validating, that the provided PCB is a good fit, or after designing your own PCB, it is time to order them. There are many options where to order: Local suppliers are usually good choice, but they aren't the cheapest when ordering low quantitys. For the EU multi-circuit-boards.eu or eurocircuits.com. If you like it cheap: jlcpcb.com or pcbway.com For ordering the components, find a local distributor or order at DigiKey, Mouser, Reichelt, etc. The Bill of material (BOM) of all required components can be found in the repository. As the official CC-Debugger is quite expensive, you can also order thrid party debuggers from amazon or ebay. I got an official and an unofficial CC-Debugger, both work without any problem.
Once you have received the boards and components, solder them to the board. Also connect the cables to the five through-hole contacts on the board and solder them to the correct contact of the feeder. The cable connections are shown in the next pictures, where the two rectangles of the same color are each connected by a cable. The green rectangle represents the hole where the antenna cable is attached. The length should be ~3.75cm for a 1/2 wavelength or ~1.87 cm for a 1/4 wavelength antenna.
Overview:
Backside of the feeder-pcb:
Backside of the zigbee-pcb:
Frontside of the zigbee-pcb:
Now connect the CC-Debugger with the 6-Pin-Connector, press the button on the debugger and check if the green led lights up. If it stays red, check the polarity of the connector and try again. If it still does not work, check your solder joints.
Once successfully connected, downlaod the .hex file from this project, open the TI Flash Programmer (not TI Flash Programmer 2 !) and select the .hex file. After flashing, you are ready to go.
The device is a battery powered ZigBee 3.0 Enddevice. All important ZigBee attributes of the device are shown in the following image or in the file Zigbee-Atrributes.txt in more detail.
I already implemented the device into Homey and Zigbee2MQTT, but an implementation into other open ZigBee-Coordinators is possible. You could also use this ZigBee-Device as "Basic ZigBee Device", but it is possible that not all the features work correctly.
To add your feeder to the zigbee2mqtt network, you need to define an external converter. To do this, you must upload the external converter to your zigbee2mqtt data folder and add two lines to your configuration.yaml. If you have installed zigbee2mqtt on a Linux system (e.g. a rapberry pi), follow the steps below. The steps are similar for other operating systems.
Option A: SSH
- Login to your zigbee2mqtt host system via SSH console.
- Navigate to the data folder:
cd /opt/zigbee2mqtt/data
- Create a blank file with the name "mhaid.js":
> mhaid.js
- Open the new file via nano:
nano mhaid.js
- Now copy the contents of the file "z2m_converter_feeder.js" into the editor window, save the changes
CTRL + O
and close the editorCTRL + X
. - Open the configuration file via nano:
nano configuration.yaml
- Append the following two lines:
external_converters:
- mhaid.js
Option B: FTP
- Rename the file "z2m_converter_feeder.js" to "mhaid.js"
- Login to your zigbee2mqtt host machine with your favorite ftp client.
- Navigate to the data folder of your zigbee2mqtt installation (for me that is /opt/zigbee2mqtt/data).
- Copy/Move the renamed file here.
- Open "configuration.yaml" in an editor of your choice.
- Append the following two lines:
external_converters:
- mhaid.js
Have fun with your new smart feeder!
Cheers, Morris