A simple LoRaWAN temperature sensor based on Multitech mDot module.
Dependencies: DS1820 libmDot mbed-rtos mbed
main.cpp
- Committer:
- SomeRandomBloke
- Date:
- 2015-09-03
- Revision:
- 1:45cec6aea002
- Parent:
- 0:5a0b43f3b143
- Child:
- 2:9db840d12557
File content as of revision 1:45cec6aea002:
/** mDot_display - Uses 160x128 SPI LCD display to show results of message * sending and receiving. * Uses MultiTech mDot developer board http://www.multitech.com/models/94558010LF * Requires a MultiTech MultiConnect Conduit http://www.multitech.com/models/94557203LF * * Example JSON received on Conduit: { "chan": 5, "codr": "4/5", "datr": "SF9BW125", "freq": "869.5", "lsnr": "8.8", "modu": "LORA", "rfch": 1, "rssi": -41, "seqn": 13, "size": 12, "timestamp": "2015-07-22T21:19:11Z", "tmst": 517590990, "payload": "{\"temperature\":21.3}", "eui": "00:80:00:00:00:00:9a:63", "_msg id": "73bcd8dd.8c4328" } * */ #include "mbed.h" #include "DS1820.h" #include "mDot.h" #include "MTSLog.h" #include "MTSText.h" #include <string> #include <vector> using namespace mts; // these options must match the settings on your Conduit in // /var/config/lora/lora-network-server.conf static std::string config_network_name = "ThingInnovations"; static std::string config_network_pass = "donkey123"; //static uint8_t config_frequency_sub_band = 1; // mDot/dev board activity LED //#define ACTIVITY_LED PA_0 // D13 #define DATA_PIN PA_5 // A0 //#define DATA_PIN PB_1 // must use the hardware SPI pins //SPI device(SPI_MOSI, SPI_MISO, SPI_SCK); // SPI device defines #define MDOT_MOSI PA_7 #define MDOT_MISO PA_6 #define MDOT_SCK PA_5 #define MDOT_TFT_CS PA_4 DS1820 probe(DATA_PIN); //void log_error(mDot* dot, const char* msg, int32_t retval); Serial pc(USBTX,USBRX); int main() { int32_t ret; mDot* dot; std::vector<uint8_t> send_data; std::vector<uint8_t> recv_data; // int32_t next_tx; // int32_t wait_time = 2; // uint8_t iterations = 99; // uint16_t txCount = 0; // uint16_t txFailCount = 0; // uint16_t rxCount = 0; // uint16_t rxOkCount = 0; // uint16_t noRxCount = 0; // uint16_t rxFailCount = 0; // bool initStatus = true; // All intialised OK until told otherwise float temperature = 0.0; pc.baud(115200); pc.printf("mDot LoRa Temperature sensor\n\r"); /* wait_ms(5000); for(int i=0; i<10; i++ ) pc.printf("."); pc.printf("\n\r"); */ /* while( 1 ) { // This takes upto 750mS, way too long. Change to 9 bit resolution if not already used. probe.convertTemperature(true, DS1820::all_devices); //Start temperature conversion, wait until ready // printf("It is %3.1fC\r\n", probe.temperature()); // Output data as JSON e.g. {"temperature":"21.3"} temperature = probe.temperature(); pc.printf("Temperature %3.1f\r\n", temperature ); wait_ms(2000); } #ifdef bollocks */ // get a mDot handle dot = mDot::getInstance(); dot->setLogLevel(MTSLog::TRACE_LEVEL); logInfo("Checking Config"); // Test if we've already saved the config std::string configNetworkName = dot->getNetworkName(); // Check pin, if low then reset config. if( config_network_name.compare(configNetworkName) != 0 ) { // Not saved config, reset logInfo("Setting Config"); // reset to default config so we know what state we're in dot->resetConfig(); // Set byte order - AEP less than 1.0.30 // dot->setJoinByteOrder(mDot::MSB); dot->setJoinByteOrder(mDot::LSB); logInfo("setting Join mode"); if ((ret = dot->setJoinMode(mDot::AUTO_OTA)) != mDot::MDOT_OK) { logError("failed to set Join Mode %d:%s", ret, mDot::getReturnCodeString(ret).c_str()); } // If on developer board then you can enable activity LED // Currently no spare pins that LEDs are connected too. // dot->setActivityLedPin( ACTIVITY_LED ); // dot->setActivityLedEnable(false); dot->setJoinRetries( 5 ); dot->setTxDataRate( mDot::SF_9 ); dot->setTxPower( 14 ); dot->setAck( 0 ); // 1 retries on Ack, 0 to disable // Not applicable for 868MHz in EU // if ((ret = dot->setFrequencySubBand(config_frequency_sub_band)) != mDot::MDOT_OK) { // initStatus = false; // logError(dot, "failed to set frequency sub band", ret); // } if ((ret = dot->setNetworkName(config_network_name)) != mDot::MDOT_OK) { // initStatus = false; logError("failed to set network name %d:%s", ret, mDot::getReturnCodeString(ret).c_str()); } if ((ret = dot->setNetworkPassphrase(config_network_pass)) != mDot::MDOT_OK) { // initStatus = false; logError("failed to set network password %d:%s", ret, mDot::getReturnCodeString(ret).c_str()); } logInfo("Saving Config"); // Save config if (! dot->saveConfig()) { logError("failed to save configuration"); } } else { logInfo("Using existing Config"); } // wait_ms(2000); // Display protocol/connection info while ((ret = dot->joinNetwork()) != mDot::MDOT_OK) { logError("failed to join network [%d][%s]", ret, mDot::getReturnCodeString(ret).c_str()); //wait(2); wait_ms(dot->getNextTxMs() + 1); } probe.setResolution(9); char dataBuf[50]; // for (uint8_t i = 0; i < iterations; i++) { while( 1 ) { // This takes upto 750mS, way too long. Change to 9 bit resolution if not already used. probe.convertTemperature(true, DS1820::all_devices); //Start temperature conversion, wait until ready // printf("It is %3.1fC\r\n", probe.temperature()); // Output data as JSON e.g. {"temperature":"21.3"} temperature = probe.temperature(); sprintf(dataBuf, "{\"tmp\":%3.1f}", temperature ); send_data.clear(); // probably not the most efficent way to do this for( int i=0; i< strlen(dataBuf); i++ ) send_data.push_back( dataBuf[i] ); if ((ret = dot->send(send_data)) != mDot::MDOT_OK) { logError("failed to send: [%d][%s]", ret, mDot::getReturnCodeString(ret).c_str()); } else { logInfo("send data: %s", Text::bin2hexString(send_data).c_str()); } // Should sleep here and wakeup after a set interval. uint32_t sleep_time = 60; //(dot->getNextTxMs() / 1000) + 10; logInfo("going to sleep..."); // go to sleep and wake up automatically sleep_time seconds later dot->sleep(sleep_time, mDot::RTC_ALARM, false); /* next_tx = dot->getNextTxMs() + 1; logInfo("waiting %ld ms to transmit again", next_tx); wait_ms(next_tx); logInfo("waiting another %d seconds", wait_time); wait(wait_time); */ } //#endif return 0; } /* void log_error(mDot* dot, const char* msg, int32_t retval) { printf("%s - %ld:%s, %s\r\n", msg, retval, mDot::getReturnCodeString(retval).c_str(), dot->getLastError().c_str()); } */