-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsmit_algorithm.py
More file actions
31 lines (31 loc) · 1.08 KB
/
smit_algorithm.py
File metadata and controls
31 lines (31 loc) · 1.08 KB
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
'''
This algorithm was taken from a An RGB to Spectrum Conversion for
Reflectances, by Brian Smits. THIS IS NOT FINISHED YET
'''
def rgb_to_wavelength(r,g,b):
int wavelength = 0
if(r <= g and r <= b):
wavelength = r * white_spectrum
if(g <= b):
wavelength += (g - r) * cyan_spectrum
wavelength += (b - g) * blue_spectrum
else
wavelength += (b - r) * cyan_spectrum
wavelength += (g - b) * green_spectrum
elif(g <= r and g <= b):
wavelength = g * white_spectrum
if(r <= b):
wavelength += (r - r) * cyan_spectrum
wavelength += (b - g) * blue_spectrum
else
wavelength += (b - r) * cyan_spectrum
wavelength += (r - b) * green_spectrum
else(b <= r and b <= g):
wavelength = b * white_spectrum
if(r <= g):
wavelength += (r - r) * cyan_spectrum
wavelength += (g - g) * blue_spectrum
else
wavelength += (b - r) * cyan_spectrum
wavelength += (g - b) * green_spectrum
return wavelength