Files
mp-units/docs/users_guide/examples/hello_units.md

3.6 KiB

tags
tags
International System
Text Formatting

hello_units

!!! example "Try it on Compiler Explorer"

This is a really simple example showcasing the features of the mp-units library.

First, we either import the mp_units module or include the headers for:

  • an International System of Quantities (ISQ)
  • an International System of units (SI)
  • units derived from the International Yard and Pound
  • text formatting and stream output support
--8<-- "example/hello_units.cpp:28:40"

Also, to shorten the definitions, we "import" all the symbols from the mp_units namespace.

--8<-- "example/hello_units.cpp:41:42"

Next, we define a simple function that calculates the average speed based on the provided arguments of length and time:

--8<-- "example/hello_units.cpp:43:46"

The above function template takes any quantities implicitly convertible to isq::length and isq::time, respectively. Those quantities can use any compatible unit and a representation type. The function returns a result of a straightforward equation and ensures that its quantity type is implicitly convertible to isq::speed.

!!! tip

Besides verifying the type returned from the function, constraining a generic return
type is beneficial for users of such a function as it provides more information
of what to expect from a function than just using `auto`.
--8<-- "example/hello_units.cpp:48:51"

The above lines explicitly opt into using unit symbols from two systems of units. As this introduces a lot of short identifiers into the current scope, it is not done implicitly while including a header file.

--8<-- "example/hello_units.cpp:53:59"
  • Lines 21 & 22 create a quantity of kind isq::length / isq::time with the numbers and units provided. Such quantities can be converted or assigned to any other quantity with a matching kind.
  • Line 23 calls our function template with quantities of kind isq::length and isq::time and number and units provided.
  • Line 24 explicitly provides quantity types of the quantities passed to a function template. This time, those will not be quantity kinds anymore and will have more restrictive conversion rules.
  • Line 25 changes the unit of a quantity v3 to m / s in a value-preserving way (floating-point representations are considered to be value-preserving).
  • Line 26 does a similar operation, but this time, it would also succeed for value-truncating cases (if that was the case).
  • Line 27 does a value-truncating conversion of changing the underlying representation type from double to int.
--8<-- "example/hello_units.cpp:61"

The above presents various ways to print a quantity. Both stream insertion operations and std::format facilities are supported.

!!! tip

`MP_UNITS_STD_FMT` is used for compatibility reasons. If a specific compiler
does not support `std::format` or a user prefers to use the `{fmt}` library, this macro
will resolve to `fmt` namespace. Otherwise, the `std` namespace will be used.