- Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::subtract_with_carry_engine(3) | C++ Standard Libary | std::subtract_with_carry_engine(3) | 
NAME¶
std::subtract_with_carry_engine - std::subtract_with_carry_engine
Synopsis¶
 Defined in header <random>
  
   template<
  
   class UIntType, (since C++11)
  
   std::size_t w, std::size_t s, std::size_t r
  
   > class subtract_with_carry_engine;
  
   Is a random number engine that uses subtract with carry algorithm.
Template parameters¶
 The result type generated by the generator. The effect is
    undefined if
  
   UIntType - this is not one of unsigned short, unsigned int, unsigned long, or
  
   unsigned long long.
  
   w - the word size, in bits, of the state sequence
  
   s - the short lag
  
   r - the long lag
  
   If w is not in [1, std::numeric_limits<UIntType>::digits], or s is not
    in [1, r),
  
   the program is ill-formed.
  
   Generator properties
  
   The size of the states of subtract_with_carry_engine is \(O(r)\)O(r), each of
    them
  
   consists of two parts:
  
   * A sequence X of r integer values, where each value is in [0, 2w
  
   ).
  
   * An integer c (known as the carry ), whose value is either 0 or
  1.
  
   Given that \(X_j\)X
  
   j stands for the \(j\mod r\)j mod rth value (starting from 0) of X, the
    transition
  
   algorithm of subtract_with_carry_engine (\(TA(x_i)\)TA(x
  
   i)) is defined as follows:
  
   1. Let Y be \(X_{i-s}-X_{i-r}-c\)X
  
   i-s-X
  
   i-r-c.
  
   2. Let y be \(Y\mod 2^w\)Y mod 2w
  
   , and set \(X_i\)X
  
   i to y.
  
   3. If Y is negative, set c to 1, otherwise set c to 0.
  
   The generation algorithm of subtract_with_carry_engine is \(GA(x_i) = y\)GA(x
  
   i) = y, where y is the value produced in step 2 of the transition
  algorithm.
  
   Predefined specializations
  
   The following specializations define the random number engine with two
    commonly used
  
   parameter sets:
  
   Defined in header <random>
  
   Type Definition
  
   ranlux24_base std::subtract_with_carry_engine<std::uint_fast32_t, 24, 10,
  
   (C++11) 24>
  
   ranlux48_base std::subtract_with_carry_engine<std::uint_fast64_t, 48, 5,
  
   (C++11) 12>
  
   Nested types
  
   Type Definition
  
   result_type UIntType
  
   Data members
  
   constexpr std::size_t word_size w
  
   [static] (public static member constant)
  
   constexpr std::size_t short_lag s
  
   [static] (public static member constant)
  
   constexpr std::size_t long_lag r
  
   [static] (public static member constant)
  
   constexpr std::uint_least32_t default_seed 19780503u
  
   [static] (public static member constant)
Member functions¶
Construction and Seeding¶
 constructor constructs the engine
  
   (C++11) (public member function)
  
   seed sets the current state of the engine
  
   (C++11) (public member function)
Generation¶
 operator() advances the engine's state and returns the generated
    value
  
   (C++11) (public member function)
  
   discard advances the engine's state by a specified amount
  
   (C++11) (public member function)
Characteristics¶
 min gets the smallest possible value in the output range
  
   [static] (C++11) (public static member function)
  
   max gets the largest possible value in the output range
  
   [static] (C++11) (public static member function)
Non-member functions¶
 operator== compares the internal states of two pseudo-random
    number
  
   operator!= engines
  
   (C++11) (function)
  
   (C++11)(removed in C++20)
  
   operator<< performs stream input and output on pseudo-random number
  
   operator>> engine
  
   (C++11) (function template)
Example¶
 This section is incomplete
  
   Reason: no example
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 3809 C++11 default_seed might not be changed its type to
  
   representable with result_type std::uint_least32_t
Category:¶
* Todo no example
| 2024.06.10 | http://cppreference.com |