123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- #pragma once
- #include "FrameworkMath.h"
- namespace Framework
- {
- template<typename T, int N>
-
- class VecN
- {
- private:
- T v[N];
- public:
-
- inline VecN() {}
-
-
- inline VecN(const T v[N])
- {
- memcpy(this->v, v, sizeof(T) * N);
- }
- inline VecN(std::initializer_list<T> l)
- {
- assert(l.size() == N);
- int i = 0;
- for (auto v : l)
- {
- this->v[i] = v;
- i++;
- }
- }
-
-
- inline VecN(const VecN& vect)
- : VecN(vect.v)
- {}
-
- inline VecN& normalize()
- {
- const T length = getLength();
- for (int i = 0; i < N; i++)
- v[i] /= length;
- return *this;
- }
-
-
- inline VecN& swap(VecN& vect)
- {
- const VecN tmp = vect;
- vect = *this;
- *this = tmp;
- return *this;
- }
-
- inline float angle(VecN vect)
- {
- return lowPrecisionACos(
- (float)(*this * vect)
- / ((float)getLength() * (float)vect.getLength()));
- }
-
-
- inline VecN operator=(const VecN& r)
- {
- memcpy(v, r.v, sizeof(T) * N);
- return *this;
- }
-
-
- inline VecN operator+=(const VecN& r)
- {
- for (int i = 0; i < N; i++)
- v[i] += r.v[i];
- return *this;
- }
-
-
- inline VecN operator-=(const VecN& r)
- {
- for (int i = 0; i < N; i++)
- v[i] -= r.v[i];
- return *this;
- }
-
-
- inline VecN operator*=(const T& r)
- {
- for (int i = 0; i < N; i++)
- v[i] *= r;
- return *this;
- }
-
-
- inline VecN operator/=(const T& r)
- {
- for (int i = 0; i < N; i++)
- v[i] /= r;
- return *this;
- }
-
-
- inline T abstandSq(const VecN& p) const
- {
- T sum = (T)0;
- for (int i = 0; i < N; i++)
- sum += (v[i] - p.v[i]) * (v[i] - p.v[i]);
- return sum;
- }
-
-
- inline T abstand(const VecN& p) const
- {
- return sqrt(abstandSq(p));
- }
-
- inline VecN operator-() const
- {
- T r[N];
- for (int i = 0; i < N; i++)
- r[i] = -v[i];
- return {r};
- }
- template<typename T2>
-
- inline operator VecN<T2, N>() const
- {
- T2 r[N];
- for (int i = 0; i < N; i++)
- r[i] = (T2)v[i];
- return {r};
- }
-
- inline T getLengthSq() const
- {
- return *this * *this;
- }
-
- inline T getLength() const
- {
- return (T)sqrt(getLengthSq());
- }
-
-
- inline T operator*(const VecN& r) const
- {
- T sum = (T)0;
- for (int i = 0; i < N; i++)
- sum += v[i] * r.v[i];
- return sum;
- }
-
-
- inline VecN operator+(const VecN& r) const
- {
- return VecN(*this) += r;
- }
-
-
- inline VecN operator-(const VecN& r) const
- {
- return VecN(*this) -= r;
- }
-
-
- inline VecN operator*(const T& r) const
- {
- return VecN(*this) *= r;
- }
-
-
- inline VecN operator/(const T& r) const
- {
- return VecN(*this) /= r;
- }
-
-
- inline bool operator==(const VecN& r) const
- {
- for (int i = 0; i < N; i++)
- {
- if (v[i] != r.v[i]) return 0;
- }
- return 1;
- }
-
-
- inline bool operator!=(const VecN& r) const
- {
- return !(*this == r);
- }
- inline T operator[](int i) const
- {
- return v[i];
- }
- };
- }
|