1
0

optimize random_point_in_unit_sphere

This commit is contained in:
Ishan Jain 2023-05-31 16:53:02 +05:30
parent 922d0f1656
commit 185791eddb
Signed by: ishan
GPG Key ID: 0506DB2A1CC75C27

View File

@ -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> {