A simple measurement unit API to handle basic unit conversions.
Project description
Simple Unit (Python implementation)
This package is the Python Reference Implementation (RI) of the Simple Unit specification. Nevertheless, it also contains some extensions to the specification standard.
Standard usage
The standard usage refers to methods and classes defined in the Simple Unit specification.
Usage of transformed units:
from simpleunit import FundamentalUnit
m = FundamentalUnit()
km = m.scale_multiply(1000)
cm = m.scale_divide(100)
cmToKm = cm.get_converter_to(km)
cmToKm.convert(3) # 0.00003
cmToKm.inverse().convert(0.00003) # 3
Usage of derived units:
from simpleunit import FundamentalUnit, DerivedUnit
m = FundamentalUnit()
km = m.scale_multiply(1000)
km2 = DerivedUnit(km.factor(2))
cm = m.scale_divide(100)
cm2 = DerivedUnit(cm.factor(2))
km2Tocm2 = km2.get_converter_to(cm2)
km2Tocm2.convert(3) # 30000000000
km2Tocm2.inverse().convert(30000000000) # 3
Usage of derived units combining dimensions:
from simpleunit import FundamentalUnit, DerivedUnit
m = FundamentalUnit()
kg = FundamentalUnit()
g = kg.scale_divide(1000)
ton = kg.scale_multiply(1000)
gPerM2 = DerivedUnit(g, m.factor(-2))
km = m.scale_multiply(1000)
tonPerKm2 = DerivedUnit(ton, km.factor(-2))
cm = m.scale_divide(100)
tonPerCm2 = DerivedUnit(ton, cm.factor(-2))
gPerM2ToTonPerKm2 = gPerM2.get_converter_to(tonPerKm2)
gPerM2ToTonPerCm2 = gPerM2.get_converter_to(tonPerCm2)
gPerM2ToTonPerKm2.convert(1) # 1
gPerM2ToTonPerKm2.inverse().convert(3) # 3
gPerM2ToTonPerCm2.convert(1) # 1e-4
gPerM2ToTonPerCm2.convert(3) # 3e-10
gPerM2ToTonPerCm2.offset() # 0.0
gPerM2ToTonPerCm2.scale() # 1e-10
gPerM2ToTonPerCm2.inverse().offset() # -0.0
gPerM2ToTonPerCm2.inverse().convert(3e-10) # 3
Usage of temperatures (affine and linear conversions):
from simpleunit import FundamentalUnit, DerivedUnit
k = FundamentalUnit()
c = k.shift(273.15)
kToC = k.get_converter_to(c)
kToC.convert(0) # -273.15
kToC.inverse().convert(0) # 273.15
# combined with other units, temperatures only keep their linear conversion part
m = FundamentalUnit()
cPerM = DerivedUnit(c, m.factor(-1))
kPerM = DerivedUnit(k, m.factor(-1))
kPerMToCPerM = kPerM.get_converter_to(cPerM)
kPerMToCPerM.convert(3) # 3
kPerMToCPerM.inverse().convert(3) # 3
Usage of non-decimal conversions:
from simpleunit import FundamentalUnit, DerivedUnit
m = FundamentalUnit()
km = m.scale_multiply(1000.)
s = FundamentalUnit()
h = s.scale_multiply(3600.)
ms = DerivedUnit(m, s.factor(-1))
kmh = DerivedUnit(km, h.factor(-1))
msToKmh = ms.get_converter_to(kmh)
msToKmh.convert(100.) # 360
msToKmh.inverse().convert(18.) # 5
Operator overloading usage
The Simple Unit Python implementation provides an extension of the base specification to overloads some language operators.
Usage of transformed units:
from simpleunit import FundamentalUnit
m = FundamentalUnit()
km = m * 1000
cm = m / 100
cmToKm = cm >> km
cmToKm(3) # 0.00003
(~cmToKm)(0.00003) # 3
Usage of derived Units:
from simpleunit import FundamentalUnit
m = FundamentalUnit()
km = m * 1000
km2 = km ** 2
cm = m / 100
cm2 = cm ** 2
km2Tocm2 = km2 >> cm2
km2Tocm2(3) # 30000000000
(~km2Tocm2)(30000000000) # 3
Usage of derived units combining dimensions:
from simpleunit import FundamentalUnit
m = FundamentalUnit()
kg = FundamentalUnit()
g = kg / 1000
ton = kg * 1000
gPerM2 = g / m ** 2
km = m * 1000
tonPerKm2 = ton * ~km ** 2
cm = m / 100
tonPerCm2 = ton / cm ** 2
gPerM2ToTonPerKm2 = gPerM2 >> tonPerKm2
gPerM2ToTonPerCm2 = tonPerCm2 << gPerM2
gPerM2ToTonPerKm2(1) # 1
(~gPerM2ToTonPerKm2)(3) # 3
gPerM2ToTonPerCm2(1) # 1e-10
gPerM2ToTonPerCm2(3) # 3e-10
gPerM2ToTonPerCm2.offset() # 0.0
gPerM2ToTonPerCm2.scale() # 1e-10
(~gPerM2ToTonPerCm2).offset() # -0.0
(~gPerM2ToTonPerCm2)(3e-10) # 3
Usage of temperatures (affine and linear conversions):
from simpleunit import FundamentalUnit
k = FundamentalUnit()
c = k + 273.15
kToC = k >> c
kToC(0) # -273.15
(~kToC)(0) # 273.15
# combined with other units, temperatures only keep their linear conversion part
m = FundamentalUnit()
cPerM = c / m
kPerM = k / m
kPerMToCPerM = kPerM >> cPerM
kPerMToCPerM(3) # 3
(~kPerMToCPerM)(3) # 3
Usage of non-decimal conversions:
from simpleunit import FundamentalUnit
m = FundamentalUnit()
km = m * 1000.
s = FundamentalUnit()
h = s * 3600.
ms = m / s
kmh = km / h
msToKmh = ms >> kmh
msToKmh(100.) # 360
(~msToKmh)(18.) # 5
Documentation
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file simpleunit-1.0.28.tar.gz
.
File metadata
- Download URL: simpleunit-1.0.28.tar.gz
- Upload date:
- Size: 9.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4daed3b094ff7be75b28592693a71b08150a1b690e76e38171bd215d56353371 |
|
MD5 | b598a7b3bce0a267b48ecbaf62b5b143 |
|
BLAKE2b-256 | ef5c029ad9de8d39182195743b2710768ebceb285fbd451a20313a4927421f7e |
File details
Details for the file simpleunit-1.0.28-py3-none-any.whl
.
File metadata
- Download URL: simpleunit-1.0.28-py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a9fe13e025ad281a7a2031cfee0b87e88222596b6f989601125513678f0bbb9b |
|
MD5 | c6de93df65dd88cc7c86000c79ea907a |
|
BLAKE2b-256 | 7004a25cabe7f510e3607067e854e4e89cdfdda44914275cad88a5b51da30e53 |