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
use crate::core::geometry::{Point3f, Vector3f};
use crate::core::interaction::SurfaceInteraction;
use crate::core::pbrt::Float;
use crate::core::texture::fbm;
use crate::core::texture::{Texture, TextureMapping3D};
pub struct FBmTexture {
pub mapping: Box<TextureMapping3D>,
pub omega: Float,
pub octaves: i32,
}
impl FBmTexture {
pub fn new(mapping: Box<TextureMapping3D>, octaves: i32, omega: Float) -> Self {
FBmTexture {
mapping,
omega,
octaves,
}
}
}
impl<T> Texture<T> for FBmTexture
where
T: From<Float>,
{
fn evaluate(&self, si: &SurfaceInteraction) -> T {
let mut dpdx: Vector3f = Vector3f::default();
let mut dpdy: Vector3f = Vector3f::default();
let p: Point3f = self.mapping.map(si, &mut dpdx, &mut dpdy);
T::from(fbm(&p, &dpdx, &dpdy, self.omega, self.octaves))
}
}