Namespaces
Variants
Views
Actions

std::ratio_add

From cppreference.com
< cpp‎ | numeric‎ | ratio
Revision as of 19:24, 31 May 2013 by P12bot (Talk | contribs)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Defined in header <ratio>
template< class R1, class R2 >
using ratio_add = /* unspecified */;

The template alias std::ratio_add denotes the result of adding two exact rational fractions represented by the std::ratio instances R1 and R2. The result a std::ratio instance std::ratio<Num, Denom> where Num == R1::num * R2::den + R2::num * R1::den and Denom == R1::den * R2::den.

[edit] Member types

Member type Definition
type std::ratio<num, den>

[edit] Member constants

num
[static]
constexpr value of type std::intmax_t equal to sign(Num) * sign(Denom) * abs(Num) / gcd(Num, Denom)
(public static member constant)
den
[static]
constexpr value of type std::intmax_t equal to abs(Denom) / gcd(Num, Denom)
(public static member constant)

[edit] Example

#include <iostream>
#include <ratio>
 
int main()
{
    typedef std::ratio<2, 3> two_third;
    typedef std::ratio<1, 6> one_sixth;
 
    typedef std::ratio_add<two_third, one_sixth> sum;
    std::cout << "2/3 + 1/6 = " << sum::num << '/' << sum::den << '\n';
}

Output:

2/3 + 1/6 = 5/6