Mdot control and communication for the exosonde
Dependencies: libmDot-mbed5 mbed
Diff: main.cpp
- Revision:
- 3:805c0c2f82d3
- Parent:
- 2:e7e272186bf2
- Child:
- 4:a241bf8f70bb
- Child:
- 6:f3407f58f521
diff -r e7e272186bf2 -r 805c0c2f82d3 main.cpp --- a/main.cpp Thu Aug 31 23:08:23 2017 +0000 +++ b/main.cpp Mon Sep 04 02:58:01 2017 +0000 @@ -3,6 +3,7 @@ #include <string> #include <vector> #include <algorithm> +#include "ChannelPlans.h" #define PARAMSNUM 10 #define PARAMLENGTH 15 @@ -10,18 +11,20 @@ char sonde_buffer[SONDEBUFFERLEN]; char parameters[PARAMSNUM][PARAMLENGTH]; +lora::ChannelPlan* plan = NULL; +mDot* dot = NULL; + static std::string config_network_name = "UQ_St_Lucia"; static std::string config_network_pass = "L0raStLucia"; static uint8_t config_frequency_sub_band = 7; int32_t ret; -mDot* dot; Serial device(USBTX, USBRX); //will need to change this to the appropriate pins once connected ot the exosonde Serial debugger(USBTX,USBRX); //update this depending on the desired readings' identifier characters -const char identifiers[PARAMSNUM] = {'a','b','c','d','e','f','g'}; +const char identifiers[PARAMSNUM] = {'a','b','c','d','e','f','g','h','i','j'}; void flushRXbuffer(Serial *serial){ while(serial -> readable()) serial -> getc(); } @@ -78,26 +81,32 @@ payload.push_back((uint8_t)identifiers[i]); payload.push_back((uint8_t)':'); while(parameters[i][j] != '\0'){ - payload.push_back(parameters[i][j]); + payload.push_back(parameters[i][j]); + j++; } if(i != PARAMSNUM-1){ payload.push_back((uint8_t)','); } } + payload.push_back((uint8_t)'\0'); + debugger.printf("made packet %s\r\n", payload); // join the network if not joined if (!dot->getNetworkJoinStatus()) { - debugger.printf("joining network\n"); + debugger.printf("joining network\r\n"); if ((ret = dot->joinNetwork()) != mDot::MDOT_OK) { - debugger.printf("\n---------\nJoin Failed, code: %s,\n---------\n",mDot::getReturnCodeString(ret).c_str()); + debugger.printf("\r\n---------\r\nJoin Failed, code: %s\r\n---------\r\n",mDot::getReturnCodeString(ret).c_str()); + } + else{ + debugger.printf("joined successfully\r\n"); } } if (dot->getNetworkJoinStatus()) { // send the data // ACKs are enabled by default, so we're expecting to get one back if ((ret = dot->send(payload)) != mDot::MDOT_OK) { - debugger.printf("\nFailed send, code: %s\n",mDot::getReturnCodeString(ret).c_str()); + debugger.printf("\r\nFailed send, code: %s\r\n",mDot::getReturnCodeString(ret).c_str()); } else { - debugger.printf("\ndata sent\n"); + debugger.printf("\r\n data sent\r\n"); } } @@ -105,39 +114,41 @@ void Loraconfig(void){ if ((ret = dot->setFrequencySubBand(config_frequency_sub_band)) != mDot::MDOT_OK) { - debugger.printf("Could not set FSB\n"); + debugger.printf("Could not set FSB\r\n"); } if ((ret = dot->setNetworkName(config_network_name)) != mDot::MDOT_OK) { - debugger.printf("Could not set network name\n"); + debugger.printf("Could not set network name\r\n"); } if ((ret = dot->setNetworkPassphrase(config_network_pass)) != mDot::MDOT_OK) { - debugger.printf("Could not set network passcode\n"); + debugger.printf("Could not set network passcode\r\n"); } // in the 915 (US) frequency band, spreading factors 7 - 10 are available - if ((ret = dot->setTxDataRate(mDot::SF_10)) != mDot::MDOT_OK) { - debugger.printf("Could not set spread factor\n"); + if ((ret = dot->setTxDataRate(mDot::SF_7)) != mDot::MDOT_OK) { + debugger.printf("Could not set spread factor\r\n"); } //set the number of retries for each sub band before giving up - if ((ret = dot->setJoinRetries(50)) != mDot::MDOT_OK) { - debugger.printf("Could not set retries\n"); + if ((ret = dot->setJoinRetries(100)) != mDot::MDOT_OK) { + debugger.printf("Could not set retries\r\n"); } // request receive confirmation of packets from the gateway if ((ret = dot->setAck(8)) != mDot::MDOT_OK) { - debugger.printf("Could not set ACK\n"); + debugger.printf("Could not set ACK\r\n"); } // set join mode - if ((ret = dot->setJoinMode(mDot::OTA)) != mDot::MDOT_OK) { - debugger.printf("Could not set join mode\n"); + if ((ret = dot->setJoinMode(mDot::AUTO_OTA)) != mDot::MDOT_OK) { + debugger.printf("Could not set join mode\r\n"); } } + int main() { // get an mDot handle - dot = mDot::getInstance(); + plan = new lora::ChannelPlan_AU915(); + dot = mDot::getInstance(plan); + assert(dot); Loraconfig(); while(1){ wait(0.5); getsondedata(&device, &debugger); - debugger.printf("sonde: %s\r\n",sonde_buffer); if(!checkforcomma(&debugger)){ setcommadelim(&device); continue;