natural_unit

Crates.ionatural_unit
lib.rsnatural_unit
version0.1.4
sourcesrc
created_at2019-05-14 11:42:32.360323
updated_at2020-04-22 16:28:09.841383
descriptionPhysical unit conversion program (SI, CGS, Natural, Geometrized)
homepage
repositoryhttps://github.com/Axect/Natural_Unit
max_upload_size
id134255
size11,860
Tae-Geun Kim (Axect)

documentation

https://docs.rs/natural_unit/

README

Natural Unit

On crates.io On docs.rs travis
maintenance

Physical unit conversion with Fundamental constants

Unit System List

  • SI
  • CGS
  • Geometrized(With CGS)
  • Geometrized with unit solar mass
  • Natural Unit(With CGS)
  • Natural Unit(MeV)
  • Natural Unit(Gaussian)

How to use?

  1. Just declare three conversion factors - M, L, T
  2. Get automatically obtained remain conversion factors (momentum, energy and etc.)
  3. convert value using by declared conversion factor structure.

Example: CGS -> Geometrized with Solar radius = 1

extern crate natural_unit;
use natural_unit::*;

fn main() {
    // Declare mass, length, time conversion factor.
    let cgs_to_geom = ConversionFactor::new(
        CONSTANT_CGS.G / (CONSTANT_CGS.c.powi(2) * CONSTANT_CGS.r_solar),   // Mass conversion factor
        1f64 / CONSTANT_CGS.r_solar,                                        // Length conversion factor
        CONSTANT_CGS.c / CONSTANT_CGS.r_solar                               // Time conversion factor
    );
    
    // What do you want to convert?
    let solar_mass_cgs = CONSTANT_CGS.m_solar;                              // CGS Solar Mass
    
    // Convert! (`convert(f64, Dimension, ConversionFactor)`)
    let new_solar_mass = convert(solar_mass_cgs, Mass, cgs_to_geom);        // Converted Solar Mass
    
    // Invert! (`invert(f64, Dimension, ConversionFactor)`)
    let inverted_solar_mass = invert(new_solar_mass, Mass, cgs_to_geom);    // Inverted Solar Mass
    assert_eq!(solar_mass_cgs, inverted_solar_mass);
}
Commit count: 11

cargo fmt