WPILibC++ 2024.1.1-beta-4
velocity.h
Go to the documentation of this file.
1// Copyright (c) FIRST and other WPILib contributors.
2// Open Source Software; you can modify and/or share it under the terms of
3// the WPILib BSD license file in the root directory of this project.
4
5// Copyright (c) 2016 Nic Holthaus
6//
7// The MIT License (MIT)
8//
9// Permission is hereby granted, free of charge, to any person obtaining a copy
10// of this software and associated documentation files (the "Software"), to deal
11// in the Software without restriction, including without limitation the rights
12// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13// copies of the Software, and to permit persons to whom the Software is
14// furnished to do so, subject to the following conditions:
15//
16// The above copyright notice and this permission notice shall be included in
17// all copies or substantial portions of the Software.
18//
19// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
25// SOFTWARE.
26
27#pragma once
28
29#include "units/base.h"
30#include "units/length.h"
31#include "units/time.h"
32
33namespace units {
34/**
35 * @namespace units::velocity
36 * @brief namespace for unit types and containers representing velocity values
37 * @details The SI unit for velocity is `meters_per_second`, and the
38 * corresponding `base_unit` category is `velocity_unit`.
39 * @anchor velocityContainers
40 * @sa See unit_t for more information on unit type containers.
41 */
42#if !defined(DISABLE_PREDEFINED_UNITS) || \
43 defined(ENABLE_PREDEFINED_VELOCITY_UNITS)
44UNIT_ADD(velocity, meters_per_second, meters_per_second, mps,
47 compound_unit<length::feet, inverse<time::seconds>>)
48UNIT_ADD(velocity, miles_per_hour, miles_per_hour, mph,
49 compound_unit<length::miles, inverse<time::hour>>)
51 compound_unit<length::kilometers, inverse<time::hour>>)
52UNIT_ADD(velocity, knot, knots, kts,
53 compound_unit<length::nauticalMiles, inverse<time::hour>>)
54
56#endif
57
58using namespace velocity;
59} // namespace units
#define UNIT_ADD_CATEGORY_TRAIT(unitCategory)
Macro to create the is_category_unit type trait.
Definition: base.h:381
typename units::detail::inverse_impl< U >::type inverse
represents the inverse unit type of class U.
Definition: base.h:1146
typename units::detail::compound_impl< U, Us... >::type compound_unit
Represents a unit type made up from other units.
Definition: base.h:1446
Unit Conversion Library namespace.
Definition: angle.h:31
compound_unit< length::feet, inverse< time::seconds > > kph
Definition: velocity.h:50
fps
Definition: velocity.h:46
nauticalMiles
Definition: length.h:48
compound_unit< length::feet, inverse< time::seconds > > kilometers_per_hour
Definition: velocity.h:50
feet_per_second
Definition: velocity.h:46
unit< std::ratio< 1, 180 >, radians, std::ratio< 1 > > UNIT_ADD(angle, arcsecond, arcseconds, arcsec, unit< std::ratio< 1, 60 >, arcminutes >) using namespace angle
Class representing SI base unit types.
Definition: base.h:769
Type representing an arbitrary unit.
Definition: base.h:896