PhysicalQuantity struct
Encapsulates a quantity with physical units.
Contents
Multiplying a double by a
dip::Units
object yields a PhysicalQuantity
object. Numbers and units implicitly
convert to a PhysicalQuantity
. It is possible to multiply and divide any physical
quantities, but adding and subtracting is only possible if the units match.
dip::PhysicalQuantity a = 50 * dip::Units( dip::Units::BaseUnits::LENGTH );
Constructors, destructors, assignment and conversion operators
- PhysicalQuantity() defaulted constexpr
- A default-constructed
PhysicalQuantity
has magnitude 0 and is unitless. - PhysicalQuantity(dip::dfloat m, dip::Units const& u = {}) constexpr
- Create an arbitrary physical quantity.
- PhysicalQuantity(dip::Units const& u) constexpr
- Create a unit-valued physical quantity.
Functions
- static auto Nanometer() -> dip::PhysicalQuantity constexpr
- One nanometer.
- static auto Micrometer() -> dip::PhysicalQuantity constexpr
- One micrometer.
- static auto Millimeter() -> dip::PhysicalQuantity constexpr
- One millimeter.
- static auto Centimeter() -> dip::PhysicalQuantity constexpr
- One centimeter.
- static auto Meter() -> dip::PhysicalQuantity constexpr
- One meter.
- static auto Kilometer() -> dip::PhysicalQuantity constexpr
- One kilometer.
- static auto Inch() -> dip::PhysicalQuantity constexpr
- One inch.
- static auto Mile() -> dip::PhysicalQuantity constexpr
- One mile.
- static auto Millisecond() -> dip::PhysicalQuantity constexpr
- One millisecond
- static auto Second() -> dip::PhysicalQuantity constexpr
- One second
- static auto Minute() -> dip::PhysicalQuantity constexpr
- One minute
- static auto Hour() -> dip::PhysicalQuantity constexpr
- One hour
- static auto Day() -> dip::PhysicalQuantity constexpr
- One day
- static auto Radian() -> dip::PhysicalQuantity constexpr
- One radian
- static auto Degree() -> dip::PhysicalQuantity constexpr
- One degree
- static auto Pixel() -> dip::PhysicalQuantity constexpr
- One pixel
- static auto SquarePixel() -> dip::PhysicalQuantity constexpr
- One square pixel
- static auto CubicPixel() -> dip::PhysicalQuantity constexpr
- One cubic pixel
- auto Power(dip::sint8 p) const -> dip::PhysicalQuantity
- Computes a physical quantity to the power of
p
. - auto Invert() const -> dip::PhysicalQuantity constexpr
- Computes a physical quantity to the power of -1.
- auto ApproximatelyEquals(dip::PhysicalQuantity const& rhs, dip::dfloat tolerance = 1e-6) const -> bool constexpr
- Approximate equality comparison of two physical quantities.
- auto NotApproximatelyEquals(dip::PhysicalQuantity const& rhs, dip::dfloat tolerance = 1e-6) const -> bool constexpr
- Exact inequality comparison of two physical quantities
- auto HasSameDimensions(dip::PhysicalQuantity const& other) const -> bool constexpr
- Test to see if the physical quantities can be added together.
- auto IsDimensionless() const -> bool constexpr
- Test to see if the physical quantity is dimensionless (has no units).
- auto IsPhysical() const -> bool constexpr
- Test to see if the physical quantity is actually physical. If pixels are used as units, it’s not a physical quantity, and dimensionless quantities are not physical either.
- auto Normalize() -> dip::PhysicalQuantity& constexpr
- Adjusts the SI prefix such that the magnitude of the quantity is readable.
- auto RemovePrefix() -> dip::PhysicalQuantity& constexpr
- Removes the SI prefix, such that the quantity is in base units (i.e. m rather than nm).
- void swap(dip::PhysicalQuantity& other) noexcept
- Swaps the values of
this
andother
.
Operators
- auto operator*=(dip::PhysicalQuantity const& other) -> dip::PhysicalQuantity& constexpr
- Multiplies two physical quantities.
- auto operator*=(dip::dfloat other) -> dip::PhysicalQuantity& constexpr
- Scaling of a physical quantity.
- auto operator/=(dip::PhysicalQuantity const& other) -> dip::PhysicalQuantity& constexpr
- Divides two physical quantities.
- auto operator/=(dip::dfloat other) -> dip::PhysicalQuantity& constexpr
- Scaling of a physical quantity.
- auto operator-() const -> dip::PhysicalQuantity constexpr
- Unary negation.
- auto operator+=(dip::PhysicalQuantity const& other) -> dip::PhysicalQuantity& constexpr
- Addition of two physical quantities.
- auto operator-=(dip::PhysicalQuantity other) -> dip::PhysicalQuantity& constexpr
- Subtraction of two physical quantities.
- auto operator==(dip::PhysicalQuantity const& rhs) const -> bool constexpr
- Exact equality comparison of two physical quantities.
- auto operator!=(dip::PhysicalQuantity const& rhs) const -> bool constexpr
- Exact inequality comparison of two physical quantities
- auto operator dip::dfloat() const -> dip::dfloat explicit constexpr
- Retrieve the magnitude, discarding units.
- auto operator bool() const -> bool explicit constexpr
- A physical quantity tests true if it is different from 0.
Variables
- dip::dfloat magnitude = 0
- The magnitude
- dip::Units units
- The units