From 80b19c0c380212391a039a556976e63e63fdee35 Mon Sep 17 00:00:00 2001 From: Koen <98043234+koen1711@users.noreply.github.com> Date: Tue, 28 Mar 2023 10:30:17 +0200 Subject: [PATCH 01/10] a --- src/LSM303AGR.h | 1 + 1 file changed, 1 insertion(+) diff --git a/src/LSM303AGR.h b/src/LSM303AGR.h index 485c624..e158e76 100644 --- a/src/LSM303AGR.h +++ b/src/LSM303AGR.h @@ -20,6 +20,7 @@ class CompassSensor { lis2mdl_rate_t getDataRate(); void setDataRate(lis2mdl_rate_t rate); void reset(); + void update(); }; #endif From db11875f3a9480e9e4045c9124c28a67c2e6993e Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 15:33:24 +0200 Subject: [PATCH 02/10] LightSensor code --- src/LightSensor.cpp | 17 +++++++++++++++++ src/LightSensor.h | 16 ++++++++++++++++ 2 files changed, 33 insertions(+) create mode 100644 src/LightSensor.cpp create mode 100644 src/LightSensor.h diff --git a/src/LightSensor.cpp b/src/LightSensor.cpp new file mode 100644 index 0000000..7713e06 --- /dev/null +++ b/src/LightSensor.cpp @@ -0,0 +1,17 @@ +#include "LightSensor.h" + +LIGHTSENSOR::LIGHTSENSOR(int pin) +{ + this->pin = pin; +} + +bool LIGHTSENSOR::begin() +{ + pinMode(A0, INPUT); + return true; +} + +int LIGHTSENSOR::read() +{ + return analogRead(A0); +} \ No newline at end of file diff --git a/src/LightSensor.h b/src/LightSensor.h new file mode 100644 index 0000000..8b94ce0 --- /dev/null +++ b/src/LightSensor.h @@ -0,0 +1,16 @@ +#ifndef LIGHTSENSOR_H +#define LIGHTSENSOR_H + +class LIGHTSENSOR +{ +public: + private: + int pin; + public: + LIGHTSENSOR(int pin); + bool begin(); + int read(); +}; + + +#endif \ No newline at end of file From 34c55ea35bd2559b1997d653f34f20c1398359f6 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 15:35:19 +0200 Subject: [PATCH 03/10] Update library.properties --- library.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/library.properties b/library.properties index a34a7e5..49c7c75 100644 --- a/library.properties +++ b/library.properties @@ -1,5 +1,5 @@ name=Leaphy Extra Extension -version=0.0.14 +version=0.0.17 author=Leaphy Robotics maintainer=Leaphy Robotics sentence=Provides Extra functionality to Leaphy robots From bfdadbe49c0ea93d3986a1da6b4dfc7c5a36cfc7 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 15:43:59 +0200 Subject: [PATCH 04/10] Library update --- library.properties | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/library.properties b/library.properties index 49c7c75..078c8ca 100644 --- a/library.properties +++ b/library.properties @@ -7,5 +7,5 @@ paragraph= category=Device Control url=https://github.com/leaphy-robotics/leaphy-extensions-extra architectures=avr -includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h +includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h,LightSensor.h depends=Adafruit SSD1306,Adafruit GFX Library,Adafruit LSM303 Accel,Adafruit LIS2MDL,Adafruit BusIO Register,Adafruit I2CDevice,Adafruit SPIDevice,Adafruit Sensor,Wire \ No newline at end of file From 6df965cdc28c2201556ba01e8f9c17d51378c267 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 16:00:03 +0200 Subject: [PATCH 05/10] TimeOfFlight --- library.properties | 4 ++-- src/TimeofFlight.cpp | 36 ++++++++++++++++++++++++++++++++++++ src/TimeofFlight.h | 21 +++++++++++++++++++++ 3 files changed, 59 insertions(+), 2 deletions(-) create mode 100644 src/TimeofFlight.cpp create mode 100644 src/TimeofFlight.h diff --git a/library.properties b/library.properties index 078c8ca..9d3bad8 100644 --- a/library.properties +++ b/library.properties @@ -7,5 +7,5 @@ paragraph= category=Device Control url=https://github.com/leaphy-robotics/leaphy-extensions-extra architectures=avr -includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h,LightSensor.h -depends=Adafruit SSD1306,Adafruit GFX Library,Adafruit LSM303 Accel,Adafruit LIS2MDL,Adafruit BusIO Register,Adafruit I2CDevice,Adafruit SPIDevice,Adafruit Sensor,Wire \ No newline at end of file +includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h,LightSensor.h,TimeOfFlight.h +depends=Adafruit SSD1306,Adafruit GFX Library,Adafruit LSM303 Accel,Adafruit LIS2MDL,Adafruit BusIO Register,Adafruit I2CDevice,Adafruit SPIDevice,Adafruit Sensor,Wire,Adafruit_VL53L0X \ No newline at end of file diff --git a/src/TimeofFlight.cpp b/src/TimeofFlight.cpp new file mode 100644 index 0000000..44fa5f1 --- /dev/null +++ b/src/TimeofFlight.cpp @@ -0,0 +1,36 @@ +#include "TimeofFlight.h" +#include "Adafruit_VL53L0X.h" + +TimeOfFlight::TimeOfFlight(int a0, int a1) +{ + this->pin = pin; +} + +bool TimeOfFlight::begin() +{ + if (!sensor.begin()) { + Serial.println(F("Failed to boot VL53L0X")); + return false; + } + return true; +} + +int TimeOfFlight::read() +{ + VL53L0X_RangingMeasurementData_t measure; + sensor.rangingTest(&measure, false); + if (measure.RangeStatus == 4) { + return -1; + } + return measure.RangeMilliMeter; +} + +int TimeOfFlight::readCm() +{ + return this->read() / 10; +} + +int TimeOfFlight::readMm() +{ + return this->read(); +} \ No newline at end of file diff --git a/src/TimeofFlight.h b/src/TimeofFlight.h new file mode 100644 index 0000000..4c4ebaa --- /dev/null +++ b/src/TimeofFlight.h @@ -0,0 +1,21 @@ +#ifndef tof +#define tof +#include "Adafruit_VL53L0X.h" + +class TimeOfFlight +{ +public: + private: + int a0; + int a1; + Adafruit_VL53L0X sensor = Adafruit_VL53L0X(); + int read(); + public: + TimeOfFlight(int a0, int a1); + bool begin(); + int readCm(); + int readMm(); +}; + + +#endif \ No newline at end of file From 4b53fd0b7c81710882bb8c6691f71b9443aea5bc Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 16:04:31 +0200 Subject: [PATCH 06/10] Update --- src/LightSensor.cpp | 5 +++-- src/TimeofFlight.cpp | 6 ------ src/TimeofFlight.h | 3 --- 3 files changed, 3 insertions(+), 11 deletions(-) diff --git a/src/LightSensor.cpp b/src/LightSensor.cpp index 7713e06..83a71de 100644 --- a/src/LightSensor.cpp +++ b/src/LightSensor.cpp @@ -1,4 +1,5 @@ #include "LightSensor.h" +#include LIGHTSENSOR::LIGHTSENSOR(int pin) { @@ -7,11 +8,11 @@ LIGHTSENSOR::LIGHTSENSOR(int pin) bool LIGHTSENSOR::begin() { - pinMode(A0, INPUT); + pinMode(pin, INPUT); return true; } int LIGHTSENSOR::read() { - return analogRead(A0); + return analogRead(pin); } \ No newline at end of file diff --git a/src/TimeofFlight.cpp b/src/TimeofFlight.cpp index 44fa5f1..982c0ce 100644 --- a/src/TimeofFlight.cpp +++ b/src/TimeofFlight.cpp @@ -1,15 +1,9 @@ #include "TimeofFlight.h" #include "Adafruit_VL53L0X.h" -TimeOfFlight::TimeOfFlight(int a0, int a1) -{ - this->pin = pin; -} - bool TimeOfFlight::begin() { if (!sensor.begin()) { - Serial.println(F("Failed to boot VL53L0X")); return false; } return true; diff --git a/src/TimeofFlight.h b/src/TimeofFlight.h index 4c4ebaa..fda90ae 100644 --- a/src/TimeofFlight.h +++ b/src/TimeofFlight.h @@ -6,12 +6,9 @@ class TimeOfFlight { public: private: - int a0; - int a1; Adafruit_VL53L0X sensor = Adafruit_VL53L0X(); int read(); public: - TimeOfFlight(int a0, int a1); bool begin(); int readCm(); int readMm(); From 07263f29a95005644a8629266ea994273223347c Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 19:28:16 +0200 Subject: [PATCH 07/10] AirQuality --- src/AirQuality.cpp | 204 +++++++++++++++++++++++++++++++++++++++++++++ src/AirQuality.h | 76 +++++++++++++++++ 2 files changed, 280 insertions(+) create mode 100644 src/AirQuality.cpp create mode 100644 src/AirQuality.h diff --git a/src/AirQuality.cpp b/src/AirQuality.cpp new file mode 100644 index 0000000..16d79dd --- /dev/null +++ b/src/AirQuality.cpp @@ -0,0 +1,204 @@ +#include "AirQuality.h" + +SGP30::SGP30(TwoWire *wire) +{ + _address = 0x58; + _wire = wire; + + _tvoc = 0; + _co2 = 0; + _h2 = 0; + _ethanol = 0; + + _lastTime = 0; + _error = SGP30_OK; +} + + +bool SGP30::begin() +{ + _wire->begin(); + if (! isConnected()) return false; + _init(); + return true; +} + + +bool SGP30::isConnected() +{ + _wire->beginTransmission(_address); + return ( _wire->endTransmission() == 0); +} + +bool SGP30::measure(bool all) +{ + if (millis() - _lastTime < 1000) return false; + _lastTime = millis(); + + request(); + delay(12); + read(); + + if (not all) return true; + + requestRaw(); + delay(25); + readRaw(); + return true; +} + + +void SGP30::request() +{ + _lastRequest = millis(); + _command(0x2008); +} + + +bool SGP30::read() +{ + if (_lastRequest == 0) return false; + if (millis() - _lastRequest < 13) return false; + _lastRequest = 0; + + if (_wire->requestFrom(_address, (uint8_t)6) != 6) + { + _error = SGP30_ERROR_I2C; + return false; + } + _co2 = _wire->read() << 8; + _co2 += _wire->read(); + uint8_t crc = _wire->read(); + if (_CRC8(_co2) != crc) + { + _error = SGP30_ERROR_CRC; + return false; + } + _tvoc = _wire->read() << 8; + _tvoc += _wire->read(); + crc = _wire->read(); + if (_CRC8(_tvoc) != crc) + { + _error = SGP30_ERROR_CRC; + return false; + } + _error = SGP30_OK; + return true; +} + + +void SGP30::requestRaw() +{ + _lastRequest = millis(); + _command(0x2050); +} + + +bool SGP30::readRaw() +{ + if (_lastRequest == 0) return false; + if (millis() - _lastRequest < 26) return false; + _lastRequest = 0; + + if (_wire->requestFrom(_address, (uint8_t)6) != 6) + { + _error = SGP30_ERROR_I2C; + return false; + } + _h2 = _wire->read() << 8; + _h2 += _wire->read(); + uint8_t crc = _wire->read(); + if (_CRC8(_h2) != crc) + { + _error = SGP30_ERROR_CRC; + return false; + } + _ethanol = _wire->read() << 8; + _ethanol += _wire->read(); + crc = _wire->read(); + if (_CRC8(_ethanol) != crc) + { + _error = SGP30_ERROR_CRC; + return false; + } + _error = SGP30_OK; + return true; +} + +float SGP30::getH2() +{ + float cref = 0.5; // ppm + return cref * exp((_srefH2 - _h2) * 1.953125e-3); +} + + +float SGP30::getEthanol() +{ + float cref = 0.4; // ppm + return cref * exp((_srefEth - _ethanol) * 1.953125e-3); +} + +int SGP30::_command(uint16_t cmd) +{ + _wire->beginTransmission(_address); + _wire->write(cmd >> 8); + _wire->write(cmd & 0xFF); + _error = _wire->endTransmission(); + return _error; +} + + +int SGP30::_command(uint16_t cmd, uint16_t v1) +{ + _wire->beginTransmission(_address); + _wire->write(cmd >> 8); + _wire->write(cmd & 0xFF); + _wire->write(v1 >> 8); + _wire->write(v1 & 0xFF); + _wire->write(_CRC8(v1)); + _error = _wire->endTransmission(); + return _error; +} + + +int SGP30::_command(uint16_t cmd, uint16_t v1, uint16_t v2) +{ + _wire->beginTransmission(_address); + _wire->write(cmd >> 8); + _wire->write(cmd & 0xFF); + _wire->write(v1 >> 8); + _wire->write(v1 & 0xFF); + _wire->write(_CRC8(v1)); + _wire->write(v2 >> 8); + _wire->write(v2 & 0xFF); + _wire->write(_CRC8(v2)); + _error = _wire->endTransmission(); + return _error; +} + +uint8_t SGP30::_CRC8(uint16_t data) +{ + uint8_t val[2]; + val[0] = data >> 8; + val[1] = data & 0xFF; + + uint8_t crc = 0xFF; + for(uint8_t i = 0; i < 2; i++) + { + crc ^= val[i]; + for (uint8_t b = 8; b > 0; b--) + { + if (crc & 0x80) + crc = (crc << 1) ^ 0x31; + else + crc <<= 1; + } + } + return crc; +}; + + +void SGP30::_init() +{ + _command(0x2003); +}; diff --git a/src/AirQuality.h b/src/AirQuality.h new file mode 100644 index 0000000..a3c8a5e --- /dev/null +++ b/src/AirQuality.h @@ -0,0 +1,76 @@ +#pragma once +// +// FILE: SGP30.h +// AUTHOR: Rob Tillaart +// VERSION: 0.2.0 +// DATE: 2021-06-24 +// PURPOSE: Arduino library for SGP30 environment sensor. +// URL: https://github.com/RobTillaart/SGP30 +// https://www.adafruit.com/product/3709 + + +#include "Arduino.h" +#include "Wire.h" + +#define SGP30_OK 0x00 +#define SGP30_ERROR_CRC 0xFF +#define SGP30_ERROR_I2C 0xFE + + +class SGP30 +{ +public: + explicit SGP30(TwoWire *wire = &Wire); + bool begin(); + bool isConnected(); + void GenericReset(); + bool getID(); + uint16_t getFeatureSet(); + bool measureTest(); + uint32_t lastMeasurement() { return _lastTime; }; + bool measure(bool all = false); + void request(); + bool read(); + void requestRaw(); + bool readRaw(); + + uint16_t getTVOC() { return _tvoc; }; // PPB + uint16_t getCO2() { return _co2; }; // PPM + uint16_t getH2_raw() { return _h2; }; // UNKNOWN + uint16_t getEthanol_raw() { return _ethanol; }; // UNKNOWN + float getH2(); // experimental // PPM + float getEthanol(); // experimental // PPM + + void setSrefH2(uint16_t s = 13119) { _srefH2 = s; }; + uint16_t getSrefH2() { return _srefH2; }; + void setSrefEthanol(uint16_t s = 18472) { _srefEth = s; }; + uint16_t getSrefEthanol() { return _srefEth; }; + + + int lastError(); + uint8_t _id[6]; + + +private: + uint8_t _address; + int _error; + uint32_t _lastTime = 0; + uint32_t _lastRequest = 0; + int _command(uint16_t cmd); + int _command(uint16_t cmd, uint16_t v1); + int _command(uint16_t cmd, uint16_t v1, uint16_t v2); + uint8_t _CRC8(uint16_t val); + void _init(); + + uint16_t _tvoc; + uint16_t _co2; + uint16_t _h2; + uint16_t _ethanol; + uint16_t _srefH2 = 13119; + uint16_t _srefEth = 18472; + + TwoWire* _wire; +}; + + +// -- END OF FILE -- From 2f2d2406f72b3225ef905fd1a13d670556e01ff4 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 20:21:21 +0200 Subject: [PATCH 08/10] AirQuality added --- src/AirQuality.cpp | 48 +++++++++++++++++++++++----------------------- src/AirQuality.h | 10 +++++----- 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/src/AirQuality.cpp b/src/AirQuality.cpp index 16d79dd..df74456 100644 --- a/src/AirQuality.cpp +++ b/src/AirQuality.cpp @@ -1,6 +1,6 @@ #include "AirQuality.h" -SGP30::SGP30(TwoWire *wire) +AirQuality::AirQuality(TwoWire *wire) { _address = 0x58; _wire = wire; @@ -11,11 +11,11 @@ SGP30::SGP30(TwoWire *wire) _ethanol = 0; _lastTime = 0; - _error = SGP30_OK; + _error = AirQuality_OK; } -bool SGP30::begin() +bool AirQuality::begin() { _wire->begin(); if (! isConnected()) return false; @@ -24,13 +24,13 @@ bool SGP30::begin() } -bool SGP30::isConnected() +bool AirQuality::isConnected() { _wire->beginTransmission(_address); return ( _wire->endTransmission() == 0); } -bool SGP30::measure(bool all) +bool AirQuality::measure(bool all) { if (millis() - _lastTime < 1000) return false; _lastTime = millis(); @@ -48,14 +48,14 @@ bool SGP30::measure(bool all) } -void SGP30::request() +void AirQuality::request() { _lastRequest = millis(); _command(0x2008); } -bool SGP30::read() +bool AirQuality::read() { if (_lastRequest == 0) return false; if (millis() - _lastRequest < 13) return false; @@ -63,7 +63,7 @@ bool SGP30::read() if (_wire->requestFrom(_address, (uint8_t)6) != 6) { - _error = SGP30_ERROR_I2C; + _error = AirQuality_ERROR_I2C; return false; } _co2 = _wire->read() << 8; @@ -71,7 +71,7 @@ bool SGP30::read() uint8_t crc = _wire->read(); if (_CRC8(_co2) != crc) { - _error = SGP30_ERROR_CRC; + _error = AirQuality_ERROR_CRC; return false; } _tvoc = _wire->read() << 8; @@ -79,22 +79,22 @@ bool SGP30::read() crc = _wire->read(); if (_CRC8(_tvoc) != crc) { - _error = SGP30_ERROR_CRC; + _error = AirQuality_ERROR_CRC; return false; } - _error = SGP30_OK; + _error = AirQuality_OK; return true; } -void SGP30::requestRaw() +void AirQuality::requestRaw() { _lastRequest = millis(); _command(0x2050); } -bool SGP30::readRaw() +bool AirQuality::readRaw() { if (_lastRequest == 0) return false; if (millis() - _lastRequest < 26) return false; @@ -102,7 +102,7 @@ bool SGP30::readRaw() if (_wire->requestFrom(_address, (uint8_t)6) != 6) { - _error = SGP30_ERROR_I2C; + _error = AirQuality_ERROR_I2C; return false; } _h2 = _wire->read() << 8; @@ -110,7 +110,7 @@ bool SGP30::readRaw() uint8_t crc = _wire->read(); if (_CRC8(_h2) != crc) { - _error = SGP30_ERROR_CRC; + _error = AirQuality_ERROR_CRC; return false; } _ethanol = _wire->read() << 8; @@ -118,27 +118,27 @@ bool SGP30::readRaw() crc = _wire->read(); if (_CRC8(_ethanol) != crc) { - _error = SGP30_ERROR_CRC; + _error = AirQuality_ERROR_CRC; return false; } - _error = SGP30_OK; + _error = AirQuality_OK; return true; } -float SGP30::getH2() +float AirQuality::getH2() { float cref = 0.5; // ppm return cref * exp((_srefH2 - _h2) * 1.953125e-3); } -float SGP30::getEthanol() +float AirQuality::getEthanol() { float cref = 0.4; // ppm return cref * exp((_srefEth - _ethanol) * 1.953125e-3); } -int SGP30::_command(uint16_t cmd) +int AirQuality::_command(uint16_t cmd) { _wire->beginTransmission(_address); _wire->write(cmd >> 8); @@ -148,7 +148,7 @@ int SGP30::_command(uint16_t cmd) } -int SGP30::_command(uint16_t cmd, uint16_t v1) +int AirQuality::_command(uint16_t cmd, uint16_t v1) { _wire->beginTransmission(_address); _wire->write(cmd >> 8); @@ -161,7 +161,7 @@ int SGP30::_command(uint16_t cmd, uint16_t v1) } -int SGP30::_command(uint16_t cmd, uint16_t v1, uint16_t v2) +int AirQuality::_command(uint16_t cmd, uint16_t v1, uint16_t v2) { _wire->beginTransmission(_address); _wire->write(cmd >> 8); @@ -176,7 +176,7 @@ int SGP30::_command(uint16_t cmd, uint16_t v1, uint16_t v2) return _error; } -uint8_t SGP30::_CRC8(uint16_t data) +uint8_t AirQuality::_CRC8(uint16_t data) { uint8_t val[2]; val[0] = data >> 8; @@ -198,7 +198,7 @@ uint8_t SGP30::_CRC8(uint16_t data) }; -void SGP30::_init() +void AirQuality::_init() { _command(0x2003); }; diff --git a/src/AirQuality.h b/src/AirQuality.h index a3c8a5e..0a81140 100644 --- a/src/AirQuality.h +++ b/src/AirQuality.h @@ -12,15 +12,15 @@ #include "Arduino.h" #include "Wire.h" -#define SGP30_OK 0x00 -#define SGP30_ERROR_CRC 0xFF -#define SGP30_ERROR_I2C 0xFE +#define AirQuality_OK 0x00 +#define AirQuality_ERROR_CRC 0xFF +#define AirQuality_ERROR_I2C 0xFE -class SGP30 +class AirQuality { public: - explicit SGP30(TwoWire *wire = &Wire); + explicit AirQuality(TwoWire *wire = &Wire); bool begin(); bool isConnected(); void GenericReset(); From 7290aa0b5cd0d119d33704ef453b154d3f4eaff1 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 21 Apr 2023 20:43:19 +0200 Subject: [PATCH 09/10] Add Magnet sensor --- library.properties | 2 +- src/Magnet.cpp | 19 +++++++++++++++++++ src/Magnet.h | 17 +++++++++++++++++ 3 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 src/Magnet.cpp create mode 100644 src/Magnet.h diff --git a/library.properties b/library.properties index 9d3bad8..c1c0fb2 100644 --- a/library.properties +++ b/library.properties @@ -7,5 +7,5 @@ paragraph= category=Device Control url=https://github.com/leaphy-robotics/leaphy-extensions-extra architectures=avr -includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h,LightSensor.h,TimeOfFlight.h +includes=Adafruit_NeoPixel.h,Adafruit_TCS34725.h,ledstrip.h,Leaphy_Extra.h,OLED_Display.h,LSM303AGR.h,LightSensor.h,TimeOfFlight.h,AirQuality.h,Magnet.h depends=Adafruit SSD1306,Adafruit GFX Library,Adafruit LSM303 Accel,Adafruit LIS2MDL,Adafruit BusIO Register,Adafruit I2CDevice,Adafruit SPIDevice,Adafruit Sensor,Wire,Adafruit_VL53L0X \ No newline at end of file diff --git a/src/Magnet.cpp b/src/Magnet.cpp new file mode 100644 index 0000000..efe9196 --- /dev/null +++ b/src/Magnet.cpp @@ -0,0 +1,19 @@ +#include "Magnet.h" + +Magnet::Magnet(int d0, int a0) +{ + this->d0 = d0; + this->a0 = a0; + pinMode(d0, INPUT); + pinMode(a0, INPUT); +} + +bool Magnet::readD() +{ + return digitalRead(d0); +} + +int Magnet::readA() +{ + return analogRead(a0); +} \ No newline at end of file diff --git a/src/Magnet.h b/src/Magnet.h new file mode 100644 index 0000000..4412472 --- /dev/null +++ b/src/Magnet.h @@ -0,0 +1,17 @@ +#ifndef MAGNET_H +#define MAGNET_H + +#include "Arduino.h" + +class Magnet +{ + public: + Magnet(int d0 = -1, int a0 = -1); + bool readD(); + int readA(); + private: + int d0; + int a0; +}; + +#endif \ No newline at end of file From 20085a78367993acffb9caec58b645c0a7e60a66 Mon Sep 17 00:00:00 2001 From: koen1711 <98043234+koen1711@users.noreply.github.com> Date: Fri, 28 Apr 2023 19:26:07 +0200 Subject: [PATCH 10/10] Added LeaphyCompass --- src/LeaphyCompass.cpp | 179 ++++++++++++++++++++++++++++++++++++++++++ src/LeaphyCompass.h | 62 +++++++++++++++ 2 files changed, 241 insertions(+) create mode 100644 src/LeaphyCompass.cpp create mode 100644 src/LeaphyCompass.h diff --git a/src/LeaphyCompass.cpp b/src/LeaphyCompass.cpp new file mode 100644 index 0000000..4142204 --- /dev/null +++ b/src/LeaphyCompass.cpp @@ -0,0 +1,179 @@ + + + + +#include "Arduino.h" +#include "QMC5883LCompass.h" +#include + +void QMC5883LCompass::init(){ + Wire.begin(); + _writeReg(0x0B,0x01); + setMode(0x01,0x0C,0x10,0X00); +} + +void QMC5883LCompass::_writeReg(byte r, byte v){ + Wire.beginTransmission(_ADDR); + Wire.write(r); + Wire.write(v); + Wire.endTransmission(); +} + + + + +void QMC5883LCompass::setMode(byte mode, byte odr, byte rng, byte osr){ + _writeReg(0x09,mode|odr|rng|osr); +} + + + + + +void QMC5883LCompass::setSmoothing(byte steps, bool adv){ + _smoothUse = true; + _smoothSteps = ( steps > 10) ? 10 : steps; + _smoothAdvanced = (adv == true) ? true : false; +} + + +void QMC5883LCompass::setCalibration(int x_min, int x_max, int y_min, int y_max, int z_min, int z_max){ + _calibrationUse = true; + + _vCalibration[0][0] = x_min; + _vCalibration[0][1] = x_max; + _vCalibration[1][0] = y_min; + _vCalibration[1][1] = y_max; + _vCalibration[2][0] = z_min; + _vCalibration[2][1] = z_max; +} + + + + +void QMC5883LCompass::read(){ + Wire.beginTransmission(_ADDR); + Wire.write(0x00); + int err = Wire.endTransmission(); + if (!err) { + Wire.requestFrom(_ADDR, (byte)6); + _vRaw[0] = (int)(int16_t)(Wire.read() | Wire.read() << 8); + _vRaw[1] = (int)(int16_t)(Wire.read() | Wire.read() << 8); + _vRaw[2] = (int)(int16_t)(Wire.read() | Wire.read() << 8); + + if ( _calibrationUse ) { + _applyCalibration(); + } + + if ( _smoothUse ) { + _smoothing(); + } + + + + } +} + + +void QMC5883LCompass::_applyCalibration(){ + int x_offset = (_vCalibration[0][0] + _vCalibration[0][1])/2; + int y_offset = (_vCalibration[1][0] + _vCalibration[1][1])/2; + int z_offset = (_vCalibration[2][0] + _vCalibration[2][1])/2; + int x_avg_delta = (_vCalibration[0][1] - _vCalibration[0][0])/2; + int y_avg_delta = (_vCalibration[1][1] - _vCalibration[1][0])/2; + int z_avg_delta = (_vCalibration[2][1] - _vCalibration[2][0])/2; + + int avg_delta = (x_avg_delta + y_avg_delta + z_avg_delta) / 3; + + float x_scale = (float)avg_delta / x_avg_delta; + float y_scale = (float)avg_delta / y_avg_delta; + float z_scale = (float)avg_delta / z_avg_delta; + + _vCalibrated[0] = (_vRaw[0] - x_offset) * x_scale; + _vCalibrated[1] = (_vRaw[1] - y_offset) * y_scale; + _vCalibrated[2] = (_vRaw[2] - z_offset) * z_scale; +} + + + +void QMC5883LCompass::_smoothing(){ + byte max = 0; + byte min = 0; + + if ( _vScan > _smoothSteps - 1 ) { _vScan = 0; } + + for ( int i = 0; i < 3; i++ ) { + if ( _vTotals[i] != 0 ) { + _vTotals[i] = _vTotals[i] - _vHistory[_vScan][i]; + } + _vHistory[_vScan][i] = ( _calibrationUse ) ? _vCalibrated[i] : _vRaw[i]; + _vTotals[i] = _vTotals[i] + _vHistory[_vScan][i]; + + if ( _smoothAdvanced ) { + max = 0; + for (int j = 0; j < _smoothSteps - 1; j++) { + max = ( _vHistory[j][i] > _vHistory[max][i] ) ? j : max; + } + + min = 0; + for (int k = 0; k < _smoothSteps - 1; k++) { + min = ( _vHistory[k][i] < _vHistory[min][i] ) ? k : min; + } + + _vSmooth[i] = ( _vTotals[i] - (_vHistory[max][i] + _vHistory[min][i]) ) / (_smoothSteps - 2); + } else { + _vSmooth[i] = _vTotals[i] / _smoothSteps; + } + } + + _vScan++; +} + + + +int QMC5883LCompass::getX(){ + return _get(0); +} + + + +int QMC5883LCompass::getY(){ + return _get(1); +} + + + +int QMC5883LCompass::getZ(){ + return _get(2); +} + + +int QMC5883LCompass::_get(int i){ + if ( _smoothUse ) + return _vSmooth[i]; + + if ( _calibrationUse ) + return _vCalibrated[i]; + + return _vRaw[i]; +} + + + + +byte QMC5883LCompass::getBearing(int azimuth){ + unsigned long a = azimuth / 22.5; + unsigned long r = a - (int)a; + byte sexdec = 0; + sexdec = ( r >= .5 ) ? ceil(a) : floor(a); + return sexdec; +} + + + +void QMC5883LCompass::getDirection(char* myArray, int azimuth){ + int d = getBearing(azimuth); + myArray[0] = _bearings[d][0]; + myArray[1] = _bearings[d][1]; + myArray[2] = _bearings[d][2]; +} \ No newline at end of file diff --git a/src/LeaphyCompass.h b/src/LeaphyCompass.h new file mode 100644 index 0000000..4dc4b9c --- /dev/null +++ b/src/LeaphyCompass.h @@ -0,0 +1,62 @@ +#ifndef QMC5883L_Compass +#define QMC5883L_Compass + +#include "Arduino.h" +#include "Wire.h" + + +class QMC5883LCompass{ + + public: + void init(); + void setMode(byte mode, byte odr, byte rng, byte osr); + void setSmoothing(byte steps, bool adv); + void setCalibration(int x_min, int x_max, int y_min, int y_max, int z_min, int z_max); + void read(); + int getX(); + int getY(); + int getZ(); + byte getBearing(int azimuth); + void getDirection(char* myArray, int azimuth); + + private: + void _writeReg(byte reg,byte val); + int _get(int index); + bool _smoothUse = false; + byte _smoothSteps = 5; + bool _smoothAdvanced = false; + byte _ADDR = 0x0D; + int _vRaw[3] = {0,0,0}; + int _vHistory[10][3]; + int _vScan = 0; + long _vTotals[3] = {0,0,0}; + int _vSmooth[3] = {0,0,0}; + void _smoothing(); + bool _calibrationUse = false; + int _vCalibration[3][2]; + int _vCalibrated[3]; + void _applyCalibration(); + const char _bearings[16][3] = { + {' ', ' ', 'N'}, + {'N', 'N', 'E'}, + {' ', 'N', 'E'}, + {'E', 'N', 'E'}, + {' ', ' ', 'E'}, + {'E', 'S', 'E'}, + {' ', 'S', 'E'}, + {'S', 'S', 'E'}, + {' ', ' ', 'S'}, + {'S', 'S', 'W'}, + {' ', 'S', 'W'}, + {'W', 'S', 'W'}, + {' ', ' ', 'W'}, + {'W', 'N', 'W'}, + {' ', 'N', 'W'}, + {'N', 'N', 'W'}, + }; + + + +}; + +#endif