<ratio>

Включите стандартное соотношение> заголовков <для определения констант и шаблонов, которые используются для хранения и управления рациональными числами во время компиляции.

Синтаксис

#include <ratio>

Шаблон коэффициента

template<std::intmax_t Numerator, std::intmax_t Denominator = 1>
struct ratio // holds the ratio of Numerator to Denominator
{
   static constexpr std::intmax_t num;
   static constexpr std::intmax_t den;
   typedef ratio<num, den> type;
}

Шаблон ratio определяет статические константы num и den таким образом, что numden / == Numerator / Знаменатель и dennum не имеют общих факторов. num / den — это значение, представленное шаблоном класса. type Поэтому указывает экземплярratio<num, den>.

Специализации

<коэффициент> также определяет специализации ratio , имеющие следующую форму.

template <class R1, class R2> struct ratio_specialization

Каждая специализация принимает два параметра-шаблона, которые также должны быть специализациями ratio. Значение type определяется связанной логической операцией.

Имя type Значение
ratio_add R1 + R2
ratio_divide R1 / R2
ratio_equal R1 == R2
ratio_greater R1 > R2
ratio_greater_equal R1 >= R2
ratio_less R1 < R2
ratio_less_equal R1 <= R2
ratio_multiply R1 * R2
ratio_not_equal !(R1 == R2)
ratio_subtract R1 - R2

определения типов

Для удобства заголовок определяет коэффициенты для стандартных префиксов SI:

typedef ratio<1, 1000000000000000000> atto;
typedef ratio<1, 1000000000000000> femto;
typedef ratio<1, 1000000000000> pico;
typedef ratio<1, 1000000000> nano;
typedef ratio<1, 1000000> micro;
typedef ratio<1, 1000> milli;
typedef ratio<1, 100> centi;
typedef ratio<1, 10> deci;
typedef ratio<10, 1> deca;
typedef ratio<100, 1> hecto;
typedef ratio<1000, 1> kilo;
typedef ratio<1000000, 1> mega;
typedef ratio<1000000000, 1> giga;
typedef ratio<1000000000000, 1> tera;
typedef ratio<1000000000000000, 1> peta;
typedef ratio<1000000000000000000, 1> exa;

См. также

Справочник по файлам заголовков