ASL
0.1.7
Advanced Simulation Library
Toggle main menu visibility
Loading...
Searching...
No Matches
src
acl
aclMath
aclQuaternionOfElements.h
Go to the documentation of this file.
1
/*
2
* Advanced Simulation Library <http://asl.org.il>
3
*
4
* Copyright 2015 Avtech Scientific <http://avtechscientific.com>
5
*
6
*
7
* This file is part of Advanced Simulation Library (ASL).
8
*
9
* ASL is free software: you can redistribute it and/or modify it
10
* under the terms of the GNU Affero General Public License as
11
* published by the Free Software Foundation, version 3 of the License.
12
*
13
* ASL is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU Affero General Public License for more details.
17
*
18
* You should have received a copy of the GNU Affero General Public License
19
* along with ASL. If not, see <http://www.gnu.org/licenses/>.
20
*
21
*/
22
23
24
#ifndef ACLQUATERNIONOFELEMENTS_H
25
#define ACLQUATERNIONOFELEMENTS_H
26
27
#include "
aclVectorOfElements.h
"
28
29
namespace
acl
30
{
32
35
class
QuaternionOfElements
36
{
37
private
:
38
VectorOfElements
w;
39
VectorOfElements
u;
40
public
:
41
QuaternionOfElements
();
42
43
void
setWElement
(
Element
a);
44
void
setUElement
(
unsigned
int
i,
Element
a);
45
const
Element
getWElement
()
const
;
46
const
Element
getUElement
(
unsigned
int
i)
const
;
47
VectorOfElements
&
getU
();
48
const
VectorOfElements
&
getU
()
const
;
49
VectorOfElements
&
getW
();
50
const
VectorOfElements
&
getW
()
const
;
51
};
52
54
57
void
copy
(
const
QuaternionOfElements
& source,
QuaternionOfElements
& destination);
58
60
63
QuaternionOfElements
operator+
(
QuaternionOfElements
& a,
QuaternionOfElements
& b);
65
68
QuaternionOfElements
operator-
(
QuaternionOfElements
& a,
QuaternionOfElements
& b);
69
71
74
QuaternionOfElements
operator*
(
const
QuaternionOfElements
& a,
const
QuaternionOfElements
& b);
75
77
80
81
VectorOfElements
l2
(
QuaternionOfElements
& a);
82
83
QuaternionOfElements
normalize
(
QuaternionOfElements
& a);
84
85
86
87
88
89
}
//namespace acl
90
91
#endif
// ACLQUATERNIONOFELEMENTS_H
aclVectorOfElements.h
acl::QuaternionOfElements
The class represents a matrix elements of Element.
Definition
aclQuaternionOfElements.h:36
acl::QuaternionOfElements::operator*
QuaternionOfElements operator*(const QuaternionOfElements &a, const QuaternionOfElements &b)
product of two matrices
acl::QuaternionOfElements::QuaternionOfElements
QuaternionOfElements()
acl::QuaternionOfElements::copy
void copy(const QuaternionOfElements &source, QuaternionOfElements &destination)
function copies the QuaternionOfElements class.
acl::QuaternionOfElements::getU
const VectorOfElements & getU() const
acl::QuaternionOfElements::l2
VectorOfElements l2(QuaternionOfElements &a)
L2 norm of a quaternion.
acl::QuaternionOfElements::setWElement
void setWElement(Element a)
acl::QuaternionOfElements::getW
const VectorOfElements & getW() const
acl::QuaternionOfElements::setUElement
void setUElement(unsigned int i, Element a)
acl::QuaternionOfElements::getW
VectorOfElements & getW()
acl::QuaternionOfElements::getU
VectorOfElements & getU()
acl::QuaternionOfElements::getUElement
const Element getUElement(unsigned int i) const
acl::QuaternionOfElements::operator-
QuaternionOfElements operator-(QuaternionOfElements &a, QuaternionOfElements &b)
difference of two matrices
acl::QuaternionOfElements::getWElement
const Element getWElement() const
acl::QuaternionOfElements::operator+
QuaternionOfElements operator+(QuaternionOfElements &a, QuaternionOfElements &b)
summ of two matrices
acl::VectorOfElements
The class represents several Element.
Definition
aclVectorOfElementsDef.h:92
acl
Advanced Computational Language.
Definition
acl.h:41
acl::normalize
QuaternionOfElements normalize(QuaternionOfElements &a)
acl::Element
std::shared_ptr< ElementBase > Element
Definition
acl.h:49
Generated by
1.17.0