optimize random_point_in_unit_sphere
This commit is contained in:
parent
922d0f1656
commit
185791eddb
|
@ -58,11 +58,19 @@ fn refract(incident: Vec3, normal: Vec3, ni_over_nt: f64) -> Option<Vec3> {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn random_point_in_unit_sphere<R: Rng + ?Sized>(rng: &mut R) -> Vec3 {
|
fn random_point_in_unit_sphere<R: Rng + ?Sized>(rng: &mut R) -> Vec3 {
|
||||||
let mut point = Vec3::random(rng) * 2.0 - Vec3::splat(1.0);
|
let u: f64 = rng.gen();
|
||||||
while point.sq_len() >= 1.0 {
|
let v: f64 = rng.gen();
|
||||||
point = Vec3::random(rng) * 2.0 - Vec3::splat(1.0);
|
|
||||||
}
|
let theta = u * 2.0 * std::f64::consts::PI;
|
||||||
point
|
let phi = (2.0 * v - 1.0).acos();
|
||||||
|
|
||||||
|
let radius = rng.gen::<f64>().cbrt();
|
||||||
|
|
||||||
|
let x = radius * phi.sin() * theta.cos();
|
||||||
|
let y = radius * phi.sin() * theta.sin();
|
||||||
|
let z = radius * phi.cos();
|
||||||
|
|
||||||
|
Vec3::new(x, y, z)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait MaterialBuilder<T> {
|
pub trait MaterialBuilder<T> {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user