2018-07-02 18:40:45 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2018 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// skcms_internal.h contains APIs shared by skcms' internals and its test tools.
|
|
|
|
// Please don't use this header from outside the skcms repo.
|
|
|
|
|
|
|
|
#include "skcms.h"
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2018-07-02 20:24:31 +00:00
|
|
|
#ifdef __cplusplus
|
2018-07-02 18:40:45 +00:00
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// ~~~~ General Helper Macros ~~~~
|
2018-07-02 19:40:45 +00:00
|
|
|
#define ARRAY_COUNT(arr) (int)(sizeof((arr)) / sizeof(*(arr)))
|
2018-07-02 18:40:45 +00:00
|
|
|
|
|
|
|
// ~~~~ skcms_TransferFunction ~~~~
|
2018-07-02 19:40:45 +00:00
|
|
|
float skcms_TransferFunction_eval (const skcms_TransferFunction*, float);
|
|
|
|
bool skcms_TransferFunction_invert(const skcms_TransferFunction*, skcms_TransferFunction*);
|
2018-07-02 18:40:45 +00:00
|
|
|
|
|
|
|
// ~~~~ skcms_ICCProfile ~~~~
|
|
|
|
bool skcms_GetCHAD(const skcms_ICCProfile* profile, skcms_Matrix3x3* m);
|
|
|
|
|
|
|
|
// 252 of a random shuffle of all possible bytes.
|
|
|
|
// 252 is evenly divisible by 3 and 4. Only 192, 10, 241, and 43 are missing.
|
|
|
|
// Used for ICC profile equivalence testing.
|
|
|
|
extern const uint8_t skcms_252_random_bytes[252];
|
|
|
|
|
|
|
|
// ~~~~ Linear Algebra ~~~~
|
|
|
|
// It is _not_ safe to alias the pointers to invert in-place.
|
|
|
|
bool skcms_Matrix3x3_invert(const skcms_Matrix3x3*, skcms_Matrix3x3*);
|
|
|
|
skcms_Matrix3x3 skcms_Matrix3x3_concat(const skcms_Matrix3x3* A, const skcms_Matrix3x3* B);
|
|
|
|
|
|
|
|
// ~~~~ Portable Math ~~~~
|
|
|
|
static inline float floorf_(float x) {
|
|
|
|
float roundtrip = (float)((int)x);
|
|
|
|
return roundtrip > x ? roundtrip - 1 : roundtrip;
|
|
|
|
}
|
|
|
|
static inline float fabsf_(float x) { return x < 0 ? -x : x; }
|
|
|
|
float powf_(float, float);
|
|
|
|
|
2018-07-02 20:24:31 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
2018-07-02 18:40:45 +00:00
|
|
|
#endif
|