File: vec_traits_gnuc_test.cpp

package info (click to toggle)
boost1.90 1.90.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 593,120 kB
  • sloc: cpp: 4,190,908; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,774; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (116 lines) | stat: -rw-r--r-- 3,323 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// Copyright 2008-2024 Emil Dotchevski and Reverge Studios, Inc.
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

#if !defined(__GNUC__) || !defined(__SSE__)

#include <iostream>

int main()
{
    std::cout << "Test not applicable due to lack of C++11 support in the compiler" << std::endl;
    return 0;
}

#else

#ifdef BOOST_QVM_TEST_SINGLE_HEADER
#   include BOOST_QVM_TEST_SINGLE_HEADER
#else
#   include <boost/qvm/vec_access.hpp>
#   include <boost/qvm/vec_operations.hpp>
#   include <boost/qvm/vec.hpp>
#   include <boost/qvm/swizzle4.hpp>
#endif

#include <boost/qvm/vec_traits_gnuc.hpp>
#include <boost/core/lightweight_test.hpp>
#include <xmmintrin.h>

template <class T,class U>
struct same_type;

template <class T>
struct
same_type<T,T>
    {
    };

int
main()
    {
    using namespace boost::qvm;
    typedef float v2sf __attribute__ ((vector_size(8)));
    typedef float v4sf __attribute__ ((vector_size(16)));
    typedef double v2sd __attribute__ ((vector_size(16)));
    typedef double v4sd __attribute__ ((vector_size(32)));
    BOOST_QVM_STATIC_ASSERT(is_vec<v2sf>::value);
    BOOST_QVM_STATIC_ASSERT(is_vec<v4sf>::value);
    BOOST_QVM_STATIC_ASSERT(is_vec<__v4sf>::value);
    BOOST_QVM_STATIC_ASSERT(is_vec<v2sd>::value);
    BOOST_QVM_STATIC_ASSERT(is_vec<v4sd>::value);
    BOOST_QVM_STATIC_ASSERT(vec_traits<v2sf>::dim==2);
    BOOST_QVM_STATIC_ASSERT(vec_traits<v4sf>::dim==4);
    BOOST_QVM_STATIC_ASSERT(vec_traits<__v4sf>::dim==4);
    BOOST_QVM_STATIC_ASSERT(vec_traits<v2sd>::dim==2);
    BOOST_QVM_STATIC_ASSERT(vec_traits<v4sd>::dim==4);
    {
        __v4sf v = { 1, 2, 3, 4 };
        BOOST_TEST_EQ(X(v), 1);
        BOOST_TEST_EQ(Y(v), 2);
        BOOST_TEST_EQ(Z(v), 3);
        BOOST_TEST_EQ(W(v), 4);
        X(v) = 5;
        BOOST_TEST_EQ(X(v), 5);
        BOOST_TEST_EQ(Y(v), 2);
        BOOST_TEST_EQ(Z(v), 3);
        BOOST_TEST_EQ(W(v), 4);
        Y(v) = 6;
        BOOST_TEST_EQ(X(v), 5);
        BOOST_TEST_EQ(Y(v), 6);
        BOOST_TEST_EQ(Z(v), 3);
        BOOST_TEST_EQ(W(v), 4);
        Z(v) = 7;
        BOOST_TEST_EQ(X(v), 5);
        BOOST_TEST_EQ(Y(v), 6);
        BOOST_TEST_EQ(Z(v), 7);
        BOOST_TEST_EQ(W(v), 4);
        W(v) = 8;
        BOOST_TEST_EQ(X(v), 5);
        BOOST_TEST_EQ(Y(v), 6);
        BOOST_TEST_EQ(Z(v), 7);
        BOOST_TEST_EQ(W(v), 8);
    }
    {
        vec<float,4> v1 = {{1, 2, 3, 4}};
        __v4sf v2 = {5, 6, 7, 8};
        __v4sf r1 = v1 + v2;
        BOOST_TEST_EQ(X(r1), 6);
        BOOST_TEST_EQ(Y(r1), 8);
        BOOST_TEST_EQ(Z(r1), 10);
        BOOST_TEST_EQ(W(r1), 12);
        v4sd r2 = v1 - v2;
        BOOST_TEST_EQ(X(r2), -4);
        BOOST_TEST_EQ(Y(r2), -4);
        BOOST_TEST_EQ(Z(r2), -4);
        BOOST_TEST_EQ(W(r2), -4);
    }
#ifndef BOOST_QVM_TEST_SINGLE_HEADER
    {
        vec<float,4> v1 = {{1, 2, 3, 4}};
        __v4sf v2 = {0, 0, 0, 0};
        BOOST_TEST_EQ(X(v2), 0);
        BOOST_TEST_EQ(Y(v2), 0);
        BOOST_TEST_EQ(Z(v2), 0);
        BOOST_TEST_EQ(W(v2), 0);
        WZYX(v2) = v1;
        BOOST_TEST_EQ(X(v2), 4);
        BOOST_TEST_EQ(Y(v2), 3);
        BOOST_TEST_EQ(Z(v2), 2);
        BOOST_TEST_EQ(W(v2), 1);
    }
#endif
    return boost::report_errors();
    }

#endif