std:: student_t_distribution
|
Definido en el encabezado
<random>
|
||
|
template
<
class
RealType
=
double
>
class student_t_distribution ; |
(desde C++11) | |
Produce valores de punto flotante aleatorios x , distribuidos de acuerdo con la función de densidad de probabilidad:
-
p(x|n) =
·1 √ nπ
· ⎛Γ(
)n+1 2 Γ(
)n 2
⎜
⎝ 1+
⎞x 2
n
⎟
⎠ -n+1 2
donde n se conoce como el número de grados de libertad . Esta distribución se utiliza al estimar la media de un valor normalmente distribuido desconocido dados n + 1 mediciones independientes, cada una con errores aditivos de desviación estándar desconocida, como en mediciones físicas. O, alternativamente, al estimar la media desconocida de una distribución normal con desviación estándar desconocida, dados n + 1 muestras.
std::student_t_distribution
satisface todos los requisitos de
RandomNumberDistribution
.
Contenidos |
Parámetros de plantilla
| RealType | - | El tipo de resultado generado por el generador. El efecto es indefinido si este no es uno de float , double , o long double . |
Tipos de miembros
| Tipo de miembro | Definición |
result_type
(C++11)
|
RealType |
param_type
(C++11)
|
el tipo del conjunto de parámetros, ver RandomNumberDistribution . |
Funciones miembro
|
(C++11)
|
construye una nueva distribución
(función miembro pública) |
|
(C++11)
|
restablece el estado interno de la distribución
(función miembro pública) |
Generación |
|
|
(C++11)
|
genera el siguiente número aleatorio en la distribución
(función miembro pública) |
Características |
|
|
devuelve el parámetro de distribución
n
(grados de libertad)
(función miembro pública) |
|
|
(C++11)
|
obtiene o establece el objeto de parámetros de distribución
(función miembro pública) |
|
(C++11)
|
devuelve el valor mínimo potencialmente generado
(función miembro pública) |
|
(C++11)
|
devuelve el valor máximo potencialmente generado
(función miembro pública) |
Funciones no miembro
|
(C++11)
(C++11)
(removed in C++20)
|
compara dos objetos de distribución
(función) |
|
(C++11)
|
realiza entrada y salida de flujo en la distribución de números pseudoaleatorios
(plantilla de función) |
Ejemplo
#include <algorithm> #include <cmath> #include <iomanip> #include <iostream> #include <map> #include <random> #include <vector> template<int Height = 5, int BarWidth = 1, int Padding = 1, int Offset = 0, class Seq> void draw_vbars(Seq&& s, const bool DrawMinMax = true) { static_assert(0 < Height and 0 < BarWidth and 0 <= Padding and 0 <= Offset); auto cout_n = [](auto&& v, int n = 1) { while (n-- > 0) std::cout << v; }; const auto [min, max] = std::minmax_element(std::cbegin(s), std::cend(s)); std::vector<std::div_t> qr; for (typedef decltype(*std::cbegin(s)) V; V e : s) qr.push_back(std::div(std::lerp(V(0), 8 * Height, (e - *min) / (*max - *min)), 8)); for (auto h{Height}; h-- > 0; cout_n('\n')) { cout_n(' ', Offset); for (auto dv : qr) { const auto q{dv.quot}, r{dv.rem}; unsigned char d[]{0xe2, 0x96, 0x88, 0}; // Full Block: '█' q < h ? d[0] = ' ', d[1] = 0 : q == h ? d[2] -= (7 - r) : 0; cout_n(d, BarWidth), cout_n(' ', Padding); } if (DrawMinMax && Height > 1) Height - 1 == h ? std::cout << "┬ " << *max: h ? std::cout << "│ " : std::cout << "┴ " << *min; } } int main() { std::random_device rd{}; std::mt19937 gen{rd()}; std::student_t_distribution<> d{10.0f}; const int norm = 10'000; const float cutoff = 0.000'3f; std::map<int, int> hist{}; for (int n = 0; n != norm; ++n) ++hist[std::round(d(gen))]; std::vector<float> bars; std::vector<int> indices; for (const auto& [n, p] : hist) if (float x = p * (1.0f / norm); cutoff < x) { bars.push_back(x); indices.push_back(n); } for (draw_vbars<8, 5>(bars); const int n : indices) std::cout << " " << std::setw(2) << n << " "; std::cout << '\n'; }
Salida posible:
█████ ┬ 0.3753
█████ │
▁▁▁▁▁ █████ │
█████ █████ ▆▆▆▆▆ │
█████ █████ █████ │
█████ █████ █████ │
▄▄▄▄▄ █████ █████ █████ ▄▄▄▄▄ │
▁▁▁▁▁ ▃▃▃▃▃ █████ █████ █████ █████ █████ ▃▃▃▃▃ ▁▁▁▁▁ ▁▁▁▁▁ ┴ 0.0049
-4 -3 -2 -1 0 1 2 3 4 5
Enlaces externos
| Weisstein, Eric W. "Distribución t de Student." De MathWorld — Un recurso web de Wolfram. |