Skyward boardcore
Loading...
Searching...
No Matches
Acceleration.h
Go to the documentation of this file.
1/* Copyright (c) 2023 Skyward Experimental Rocketry
2 * Author: Davide Basso
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 * THE SOFTWARE.
21 */
22
23#pragma once
24
25#include <utils/Constants.h>
26
27#include <ratio>
28
29#include "Units.h"
30
31namespace Boardcore
32{
33namespace Units
34{
35namespace Acceleration
36{
37
38template <class Ratio = std::ratio<1>>
39using Acceleration = Unit<UnitKind::Acceleration, Ratio>;
40
41template <class ToAcceleration, class FromAcceleration>
42ToAcceleration acceleration_cast(FromAcceleration const& from)
43{
44 return ToAcceleration(from);
45}
46
47using MeterPerSecondSquared = Acceleration<>; // Acceleration in m/s^2
48using G =
49 Acceleration<std::ratio<static_cast<std::intmax_t>(Constants::g * 1e10),
50 static_cast<std::intmax_t>(1e10)>>; // Acceleration
51 // in Gs
52
56static_assert(MeterPerSecondSquared{G{1}}.value() == Constants::g,
57 "Not enough precision to represent g in m/s^2");
58
59// Floats
60constexpr auto operator""_mps2(long double n)
61{
62 return MeterPerSecondSquared(static_cast<float>(n));
63};
64constexpr auto operator""_g(long double n) { return G(static_cast<float>(n)); };
65// Integers
66constexpr auto operator""_mps2(unsigned long long n)
67{
68 return MeterPerSecondSquared(static_cast<float>(n));
69};
70constexpr auto operator""_g(unsigned long long n)
71{
72 return G(static_cast<float>(n));
73};
74
75} // namespace Acceleration
76} // namespace Units
77} // namespace Boardcore
Acceleration< std::ratio< static_cast< std::intmax_t >(Constants::g *1e10), static_cast< std::intmax_t >(1e10)> > G
ToAcceleration acceleration_cast(FromAcceleration const &from)
Acceleration<> MeterPerSecondSquared
Unit< UnitKind::Acceleration, Ratio > Acceleration
This file includes all the types the logdecoder script will decode.