2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/PulsePattern/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-12-24 15:10:06 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/PulsePattern/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/PulsePattern/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/PulsePattern/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/PulsePattern/actions/workflows/jsoncheck.yml)
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/PulsePattern/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/PulsePattern.svg?maxAge=3600)](https://github.com/RobTillaart/PulsePattern/releases)
|
|
|
|
|
|
|
|
|
2020-11-27 11:28:57 +01:00
|
|
|
# PulsePattern
|
|
|
|
|
2021-12-24 15:10:06 +01:00
|
|
|
Arduino Library to generate repeating pulse patterns **AVR ONLY**.
|
|
|
|
|
2020-11-27 11:28:57 +01:00
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
This is an **experimental** library to generate pulse patterns by means of an Arduino UNO.
|
|
|
|
As the library uses **AVR hardware timers** it is definitely **NOT** working for ESP
|
|
|
|
or other non-AVR processors.
|
|
|
|
|
|
|
|
The library uses timer1 for the timing of the pulses.
|
2021-12-24 15:10:06 +01:00
|
|
|
Therefore the class is implemented with a static instance called PPO.
|
|
|
|
Still by calling **init()** one can change all parameters of the process.
|
|
|
|
One should note that calling **init()** forces the timer to stop.
|
2020-11-27 11:28:57 +01:00
|
|
|
|
|
|
|
The timer code is based upon the website of Nick Gammon which
|
|
|
|
holds quite a lot of good solid material (Thanks Nick!).
|
|
|
|
https://gammon.com.au/forum/bbshowpost.php?bbtopic_id=123
|
|
|
|
|
|
|
|
Use with care.
|
|
|
|
|
2021-12-24 15:10:06 +01:00
|
|
|
(there is no active development)
|
|
|
|
|
|
|
|
|
2020-11-27 11:28:57 +01:00
|
|
|
## Interface
|
|
|
|
|
|
|
|
- **PulsePattern()** constructor
|
2021-12-24 15:10:06 +01:00
|
|
|
- **void init(uint8_t pin, uint16_t\*ar, uint8_t size, luint8_t evel, uint8_t prescaler)** initializer of the Timer1
|
2021-01-29 12:31:58 +01:00
|
|
|
- pin that outputs the pattern
|
|
|
|
- array of durations
|
|
|
|
- size (or part) of the array to be used
|
|
|
|
- starting level HIGH/LOW
|
|
|
|
- prescaler, one of the 5 defines from .h file (table below)
|
2021-12-24 15:10:06 +01:00
|
|
|
- **void setFactor(float perc)** percentage = factor to correct timing (relative).
|
|
|
|
- **float getFactor()** get the internal used factor. Due to rounding it can be slightly different.
|
|
|
|
- **void stop()** stop the pattern generator
|
2022-03-11 10:36:49 +01:00
|
|
|
- **void start(uint32_t times = PP_CONTINUOUS)** start the pattern generator.
|
|
|
|
Default in the continuous mode to be backwards compatible.
|
|
|
|
**PP_CONTINUOUS** == 0xFFFFFFFF, so times should be less than 4294967295. For convenience there is a **PP_ONCE** == 1 defined.
|
2021-12-24 15:10:06 +01:00
|
|
|
- **void cont()** continue the pattern generator from the last stopped place (approx).
|
|
|
|
- **bool isRunning()** status indicator
|
|
|
|
- **void worker()** must be public otherwise the ISR cannot call it.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2020-11-27 11:28:57 +01:00
|
|
|
There is some bad understood __vector_11() error when worker() is private.
|
|
|
|
|
2021-12-24 15:10:06 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Prescaler constants
|
2020-11-27 11:28:57 +01:00
|
|
|
|
2021-12-24 15:10:06 +01:00
|
|
|
| Value | Prescaler | Timer1 | Notes |
|
|
|
|
|:-----:|:---------------|:-----------|:-----------:|
|
|
|
|
| 0 | NO_CLOCK | timer off |
|
|
|
|
| 1 | PRESCALE_1 | clk / 1 |
|
|
|
|
| 2 | PRESCALE_8 | clk / 8 |
|
|
|
|
| 3 | PRESCALE_64 | clk / 64 |
|
|
|
|
| 4 | PRESCALE_256 | clk / 250 |
|
|
|
|
| 5 | PRESCALE_1024 | clk / 1024 | about 1 ms / pulse
|
|
|
|
| 6 | EXT_T1_FALLING | T1 = pin 5 | not tested
|
|
|
|
| 7 | EXT_T2_RISING | | not tested
|
|
|
|
|
|
|
|
|
|
|
|
# Operation
|
|
|
|
|
|
|
|
See examples.
|
2020-11-27 11:28:57 +01:00
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Future
|
|
|
|
|
2021-12-24 15:10:06 +01:00
|
|
|
- ESP32 variant of this class (base class -> AVR -> ESP class)
|
2021-01-29 12:31:58 +01:00
|
|
|
- pulse recorder class to record / generate patterns
|
2022-03-11 10:36:49 +01:00
|
|
|
- add interval between patterns?
|
|
|
|
- or is this just LOW/HIGH for a certain time.
|
2021-01-29 12:31:58 +01:00
|
|
|
if time permits ...
|