Shoalhaven Water / Mbed OS Cloudtracker

Dependencies:   libmDot-mbed5 ISL29011

Revision:
46:f5b9b5cedae6
Parent:
45:0d541f98d058
Child:
47:2bc515eeaa18
--- a/examples/src/ota_example.cpp	Wed Nov 11 00:38:59 2020 +0000
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,271 +0,0 @@
-#include "dot_util.h"
-#include "RadioEvent.h"
-#include "InterruptIn.h"
-#include "Callback.h"
-
-#define CHANNEL_PLAN CP_AS923       // Uncomment for different Freq. plans.
-//#define CHANNEL_PLAN CP_AU915
-static float batMAx = 4.18;         // Change for different battery set up.
-static int uplinkInterval = 15;     // Value of MINUTES between transmissions
-static uint16_t locationID = 001;        // Change for different locations. (1 --> 65535)
-static float rawLatitude = -34.406000;      // Change for different location 
-static float rawLongitude = 150.880429;         // left here as a potential feature
-//// Update if different TTN application is used. ////
-static uint8_t network_id[] = { 0x70, 0xB3, 0xD5, 0x7E, 0xD0, 0x03, 0x3B, 0xB9 };
-static uint8_t network_key[] = { 0x12, 0x1A, 0x81, 0x8F, 0x10, 0x6B, 0x18, 0x67, 0x54, 0xE6, 0x9E, 0x70, 0x53, 0x7C, 0xAD, 0xCF };
-
-/////////////////////////////////////////////////////////////////////////////
-// -------------------- DOT LIBRARY REQUIRED ------------------------------//
-// * Because these example programs can be used for both mDot and xDot     //
-//     devices, the LoRa stack is not included. The libmDot library should //
-//     be imported if building for mDot devices. The libxDot library       //
-//     should be imported if building for xDot devices.                    //
-// * https://developer.mbed.org/teams/MultiTech/code/libmDot-dev-mbed5/    //
-// * https://developer.mbed.org/teams/MultiTech/code/libmDot-mbed5/        //
-// * https://developer.mbed.org/teams/MultiTech/code/libxDot-dev-mbed5/    //
-// * https://developer.mbed.org/teams/MultiTech/code/libxDot-mbed5/        //
-/////////////////////////////////////////////////////////////////////////////
-
-/////////////////////////////////////////////////////////////
-// * these options must match the settings on your gateway //
-// * edit their values to match your configuration         //
-// * frequency sub band is only relevant for the 915 bands //
-// * either the network name and passphrase can be used or //
-//     the network ID (8 bytes) and KEY (16 bytes)         //
-/////////////////////////////////////////////////////////////
-static std::string network_name = "MultiTech";
-static std::string network_passphrase = "MultiTech";
-static uint8_t frequency_sub_band = 0;
-static lora::NetworkType network_type = lora::PUBLIC_LORAWAN;
-static uint8_t join_delay = 5;
-static uint8_t ack = 0;
-static bool adr = true;
-
-// deepsleep consumes slightly less current than sleep
-// in sleep mode, IO state is maintained, RAM is retained, and application will resume after waking up
-// in deepsleep mode, IOs float, RAM is lost, and application will start from beginning after waking up
-// if deep_sleep == true, device will enter deepsleep mode
-static bool deep_sleep = false;
-I2C i2c(PC_9, PA_8 ); 
-
-mDot* dot = NULL;
-lora::ChannelPlan* plan = NULL;
-
-Serial pc(USBTX, USBRX);    
-
-// Initialize I2C
-const int addr7bit = 0x40;      // 7 bit I2C address
-const int addr8bit = addr7bit << 1; // 8bit I2C address, 0x80
-
-volatile int _count = 0;
-
-void incrementCounter(){
-    _count++;
-    wait_us(200000);    // delay for debouncing
-}
-void voidCounter(){
-    wait_us(200000);    // delay for debouncing
-}
-int readCounter(){
-    return _count;
-}
-void clearCounter(){
-    logInfo("Setting counter to 0");
-    _count = 0;
-}
-
-int main(){
-    AnalogIn bat(A0);       // Battery % analog input pin
-    DigitalIn tamp(PA_3);
-    
-    InterruptIn in(PA_11); 
-    in.fall(&incrementCounter);     // rise OR fall
-    in.rise(&voidCounter);
-    in.mode(PullUp);
-    __enable_irq();
-    
-    RadioEvent events;
-    
-    pc.baud(115200);
-    i2c.frequency(400000);
-    
-    mts::MTSLog::setLogLevel(mts::MTSLog::TRACE_LEVEL);
-    
-#if CHANNEL_PLAN == CP_AU915
-    plan = new lora::ChannelPlan_AU915();
-#elif CHANNEL_PLAN == CP_AS923
-    plan = new lora::ChannelPlan_AS923();
-#endif
-    assert(plan);
-
-    dot = mDot::getInstance(plan);
-    assert(dot);
-
-    // attach the custom events handler
-    dot->setEvents(&events);
-
-    if (!dot->getStandbyFlag() && !dot->getPreserveSession()) {
-        logInfo("mbed-os library version: %d.%d.%d", MBED_MAJOR_VERSION, MBED_MINOR_VERSION, MBED_PATCH_VERSION);
-
-        // start from a well-known state
-        logInfo("defaulting Dot configuration");
-        dot->resetConfig();
-        dot->resetNetworkSession();
-
-        // make sure library logging is turned on
-        dot->setLogLevel(mts::MTSLog::INFO_LEVEL);
-
-        // update configuration if necessary
-        if (dot->getJoinMode() != mDot::OTA) {
-            logInfo("changing network join mode to OTA");
-            if (dot->setJoinMode(mDot::OTA) != mDot::MDOT_OK) {
-                logError("failed to set network join mode to OTA");
-            }
-        }
-
-        // To preserve session over power-off or reset enable this flag
-        // dot->setPreserveSession(true);
-
-        update_ota_config_id_key(network_id, network_key, frequency_sub_band, network_type, ack);
-
-        // configure network link checks
-        // network link checks are a good alternative to requiring the gateway to ACK every packet and should allow a single gateway to handle more Dots
-        // check the link every count packets
-        // declare the Dot disconnected after threshold failed link checks
-        // for count = 3 and threshold = 5, the Dot will ask for a link check response every 5 packets and will consider the connection lost if it fails to receive 3 responses in a row
-        update_network_link_check_config(3, 5);
-
-        // enable or disable Adaptive Data Rate
-        dot->setAdr(adr);
-
-        // Configure the join delay
-        dot->setJoinDelay(join_delay);
-
-        // save changes to configuration
-        logInfo("saving configuration");
-        if (!dot->saveConfig()) {
-            logError("failed to save configuration");
-        }
-
-        // display configuration
-        display_config();
-    } else {
-        // restore the saved session if the dot woke from deepsleep mode
-        // useful to use with deepsleep because session info is otherwise lost when the dot enters deepsleep
-        logInfo("restoring network session from NVM");
-        dot->restoreNetworkSession();
-    }
-
-    while (true) {
-        uint16_t light;
-        uint16_t rain;
-        uint16_t temp;
-        uint16_t humid;
-        uint32_t lat;
-        uint32_t lon;
-        uint8_t tamper;
-        
-        char cmd[2];        // I2C command address byte 8-bit
-        char my_data[2];    // I2C return address bytes 16-bit
-        
-        std::vector<uint8_t> tx_data;
-
-        //  join network if not joined
-        if (!dot->getNetworkJoinStatus()) {
-            join_network();
-        }
-    
-        // Wake sensor /////////////////////////////////////////////////////////
-        cmd[0] = 0x01;
-        cmd[1] = 0x00;
-        i2c.write(addr8bit, cmd, 2);
-        
-        // Read TEMERATURE
-        cmd[0] = 0xE3;     // For 
-        i2c.write(addr8bit, cmd, 1);
-        i2c.read(addr8bit, my_data, 2);
-        wait_us(20000);       
-        
-        uint16_t amb = (my_data[0] << 8) | my_data[1];
-        float temperature = amb;
-        temperature *= 175.72;
-        temperature /= 65536;
-        temperature -= 46.85;
-        logInfo("Temp = %4.2f*C", temperature);
-        
-        wait_us(6000);
-        
-        // Read HUMIDITY
-        cmd[0] = 0xE5;     // For
-        i2c.write(addr8bit, cmd, 1);
-        i2c.read( addr8bit, my_data, 2);
-        wait_us(20000);       
-
-        uint16_t hum = (my_data[0] << 8) | my_data[1];
-        float humidity = hum;
-        humidity *= 125;
-        humidity /= 65536;
-        humidity -= 6;
-        if(humidity > 100.00){
-            humidity = 100.00;
-        }
-        logInfo("Humidity = %4.2f%", humidity);
-        
-        // Shutdown temp sensor
-        cmd[0] = 0x00;
-        cmd[1] = 0x00;
-        i2c.write(addr8bit, cmd, 2);
-        ////////////////////////////////////////////////////////////////////////
-        
-        float battery = bat.read();
-        battery = ((3*battery)*2) / batMAx * 100;   // Turn battery V to a %
-        logInfo("Battery = %f", battery);
-        if(battery > 100){
-            battery = 100;
-        }
-                    
-        // Send it to the Cloudtracker
-        rain = readCounter();   // Read the pulse count
-        tx_data.push_back((rain >> 8) & 0xFF);
-        tx_data.push_back(rain & 0xFF);
-        clearCounter();         // Set pulse count back to 0
-        
-        uint16_t battery_send = battery * 10;
-        tx_data.push_back((battery_send >> 8) & 0xFF);
-        tx_data.push_back(battery_send & 0xFF);
-        
-        humid = humidity * 10;  
-        tx_data.push_back((humid >> 8) & 0xFF);
-        tx_data.push_back(humid & 0xFF);
-        
-        temp = temperature * 10;
-        tx_data.push_back((temp >> 8) & 0xFF);
-        tx_data.push_back(temp & 0xFF);
-        
-        tamper = 0;
-        if(tamp == 0){
-            tamper = 1;
-        }
-        tx_data.push_back(tamper & 0xFF);
-        
-        tx_data.push_back((locationID >> 8) & 0xFF);
-        tx_data.push_back(locationID & 0xFF);
-        
-        // lat = (rawLatitude * 10000) + 900000;
-        // tx_data.push_back((lat >> 16) & 0xFF);
-        // tx_data.push_back((lat >> 8) & 0xFF);
-        // tx_data.push_back(lat & 0xFF);
-        
-        // lon = (rawLongitude * 10000) + 1800000;
-        // tx_data.push_back((lon >> 16) & 0xFF);
-        // tx_data.push_back((lon >> 8) & 0xFF);
-        // tx_data.push_back(lon & 0xFF);
-        
-        send_data(tx_data);
-        
-        // Send to sleep for desired time. 
-        ThisThread::sleep_for(uplinkInterval * 60000);  // seconds
-    }
-    
-    return 0;
-}