{"id":13779906,"url":"https://github.com/LowPowerLab/RFM69","last_synced_at":"2025-05-11T13:31:11.699Z","repository":{"id":9059739,"uuid":"10827890","full_name":"LowPowerLab/RFM69","owner":"LowPowerLab","description":"RFM69 library for RFM69W, RFM69HW, RFM69CW, RFM69HCW (semtech SX1231, SX1231H)","archived":false,"fork":false,"pushed_at":"2023-08-13T01:29:07.000Z","size":7839,"stargazers_count":772,"open_issues_count":15,"forks_count":381,"subscribers_count":111,"default_branch":"master","last_synced_at":"2024-08-03T18:14:29.049Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"C++","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/LowPowerLab.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"License.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2013-06-20T19:36:14.000Z","updated_at":"2024-08-03T18:14:29.050Z","dependencies_parsed_at":"2023-02-11T23:15:41.663Z","dependency_job_id":"d780fc7a-c8b9-47a5-8d20-de880dd2417f","html_url":"https://github.com/LowPowerLab/RFM69","commit_stats":null,"previous_names":[],"tags_count":16,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LowPowerLab%2FRFM69","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LowPowerLab%2FRFM69/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LowPowerLab%2FRFM69/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/LowPowerLab%2FRFM69/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/LowPowerLab","download_url":"https://codeload.github.com/LowPowerLab/RFM69/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":225056747,"owners_count":17414200,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-08-03T18:01:10.399Z","updated_at":"2025-05-11T13:31:11.664Z","avatar_url":"https://github.com/LowPowerLab.png","language":"C++","readme":"# RFM69 Library\n[![arduino-library-badge](https://www.ardu-badge.com/badge/RFM69_LowPowerLab.svg?)](https://www.ardu-badge.com/RFM69_LowPowerLab)\n[![Build Status](https://app.travis-ci.com/LowPowerLab/RFM69.svg)](https://app.travis-ci.com/LowPowerLab/RFM69)\n[![GitHub release](https://img.shields.io/github/release/LowPowerLab/RFM69.svg)](https://github.com/LowPowerLab/RFM69)\n[![GitHub issues](https://img.shields.io/github/issues/LowPowerLab/RFM69.svg)](https://github.com/LowPowerLab/RFM69/issues)\n[![GitHub pull requests](https://img.shields.io/github/issues-pr/LowPowerLab/RFM69.svg)](https://github.com/LowPowerLab/RFM69/pulls)\n[![license](https://img.shields.io/github/license/LowPowerLab/RFM69.svg)](https://github.com/LowPowerLab/RFM69/blob/master/LICENSE.txt)\n\nBy Felix Rusu, [LowPowerLab.com](http://LowPowerLab.com)\n\u003cbr/\u003e\nRFM69 library for RFM69W, RFM69HW, RFM69CW, RFM69HCW (semtech SX1231, SX1231H)\n\u003cbr/\u003e\nThe latest examples, new features and bug fixes are found in the [original repository](https://github.com/LowPowerLab/RFM69) of this library.\n\n## License\nGPL 3.0, please see the [License.txt](https://github.com/LowPowerLab/RFM69/blob/master/License.txt) file for details. Be sure to include the same license with any fork or redistribution of this library.\n\n## Features\n- easy to use API with a few simple functions for basic usage\n- 1023 possible nodes on 256 possible networks\n- 61 bytes max message length (limited to 61 to support AES hardware encryption)\n- customizable transmit power (32 levels) for low-power transmission control\n- sleep function for power saving\n- automatic ACKs with the `sendWithRetry()` function\n- hardware 128bit AES encryption\n- hardware preamble, synch recognition and CRC check\n- digital RSSI can be read at any time with `readRSSI()`\n- interrupt driven\n- tested on [all Moteinos \u0026 many custom boards designed by LowPowerLab](https://lowpowerlab.com/shop/moteino)\n- works with RFM69W, RFM69HW, RFM69CW, RFM69HCW, Semtech SX1231/SX1231H transceivers\n- promiscuous mode allows any node to listen to any packet on same network\n\n### Library Installation\n#### Arduino IDE\nCopy the content of this library in the `Arduino/libraries/RFM69` folder.\n\u003cbr /\u003e\nTo find your Arduino folder go to `File -\u003e Preferences` in the Arduino IDE.\n\u003cbr/\u003e\nSee [this tutorial](https://www.arduino.cc/en/Guide/Libraries) on Arduino libraries.\n\n#### PlatformIO\nSee [PlatformIO registry](https://registry.platformio.org/libraries/lowpowerlab/RFM69) for latest installation details.\n\n### Hardware \u0026 programming\nThe easiest way to get started is with the well documented and supported [Moteino](http://moteino.com) microcontroller platform which is [easily programmable](https://lowpowerlab.com/programming) from the Arduino IDE. This includes the [Moteino, MoteinoUSB \u0026 MoteinoMEGA](https://lowpowerlab.com/shop/Moteino). RFM69 transceivers were extensively tested on Moteinos for the purpose of building internet of things (IoT) devices that can be controlled wirelessly. This platform has matured over time and there is now a [dedicated page](https://lowpowerlab.com/gateway) where you can review how these devices can interact with each other via a RaspberryPi gateway interface. Here's a video overview:\u003cbr/\u003e\nhttps://www.youtube.com/watch?v=YUUZ6k0pBHg\n\u003cbr/\u003e\nhttps://www.youtube.com/watch?v=I9MNZQgqKHA\n\u003cbr/\u003e\nhttps://www.youtube.com/watch?v=F15dEqZ4pMM\n\n### Basic sample usage\n- The [Gateway](https://github.com/LowPowerLab/RFM69/blob/master/Examples/Gateway/Gateway.ino) example listens for incoming data from remote nodes and responds to any ACK requests\n- The [Node](https://github.com/LowPowerLab/RFM69/blob/master/Examples/Node/Node.ino) example is a loop that sends increasingly longer packets to the gateway and waits for an ACK each time\n- More examples are added from time to time, check all the [examples](https://github.com/LowPowerLab/RFM69/tree/master/Examples), visit the [LowPowerLab blog](http://lowpowerlab.com) for latest news and projects, and check out the [LowPowerLab forums](https://lowpowerlab.com/forum) for projects and discussion\n\n## Blog writeup\nSee the [library release blog post](http://lowpowerlab.com/blog/2013/06/20/rfm69-library/)\n\n## Why RFM69\n- I have spent a lot of time developing this library for RFM69W/CW/HW/HCW transceivers. I made it open source because I believe a lot of people can benefit from this new powerful transceiver. I hope others will also contribute and build on my work\n- I have long researched alternative transceivers for RFM12B which is still an excellent transceiver but it is much lower output power and has limited built in features which need to be implemented in firmware (PREAMBLE, SYNC, CRC, packet engine, encryption etc).\n- I wanted a transceiver that could still be very small, easy to use, and have the longer range that I needed\n- RFM69 comes in 2 variants: RFM69W/CW (13dBm, 45mA TX) and RFM69HW/HCW (20dBm, 130mA TX). They are not pin compatible. The RFM69HCW is generally recommended since it has the extra power when needed.\n\n## RFM69 range and antennas\n- I have tested open-air range on these transceivers in various combinations.\n- I am happy to say that a range of upwards of 400m can be achieved with the default settings provided in the library. Some users reported upwards of 500m by lowering the bitrate, and a forum user reported 1.5miles at 1.2Kbps: see [this forum post](http://lowpowerlab.com/forum/index.php/topic,112.msg288.html) and [this blog page](http://lowpowerlab.com/moteino/#antennas)\n- The caveat with these higher RF power units is that they need more DC power when they transmit. For battery powered motes, you will need to keep them powered down and only transmit periodically. Use the sleep() function to put the radios in low power mode and use the [LowPower](https://github.com/lowpowerlab/lowpower) library to power down your Moteino.\n- The RFM69 ATC feature enables keeping transmit power only at the required level to achieve the desired RSSI at the receiving end, see examples for usage\n","funding_links":[],"categories":["Libraries","C++"],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FLowPowerLab%2FRFM69","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FLowPowerLab%2FRFM69","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FLowPowerLab%2FRFM69/lists"}