WPILibC++ 2024.1.1-beta-4
temperature.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
31namespace units {
32// NOTE: temperature units have special conversion overloads, since they
33// require translations and aren't a reversible transform.
34
35/**
36 * @namespace units::temperature
37 * @brief namespace for unit types and containers representing temperature
38 * values
39 * @details The SI unit for temperature is `kelvin`, and the corresponding
40 * `base_unit` category is `temperature_unit`.
41 * @anchor temperatureContainers
42 * @sa See unit_t for more information on unit type containers.
43 */
44#if !defined(DISABLE_PREDEFINED_UNITS) || \
45 defined(ENABLE_PREDEFINED_TEMPERATURE_UNITS)
46UNIT_ADD(temperature, kelvin, kelvin, K,
49 unit<std::ratio<1>, kelvin, std::ratio<0>, std::ratio<27315, 100>>)
50UNIT_ADD(temperature, fahrenheit, fahrenheit, degF,
51 unit<std::ratio<5, 9>, celsius, std::ratio<0>, std::ratio<-160, 9>>)
52UNIT_ADD(temperature, reaumur, reaumur, Re, unit<std::ratio<10, 8>, celsius>)
53UNIT_ADD(temperature, rankine, rankine, Ra, unit<std::ratio<5, 9>, kelvin>)
54
55UNIT_ADD_CATEGORY_TRAIT(temperature)
56#endif
57
58using namespace temperature;
59} // namespace units
#define UNIT_ADD_CATEGORY_TRAIT(unitCategory)
Macro to create the is_category_unit type trait.
Definition: base.h:381
Definition: array.h:89
Unit Conversion Library namespace.
Definition: angle.h:31
celsius
Definition: temperature.h:48
degC
Definition: temperature.h:48
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