Files
mp-units/docs/quick_start.rst

80 lines
2.7 KiB
ReStructuredText
Raw Normal View History

2020-03-09 18:55:41 +01:00
Quick Start
===========
Here is a small example of possible operations::
#include <units/physical/si/area.h>
#include <units/physical/si/frequency.h>
#include <units/physical/si/speed.h>
using namespace units::physical::si;
2020-03-09 18:55:41 +01:00
// simple numeric operations
static_assert(10_q_km / 2 == 5_q_km);
2020-03-09 18:55:41 +01:00
// unit conversions
static_assert(1_q_h == 3600_q_s);
static_assert(1_q_km + 1_q_m == 1001_q_m);
2020-03-09 18:55:41 +01:00
// dimension conversions
static_assert(1_q_km / 1_q_s == 1000_q_m_per_s);
static_assert(2_q_km_per_h * 2_q_h == 4_q_km);
static_assert(2_q_km / 2_q_km_per_h == 1_q_h);
2020-03-09 18:55:41 +01:00
static_assert(2_q_m * 3_q_m == 6_q_m2);
2020-06-25 17:45:11 +02:00
static_assert(10_q_km / 5_q_km == 2);
2020-06-25 17:45:11 +02:00
static_assert(1000 / 1_q_s == 1_q_kHz);
2020-06-25 17:45:11 +02:00
2020-03-09 18:55:41 +01:00
.. admonition:: Try it on Compiler Explorer
2020-09-13 11:36:37 +02:00
`Example #1 <https://godbolt.org/z/YWch6d>`_
2020-03-09 18:55:41 +01:00
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 <units/format.h>
#include <units/physical/si/speed.h>
#include <units/physical/si/international/speed.h>
2020-12-28 17:40:29 +01:00
#include <units/quantity_io.h>
2020-03-09 18:55:41 +01:00
#include <iostream>
using namespace units::physical;
2020-03-09 18:55:41 +01:00
constexpr Speed auto avg_speed(Length auto d, Time auto t)
2020-03-09 18:55:41 +01:00
{
return d / t;
}
int main()
{
using namespace units::physical::si::literals;
using namespace units::physical::si::unit_constants;
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<si::international::mile>(140), si::time<si::hour>(2));
constexpr Speed auto v4 = quantity_cast<si::speed<si::metre_per_second>>(v2);
constexpr Speed auto v5 = quantity_cast<si::metre_per_second>(v3);
constexpr Speed auto v6 = quantity_cast<int>(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
2020-03-09 18:55:41 +01:00
}
.. admonition:: Try it on Compiler Explorer
`Example #2 <https://godbolt.org/z/eca49d>`_
2020-03-09 18:55:41 +01:00
.. seealso::
2021-02-16 16:19:57 +01:00
You can find more code examples in the :ref:`examples:Examples` chapter.