2023-02-18 15:26:18 +01:00
..
2023-02-18 15:26:18 +01:00
2021-12-29 13:37:09 +01:00
2023-02-18 15:26:18 +01:00
2022-11-26 17:40:57 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00
2023-02-18 15:26:18 +01:00

Arduino CI Arduino-lint JSON check License: MIT GitHub release

TSL235R

Arduino library for the TSL235R light to frequency convertor.

Description

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.

The library is not tested extensively yet.

The sensor operating voltage is between 2.7 and 5.5 max. This can be set in the constructor, or runtime adjusted.

For measurements below 1 uW/cm2 one should measure for multiple seconds. Above 1 uW/cm2 1 second or shorter is OK.

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. The library provides two irradiance() functions to do that for you.

Connection

Always check the datasheet.

//  PIN 1  -  GND
//  PIN 2  -  VDD      2.7 V .. 5.5 V
//  PIN 3  -  SIGNAL   1 Hz  .. 800 KHz

Interface

#include "TSL235R.h"

Constructor

  • TSL235R(float voltage = TSL235_DEFAULT_VOLTAGE) constructor, optionally one can give the operational voltage to add a small correction (< 1.5%). Default voltage is 5.0 Volts, this define can be overruled from command line.

Irradiance

  • float irradiance(uint32_t Hz) returns the irradiance in uW/cm2. Note that Hz implies the measured pulses for 1 second.
  • float irradiance(uint32_t pulses, uint32_t milliseconds) returns the irradiance in uW/cm2. This formula is used for other duration than 1 second. To get irradiance in W/m2 one must divide by 100.
  • 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.

Configuration

  • float getFactor() returns the inner conversion factor from Hz to Watt/cm2.
  • void setWavelength(uint16_t wavelength = 635) sets the wavelength so the formulas can use a correction factor. At the default wavelength of 635 nm the wavelength correction factor == 1.0.
  • uint16_t getWavelength() returns the set wavelength.
  • float getWaveLengthFactor() returns the wavelength correction factor. As the sensor is most sensitive around 750 nm this value helps to normalize the signal. This works only for (almost) monochromatic light.
  • void setVoltage(float voltage = TSL235_DEFAULT_VOLTAGE) sets the voltage so the formulas can use a correction factor. 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.

Operations

See examples for typical usage.

Future

Must

  • improve documentation
  • test test test

Should

Could

  • investigate hardware solutions for e.g. divide by 100 or 1000 or so.
  • investigate correction factor for white light and mixed light sources.
  • investigate calibration factor for timing of processor used.

Wont

  • irradiance(pulses, millis) can be given a default of 1000 millis.
    • makes irradiance(Hz) obsolete.
    • performance is less!