WPILibC++ 2023.4.3-108-ge5452e3
magnetic_field_strength.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/magnetic_flux.h"
32
33namespace units {
34/**
35 * @namespace units::magnetic_field_strength
36 * @brief namespace for unit types and containers representing
37 * magnetic_field_strength values
38 * @details The SI unit for magnetic_field_strength is `teslas`, and the
39 * corresponding `base_unit` category is
40 * `magnetic_field_strength_unit`.
41 * @anchor magneticFieldStrengthContainers
42 * @sa See unit_t for more information on unit type containers.
43 */
44// Unfortunately `_T` is a WINAPI macro, so we have to use `_Te` as the tesla
45// abbreviation.
46#if !defined(DISABLE_PREDEFINED_UNITS) || \
47 defined(ENABLE_PREDEFINED_MAGNETIC_FIELD_STRENGTH_UNITS)
49 magnetic_field_strength, tesla, teslas, Te,
52 magnetic_field_strength, gauss, gauss, G,
53 compound_unit<magnetic_flux::maxwell, inverse<squared<length::centimeter>>>)
54
55UNIT_ADD_CATEGORY_TRAIT(magnetic_field_strength)
56#endif
57
58using namespace magnetic_field_strength;
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:1145
typename units::detail::squared_impl< U >::type squared
represents the unit type of class U squared
Definition: base.h:1176
typename units::detail::compound_impl< U, Us... >::type compound_unit
Represents a unit type made up from other units.
Definition: base.h:1445
Unit Conversion Library namespace.
Definition: magnetic_flux.h:31
UNIT_ADD(moment_of_inertia, kilogram_square_meter, kilogram_square_meters, kg_sq_m, compound_unit< mass::kilograms, area::square_meters >) using namespace moment_of_inertia
maxwell
Definition: magnetic_flux.h:46
gauss
Definition: magnetic_field_strength.h:52
G
Definition: magnetic_field_strength.h:52
UNIT_ADD_WITH_METRIC_PREFIXES(magnetic_flux, weber, webers, Wb, unit< std::ratio< 1 >, units::category::magnetic_flux_unit >) UNIT_ADD(magnetic_flux
Class representing SI base unit types.
Definition: base.h:769
Type representing an arbitrary unit.
Definition: base.h:895