Fix msvc compile error with subdivide use_smooth_even option.
[blender.git] / intern / cycles / kernel / shaders / node_color.h
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  */
16
17 /* Color Management */
18
19 float color_srgb_to_scene_linear(float c)
20 {
21         if (c < 0.04045)
22                 return (c < 0.0) ? 0.0 : c * (1.0 / 12.92);
23         else
24                 return pow((c + 0.055) * (1.0 / 1.055), 2.4);
25 }
26
27 float color_scene_linear_to_srgb(float c)
28 {
29         if (c < 0.0031308)
30                 return (c < 0.0) ? 0.0 : c * 12.92;
31         else
32                 return 1.055 * pow(c, 1.0 / 2.4) - 0.055;
33 }
34
35 color color_srgb_to_scene_linear(color c)
36 {
37         return color(
38                 color_srgb_to_scene_linear(c[0]),
39                 color_srgb_to_scene_linear(c[1]),
40                 color_srgb_to_scene_linear(c[2]));
41 }
42
43 color color_scene_linear_to_srgb(color c)
44 {
45         return color(
46                 color_scene_linear_to_srgb(c[0]),
47                 color_scene_linear_to_srgb(c[1]),
48                 color_scene_linear_to_srgb(c[2]));
49 }
50
51 color color_unpremultiply(color c, float alpha)
52 {
53         if(alpha != 1.0 && alpha != 0.0)
54                 return c/alpha;
55
56         return c;
57 }
58
59 /* Color Operations */
60
61 color rgb_to_hsv(color rgb)
62 {
63         float cmax, cmin, h, s, v, cdelta;
64         color c;
65
66         cmax = max(rgb[0], max(rgb[1], rgb[2]));
67         cmin = min(rgb[0], min(rgb[1], rgb[2]));
68         cdelta = cmax - cmin;
69
70         v = cmax;
71
72         if (cmax != 0.0) {
73                 s = cdelta / cmax;
74         }
75         else {
76                 s = 0.0;
77                 h = 0.0;
78         }
79
80         if (s == 0.0) {
81                 h = 0.0;
82         }
83         else {
84                 c = (color(cmax, cmax, cmax) - rgb) / cdelta;
85
86                 if (rgb[0] == cmax) h = c[2] - c[1];
87                 else if (rgb[1] == cmax) h = 2.0 + c[0] -  c[2];
88                 else h = 4.0 + c[1] - c[0];
89
90                 h /= 6.0;
91
92                 if (h < 0.0)
93                         h += 1.0;
94         }
95
96         return color(h, s, v);
97 }
98
99 color hsv_to_rgb(color hsv)
100 {
101         float i, f, p, q, t, h, s, v;
102         color rgb;
103
104         h = hsv[0];
105         s = hsv[1];
106         v = hsv[2];
107
108         if (s == 0.0) {
109                 rgb = color(v, v, v);
110         }
111         else {
112                 if (h == 1.0)
113                         h = 0.0;
114                 
115                 h *= 6.0;
116                 i = floor(h);
117                 f = h - i;
118                 rgb = color(f, f, f);
119                 p = v * (1.0 - s);
120                 q = v * (1.0 - (s * f));
121                 t = v * (1.0 - (s * (1.0 - f)));
122
123                 if (i == 0.0) rgb = color(v, t, p);
124                 else if (i == 1.0) rgb = color(q, v, p);
125                 else if (i == 2.0) rgb = color(p, v, t);
126                 else if (i == 3.0) rgb = color(p, q, v);
127                 else if (i == 4.0) rgb = color(t, p, v);
128                 else rgb = color(v, p, q);
129         }
130
131         return rgb;
132 }
133