File size: 1,544 Bytes
2409829
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
pub trait ToFloat {
	fn to_float(&self) -> f64;
}

impl ToFloat for u32 {
	fn to_float(&self) -> f64 {
		*self as f64
	}
}

impl ToFloat for i32 {
	fn to_float(&self) -> f64 {
		*self as f64
	}
}

pub struct Rational<T: ToFloat> {
	pub numerator: T,
	pub denominator: T,
}

impl<T: ToFloat> ToFloat for Rational<T> {
	fn to_float(&self) -> f64 {
		self.numerator.to_float() / self.denominator.to_float()
	}
}

pub struct CurveLookupTable {
	table: Vec<u16>,
}

impl CurveLookupTable {
	pub fn from_sony_tone_table(values: [u16; 4]) -> CurveLookupTable {
		let mut sony_curve = [0, 0, 0, 0, 0, 4095];
		for i in 0..4 {
			sony_curve[i + 1] = values[i] >> 2 & 0xfff;
		}

		let mut table = vec![0_u16; (sony_curve[5] + 1).into()];
		for i in 0..5 {
			for j in (sony_curve[i] + 1)..=sony_curve[i + 1] {
				table[j as usize] = table[(j - 1) as usize] + (1 << i);
			}
		}

		CurveLookupTable { table }
	}

	pub fn get(&self, x: usize) -> u16 {
		self.table[x]
	}
}

#[derive(Copy, Clone, Eq, PartialEq)]
pub enum Transform {
	Horizontal,
	MirrorHorizontal,
	Rotate180,
	MirrorVertical,
	MirrorHorizontalRotate270,
	Rotate90,
	MirrorHorizontalRotate90,
	Rotate270,
}

impl Transform {
	pub fn is_identity(&self) -> bool {
		*self == Transform::Horizontal
	}

	pub fn will_swap_coordinates(&self) -> bool {
		use Transform as Tr;

		match *self {
			Tr::Horizontal | Tr::MirrorHorizontal | Tr::Rotate180 | Tr::MirrorVertical => false,
			Tr::MirrorHorizontalRotate270 | Tr::Rotate90 | Tr::MirrorHorizontalRotate90 | Tr::Rotate270 => true,
		}
	}
}