xsvector3.h
Go to the documentation of this file.
1 
2 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification,
6 // are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions, and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions, and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the names of the copyright holders nor the names of their contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
24 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
26 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
28 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
29 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
30 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
31 //
32 
33 
34 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
35 // All rights reserved.
36 //
37 // Redistribution and use in source and binary forms, with or without modification,
38 // are permitted provided that the following conditions are met:
39 //
40 // 1. Redistributions of source code must retain the above copyright notice,
41 // this list of conditions, and the following disclaimer.
42 //
43 // 2. Redistributions in binary form must reproduce the above copyright notice,
44 // this list of conditions, and the following disclaimer in the documentation
45 // and/or other materials provided with the distribution.
46 //
47 // 3. Neither the names of the copyright holders nor the names of their contributors
48 // may be used to endorse or promote products derived from this software without
49 // specific prior written permission.
50 //
51 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
52 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
53 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
54 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
55 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
56 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
57 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
58 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
59 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
60 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
61 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
62 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
63 //
64 
65 #ifndef XSVECTOR3_H
66 #define XSVECTOR3_H
67 
68 #include "xsvector.h"
69 
70 struct XsVector3;
71 #ifdef __cplusplus
72 extern "C" {
73 #endif
74 #ifndef __cplusplus
75 typedef struct XsVector3 XsVector3;
76 #endif
77 
78 XSTYPES_DLL_API void XsVector3_construct(XsVector3* thisPtr, const XsReal* src);
79 XSTYPES_DLL_API void XsVector3_assign(XsVector3* thisPtr, const XsReal* src);
81 XSTYPES_DLL_API void XsVector3_copy(XsVector* copy, XsVector3 const* src);
82 
83 #ifdef __cplusplus
84 } // extern "C"
85 #endif
86 
87 #ifdef __cplusplus
88 /* This is allowed since the C standard says that no padding appears before the first member of a struct.
89  Basically we're defining a union between a C++ inherited type and a C encapsulated type.
90 */
91 struct XsVector3 : public XsVector
92 {
94 #else
95 struct XsVector3
96 {
98 #endif
100 
101 #ifdef __cplusplus
102 public:
105  {
106  //XsVector3_construct(this, 0);
107  }
108 
110  XsVector3(XsVector3 const& other) : XsVector(other, m_fixedData, 3, XSDF_FixedSize)
111  {
112  }
113 
115  XsVector3(XsVector const& other) : XsVector(other, m_fixedData, 3, XSDF_FixedSize)
116  {
117  }
118 
121  {
122  m_data[0] = x;
123  m_data[1] = y;
124  m_data[2] = z;
125  }
126 
128  static XsVector3 const& zero3()
129  {
130  static const XsVector3 rv(XsMath_zero, XsMath_zero, XsMath_zero);
131  return rv;
132  }
133 
134  using XsVector::operator=;
136  inline XsVector3& operator=(const XsVector3& other)
137  {
138  XsVector_copy(this, &other);
139  return *this;
140  }
141 
142  using XsVector::assign;
144  inline void assign(XsReal x, XsReal y, XsReal z)
145  {
146  m_data[0] = x;
147  m_data[1] = y;
148  m_data[2] = z;
149  const_cast<XsSize&>(m_flags) &= ~XSDF_Empty;
150  }
151  // using XsVector::operator[];
152 #endif
153 };
154 
155 #endif
XsVector3::m_fixedData
XsReal m_fixedData[3]
Fixed size storage for the components in the vector.
Definition: xsvector3.h:99
XsVector
A class that represents a vector of real numbers.
Definition: xsvector.h:113
XsVector3
struct XsVector3 XsVector3
Definition: xsvector3.h:75
xsvector.h
XsVector_copy
XSTYPES_DLL_API void XsVector_copy(XsVector *copy, XsVector const *src)
XSDF_FixedSize
@ XSDF_FixedSize
The contained data points to a fixed-size buffer, this allows creation of dynamic objects on the stac...
Definition: xstypedefs.h:111
XsVector3::XsVector3_copy
void XsVector3_copy(XsVector *copy, XsVector3 const *src)
Copy the contents of the XsVector3 to copy.
Definition: xsvector3.c:99
XSCPPPROTECTED
#define XSCPPPROTECTED
Definition: xstypesconfig.h:116
XsReal
double XsReal
Defines the floating point type used by the Xsens libraries.
Definition: xstypedefs.h:73
XsSize
size_t XsSize
XsSize must be unsigned number!
Definition: xstypedefs.h:74
XsVector3::XsVector3_construct
void XsVector3_construct(XsVector3 *thisPtr, const XsReal *src)
Init the XsVector3 and copy the data from src into the vector if src is not null.
Definition: xsvector3.c:77
XsVector3::m_vector
XsVector m_vector
The underlying vector.
Definition: xsvector3.h:97
XSDF_Empty
@ XSDF_Empty
The object contains undefined data / should be considered empty. Usually only relevant when XSDF_Fixe...
Definition: xstypedefs.h:112
XsMath_zero
XSMATHCONST XsReal XsMath_zero
0
Definition: xsmath.h:150
XSTYPES_DLL_API
#define XSTYPES_DLL_API
Definition: xstypesconfig.h:65
XsVector3
A class that represents a fixed size (3) vector.
Definition: xsvector3.h:95
XsVector3::XsVector3_destruct
void XsVector3_destruct(XsVector3 *thisPtr)
Frees the XsVector3.
Definition: xsvector3.c:91
XsVector3::XsVector3_assign
void XsVector3_assign(XsVector3 *thisPtr, const XsReal *src)
Init the XsVector3 and copy the data from src into the vector if src is not null.
Definition: xsvector3.c:85


xsens_mti_driver
Author(s):
autogenerated on Sun Sep 3 2023 02:43:20