Fork of the espurna firmware for `mhsw` switches
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

871 lines
28 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
6 years ago
  1. // =============================================================================
  2. // SENSORS - General data
  3. // =============================================================================
  4. #define SENSOR_DEBUG 1 // Debug sensors
  5. #define SENSOR_READ_INTERVAL 6 // Read data from sensors every 6 seconds
  6. #define SENSOR_READ_MIN_INTERVAL 1 // Minimum read interval
  7. #define SENSOR_READ_MAX_INTERVAL 3600 // Maximum read interval
  8. #define SENSOR_INIT_INTERVAL 10000 // Try to re-init non-ready sensors every 10s
  9. #define SENSOR_REPORT_EVERY 10 // Report every this many readings
  10. #define SENSOR_REPORT_MIN_EVERY 1 // Minimum every value
  11. #define SENSOR_REPORT_MAX_EVERY 60 // Maximum
  12. #define SENSOR_USE_INDEX 0 // Use the index in topic (i.e. temperature/0)
  13. // even if just one sensor (0 for backwards compatibility)
  14. #ifndef SENSOR_POWER_CHECK_STATUS
  15. #define SENSOR_POWER_CHECK_STATUS 1 // If set to 1 the reported power/current/energy will be 0 if the relay[0] is OFF
  16. #endif
  17. #ifndef SENSOR_TEMPERATURE_CORRECTION
  18. #define SENSOR_TEMPERATURE_CORRECTION 0.0 // Offset correction
  19. #endif
  20. #ifndef TEMPERATURE_MIN_CHANGE
  21. #define TEMPERATURE_MIN_CHANGE 0.0 // Minimum temperature change to report
  22. #endif
  23. #ifndef SENSOR_HUMIDITY_CORRECTION
  24. #define SENSOR_HUMIDITY_CORRECTION 0.0 // Offset correction
  25. #endif
  26. #ifndef HUMIDITY_MIN_CHANGE
  27. #define HUMIDITY_MIN_CHANGE 0 // Minimum humidity change to report
  28. #endif
  29. #ifndef ENERGY_MAX_CHANGE
  30. #define ENERGY_MAX_CHANGE 0 // Maximum energy change to report (if >0 it will allways report when delta(E) is greater than this)
  31. #endif
  32. #ifndef SENSOR_SAVE_EVERY
  33. #define SENSOR_SAVE_EVERY 0 // Save accumulating values to EEPROM (atm only energy)
  34. // A 0 means do not save and it's the default value
  35. // A number different from 0 means it should store the value in EEPROM
  36. // after these many reports
  37. // Warning: this might wear out flash fast!
  38. #endif
  39. #define SENSOR_PUBLISH_ADDRESSES 0 // Publish sensor addresses
  40. #define SENSOR_ADDRESS_TOPIC "address" // Topic to publish sensor addresses
  41. #ifndef SENSOR_TEMPERATURE_UNITS
  42. #define SENSOR_TEMPERATURE_UNITS TMP_CELSIUS // Temperature units (TMP_CELSIUS | TMP_FAHRENHEIT)
  43. #endif
  44. #ifndef SENSOR_ENERGY_UNITS
  45. #define SENSOR_ENERGY_UNITS ENERGY_JOULES // Energy units (ENERGY_JOULES | ENERGY_KWH)
  46. #endif
  47. #ifndef SENSOR_POWER_UNITS
  48. #define SENSOR_POWER_UNITS POWER_WATTS // Power units (POWER_WATTS | POWER_KILOWATTS)
  49. #endif
  50. // =============================================================================
  51. // Specific data for each sensor
  52. // =============================================================================
  53. //------------------------------------------------------------------------------
  54. // AM2320 Humidity & Temperature sensor over I2C
  55. // Enable support by passing AM2320_SUPPORT=1 build flag
  56. //------------------------------------------------------------------------------
  57. #ifndef AM2320_SUPPORT
  58. #define AM2320_SUPPORT 0
  59. #endif
  60. #ifndef AM2320_ADDRESS
  61. #define AM2320_ADDRESS 0x00 // 0x00 means auto
  62. #endif
  63. //------------------------------------------------------------------------------
  64. // Analog sensor
  65. // Enable support by passing ANALOG_SUPPORT=1 build flag
  66. //--------------------------------------------------------------------------------
  67. #ifndef ANALOG_SUPPORT
  68. #define ANALOG_SUPPORT 0
  69. #endif
  70. #ifndef ANALOG_SAMPLES
  71. #define ANALOG_SAMPLES 10 // Number of samples
  72. #endif
  73. #ifndef ANALOG_DELAY
  74. #define ANALOG_DELAY 0 // Delay between samples in micros
  75. #endif
  76. //------------------------------------------------------------------------------
  77. // BH1750
  78. // Enable support by passing BH1750_SUPPORT=1 build flag
  79. // http://www.elechouse.com/elechouse/images/product/Digital%20light%20Sensor/bh1750fvi-e.pdf
  80. //------------------------------------------------------------------------------
  81. #ifndef BH1750_SUPPORT
  82. #define BH1750_SUPPORT 0
  83. #endif
  84. #ifndef BH1750_ADDRESS
  85. #define BH1750_ADDRESS 0x00 // 0x00 means auto
  86. #endif
  87. #define BH1750_MODE BH1750_CONTINUOUS_HIGH_RES_MODE
  88. //------------------------------------------------------------------------------
  89. // BME280/BMP280
  90. // Enable support by passing BMX280_SUPPORT=1 build flag
  91. //------------------------------------------------------------------------------
  92. #ifndef BMX280_SUPPORT
  93. #define BMX280_SUPPORT 0
  94. #endif
  95. #ifndef BMX280_ADDRESS
  96. #define BMX280_ADDRESS 0x00 // 0x00 means auto
  97. #endif
  98. #define BMX280_MODE 1 // 0 for sleep mode, 1 or 2 for forced mode, 3 for normal mode
  99. #define BMX280_STANDBY 0 // 0 for 0.5ms, 1 for 62.5ms, 2 for 125ms
  100. // 3 for 250ms, 4 for 500ms, 5 for 1000ms
  101. // 6 for 10ms, 7 for 20ms
  102. #define BMX280_FILTER 0 // 0 for OFF, 1 for 2 values, 2 for 4 values, 3 for 8 values and 4 for 16 values
  103. #define BMX280_TEMPERATURE 1 // Oversampling for temperature (set to 0 to disable magnitude)
  104. #define BMX280_HUMIDITY 1 // Oversampling for humidity (set to 0 to disable magnitude, only for BME280)
  105. #define BMX280_PRESSURE 1 // Oversampling for pressure (set to 0 to disable magnitude)
  106. //------------------------------------------------------------------------------
  107. // Dallas OneWire temperature sensors
  108. // Enable support by passing DALLAS_SUPPORT=1 build flag
  109. //------------------------------------------------------------------------------
  110. #ifndef DALLAS_SUPPORT
  111. #define DALLAS_SUPPORT 0
  112. #endif
  113. #ifndef DALLAS_PIN
  114. #define DALLAS_PIN 14
  115. #endif
  116. #define DALLAS_RESOLUTION 9 // Not used atm
  117. #define DALLAS_READ_INTERVAL 2000 // Force sensor read & cache every 2 seconds
  118. //------------------------------------------------------------------------------
  119. // DHTXX temperature/humidity sensor
  120. // Enable support by passing DHT_SUPPORT=1 build flag
  121. //------------------------------------------------------------------------------
  122. #ifndef DHT_SUPPORT
  123. #define DHT_SUPPORT 0
  124. #endif
  125. #ifndef DHT_PIN
  126. #define DHT_PIN 14
  127. #endif
  128. #ifndef DHT_TYPE
  129. #define DHT_TYPE DHT_CHIP_DHT22
  130. #endif
  131. //------------------------------------------------------------------------------
  132. // CSE7766 based power sensor
  133. // Enable support by passing CSE7766_SUPPORT=1 build flag
  134. //------------------------------------------------------------------------------
  135. #ifndef CSE7766_SUPPORT
  136. #define CSE7766_SUPPORT 0
  137. #endif
  138. #ifndef CSE7766_PIN
  139. #define CSE7766_PIN 1 // TX pin from the CSE7766
  140. #endif
  141. #ifndef CSE7766_PIN_INVERSE
  142. #define CSE7766_PIN_INVERSE 0 // Signal is inverted
  143. #endif
  144. #define CSE7766_SYNC_INTERVAL 300 // Safe time between transmissions (ms)
  145. #define CSE7766_BAUDRATE 4800 // UART baudrate
  146. #define CSE7766_V1R 1.0 // 1mR current resistor
  147. #define CSE7766_V2R 1.0 // 1M voltage resistor
  148. //------------------------------------------------------------------------------
  149. // Digital sensor
  150. // Enable support by passing DIGITAL_SUPPORT=1 build flag
  151. //------------------------------------------------------------------------------
  152. #ifndef DIGITAL_SUPPORT
  153. #define DIGITAL_SUPPORT 0
  154. #endif
  155. #ifndef DIGITAL_PIN
  156. #define DIGITAL_PIN 2
  157. #endif
  158. #ifndef DIGITAL_PIN_MODE
  159. #define DIGITAL_PIN_MODE INPUT_PULLUP
  160. #endif
  161. #ifndef DIGITAL_DEFAULT_STATE
  162. #define DIGITAL_DEFAULT_STATE 1
  163. #endif
  164. //------------------------------------------------------------------------------
  165. // ECH1560 based power sensor
  166. // Enable support by passing ECH1560_SUPPORT=1 build flag
  167. //------------------------------------------------------------------------------
  168. #ifndef ECH1560_SUPPORT
  169. #define ECH1560_SUPPORT 0
  170. #endif
  171. #ifndef ECH1560_CLK_PIN
  172. #define ECH1560_CLK_PIN 4 // CLK pin for the ECH1560
  173. #endif
  174. #ifndef ECH1560_MISO_PIN
  175. #define ECH1560_MISO_PIN 5 // MISO pin for the ECH1560
  176. #endif
  177. #ifndef ECH1560_INVERTED
  178. #define ECH1560_INVERTED 0 // Signal is inverted
  179. #endif
  180. //------------------------------------------------------------------------------
  181. // Energy Monitor general settings
  182. //------------------------------------------------------------------------------
  183. #define EMON_MAX_SAMPLES 1000 // Max number of samples to get
  184. #define EMON_MAX_TIME 250 // Max time in ms to sample
  185. #define EMON_FILTER_SPEED 512 // Mobile average filter speed
  186. #define EMON_MAINS_VOLTAGE 230 // Mains voltage
  187. #define EMON_REFERENCE_VOLTAGE 3.3 // Reference voltage of the ADC
  188. #define EMON_CURRENT_RATIO 30 // Current ratio in the clamp (30V/1A)
  189. #define EMON_REPORT_CURRENT 0 // Report current
  190. #define EMON_REPORT_POWER 1 // Report power
  191. #define EMON_REPORT_ENERGY 1 // Report energy
  192. //------------------------------------------------------------------------------
  193. // Energy Monitor based on ADC121
  194. // Enable support by passing EMON_ADC121_SUPPORT=1 build flag
  195. //------------------------------------------------------------------------------
  196. #ifndef EMON_ADC121_SUPPORT
  197. #define EMON_ADC121_SUPPORT 0 // Do not build support by default
  198. #endif
  199. #define EMON_ADC121_I2C_ADDRESS 0x00 // 0x00 means auto
  200. //------------------------------------------------------------------------------
  201. // Energy Monitor based on ADS1X15
  202. // Enable support by passing EMON_ADS1X15_SUPPORT=1 build flag
  203. //------------------------------------------------------------------------------
  204. #ifndef EMON_ADS1X15_SUPPORT
  205. #define EMON_ADS1X15_SUPPORT 0 // Do not build support by default
  206. #endif
  207. #define EMON_ADS1X15_I2C_ADDRESS 0x00 // 0x00 means auto
  208. #define EMON_ADS1X15_TYPE ADS1X15_CHIP_ADS1115
  209. #define EMON_ADS1X15_GAIN ADS1X15_REG_CONFIG_PGA_4_096V
  210. #define EMON_ADS1X15_MASK 0x0F // A0=1 A1=2 A2=4 A3=8
  211. //------------------------------------------------------------------------------
  212. // Energy Monitor based on interval analog GPIO
  213. // Enable support by passing EMON_ANALOG_SUPPORT=1 build flag
  214. //------------------------------------------------------------------------------
  215. #ifndef EMON_ANALOG_SUPPORT
  216. #define EMON_ANALOG_SUPPORT 0 // Do not build support by default
  217. #endif
  218. //------------------------------------------------------------------------------
  219. // Counter sensor
  220. // Enable support by passing EVENTS_SUPPORT=1 build flag
  221. //------------------------------------------------------------------------------
  222. #ifndef EVENTS_SUPPORT
  223. #define EVENTS_SUPPORT 0 // Do not build with counter support by default
  224. #endif
  225. #ifndef EVENTS_TRIGGER
  226. #define EVENTS_TRIGGER 1 // 1 to trigger callback on events,
  227. // 0 to only count them and report periodically
  228. #endif
  229. #ifndef EVENTS_PIN
  230. #define EVENTS_PIN 2 // GPIO to monitor
  231. #endif
  232. #ifndef EVENTS_PIN_MODE
  233. #define EVENTS_PIN_MODE INPUT // INPUT, INPUT_PULLUP
  234. #endif
  235. #ifndef EVENTS_INTERRUPT_MODE
  236. #define EVENTS_INTERRUPT_MODE RISING // RISING, FALLING, CHANGE
  237. #endif
  238. #define EVENTS_DEBOUNCE 50 // Do not register events within less than 50 millis
  239. //------------------------------------------------------------------------------
  240. // Geiger sensor
  241. // Enable support by passing GEIGER_SUPPORT=1 build flag
  242. //------------------------------------------------------------------------------
  243. #ifndef GEIGER_SUPPORT
  244. #define GEIGER_SUPPORT 0 // Do not build with geiger support by default
  245. #endif
  246. #ifndef GEIGER_PIN
  247. #define GEIGER_PIN D1 // GPIO to monitor "D1" => "GPIO5"
  248. #endif
  249. #ifndef GEIGER_PIN_MODE
  250. #define GEIGER_PIN_MODE INPUT // INPUT, INPUT_PULLUP
  251. #endif
  252. #ifndef GEIGER_INTERRUPT_MODE
  253. #define GEIGER_INTERRUPT_MODE RISING // RISING, FALLING, CHANGE
  254. #endif
  255. #define GEIGER_DEBOUNCE 25 // Do not register events within less than 25 millis.
  256. // Value derived here: Debounce time 25ms, because https://github.com/Trickx/espurna/wiki/Geiger-counter
  257. #define GEIGER_CPM2SIEVERT 240 // CPM to µSievert per hour conversion factor
  258. // Typically the literature uses the invers, but I find an integer type more convienient.
  259. #define GEIGER_REPORT_SIEVERTS 1 // Enabler for local dose rate reports in µSv/h
  260. #define GEIGER_REPORT_CPM 1 // Enabler for local dose rate reports in counts per minute
  261. //------------------------------------------------------------------------------
  262. // GUVAS12SD UV Sensor (analog)
  263. // Enable support by passing GUVAS12SD_SUPPORT=1 build flag
  264. //------------------------------------------------------------------------------
  265. #ifndef GUVAS12SD_SUPPORT
  266. #define GUVAS12SD_SUPPORT 0
  267. #endif
  268. #ifndef GUVAS12SD_PIN
  269. #define GUVAS12SD_PIN 14
  270. #endif
  271. //------------------------------------------------------------------------------
  272. // HLW8012 Energy monitor IC
  273. // Enable support by passing HLW8012_SUPPORT=1 build flag
  274. //------------------------------------------------------------------------------
  275. #ifndef HLW8012_SUPPORT
  276. #define HLW8012_SUPPORT 0
  277. #endif
  278. #ifndef HLW8012_SEL_PIN
  279. #define HLW8012_SEL_PIN 5
  280. #endif
  281. #ifndef HLW8012_CF1_PIN
  282. #define HLW8012_CF1_PIN 13
  283. #endif
  284. #ifndef HLW8012_CF_PIN
  285. #define HLW8012_CF_PIN 14
  286. #endif
  287. #ifndef HLW8012_SEL_CURRENT
  288. #define HLW8012_SEL_CURRENT HIGH // SEL pin to HIGH to measure current
  289. #endif
  290. #ifndef HLW8012_CURRENT_R
  291. #define HLW8012_CURRENT_R 0.001 // Current resistor
  292. #endif
  293. #ifndef HLW8012_VOLTAGE_R_UP
  294. #define HLW8012_VOLTAGE_R_UP ( 5 * 470000 ) // Upstream voltage resistor
  295. #endif
  296. #ifndef HLW8012_VOLTAGE_R_DOWN
  297. #define HLW8012_VOLTAGE_R_DOWN ( 1000 ) // Downstream voltage resistor
  298. #endif
  299. #ifndef HLW8012_CURRENT_RATIO
  300. #define HLW8012_CURRENT_RATIO 0 // Set to 0 to use factory defaults
  301. #endif
  302. #ifndef HLW8012_VOLTAGE_RATIO
  303. #define HLW8012_VOLTAGE_RATIO 0 // Set to 0 to use factory defaults
  304. #endif
  305. #ifndef HLW8012_POWER_RATIO
  306. #define HLW8012_POWER_RATIO 0 // Set to 0 to use factory defaults
  307. #endif
  308. #ifndef HLW8012_USE_INTERRUPTS
  309. #define HLW8012_USE_INTERRUPTS 1 // Use interrupts to trap HLW8012 signals
  310. #endif
  311. #ifndef HLW8012_INTERRUPT_ON
  312. #define HLW8012_INTERRUPT_ON CHANGE // When to trigger the interrupt
  313. // Use CHANGE for HLW8012
  314. // Use FALLING for BL0937 / HJL0
  315. #endif
  316. //------------------------------------------------------------------------------
  317. // MHZ19 CO2 sensor
  318. // Enable support by passing MHZ19_SUPPORT=1 build flag
  319. //------------------------------------------------------------------------------
  320. #ifndef MHZ19_SUPPORT
  321. #define MHZ19_SUPPORT 0
  322. #endif
  323. #ifndef MHZ19_RX_PIN
  324. #define MHZ19_RX_PIN 13
  325. #endif
  326. #ifndef MHZ19_TX_PIN
  327. #define MHZ19_TX_PIN 15
  328. #endif
  329. //------------------------------------------------------------------------------
  330. // NTC sensor
  331. // Enable support by passing NTC_SUPPORT=1 build flag
  332. //--------------------------------------------------------------------------------
  333. #ifndef NTC_SUPPORT
  334. #define NTC_SUPPORT 0
  335. #endif
  336. #ifndef NTC_SAMPLES
  337. #define NTC_SAMPLES 10 // Number of samples
  338. #endif
  339. #ifndef NTC_DELAY
  340. #define NTC_DELAY 0 // Delay between samples in micros
  341. #endif
  342. #ifndef NTC_R_UP
  343. #define NTC_R_UP 0 // Resistor upstream, set to 0 if none
  344. #endif
  345. #ifndef NTC_R_DOWN
  346. #define NTC_R_DOWN 10000 // Resistor downstream, set to 0 if none
  347. #endif
  348. #ifndef NTC_T0
  349. #define NTC_T0 298.15 // 25 Celsius
  350. #endif
  351. #ifndef NTC_R0
  352. #define NTC_R0 10000 // Resistance at T0
  353. #endif
  354. #ifndef NTC_BETA
  355. #define NTC_BETA 3977 // Beta coeficient
  356. #endif
  357. //------------------------------------------------------------------------------
  358. // SenseAir CO2 sensor
  359. // Enable support by passing SENSEAIR_SUPPORT=1 build flag
  360. //------------------------------------------------------------------------------
  361. #ifndef SENSEAIR_SUPPORT
  362. #define SENSEAIR_SUPPORT 0
  363. #endif
  364. #ifndef SENSEAIR_RX_PIN
  365. #define SENSEAIR_RX_PIN 0
  366. #endif
  367. #ifndef SENSEAIR_TX_PIN
  368. #define SENSEAIR_TX_PIN 2
  369. #endif
  370. //------------------------------------------------------------------------------
  371. // Particle Monitor based on Plantower PMS
  372. // Enable support by passing PMSX003_SUPPORT=1 build flag
  373. //------------------------------------------------------------------------------
  374. #ifndef PMSX003_SUPPORT
  375. #define PMSX003_SUPPORT 0
  376. #endif
  377. #ifndef PMS_TYPE
  378. #define PMS_TYPE PMS_TYPE_X003
  379. #endif
  380. // You can enable smart sleep (read 6-times then sleep on 24-reading-cycles) to extend PMS sensor's life.
  381. // Otherwise the default lifetime of PMS sensor is about 8000-hours/1-years.
  382. // The PMS's fan will stop working on sleeping cycle, and will wake up on reading cycle.
  383. #ifndef PMS_SMART_SLEEP
  384. #define PMS_SMART_SLEEP 0
  385. #endif
  386. #ifndef PMS_USE_SOFT
  387. #define PMS_USE_SOFT 0 // If PMS_USE_SOFT == 1, DEBUG_SERIAL_SUPPORT must be 0
  388. #endif
  389. #ifndef PMS_RX_PIN
  390. #define PMS_RX_PIN 13 // Software serial RX GPIO (if PMS_USE_SOFT == 1)
  391. #endif
  392. #ifndef PMS_TX_PIN
  393. #define PMS_TX_PIN 15 // Software serial TX GPIO (if PMS_USE_SOFT == 1)
  394. #endif
  395. #ifndef PMS_HW_PORT
  396. #define PMS_HW_PORT Serial // Hardware serial port (if PMS_USE_SOFT == 0)
  397. #endif
  398. //------------------------------------------------------------------------------
  399. // PZEM004T based power monitor
  400. // Enable support by passing PZEM004T_SUPPORT=1 build flag
  401. //------------------------------------------------------------------------------
  402. #ifndef PZEM004T_SUPPORT
  403. #define PZEM004T_SUPPORT 0
  404. #endif
  405. #ifndef PZEM004T_USE_SOFT
  406. #define PZEM004T_USE_SOFT 0 // Software serial is not working atm, use hardware serial
  407. #endif
  408. #ifndef PZEM004T_RX_PIN
  409. #define PZEM004T_RX_PIN 13 // Software serial RX GPIO (if PZEM004T_USE_SOFT == 1)
  410. #endif
  411. #ifndef PZEM004T_TX_PIN
  412. #define PZEM004T_TX_PIN 15 // Software serial TX GPIO (if PZEM004T_USE_SOFT == 1)
  413. #endif
  414. #ifndef PZEM004T_HW_PORT
  415. #define PZEM004T_HW_PORT Serial // Hardware serial port (if PZEM004T_USE_SOFT == 0)
  416. #endif
  417. //------------------------------------------------------------------------------
  418. // SHT3X I2C (Wemos) temperature & humidity sensor
  419. // Enable support by passing SHT3X_I2C_SUPPORT=1 build flag
  420. //------------------------------------------------------------------------------
  421. #ifndef SHT3X_I2C_SUPPORT
  422. #define SHT3X_I2C_SUPPORT 0
  423. #endif
  424. #ifndef SHT3X_I2C_ADDRESS
  425. #define SHT3X_I2C_ADDRESS 0x00 // 0x00 means auto
  426. #endif
  427. //------------------------------------------------------------------------------
  428. // SI7021 temperature & humidity sensor
  429. // Enable support by passing SI7021_SUPPORT=1 build flag
  430. //------------------------------------------------------------------------------
  431. #ifndef SI7021_SUPPORT
  432. #define SI7021_SUPPORT 0
  433. #endif
  434. #ifndef SI7021_ADDRESS
  435. #define SI7021_ADDRESS 0x00 // 0x00 means auto
  436. #endif
  437. //------------------------------------------------------------------------------
  438. // Sonar
  439. // Enable support by passing SONAR_SUPPORT=1 build flag
  440. //------------------------------------------------------------------------------
  441. #ifndef SONAR_SUPPORT
  442. #define SONAR_SUPPORT 0
  443. #endif
  444. #ifndef SONAR_TRIGGER
  445. #define SONAR_TRIGGER 12 // GPIO for the trigger pin (output)
  446. #endif
  447. #ifndef SONAR_ECHO
  448. #define SONAR_ECHO 14 // GPIO for the echo pin (input)
  449. #endif
  450. #ifndef SONAR_MAX_DISTANCE
  451. #define SONAR_MAX_DISTANCE MAX_SENSOR_DISTANCE // Max sensor distance in cm
  452. #endif
  453. #ifndef SONAR_ITERATIONS
  454. #define SONAR_ITERATIONS 5 // Number of iterations to ping for
  455. #endif // error correction.
  456. //------------------------------------------------------------------------------
  457. // SONOFF SC
  458. // Enable support by passing SONOFFSC_SUPPORT=1 build flag
  459. //------------------------------------------------------------------------------
  460. #ifndef SONOFFSC_SUPPORT
  461. #define SONOFFSC_SUPPORT 0
  462. #endif
  463. #define SONOFFSC_BAUDRATE 19200
  464. #define SONOFFSC_BUFFER_SIZE 256
  465. #ifndef SONOFFSC_HAS_LIGHT_REL
  466. #define SONOFFSC_HAS_LIGHT_REL 1 // sensor reports light in %
  467. #endif
  468. #ifndef SONOFFSC_HAS_DUST_REL
  469. #define SONOFFSC_HAS_DUST_REL 1 // sensor reports dust in %
  470. #endif
  471. #ifndef SONOFFSC_HAS_MOVEMENT
  472. #define SONOFFSC_HAS_MOVEMENT 1 // sensor reports movement
  473. #endif
  474. #ifndef SONOFFSC_HAS_LUX
  475. #define SONOFFSC_HAS_LUX 1 // sensor reports light in LUX
  476. #endif
  477. #ifndef SONOFFSC_HAS_DUST
  478. #define SONOFFSC_HAS_DUST 1 // sensor reports abs dust value
  479. #endif
  480. #ifndef SONOFFSC_HAS_CLAP
  481. #define SONOFFSC_HAS_CLAP 0 // sensor reports claps
  482. #endif
  483. //------------------------------------------------------------------------------
  484. // TMP3X analog temperature sensor
  485. // Enable support by passing TMP3X_SUPPORT=1 build flag
  486. //------------------------------------------------------------------------------
  487. #ifndef TMP3X_SUPPORT
  488. #define TMP3X_SUPPORT 0
  489. #endif
  490. #ifndef TMP3X_TYPE
  491. #define TMP3X_TYPE TMP3X_TMP35
  492. #endif
  493. //------------------------------------------------------------------------------
  494. // V9261F based power sensor
  495. // Enable support by passing SI7021_SUPPORT=1 build flag
  496. //------------------------------------------------------------------------------
  497. #ifndef V9261F_SUPPORT
  498. #define V9261F_SUPPORT 0
  499. #endif
  500. #ifndef V9261F_PIN
  501. #define V9261F_PIN 2 // TX pin from the V9261F
  502. #endif
  503. #ifndef V9261F_PIN_INVERSE
  504. #define V9261F_PIN_INVERSE 1 // Signal is inverted
  505. #endif
  506. #define V9261F_SYNC_INTERVAL 600 // Sync signal length (ms)
  507. #define V9261F_BAUDRATE 4800 // UART baudrate
  508. // Default ratios
  509. #define V9261F_CURRENT_FACTOR 79371434.0
  510. #define V9261F_VOLTAGE_FACTOR 4160651.0
  511. #define V9261F_POWER_FACTOR 153699.0
  512. #define V9261F_RPOWER_FACTOR V9261F_CURRENT_FACTOR
  513. // =============================================================================
  514. // Sensor helpers configuration - can't move to dependencies.h
  515. // =============================================================================
  516. #ifndef SENSOR_SUPPORT
  517. #define SENSOR_SUPPORT ( \
  518. AM2320_SUPPORT || \
  519. ANALOG_SUPPORT || \
  520. BH1750_SUPPORT || \
  521. BMX280_SUPPORT || \
  522. CSE7766_SUPPORT || \
  523. DALLAS_SUPPORT || \
  524. DHT_SUPPORT || \
  525. DIGITAL_SUPPORT || \
  526. ECH1560_SUPPORT || \
  527. EMON_ADC121_SUPPORT || \
  528. EMON_ADS1X15_SUPPORT || \
  529. EMON_ANALOG_SUPPORT || \
  530. EVENTS_SUPPORT || \
  531. GEIGER_SUPPORT || \
  532. GUVAS12SD_SUPPORT || \
  533. HLW8012_SUPPORT || \
  534. MHZ19_SUPPORT || \
  535. NTC_SUPPORT || \
  536. SENSEAIR_SUPPORT || \
  537. PMSX003_SUPPORT || \
  538. PZEM004T_SUPPORT || \
  539. SHT3X_I2C_SUPPORT || \
  540. SI7021_SUPPORT || \
  541. SONAR_SUPPORT || \
  542. SONOFFSC_SUPPORT || \
  543. TMP3X_SUPPORT || \
  544. V9261F_SUPPORT \
  545. )
  546. #endif
  547. // -----------------------------------------------------------------------------
  548. // ADC
  549. // -----------------------------------------------------------------------------
  550. // Default ADC mode is to monitor internal power supply
  551. #ifndef ADC_MODE_VALUE
  552. #define ADC_MODE_VALUE ADC_VCC
  553. #endif
  554. // -----------------------------------------------------------------------------
  555. // I2C
  556. // -----------------------------------------------------------------------------
  557. #ifndef I2C_SUPPORT
  558. #define I2C_SUPPORT 0 // I2C enabled (1.98Kb)
  559. #endif
  560. #define I2C_USE_BRZO 0 // Use brzo_i2c library or standard Wire
  561. #ifndef I2C_SDA_PIN
  562. #define I2C_SDA_PIN SDA // SDA GPIO (Sonoff => 4)
  563. #endif
  564. #ifndef I2C_SCL_PIN
  565. #define I2C_SCL_PIN SCL // SCL GPIO (Sonoff => 14)
  566. #endif
  567. #define I2C_CLOCK_STRETCH_TIME 200 // BRZO clock stretch time
  568. #define I2C_SCL_FREQUENCY 1000 // BRZO SCL frequency
  569. #define I2C_CLEAR_BUS 0 // Clear I2C bus on boot
  570. #define I2C_PERFORM_SCAN 1 // Perform a bus scan on boot
  571. //--------------------------------------------------------------------------------
  572. // Class loading
  573. //--------------------------------------------------------------------------------
  574. #if SENSOR_SUPPORT
  575. #if SENSOR_DEBUG
  576. #include "../config/debug.h"
  577. #endif
  578. #include "../sensors/BaseSensor.h"
  579. #if AM2320_SUPPORT
  580. #include "../sensors/AM2320Sensor.h"
  581. #endif
  582. #if ANALOG_SUPPORT
  583. #include "../sensors/AnalogSensor.h"
  584. #endif
  585. #if BH1750_SUPPORT
  586. #include "../sensors/BH1750Sensor.h"
  587. #endif
  588. #if BMX280_SUPPORT
  589. #include "../sensors/BMX280Sensor.h"
  590. #endif
  591. #if CSE7766_SUPPORT
  592. #include <SoftwareSerial.h>
  593. #include "../sensors/CSE7766Sensor.h"
  594. #endif
  595. #if DALLAS_SUPPORT
  596. #include <OneWire.h>
  597. #include "../sensors/DallasSensor.h"
  598. #endif
  599. #if DHT_SUPPORT
  600. #include "../sensors/DHTSensor.h"
  601. #endif
  602. #if DIGITAL_SUPPORT
  603. #include "../sensors/DigitalSensor.h"
  604. #endif
  605. #if ECH1560_SUPPORT
  606. #include "../sensors/ECH1560Sensor.h"
  607. #endif
  608. #if EMON_ADC121_SUPPORT
  609. #include "../sensors/EmonADC121Sensor.h"
  610. #endif
  611. #if EMON_ADS1X15_SUPPORT
  612. #include "../sensors/EmonADS1X15Sensor.h"
  613. #endif
  614. #if EMON_ANALOG_SUPPORT
  615. #include "../sensors/EmonAnalogSensor.h"
  616. #endif
  617. #if EVENTS_SUPPORT
  618. #include "../sensors/EventSensor.h"
  619. #endif
  620. #if GEIGER_SUPPORT
  621. #include "../sensors/GeigerSensor.h" // The main file for geiger counting module
  622. #endif
  623. #if GUVAS12SD_SUPPORT
  624. #include "../sensors/GUVAS12SDSensor.h"
  625. #endif
  626. #if HLW8012_SUPPORT
  627. #include <HLW8012.h>
  628. #include "../sensors/HLW8012Sensor.h"
  629. #endif
  630. #if MHZ19_SUPPORT
  631. #include <SoftwareSerial.h>
  632. #include "../sensors/MHZ19Sensor.h"
  633. #endif
  634. #if NTC_SUPPORT
  635. #include "../sensors/AnalogSensor.h"
  636. #include "../sensors/NTCSensor.h"
  637. #endif
  638. #if SENSEAIR_SUPPORT
  639. #include <SoftwareSerial.h>
  640. #include "../sensors/SenseAirSensor.h"
  641. #endif
  642. #if PMSX003_SUPPORT
  643. #include <SoftwareSerial.h>
  644. #include "../sensors/PMSX003Sensor.h"
  645. #endif
  646. #if PZEM004T_SUPPORT
  647. #include <SoftwareSerial.h>
  648. #include "../sensors/PZEM004TSensor.h"
  649. #endif
  650. #if SI7021_SUPPORT
  651. #include "../sensors/SI7021Sensor.h"
  652. #endif
  653. #if SHT3X_I2C_SUPPORT
  654. #include "../sensors/SHT3XI2CSensor.h"
  655. #endif
  656. #if SONAR_SUPPORT
  657. #include "../sensors/SonarSensor.h"
  658. #endif
  659. #if SONOFFSC_SUPPORT
  660. #include "../sensors/SonoffSCSensor.h"
  661. #endif
  662. #if TMP3X_SUPPORT
  663. #include "../sensors/TMP3XSensor.h"
  664. #endif
  665. #if V9261F_SUPPORT
  666. #include <SoftwareSerial.h>
  667. #include "../sensors/V9261FSensor.h"
  668. #endif
  669. #endif // SENSOR_SUPPORT