BlinkenArea - GitList
Repositories
Blog
Wiki
libetherpix
Code
Commits
Branches
Tags
Search
Tree:
fb91a00
Branches
Tags
master
libetherpix
src
mapping.c
v1.0.5
Stefan Schuermans
commited
fb91a00
at 2011-09-11 17:17:19
mapping.c
Blame
History
Raw
/* * FlexiPix library * !version: 1.0.5! !date: 2010-12-22! * * Copyright 2010 Stefan Schuermans <stefan schuermans info> * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, version 3 of the License. * * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ #include <math.h> #include <flexipix/types.h> #include <intern/mapping.h> #include <intern/types.h> /** * \brief precalculate mapping table * * updates the internal lookup table according to the parameters * * \param[in,out] p_mapping mapping to precalculate */ void flp_mapping_precalc(flp_mapping_t *p_mapping) { double gamma_1; int v; /* precalculate 1 / gamma */ gamma_1 = 1.0 / p_mapping->gamma; /* map all values */ for (v = 0; v < 256; v++) { double val = p_mapping->base + p_mapping->factor * pow((double)v / 255.0, gamma_1); if (val < 0.0) p_mapping->table[v] = 0; else if (val > 1.0) p_mapping->table[v] = 255; else p_mapping->table[v] = (flp_u8_t)(val * 255.0 + 0.5); } }