2021-05-30 08:16:15 -04:00
|
|
|
//
|
|
|
|
// FILE: TSL235R_pulses.ino
|
|
|
|
// AUTHOR: Rob Tillaart
|
2021-06-04 09:58:39 -04:00
|
|
|
// VERSION: 0.1.1
|
2021-05-30 08:16:15 -04:00
|
|
|
// PURPOSE: demo
|
|
|
|
// DATE: 2021-05-29
|
|
|
|
|
2021-06-04 09:58:39 -04:00
|
|
|
// NOTE
|
|
|
|
// This code will work up to ~150 kHz on an Arduino UNO
|
|
|
|
// above that pulses come in faster than the code can reliably handle
|
|
|
|
|
2021-05-30 08:16:15 -04:00
|
|
|
//
|
|
|
|
// Digital Pin layout ARDUINO
|
|
|
|
// =============================
|
|
|
|
// 2 IRQ 0 - to TSL235R
|
|
|
|
// 3 IRQ 1 - to TSL235R
|
|
|
|
//
|
|
|
|
// PIN 1 - GND
|
|
|
|
// PIN 2 - VDD - 5V
|
|
|
|
// PIN 3 - SIGNAL
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#include "TSL235R.h"
|
|
|
|
|
|
|
|
TSL235R mySensor;
|
|
|
|
|
|
|
|
volatile uint32_t cnt1 = 0;
|
|
|
|
uint32_t oldcnt1 = 0;
|
|
|
|
uint32_t t = 0;
|
|
|
|
uint32_t lastMeasurement = 0;
|
|
|
|
|
|
|
|
|
|
|
|
void count_irq1()
|
|
|
|
{
|
|
|
|
cnt1++;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// SETUP
|
|
|
|
//
|
|
|
|
void setup()
|
|
|
|
{
|
|
|
|
Serial.begin(115200);
|
|
|
|
Serial.println(__FILE__);
|
|
|
|
|
2021-06-04 09:58:39 -04:00
|
|
|
pinMode(2, INPUT_PULLUP);
|
|
|
|
attachInterrupt(0, count_irq1, FALLING);
|
2021-05-30 08:16:15 -04:00
|
|
|
|
|
|
|
mySensor.setWavelength(450);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
uint32_t now = millis();
|
|
|
|
if (now - lastMeasurement >= 1000)
|
|
|
|
{
|
|
|
|
|
|
|
|
t = cnt1;
|
|
|
|
uint32_t Hz = t - oldcnt1;
|
|
|
|
oldcnt1 = t;
|
2021-06-04 09:58:39 -04:00
|
|
|
|
2021-05-30 08:16:15 -04:00
|
|
|
Serial.print("irradiance(Hz):\t\t");
|
|
|
|
Serial.print(mySensor.irradiance(Hz)); // assumption 1 second
|
|
|
|
Serial.println(" uW/cm2");
|
|
|
|
|
|
|
|
Serial.print("irradiance(puls, time):\t");
|
|
|
|
Serial.print(mySensor.irradiance(Hz, now - lastMeasurement)); // accurate time
|
|
|
|
Serial.println(" uW/cm2");
|
|
|
|
|
|
|
|
lastMeasurement = now;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// -- END OF FILE --
|