add curve compensation
This commit is contained in:
61
src/uvosunwrap/curve.h
Normal file
61
src/uvosunwrap/curve.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/**
|
||||||
|
* Lubricant Detecter
|
||||||
|
* Copyright (C) 2021 Carl Klemm
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* version 3 as published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* 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 General Public License
|
||||||
|
* along with this program; if not, write to the
|
||||||
|
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include <opencv2/core/ocl.hpp>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
float applyCurve(float in, cv::Mat curve)
|
||||||
|
{
|
||||||
|
assert(curve.type() == CV_32FC1);
|
||||||
|
assert(curve.rows == 2);
|
||||||
|
|
||||||
|
float* keys = curve.ptr<float>(0);
|
||||||
|
float* values = curve.ptr<float>(1);
|
||||||
|
|
||||||
|
if(in < keys[0])
|
||||||
|
return values[0];
|
||||||
|
|
||||||
|
|
||||||
|
for(int i = 1; i < curve.cols; ++i)
|
||||||
|
{
|
||||||
|
if(in < keys[i])
|
||||||
|
{
|
||||||
|
double slope = (values[i] - (double)values[i-1])/(keys[i] - keys[i-1]);
|
||||||
|
return (in-keys[i-1])*slope+values[i-1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return values[curve.cols-1];
|
||||||
|
}
|
||||||
|
|
||||||
|
void applyCurve(cv::Mat image, cv::Mat curve)
|
||||||
|
{
|
||||||
|
assert(image.type() == CV_32FC1);
|
||||||
|
assert(curve.type() == CV_32FC1);
|
||||||
|
assert(curve.rows == 2);
|
||||||
|
|
||||||
|
for(int y = 0; y < image.rows; y++)
|
||||||
|
{
|
||||||
|
float* col = image.ptr<float>(y);
|
||||||
|
for(int x = 0; x < image.cols; ++x)
|
||||||
|
{
|
||||||
|
col[x]=applyCurve(col[x], curve);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user