206 lines
3.3 KiB
C
Raw Normal View History

2023-09-14 21:35:55 +02:00
#pragma once
//
// FILE: PulseDivider.h
// AUTHOR: Rob Tillaart
2023-09-17 10:41:15 +02:00
// VERSION: 0.1.1
2023-09-14 21:35:55 +02:00
// DATE: 2023-09-13
2023-09-17 10:41:15 +02:00
// PURPOSE: Arduino library to divide a pulse stream with a float factor.
2023-09-14 21:35:55 +02:00
// URL: https://github.com/RobTillaart/PulseDivider
//
2023-09-17 10:41:15 +02:00
2023-09-14 21:35:55 +02:00
#include "Arduino.h"
2023-09-17 10:41:15 +02:00
#define PULSEDIVIDER_LIB_VERSION (F("0.1.1"))
2023-09-14 21:35:55 +02:00
class PulseDivider
{
public:
// CONSTRUCTOR
PulseDivider(uint8_t inPin, uint8_t outPin, uint16_t inCount, uint16_t outCount,
uint32_t duration = 1, uint8_t edge = RISING, bool invert = false)
{
setInPin(inPin);
setOutPin(outPin);
setRatio(inCount, outCount);
2023-09-17 10:41:15 +02:00
setDuration(duration);
setEdge(edge);
setInvert(invert);
2023-09-14 21:35:55 +02:00
2023-09-17 10:41:15 +02:00
_prevState = _read();
2023-09-14 21:35:55 +02:00
stop();
}
///////////////////////////////////////////
//
// GETTERS && SETTERS
//
void setInPin(uint8_t inPin)
{
_inPin = inPin;
pinMode(_inPin, INPUT);
}
uint8_t getInPin()
{
return _inPin;
}
void setOutPin(uint8_t outPin)
{
_outPin = outPin;
pinMode(_outPin, OUTPUT);
2023-09-17 10:41:15 +02:00
_write(_invert ? HIGH : LOW);
2023-09-14 21:35:55 +02:00
}
uint8_t getOutPin()
{
return _outPin;
}
void setRatio(uint16_t inCount, uint16_t outCount = 1)
{
_inCount = inCount;
_outCount = outCount;
_counter = inCount / 2;
}
float getRatio()
{
return float(_inCount) / _outCount;
}
void setDuration(uint32_t duration)
{
_duration = duration;
}
uint32_t getDuration()
{
return _duration;
}
void setEdge(uint8_t edge)
{
2023-09-17 10:41:15 +02:00
if ((edge != FALLING) && (edge != RISING)) return;
2023-09-14 21:35:55 +02:00
_edge = edge;
}
uint8_t getEdge()
{
return _edge;
}
void setInvert(bool invert)
{
_invert = invert;
2023-09-17 10:41:15 +02:00
_write(_invert ? HIGH : LOW);
2023-09-14 21:35:55 +02:00
}
bool getInvert()
{
return _invert;
}
///////////////////////////////////////////
//
// CONTROL
//
void start()
{
2023-09-17 10:41:15 +02:00
_prevState = _read();
2023-09-14 21:35:55 +02:00
_counter = _inCount / 2;
_running = true;
}
void stop()
{
_running = false;
2023-09-17 10:41:15 +02:00
_write(_invert ? HIGH : LOW);
2023-09-14 21:35:55 +02:00
}
bool isRunning()
{
return _running;
}
///////////////////////////////////////////
//
// MAIN WORKER
//
void check()
{
2023-09-17 10:41:15 +02:00
if (_running == false) return;
uint8_t value = _read();
if (_prevState != value)
2023-09-14 21:35:55 +02:00
{
2023-09-17 10:41:15 +02:00
if (((_edge == RISING) and (value == HIGH)) or
((_edge == FALLING) and (value == LOW)))
{
doPulse();
}
2023-09-14 21:35:55 +02:00
}
_prevState = value;
2023-09-17 10:41:15 +02:00
// reset the output?
if (_pulseStarted and (micros() - _start >= _duration))
2023-09-14 21:35:55 +02:00
{
2023-09-17 10:41:15 +02:00
_write(_invert ? HIGH : LOW);
_pulseStarted = false;
2023-09-14 21:35:55 +02:00
}
}
2023-09-17 10:41:15 +02:00
inline void doPulse()
2023-09-14 21:35:55 +02:00
{
_counter += _outCount;
if (_counter >= _inCount)
{
_counter -= _inCount;
_start = micros();
2023-09-17 10:41:15 +02:00
_write(_invert ? LOW : HIGH);
_pulseStarted = true;
2023-09-14 21:35:55 +02:00
}
}
private:
2023-09-17 10:41:15 +02:00
// default reference
void _write(uint8_t value)
{
digitalWrite(_outPin, value);
}
2023-09-14 21:35:55 +02:00
2023-09-17 10:41:15 +02:00
uint8_t _read()
{
return digitalRead(_inPin);
}
uint8_t _inPin;
uint8_t _outPin;
uint16_t _inCount = 1;
uint16_t _outCount = 1;
uint16_t _counter = 0;
uint32_t _duration = 1;
uint8_t _edge = RISING;
bool _invert = false;
bool _running = false;
uint8_t _prevState = LOW;
uint32_t _start = 0;
bool _pulseStarted = false;
2023-09-14 21:35:55 +02:00
};
// -- END OF FILE --