vector: operate on value types, not references

This commit is contained in:
Danny Robson 2015-04-15 14:06:49 +10:00
parent ffaf10de21
commit 71d8a30769
2 changed files with 29 additions and 27 deletions

View File

@ -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)
@ -247,9 +249,9 @@ 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>&);

View File

@ -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>&);