2020-03-09 18:55:41 +01:00
|
|
|
Quick Start
|
|
|
|
===========
|
|
|
|
|
|
|
|
Here is a small example of possible operations::
|
|
|
|
|
2020-09-11 23:32:41 +02:00
|
|
|
#include <units/physical/si/si.h>
|
|
|
|
|
|
|
|
using namespace units::physical::si;
|
|
|
|
|
2020-03-09 18:55:41 +01:00
|
|
|
// simple numeric operations
|
2020-09-09 19:20:35 +02:00
|
|
|
static_assert(10_q_km / 2 == 5_q_km);
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
// unit conversions
|
2020-09-09 19:20:35 +02:00
|
|
|
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
|
2020-09-09 19:20:35 +02:00
|
|
|
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
|
|
|
|
2020-09-09 19:20:35 +02:00
|
|
|
static_assert(2_q_m * 3_q_m == 6_q_m2);
|
2020-06-25 17:45:11 +02:00
|
|
|
|
2020-09-09 19:20:35 +02:00
|
|
|
static_assert(10_q_km / 5_q_km == 2);
|
2020-06-25 17:45:11 +02:00
|
|
|
|
2020-09-09 19:20:35 +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-11 08:46:09 +02:00
|
|
|
`Example #1 <https://godbolt.org/z/oc7P9z>`_
|
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::
|
|
|
|
|
2020-09-11 23:32:41 +02:00
|
|
|
#include <units/physical/si/si.h>
|
|
|
|
#include <units/physical/si/international/international.h>
|
2020-09-07 12:45:56 +02:00
|
|
|
#include <units/format.h>
|
2020-03-09 18:55:41 +01:00
|
|
|
#include <iostream>
|
|
|
|
|
2020-05-08 22:39:24 +02:00
|
|
|
using namespace units::physical;
|
2020-03-09 18:55:41 +01:00
|
|
|
|
2020-05-10 17:31:47 +02: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()
|
|
|
|
{
|
2020-05-08 22:39:24 +02:00
|
|
|
using namespace units::physical::si::literals;
|
2020-09-09 19:20:35 +02:00
|
|
|
Speed auto v1 = avg_speed(220_q_km, 2_q_h);
|
2020-09-10 17:14:33 +02:00
|
|
|
Speed auto v2 = avg_speed(si::length<si::international::mile>(140), si::time<si::hour>(2));
|
2020-05-10 17:31:47 +02:00
|
|
|
Speed auto v3 = quantity_cast<si::metre_per_second>(v2);
|
|
|
|
Speed auto v4 = quantity_cast<int>(v3);
|
2020-03-09 18:55:41 +01:00
|
|
|
|
2020-09-11 08:46:09 +02:00
|
|
|
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
|
2020-03-09 18:55:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.. admonition:: Try it on Compiler Explorer
|
|
|
|
|
2020-09-11 08:46:09 +02:00
|
|
|
`Example #2 <https://godbolt.org/z/Wd9d87>`_
|
2020-03-09 18:55:41 +01:00
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
You can find more code examples in the :ref:`Examples` chapter.
|