mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
81 lines
3.2 KiB
Markdown
81 lines
3.2 KiB
Markdown
|
|
[![Arduino CI](https://github.com/RobTillaart/AnalogPin/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
[![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)
|
|
[![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)
|
|
|
|
|
|
# AnalogPin
|
|
|
|
Arduino library to add functionality on top of analogRead().
|
|
|
|
|
|
## Description
|
|
|
|
AnalogPin is an Arduino class that adds noise filtering and smoothing to analogRead().
|
|
Furthermore it can speed up the analogRead() function by tuning the pre-scaler.
|
|
This latter is AVR only.
|
|
|
|
|
|
## 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.
|
|
|
|
|
|
## Operation
|
|
|
|
**get/setPrescaler(uint8_t prescale)** can be used to speed up analogRead().
|
|
The effect is that both the accuracy and precision are affected.
|
|
You should verify if this is acceptable for your project.
|
|
***Works only for AVR based boards***
|
|
|
|
**get/setNoiseThreshold(uint8_t noise)** is used to set the noise threshold to be used by the **read()** function.
|
|
|
|
**read(bool twice)** implements an **analogRead()** that suppresses small noise fluctuations.
|
|
The parameter twice is used to force analogRead() to be executed twice to reduce noise from the multiplexing.
|
|
|
|
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();
|
|
```
|
|
|
|
**get/setSmoothWeight(uint8_t alpha)** is used to set the weight factor for the **readSmoothed()** function.
|
|
|
|
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.
|
|
|
|
|
|
## Future
|
|
|
|
- update documentation
|
|
- advantage of certain functions, when to use
|
|
- more examples
|
|
- **volts()** + get/setFactor(float f)
|
|
-
|
|
|
|
|