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 IntType = int> 1311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert// class discrete_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::discrete_distribution<> D; 2511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef D::param_type param_type; 2611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert double p0[] = {30, 10}; 2711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p1(p0, p0+2); 2811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p2(p0, p0+2); 2911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert assert(p1 == p2); 3011cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 3111cd02dfb91661c65134cac258cf5924270e9d2Dan Albert { 3211cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef std::discrete_distribution<> D; 3311cd02dfb91661c65134cac258cf5924270e9d2Dan Albert typedef D::param_type param_type; 3411cd02dfb91661c65134cac258cf5924270e9d2Dan Albert double p0[] = {30, 10}; 3511cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p1(p0, p0+2); 3611cd02dfb91661c65134cac258cf5924270e9d2Dan Albert param_type p2; 3711cd02dfb91661c65134cac258cf5924270e9d2Dan Albert assert(p1 != p2); 3811cd02dfb91661c65134cac258cf5924270e9d2Dan Albert } 3911cd02dfb91661c65134cac258cf5924270e9d2Dan Albert} 40