15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier
95a83710eSEric Fiselier // <valarray>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // template<class T> class valarray;
125a83710eSEric Fiselier
135a83710eSEric Fiselier // valarray operator[](const valarray<size_t>& vs) const;
145a83710eSEric Fiselier
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier
18*7fc6a556SMarshall Clow #include "test_macros.h"
19*7fc6a556SMarshall Clow
main(int,char **)202df59c50SJF Bastien int main(int, char**)
215a83710eSEric Fiselier {
2206571975SEric Fiselier {
235a83710eSEric Fiselier int a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11,
245a83710eSEric Fiselier 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
255a83710eSEric Fiselier 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35,
265a83710eSEric Fiselier 36, 37, 38, 39, 40};
275a83710eSEric Fiselier const std::size_t N1 = sizeof(a)/sizeof(a[0]);
285a83710eSEric Fiselier std::size_t s[] = { 3, 4, 5, 7, 8, 9, 11, 12, 13, 15, 16, 17,
295a83710eSEric Fiselier 22, 23, 24, 26, 27, 28, 30, 31, 32, 34, 35, 36};
305a83710eSEric Fiselier const std::size_t S = sizeof(s)/sizeof(s[0]);
315a83710eSEric Fiselier const std::valarray<int> v1(a, N1);
325a83710eSEric Fiselier std::valarray<std::size_t> ia(s, S);
335a83710eSEric Fiselier std::valarray<int> v = v1[ia];
345a83710eSEric Fiselier assert(v.size() == 24);
355a83710eSEric Fiselier assert(v[ 0] == 3);
365a83710eSEric Fiselier assert(v[ 1] == 4);
375a83710eSEric Fiselier assert(v[ 2] == 5);
385a83710eSEric Fiselier assert(v[ 3] == 7);
395a83710eSEric Fiselier assert(v[ 4] == 8);
405a83710eSEric Fiselier assert(v[ 5] == 9);
415a83710eSEric Fiselier assert(v[ 6] == 11);
425a83710eSEric Fiselier assert(v[ 7] == 12);
435a83710eSEric Fiselier assert(v[ 8] == 13);
445a83710eSEric Fiselier assert(v[ 9] == 15);
455a83710eSEric Fiselier assert(v[10] == 16);
465a83710eSEric Fiselier assert(v[11] == 17);
475a83710eSEric Fiselier assert(v[12] == 22);
485a83710eSEric Fiselier assert(v[13] == 23);
495a83710eSEric Fiselier assert(v[14] == 24);
505a83710eSEric Fiselier assert(v[15] == 26);
515a83710eSEric Fiselier assert(v[16] == 27);
525a83710eSEric Fiselier assert(v[17] == 28);
535a83710eSEric Fiselier assert(v[18] == 30);
545a83710eSEric Fiselier assert(v[19] == 31);
555a83710eSEric Fiselier assert(v[20] == 32);
565a83710eSEric Fiselier assert(v[21] == 34);
575a83710eSEric Fiselier assert(v[22] == 35);
585a83710eSEric Fiselier assert(v[23] == 36);
5906571975SEric Fiselier }
6006571975SEric Fiselier {
6106571975SEric Fiselier int raw_data[] = {0,1,2,3,4,5,6,7,8,9};
6206571975SEric Fiselier std::size_t idx_data[] = {0,2,4,6,8};
6306571975SEric Fiselier const std::valarray<int> data(raw_data, sizeof(raw_data)/sizeof(raw_data[0]));
6406571975SEric Fiselier std::valarray<std::size_t> idx(idx_data, sizeof(idx_data)/sizeof(idx_data[0]));
6506571975SEric Fiselier std::valarray<int> result = (data + 0)[idx];
6606571975SEric Fiselier assert(result.size() == 5);
6706571975SEric Fiselier assert(result[0] == data[idx[0]]);
6806571975SEric Fiselier assert(result[1] == data[idx[1]]);
6906571975SEric Fiselier assert(result[2] == data[idx[2]]);
7006571975SEric Fiselier assert(result[3] == data[idx[3]]);
7106571975SEric Fiselier assert(result[4] == data[idx[4]]);
7206571975SEric Fiselier }
732df59c50SJF Bastien return 0;
745a83710eSEric Fiselier }
75