2021-05-30 14:16:15 +02:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/TSL235R/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-12-29 13:37:09 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/TSL235R/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/TSL235R/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/TSL235R/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/TSL235R/actions/workflows/jsoncheck.yml)
|
2021-05-30 14:16:15 +02:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/TSL235R/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/TSL235R.svg?maxAge=3600)](https://github.com/RobTillaart/TSL235R/releases)
|
|
|
|
|
|
|
|
|
|
|
|
# TSL235R
|
|
|
|
|
|
|
|
Arduino library for the TSL235R light to frequency convertor.
|
|
|
|
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
2022-11-26 17:40:57 +01:00
|
|
|
This library does not measure the frequency.
|
|
|
|
That should be done with an interrupt function (user code).
|
|
|
|
The library provides functions to calculate the radiation and
|
|
|
|
has functions to compensate e.g. for wavelength and voltage used.
|
2021-05-30 14:16:15 +02:00
|
|
|
|
|
|
|
The library is not tested extensively yet.
|
|
|
|
|
|
|
|
The sensor operating voltage is between 2.7 and 5.5 max.
|
2022-11-26 17:40:57 +01:00
|
|
|
This can be set in the constructor, or runtime adjusted.
|
2021-05-30 14:16:15 +02:00
|
|
|
|
2022-11-26 17:40:57 +01:00
|
|
|
For measurements below 1 uW/cm2 one should measure for multiple seconds.
|
2021-05-30 14:16:15 +02:00
|
|
|
Above 1 uW/cm2 1 second or shorter is OK.
|
|
|
|
|
2022-11-26 17:40:57 +01:00
|
|
|
Note that for longer and shorter measurements than 1 second one must
|
|
|
|
convert the value to Hz, which is the number of pulses in 1 second.
|
2023-02-18 15:26:18 +01:00
|
|
|
The library provides two **irradiance()** functions to do that for you.
|
|
|
|
|
|
|
|
|
|
|
|
#### Related
|
|
|
|
|
|
|
|
- https://github.com/RobTillaart/TSL235R pulse based irradiance variant.
|
|
|
|
- https://github.com/RobTillaart/TSL260R analog IR irradiance variant.
|
|
|
|
- https://github.com/RobTillaart/AnalogUVSensor
|
|
|
|
- https://github.com/RobTillaart/ML8511 UV sensor
|
2021-05-30 14:16:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
## Connection
|
|
|
|
|
2022-11-26 17:40:57 +01:00
|
|
|
Always check the datasheet.
|
|
|
|
|
2021-05-30 14:16:15 +02:00
|
|
|
```
|
2022-11-26 17:40:57 +01:00
|
|
|
// PIN 1 - GND
|
|
|
|
// PIN 2 - VDD 2.7 V .. 5.5 V
|
|
|
|
// PIN 3 - SIGNAL 1 Hz .. 800 KHz
|
2021-05-30 14:16:15 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
2023-02-18 15:26:18 +01:00
|
|
|
```cpp
|
|
|
|
#include "TSL235R.h"
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Constructor
|
|
|
|
|
|
|
|
- **TSL235R(float voltage = TSL235_DEFAULT_VOLTAGE)** constructor, optionally one can give the operational voltage
|
2022-11-26 17:40:57 +01:00
|
|
|
to add a small correction (< 1.5%).
|
2023-02-18 15:26:18 +01:00
|
|
|
Default voltage is 5.0 Volts, this define can be overruled from command line.
|
|
|
|
|
|
|
|
|
|
|
|
#### Irradiance
|
|
|
|
|
2021-05-30 14:16:15 +02:00
|
|
|
- **float irradiance(uint32_t Hz)** returns the irradiance in uW/cm2.
|
2021-06-04 15:58:39 +02:00
|
|
|
Note that Hz implies the measured pulses for 1 second.
|
2022-11-26 17:40:57 +01:00
|
|
|
- **float irradiance(uint32_t pulses, uint32_t milliseconds)** returns the irradiance in uW/cm2.
|
2021-05-30 14:16:15 +02:00
|
|
|
This formula is used for other duration than 1 second.
|
|
|
|
To get irradiance in W/m2 one must divide by 100.
|
2022-11-26 17:40:57 +01:00
|
|
|
- **float irradiance_HS(uint32_t pulses, uint32_t microseconds)** returns the irradiance in uW/cm2.
|
|
|
|
This formula is used when the time is measured in microseconds.
|
|
|
|
This is the most accurate measurement.
|
2023-02-18 15:26:18 +01:00
|
|
|
|
|
|
|
#### Configuration
|
|
|
|
|
2021-05-30 14:16:15 +02:00
|
|
|
- **float getFactor()** returns the inner conversion factor from Hz to Watt/cm2.
|
2021-12-29 13:37:09 +01:00
|
|
|
- **void setWavelength(uint16_t wavelength = 635)** sets the wavelength so the formulas can use a
|
2022-11-26 17:40:57 +01:00
|
|
|
correction factor.
|
|
|
|
At the default wavelength of 635 nm the wavelength correction factor == 1.0.
|
|
|
|
- **uint16_t getWavelength()** returns the set wavelength.
|
2021-05-30 14:16:15 +02:00
|
|
|
- **float getWaveLengthFactor()** returns the wavelength correction factor.
|
|
|
|
As the sensor is most sensitive around 750 nm this value helps to normalize the signal.
|
2021-12-29 13:37:09 +01:00
|
|
|
This works only for (almost) monochromatic light.
|
2023-02-18 15:26:18 +01:00
|
|
|
- **void setVoltage(float voltage = TSL235_DEFAULT_VOLTAGE)** sets the voltage so the formulas can use a correction factor.
|
2022-11-26 17:40:57 +01:00
|
|
|
This voltage correction factor is rather small < 1.5%.
|
|
|
|
Note: this voltage can be changed runtime.
|
|
|
|
- **float getVoltage()** returns the set voltage, by constructor or by **setVoltage()**.
|
|
|
|
Default voltage is 5.0 Volts.
|
2021-05-30 14:16:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
## Operations
|
|
|
|
|
|
|
|
See examples for typical usage.
|
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
2023-02-18 15:26:18 +01:00
|
|
|
#### Must
|
|
|
|
|
2021-12-29 13:37:09 +01:00
|
|
|
- improve documentation
|
|
|
|
- test test test
|
2022-11-26 17:40:57 +01:00
|
|
|
|
2023-02-18 15:26:18 +01:00
|
|
|
#### Should
|
|
|
|
|
|
|
|
#### Could
|
2022-11-26 17:40:57 +01:00
|
|
|
|
|
|
|
- investigate hardware solutions for e.g. divide by 100 or 1000 or so.
|
2021-05-30 14:16:15 +02:00
|
|
|
- investigate correction factor for white light and mixed light sources.
|
2021-12-29 13:37:09 +01:00
|
|
|
- investigate calibration factor for timing of processor used.
|
2022-11-26 17:40:57 +01:00
|
|
|
|
2023-02-18 15:26:18 +01:00
|
|
|
#### Wont
|
|
|
|
|
|
|
|
- irradiance(pulses, millis) can be given a default of 1000 millis.
|
|
|
|
- makes irradiance(Hz) obsolete.
|
|
|
|
- performance is less!
|
|
|
|
|