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;
145a83710eSEric Fiselier
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
17e898b484SStephan T. Lavavej #include <cstddef>
185a83710eSEric Fiselier
197fc6a556SMarshall Clow #include "test_macros.h"
207fc6a556SMarshall Clow
main(int,char **)212df59c50SJF Bastien int main(int, char**)
225a83710eSEric Fiselier {
235a83710eSEric Fiselier {
245a83710eSEric Fiselier typedef int T;
255a83710eSEric Fiselier T a[] = {1, 2, 3, 4, 5};
265a83710eSEric Fiselier const unsigned N = sizeof(a)/sizeof(a[0]);
275a83710eSEric Fiselier std::valarray<T> v(a, N);
285a83710eSEric Fiselier std::valarray<T> v2 = +v;
295a83710eSEric Fiselier assert(v2.size() == v.size());
30e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
315a83710eSEric Fiselier assert(v2[i] == +v[i]);
325a83710eSEric Fiselier }
335a83710eSEric Fiselier {
345a83710eSEric Fiselier typedef double T;
355a83710eSEric Fiselier T a[] = {1, 2.5, 3, 4.25, 5};
365a83710eSEric Fiselier const unsigned N = sizeof(a)/sizeof(a[0]);
375a83710eSEric Fiselier std::valarray<T> v(a, N);
385a83710eSEric Fiselier std::valarray<T> v2 = +v;
395a83710eSEric Fiselier assert(v2.size() == v.size());
40e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
415a83710eSEric Fiselier assert(v2[i] == +v[i]);
425a83710eSEric Fiselier }
435a83710eSEric Fiselier {
445a83710eSEric Fiselier typedef std::valarray<double> T;
455a83710eSEric Fiselier T a[] = {T(1), T(2), T(3), T(4), T(5)};
465a83710eSEric Fiselier const unsigned N = sizeof(a)/sizeof(a[0]);
475a83710eSEric Fiselier std::valarray<T> v(a, N);
485a83710eSEric Fiselier std::valarray<T> v2 = +v;
495a83710eSEric Fiselier assert(v2.size() == v.size());
50c71bd55bSEric Fiselier for (unsigned i = 0; i < N; ++i)
515a83710eSEric Fiselier {
525a83710eSEric Fiselier assert(v2[i].size() == v[i].size());
53e898b484SStephan T. Lavavej for (std::size_t j = 0; j < v[i].size(); ++j)
545a83710eSEric Fiselier assert(v2[i][j] == +v[i][j]);
555a83710eSEric Fiselier }
565a83710eSEric Fiselier }
575a83710eSEric Fiselier {
585a83710eSEric Fiselier typedef double T;
595a83710eSEric Fiselier T a[] = {1, 2.5, 3, 4.25, 5};
605a83710eSEric Fiselier const unsigned N = sizeof(a)/sizeof(a[0]);
615a83710eSEric Fiselier std::valarray<T> v(a, N);
625a83710eSEric Fiselier std::valarray<T> v2 = +(v + v);
635a83710eSEric Fiselier assert(v2.size() == v.size());
64e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
655a83710eSEric Fiselier assert(v2[i] == +2*v[i]);
665a83710eSEric Fiselier }
67*b8f6f9e7SLouis Dionne {
68*b8f6f9e7SLouis Dionne // Make sure we don't have dangling reference problems with unary expressions
69*b8f6f9e7SLouis Dionne int array[] = {1, 2, 3};
70*b8f6f9e7SLouis Dionne std::valarray<int> a(array, 3);
71*b8f6f9e7SLouis Dionne std::valarray<int> b(array, 3);
72*b8f6f9e7SLouis Dionne auto c = +a * b;
73*b8f6f9e7SLouis Dionne assert(c.size() == 3);
74*b8f6f9e7SLouis Dionne assert(c[0] == 1 && c[1] == 4 && c[2] == 9);
75*b8f6f9e7SLouis Dionne }
762df59c50SJF Bastien
772df59c50SJF Bastien return 0;
785a83710eSEric Fiselier }
79