mp-units

June 3, 2026 Β· View on GitHub

logo

License C++ Standard

Conan CI CMake CI clang-tidy CI Freestanding CI Formatting CI

Conan Center Conan testing

mp-units – The Domain-Correct Quantities and Units Library for C++

🎯 Overview

mp-units is a Modern C++ (C++20 and later) library providing the full spectrum of compile‑time safety for domain-specific quantities and units β€” from dimensional analysis to quantity kind safety β€” built on the ISO 80000 International System of Quantities (ISQ). It is a candidate for C++29 standardization (P3045) β€” your chance to shape the future of C++.

#include <mp-units/systems/isq.h>
#include <mp-units/systems/si.h>

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

// Compile-time dimensional analysis β€” zero runtime overhead
static_assert(1 * km / (1 * s) == 1000 * m / s);

// Function signatures encode domain/physics, not just dimensions
void calculate_trajectory(quantity<isq::kinetic_energy[J]> e);

int main()
{
  quantity<isq::potential_energy[J]> Ep = 42 * J;
  quantity<isq::kinetic_energy[J]>   Ek = 123 * J;
  calculate_trajectory(Ek);         // βœ… correct
  // calculate_trajectory(Ep);      // ❌ potential energy β‰  kinetic energy (both in J)

  // quantity<Gy> q = 42 * Sv;      // ❌ absorbed dose β‰  dose equivalent (both J/kg)
}

Try it live on Compiler Explorer

What Sets mp-units Apart?

Beyond standard dimensional analysis and automatic unit conversions, mp-units provides additional safety levels:

  • Quantity Kind Safety β€” mp-units pioneered this safety level: distinguishes quantities that share the same dimension but represent fundamentally different physical concepts: frequency (Hz) β‰  radioactive activity (Bq), absorbed dose (Gy) β‰  dose equivalent (Sv), plane angle (rad) β‰  solid angle (sr). Dimensional analysis alone cannot catch these errors β€” mp-units prevents them at compile time.

  • ISO 80000 (ISQ) Support β€” Built on the International System of Quantities, functions can require specific quantities: isq::height (not just any isq::length), isq::kinetic_energy (not just any isq::energy). The physics of your domain becomes part of the type system.

  • Strongly-Typed Numerics for Any Domain β€” The quantity framework extends beyond physics: define semantically distinct types for item counts, financial values, identifiers, or any numeric abstraction that should never be silently mixed at compile time.

βœ… Key Features

Safety

  • Quantity kind safety: same dimension, different meaning β†’ compile-time error
  • Affine space strong types (quantity and quantity_point)
  • Value-preserving conversions

Performance

  • All dimensional analysis at compile time β€” zero runtime overhead
  • Performance on par with (sometimes even better than) fundamental types

User Experience

  • Optimized for readable, actionable compilation errors
  • Expressive, composable unit expressions

Feature Rich

  • Systems of Quantities and Units; scalar, vector, and tensor quantities
  • Affine space, natural units, strong angular system
  • Highly adjustable text output formatting

Easy to Extend

  • Custom dimensions, quantities, and units in a single line of code

Low Adoption Cost

  • No external dependencies Β· macro-free API Β· C++20 modules-ready Β· freestanding-capable

β†’ Full feature overview

πŸ“š Documentation

Extensive project documentation covers everything from getting started to advanced usage:

β†’ Explore the full documentation

πŸ” Try It Out

For advanced development or contributions, we provide a fully configured cloud development environment with GitHub Codespaces:

Open in GitHub Codespaces

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.

πŸš€ Help Shape the Future of C++

mp-units is a candidate for ISO standardization for C++29 β€” the future of dimensional analysis in C++! The technical case is documented in:

🀝 We are actively seeking organizations and individuals interested in field‑trialing the library!

Your experience matters. Real-world testimonials demonstrate value to the ISO C++ Committee and help potential adopters decide. 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

🀝 Contributors

mp-units is made possible by our community of contributors! πŸ’ͺ

Contributors Commits Stars

πŸ† Core Team

πŸ™ All Contributors

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

🌟 See our Contributors Page for the complete list and recognition details.

Ready to contribute? Check out our Contributing Guide 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

    Sponsor

  • πŸ“’ Share your success story – Help demonstrate real-world value for standardization and other potential users

  • 🀝 Contribute – Code, documentation, feedback, and community support