St-connect
Dependencies: HP206C mbed WakeUp QMC5883L DHT22 DS1820
- ST Conect Project Look how we did it : [Hackster](https://www.hackster.io/monginjulien/st-connect-dike-monitoring-534a32)
main.cpp@8:c4801ce16934, 2018-11-12 (annotated)
- Committer:
- raminou
- Date:
- Mon Nov 12 10:24:45 2018 +0000
- Revision:
- 8:c4801ce16934
- Parent:
- 7:036d9a2accff
- Child:
- 9:2f31939caaf2
sigfox sleep tested OK
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
raminou | 0:1c266599e07b | 1 | #include "mbed.h" |
raminou | 0:1c266599e07b | 2 | #include "WakeUp.h" |
raminou | 0:1c266599e07b | 3 | #include "DHT22.h" |
raminou | 0:1c266599e07b | 4 | #include "HP20x_dev.h" |
raminou | 5:d805b1c2dc1e | 5 | #include "DS1820.h" |
raminou | 5:d805b1c2dc1e | 6 | #include "QMC5883L.h" |
raminou | 8:c4801ce16934 | 7 | |
raminou | 7:036d9a2accff | 8 | #define ENABLE_BAROMETER 1 |
raminou | 7:036d9a2accff | 9 | #define ENABLE_MAGNETOMETER 1 |
raminou | 7:036d9a2accff | 10 | #define ENABLE_GROUND_TEMPERATURE 1 |
raminou | 7:036d9a2accff | 11 | #define ENABLE_GROUND_HUMIDITY 1 |
raminou | 7:036d9a2accff | 12 | #define ENABLE_DHT22 1 |
raminou | 8:c4801ce16934 | 13 | |
raminou | 6:865aa63f2106 | 14 | #define MESSAGE_SIZE 32 |
raminou | 6:865aa63f2106 | 15 | #define TRAME_SIZE 25 |
raminou | 5:d805b1c2dc1e | 16 | |
raminou | 7:036d9a2accff | 17 | #define DEBUG |
raminou | 8:c4801ce16934 | 18 | #define SEND_SIGFOX 1 |
raminou | 0:1c266599e07b | 19 | |
raminou | 0:1c266599e07b | 20 | #ifdef DEBUG |
raminou | 0:1c266599e07b | 21 | Serial pc(USBTX, USBRX); |
raminou | 0:1c266599e07b | 22 | #endif |
raminou | 0:1c266599e07b | 23 | |
raminou | 7:036d9a2accff | 24 | #ifdef ENABLE_BAROMETER |
raminou | 7:036d9a2accff | 25 | HP20x_dev capt_barometer(D4, D5); |
raminou | 7:036d9a2accff | 26 | #endif |
raminou | 7:036d9a2accff | 27 | |
raminou | 7:036d9a2accff | 28 | #ifdef ENABLE_MAGNETOMETER |
raminou | 7:036d9a2accff | 29 | QMC5883L capt_magnetometer(D4, D5); |
raminou | 7:036d9a2accff | 30 | #endif |
raminou | 7:036d9a2accff | 31 | |
raminou | 7:036d9a2accff | 32 | #ifdef ENABLE_GROUND_TEMPERATURE |
raminou | 7:036d9a2accff | 33 | DS1820 capt_ground_temperature(A1); |
raminou | 7:036d9a2accff | 34 | #endif |
raminou | 7:036d9a2accff | 35 | |
raminou | 7:036d9a2accff | 36 | #ifdef ENABLE_GROUND_HUMIDITY |
raminou | 7:036d9a2accff | 37 | AnalogIn capt_ground_humidity(A0); // SEN0 |
raminou | 7:036d9a2accff | 38 | #endif |
raminou | 7:036d9a2accff | 39 | |
raminou | 7:036d9a2accff | 40 | #ifdef ENABLE_DHT22 |
raminou | 7:036d9a2accff | 41 | DHT22 capt_thermo_air_humidity(D3); // DHT22 |
raminou | 7:036d9a2accff | 42 | #endif |
raminou | 7:036d9a2accff | 43 | |
raminou | 0:1c266599e07b | 44 | Serial sigfox(D1, D0); |
raminou | 8:c4801ce16934 | 45 | DigitalInOut reset_sigfox(D9); |
raminou | 0:1c266599e07b | 46 | |
raminou | 6:865aa63f2106 | 47 | char message[MESSAGE_SIZE] = "AT$SF="; |
raminou | 0:1c266599e07b | 48 | |
raminou | 5:d805b1c2dc1e | 49 | long pressure = 10000; |
raminou | 5:d805b1c2dc1e | 50 | float air_temperature = 20.0; |
raminou | 5:d805b1c2dc1e | 51 | float air_humidity = 50.0; |
raminou | 5:d805b1c2dc1e | 52 | float ground_temperature = 20.0; |
raminou | 5:d805b1c2dc1e | 53 | float ground_humidity = 0.5; |
raminou | 5:d805b1c2dc1e | 54 | int16_t magnetic_field[3] = {}; // x, y, z |
raminou | 0:1c266599e07b | 55 | |
raminou | 0:1c266599e07b | 56 | void mycallback() |
raminou | 0:1c266599e07b | 57 | { |
raminou | 0:1c266599e07b | 58 | } |
raminou | 0:1c266599e07b | 59 | |
raminou | 6:865aa63f2106 | 60 | int16_t round(float f) |
raminou | 6:865aa63f2106 | 61 | { |
raminou | 6:865aa63f2106 | 62 | int16_t res = (int16_t)f; |
raminou | 6:865aa63f2106 | 63 | if (f - res > 1/2) |
raminou | 6:865aa63f2106 | 64 | res++; |
raminou | 6:865aa63f2106 | 65 | |
raminou | 6:865aa63f2106 | 66 | return res; |
raminou | 6:865aa63f2106 | 67 | } |
raminou | 6:865aa63f2106 | 68 | |
raminou | 6:865aa63f2106 | 69 | void format(float v_ground_temperature, float v_air_temperature, float v_ground_humidity, float v_air_humidity, long v_pressure, int16_t* v_magnetic_field, char* v_trame) |
raminou | 6:865aa63f2106 | 70 | { |
raminou | 6:865aa63f2106 | 71 | int16_t i_ground_temperature = (int16_t) round(v_ground_temperature * 10); |
raminou | 6:865aa63f2106 | 72 | int16_t i_air_temperature = (int16_t) round(v_air_temperature * 10); |
raminou | 6:865aa63f2106 | 73 | int16_t i_ground_humidity = (int16_t) round(v_ground_humidity); |
raminou | 6:865aa63f2106 | 74 | int16_t i_air_humidity = (int16_t) round(v_air_humidity); |
raminou | 6:865aa63f2106 | 75 | int32_t i_pressure = (int32_t) v_pressure; |
raminou | 6:865aa63f2106 | 76 | bool err[3] = {false, false, false}; // x,y,z |
raminou | 6:865aa63f2106 | 77 | |
raminou | 6:865aa63f2106 | 78 | // Checking if the values are in the range |
raminou | 6:865aa63f2106 | 79 | if(!(i_ground_temperature >= -512 && i_ground_temperature < 511)) |
raminou | 6:865aa63f2106 | 80 | i_ground_temperature = -512; |
raminou | 6:865aa63f2106 | 81 | |
raminou | 6:865aa63f2106 | 82 | if(!(i_air_temperature >= -512 && i_air_temperature < 511)) |
raminou | 6:865aa63f2106 | 83 | i_air_temperature = -512; |
raminou | 6:865aa63f2106 | 84 | |
raminou | 6:865aa63f2106 | 85 | if(!(i_ground_humidity <= 100)) |
raminou | 6:865aa63f2106 | 86 | i_ground_humidity = 127; |
raminou | 6:865aa63f2106 | 87 | |
raminou | 6:865aa63f2106 | 88 | if(!(i_air_humidity <= 100)) |
raminou | 6:865aa63f2106 | 89 | i_air_humidity = 127; |
raminou | 6:865aa63f2106 | 90 | |
raminou | 6:865aa63f2106 | 91 | if(!(i_pressure <= 131071)) |
raminou | 6:865aa63f2106 | 92 | i_pressure = 0; |
raminou | 6:865aa63f2106 | 93 | |
raminou | 6:865aa63f2106 | 94 | unsigned int i; |
raminou | 6:865aa63f2106 | 95 | for(i = 0; i < 3; i++) |
raminou | 6:865aa63f2106 | 96 | { |
raminou | 6:865aa63f2106 | 97 | if(!(v_magnetic_field[i] > -65536 && v_magnetic_field[i] < 65535)) |
raminou | 6:865aa63f2106 | 98 | err[i] = true; |
raminou | 6:865aa63f2106 | 99 | } |
raminou | 6:865aa63f2106 | 100 | |
raminou | 6:865aa63f2106 | 101 | snprintf(v_trame, TRAME_SIZE, "%02x", (char)(i_ground_temperature >> 2)); |
raminou | 6:865aa63f2106 | 102 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((i_ground_temperature << 6) | ((i_air_temperature >> 4) & 0x3f))); |
raminou | 6:865aa63f2106 | 103 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((i_air_temperature << 4) | ((i_ground_humidity >> 3) & 0x0f))); |
raminou | 6:865aa63f2106 | 104 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((i_ground_humidity << 5) | ((i_air_humidity >> 2) & 0x1f))); |
raminou | 6:865aa63f2106 | 105 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((i_air_humidity << 6) | ((i_pressure >> 11) & 0x3f))); |
raminou | 6:865aa63f2106 | 106 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)(i_pressure >> 3)); |
raminou | 6:865aa63f2106 | 107 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((i_pressure << 5) | ((v_magnetic_field[0] >> 9) & 0x1f))); |
raminou | 6:865aa63f2106 | 108 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)(v_magnetic_field[0] >> 1)); |
raminou | 6:865aa63f2106 | 109 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((v_magnetic_field[0] << 7) | ((v_magnetic_field[1] >> 7) & 0x7f))); |
raminou | 6:865aa63f2106 | 110 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((v_magnetic_field[1] << 1) | ((v_magnetic_field[2] >> 13) & 0x01))); |
raminou | 6:865aa63f2106 | 111 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)(v_magnetic_field[2] >> 5)); |
raminou | 6:865aa63f2106 | 112 | snprintf(v_trame, TRAME_SIZE, "%s%02x", v_trame, (char)((v_magnetic_field[2] << 3) | (err[0] << 2) | (err[1] << 1) | (err[2]))); |
raminou | 6:865aa63f2106 | 113 | /* |
raminou | 6:865aa63f2106 | 114 | v_trame[0] = i_ground_temperature >> 2; |
raminou | 6:865aa63f2106 | 115 | v_trame[1] = (i_ground_temperature << 6) | ((i_air_temperature >> 4) & 0x3f); |
raminou | 6:865aa63f2106 | 116 | v_trame[2] = (i_air_temperature << 4) | ((i_ground_humidity >> 3) & 0x0f); |
raminou | 6:865aa63f2106 | 117 | v_trame[3] = (i_ground_humidity << 5) | ((i_air_humidity >> 2) & 0x1f); |
raminou | 6:865aa63f2106 | 118 | v_trame[4] = (i_air_humidity << 6) | ((i_pressure >> 11) & 0x3f); |
raminou | 6:865aa63f2106 | 119 | v_trame[5] = (i_pressure >> 3); |
raminou | 6:865aa63f2106 | 120 | v_trame[6] = (i_pressure << 5) | ((v_magnetic_field[0] >> 9) & 0x1f); |
raminou | 6:865aa63f2106 | 121 | v_trame[7] = (v_magnetic_field[0] >> 1); |
raminou | 6:865aa63f2106 | 122 | v_trame[8] = (v_magnetic_field[0] << 7) | ((v_magnetic_field[1] >> 7) & 0x7f); |
raminou | 6:865aa63f2106 | 123 | v_trame[9] = (v_magnetic_field[1] << 1) | ((v_magnetic_field[2] >> 13) & 0x01); |
raminou | 6:865aa63f2106 | 124 | v_trame[10] = (v_magnetic_field[2] >> 5); |
raminou | 6:865aa63f2106 | 125 | v_trame[11] = (v_magnetic_field[2] << 3) | (err[0] << 2) | (err[1] << 1) | (err[2]); |
raminou | 6:865aa63f2106 | 126 | */ |
raminou | 6:865aa63f2106 | 127 | } |
raminou | 6:865aa63f2106 | 128 | |
raminou | 0:1c266599e07b | 129 | int main() |
raminou | 0:1c266599e07b | 130 | { |
raminou | 0:1c266599e07b | 131 | #ifdef DEBUG |
raminou | 0:1c266599e07b | 132 | pc.printf("\r\n\r\n\r\nInit...\r\n"); |
raminou | 0:1c266599e07b | 133 | #endif |
raminou | 0:1c266599e07b | 134 | |
raminou | 8:c4801ce16934 | 135 | sigfox.printf("\r\n"); |
raminou | 8:c4801ce16934 | 136 | |
raminou | 8:c4801ce16934 | 137 | #ifdef ENABLE_MAGNETOMETER |
raminou | 8:c4801ce16934 | 138 | capt_magnetometer.init(); |
raminou | 8:c4801ce16934 | 139 | wait_ms(1500); |
raminou | 8:c4801ce16934 | 140 | #endif |
raminou | 8:c4801ce16934 | 141 | |
raminou | 0:1c266599e07b | 142 | while(1) { |
raminou | 8:c4801ce16934 | 143 | // Wake Up sigfox |
raminou | 8:c4801ce16934 | 144 | reset_sigfox.output(); |
raminou | 8:c4801ce16934 | 145 | reset_sigfox = 0; |
raminou | 8:c4801ce16934 | 146 | wait(5); |
raminou | 8:c4801ce16934 | 147 | |
raminou | 8:c4801ce16934 | 148 | // Set high impendance the sigfox reset pin |
raminou | 8:c4801ce16934 | 149 | reset_sigfox.input(); |
raminou | 8:c4801ce16934 | 150 | |
raminou | 7:036d9a2accff | 151 | #ifdef ENABLE_GROUND_TEMPERATURE |
raminou | 7:036d9a2accff | 152 | // Temperature Sol |
raminou | 7:036d9a2accff | 153 | capt_ground_temperature.convertTemperature(true, DS1820::all_devices); |
raminou | 7:036d9a2accff | 154 | ground_temperature = capt_ground_temperature.temperature(); |
raminou | 7:036d9a2accff | 155 | #endif |
raminou | 0:1c266599e07b | 156 | |
raminou | 7:036d9a2accff | 157 | #ifdef ENABLE_GROUND_HUMIDITY |
raminou | 7:036d9a2accff | 158 | // Humidite Sol |
raminou | 7:036d9a2accff | 159 | ground_humidity = capt_ground_humidity.read() * 100; |
raminou | 7:036d9a2accff | 160 | #endif |
raminou | 0:1c266599e07b | 161 | |
raminou | 7:036d9a2accff | 162 | #ifdef ENABLE_DHT22 |
raminou | 7:036d9a2accff | 163 | // Temperature et Humidite Air |
raminou | 7:036d9a2accff | 164 | if(capt_thermo_air_humidity.sample()) |
raminou | 7:036d9a2accff | 165 | { |
raminou | 7:036d9a2accff | 166 | air_temperature = capt_thermo_air_humidity.getTemperature() / 10.0; |
raminou | 7:036d9a2accff | 167 | air_humidity = capt_thermo_air_humidity.getHumidity() / 10.0; |
raminou | 7:036d9a2accff | 168 | } |
raminou | 7:036d9a2accff | 169 | #endif |
raminou | 0:1c266599e07b | 170 | |
raminou | 7:036d9a2accff | 171 | #ifdef ENABLE_BAROMETER |
raminou | 7:036d9a2accff | 172 | // Pression |
raminou | 7:036d9a2accff | 173 | if(capt_barometer.isAvailable()) |
raminou | 8:c4801ce16934 | 174 | { |
raminou | 7:036d9a2accff | 175 | pressure = capt_barometer.ReadPressure(); |
raminou | 8:c4801ce16934 | 176 | } |
raminou | 7:036d9a2accff | 177 | #endif |
raminou | 0:1c266599e07b | 178 | |
raminou | 7:036d9a2accff | 179 | #ifdef ENABLE_MAGNETOMETER |
raminou | 7:036d9a2accff | 180 | // Magnetometre |
raminou | 8:c4801ce16934 | 181 | // capt_magnetometer.soft_reset(); |
raminou | 7:036d9a2accff | 182 | magnetic_field[0] = capt_magnetometer.getMagXvalue(); |
raminou | 7:036d9a2accff | 183 | magnetic_field[1] = capt_magnetometer.getMagYvalue(); |
raminou | 7:036d9a2accff | 184 | magnetic_field[2] = capt_magnetometer.getMagZvalue(); |
raminou | 8:c4801ce16934 | 185 | // capt_magnetometer.standby(); |
raminou | 7:036d9a2accff | 186 | #endif |
raminou | 0:1c266599e07b | 187 | |
raminou | 0:1c266599e07b | 188 | // Affichage pour debug |
raminou | 0:1c266599e07b | 189 | #ifdef DEBUG |
raminou | 5:d805b1c2dc1e | 190 | pc.printf("\r\n"); |
raminou | 5:d805b1c2dc1e | 191 | pc.printf("Pressure: %f hPa\r\n", pressure/100.0); |
raminou | 5:d805b1c2dc1e | 192 | pc.printf("Ground Temperature: %f\t|\t", ground_temperature); |
raminou | 6:865aa63f2106 | 193 | pc.printf("Ground Humidity: %.1f\r\n", ground_humidity); |
raminou | 0:1c266599e07b | 194 | pc.printf("Air Temperature: %.1f\t|\tAir Humidity: %.1f\r\n", air_temperature, air_humidity); |
raminou | 5:d805b1c2dc1e | 195 | pc.printf("Magnetic field: x: %hd, y: %hd, z: %hd\r\n", magnetic_field[0], magnetic_field[1], magnetic_field[2]); |
raminou | 0:1c266599e07b | 196 | #endif |
raminou | 0:1c266599e07b | 197 | |
raminou | 0:1c266599e07b | 198 | // Envoie sigfox |
raminou | 6:865aa63f2106 | 199 | format(ground_temperature, air_temperature, ground_humidity, air_humidity, pressure, magnetic_field, &(message[6])); |
raminou | 6:865aa63f2106 | 200 | message[MESSAGE_SIZE-2] = '\r'; |
raminou | 6:865aa63f2106 | 201 | message[MESSAGE_SIZE-1] = '\n'; |
raminou | 0:1c266599e07b | 202 | #ifdef DEBUG |
raminou | 6:865aa63f2106 | 203 | pc.printf("msg=%s", message); |
raminou | 0:1c266599e07b | 204 | #endif |
raminou | 0:1c266599e07b | 205 | |
raminou | 5:d805b1c2dc1e | 206 | #ifdef SEND_SIGFOX |
raminou | 8:c4801ce16934 | 207 | #ifdef DEBUG |
raminou | 8:c4801ce16934 | 208 | pc.printf("ENVOIE\r\n", message); |
raminou | 8:c4801ce16934 | 209 | #endif |
raminou | 5:d805b1c2dc1e | 210 | sigfox.printf("%s", message); |
raminou | 8:c4801ce16934 | 211 | wait(10); |
raminou | 8:c4801ce16934 | 212 | #endif |
raminou | 8:c4801ce16934 | 213 | sigfox.printf("AT$P=1\r\n"); |
raminou | 8:c4801ce16934 | 214 | #ifdef DEBUG |
raminou | 8:c4801ce16934 | 215 | pc.printf("Sleep"); |
raminou | 5:d805b1c2dc1e | 216 | #endif |
raminou | 6:865aa63f2106 | 217 | |
raminou | 0:1c266599e07b | 218 | // DEEPSLEEP |
raminou | 8:c4801ce16934 | 219 | WakeUp::set_ms(30000); |
raminou | 0:1c266599e07b | 220 | WakeUp::attach(&mycallback); |
raminou | 0:1c266599e07b | 221 | deepsleep(); |
raminou | 8:c4801ce16934 | 222 | //wait(30); |
raminou | 8:c4801ce16934 | 223 | //wait(10); |
raminou | 0:1c266599e07b | 224 | } |
raminou | 6:865aa63f2106 | 225 | } |