# Physics

`physics`

is a library for working with quantities in a performant and
type safe manner. It provides some common constants and functions to
work on quantities.

## Typesafety

Quantities do not have an instance of Num to prevent multiplication without changing the units.
Special functions are provided which substitute common operations like `>+<`

, `>-<`

, `>/<`

, `>*<`

.

The naming convention is that operators get on quantity facing sides a
greater than or an less than sign. If you want to multiply a quantity with a number you can use `*<`

.

## Planck units

`physics`

supports planck units, albeit for most cases they are not
recommended. The standard used are SI units.

```
import Physics.Units
import qualified Physics.Units.Planck as P
main = do
print lightspeed
-- 299792458 m s⁻¹
print $ fromSI lightspeed
-- 1.0 mₚ sₚ⁻¹
print . fromPlanck $ P.metre >/< P.second
-- 2.99792458e8 m s⁻¹
```

## Constants

Constants are divided into measured constants (which are sorted by
increasing precision), exact constants (lightspeed for example) and
derived constants. All derived constants are defined in terms of
measured and exact constants and not simply as a number.

Because of this, updating constants is quite easy, only a small number
of measured constants need to be updated when more precise
measurements are available.

`physics`

strives to be as performant as possible. Quantities are
newtypes and operators are defined in terms of num operators.

## Example usage

```
{-# LANGUAGE TypeOperators #-}
module Main where
import Physics.Units
main :: IO ()
main = do
print $ fmap round momentum
-- 992 m kg s⁻¹
print $ fmap round kineticEnergy
-- 5176 m² kg s⁻²
mass :: Kilogram Double
mass = 95 *< kilogram
time :: Second Double
time = 9.58 *< second
distance :: Metre Double
distance = 100 *< metre
speed :: (Metre >/< Second) Double
speed = distance >/< time
momentum :: (Newton >*< Second) Double
momentum = mass >*< speed
kineticEnergy :: Joule Double
kineticEnergy = 1/2 *< mass >*< square speed
-- This would be a type error:
-- kineticEnergy = 1/2 *< mass >*< speed
```

## Compatibility

`physics`

works with GHC 7.10.3 or newer. Some features like showing
an Unit or nicer type errors are only available on newer ghcs.