1 //===----------------------------------------------------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
11 // template <class T> class mask_array
13 // void operator<<=(const valarray<value_type>& v) const;
18 #include "test_macros.h"
22 int a1
[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
23 const std::size_t N1
= sizeof(a1
)/sizeof(a1
[0]);
24 int a2
[] = {1, 2, 3, 4, 5};
25 const std::size_t N2
= sizeof(a2
)/sizeof(a2
[0]);
26 bool b
[N1
] = {true, false, false, true, true, false,
27 false, true, false, false, false, true};
28 std::valarray
<int> v1(a1
, N1
);
29 std::valarray
<int> v2(a2
, N2
);
30 assert(N2
== std::count(b
, b
+N1
, true));
31 std::valarray
<bool> vb(b
, N1
);
33 assert(v1
.size() == 16);
41 assert(v1
[ 7] == 112);
45 assert(v1
[11] == 352);