#si-units #physics #units #unit #si #array

quantity

Representation of quantites, i.e. of unit valued scalars and arrays.

19 unstable releases (9 breaking)

new 0.10.1 Jan 9, 2025
0.10.0 Dec 5, 2024
0.9.1 Nov 28, 2024
0.8.0 Apr 11, 2024
0.2.0 Jul 26, 2021

#48 in Science

Download history 44/week @ 2024-09-19 32/week @ 2024-09-26 12/week @ 2024-10-03 4/week @ 2024-10-10 287/week @ 2024-10-24 13/week @ 2024-10-31 7/week @ 2024-11-14 25/week @ 2024-11-21 123/week @ 2024-11-28 269/week @ 2024-12-05 73/week @ 2024-12-12 9/week @ 2024-12-19 45/week @ 2024-12-26 278/week @ 2025-01-02

425 downloads per month
Used in 8 crates

MIT/Apache

63KB
1K SLoC

quantity

crate documentation

Representation of quantities, i.e. of unit valued scalars and arrays.

The units are checked at compile time and can be arbitrarily complex. Additional to simple scalar quantities, it also provides utilities for vector valued quantities, based on the ndarray crate, where all entries share the same unit.

The crate is published together with the standalone Python package si-units. Together with PyO3, the data types defined in the Rust crate can be directly used in a Python interface. See the example for details.

Installation and Usage

Add this to your Cargo.toml:

[dependencies]
quantity = "0.10"

Examples

Calculate pressure of an ideal gas.

let temperature = 25.0 * CELSIUS;
let volume = 1.5 * METER.powi(3);
let moles = 75.0 * MOL;
let pressure = moles * RGAS * temperature / volume;
println!("{:.5}", pressure);            // 123.94785 kPa

Calculate the gravitational pull of the moon on the earth.

let mass_earth = 5.9724e24 * KILOGRAM;
let mass_moon = 7.346e22 * KILOGRAM;
let distance = 383.398 * KILO * METER;
let force = G * mass_earth * mass_moon / distance.powi(2);
println!("{:.5e}", force);              // 1.99208e26 N

Calculate the pressure distribution in the atmosphere using the barometric formula.

let z = SIArray1::linspace(1.0 * METER, 70.0 * KILO * METER, 10)?;
let g = 9.81 * METER / SECOND.powi(2);
let m = 28.949 * GRAM / MOL;
let t = 10.0 * CELSIUS;
let p0 = BAR;
let pressure = p0 * (-&z * m * g).to_reduced(RGAS * t)?.mapv(f64::exp);
for i in 0..10 {
    println!("z = {:8.5}   p = {:9.5}", z.get(i), pressure.get(i));
}
// z =  1.00000  m   p =  99.98794 kPa
// z =  7.77867 km   p =  39.12796 kPa
// z = 15.55633 km   p =  15.31182 kPa
// z = 23.33400 km   p =   5.99192 kPa
// z = 31.11167 km   p =   2.34480 kPa
// z = 38.88933 km   p = 917.58301  Pa
// z = 46.66700 km   p = 359.07479  Pa
// z = 54.44467 km   p = 140.51557  Pa
// z = 62.22233 km   p =  54.98750  Pa
// z = 70.00000 km   p =  21.51808  Pa

Python Package

For information on how to install, use and build the Python package, see here.

Documentation

For the rust documentation, see here.

For the python documentation, see here.

Dependencies

~0.3–2MB
~41K SLoC