Compartilhar via


linear_congruential Class

Gera uma seqüência aleatório pelo algoritmo congruential linear.Retido para compatibilidade TR1.Use linear_congruential_engine Class em vez de isso.

template<class UIntType,
   UIntType A, UIntType C, UIntType M>
   class linear_congruential {
public:
   typedef linear_congruential<UIntType, A, C, M> _MyT;
   typedef UIntType result_type;
   static const UIntType multiplier = A;
   static const UIntType increment = C;
   static const UIntType modulus = M;
   static const UIntType default_seed = 1U;
   explicit linear_congruential(UIntType x0 = default_seed)
   linear_congruential(const linear_congruential& right);
   linear_congruential(linear_congruential& right);
   template<class Gen>
      linear_congruential(Gen& gen);
   void seed(UIntType x0 = default_seed);
   template<class Gen>
      void seed(Gen& gen);
   result_type min() const;
   result_type max() const;
   result_type operator()();
private:
   result_type stored_value;    // exposition only
   };

Parâmetros

  • UIntType
    O tipo do resultado inteiro sem sinal de.

  • A
    O parâmetro do mecanismo de.

  • C
    O parâmetro do mecanismo de C.

  • M
    O parâmetro do mecanismo de M.

Comentários

Esta classe de modelo descreve um mecanismo que produz valores de um tipo integral sem sinal especificado pelo usuário usando a relação de recorrência x(i) = (A * x(i-1) + C) mod M.O estado do mecanismo é o último valor retornado, ou o valor semente se nenhum chamada foi feita para operator().

O argumento UIntType de modelo deve ser grande o suficiente para armazenar valores até M - 1.Os valores dos argumentos A e C de modelo devem ser menor que M.

Requisitos

Cabeçalho: <random>

namespace: STD

Consulte também

Referência

<random>

linear_congruential::linear_congruential

linear_congruential::operator()

linear_congruential::seed