Skyward boardcore
Loading...
Searching...
No Matches
Frequency.h
Go to the documentation of this file.
1
/* Copyright (c) 2024 Skyward Experimental Rocketry
2
* Author: Niccolò Betto
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 <cstdint>
26
27
#include "
Units.h
"
28
29
namespace
Boardcore
30
{
31
32
namespace
Units
33
{
34
35
namespace
Frequency
36
{
37
38
template
<
class
Ratio = std::ratio<1>>
39
using
Frequency
= Unit<UnitKind::Frequency, Ratio>;
40
41
using
Hertz
= Frequency<>;
42
using
Kilohertz
= Frequency<std::kilo>;
43
44
// Integers
45
constexpr
auto
operator
""
_hz(
unsigned
long
long
n)
46
{
47
return
Hertz
(
static_cast<
float
>
(n));
48
};
49
50
constexpr
auto
operator
""
_khz(
unsigned
long
long
n)
51
{
52
return
Kilohertz
(
static_cast<
float
>
(n));
53
};
54
55
// Floats
56
constexpr
auto
operator
""
_hz(
long
double
n)
57
{
58
return
Hertz
(
static_cast<
float
>
(n));
59
};
60
61
constexpr
auto
operator
""
_khz(
long
double
n)
62
{
63
return
Kilohertz
(
static_cast<
float
>
(n));
64
};
65
66
}
// namespace Frequency
67
68
}
// namespace Units
69
70
}
// namespace Boardcore
Units.h
Boardcore::Units::Unit
Definition
Units.h:62
Boardcore::Units::Frequency::Kilohertz
Frequency< std::kilo > Kilohertz
Definition
Frequency.h:42
Boardcore::Units::Frequency::Hertz
Frequency<> Hertz
Definition
Frequency.h:41
Boardcore
This file includes all the types the logdecoder script will decode.
Definition
ActiveObject.h:31
src
shared
units
Frequency.h
Generated by
1.10.0