blob: 53bd7c902f9e42185a1da7fbb5758bdb093f341e [file] [log] [blame]
Sebastian Jansson26b5e352019-06-07 11:05:31 +02001/*
2 * Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10#ifndef API_UNITS_FREQUENCY_H_
11#define API_UNITS_FREQUENCY_H_
12
13#ifdef UNIT_TEST
14#include <ostream> // no-presubmit-check TODO(webrtc:8982)
15#endif // UNIT_TEST
16
17#include <cstdlib>
18#include <limits>
19#include <string>
20#include <type_traits>
21
22#include "api/units/time_delta.h"
23#include "rtc_base/units/unit_base.h"
24
25namespace webrtc {
26
27class Frequency final : public rtc_units_impl::RelativeUnit<Frequency> {
28 public:
29 Frequency() = delete;
30 template <int64_t hertz>
31 static constexpr Frequency Hertz() {
Danil Chapovalov7356a562020-01-20 13:02:44 +010032 return FromFraction(1000, hertz);
Sebastian Jansson26b5e352019-06-07 11:05:31 +020033 }
34 template <typename T>
Sebastian Jansson1cf15bf2020-01-29 10:56:25 +010035 static constexpr Frequency kHz(T hertz) {
36 static_assert(std::is_arithmetic<T>::value, "");
37 return FromFraction(1000000, hertz);
38 }
39 template <typename T>
Sebastian Janssond7fade52020-01-29 10:44:51 +010040 static constexpr Frequency hertz(T hertz) {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020041 static_assert(std::is_arithmetic<T>::value, "");
Danil Chapovalov7356a562020-01-20 13:02:44 +010042 return FromFraction(1000, hertz);
Sebastian Jansson26b5e352019-06-07 11:05:31 +020043 }
44 template <typename T>
Sebastian Janssond7fade52020-01-29 10:44:51 +010045 static constexpr Frequency millihertz(T hertz) {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020046 static_assert(std::is_arithmetic<T>::value, "");
47 return FromValue(hertz);
48 }
49 template <typename T = int64_t>
Sebastian Janssond7fade52020-01-29 10:44:51 +010050 constexpr T hertz() const {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020051 return ToFraction<1000, T>();
52 }
53 template <typename T = int64_t>
Sebastian Janssond7fade52020-01-29 10:44:51 +010054 constexpr T millihertz() const {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020055 return ToValue<T>();
56 }
57
58 private:
59 friend class rtc_units_impl::UnitBase<Frequency>;
60 using RelativeUnit::RelativeUnit;
61 static constexpr bool one_sided = true;
62};
63
Sebastian Janssond7fade52020-01-29 10:44:51 +010064inline constexpr Frequency operator/(int64_t nominator,
65 const TimeDelta& interval) {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020066 constexpr int64_t kKiloPerMicro = 1000 * 1000000;
67 RTC_DCHECK_LE(nominator, std::numeric_limits<int64_t>::max() / kKiloPerMicro);
68 RTC_CHECK(interval.IsFinite());
69 RTC_CHECK(!interval.IsZero());
70 return Frequency::millihertz(nominator * kKiloPerMicro / interval.us());
71}
72
Sebastian Janssond7fade52020-01-29 10:44:51 +010073inline constexpr TimeDelta operator/(int64_t nominator,
74 const Frequency& frequency) {
Sebastian Jansson26b5e352019-06-07 11:05:31 +020075 constexpr int64_t kMegaPerMilli = 1000000 * 1000;
76 RTC_DCHECK_LE(nominator, std::numeric_limits<int64_t>::max() / kMegaPerMilli);
77 RTC_CHECK(frequency.IsFinite());
78 RTC_CHECK(!frequency.IsZero());
79 return TimeDelta::us(nominator * kMegaPerMilli / frequency.millihertz());
80}
81
Sebastian Jansson1cf15bf2020-01-29 10:56:25 +010082inline constexpr double operator*(Frequency frequency, TimeDelta time_delta) {
83 return frequency.hertz<double>() * time_delta.seconds<double>();
84}
85inline constexpr double operator*(TimeDelta time_delta, Frequency frequency) {
86 return frequency * time_delta;
87}
88
Sebastian Jansson26b5e352019-06-07 11:05:31 +020089std::string ToString(Frequency value);
90inline std::string ToLogString(Frequency value) {
91 return ToString(value);
92}
93
94#ifdef UNIT_TEST
95inline std::ostream& operator<<( // no-presubmit-check TODO(webrtc:8982)
96 std::ostream& stream, // no-presubmit-check TODO(webrtc:8982)
97 Frequency value) {
98 return stream << ToString(value);
99}
100#endif // UNIT_TEST
101
102} // namespace webrtc
103#endif // API_UNITS_FREQUENCY_H_