82 constexpr const T &
operator[](
const int index)
const {
return index ?
y :
x; }
90 float c = std::cos(
angle);
103 return a.
x * b.
x + a.
y * b.
y;
106template<std::
floating_po
int T>
109 return std::sqrt(
dot(a, a));
112template<std::
integral T>
115 return std::sqrt(
static_cast<float>(
dot(a, a)));
125 if(a.
x == 0 && a.
y == 0)
128 return a.
y < 0 ? -
pi / 2 :
pi / 2;
129 float result = std::atan(a.
y / a.
x);
131 result = result +
pi;
145 float divisor =
length(v);
148 float l = 1.0f / divisor;
170 T SquaredMagnitudeAB =
dot(AB, AB);
171 if(SquaredMagnitudeAB > 0)
174 T APdotAB =
dot(AP, AB);
175 T t = APdotAB / SquaredMagnitudeAB;
176 out_pos = line_pointA + AB * std::clamp(t, (T)0, (T)1);
187 vec2 Delta = LineEnd - LineStart;
188 vec2 Offset = LineStart - CircleCenter;
192 float B = 2.0f *
dot(Offset, Delta);
193 float C =
dot(Offset, Offset) - Radius * Radius;
195 float Discriminant =
B *
B - 4.0f * A * C;
196 if(Discriminant < 0.0f || A == 0.0f)
201 else if(Discriminant == 0.0f)
204 float Time = -
B / (2.0f * A);
205 aIntersections[0] = LineStart + Delta * Time;
210 Discriminant = std::sqrt(Discriminant);
211 float Time1 = (-
B - Discriminant) / (2.0f * A);
212 float Time2 = (-
B + Discriminant) / (2.0f * A);
214 aIntersections[0] = LineStart + Delta * Time1;
215 aIntersections[1] = LineStart + Delta * Time2;
309 return a.
x * b.
x + a.
y * b.
y + a.
z * b.
z;
316 a.
y * b.
z - a.
z * b.
y,
317 a.
z * b.
x - a.
x * b.
z,
318 a.
x * b.
y - a.
y * b.
x);
324 return std::sqrt(
dot(a, a));
329 float divisor =
length(v);
332 float l = 1.0f / divisor;
365 x(nx),
y(ny),
z(nz),
w(nw)
constexpr bool operator!=(const vector2_base &vec) const
Definition vmath.h:79
constexpr vector2_base operator*(const T rhs) const
Definition vmath.h:36
constexpr vector2_base operator*(const vector2_base &vec) const
Definition vmath.h:37
constexpr vector2_base operator+(const vector2_base &vec) const
Definition vmath.h:35
constexpr vector2_base(T nx, T ny)
Definition vmath.h:28
constexpr vector2_base operator/(const vector2_base &vec) const
Definition vmath.h:39
constexpr vector2_base operator-() const
Definition vmath.h:33
constexpr const T & operator[](const int index) const
Definition vmath.h:82
constexpr vector2_base & operator/=(const T rhs)
Definition vmath.h:65
constexpr vector2_base & operator*=(const vector2_base &vec)
Definition vmath.h:59
constexpr vector2_base & operator-=(const vector2_base &vec)
Definition vmath.h:47
constexpr bool operator==(const vector2_base &vec) const
Definition vmath.h:78
constexpr vector2_base()=default
constexpr vector2_base & operator*=(const T rhs)
Definition vmath.h:53
constexpr vector2_base operator-(const vector2_base &vec) const
Definition vmath.h:34
constexpr vector2_base operator/(const T rhs) const
Definition vmath.h:38
constexpr vector2_base & operator/=(const vector2_base &vec)
Definition vmath.h:71
constexpr T & operator[](const int index)
Definition vmath.h:81
constexpr vector2_base & operator+=(const vector2_base &vec)
Definition vmath.h:41
T z
Definition vmath.h:236
constexpr vector3_base()=default
constexpr vector3_base & operator+=(const vector3_base &vec)
Definition vmath.h:253
constexpr vector3_base operator*(const T rhs) const
Definition vmath.h:248
constexpr vector3_base operator-(const vector3_base &vec) const
Definition vmath.h:245
T x
Definition vmath.h:228
constexpr vector3_base & operator/=(const T rhs)
Definition vmath.h:281
constexpr bool operator==(const vector3_base &vec) const
Definition vmath.h:296
constexpr vector3_base & operator-=(const vector3_base &vec)
Definition vmath.h:260
T y
Definition vmath.h:232
constexpr vector3_base & operator/=(const vector3_base &vec)
Definition vmath.h:288
T s
Definition vmath.h:232
T v
Definition vmath.h:232
T r
Definition vmath.h:228
constexpr vector3_base operator/(const T rhs) const
Definition vmath.h:250
T g
Definition vmath.h:232
constexpr vector3_base operator/(const vector3_base &vec) const
Definition vmath.h:251
constexpr vector3_base & operator*=(const T rhs)
Definition vmath.h:267
T u
Definition vmath.h:228
constexpr bool operator!=(const vector3_base &vec) const
Definition vmath.h:297
constexpr vector3_base operator+(const vector3_base &vec) const
Definition vmath.h:247
constexpr vector3_base operator*(const vector3_base &vec) const
Definition vmath.h:249
T w
Definition vmath.h:236
T b
Definition vmath.h:236
constexpr vector3_base & operator*=(const vector3_base &vec)
Definition vmath.h:274
T h
Definition vmath.h:228
constexpr vector3_base operator-() const
Definition vmath.h:246
T l
Definition vmath.h:236
constexpr vector3_base(T nx, T ny, T nz)
Definition vmath.h:240
T g
Definition vmath.h:352
constexpr vector4_base & operator/=(const vector4_base &vec)
Definition vmath.h:417
T w
Definition vmath.h:360
constexpr bool operator!=(const vector4_base &vec) const
Definition vmath.h:427
T b
Definition vmath.h:356
T s
Definition vmath.h:352
T r
Definition vmath.h:348
T h
Definition vmath.h:348
constexpr vector4_base operator+(const vector4_base &vec) const
Definition vmath.h:369
T z
Definition vmath.h:356
constexpr vector4_base operator/(const vector4_base &vec) const
Definition vmath.h:374
constexpr vector4_base & operator/=(const T rhs)
Definition vmath.h:409
constexpr vector4_base operator-(const vector4_base &vec) const
Definition vmath.h:370
constexpr vector4_base(T nx, T ny, T nz, T nw)
Definition vmath.h:364
constexpr vector4_base & operator*=(const vector4_base &vec)
Definition vmath.h:401
T y
Definition vmath.h:352
T l
Definition vmath.h:356
constexpr vector4_base & operator*=(const T rhs)
Definition vmath.h:393
constexpr vector4_base()=default
constexpr vector4_base operator*(const T rhs) const
Definition vmath.h:373
T a
Definition vmath.h:360
constexpr vector4_base operator/(const T vec) const
Definition vmath.h:375
constexpr vector4_base & operator+=(const vector4_base &vec)
Definition vmath.h:377
constexpr vector4_base & operator-=(const vector4_base &vec)
Definition vmath.h:385
constexpr vector4_base operator*(const vector4_base &vec) const
Definition vmath.h:372
T x
Definition vmath.h:348
constexpr vector4_base operator-() const
Definition vmath.h:371
constexpr bool operator==(const vector4_base &vec) const
Definition vmath.h:426
static SHA256_DIGEST s(const char *pSha256)
Definition mapbugs.cpp:38
constexpr float pi
Definition math.h:14
float random_angle()
Definition math.h:77
vector4_base< int > ivec4
Definition vmath.h:432
constexpr float angle(const vector2_base< float > &a)
Definition vmath.h:123
vector2_base< float > normalize(const vector2_base< float > &v)
Definition vmath.h:143
vector4_base< uint8_t > ubvec4
Definition vmath.h:433
constexpr float length_squared(const vector2_base< float > &a)
Definition vmath.h:118
constexpr vector3_base< T > cross(const vector3_base< T > &a, const vector3_base< T > &b)
Definition vmath.h:313
vector2_base< float > direction(float angle)
Definition vmath.h:152
float length(const vector2_base< T > &a)
Definition vmath.h:107
vector4_base< bool > bvec4
Definition vmath.h:431
vector3_base< float > vec3
Definition vmath.h:336
vector4_base< float > vec4
Definition vmath.h:430
vector2_base< int > ivec2
Definition vmath.h:164
vector3_base< int > ivec3
Definition vmath.h:338
constexpr int intersect_line_circle(const vec2 LineStart, const vec2 LineEnd, const vec2 CircleCenter, float Radius, vec2 aIntersections[2])
Definition vmath.h:185
vector2_base< bool > bvec2
Definition vmath.h:163
vector2_base< float > random_direction()
Definition vmath.h:157
vector3_base< bool > bvec3
Definition vmath.h:337
constexpr vector2_base< T > rotate(const vector2_base< T > &a, float angle)
Definition vmath.h:86
vector2_base< float > vec2
Definition vmath.h:162
constexpr vector2_base< T > normalize_pre_length(const vector2_base< T > &v, T len)
Definition vmath.h:136
constexpr bool closest_point_on_line(vector2_base< T > line_pointA, vector2_base< T > line_pointB, vector2_base< T > target_point, vector2_base< T > &out_pos)
Definition vmath.h:167
constexpr T dot(const vector2_base< T > a, const vector2_base< T > &b)
Definition vmath.h:101
T distance(const vector2_base< T > a, const vector2_base< T > &b)
Definition vmath.h:95