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++
- Host: GitHub
- URL: https://github.com/mpusz/mp-units
- Owner: mpusz
- License: mit
- Created: 2018-08-22T10:12:46.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2025-04-04T11:27:56.000Z (12 months ago)
- Last Synced: 2025-04-11T16:19:13.527Z (11 months ago)
- Topics: 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
- Language: C++
- Homepage: https://mpusz.github.io/mp-units/
- Size: 35.9 MB
- Stars: 1,172
- Watchers: 34
- Forks: 100
- Open Issues: 62
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
- Citation: CITATION.cff
Awesome Lists containing this project
README

[](./LICENSE.md)
[](https://en.cppreference.com/w/cpp/compiler_support#cpp20)
[](https://github.com/mpusz/mp-units/actions/workflows/ci-conan.yml)
[](https://github.com/mpusz/mp-units/actions/workflows/ci-test-package-cmake.yml)
[](https://github.com/mpusz/mp-units/actions/workflows/ci-clang-tidy.yml)
[](https://github.com/mpusz/mp-units/actions/workflows/ci-freestanding.yml)
[](https://github.com/mpusz/mp-units/actions/workflows/ci-formatting.yml)
[](https://github.com/mpusz/mp-units/actions?query=workflow%3ADocumentation+branch%3Amaster)
[](https://conan.io/center/mp-units)
[](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
[](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);
```
[](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
}
```
[](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):
[](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! 💪
[](https://github.com/mpusz/mp-units/graphs/contributors)
[](https://github.com/mpusz/mp-units/pulse)
[](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