Quick Start =========== Here is a small example of possible operations:: #define UNITS_REFERENCES #include #include #include #include #include using namespace units::isq::si::references; // simple numeric operations static_assert(10 * km / 2 == 5 * km); // unit conversions static_assert(1 * h == 3600 * s); static_assert(1 * km + 1 * m == 1001 * m); // dimension conversions inline constexpr auto kmph = km / h; static_assert(1 * km / (1 * s) == 1000 * (m / s)); static_assert(2 * kmph * (2 * h) == 4 * km); static_assert(2 * km / (2 * kmph) == 1 * h); static_assert(2 * m * (3 * m) == 6 * m2); static_assert(10 * km / (5 * km) == 2); static_assert(1000 / (1 * s) == 1 * kHz); .. admonition:: Try it on Compiler Explorer `Example #1 `_ This library requires some C++20 features (concepts, classes as :abbr:`NTTP (Non-Type Template Parameter)`, ...). Thanks to them the user gets a powerful but still easy to use interface where 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:: #define UNITS_REFERENCES #define UNITS_LITERALS #include #include #include #include #include #include #include #include using namespace units::isq; constexpr Speed auto avg_speed(Length auto d, Time auto t) { return d / t; } int main() { using namespace units::isq::si::literals; using namespace units::isq::si::references; constexpr Speed auto v1 = 110 * (km / h); constexpr Speed auto v2 = avg_speed(220_q_km, 2_q_h); constexpr Speed auto v3 = avg_speed(si::length(140), si::time(2)); constexpr Speed auto v4 = units::quantity_cast>(v2); constexpr Speed auto v5 = units::quantity_cast(v3); constexpr Speed auto v6 = units::quantity_cast(v5); std::cout << v1 << '\n'; // 110 km/h std::cout << fmt::format("{}", v2) << '\n'; // 110 km/h std::cout << fmt::format("{:*^14}", v3) << '\n'; // ***70 mi/h**** std::cout << fmt::format("{:%Q in %q}", v4) << '\n'; // 30.5556 in m/s std::cout << fmt::format("{0:%Q} in {0:%q}", v5) << '\n'; // 31.2928 in m/s std::cout << fmt::format("{:%Q}", v6) << '\n'; // 31 } .. admonition:: Try it on Compiler Explorer `Example #2 `_ .. seealso:: You can find more code examples in the :ref:`examples:Examples` chapter.