2020-09-05 13:06:09 +02:00
2020-09-05 11:54:09 +02:00
2020-09-04 23:06:57 +02:00
2020-09-04 23:06:57 +02:00
2020-09-04 23:06:57 +02:00
2020-09-04 23:06:57 +02:00
2020-05-10 22:59:16 +02:00
2019-05-08 09:53:07 -06:00
2018-10-01 11:44:35 +02:00
2020-05-29 10:07:01 +02:00
2020-09-05 13:06:09 +02:00
2020-09-04 23:06:57 +02:00
2020-06-25 17:45:11 +02:00

GitHub license Travis CI Conan stable Conan testing

mp-units - A Units Library for C++

The mp-units library is the subject of this ISO C++ paper: P1935. It is explained in this CppCon 2019 talk (slightly dated now). We are working towards potentially having it standardized for C++23 and are actively looking for parties interested in field trialing the library.

Documentation

An extensive project documentation including installation instructions and user's guide can be found on mp-units GitHub Pages.

TL;DR

mp-units is a compile-time enabled Modern C++ library that provides compile-time dimensional analysis and unit/quantity manipulation. The basic idea and design heavily bases on std::chrono::duration and extends it to work properly with many dimensions.

Here is a small example of possible operations:

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

// unit conversions
static_assert(1q_h == 3600q_s);
static_assert(1q_km + 1q_m == 1001q_m);

// dimension conversions
static_assert(1q_km / 1q_s == 1000q_m_per_s);
static_assert(2q_km_per_h * 2q_h == 4q_km);
static_assert(2q_km / 2q_km_per_h == 1q_h);

static_assert(2q_m * 3q_m == 6q_m2);

static_assert(10q_km / 5q_km == 2);

static_assert(1000 / 1q_s == 1q_kHz);

Try it on the Compiler Explorer.

This library requires some C++20 features (concepts, classes as NTTPs, ...). Thanks to them the user gets a powerful but still easy to use interface and all unit conversions and dimensional analysis can be performed without sacrificing on accuracy. Please see the below example for a quick preview of basic library features:

#include <units/physical/si/speed.h>
#include <units/physical/international/speed.h>
#include <iostream>

using namespace units::physical;

constexpr Speed auto avg_speed(Length auto d, Time auto t)
{
  return d / t;
}

int main()
{
  using namespace units::physical::si::literals;
  Speed auto v1 = avg_speed(220q_km, 2q_h);
  Speed auto v2 = avg_speed(si::length<international::mile>(140), si::time<si::hour>(2));
  Speed auto v3 = quantity_cast<si::metre_per_second>(v2);
  Speed auto v4 = quantity_cast<int>(v3);

  std::cout << v1 << '\n';    // 110 km/h
  std::cout << v2 << '\n';    // 70 mi/h
  std::cout << v3 << '\n';    // 31.2928 m/s
  std::cout << v4 << '\n';    // 31 m/s
}

Try it on the Compiler Explorer.

Languages
C++ 71.3%
CMake 26.9%
C 1%
Python 0.8%