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