#[cfg_attr(
feature = "lab",
doc = "
let colour_1 = lab::Lab { l: 38.972, a: 58.991, b: 37.138 };
let colour_2 = lab::Lab { l: 54.528, a: 42.416, b: 54.497 };
"
)]
#[cfg_attr(
not(feature = "lab"),
doc = "
let colour_1 = (38.972, 58.991, 37.138);
let colour_2 = (54.528, 42.416, 54.497);
"
)]
#[cfg_attr(
all(feature = "lab", feature = "rgb"),
doc = r#"
let colour_1 = rgb::RGB::<u8>::new(234, 76, 76);
let colour_2 = rgb::RGB::<u8>::new(76, 187, 234);
let delta_e = cie76::diff(colour_1, colour_2);
println!("The colour difference is: {}", delta_e);
assert_eq!(104.05857, delta_e);
"#
)]
pub fn diff(colour_1: impl crate::ToLab, colour_2: impl crate::ToLab) -> f32 {
let colour_1 = colour_1.to_lab();
let colour_2 = colour_2.to_lab();
let dl = colour_1.0 - colour_2.0;
let da = colour_1.1 - colour_2.1;
let db = colour_1.2 - colour_2.2;
(dl * dl + da * da + db * db).sqrt()
}
#[cfg(feature = "lab")]
#[deprecated(note = "Use cie76::diff() with rgb::RGB8 argument")]
pub fn diff_rgb(colour_1: &[u8; 3], colour_2: &[u8; 3]) -> f32 {
diff(lab::Lab::from_rgb(colour_1), lab::Lab::from_rgb(colour_2))
}
#[cfg(test)]
mod tests {
#[rustfmt::skip]
static TESTS: [(f32, (f32, f32, f32), (f32, f32, f32)); 6] = [
( 5.0, (0.0, 0.0, 0.0), ( 3.0, 4.0, 0.0)),
( 5.0, (0.0, 0.0, 0.0), ( 3.0, -4.0, 0.0)),
( 5.0, (0.0, 0.0, 0.0), (-3.0, 4.0, 0.0)),
( 5.0, (0.0, 4.0, 0.0), ( 3.0, 0.0, 0.0)),
( 5.0, (0.0, 2.0, 0.0), ( 3.0, -2.0, 0.0)),
(97.0, (0.0, 0.0, 0.0), ( 0.0, 65.0, -72.0)),
];
#[test]
fn test_difference() {
crate::testutil::do_test_difference(&TESTS, super::diff);
}
#[test]
fn test_zero() { crate::testutil::do_test_zero(|a, b| super::diff(a, b)) }
#[test]
fn test_symmetric() {
crate::testutil::do_test_symmetric(|a, b| super::diff(a, b))
}
}