mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
64 lines
2.5 KiB
Markdown
64 lines
2.5 KiB
Markdown
|
|
[![Arduino CI](https://github.com/RobTillaart/GAMMA/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/GAMMA/blob/master/LICENSE)
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/GAMMA.svg?maxAge=3600)](https://github.com/RobTillaart/GAMMA/releases)
|
|
|
|
# GAMMA
|
|
|
|
Arduino Library for the GAMMA function to adjust brightness of LED's etc.
|
|
|
|
## Description
|
|
|
|
This library is provides a gamma lookup class. It is typical used to
|
|
change the intensity / brightness of a LED to match the human eye.
|
|
When a LED is given 50% PWM it looks far brighter for the eye.
|
|
|
|
This lib provides a balance between an expensive math function and the speed
|
|
of a lookup table.
|
|
|
|
The accuracy of the library depends on the size of the internal array.
|
|
A size of 256 is the reference. Smaller arrays use interpolation and
|
|
these interpolated values are good (< 1%) down to internal array size 16.
|
|
The size can be as small as 2 which is pretty inaccurate.
|
|
In this latter case the curve is approximated by only two linear interpolations.
|
|
In short, choose the size that fits your application.
|
|
|
|
The library has a **setGamma()** function that allows an application to change
|
|
the gamma value runtime. This allows adjustments that a fixed table does not have.
|
|
|
|
The class can be used to dump the internal table e.g. to place in PROGMEM.
|
|
|
|
## Interface
|
|
|
|
### Core functions
|
|
|
|
- **GAMMA(size = 32)** constructor, gets the size of the internal
|
|
array as parameter. The array is initialized with a gamma == 2.8 which
|
|
is an often used value.
|
|
The default for size = 32 as this is a good balance between performance
|
|
and size ot the internal array.
|
|
The size parameter must be in {2, 4, 8, 16, 32, 64, 128, 256 }
|
|
- **setGamma(float gamma)** calculates and fills the array with new values.
|
|
This can be done runtime so runtime adjustment of gamma mapping.
|
|
This function relative quite some time.
|
|
- **getGamma()** returns the set gamma value.
|
|
- **operator \[\]** allows the GAMMA object to be accessed as an array.
|
|
like ```x = G[40];``` Makes it easy to switch with a real array.
|
|
|
|
### Development functions
|
|
|
|
- **size()** returns size of the internal array.
|
|
- **distinct()** returns the number of distinct values in the table.
|
|
- **dump()** dumps the internal table to Serial. Can be useful to create
|
|
a direct usable array in RAM, PROGMEM or wherever.
|
|
|
|
## Future ideas
|
|
|
|
- look for optimizations
|
|
- uint16 version?
|
|
-
|
|
|
|
## Operation
|
|
|
|
See example
|