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 shift(int i) const;
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
18*2df59c50SJF Bastien int main(int, char**)
195a83710eSEric Fiselier {
205a83710eSEric Fiselier     {
215a83710eSEric Fiselier         typedef int T;
225a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
235a83710eSEric Fiselier         T a2[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
245a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
255a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
265a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(0);
275a83710eSEric Fiselier         assert(v2.size() == N1);
285a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
295a83710eSEric Fiselier             assert(v2[i] == a2[i]);
305a83710eSEric Fiselier     }
315a83710eSEric Fiselier     {
325a83710eSEric Fiselier         typedef int T;
335a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
345a83710eSEric Fiselier         T a2[] = {2, 3, 4, 5, 6, 7, 8, 9, 10, 0};
355a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
365a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
375a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(1);
385a83710eSEric Fiselier         assert(v2.size() == N1);
395a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
405a83710eSEric Fiselier             assert(v2[i] == a2[i]);
415a83710eSEric Fiselier     }
425a83710eSEric Fiselier     {
435a83710eSEric Fiselier         typedef int T;
445a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
455a83710eSEric Fiselier         T a2[] = {10, 0, 0, 0, 0, 0, 0, 0, 0, 0};
465a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
475a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
485a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(9);
495a83710eSEric Fiselier         assert(v2.size() == N1);
505a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
515a83710eSEric Fiselier             assert(v2[i] == a2[i]);
525a83710eSEric Fiselier     }
535a83710eSEric Fiselier     {
545a83710eSEric Fiselier         typedef int T;
555a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
565a83710eSEric Fiselier         T a2[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
575a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
585a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
595a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(90);
605a83710eSEric Fiselier         assert(v2.size() == N1);
615a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
625a83710eSEric Fiselier             assert(v2[i] == a2[i]);
635a83710eSEric Fiselier     }
645a83710eSEric Fiselier     {
655a83710eSEric Fiselier         typedef int T;
665a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
675a83710eSEric Fiselier         T a2[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
685a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
695a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
705a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(-1);
715a83710eSEric Fiselier         assert(v2.size() == N1);
725a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
735a83710eSEric Fiselier             assert(v2[i] == a2[i]);
745a83710eSEric Fiselier     }
755a83710eSEric Fiselier     {
765a83710eSEric Fiselier         typedef int T;
775a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
785a83710eSEric Fiselier         T a2[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 1};
795a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
805a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
815a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(-9);
825a83710eSEric Fiselier         assert(v2.size() == N1);
835a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
845a83710eSEric Fiselier             assert(v2[i] == a2[i]);
855a83710eSEric Fiselier     }
865a83710eSEric Fiselier     {
875a83710eSEric Fiselier         typedef int T;
885a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
895a83710eSEric Fiselier         T a2[] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
905a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
915a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
925a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(-90);
935a83710eSEric Fiselier         assert(v2.size() == N1);
945a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
955a83710eSEric Fiselier             assert(v2[i] == a2[i]);
965a83710eSEric Fiselier     }
975a83710eSEric Fiselier     {
985a83710eSEric Fiselier         typedef int T;
995a83710eSEric Fiselier         const unsigned N1 = 0;
1005a83710eSEric Fiselier         std::valarray<T> v1;
1015a83710eSEric Fiselier         std::valarray<T> v2 = v1.shift(-90);
1025a83710eSEric Fiselier         assert(v2.size() == N1);
1035a83710eSEric Fiselier     }
1045a83710eSEric Fiselier     {
1055a83710eSEric Fiselier         typedef int T;
1065a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
1075a83710eSEric Fiselier         T a2[] = {8, 10, 12, 14, 16, 18, 20, 0, 0, 0};
1085a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
1095a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
1105a83710eSEric Fiselier         std::valarray<T> v2 = (v1 + v1).shift(3);
1115a83710eSEric Fiselier         assert(v2.size() == N1);
1125a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
1135a83710eSEric Fiselier             assert(v2[i] == a2[i]);
1145a83710eSEric Fiselier     }
1155a83710eSEric Fiselier     {
1165a83710eSEric Fiselier         typedef int T;
1175a83710eSEric Fiselier         T a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
1185a83710eSEric Fiselier         T a2[] = {0, 0, 0, 2, 4, 6, 8, 10, 12, 14};
1195a83710eSEric Fiselier         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
1205a83710eSEric Fiselier         std::valarray<T> v1(a1, N1);
1215a83710eSEric Fiselier         std::valarray<T> v2 = (v1 + v1).shift(-3);
1225a83710eSEric Fiselier         assert(v2.size() == N1);
1235a83710eSEric Fiselier         for (unsigned i = 0; i < N1; ++i)
1245a83710eSEric Fiselier             assert(v2[i] == a2[i]);
1255a83710eSEric Fiselier     }
126*2df59c50SJF Bastien 
127*2df59c50SJF Bastien   return 0;
1285a83710eSEric Fiselier }
129