80 lines
3.2 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/AnalogPin/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
2021-10-17 19:20:48 +02:00
[![Arduino-lint](https://github.com/RobTillaart/AnalogPin/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/AnalogPin/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/AnalogPin/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/AnalogPin/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/AnalogPin/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/AnalogPin.svg?maxAge=3600)](https://github.com/RobTillaart/AnalogPin/releases)
2021-10-17 19:20:48 +02:00
2020-11-27 11:10:47 +01:00
# AnalogPin
2021-01-29 12:31:58 +01:00
2021-12-12 15:57:24 +01:00
Arduino library to add functionality on top of analogRead().
2020-11-27 11:10:47 +01:00
2021-01-29 12:31:58 +01:00
2020-11-27 11:10:47 +01:00
## Description
2021-01-29 12:31:58 +01:00
2021-12-12 15:57:24 +01:00
AnalogPin is an Arduino class that adds noise filtering and smoothing to analogRead().
2021-10-17 19:20:48 +02:00
Furthermore it can speed up the analogRead() function by tuning the pre-scaler.
2020-11-27 11:10:47 +01:00
This latter is AVR only.
2021-01-29 12:31:58 +01:00
2021-10-17 19:20:48 +02:00
## Interface
- **AnalogPin(uint8_t pin)** constructor with analogue pin as parameter.
- **void setPrescaler(uint8_t prescale = 7)** AVR only pre-scaler.
- **uint8_t getPrescaler()** return pre-scaler set.
- **void setNoiseThreshold(uint8_t noise = 0)** set noise level that should be ignored. Typical 0..2.
- **uint8_t getNoiseThreshold()** return set value.
- **void setSmoothWeight(uint8_t alpha = 0)** alpha = 0..31, parameter for low pass filter.
- **uint8_t getSmoothWeight(void)** returns set alpha.
- **int read(bool twice = false)** read function, optional read twice to stabilize.
- **int readSmoothed()** read version that uses low pass filter.
- **int readPrevious()** returns previous read value.
- **int readLast()** returns last read value without reading a new one.
2020-11-27 11:10:47 +01:00
2021-10-17 19:20:48 +02:00
## Operation
2020-11-27 11:10:47 +01:00
2021-12-12 15:57:24 +01:00
**get/setPrescaler(uint8_t prescale)** can be used to speed up analogRead().
2021-10-17 19:20:48 +02:00
The effect is that both the accuracy and precision are affected.
2020-11-27 11:10:47 +01:00
You should verify if this is acceptable for your project.
***Works only for AVR based boards***
2021-12-12 15:57:24 +01:00
**get/setNoiseThreshold(uint8_t noise)** is used to set the noise threshold to be used by the **read()** function.
2020-11-27 11:10:47 +01:00
2021-12-12 15:57:24 +01:00
**read(bool twice)** implements an **analogRead()** that suppresses small noise fluctuations.
2021-10-17 19:20:48 +02:00
The parameter twice is used to force analogRead() to be executed twice to reduce noise from the multiplexing.
2020-11-27 11:10:47 +01:00
Example: if the previous read has the value 300 and you
want to interpret all subsequent readings between 290
and 310 as 300 (the same) your code should look like:
```
AP.setNoiseThreshold(10);
AP.read();
```
2021-12-12 15:57:24 +01:00
**get/setSmoothWeight(uint8_t alpha)** is used to set the weight factor for the **readSmoothed()** function.
2020-11-27 11:10:47 +01:00
The weight of the previous read is **alpha/32**.
A higher alpha will dampen the signal more, a lower alpha
will follow the actual signal better.
This can be used to suppress noise too.
```
AP.setSmoothWeight(4); // weight = 4/32 = 1/8 = 12.5%
AP.readSmoothed();
```
**readSmoothed()** implements an analogRead with a running average build in.
2021-10-17 19:20:48 +02:00
## Future
2021-12-12 15:57:24 +01:00
- update documentation
- advantage of certain functions, when to use
2021-10-17 19:20:48 +02:00
- more examples
2021-12-12 15:57:24 +01:00
- **volts()** + get/setFactor(float f)
2022-10-28 21:33:10 +02:00
- move code to .cpp
2021-10-17 19:20:48 +02:00
2020-11-27 11:10:47 +01:00