oxiphysics_geometry/implicit_geometry/sdfgyroid_traits.rs
1//! # SdfGyroid - Trait Implementations
2//!
3//! This module contains trait implementations for `SdfGyroid`.
4//!
5//! ## Implemented Traits
6//!
7//! - `Sdf`
8//!
9//! 🤖 Generated with [SplitRS](https://github.com/cool-japan/splitrs)
10
11use std::f64::consts::PI;
12
13use super::functions::*;
14use super::types::SdfGyroid;
15
16impl Sdf for SdfGyroid {
17 fn dist(&self, p: [f64; 3]) -> f64 {
18 let q = scale(p, self.scale * 2.0 * PI);
19 let v = q[0].sin() * q[1].cos() + q[1].sin() * q[2].cos() + q[2].sin() * q[0].cos();
20 v.abs() / self.scale - self.thickness
21 }
22}