GithubHelp home page GithubHelp logo

ozgunawesome / homebridge-gpio-ledstrip-gamma-corrected Goto Github PK

View Code? Open in Web Editor NEW

This project forked from giniae/homebridge-gpio-ledstrip

0.0 2.0 0.0 11 KB

RPi GPIO based LED Strip plugin for Homebridge

TypeScript 100.00%

homebridge-gpio-ledstrip-gamma-corrected's Introduction

homebridge-gpio-ledstrip-gamma-corrected

RPi GPIO based LED Strip plugin for Homebridge

Forked from GiniaE/homebridge-gpio-ledstrip and added gamma correction as a configurable parameter, to make color representation more accurate.

Installation

  1. Install homebridge using: npm install -g homebridge
  2. Install this plugin using: npm install -g homebridge-gpio-ledstrip-gamma-corrected
  3. Update your configuration file. See sample config.json snippet below.

Configuration

Configuration sample

   "accessories": [
     {
       "accessory": "GPIORGBLEDStripGammaCorrected",
       "name": "Kitchen Cabinet Strip",
       "redPin": 22,
       "greenPin": 27,
       "bluePin": 17,
       "gamma": 2.8
     }
   ]

Fields

  • "accessory": Must always be "GPIORGBLEDStripGammaCorrected" (required)
  • "name": Can be anything (required)
  • "redPin": GPIO pin that is used to set red value (required)
  • "greenPin": GPIO pin that is used to set green value (required)
  • "bluePin": GPIO pin that is used to set blue value (required)
  • "gamma": Gamma correction factor to apply. (optional, defaults to 2.8)

Gamma correction

The PWM driven RGB LED strip will adjust its brightness linearly in relation to the PWM duty cycle. For example, if you output 100% duty cycle PWM to the red pin and 50% to the green pin, you'd expect to see orange but you'll instead see yellow. The reason for that, is that while the LEDs are linear; the human eye perception is non-linear and follows an exponential curve:

So the trick here is to apply an inverse of this curve and that's called "gamma correction":

Image credit and more info at Adafruit.

Implementation

After conversion from HSV to RGB colorspace, the following snippet is applied to each individual RGB color value:

out = Math.floor(Math.pow(in / 255, gamma) * 255 + 0.5)

This will convert a color value in in the 0..255 range to another color value out also in the 0..255 range that follows an exponential curve.

I found 2.8 to be a good gamma factor for my specific RGB strip. For reference CRT monitors are usually corrected to 2.2 and Mac LCD displays are often corrected to 1.8. Feel free to experiment with different values to find the most accurate color representation.

homebridge-gpio-ledstrip-gamma-corrected's People

Contributors

giniae avatar kraigm avatar ozgunawesome avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.