Loom
|
Nordic Radio communication platform module. More...
#include <nRF.h>
Public Member Functions | |
CONSTRUCTORS / DESTRUCTOR | |
Loom_nRF (LoomManager *manager, const uint16_t max_message_len=120, const uint8_t address=0, const uint8_t data_rate=1, const uint8_t power_level=0, const uint8_t retry_count=3, const uint16_t retry_timeout=200, const uint8_t multicast_level=1) | |
nRF module constructor More... | |
Loom_nRF (LoomManager *manager, JsonArrayConst p) | |
Constructor that takes Json Array, extracts args and delegates to regular constructor. More... | |
~Loom_nRF () | |
Destructor. More... | |
OPERATION | |
void | add_config (JsonObject json) override |
Add configuration information to JsonObject. More... | |
PRINT INFORMATION | |
void | print_config () const override |
Display the configuration settings of the module. More... | |
GETTERS | |
uint8_t | get_address () const override |
Get the address of this device. More... | |
uint8_t | get_multicast_level () const |
Get multicast(broadcast) level. More... | |
SETTERS | |
void | set_address (const uint8_t addr) override |
Set the address of this device. More... | |
void | set_multicast_level (const uint8_t level) |
Set multicast(broadcast) level. More... | |
![]() | |
LoomCommPlat (LoomManager *manager, const char *module_name, const LoomModule::Type module_type, const uint16_t max_message_len) | |
Constructor. More... | |
virtual | ~LoomCommPlat ()=default |
Destructor. More... | |
virtual void | package (JsonObject json) override |
Package a modules measurements or state. More... | |
bool | receive_blocking (JsonObject json, uint max_wait_time) |
Receive, but block until packet received, or timeout reached. More... | |
bool | receive (JsonObject json) |
Build json from packet if any exists. More... | |
bool | receive_batch () |
Receive and immediately create a batch file from JSON receieved. More... | |
bool | receive_batch_blocking (uint max_wait_time) |
Receive, and block until packet recieved or timeout, and immediately create a batch file from JSON receieved. More... | |
bool | receive () |
Version of receive for use with LoomManager. More... | |
bool | receive_blocking (const uint max_wait_time) |
Version of receive_blocking for use with LoomManager. More... | |
JsonObject | pre_merge_receive_blocking (JsonObject json) |
Giving the header of the Package from the other board. More... | |
bool | merge_json (JsonObject json, const uint8_t loop) |
It will merge all the small packages into one big package. More... | |
bool | send (JsonObject json, const uint8_t destination) |
Send json to a specific address. More... | |
bool | send (const uint8_t destination) |
Version of send for use with LoomManager. More... | |
uint8_t | send_batch (const uint8_t destination, int delay_time) |
Sends all the jsons stored in the batch. More... | |
uint16_t | determine_json_size (JsonObject json) |
Return the size of the json to determing wether to send as split or not. More... | |
bool | split_send_notification (JsonObject json, const uint8_t destination) |
If the json is over 251, then it let the user the know that it will be sending small mulitple jsons with how many will it be splited into. More... | |
bool | split_send (JsonObject json, const uint8_t destination, const uint8_t index) |
The actual processing spliting into small json. More... | |
void | broadcast (JsonObject json) |
Broadcast data to all that can receive. More... | |
void | broadcast () |
Version of send for use with LoomManager. More... | |
void | broadcast_batch (int delay_time) |
Broadcasts all the jsons stored in the batch. More... | |
virtual void | print_state () const override |
Display current state of the module. More... | |
float | get_drop_rate () const |
Get the packet drop rate since the start of operation. More... | |
float | get_last_ten_drop_rate () const |
Get the packet drop rate of the last ten send() calls. More... | |
![]() | |
LoomModule (LoomManager *manager, const char *module_name="Unknown", const Type module_type=Type::Unknown) | |
Constructor. More... | |
virtual | ~LoomModule ()=default |
Destructor. More... | |
virtual void | second_stage_ctor () |
Second stage construction. More... | |
virtual bool | dispatch (JsonObject json) |
Route command to driver. More... | |
virtual void | power_down () |
Turn off any hardware. More... | |
virtual void | power_up () |
Turn on any hardware. More... | |
Type | get_module_type () const |
Get module type. More... | |
LoomManager * | get_device_manager () const |
Get the device manager class if linked. More... | |
void | get_module_name (char *buf) const |
Copy module name into buffer. More... | |
const char * | get_module_name () const |
Get module name. More... | |
Verbosity | get_print_verbosity () const |
Get print verbosity. More... | |
Verbosity | get_package_verbosity () const |
Get package verbosity. More... | |
bool | get_active () const |
Get whether or not the module should be treated as active. More... | |
Category | category () const |
Get the category of the module. More... | |
virtual void | link_device_manager (LoomManager *LM) |
Add pointer back to device manager. More... | |
void | set_print_verbosity (const Verbosity v) |
Set print verbosity Controlls level of detail included in debug prints. More... | |
void | set_package_verbosity (const Verbosity v) |
Set package verbosity. More... | |
void | set_active (const bool enable) |
Set whether or not the module should be treated as active. More... | |
Protected Member Functions | |
RADIO IMPLEMENTATION | |
bool | receive_blocking_impl (JsonObject json, uint max_wait_time) override |
Receive, but block until packet received, or timeout reached. More... | |
bool | send_impl (JsonObject json, const uint8_t destination) override |
Send json to a specific address. More... | |
void | broadcast_impl (JsonObject json) override |
Broadcast data to all that can receive. More... | |
![]() | |
bool | json_to_msgpack_buffer (JsonObjectConst json, char *buffer, const uint16_t max_len) const |
Serialize a JsonObject into a MessagePack buffer. More... | |
bool | msgpack_buffer_to_json (const char *buffer, JsonObject json) |
Deserialize a MessagePack buffer into a JsonObject. More... | |
void | add_packet_result (const bool did_drop) |
Add the result of a packet to the drop_rate tracker. More... | |
![]() | |
void | print_module_label () const |
Print the module name as a label. More... | |
Protected Attributes | |
RF24 | radio |
Underlying nRF24L01(+) radio object. More... | |
RF24Network * | network |
Network layer manager for radio. More... | |
uint8_t | address |
Device Address (should this be part of LoomCommPlat? – maybe not as each platform handles addresses differently) More... | |
uint8_t | data_rate |
Data rate. More... | |
uint8_t | power_level |
Power level to send at. More... | |
uint8_t | retry_count |
Number of transmission retries allowed. More... | |
uint16_t | retry_timeout |
Delay between transmission retries (in milliseconds) More... | |
uint8_t | multicast_level |
Which level(s) of the network to broadcast to. More... | |
![]() | |
uint16_t | max_message_len |
The maximum message length. More... | |
int16_t | signal_strength |
RSSI for Lora (need to determine what the other platforms use) More... | |
StaticJsonDocument< 1500 > | messageJson |
Document to read incoming data into. More... | |
DynamicJsonDocument | mergeJson |
uint32_t | total_packet_count |
uint32_t | total_drop_count |
bool | last_ten_dropped [10] |
uint8_t | last_ten_dropped_idx |
![]() | |
const Type | module_type |
Module type. More... | |
LoomManager * | device_manager |
Pointer to manager. More... | |
const String | module_name_base |
The name of the module (Should have a DEFAULT but can be overriden if provided to constructor) More... | |
const char * | module_name |
bool | active |
Whether or not the module should be treated as active. More... | |
Verbosity | print_verbosity |
Print verbosity. More... | |
Verbosity | package_verbosity |
Package verbosity. More... | |
Nordic Radio communication platform module.
Loom_nRF::Loom_nRF | ( | LoomManager * | manager, |
const uint16_t | max_message_len = 120 , |
||
const uint8_t | address = 0 , |
||
const uint8_t | data_rate = 1 , |
||
const uint8_t | power_level = 0 , |
||
const uint8_t | retry_count = 3 , |
||
const uint16_t | retry_timeout = 200 , |
||
const uint8_t | multicast_level = 1 |
||
) |
nRF module constructor
[in] | max_message_len | Set(Int) | <120> | {120("Max length")} | The maximum possible message length |
[in] | address | Int | <01> | [0-99] | This device's nRF address |
[in] | data_rate | Set(Int) | <0> | {0("Default"), 1("250KBPS"), 2("1MBPS"), 3("2MBPS")} | Transmission data rate |
[in] | power_level | Set(Int) | <0> | {0("Default"), 1("Min"), 2("Low"), 3("High"), 4("Max")} | Transmission ower level |
[in] | retry_count | Int | <3> | [0-15] | Max number of transmission retries |
[in] | retry_timeout | Int | <200> | [20-500] | Delay between retransmissions (ms) |
[in] | multicast_level | Int | <1> | [1-3] | How many levels to propogate message through heirarchy |
Loom_nRF::Loom_nRF | ( | LoomManager * | manager, |
JsonArrayConst | p | ||
) |
Constructor that takes Json Array, extracts args and delegates to regular constructor.
[in] | p | The array of constuctor args to expand |
Loom_nRF::~Loom_nRF | ( | ) |
Destructor.
|
overridevirtual |
Add configuration information to JsonObject.
LoomManager iterates over modules to build complete configuration
[in] | json | Json configuration object to add to |
Reimplemented from LoomModule.
|
overrideprotectedvirtual |
Broadcast data to all that can receive.
Derived classes can optionally provide an implementation for this, As supported by the radio/platform's library
[in] | json | Json object to send |
Reimplemented from LoomCommPlat.
|
inlineoverridevirtual |
Get the address of this device.
Each platform may have a different addressing scheme
Implements LoomCommPlat.
|
inline |
Get multicast(broadcast) level.
nRF has varying degrees of broadcast corresponding to depth to broadcast through network tree
|
overridevirtual |
Display the configuration settings of the module.
Reimplemented from LoomCommPlat.
|
overrideprotectedvirtual |
Receive, but block until packet received, or timeout reached.
[out] | json | Json object to fill with incoming data |
[in] | max_wait_time | Maximum number of milliseconds to block for (can be zero for non-blocking) |
Reimplemented from LoomCommPlat.
|
overrideprotectedvirtual |
Send json to a specific address.
[in] | json | Json package to send |
[in] | destination | Device to send to |
Reimplemented from LoomCommPlat.
|
overridevirtual |
Set the address of this device.
Each platform may have a different addressing scheme. Changing the device's address is not recommended.
[in] | a | The address to set this device to |
Implements LoomCommPlat.
|
inline |
Set multicast(broadcast) level.
nRF has varying degrees of broadcast corresponding to depth to broadcast through network tree
[in] | level | Multicast level to set to |
|
protected |
Device Address (should this be part of LoomCommPlat? – maybe not as each platform handles addresses differently)
|
protected |
Data rate.
|
protected |
Which level(s) of the network to broadcast to.
|
protected |
Network layer manager for radio.
|
protected |
Power level to send at.
|
protected |
Underlying nRF24L01(+) radio object.
|
protected |
Number of transmission retries allowed.
|
protected |
Delay between transmission retries (in milliseconds)