Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: DHT libmDot mbed-rtos mbed
Fork of mDot_Connect_IoTClub_one_wire_4ch_8_24 by
Diff: main.cpp
- Revision:
- 15:04b37f329c84
- Parent:
- 14:0616e4361f0c
--- a/main.cpp Wed Aug 24 11:52:28 2016 +0000
+++ b/main.cpp Thu Aug 25 12:58:12 2016 +0000
@@ -4,32 +4,25 @@
#include <string>
#include <vector>
#include <algorithm>
-#include "AnalogPH.h"
+
const char TURNON[] = "ON";
const char TURNOFF[] = "OFF";
-DigitalOut Alarm(PA_2);
+bool cmpStr(char* str1, const char* str2, int len)
+{
+ int k;
+ for (k=0; k<len; k++){
+ if (str1[k] != str2[k]) return false;
+ }
+ return true;
+}
+
+DigitalOut Alarm(PB_0);
//defined for mDot SVB debug, comment it if applying for whole system
//#define NO_MULTITECH_GATEWAY
-//Define the number of channels
-#define NUM_OF_CH 4
-
-AnalogPHSensor CH1_PH(PB_1, 0.0, 0.0);
-
-#if (NUM_OF_CH >1)
- AnalogPHSensor CH2_PH(PB_0, 0.0, 0.0);
-#endif
-
-#if (NUM_OF_CH >2)
- AnalogPHSensor CH3_PH(PA_5, 0.0, 0.0);
-#endif
-#if (NUM_OF_CH >3)
- AnalogPHSensor CH4_PH(PA_4, 0.0, 0.0);
-#endif
-
// these options must match the settings on your Conduit
// uncomment the following lines and edit their values to match your configuration
static std::string config_network_name = "chinaiot";
@@ -40,16 +33,17 @@
int32_t ret;
mDot* dot;
std::vector<uint8_t> sendData, recvData;
- float phValue;
- char _header[] = "PH Sensors";
- char sendBuf[11], recvBuf[11];
- int i, k;
+ std::vector<uint8_t> sendData1,sendData2, sendData3, sendData4;
+ char recvBuf[11];
int send_failed;
- bool alarm_on;
- const uint32_t baud = 1200;
+ int i;
+ //bool alarm_on;
+ std::string data_str1 = "REQ1";
+ std::string data_str2 = "REQ2";
+ std::string data_str3 = "REQ3";
+ std::string data_str4 = "REQ4";
+ bool a1, a2, a3, a4;
- int32_t setBaud(const uint32_t& baud);
- uint32_t getBaud();
// get a mDot handle
dot = mDot::getInstance();
@@ -64,7 +58,7 @@
dot->resetConfig();
dot->setLogLevel(mts::MTSLog::INFO_LEVEL);
-#ifndef NO_MULTITECH_GATEWAY
+
// set up the mDot with our network information: frequency sub band, network name, and network password
// these can all be saved in NVM so they don't need to be set every time - see mDot::saveConfig()
@@ -116,57 +110,63 @@
// in the 868 (EU) frequency band, we need to wait until another channel is available before transmitting again
osDelay(std::max((uint32_t)1000, (uint32_t)dot->getNextTxMs()));
}
+
+ // format data for sending to the gateway
+ for (std::string::iterator it = data_str1.begin(); it != data_str1.end(); it++)
+ sendData1.push_back((uint8_t) *it);
+
+ // format data for sending to the gateway
+ for (std::string::iterator it = data_str2.begin(); it != data_str2.end(); it++)
+ sendData2.push_back((uint8_t) *it);
+
+ // format data for sending to the gateway
+ for (std::string::iterator it = data_str3.begin(); it != data_str3.end(); it++)
+ sendData3.push_back((uint8_t) *it);
- sendData.clear();
// format data for sending to the gateway
- for( int i=0; i< strlen(_header); i++ )
- sendData.push_back( _header[i] );
-
- // send the data to the gateway
- if ((ret = dot->send(sendData)) != mDot::MDOT_OK) {
- logError("failed to send", ret, mDot::getReturnCodeString(ret).c_str());
- } else {
- logInfo("successfully sent data to gateway");
- }
-#else
- logInfo("%s", _header);
-#endif
- while (true) {
- send_failed = 0;
- alarm_on = false;
- // Read the PH values
- for(k=1; k<(NUM_OF_CH+1); k++){
- switch(k){
- case 1: phValue = CH1_PH; break;
- #if (NUM_OF_CH >1)
- case 2: phValue = CH2_PH; break;
- #endif
- #if (NUM_OF_CH >2)
- case 3: phValue = CH3_PH; break;
- #endif
- #if (NUM_OF_CH >3)
- case 4: phValue = CH4_PH; break;
- #endif
- default:
- break;
- }
- sprintf(sendBuf, "CH%d:%5.4f", k, phValue);
- logInfo("%s", sendBuf);
+ for (std::string::iterator it = data_str4.begin(); it != data_str4.end(); it++)
+ sendData4.push_back((uint8_t) *it);
+
+ send_failed = 0;
+ while (true) {
+ // send the data to the gateway
+ if ((ret = dot->send(sendData1)) != mDot::MDOT_OK) {
+ send_failed++;
+ logError("failed to send", ret, mDot::getReturnCodeString(ret).c_str());
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+ } else {
+ send_failed=0;
+ logInfo("successfully sent data to gateway");
+ for(i=0;i<11;i++)recvBuf[i]=0; //clear recv buffer
+ recvData.clear(); //clear recv data
+ if ((ret = dot->recv(recvData)) != mDot::MDOT_OK) {
+ logError("failed to recv: [%d][%s]", ret, mDot::getReturnCodeString(ret).c_str());
+ } else {
+ //logInfo("datasize = %d", recvData.size());
+ for(i=0; i< recvData.size(); i++ )
+ recvBuf[i] = recvData[i];
+ //logInfo("RECV:%s", recvBuf);
+ if(cmpStr(recvBuf, TURNON, 2)){
+ a1 = true;
+ logInfo("A1 is on!");
+ }
+ if(cmpStr(recvBuf, TURNOFF, 3)){
+ a1 = false;
+ logInfo("A1 is off!");
+ }
+ }
+ }
- #ifndef NO_MULTITECH_GATEWAY
- //Send the data to Gateway
- sendData.clear();
- // probably not the most efficent way to do this
- for( int i=0; i< strlen(sendBuf); i++ )
- sendData.push_back( sendBuf[i] );
-
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+
// send the data to the gateway
- if ((ret = dot->send(sendData)) != mDot::MDOT_OK) {
+ if ((ret = dot->send(sendData2)) != mDot::MDOT_OK) {
+ send_failed++;
logError("failed to send", ret, mDot::getReturnCodeString(ret).c_str());
- send_failed++;
osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
- } else {
- logInfo("successfully sent data to gateway");
+ } else {
+ send_failed=0;
+ logInfo("successfully sent data to gateway");
for(i=0;i<11;i++)recvBuf[i]=0; //clear recv buffer
recvData.clear(); //clear recv data
if ((ret = dot->recv(recvData)) != mDot::MDOT_OK) {
@@ -175,41 +175,104 @@
//logInfo("datasize = %d", recvData.size());
for(i=0; i< recvData.size(); i++ )
recvBuf[i] = recvData[i];
- logInfo("RECV:%s", recvBuf);
- if(0==strcmp(recvBuf, TURNON)) alarm_on = true;
+ //logInfo("RECV:%s", recvBuf);
+ if(cmpStr(recvBuf, TURNON, 2)){
+ a2 = true;
+ logInfo("A2 is on!");
+ }
+ if(cmpStr(recvBuf, TURNOFF, 3)){
+ a2 = false;
+ logInfo("A2 is off!");
+ }
+ }
+ }
+
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+
+ // send the data to the gateway
+ if ((ret = dot->send(sendData3)) != mDot::MDOT_OK) {
+ send_failed++;
+ logError("failed to send", ret, mDot::getReturnCodeString(ret).c_str());
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+ } else {
+ send_failed=0;
+ logInfo("successfully sent data to gateway");
+ for(i=0;i<11;i++)recvBuf[i]=0; //clear recv buffer
+ recvData.clear(); //clear recv data
+ if ((ret = dot->recv(recvData)) != mDot::MDOT_OK) {
+ logError("failed to recv: [%d][%s]", ret, mDot::getReturnCodeString(ret).c_str());
+ } else {
+ //logInfo("datasize = %d", recvData.size());
+ for(i=0; i< recvData.size(); i++ )
+ recvBuf[i] = recvData[i];
+ //logInfo("RECV:%s", recvBuf);
+ if(cmpStr(recvBuf, TURNON, 2)){
+ a3 = true;
+ logInfo("A3 is on!");
+ }
+ if(cmpStr(recvBuf, TURNOFF, 3)){
+ a3 = false;
+ logInfo("A3 is off!");
+ }
+ }
+ }
+
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+
+ // send the data to the gateway
+ if ((ret = dot->send(sendData4)) != mDot::MDOT_OK) {
+ send_failed++;
+ logError("failed to send", ret, mDot::getReturnCodeString(ret).c_str());
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+ } else {
+ send_failed=0;
+ logInfo("successfully sent data to gateway");
+ for(i=0;i<11;i++)recvBuf[i]=0; //clear recv buffer
+ recvData.clear(); //clear recv data
+ if ((ret = dot->recv(recvData)) != mDot::MDOT_OK) {
+ logError("failed to recv: [%d][%s]", ret, mDot::getReturnCodeString(ret).c_str());
+ } else {
+ //logInfo("datasize = %d", recvData.size());
+ for(i=0; i< recvData.size(); i++ )
+ recvBuf[i] = recvData[i];
+ //logInfo("RECV:%s", recvBuf);
+ if(cmpStr(recvBuf, TURNON, 2)){
+ a4 = true;
+ logInfo("A4 is on!");
+ }
+ if(cmpStr(recvBuf, TURNOFF, 3)){
+ a4 = false;
+ logInfo("A4 is off!");
+ }
}
}
osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
- #endif
- }
-
- //handle the alarm
- if(alarm_on){
- logInfo("Turn on the alarm");
- Alarm = 1;
- }else{
- logInfo("Turn off the alarm");
- Alarm = 0;
- }
+
+ if(a1 || a2 || a3 || a4){
+ logInfo("============================");
+ logInfo("Alarm is ON");
+ Alarm = 1;
+ }else{
+ logInfo("============================");
+ logInfo("Alarm is OFF");
+ Alarm = 0;
+ }
+
+ osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
+
if(send_failed>=3){
+ send_failed=0;
// attempt to rejoin the network
logInfo("Attemp to rejoin network....");
if ((ret = dot->joinNetworkOnce()) != mDot::MDOT_OK) {
logError("Failed to rejoin network!"); // %d:%s", ret, mDot::getReturnCodeString(ret).c_str());
}else{
- logInfo("Rejoin network successfully!");
+ logInfo("Rejoin network successfully!");
}
osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
}
- //printf("++++++++++++++++++++++\t");
- // in the 868 (EU) frequency band, we need to wait until another channel is available before transmitting again
- #ifndef NO_MULTITECH_GATEWAY
- osDelay(std::max((uint32_t)5000, (uint32_t)dot->getNextTxMs()));
- #else
- osDelay(1000);
- #endif
}
}
