Кватернионы: основы и примеры PDF
Document Details
Uploaded by PeacefulEuphoria6718
Tags
Summary
Этот документ знакомит с концепцией кватернионов, подробно описывая их определение, операции сложения и умножения, а также геометрическую интерпретацию. Ключевыми понятиями являются гиперкомплексные числа, скалярная и векторная части, а также матричное представление.
Full Transcript
1. Что такое кватернион? Кватернион — это гиперкомплексное число, которое расширяет понятие комплексных чисел. Он состоит из четырех компонентов: одного скалярного (действительного) и трех мнимых. Кватернион обычно записывается в виде: q = a + bi1 + ci2 + di3, где a, b, c, d — действительные числ...
1. Что такое кватернион? Кватернион — это гиперкомплексное число, которое расширяет понятие комплексных чисел. Он состоит из четырех компонентов: одного скалярного (действительного) и трех мнимых. Кватернион обычно записывается в виде: q = a + bi1 + ci2 + di3, где a, b, c, d — действительные числа, а i1, i2, i3 — мнимые единицы, обладающие особыми свойствами умножения (см. пункт 4). 2. Как складываются кватернионы? Сложение кватернионов происходит покомпонентно. Если у нас есть два кватерниона: q1 = a1 + b1i1 + c1i2 + d1i3 q2 = a2 + b2i1 + c2i2 + d2i3 то их сумма будет равна: q1 + q2 = (a1 + a2) + (b1 + b2)i1 + (c1 + c2)i2 + (d1 + d2)i3 3. Как умножать кватернион на число? Умножение кватерниона на действительное число (скаляр) происходит покомпонентно: k * q = k * (a + bi1 + ci2 + di3) = ka + kbi1 + kci2 + kdi3 где k — действительное число. 4. Как умножать числа i1, i2, i3? Мнимые единицы i1, i2, i3 в кватернионах подчиняются следующим правилам умножения: i1² = i2² = i3² = -1 i1 * i2 = i3, i2 * i1 = -i3 i2 * i3 = i1, i3 * i2 = -i1 i3 * i1 = i2, i1 * i3 = -i2 i1 * i2 * i3 = -1 Эти правила можно запомнить с помощью круговой диаграммы: Двигаясь по кругу по часовой стрелке произведение двух соседних элементов равно третьему, а против часовой стрелки, произведение двух соседних элементов равно третьему, но со знаком минус. 5. Как умножать кватернионы? Умножение кватернионов производится с использованием дистрибутивного закона и правил умножения мнимых единиц (см. пункт 4). Если у нас есть два кватерниона: q1 = a1 + b1i1 + c1i2 + d1i3 q2 = a2 + b2i1 + c2i2 + d2i3 то их произведение q1 * q2 вычисляется путем перемножения каждого члена первого кватерниона на каждый член второго и последующего сложения с учетом правил из пункта 4. Это довольно громоздкая запись, но её можно компактно записать через скалярную и векторную части кватерниона. Пусть q1 = s1 + v1, q2 = s2 + v2, где s - скалярная часть, v - векторная. Тогда: q1 * q2 = (s1*s2 - v1*v2) + (s1*v2 + s2*v1 + v1xv2) 6. Как выглядит матричная запись умножения двух кватернионов? Умножение кватернионов можно представить в матричном виде. Для кватерниона q = a + bi1 + ci2 + di3 можно определить две матрицы: L(q) — матрица левого умножения: L(q) = | a -b -c -d | | b a -d c | | c d a -b | | d -c b a | content_copy download Use code with caution. R(q) — матрица правого умножения: R(q) = | a -b -c -d | | b a d -c | | c -d a b | | d c -b a | content_copy download Use code with caution. Тогда умножение кватерниона q1 на кватернион q2 можно записать как: q1 * q2 = L(q1) * q2_vec = R(q2) * q1_vec, где q_vec — вектор-столбец, составленный из компонентов кватерниона q. 7. Как формулируются свойства операций сложения и умножения двух кватернионов? Сложение: o Коммутативность: q1 + q2 = q2 + q1 o Ассоциативность: (q1 + q2) + q3 = q1 + (q2 + q3) o Существование нулевого элемента: q + 0 = q (где 0 = 0 + 0i1 + 0i2 + 0i3) o Существование противоположного элемента: q + (-q) = 0 Умножение: o Ассоциативность: (q1 * q2) * q3 = q1 * (q2 * q3) o Дистрибутивность: q1 * (q2 + q3) = q1 * q2 + q1 * q3 и (q1 + q2) * q3 = q1 * q3 + q2 * q3 o Существование единичного элемента: q * 1 = 1 * q = q (где 1 = 1 + 0i1 + 0i2 + 0i3) o Некоммутативность: q1 * q2 != q2 * q1 (в общем случае) 8. Как определяется сопряженный кватернион? Сопряженный кватернион q* (иногда обозначается как q̅) для кватерниона q = a + bi1 + ci2 + di3 определяется как: q* = a - bi1 - ci2 - di3 То есть меняется знак у мнимых частей. 9. Как определяется норма кватерниона? Норма кватерниона q = a + bi1 + ci2 + di3 определяется как: N(q) = q * q* = a² + b² + c² + d² 10. Как формулируется свойство нормы произведения кватернионов? Норма произведения кватернионов равна произведению их норм: N(q1 * q2) = N(q1) * N(q2) 11. Как определяется единичный кватернион? Единичный кватернион — это кватернион с нормой, равной единице: N(q) = 1 12. Как определяется модуль кватерниона? Модуль кватерниона |q| равен квадратному корню из его нормы: |q| = sqrt(N(q)) = sqrt(a² + b² + c² + d²) 13. Какой кватернион называется обратным? Обратный кватернион q⁻¹ для кватерниона q — это такой кватернион, что: q * q⁻¹ = q⁻¹ * q = 1 Обратный кватернион вычисляется по формуле: q⁻¹ = q* / |q|² 14. Как определяются скалярные и векторные части кватерниона? Для кватерниона q = a + bi1 + ci2 + di3: Скалярная часть: S(q) = a Векторная часть: V(q) = bi1 + ci2 + di3 15. Как выглядит геометрическая интерпретация кватернионов? Единичные кватернионы могут представлять вращения в трехмерном пространстве. В этом случае: Скалярная часть связана с углом поворота. Векторная часть связана с осью вращения. 16. Как записывается тригонометрическая форма представления кватернионов? Единичный кватернион q можно представить в тригонометрической форме: q = cos(φ/2) + u * sin(φ/2), где φ — угол поворота, а u — единичный вектор, представляющий ось вращения. 17. Как определяется скалярное произведение кватернионов? Скалярное произведение двух кватернионов q1 = a1 + b1i1 + c1i2 + d1i3 и q2 = a2 + b2i1 + c2i2 + d2i3 определяется как: q1 · q2 = a1a2 + b1b2 + c1c2 + d1d2 18. Единичные кватернионы как трехмерные вращения Единичный кватернион q = cos(θ/2) + sin(θ/2)(xi + yj + zk) представляет собой вращение на угол θ вокруг оси, заданной вектором (x, y, z). 19. Операции с кватернионами. Сопряжение и инверсия Сопряжение: Изменение знака векторной части кватерниона. Геометрически это отражение относительно скалярной оси. Инверсия: q⁻¹ = q* / |q|². Для единичных кватернионов инверсия эквивалентна сопряжению. Геометрически это обращение направления вращения. 20. Вращение векторов через кватернионы Чтобы повернуть вектор v с помощью кватерниона q, нужно представить вектор в виде кватерниона с нулевой скалярной частью p = 0 + v и выполнить операцию: p' = q * p * q⁻¹, где p' — кватернион с нулевой скалярной частью, векторная часть которого является результатом поворота вектора v. 21. Кватернионная конкатенация Последовательное применение нескольких вращений эквивалентно умножению соответствующих кватернионов. То есть, если q1 представляет первое вращение, а q2 — второе, то результирующее вращение будет представлено кватернионом q3 = q2 * q1 (обратите внимание на порядок умножения). 22. Кватернионно-матричная эквивалентность Любому кватерниону вращения q соответствует матрица вращения R размером 3x3. Эту матрицу можно построить из компонентов кватерниона. Обратно, по матрице вращения можно восстановить соответствующий кватернион. 23. Как записывается кватернион поворота на заданный угол φ? Кватернион поворота на угол φ вокруг оси, заданной единичным вектором u = (ux, uy, uz), записывается как: q = cos(φ/2) + sin(φ/2) * (ux*i1 + uy*i2 + uz*i3) 24. Как записывается кватернион положения? Кватернион положения обычно используется для представления координат точки в пространстве. Он записывается как кватернион с нулевой скалярной частью: p = 0 + xi1 + yi2 + zi3, где (x, y, z) — координаты точки. 25. Как выглядит кватернионная формула преобразования поворота? Кватернионная формула преобразования поворота, как уже упоминалось в пункте 20: p' = q * p * q⁻¹ Это наиболее лаконичная и эффективная форма записи поворота вектора p с помощью кватерниона q, где p' результат поворота. Надеюсь, эти ответы помогут тебе разобраться в кватернионах! Если остались вопросы, задавай. Ох, внушительный список! Давай разберем каждый вопрос по порядку. 1. Системы координат в разработке игр (декартова, цилиндрическая, сферическая). Примеры использования. Декартова (Cartesian): o Описание: Самая распространенная система координат. Определяется тремя взаимно перпендикулярными осями (обычно X, Y, Z). Положение точки задается тремя координатами (x, y, z), представляющими собой расстояния от начала координат до проекции точки на соответствующие оси. o Примеры: Позиционирование объектов: Размещение персонажей, предметов, элементов окружения в игровом мире. Физические расчеты: Определение скорости, ускорения, сил, действующих на объекты. Камера: Определение положения и направления камеры. Пользовательский интерфейс: Размещение элементов UI на экране. Цилиндрическая (Cylindrical): o Описание: Определяется радиальным расстоянием (ρ), углом (φ) в плоскости XY и высотой (z). По сути, полярная система координат в плоскости XY, дополненная координатой Z. o Примеры: Процедурная генерация: Создание объектов, симметричных относительно некоторой оси, например, колонн, деревьев, гор. Специальные эффекты: Симуляция вихрей, водоворотов, спиральных движений. Игры с видом сверху: Может быть удобна для представления положения объектов, если важна их удаленность от центра и угол относительно него. Сферическая (Spherical): o Описание: Определяется радиальным расстоянием (ρ), углом в горизонтальной плоскости (φ, азимут) и углом от вертикальной оси (θ, зенитный угол). o Примеры: Небесный свод: Размещение звезд, солнца, луны. Планеты: Генерация поверхности планет. Камера: Некоторые типы камер, например, орбитальная камера, могут использовать сферические координаты для определения своего положения. Направленные источники света: Удобно задавать направление света в сферических координатах. 2. Однородные координаты – определение и пример. Переход в декартову систему координат. Определение: Однородные координаты — это система координат, в которой к стандартным координатам (например, декартовым) добавляется еще одна координата. Для трехмерного пространства точка в однородных координатах представляется четверкой чисел (x, y, z, w), где w — однородная координата (часто называется "весовой"). Пример: Точка (2, 3, 4) в декартовых координатах в однородных координатах может быть представлена как (2, 3, 4, 1) или (4, 6, 8, 2), или (-2, -3, -4, -1) - вариантов бесконечно много. Переход в декартову систему: Чтобы получить декартовы координаты из однородных, нужно разделить первые три координаты на четвертую (w): (x, y, z, w) -> (x/w, y/w, z/w) Например, (4, 6, 8, 2) -> (4/2, 6/2, 8/2) = (2, 3, 4). Если w равно 0, то это точка на бесконечности. 3. Различие между точками и векторами с математической точки зрения и с точки зрения разработчика игр. Сложение и вычитание точек и направлений Математическое различие: o Точка: Определяет положение в пространстве. o Вектор: Определяет направление и величину (длину). Вектор не имеет фиксированного положения, только направление и длину. Различие с точки зрения разработчика игр: o Точка: Представляется как набор координат (x, y, z), который указывает конкретное место в игровом мире. o Вектор: Также представляется как набор координат (x, y, z), но интерпретируется как смещение или направление. Часто используется для представления скорости, направления движения, сил. Сложение и вычитание: o Вектор + Вектор = Вектор: Сложение векторов происходит покомпонентно и дает новый вектор. o Вектор - Вектор = Вектор: Вычитание векторов также происходит покомпонентно и дает новый вектор. o Точка + Вектор = Точка: Прибавление вектора к точке перемещает точку в направлении вектора на расстояние, равное длине вектора. o Точка - Точка = Вектор: Результатом вычитания двух точек является вектор, направленный от второй точки к первой, с длиной, равной расстоянию между точками. o Точка + Точка: Не имеет смысла. 4. Рассмотрите задачу проверки пересечения двух сфер. Используйте операции вычитания векторов, масштабирования длин векторов и сравнения чисел с плавающей точкой. Пусть есть две сферы с центрами C1 и C2 и радиусами R1 и R2 соответственно. 1. Вычитание векторов: Находим вектор D, соединяющий центры сфер: D = C2 - C1. 2. Находим длину вектора: Вычисляем длину вектора D: |D| = sqrt(D.x² + D.y² + D.z²). Это расстояние между центрами сфер. 3. Сравнение: Сферы пересекаются, если расстояние между центрами меньше или равно сумме их радиусов: |D|