-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathCIEDE2000.h
117 lines (103 loc) · 2.55 KB
/
CIEDE2000.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
* CIEDE2000.h
* Part of http://github.com/gfiumara/CIEDE2000 by Gregory Fiumara.
* See LICENSE for details.
*/
#ifndef GPF_CIEDE2000_H_
#define GPF_CIEDE2000_H_
#include <ostream>
#ifndef M_PI
#define M_PI 3.14159265358979323846264338327950288 /* pi */
#endif
/** Namespace containing all necessary objects and methods for CIEDE2000 */
namespace CIEDE2000
{
/***********************************************************************
* Types.
**********************************************************************/
/** A color in CIELAB colorspace */
struct LAB
{
/** Lightness */
double l;
/** Color-opponent a dimension */
double a;
/** Color-opponent b dimension */
double b;
};
/** Convenience definition for struct LAB */
using LAB = struct LAB;
/***********************************************************************
* Operations.
**********************************************************************/
/**
* @brief
* Obtain Delta-E 2000 value.
* @details
* Based on the paper "The CIEDE2000 Color-Difference Formula:
* Implementation Notes, Supplementary Test Data, and Mathematical
* Observations" by Gaurav Sharma, Wencheng Wu, and Edul N. Dalal,
* from http://www.ece.rochester.edu/~gsharma/ciede2000/.
*
* @param lab1
* First color in LAB colorspace.
* @param lab2
* Second color in LAB colorspace.
*
* @return
* Delta-E difference between lab1 and lab2.
*/
double
CIEDE2000(
const LAB &lab1,
const LAB &lab2);
/***********************************************************************
* Conversions.
**********************************************************************/
/**
* @brief
* Convert degrees to radians.
*
* @param deg
* Angle in degrees.
*
* @return
* deg in radians.
*/
constexpr double
deg2Rad(
const double deg);
/**
* @brief
* Convert radians to degrees.
*
* @param rad
* Angle in radians.
*
* @return
* rad in degrees.
*/
constexpr double
rad2Deg(
const double rad);
}
/*******************************************************************************
* Conversions.
******************************************************************************/
/**
* @brief
* LAB output stream operator.
*
* @param s
* Output stream.
* @param labColor
* Color to output.
*
* @return
* s with labColor appended.
*/
std::ostream&
operator<<(
std::ostream &s,
const CIEDE2000::LAB &labColor);
#endif /* GPF_CIEDE2000_H_ */