111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert//===----------------------------------------------------------------------===// 211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// The LLVM Compiler Infrastructure 411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// This file is dual licensed under the MIT and the University of Illinois Open 611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// Source Licenses. See LICENSE.TXT for details. 711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// 811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert//===----------------------------------------------------------------------===// 911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// <random> 1111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// template<class RealType = double> 1311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// class student_t_distribution 1411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// { 1511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// class param_type; 1611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 1711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include <random> 1811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include <limits> 1911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert#include <cassert> 2011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert 2111cd02dfb91661c65134cac258cf5924270e9d2Dan Albertint main() 2211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert{ 2311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 2411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::student_t_distribution<> D; 2511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef D::param_type param_type; 2611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p1(0.75); 2711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p2(0.75); 2811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert assert(p1 == p2); 2911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 3011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 3111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::student_t_distribution<> D; 3211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef D::param_type param_type; 3311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p1(0.75); 3411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p2(0.5); 3511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert assert(p1 != p2); 3611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 3711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} 38