vector: operate on value types, not references
This commit is contained in:
parent
ffaf10de21
commit
71d8a30769
40
vector.cpp
40
vector.cpp
@ -26,6 +26,8 @@
|
|||||||
#include <numeric>
|
#include <numeric>
|
||||||
|
|
||||||
using util::vector;
|
using util::vector;
|
||||||
|
using util::vector3f;
|
||||||
|
using util::vector3d;
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
@ -53,7 +55,7 @@ util::vector<S,T>::magnitude2 (void) const
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <size_t S, typename T>
|
template <size_t S, typename T>
|
||||||
T
|
T
|
||||||
util::vector<S,T>::difference (const util::vector<S,T> &rhs) const
|
util::vector<S,T>::difference (vector<S,T> rhs) const
|
||||||
{
|
{
|
||||||
// TODO: change the signature to ensure it does not truncate
|
// TODO: change the signature to ensure it does not truncate
|
||||||
return static_cast<T> (std::sqrt (difference2 (rhs)));
|
return static_cast<T> (std::sqrt (difference2 (rhs)));
|
||||||
@ -63,7 +65,7 @@ util::vector<S,T>::difference (const util::vector<S,T> &rhs) const
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <size_t S, typename T>
|
template <size_t S, typename T>
|
||||||
T
|
T
|
||||||
util::vector<S,T>::difference2 (const util::vector<S,T> &rhs) const
|
util::vector<S,T>::difference2 (vector<S,T> rhs) const
|
||||||
{
|
{
|
||||||
T sum {0};
|
T sum {0};
|
||||||
for (size_t i = 0; i < S; ++i)
|
for (size_t i = 0; i < S; ++i)
|
||||||
@ -112,8 +114,8 @@ util::vector<S,T>::normalised (void) const
|
|||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
template <typename T>
|
template <typename T>
|
||||||
util::vector<2,T>
|
vector<2,T>
|
||||||
util::polar_to_cartesian (util::vector<2,T> v)
|
util::polar_to_cartesian (vector<2,T> v)
|
||||||
{
|
{
|
||||||
return util::vector<2,T> {
|
return util::vector<2,T> {
|
||||||
v[0] * std::cos (v[1]),
|
v[0] * std::cos (v[1]),
|
||||||
@ -124,8 +126,8 @@ util::polar_to_cartesian (util::vector<2,T> v)
|
|||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <typename T>
|
template <typename T>
|
||||||
util::vector<2,T>
|
vector<2,T>
|
||||||
util::cartesian_to_polar (util::vector<2,T> v)
|
util::cartesian_to_polar (vector<2,T> v)
|
||||||
{
|
{
|
||||||
return util::vector<2,T> {
|
return util::vector<2,T> {
|
||||||
std::hypot (v.x, v.y),
|
std::hypot (v.x, v.y),
|
||||||
@ -136,9 +138,9 @@ util::cartesian_to_polar (util::vector<2,T> v)
|
|||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
template <typename T>
|
template <typename T>
|
||||||
util::vector<3,T>
|
vector<3,T>
|
||||||
util::cross (const util::vector<3,T> &a,
|
util::cross (vector<3,T> a,
|
||||||
const util::vector<3,T> &b)
|
vector<3,T> b)
|
||||||
{
|
{
|
||||||
return util::vector<3,T> {
|
return util::vector<3,T> {
|
||||||
a.y * b.z - a.z * b.y,
|
a.y * b.z - a.z * b.y,
|
||||||
@ -147,16 +149,16 @@ util::cross (const util::vector<3,T> &a,
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
template util::vector3f util::cross(const util::vector3f&, const util::vector3f&);
|
template vector3f util::cross(vector3f, vector3f);
|
||||||
template util::vector3d util::cross(const util::vector3d&, const util::vector3d&);
|
template vector3d util::cross(vector3d, vector3d);
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <typename T>
|
template <typename T>
|
||||||
util::vector<3,T>
|
vector<3,T>
|
||||||
util::spherical_to_cartesian (const util::vector<3,T> &s)
|
util::spherical_to_cartesian (vector<3,T> s)
|
||||||
{
|
{
|
||||||
return util::vector<3,T> {
|
return vector<3,T> {
|
||||||
s.x * sin (s.y) * cos (s.z),
|
s.x * sin (s.y) * cos (s.z),
|
||||||
s.x * sin (s.y) * sin (s.z),
|
s.x * sin (s.y) * sin (s.z),
|
||||||
s.x * cos (s.y),
|
s.x * cos (s.y),
|
||||||
@ -166,12 +168,12 @@ util::spherical_to_cartesian (const util::vector<3,T> &s)
|
|||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
template <typename T>
|
template <typename T>
|
||||||
util::vector<3,T>
|
vector<3,T>
|
||||||
util::cartesian_to_spherical (const util::vector<3,T> &c)
|
util::cartesian_to_spherical (vector<3,T> c)
|
||||||
{
|
{
|
||||||
T mag = c.magnitude ();
|
T mag = c.magnitude ();
|
||||||
|
|
||||||
return util::vector<3,T> {
|
return vector<3,T> {
|
||||||
mag,
|
mag,
|
||||||
acos (c.z / mag),
|
acos (c.z / mag),
|
||||||
atan2 (c.y, c.x)
|
atan2 (c.y, c.x)
|
||||||
@ -217,7 +219,7 @@ util::vector<S,T>::sanity (void) const
|
|||||||
|
|
||||||
template <size_t S, typename T>
|
template <size_t S, typename T>
|
||||||
std::ostream&
|
std::ostream&
|
||||||
util::operator<< (std::ostream &os, const util::vector<S,T> &v)
|
util::operator<< (std::ostream &os, util::vector<S,T> v)
|
||||||
{
|
{
|
||||||
os << "vec" << S << "(" << v.data[0];
|
os << "vec" << S << "(" << v.data[0];
|
||||||
for (size_t i = 1; i < S; ++i)
|
for (size_t i = 1; i < S; ++i)
|
||||||
@ -249,7 +251,7 @@ util::operator>> (const json::tree::node &node, util::vector<S,T> &v)
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
#define INSTANTIATE_S_T(S,T) \
|
#define INSTANTIATE_S_T(S,T) \
|
||||||
template struct util::vector<S,T>; \
|
template struct util::vector<S,T>; \
|
||||||
template std::ostream& util::operator<< (std::ostream&, const util::vector<S,T> &v);\
|
template std::ostream& util::operator<< (std::ostream&, util::vector<S,T> v); \
|
||||||
template const json::tree::node& util::operator>> (const json::tree::node&, util::vector<S,T>&);
|
template const json::tree::node& util::operator>> (const json::tree::node&, util::vector<S,T>&);
|
||||||
|
|
||||||
|
|
||||||
|
12
vector.hpp
12
vector.hpp
@ -36,8 +36,8 @@ namespace util {
|
|||||||
T magnitude (void) const;
|
T magnitude (void) const;
|
||||||
T magnitude2 (void) const;
|
T magnitude2 (void) const;
|
||||||
|
|
||||||
T difference (const vector<S,T>&) const;
|
T difference (vector<S,T>) const;
|
||||||
T difference2 (const vector<S,T>&) const;
|
T difference2 (vector<S,T>) const;
|
||||||
|
|
||||||
// normalisation
|
// normalisation
|
||||||
bool is_normalised (void) const;
|
bool is_normalised (void) const;
|
||||||
@ -56,12 +56,12 @@ namespace util {
|
|||||||
template <typename T> vector<2,T> polar_to_cartesian (vector<2,T>);
|
template <typename T> vector<2,T> polar_to_cartesian (vector<2,T>);
|
||||||
template <typename T> vector<2,T> cartesian_to_polar (vector<2,T>);
|
template <typename T> vector<2,T> cartesian_to_polar (vector<2,T>);
|
||||||
|
|
||||||
template <typename T> vector<3,T> cross (const vector<3,T>&, const vector<3,T>&);
|
template <typename T> vector<3,T> cross (vector<3,T>, vector<3,T>);
|
||||||
template <typename T> vector<3,T> spherical_to_cartesian (const vector<3,T>&);
|
template <typename T> vector<3,T> spherical_to_cartesian (vector<3,T>);
|
||||||
template <typename T> vector<3,T> cartesian_to_spherical (const vector<3,T>&);
|
template <typename T> vector<3,T> cartesian_to_spherical (vector<3,T>);
|
||||||
|
|
||||||
// output and serialisation operators
|
// output and serialisation operators
|
||||||
template <size_t S, typename T> std::ostream& operator<< (std::ostream&, const vector<S,T>&);
|
template <size_t S, typename T> std::ostream& operator<< (std::ostream&, vector<S,T>);
|
||||||
|
|
||||||
template <size_t S, typename T>
|
template <size_t S, typename T>
|
||||||
const json::tree::node& operator>> (const json::tree::node&, vector<S,T>&);
|
const json::tree::node& operator>> (const json::tree::node&, vector<S,T>&);
|
||||||
|
Loading…
Reference in New Issue
Block a user