Skip to main content

oxiphysics_geometry/implicit_geometry/
sdftwist_traits.rs

1//! # SdfTwist - Trait Implementations
2//!
3//! This module contains trait implementations for `SdfTwist`.
4//!
5//! ## Implemented Traits
6//!
7//! - `Sdf`
8//!
9//! 🤖 Generated with [SplitRS](https://github.com/cool-japan/splitrs)
10
11use super::functions::*;
12use super::types::SdfTwist;
13
14impl<S: Sdf> Sdf for SdfTwist<S> {
15    fn dist(&self, p: [f64; 3]) -> f64 {
16        let angle = self.strength * p[1];
17        let (sin_a, cos_a) = angle.sin_cos();
18        let qx = cos_a * p[0] - sin_a * p[2];
19        let qz = sin_a * p[0] + cos_a * p[2];
20        self.inner.dist([qx, p[1], qz])
21    }
22}