46 { -0.7502f, 1.7135f, 0.0367f, 0.f },
47 { 0.0389f, -0.0685f, 1.0296f, 0.f } };
50 { 0.4323f, 0.5184f, 0.0493f, 0.f },
51 { -0.0085f, 0.0400f, 0.9685f, 0.f } };
54 { 0.2664f, 1.7135f, -0.0685f, 0.f },
55 { -0.1614f, 0.0367f, 1.0296f, 0.f } };
58 { -0.1471f, 0.5184f, 0.0400f, 0.f },
59 { 0.1600f, 0.0493f, 0.9685f, 0.f } };
65 return dt_mat3x4_mul_vec4(
XYZ,
71static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
75 return dt_mat3x4_mul_vec4(
LMS,
86 { -0.250268f, 1.204414f, 0.045854f, 0.f },
87 { -0.002079f, 0.048952f, 0.953127f, 0.f } };
90 { 0.38752f , 0.621447f, -0.008974f, 0.f },
91 { -0.015841f, -0.034123f, 1.049964f, 0.f } };
94 { 0.650173f, 1.204414f, 0.048952f, 0.f },
95 { -0.051461f, 0.045854f, 0.953127f, 0.f } };
98 { -1.011255f, 0.621447f, -0.034123f, 0.f },
99 { 0.149187f, -0.008974f, 1.049964f, 0.f } };
101static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
105 return dt_mat3x4_mul_vec4(
XYZ,
111static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
115 return dt_mat3x4_mul_vec4(
LMS,
122static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
141static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
169 dt_XYZ_to_Rec709_D65(
XYZ,
RGB);
172 float max_RGB = fmaxf(fmaxf(
RGB[0],
RGB[1]),
RGB[2]);
173 for(
int c = 0;
c < 3;
c++)
RGB[c] = fmaxf(
RGB[c] / max_RGB, 0.f);
180static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
181bradford_adapt_D65(
const dt_aligned_pixel_simd_t lms_in,
182 const dt_aligned_pixel_simd_t origin_illuminant,
183 const float p,
const int full)
185 static const dt_aligned_pixel_simd_t D65 = { 0.941238f, 1.040633f, 1.088932f, 0.f };
186 dt_aligned_pixel_simd_t temp = lms_in / origin_illuminant;
187 if(full) temp[2] = (temp[2] > 0.f) ? powf(temp[2],
p) : temp[2];
192static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
194 const dt_aligned_pixel_simd_t origin_illuminant,
195 const float p,
const int full)
197 static const dt_aligned_pixel_simd_t D50 = { 0.996078f, 1.020646f, 0.818155f, 0.f };
198 dt_aligned_pixel_simd_t temp = lms_in / origin_illuminant;
199 if(full) temp[2] = (temp[2] > 0.f) ? powf(temp[2],
p) : temp[2];
206static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
207CAT16_adapt_D65(
const dt_aligned_pixel_simd_t lms_in,
208 const dt_aligned_pixel_simd_t origin_illuminant,
209 const float D,
const int full)
211 static const dt_aligned_pixel_simd_t D65 = { 0.97553267f, 1.01647859f, 1.0848344f, 0.f };
212 return full ? lms_in * D65 / origin_illuminant
217static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
219 const dt_aligned_pixel_simd_t origin_illuminant,
220 const float D,
const int full)
222 static const dt_aligned_pixel_simd_t D50 = { 0.994535f, 1.000997f, 0.833036f, 0.f };
223 return full ? lms_in * D50 / origin_illuminant
229static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
230XYZ_adapt_D65(
const dt_aligned_pixel_simd_t lms_in,
231 const dt_aligned_pixel_simd_t origin_illuminant)
233 static const dt_aligned_pixel_simd_t D65 = { 0.9504285453771807f, 1.0f, 1.0889003707981277f, 0.f };
234 return lms_in * D65 / origin_illuminant;
237static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
239 const dt_aligned_pixel_simd_t origin_illuminant)
241 static const dt_aligned_pixel_simd_t D50 = { 0.9642119944211994f, 1.0f, 0.8251882845188288f, 0.f };
242 return lms_in * D50 / origin_illuminant;
248 = { { 9.89466254e-01f, -4.00304626e-02f, 4.40530317e-02f, 0.f },
249 { -5.40518733e-03f, 1.00666069e+00f, -1.75551955e-03f, 0.f },
250 { -4.03920992e-04f, 1.50768030e-02f, 1.30210211e+00f, 0.f } };
253 = { { 0.95547342f, -0.02309845f, 0.06325924f, 0.f },
254 { -0.02836971f, 1.00999540f, 0.02104144f, 0.f },
255 { 0.01231401f, -0.02050765f, 1.33036593f, 0.f } };
258 = { { 1.01085433e+00f, 4.07086103e-02f, -3.41445825e-02f, 0.f },
259 { 5.42814201e-03f, 9.93581926e-01f, 1.15592039e-03f, 0.f },
260 { 2.50722468e-04f, -1.14918759e-02f, 7.67964947e-01f, 0.f } };
263 = { { 1.04792979f, 0.02294687f, -0.05019227f, 0.f },
264 { 0.02962781f, 0.99043443f, -0.0170738f, 0.f },
265 { -0.00924304f, 0.01505519f, 0.75187428f, 0.f } };
268 = { { 9.89466254e-01f, -5.40518733e-03f, -4.03920992e-04f, 0.f },
269 { -4.00304626e-02f, 1.00666069e+00f, 1.50768030e-02f, 0.f },
270 { 4.40530317e-02f, -1.75551955e-03f, 1.30210211e+00f, 0.f } };
273 = { { 1.01085433e+00f, 5.42814201e-03f, 2.50722468e-04f, 0.f },
274 { 4.07086103e-02f, 9.93581926e-01f, -1.14918759e-02f, 0.f },
275 { -3.41445825e-02f, 1.15592039e-03f, 7.67964947e-01f, 0.f } };
291static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
292_downscale_vector_simd(
const dt_aligned_pixel_simd_t vector,
const float scaling)
298static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
299_upscale_vector_simd(
const dt_aligned_pixel_simd_t vector,
const float scaling)
305static inline __attribute__((always_inline)) dt_aligned_pixel_simd_t
306chroma_adapt_pixel(
const dt_aligned_pixel_simd_t in,
312 const float Y = in[1];
361 dt_store_simd_aligned(D50, (dt_aligned_pixel_simd_t){ 0.9642119944211994f, 1.0f, 0.8251882845188288f, 0.f });
#define TRUE
Definition ashift_lsd.c:162
#define FALSE
Definition ashift_lsd.c:158
static void XYZ_D50_to_D65(const dt_aligned_pixel_t XYZ_in, dt_aligned_pixel_t XYZ_out)
Definition chromatic_adaptation.h:278
static const dt_aligned_pixel_simd_t const dt_adaptation_t adaptation
Definition chromatic_adaptation.h:308
const dt_colormatrix_t XYZ_D50_to_D65_Bradford
Definition chromatic_adaptation.h:253
const dt_colormatrix_t CAT16_LMS_to_XYZ
Definition chromatic_adaptation.h:89
static void XYZ_D65_to_D50(const dt_aligned_pixel_t XYZ_in, dt_aligned_pixel_t XYZ_out)
Definition chromatic_adaptation.h:284
static const dt_adaptation_t kind
Definition chromatic_adaptation.h:124
const dt_colormatrix_t XYZ_D65_to_D50_CAT16
Definition chromatic_adaptation.h:258
const dt_colormatrix_t XYZ_to_CAT16_LMS
Definition chromatic_adaptation.h:85
static void convert_D50_to_LMS(const dt_adaptation_t adaptation, dt_aligned_pixel_t D50)
Definition chromatic_adaptation.h:344
static const dt_colormatrix_t XYZ_to_CAT16_LMS_transposed
Definition chromatic_adaptation.h:93
dt_adaptation_t
Definition chromatic_adaptation.h:30
@ DT_ADAPTATION_LAST
Definition chromatic_adaptation.h:36
@ DT_ADAPTATION_FULL_BRADFORD
Definition chromatic_adaptation.h:33
@ DT_ADAPTATION_XYZ
Definition chromatic_adaptation.h:34
@ DT_ADAPTATION_CAT16
Definition chromatic_adaptation.h:32
@ DT_ADAPTATION_RGB
Definition chromatic_adaptation.h:35
@ DT_ADAPTATION_LINEAR_BRADFORD
Definition chromatic_adaptation.h:31
static const dt_colormatrix_t XYZ_to_Bradford_LMS_transposed
Definition chromatic_adaptation.h:53
static const dt_colormatrix_t XYZ_D65_to_D50_CAT16_transposed
Definition chromatic_adaptation.h:273
static const dt_colormatrix_t XYZ_D50_to_D65_CAT16_transposed
Definition chromatic_adaptation.h:268
static const dt_aligned_pixel_simd_t const dt_adaptation_t const float p
Definition chromatic_adaptation.h:309
const dt_colormatrix_t XYZ_to_Bradford_LMS
Definition chromatic_adaptation.h:45
const dt_colormatrix_t Bradford_LMS_to_XYZ
Definition chromatic_adaptation.h:49
static const float scaling
Definition chromatic_adaptation.h:293
static const dt_colormatrix_t CAT16_LMS_to_XYZ_transposed
Definition chromatic_adaptation.h:97
const dt_colormatrix_t XYZ_D65_to_D50_Bradford
Definition chromatic_adaptation.h:263
static const dt_colormatrix_t Bradford_LMS_to_XYZ_transposed
Definition chromatic_adaptation.h:57
return vector dt_simd_set1(valid ?(scaling+NORM_MIN) :NORM_MIN)
static const dt_aligned_pixel_simd_t illuminant
Definition chromatic_adaptation.h:307
static void CAT16_adapt_D50(float4 *lms_in, const float4 origin_illuminant, const float D, const int full)
Definition colorspace.h:722
static float4 convert_XYZ_to_bradford_LMS(const float4 XYZ)
Definition colorspace.h:657
static float4 convert_XYZ_to_CAT16_LMS(const float4 XYZ)
Definition colorspace.h:677
static void bradford_adapt_D50(float4 *lms_in, const float4 origin_illuminant, const float p, const int full)
Definition colorspace.h:697
static void XYZ_adapt_D50(float4 *lms_in, const float4 origin_illuminant)
Definition colorspace.h:737
static float4 convert_CAT16_LMS_to_XYZ(const float4 LMS)
Definition colorspace.h:687
static float4 convert_bradford_LMS_to_XYZ(const float4 LMS)
Definition colorspace.h:667
dt_aligned_pixel_t LMS
Definition colorspaces_inline_conversions.h:701
dt_apply_transposed_color_matrix(XYZ, xyz_to_srgb_matrix_transposed, sRGB)
static dt_aligned_pixel_t XYZ
Definition colorspaces_inline_conversions.h:98
dt_store_simd_aligned(out, dt_mat3x4_mul_vec4(vin, dt_colormatrix_row_to_simd(matrix, 0), dt_colormatrix_row_to_simd(matrix, 1), dt_colormatrix_row_to_simd(matrix, 2)))
static dt_aligned_pixel_t RGB
Definition colorspaces_inline_conversions.h:327
typedef void((*dt_cache_allocate_t)(void *userdata, dt_cache_entry_t *entry))
float dt_aligned_pixel_simd_t __attribute__((vector_size(16), aligned(16)))
Multi-tap smudge source sample with directional jitter.
Definition darktable.h:523
#define __OMP_DECLARE_SIMD__(...)
Definition darktable.h:262
#define NORM_MIN
Definition math.h:35
float DT_ALIGNED_ARRAY dt_colormatrix_t[4][4]
Definition matrices.h:33
c
Definition derive_filmic_v6_gamut_mapping.py:35
float dt_aligned_pixel_t[4]
Definition noiseprofile.c:28