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(const valarray<value_type>& v);
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
17e898b484SStephan T. Lavavej #include <cstddef>
185a83710eSEric Fiselier 
19*2df59c50SJF Bastien int main(int, char**)
205a83710eSEric Fiselier {
215a83710eSEric Fiselier     {
225a83710eSEric Fiselier         typedef int T;
235a83710eSEric Fiselier         T a[] = {1, 2, 3, 4, 5};
245a83710eSEric Fiselier         const unsigned N = sizeof(a)/sizeof(a[0]);
255a83710eSEric Fiselier         std::valarray<T> v(a, N);
265a83710eSEric Fiselier         std::valarray<T> v2 = v;
275a83710eSEric Fiselier         assert(v2.size() == v.size());
28e898b484SStephan T. Lavavej         for (std::size_t i = 0; i < v2.size(); ++i)
295a83710eSEric Fiselier             assert(v2[i] == v[i]);
305a83710eSEric Fiselier     }
315a83710eSEric Fiselier     {
325a83710eSEric Fiselier         typedef double T;
335a83710eSEric Fiselier         T a[] = {1, 2.5, 3, 4.25, 5};
345a83710eSEric Fiselier         const unsigned N = sizeof(a)/sizeof(a[0]);
355a83710eSEric Fiselier         std::valarray<T> v(a, N);
365a83710eSEric Fiselier         std::valarray<T> v2 = v;
375a83710eSEric Fiselier         assert(v2.size() == v.size());
38e898b484SStephan T. Lavavej         for (std::size_t i = 0; i < v2.size(); ++i)
395a83710eSEric Fiselier             assert(v2[i] == v[i]);
405a83710eSEric Fiselier     }
415a83710eSEric Fiselier     {
425a83710eSEric Fiselier         typedef std::valarray<double> T;
435a83710eSEric Fiselier         T a[] = {T(1), T(2), T(3), T(4), T(5)};
445a83710eSEric Fiselier         const unsigned N = sizeof(a)/sizeof(a[0]);
455a83710eSEric Fiselier         std::valarray<T> v(a, N);
465a83710eSEric Fiselier         std::valarray<T> v2 = v;
475a83710eSEric Fiselier         assert(v2.size() == v.size());
48c71bd55bSEric Fiselier         for (unsigned i = 0; i < N; ++i)
495a83710eSEric Fiselier         {
505a83710eSEric Fiselier             assert(v2[i].size() == v[i].size());
51e898b484SStephan T. Lavavej             for (std::size_t j = 0; j < v[i].size(); ++j)
525a83710eSEric Fiselier                 assert(v2[i][j] == v[i][j]);
535a83710eSEric Fiselier         }
545a83710eSEric Fiselier     }
55*2df59c50SJF Bastien 
56*2df59c50SJF Bastien   return 0;
575a83710eSEric Fiselier }
58