2020-07-21 20:05:21 -04:00
|
|
|
include <../std.scad>
|
2020-06-22 22:34:36 -07:00
|
|
|
|
|
|
|
|
2022-03-27 23:06:42 -04:00
|
|
|
module test_hsl() {
|
2020-06-22 22:34:36 -07:00
|
|
|
for (h = [0:30:360]) {
|
|
|
|
for (s = [0:0.2:1]) {
|
|
|
|
for (l = [0:0.2:1]) {
|
|
|
|
c = (1 - abs(2*l-1)) * s;
|
|
|
|
x = c * (1 - abs(((h/60)%2)-1));
|
|
|
|
m = l - c/2;
|
|
|
|
rgb = [m,m,m] + (
|
|
|
|
h<= 60? [c,x,0] :
|
|
|
|
h<=120? [x,c,0] :
|
|
|
|
h<=180? [0,c,x] :
|
|
|
|
h<=240? [0,x,c] :
|
|
|
|
h<=300? [x,0,c] :
|
|
|
|
[c,0,x]
|
|
|
|
);
|
2022-03-27 23:06:42 -04:00
|
|
|
assert_approx(hsl(h,s,l), rgb, format("h={}, s={}, l={}", [h,s,l]));
|
2020-06-22 22:34:36 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-03-27 23:06:42 -04:00
|
|
|
test_hsl();
|
2020-06-22 22:34:36 -07:00
|
|
|
|
|
|
|
|
2022-03-27 23:06:42 -04:00
|
|
|
module test_hsv() {
|
2020-06-22 22:34:36 -07:00
|
|
|
for (h = [0:30:360]) {
|
|
|
|
for (s = [0:0.2:1]) {
|
|
|
|
for (v = [0:0.2:1]) {
|
|
|
|
c = v * s;
|
|
|
|
x = c * (1 - abs(((h/60)%2)-1));
|
|
|
|
m = v - c;
|
|
|
|
rgb = [m,m,m] + (
|
|
|
|
h<= 60? [c,x,0] :
|
|
|
|
h<=120? [x,c,0] :
|
|
|
|
h<=180? [0,c,x] :
|
|
|
|
h<=240? [0,x,c] :
|
|
|
|
h<=300? [x,0,c] :
|
|
|
|
[c,0,x]
|
|
|
|
);
|
2022-03-27 23:06:42 -04:00
|
|
|
assert_approx(hsv(h,s,v), rgb, format("h={}, s={}, v={}", [h,s,v]));
|
2020-06-22 22:34:36 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-03-27 23:06:42 -04:00
|
|
|
test_hsv();
|
2020-06-22 22:34:36 -07:00
|
|
|
|
|
|
|
|
|
|
|
// vim: expandtab tabstop=4 shiftwidth=4 softtabstop=4 nowrap
|