hello_units¶
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.
Also, to shorten the definitions, we "import" all the symbols from the mp_units namespace.
| hello_units.cpp | |
|---|---|
Next, we define a simple function that calculates the average speed based on the provided arguments of length and time:
| hello_units.cpp | |
|---|---|
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.
| hello_units.cpp | |
|---|---|
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.
- Lines
27&28create a quantity of kindisq::length / isq::timewith the numbers and units provided. Such quantities can be converted or assigned to any other quantity with a matching kind. - Line
29calls our function template with quantities of kindisq::lengthandisq::timeand number and units provided. - Line
30explicitly 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
31changes the unit of a quantityv3tom / sin a value-preserving way (floating-point representations are considered to be value-preserving). - Line
32does a similar operation, but this time, it would also succeed for value-truncating cases (if that was the case). - Line
33does a value-truncating conversion of changing the underlying representation type fromdoubletoint.
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.
More about it can be found in the Wide Compatibility chapter.