Quick Start =========== Here is a small example of possible operations:: #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:: #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; using namespace units::aliases::isq::si::international; constexpr Speed auto v1 = 110 * (km / h); constexpr Speed auto v2 = mi_per_h(70.); constexpr Speed auto v3 = avg_speed(220_q_km, 2_q_h); constexpr Speed auto v4 = avg_speed(si::length(140), si::time(2)); constexpr Speed auto v5 = quantity_cast>(v3); constexpr Speed auto v6 = quantity_cast(v4); constexpr Speed auto v7 = quantity_cast(v6); std::cout << v1 << '\n'; // 110 km/h std::cout << v2 << '\n'; // 70 mi/h std::cout << std::format("{}", v3) << '\n'; // 110 km/h std::cout << std::format("{:*^14}", v4) << '\n'; // ***70 mi/h**** std::cout << std::format("{:%Q in %q}", v5) << '\n'; // 30.5556 in m/s std::cout << std::format("{0:%Q} in {0:%q}", v6) << '\n'; // 31.2928 in m/s std::cout << std::format("{:%Q}", v7) << '\n'; // 31 } .. admonition:: Try it on Compiler Explorer `Example #2 `_ .. seealso:: You can find more code examples in the :ref:`examples:Examples` chapter.