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
use crate::core::geometry::{Point2f, Vector2f};
use crate::core::pbrt::Float;
use crate::filters::boxfilter::BoxFilter;
use crate::filters::gaussian::GaussianFilter;
use crate::filters::mitchell::MitchellNetravali;
use crate::filters::sinc::LanczosSincFilter;
use crate::filters::triangle::TriangleFilter;
pub enum Filter {
Bx(BoxFilter),
Gaussian(GaussianFilter),
MitchellNetravali(MitchellNetravali),
LanczosSinc(LanczosSincFilter),
Triangle(TriangleFilter),
}
impl Filter {
pub fn evaluate(&self, p: Point2f) -> Float {
match self {
Filter::Bx(filter) => filter.evaluate(p),
Filter::Gaussian(filter) => filter.evaluate(p),
Filter::MitchellNetravali(filter) => filter.evaluate(p),
Filter::LanczosSinc(filter) => filter.evaluate(p),
Filter::Triangle(filter) => filter.evaluate(p),
}
}
pub fn get_radius(&self) -> Vector2f {
match self {
Filter::Bx(filter) => filter.get_radius(),
Filter::Gaussian(filter) => filter.get_radius(),
Filter::MitchellNetravali(filter) => filter.get_radius(),
Filter::LanczosSinc(filter) => filter.get_radius(),
Filter::Triangle(filter) => filter.get_radius(),
}
}
}