KiCad PCB EDA Suite
Loading...
Searching...
No Matches
test_vector2.cpp
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2020 KiCad Developers, see AUTHORS.TXT for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19 * or you may search the http://www.gnu.org website for the version 2 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
29
30// Code under test
31#include <math/vector2d.h>
32
36BOOST_AUTO_TEST_SUITE( VECTOR2TESTS )
37
38BOOST_AUTO_TEST_CASE( test_cross_product, *boost::unit_test::tolerance( 0.000001 ) )
39{
40 VECTOR2I v1(0, 1);
41 VECTOR2I v2(1, 0);
42
43 BOOST_CHECK( v2.Cross( v1 ) == 1 );
44}
45
46BOOST_AUTO_TEST_CASE( test_dot_product, *boost::unit_test::tolerance( 0.000001 ) )
47{
48 VECTOR2I v1( 0, 1 );
49 VECTOR2I v2( 1, 0 );
50
51 BOOST_CHECK( v2.Dot( v1 ) == 0 );
52}
53
54BOOST_AUTO_TEST_CASE( test_resize, *boost::unit_test::tolerance( 0.000001 ) )
55{
56 // just some arbitrary vectors
57 VECTOR2I v1( 4, 3 );
58 VECTOR2I v2( 5, -1 );
59 VECTOR2I v3( -2, 1 );
60 VECTOR2I v4( 1, 1 );
61 VECTOR2I v5( -70, -70 );
62
63 BOOST_CHECK( v1.Resize( 8 ) == VECTOR2I( 6, 5 ) );
64 BOOST_CHECK( v2.Resize( 10 ) == VECTOR2I( 10, -2 ) );
65 BOOST_CHECK( v3.Resize( 4 ) == VECTOR2I( -4, 2 ) );
66 BOOST_CHECK( v4.Resize( 1 ) == VECTOR2I( 1, 1 ) );
67 BOOST_CHECK( v5.Resize( 100 ) == VECTOR2I( -71, -71 ) );
68}
69
70BOOST_AUTO_TEST_CASE( test_casting )
71{
72 VECTOR2I vint( 4, 3 );
73 VECTOR2D vdouble( 4.0, 3.0 );
74 VECTOR2L vlong( 4, 3 );
75 VECTOR2<float> vfloat( 4.0f, 3.0f );
76 VECTOR2<unsigned> vunsigned( 4, 3 );
77
78 BOOST_CHECK_EQUAL( vint, VECTOR2I( vdouble ) );
79 BOOST_CHECK_EQUAL( vint, VECTOR2I( vlong ) );
80 BOOST_CHECK_EQUAL( vint, VECTOR2I( vfloat ) );
81 BOOST_CHECK_EQUAL( vint, VECTOR2I( vunsigned ) );
82
83 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( vint ) );
84 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( vlong ) );
85 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( vfloat ) );
86 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( vunsigned ) );
87
88 BOOST_CHECK_EQUAL( vlong, VECTOR2L( vint ) );
89 BOOST_CHECK_EQUAL( vlong, VECTOR2L( vdouble ) );
90 BOOST_CHECK_EQUAL( vlong, VECTOR2L( vfloat ) );
91 BOOST_CHECK_EQUAL( vlong, VECTOR2L( vunsigned ) );
92
93 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( vint ) );
94 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( vdouble ) );
95 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( vlong ) );
96 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( vunsigned ) );
97
98 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( vint ) );
99 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( vdouble ) );
100 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( vlong ) );
101 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( vfloat ) );
102
103 // Check that negative values are handled correctly
104 vint = vint - 1;
105 vdouble = vdouble - 1;
106 vlong = vlong - 1;
107 vfloat = vfloat - 1;
108 vunsigned = vunsigned - 1;
109
110 BOOST_CHECK_EQUAL( vint, VECTOR2I( 3, 2 ) );
111 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( 3.0, 2.0 ) );
112 BOOST_CHECK_EQUAL( vlong, VECTOR2L( 3, 2 ) );
113 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( 3.0f, 2.0f ) );
114 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( 3, 2 ) );
115
116 // Check that subtracting unsigned values works correctly
117 vint = vint - (unsigned)1;
118 vdouble = vdouble - (unsigned)1;
119 vlong = vlong - (unsigned)1;
120 vfloat = vfloat - (unsigned)1;
121 vunsigned = vunsigned - (unsigned)1;
122
123 BOOST_CHECK_EQUAL( vint, VECTOR2I( 2, 1 ) );
124 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( 2.0, 1.0 ) );
125 BOOST_CHECK_EQUAL( vlong, VECTOR2L( 2, 1 ) );
126 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( 2.0f, 1.0f ) );
127 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( 2, 1 ) );
128
129 vint = vint - 5.0;
130 vdouble = vdouble - 5.0;
131 vlong = vlong - 5.0;
132 vfloat = vfloat - 5.0;
133 vunsigned = vunsigned - 5.0;
134
135 BOOST_CHECK_EQUAL( vint, VECTOR2I( -3, -4 ) );
136 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( -3.0, -4.0 ) );
137 BOOST_CHECK_EQUAL( vlong, VECTOR2L( -3, -4 ) );
138 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( -3.0f, -4.0f ) );
139 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( 4294967293, 4294967292 ) ); // roll over unsigned when explicitly subtracting.
140
141 // Check that negative initial values are handled correctly
142 vint = VECTOR2I( -4, -3 );
143 vdouble = VECTOR2D( -4.0, -3.0 );
144 vlong = VECTOR2L( -4, -3 );
145 vfloat = VECTOR2<float>( -4.0f, -3.0f );
146 vunsigned = VECTOR2<unsigned>( -4, -3 );
147
148 vint = vint - 1;
149 vdouble = vdouble - 1;
150 vlong = vlong - 1;
151 vfloat = vfloat - 1;
152 vunsigned = vunsigned - 1;
153
154 BOOST_CHECK_EQUAL( vint, VECTOR2I( -5, -4 ) );
155 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( -5.0, -4.0 ) );
156 BOOST_CHECK_EQUAL( vlong, VECTOR2L( -5, -4 ) );
157 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( -5.0f, -4.0f ) );
158 BOOST_CHECK_EQUAL( vunsigned, VECTOR2<unsigned>( 4294967291, 4294967292 ) );
159
160 vint = vint - 1u;
161 vdouble = vdouble - 1u;
162 vlong = vlong - 1u;
163 vfloat = vfloat - 1u;
164
165 BOOST_CHECK_EQUAL( vint, VECTOR2I( -6, -5 ) );
166 BOOST_CHECK_EQUAL( vdouble, VECTOR2D( -6.0, -5.0 ) );
167 BOOST_CHECK_EQUAL( vlong, VECTOR2L( -6, -5 ) );
168 BOOST_CHECK_EQUAL( vfloat, VECTOR2<float>( -6.0f, -5.0f ) );
169
170 auto add = vint + vdouble;
171 BOOST_CHECK_EQUAL( add, VECTOR2D( -12.0, -10.0 ) );
172
173 auto sub = vint - 2 * vlong;
174 BOOST_CHECK_EQUAL( sub.x, 6 );
175 BOOST_CHECK_EQUAL( sub.y, 5 );
176
177 vunsigned = VECTOR2<unsigned>( std::numeric_limits<unsigned>::max(), std::numeric_limits<unsigned>::max() );
178 vint = VECTOR2I( vunsigned );
179 BOOST_CHECK_EQUAL( vint.x, std::numeric_limits<int>::max() );
180
181 vunsigned += 1;
182 BOOST_CHECK_EQUAL( vunsigned.x, 0 );
183}
184
185BOOST_AUTO_TEST_SUITE_END()
extended_type Cross(const VECTOR2< T > &aVector) const
Compute cross product of self with aVector.
Definition: vector2d.h:535
extended_type Dot(const VECTOR2< T > &aVector) const
Compute dot product of self with aVector.
Definition: vector2d.h:543
VECTOR2< T > Resize(T aNewLength) const
Return a vector of the same direction, but length specified in aNewLength.
Definition: vector2d.h:380
BOOST_AUTO_TEST_SUITE(CadstarPartParser)
VECTOR3I v1(5, 5, 5)
VECTOR2I v2(1, 0)
Test suite for KiCad math code.
VECTOR2I v4(1, 1)
VECTOR2I v5(-70, -70)
BOOST_AUTO_TEST_CASE(test_casting)
BOOST_CHECK(v2.Cross(v1)==1)
VECTOR2I v3(-2, 1)
VECTOR2< int32_t > VECTOR2I
Definition: vector2d.h:673
VECTOR2< double > VECTOR2D
Definition: vector2d.h:672
VECTOR2< int64_t > VECTOR2L
Definition: vector2d.h:674