ASCEND Flight Software
Loading...
Searching...
No Matches
Public Member Functions | Private Attributes | List of all members
BME680Sensor Class Reference

A class to interface with the Adafruit BME680 sensor for environmental data collection. More...

#include <BME680Sensor.h>

Inheritance diagram for BME680Sensor:
Collaboration diagram for BME680Sensor:

Public Member Functions

 BME680Sensor ()
 Default constructor for the BME680Sensor class.
 
 BME680Sensor (unsigned long minimum_period)
 Parameterized constructor for the BME680Sensor class.
 
bool verify () override
 Verifies the connection and readiness of the BME680 sensor.
 
String readData () override
 Reads sensor data and returns it in CSV format.
 
void readDataPacket (uint8_t *&packet) override
 Reads sensor data and appends it to the packet byte array.
 
String decodeToCSV (uint8_t *&packet) override
 Decodes the packet data and returns it in CSV format.
 
- Public Member Functions inherited from Sensor
 Sensor (String sensor_name, String csv_header, unsigned long minimum_period)
 
 Sensor (String sensor_name, String csv_header)
 
 Sensor (String sensor_name, String csv_header, int fields)
 Construct a new Sensor object with default minimum_period of 0 (depreciated)
 
 Sensor (String sensor_name, String csv_header, int fields, unsigned long minimum_period)
 Construct a new Sensor object (Depreciated)
 
unsigned long getPeriod () const
 Get the minimum minimum_period between sensor reads in ms.
 
void setPeriod (int minimum_period)
 Set the minimum minimum_period between sensor reads in ms.
 
unsigned long getLastExecution () const
 Get the system time of the last execution in ms.
 
void setLastExecution (int last_execution)
 Set the system time of the last execution in ms.
 
const String & getSensorCSVHeader () const
 Get the csv header string associated with this sensor.
 
void getDataPacket (uint32_t &sensor_id, uint8_t *&packet)
 Append the data from a sensor to the packet if the minium period is satisfied.
 
String readEmpty () const
 Returns CSV line in the same format as readData() but with "-" instead of data.
 
String getDataCSV ()
 Uses readData and readEmpty to get the data-filled or empty-celled CSV line for the sensor.
 
- Public Member Functions inherited from Device
 Device (String device_name)
 Default constructor, sets a max_attempt of 1 (device recovery won't be attempted)
 
 Device (String device_name, int max_attempts, int wait_factor)
 
const String & getDeviceName ()
 
bool getVerified ()
 Get if the Device is Verified.
 
void recoveryConfig (int max_attempts, int wait_factor)
 Set recovery config (used keep default constructor)
 
void setWaitFactor (int wait_factor)
 Set wait_factor.
 
void setMaxAttempts (int max_attempts)
 Set max_attempts.
 
bool attemptConnection ()
 If the sensor is verified, return true, if not and it has been long enough since the last attempt (decided by wait_factor and attempt_number), attempt to reverify (reinitialize) it.
 

Private Attributes

Adafruit_BME680 bme
 

Additional Inherited Members

- Protected Attributes inherited from Sensor
int num_fields
 
- Protected Attributes inherited from Device
bool verified
 
String device_name
 

Detailed Description

A class to interface with the Adafruit BME680 sensor for environmental data collection.

The BME680Sensor class is responsible for interacting with the BME680 sensor to gather environmental data such as temperature, pressure, humidity, and gas resistance. It also provides an approximation of altitude based on sea level pressure.

This class inherits from the Sensor base class and overrides its virtual methods to implement the specific functionality required to read and verify data from the BME680 sensor.

Key functionalities:

Constructor & Destructor Documentation

◆ BME680Sensor() [1/2]

BME680Sensor::BME680Sensor ( )

Default constructor for the BME680Sensor class.

Initializes the sensor object with a default minimum period of 0 milliseconds.

◆ BME680Sensor() [2/2]

BME680Sensor::BME680Sensor ( unsigned long  minimum_period)

Parameterized constructor for the BME680Sensor class.

This constructor initializes the BME680Sensor with a specified minimum period between sensor readings. It passes sensor-specific information like the name, CSV header, number of fields, and the minimum period between reads to the base Sensor class constructor.

Parameters
minimum_periodThe minimum time (in milliseconds) between consecutive sensor reads.

Member Function Documentation

◆ decodeToCSV()

String BME680Sensor::decodeToCSV ( uint8_t *&  packet)
overridevirtual

Decodes the packet data and returns it in CSV format.

Decodes the packet data from the BME680 sensor and returns it in CSV format. The data includes temperature, pressure, humidity, gas resistance, and an approximate altitude based on sea-level pressure.

Parameters
packet- Packet to decode.
Returns
String - A string containing the sensor readings

Reimplemented from Sensor.

◆ readData()

String BME680Sensor::readData ( )
overridevirtual

Reads sensor data and returns it in CSV format.

Performs a reading from the BME680 sensor, which includes temperature, pressure, humidity, gas resistance, and an approximate altitude based on sea-level pressure. If the sensor fails to perform a reading, a placeholder string ("-, -, -, -, -, ") is returned.

Returns
String - A string containing the sensor readings formatted as: "Temperature (Celsius), Pressure (hPa), Humidity (%), Gas Resistance (KOhms), Altitude (meters)".

Implements Sensor.

◆ readDataPacket()

void BME680Sensor::readDataPacket ( uint8_t *&  packet)
overridevirtual

Reads sensor data and appends it to the packet byte array.

Reads data from the BME680 sensor and appends it to the passed uint8_t array pointer, incrementing it while doing so. The data includes temperature, pressure, humidity, gas resistance, and an approximate altitude based on sea-level pressure.

Parameters
packet- Pointer to the packet byte array.

Reimplemented from Sensor.

◆ verify()

bool BME680Sensor::verify ( )
overridevirtual

Verifies the connection and readiness of the BME680 sensor.

This function initializes the sensor and configures it by setting temperature, humidity, and pressure oversampling, along with the gas heater and IIR filter. It checks if the sensor is properly connected and ready for reading data.

Returns
true - If the sensor is detected and successfully initialized.
false - If the sensor is not detected or fails to initialize.

Implements Sensor.

Member Data Documentation

◆ bme

Adafruit_BME680 BME680Sensor::bme
private

The documentation for this class was generated from the following files: