Table of Contents

Математика

Заметки

Что такое "num"?

num означает “любой численный тип” (int или fixed). Функции, принимающие num, принимают и int, и fixed. Например:

num max(num a, num b)

означает:

“Функция max принимает два числа и возвращает число. Если оба аргумента – int, то она возвращает int. Если же оба аргумента fixed, то она возвращает fixed”.

Это позволяет использовать функцию max обоими способами:

max(2, 5) == 5
max(2.0, 5.0) == 5.0

Не смешивайте int и fixed числа в num. num в сигнатуре функции все являются либо int, либо fixed! Например, вот так неправильно:

max(5, 2.0)

Функция вернёт 2.0, потому что 2.0 (65536) больше, чем 5.

Об углах

Все углы в ACSUtils используют формат fixed-point angles из ZDoom (обороты), и допускается их выход за пределы диапазона 0.0-1.0. Все подобные случаи правильно обрабатываются и движком, и ACSUtils.

Константы

ACSUtils предоставляет набор математических констант. Все fixed констаты имеют много цифр после запятой, чтобы максимизировать точность. Они имеют даже больше цифр после запятой, чем нужно.

Пи и Тау

Числа Пи и Тау.

e

fixed MATH_E = 2.7182818284590452353602874713526624977572470937;

Число e. Названо MATH_E во избежание конфликтов с именем переменной e.

Важные квадратные корни и логарифмы

Предварительно рассчитаны с максимальной точностью и часто встречаются в некоторых алгоритмах.

Математические функции общего назначения

abs

num abs(num x)

Возвращает модуль X:

Остерегайтесь использования этой функции с INT_MIN.

abs(INT_MIN) == INT_MIN, потому что -INT_MIN == INT_MIN. Это единственный случай, когда abs возвращает отрицательное число.

sgn

int sgn(int x)

Возвращает знак X:

Пример использования

// Задаём скорость по X равную 15.0
// но с таким же знаком, что и у foo
int xvel = sgn(foo) * 15.0;

min

num min(num a, num b)

Возвращает меньшее из двух чисел.

max

num max(num a, num b)

Возвращает большее из двух чисел.

clamp

num clamp(num x, num минимум, num максимум)

Ограничивает X в указанном диапазоне:

cmp

int cmp(num a, num b)

Сравнивает два числа и возвращает результат:

Тригонометрия

ACSUtils предоставляет полный набор тригонометрических функций:

Inverse trigonometric functions:

Vector math

VectorLength3D

fixed VectorLength3D(fixed x, fixed y, fixed z)

Трёхмерная версия VectorLength. Возвращает длину трёхмерного вектора.

dot

Возвращает скалярное произведение двух векторов. Краткий способ записи FixedMul(x1, x2) + FixedMul(y1, y2) + ….

normalize

Нормализует вектор и возвращает результат, используя несколько возвращаемых значений.

Пример использования

normalize3d(x, y, z);
x = r1;
y = r2;
z = r2;
normalize2d(x, y);
int normalizedX = r1;
int normalziedY = r2;

RotateVector

fixed, fixed RotateVector(fixed x, fixed y, fixed angle)

Поворачивает вектор на указанный угол и возвращает результат, используя несколько возвращаемых значений.

Example usage

RotateVector(x, y, angle);
x = r1;
y = r2;

RotateVectorCS

fixed, fixed RotateVector(fixed x, fixed y, fixed cos, fixed sin)

Более быстрая версия RotateVector, которая принимает косинус и синус угла вращения, вместо того, чтобы вычислять их.

RotatePoint

fixed, fixed RotatePoint(fixed x, fixed y, fixed originX, fixed originY, fixed angle)

Rotates the point around the specified origin by the angle and returns the result using multiple return values.

SqVectorLength

Returns vector length squared.

Because this function returns a fixed, it won't work correctly for vectors longer than 256.0!

VectorToAngles

fixed, fixed VectorToAngles(fixed x, fixed y, fixed z

Converts the vector to a pair of angles (angle, pitch) and returns them using multiple return values.

Example usage

// This function makes the actor look in the direction
// specified as a 3D vector.
function void LookInDirection(int tid, int x, int y, int z)
{
    VectorToAngles(x, y, z);
    int angle = r1;
    int pitch = r2;
    SetActorAngle(tid, angle);
    SetActorPitch(tid, -pitch); // SetActorPitch expects inverted pitch.
}

AnglesToVector

fixed, fixed, fixed AnglesToVector(fixed angle, fixed pitch)

Converts a pair of angles (angle, pitch) to a 3D vector of length 1.0 and returns it using multiple return values.