angulus

Crates.ioangulus
lib.rsangulus
version0.6.0
sourcesrc
created_at2022-08-30 16:09:21.302037
updated_at2023-12-18 16:09:01.533189
descriptionUnit agnostic angle
homepage
repositoryhttps://github.com/tguichaoua/angulus
max_upload_size
id655220
size83,186
Tristan Guichaoua (tguichaoua)

documentation

README

angulus

github crates.io docs.rs msrv

Unit agnostic angle.

What problem does it solve ?

Using simple floating point numbers to store an angle value is error-prone : you may add two angle with one in radians and the second in degrees or you may try to compute the cosine of a value in degrees and get an unexpected result.

angulus provides a type that represent an angle with no specific unit.

Example

use angulus::{Angle, ToAngle};
use angulus::units::Degrees;

// Create an angle of 90°.
let alpha = 90.0_f32.deg();

// Create an angle of π/4 rad (45°).
let beta = Angle::RAD_FRAC_PI_4;

// Add the two angle without worrying about units.
let gamma = alpha + beta;

// Print the result.
println!(
    "The cosine of {} is {}",
    Degrees(gamma), // The angle is wrapped to display the value in degrees.
    gamma.cos()     // Compute the cosine without worrying about units.
);

// Output : The cosine of 135° is -0.70710677

Features

  • std: by default angulus links to the standard library. Disable this feature to remove this dependency and be able to use angulus in #![no_std] crates.
  • libm: use the libm crate for the math methods (sin, cos, tan) when std is disabled.
  • serde: enable serialization and deserialization with the serde crate.
  • rand: enable generation of random angle with the rand crate.

Minimum Supported Rust Version

This crate requires Rust 1.61.0 or later.

License

Licensed under either of the following, at your choice:

Unless explicitly stated otherwise, any contribution intentionally submitted for inclusion in this crate, as defined in the Apache-2.0 license, shall be dual-licensed as above, without any additional terms or conditions.

Commit count: 52

cargo fmt