Commit V1.0
This commit is contained in:
BIN
docs/2017_Newson_film_grain.pdf
(Stored with Git LFS)
Normal file
BIN
docs/2017_Newson_film_grain.pdf
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
docs/A Model for Simulating the Photographic Development Process on Digital Images.pdf
(Stored with Git LFS)
Normal file
BIN
docs/A Model for Simulating the Photographic Development Process on Digital Images.pdf
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
docs/Simulation of film media.pdf
(Stored with Git LFS)
Normal file
BIN
docs/Simulation of film media.pdf
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
docs/e4050_portra_400.pdf
(Stored with Git LFS)
Normal file
BIN
docs/e4050_portra_400.pdf
(Stored with Git LFS)
Normal file
Binary file not shown.
1093
docs/negadoctor.md
Normal file
1093
docs/negadoctor.md
Normal file
File diff suppressed because it is too large
Load Diff
53
docs/negadoctor_cl.md
Normal file
53
docs/negadoctor_cl.md
Normal file
@ -0,0 +1,53 @@
|
||||
/*
|
||||
This file is part of darktable,
|
||||
Copyright (C) 2020 darktable developers.
|
||||
|
||||
darktable 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, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
darktable 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 darktable. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "common.h"
|
||||
|
||||
|
||||
kernel void
|
||||
negadoctor (read_only image2d_t in, write_only image2d_t out, int width, int height,
|
||||
const float4 Dmin, const float4 wb_high, const float4 offset,
|
||||
const float exposure, const float black, const float gamma, const float soft_clip, const float soft_clip_comp)
|
||||
{
|
||||
const unsigned int x = get_global_id(0);
|
||||
const unsigned int y = get_global_id(1);
|
||||
|
||||
if(x >= width || y >= height) return;
|
||||
|
||||
float4 i = read_imagef(in, sampleri, (int2)(x, y));
|
||||
float4 o;
|
||||
|
||||
// Convert transmission to density using Dmin as a fulcrum
|
||||
o = -native_log10(Dmin / fmax(i, (float4)2.3283064365386963e-10f)); // threshold to -32 EV
|
||||
|
||||
// Correct density in log space
|
||||
o = wb_high * o + offset;
|
||||
|
||||
// Print density on paper : ((1 - 10^corrected_de + black) * exposure)^gamma rewritten for FMA
|
||||
o = -((float4)exposure * native_exp10(o) + (float4)black);
|
||||
o = dtcl_pow(fmax(o, (float4)0.0f), gamma); // note : this is always > 0
|
||||
|
||||
// Compress highlights and clip negatives. from https://lists.gnu.org/archive/html/openexr-devel/2005-03/msg00009.html
|
||||
o = (o > (float4)soft_clip) ? soft_clip + ((float4)1.0f - native_exp(-(o - (float4)soft_clip) / (float4)soft_clip_comp)) * (float4)soft_clip_comp
|
||||
: o;
|
||||
|
||||
// Copy alpha
|
||||
o.w = i.w;
|
||||
|
||||
write_imagef(out, (int2)(x, y), o);
|
||||
}
|
BIN
docs/sigg97.pdf
(Stored with Git LFS)
Normal file
BIN
docs/sigg97.pdf
(Stored with Git LFS)
Normal file
Binary file not shown.
Reference in New Issue
Block a user