forked from patriciogonzalezvivo/lygia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdaltonize.msl
184 lines (142 loc) · 5.93 KB
/
daltonize.msl
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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
#include "space/rgb2lms.msl"
#include "space/lms2rgb.msl"
/*
contributors: Patricio Gonzalez Vivo
description: Daltonize functions based on https://web.archive.org/web/20081014161121/http://www.colorjack.com/labs/colormatrix/ http://www.daltonize.org/search/label/Daltonize
use: <float3|float4> daltonize(<float3|float4> rgb)
options:
- DALTONIZE_FNC: |
daltonizeProtanope, daltonizeProtanopia, daltonizeProtanomaly, daltonizeDeuteranope, daltonizeDeuteranopia, daltonizeDeuteranomaly, daltonizeTritanope, daltonizeTritanopia,
daltonizeTritanomaly, daltonizeAchromatopsia and daltonizeAchromatomaly
license:
- Copyright (c) 2021 Patricio Gonzalez Vivo under Prosperity License - https://prosperitylicense.com/versions/3.0.0
- Copyright (c) 2021 Patricio Gonzalez Vivo under Patron License - https://lygia.xyz/license
*/
#ifndef DALTONIZE_FNC
#define DALTONIZE_FNC daltonizeProtanope
#endif
#ifndef FNC_DALTONIZE
#define FNC_DALTONIZE
// Protanope - reds are greatly reduced (1% men)
float3 daltonizeProtanope(float3 rgb) {
float3 lms = rgb2lms(rgb);
lms.x = 0.0 * lms.x + 2.02344 * lms.y + -2.52581 * lms.z;
lms.y = 0.0 * lms.x + 1.0 * lms.y + 0.0 * lms.z;
lms.z = 0.0 * lms.x + 0.0 * lms.y + 1.0 * lms.z;
return lms2rgb(lms);
}
float4 daltonizeProtanope(float4 rgba) {
return float4(daltonizeProtanope(rgba.rgb), rgba.a);
}
float3 daltonizeProtanopia(float3 rgb) {
return float3(rgb.r * 0.56667 + rgb.g * 0.43333 + rgb.b * 0.00000,
rgb.r * 0.55833 + rgb.g * 0.44267 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.24167 + rgb.b * 0.75833);
}
float4 daltonizeProtanopia(float4 rgba) {
return float4(daltonizeProtanopia(rgba.rgb), rgba.a);
}
float3 daltonizeProtanomaly(float3 rgb) {
return float3(rgb.r * 0.81667 + rgb.g * 0.18333 + rgb.b * 0.00000,
rgb.r * 0.33333 + rgb.g * 0.66667 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.12500 + rgb.b * 0.87500);
}
float4 daltonizeProtanomaly(float4 rgba) {
return float4(daltonizeProtanomaly(rgba.rgb), rgba.a);
}
// Deuteranope - greens are greatly reduced (1% men)
float3 daltonizeDeuteranope(float3 rgb) {
float3 lms = rgb2lms(rgb);
lms.x = 1.0 * lms.x + 0.0 * lms.y + 0.0 * lms.z;
lms.y = 0.494207 * lms.x + 0.0 * lms.y + 1.24827 * lms.z;
lms.z = 0.0 * lms.x + 0.0 * lms.y + 1.0 * lms.z;
return lms2rgb(lms);
}
float4 daltonizeDeuteranope(float4 rgba) {
return float4(daltonizeDeuteranope(rgba.rgb), rgba.a);
}
float3 daltonizeDeuteranopia(float3 rgb) {
return float3(rgb.r * 0.62500 + rgb.g * 0.37500 + rgb.b * 0.00000,
rgb.r * 0.70000 + rgb.g * 0.30000 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.30000 + rgb.b * 0.70000);
}
float4 daltonizeDeuteranopia(float4 rgba) {
return float4(daltonizeDeuteranopia(rgba.rgb), rgba.a);
}
float3 daltonizeDeuteranomaly(float3 rgb) {
return float3(rgb.r * 0.80000 + rgb.g * 0.20000 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.25833 + rgb.b * 0.74167,
rgb.r * 0.00000 + rgb.g * 0.14167 + rgb.b * 0.85833);
}
float4 daltonizeDeuteranomaly(float4 rgba) {
return float4(daltonizeDeuteranomaly(rgba.rgb), rgba.a);
}
// Tritanope - blues are greatly reduced (0.003% population)
float3 daltonizeTritanope(float3 rgb) {
float3 lms = rgb2lms(rgb);
// Simulate rgb blindness
lms.x = 1.0 * lms.x + 0.0 * lms.y + 0.0 * lms.z;
lms.y = 0.0 * lms.x + 1.0 * lms.y + 0.0 * lms.z;
lms.z = -0.395913 * lms.x + 0.801109 * lms.y + 0.0 * lms.z;
return lms2rgb(lms);
}
float4 daltonizeTritanope(float4 rgba) {
return float4(daltonizeTritanope(rgba.rgb), rgba.a);
}
float3 daltonizeTritanopia(float3 rgb) {
return float3(rgb.r * 0.95 + rgb.g * 0.05 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.43333 + rgb.b * 0.56667,
rgb.r * 0.00000 + rgb.g * 0.47500 + rgb.b * 0.52500);
}
float4 daltonizeTritanopia(float4 rgba) {
return float4(daltonizeTritanopia(rgba.rgb), rgba.a);
}
float3 daltonizeTritanomaly(float3 rgb) {
return float3(rgb.r * 0.96667 + rgb.g * 0.33333 + rgb.b * 0.00000,
rgb.r * 0.00000 + rgb.g * 0.73333 + rgb.b * 0.26667,
rgb.r * 0.00000 + rgb.g * 0.18333 + rgb.b * 0.81667);
}
float4 daltonizeTritanomaly(float4 rgba) {
return float4(daltonizeTritanomaly(rgba.rgb), rgba.a);
}
float3 daltonizeAchromatopsia(float3 rgb) {
return float3(rgb.r * 0.299 + rgb.g * 0.587 + rgb.b * 0.114,
rgb.r * 0.299 + rgb.g * 0.587 + rgb.b * 0.114,
rgb.r * 0.299 + rgb.g * 0.587 + rgb.b * 0.114);
}
float4 daltonizeAchromatopsia(float4 rgba) {
return float4(daltonizeAchromatopsia(rgba.rgb), rgba.a);
}
float3 daltonizeAchromatomaly(float3 rgb) {
return float3(rgb.r * 0.618 + rgb.g * 0.320 + rgb.b * 0.062,
rgb.r * 0.163 + rgb.g * 0.775 + rgb.b * 0.062,
rgb.r * 0.163 + rgb.g * 0.320 + rgb.b * 0.516);
}
float4 daltonizeAchromatomaly(float4 rgba) {
return float4(daltonizeAchromatomaly(rgba.rgb), rgba.a);
}
// GENERAL FUNCTION
float3 daltonize(float3 rgb) {
return DALTONIZE_FNC(rgb);
}
float4 daltonize( float4 rgba ) {
return DALTONIZE_FNC(rgba);
}
// From https://gist.github.com/jcdickinson/580b7fb5cc145cee8740
//
float3 daltonizeCorrection(float3 rgb) {
// Isolate invisible rgbs to rgb vision deficiency (calculate error matrix)
float3 error = (rgb - daltonize(rgb));
// Shift rgbs towards visible spectrum (apply error modifications)
float3 correction;
correction.r = 0.0; // (error.r * 0.0) + (error.g * 0.0) + (error.b * 0.0);
correction.g = (error.r * 0.7) + (error.g * 1.0); // + (error.b * 0.0);
correction.b = (error.r * 0.7) + (error.b * 1.0); // + (error.g * 0.0);
// Add compensation to original values
correction = rgb + correction;
return correction.rgb;
}
float4 daltonizeCorrection(float4 rgb) {
return float4(daltonizeCorrection( rgb.rgb ), rgb.a);
}
#endif