An open API service indexing awesome lists of open source software.

https://github.com/mpusz/mp-units

The quantities and units library for C++
https://github.com/mpusz/mp-units

cmake conan cpp cpp20 cpp23 dimensional-analysis dimensions isq library physical-quantities physical-units quantity quantity-manipulation safety si system-of-quantities system-of-units units units-of-measure units-of-measurement

Last synced: 3 months ago
JSON representation

The quantities and units library for C++

Awesome Lists containing this project

README

          

logo

[![License](https://img.shields.io/github/license/mpusz/mp-units?cacheSeconds=3600&color=informational&label=License)](./LICENSE.md)
[![C++ Standard](https://img.shields.io/badge/C%2B%2B-20%2F23-blue)](https://en.cppreference.com/w/cpp/compiler_support#cpp20)

[![Conan CI](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/ci-conan.yml?branch=master&label=Conan%20CI)](https://github.com/mpusz/mp-units/actions/workflows/ci-conan.yml)
[![CMake CI](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/ci-test-package-cmake.yml?branch=master&label=CMake%20CI)](https://github.com/mpusz/mp-units/actions/workflows/ci-test-package-cmake.yml)
[![clang-tidy CI](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/ci-clang-tidy.yml?branch=master&label=clang-tidy%20CI)](https://github.com/mpusz/mp-units/actions/workflows/ci-clang-tidy.yml)
[![Freestanding CI](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/ci-freestanding.yml?branch=master&label=Freestanding%20CI)](https://github.com/mpusz/mp-units/actions/workflows/ci-freestanding.yml)
[![Formatting CI](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/ci-formatting.yml?branch=master&label=Formatting%20CI)](https://github.com/mpusz/mp-units/actions/workflows/ci-formatting.yml)
[![Documentation](https://img.shields.io/github/actions/workflow/status/mpusz/mp-units/documentation.yml?branch=master&label=Documentation)](https://github.com/mpusz/mp-units/actions?query=workflow%3ADocumentation+branch%3Amaster)

[![Conan Center](https://img.shields.io/conan/v/mp-units?label=ConanCenter&color=blue)](https://conan.io/center/mp-units)
[![Conan testing](https://img.shields.io/badge/mpusz.jfrog.io-2.5.0%3Atesting-blue)](https://mpusz.jfrog.io/ui/packages/conan:%2F%2Fmp-units/2.5.0)

# `mp-units` – The Quantities and Units Library for C++

> 🚀 **ISO C++29 Standardization Candidate** – The future of dimensional analysis in C++!

**The `mp-units` library is a candidate for ISO standardization for C++29.**
More context can be found in the following ISO C++ proposals:

- [P1935: A C++ Approach to Physical Units](https://wg21.link/p1935)
- [P2980: A motivation, scope, and plan for a quantities and units library](https://wg21.link/p2980)
- [P3045: Quantities and units library](https://wg21.link/p3045)

> 🤝 **We are actively seeking organizations and individuals interested in**
> **field‑trialing the library!**

## 🌟 Share Your Success Story

**Help shape the future of C++!**
Your testimonials help **demonstrate real-world value** to the ISO C++ Committee and
other potential library users!

Whether you're using mp-units in **production**, **research**, or **education**:

- **Organizations**: Share your production deployments and success stories
- **Academics**: Report research applications and teaching experiences
- **Developers**: Tell us about your innovative use cases and benefits

[![Share Experience](https://img.shields.io/badge/Share_Your-Usage_Experience-blue?style=for-the-badge&labelColor=black&label=🌟%20Share%20Your)](https://github.com/mpusz/mp-units/issues/new?template=usage_experience.yml)

## 📚 Documentation

Extensive project documentation is available on the **[project site](https://mpusz.github.io/mp-units)**.
It includes:

- **Installation instructions** – Get up and running quickly
- **Detailed user's guide** – Comprehensive usage documentation
- **Design rationale** – Understanding the architectural decisions
- **API reference** – Complete technical documentation
- **Tutorials** – Step-by-step learning resources
- **Examples** – Real-world usage demonstrations

## ⚡ TL;DR

**`mp-units`** is a Modern C++ (C++20 and later) library providing compile‑time
dimensional analysis and safe manipulation of units, quantities, and quantity points.

### Key Features

- **Type Safety** – Strongly typed quantities, units, dimensions, and quantity points
- **Zero Runtime Cost** – Compile‑time dimensional analysis with no runtime overhead
- **Unified Design** – Comprehensive model for units, dimensions, quantities, and point origins
- **Rich Text Formatting** – Text formatting support with extensive options &
character sets
- **Flexible Usage** – C++ modules support (when available) and header‑only usage
- **Configurable** – Contracts, freestanding mode, and natural units (experimental)
- **Interoperable** – Seamless pathways for legacy and external libraries

### Quick Example

Here's a taste of what **mp-units** can do:

```cpp
#include

using namespace mp_units;
using namespace mp_units::si::unit_symbols;

// simple numeric operations
static_assert(10 * km / 2 == 5 * km);

// conversions to common units
static_assert(1 * h == 3600 * s);
static_assert(1 * km + 1 * m == 1001 * m);

// derived quantities
static_assert(1 * km / (1 * s) == 1000 * m / s);
static_assert(2 * km / h * (2 * h) == 4 * km);
static_assert(2 * km / (2 * km / h) == 1 * h);

static_assert(2 * m * (3 * m) == 6 * m2);

static_assert(10 * km / (5 * km) == 2 * one);

static_assert(1000 / (1 * s) == 1 * kHz);
```

[![Try it live on Compiler Explorer](https://img.shields.io/badge/Try_live_on-Compiler_Explorer-black?style=for-the-badge&logo=compilerexplorer&labelColor=black&color=67C52A)](https://godbolt.org/z/fT1r4sohs)

### Modern C++ Design

The library makes extensive use of **C++20 features** (concepts, class types as NTTPs, etc.).
This enables powerful yet easy‑to‑use interfaces while performing all conversions and dimensional
analysis at compile time—without sacrificing runtime performance or accuracy.

### More Advanced Example

Here's a broader preview showcasing **mp-units** capabilities:

```cpp
#include
#include
#include
#include
#include
#include
#include

using namespace mp_units;

constexpr QuantityOf auto avg_speed(QuantityOf auto d,
QuantityOf auto t)
{
return d / t;
}

int main()
{
using namespace mp_units::si::unit_symbols;
using namespace mp_units::international::unit_symbols;

constexpr quantity v1 = 110 * km / h;
constexpr quantity v2 = 70 * mph;
constexpr quantity v3 = avg_speed(220. * isq::distance[km], 2 * h);
constexpr quantity v4 = avg_speed(isq::distance(140. * mi), 2 * h);
constexpr quantity v5 = v3.in(m / s);
constexpr quantity v6 = value_cast(v4);
constexpr quantity v7 = value_cast(v6);

std::cout << v1 << '\n'; // 110 km/h
std::cout << std::setw(10) << std::setfill('*') << v2 << '\n'; // ***70 mi/h
std::cout << std::format("{:*^10}\n", v3); // *110 km/h*
std::println("{:%N in %U of %D}", v4); // 70 in mi/h of LT⁻¹
std::println("{::N[.2f]}", v5); // 30.56 m/s
std::println("{::N[.2f]U[dn]}", v6); // 31.29 m⋅s⁻¹
std::println("{:%N}", v7); // 31
}
```

[![Try it live on Compiler Explorer](https://img.shields.io/badge/Try_live_on-Compiler_Explorer-black?style=for-the-badge&logo=compilerexplorer&labelColor=black&color=67C52A)](https://godbolt.org/z/fxcjs19ah)

## 🔍 Try It Out

### Compiler Explorer

**mp-units** is available on Compiler Explorer for instant experimentation!
Perfect for fast, zero‑setup trials and prototyping your ideas.

### GitHub Codespaces

For **advanced development** or **contributions**, we provide a fully configured cloud
development environment with [GitHub Codespaces](https://docs.github.com/en/codespaces):

[![Open in GitHub Codespaces](https://img.shields.io/badge/Open_in-GitHub_Codespaces-blue?style=for-the-badge&logo=github&labelColor=black&color=2088FF)](https://codespaces.new/mpusz/mp-units)

**Alternatives:**
1. Navigate to the repository → **"Code"** → **"Codespaces"** → **"Create codespace on master"**
2. Use the pre‑configured devcontainer and Docker image manually in your IDE

For detailed environment documentation, see [`.devcontainer/README.md`](.devcontainer/README.md).

### Install as a Dependency

🥇 **Recommended:** We recommend using [**Conan**](https://conan.io/center/recipes/mp-units)
to integrate **mp-units** with your project.

**Multiple options available!** Please refer to our comprehensive
[**Installation and Usage Guide**](https://mpusz.github.io/mp-units/latest/getting_started/installation_and_usage)
for all supported integration methods.

## 🤝 Contributors

**mp-units** is made possible by our amazing community of contributors! 💪

[![Contributors](https://img.shields.io/github/contributors/mpusz/mp-units?style=for-the-badge&logo=github&labelColor=black&color=blue)](https://github.com/mpusz/mp-units/graphs/contributors)
[![Commits](https://img.shields.io/github/commit-activity/m/mpusz/mp-units?style=for-the-badge&logo=git&labelColor=black&color=green)](https://github.com/mpusz/mp-units/pulse)
[![Stars](https://img.shields.io/github/stars/mpusz/mp-units?style=for-the-badge&label=⭐%20Stars&labelColor=black&color=gold)](https://github.com/mpusz/mp-units/stargazers)

### 🏆 Core Team

- **[Mateusz Pusz](https://github.com/mpusz)** – Project founder and lead
- **[Johel Ernesto Guerrero Peña](https://github.com/JohelEGP)** – Core maintainer
- **[Chip Hogg](https://github.com/chiphogg)** – Core maintainer

### 🙏 All Contributors

We appreciate **every contribution**, from code to documentation to community support!

🌟 See our [**Contributors Page**](CONTRIBUTORS.md) for the complete list and recognition details.

> **Ready to contribute?** Check out our
[**Contributing Guide**](https://mpusz.github.io/mp-units/latest/getting_started/contributing/)
to get started! 🚀

## 💝 Support the Project

**mp-units** is developed as open source with the ambitious goal of C++29 standardization.
Your support helps maintain development momentum and accelerate standardization efforts!

**Ways to support:**
- ⭐ **Star the repository** – Show your appreciation and help others discover **mp-units**
- 💰 **Become a sponsor** – Financial support enables continued development
- 📢 **Share your success story** – Help demonstrate real-world value for standardization
and other potential users
- 🤝 **Contribute** – Code, documentation, feedback, and community support