Формализмы вращения в трех измерениях

Способы представления 3D-вращений

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

Согласно теореме Эйлера о вращении , вращение твердого тела (или трехмерной системы координат с фиксированным началом ) описывается одним вращением вокруг некоторой оси. Такое вращение может быть однозначно описано минимум тремя действительными параметрами. Однако по разным причинам существует несколько способов его представления. Многие из этих представлений используют больше необходимого минимума в три параметра, хотя каждый из них по-прежнему имеет только три степени свободы .

Примером использования представления вращения является компьютерное зрение , где автоматизированному наблюдателю необходимо отслеживать цель. Рассмотрим твердое тело с тремя ортогональными единичными векторами, закрепленными на его теле (представляющими три оси локальной системы координат объекта ). Основная проблема заключается в указании ориентации этих трех единичных векторов , а следовательно, и твердого тела, относительно системы координат наблюдателя, рассматриваемой как опорное размещение в пространстве.

Вращения и движения

Формализмы вращения сосредоточены на собственных ( сохраняющих ориентацию ) движениях евклидова пространства с одной неподвижной точкой , к которой относится вращение . Хотя физические движения с неподвижной точкой являются важным случаем (например, описанные в системе центра масс или движения сустава ) , этот подход создает знание обо всех движениях. Любое собственное движение евклидова пространства разлагается на вращение вокруг начала координат и перенос . Каким бы ни был порядок их композиции , «чистая» компонента вращения не изменится, однозначно определяемая полным движением.

Можно также понимать «чистые» вращения как линейные отображения в векторном пространстве, снабженном евклидовой структурой, а не как отображения точек соответствующего аффинного пространства . Другими словами, формализм вращения охватывает только вращательную часть движения, которая содержит три степени свободы, и игнорирует трансляционную часть, которая содержит еще три.

При представлении вращения в виде чисел на компьютере некоторые люди предпочитают представление кватерниона или представление оси+угла, поскольку они позволяют избежать карданного захвата , который может возникнуть при вращениях Эйлера. [1]

Альтернативы формализма

Матрица вращения

Вышеупомянутая триада единичных векторов также называется базисом . Указание координат ( компонент ) векторов этого базиса в его текущем (повернутом) положении в терминах опорных (неповернутых) осей координат полностью опишет поворот. Три единичных вектора, û , и ŵ , которые образуют повернутый базис, состоят каждый из 3 координат, что дает в общей сложности 9 параметров.

Эти параметры можно записать как элементы матрицы A размером 3 × 3 , называемой матрицей вращения . Обычно координаты каждого из этих векторов располагаются вдоль столбца матрицы (однако следует помнить, что существует и широко используется альтернативное определение матрицы вращения, в котором координаты векторов, определенные выше, располагаются по строкам [2] ). А = [ ты ^ х в ^ х ж ^ х ты ^ у в ^ у ж ^ у ты ^ з в ^ з ж ^ з ] {\displaystyle \mathbf {A} = {\begin{bmatrix}{\hat {\mathbf {u} }}_{x} & {\hat {\mathbf {v} }}_{x} & {\hat {\mathbf {w} }}_{x}\\{\hat {\mathbf {u} }}_{y} & {\hat {\mathbf {v} }}_{y} & {\hat { \mathbf {w} }}_{y}\\{\hat {\mathbf {u} }}_{z} & {\hat {\mathbf {v} }}_{z} & {\hat {\ mathbf {w} }}_{z}\\\end{bmatrix}}}

Не все элементы матрицы вращения независимы — как гласит теорема Эйлера о вращении, матрица вращения имеет только три степени свободы.

Матрица вращения имеет следующие свойства:

  • A — действительная ортогональная матрица , поэтому каждая ее строка или столбец представляет собой единичный вектор .
  • Собственные значения матрицы A равны , где i — стандартная мнимая единица со свойством i 2 = −1 { 1 , е ± я θ } = { 1 ,   потому что θ + я грех θ ,   потому что θ я грех θ } {\displaystyle \left\{1,e^{\pm i\theta }\right\}=\{1,\ \cos \theta +i\sin \theta ,\ \cos \theta -i\sin \theta \}}
  • Определитель матрицы А равен +1, что эквивалентно произведению ее собственных значений .
  • След A равен 1 + 2 cos θ , что эквивалентно сумме его собственных значений.

Угол θ , который появляется в выражении собственного значения, соответствует углу оси Эйлера и представлению угла. Собственный вектор, соответствующий собственному значению 1, является сопутствующей осью Эйлера, поскольку ось является единственным (ненулевым) вектором, который остается неизменным при умножении слева (повороте) на матрицу поворота.

Вышеуказанные свойства эквивалентны , что является другим способом утверждения, что ( û , , ŵ ) образуют 3D ортонормированный базис . Эти утверждения включают в общей сложности 6 условий (в перекрестном произведении их 3), оставляя матрицу вращения всего с 3 степенями свободы, как и требуется. | ты ^ | = | в ^ | = | ж ^ | = 1 ты ^ в ^ = 0 ты ^ × в ^ = ж ^ , {\displaystyle {\begin{aligned}|{\hat {\mathbf {u} }}|=|{\hat {\mathbf {v} }}|=|{\hat {\mathbf {w} }}| &=1\\{\hat {\mathbf {u} }}\cdot {\hat {\mathbf {v} }}&=0\\{\hat {\mathbf {u} }}\times {\hat {\mathbf {v} }}&={\hat {\mathbf {w} }}\,,\end{aligned}}}

Два последовательных поворота, представленных матрицами A 1 и A 2, легко объединяются как элементы группы (обратите внимание на порядок, поскольку вектор, который поворачивается, умножается справа). А общий = А 2 А 1 {\displaystyle \mathbf {A} _{\text{total}}=\mathbf {A} _{2}\mathbf {A} _{1}}

Легкость, с которой векторы можно вращать с помощью матрицы вращения, а также простота объединения последовательных вращений делают матрицу вращения полезным и популярным способом представления вращений, хотя она и менее лаконична, чем другие представления.

Ось Эйлера и угол (вектор вращения)

Визуализация вращения, представленного осью Эйлера и углом.

Из теоремы Эйлера о вращении мы знаем, что любое вращение можно выразить как одиночное вращение вокруг некоторой оси. Ось — это единичный вектор (уникальный, за исключением знака), который остается неизменным при вращении. Величина угла также уникальна, а ее знак определяется знаком оси вращения.

Ось можно представить как трехмерный единичный вектор , а угол — как скаляр θ . е ^ = [ е х е у е з ] {\displaystyle {\hat {\mathbf {e} }}={\begin{bmatrix}e_{x}\\e_{y}\\e_{z}\end{bmatrix}}}

Поскольку ось нормализована, она имеет только две степени свободы . Угол добавляет третью степень свободы к этому представлению вращения.

Можно выразить вращение как вектор вращения , или вектор Эйлера , ненормализованный трехмерный вектор, направление которого определяет ось, а длина которого равна θ , г = θ е ^ . {\displaystyle \mathbf {r} =\theta {\hat {\mathbf {e} }}\,.}

Вектор вращения полезен в некоторых контекстах, поскольку он представляет трехмерное вращение только с тремя скалярными значениями (его компонентами), представляющими три степени свободы. Это также верно для представлений, основанных на последовательностях трех углов Эйлера (см. ниже).

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

Повороты Эйлера

Эйлеровы вращения Земли. Внутреннее (зеленый), прецессия (синий) и нутация (красный)

Идея вращений Эйлера заключается в том, чтобы разделить полное вращение системы координат на три более простых конститутивных вращения, называемых прецессией , нутацией и внутренним вращением , каждое из которых является приращением одного из углов Эйлера . Обратите внимание, что внешняя матрица будет представлять вращение вокруг одной из осей системы отсчета, а внутренняя матрица представляет вращение вокруг одной из осей подвижной системы отсчета. Средняя матрица представляет вращение вокруг промежуточной оси, называемой линией узлов .

Однако определение углов Эйлера не является единственным, и в литературе используется много различных соглашений. Эти соглашения зависят от осей, вокруг которых выполняются вращения, и их последовательности (поскольку вращения на сфере некоммутативны ) .

Используемое соглашение обычно указывается путем указания осей, вокруг которых происходят последовательные вращения (до их составления), ссылаясь на них индексом (1, 2, 3) или буквой (X, Y, Z) . Инженерные и робототехнические сообщества обычно используют углы Эйлера 3-1-3. Обратите внимание, что после составления независимых вращений они больше не вращаются вокруг своей оси. Самая внешняя матрица вращает другие две, оставляя вторую матрицу вращения над линией узлов, а третью — в кадре, движущемся вместе с телом. Существует 3 × 3 × 3 = 27 возможных комбинаций трех основных вращений, но только 3 × 2 × 2 = 12 из них можно использовать для представления произвольных трехмерных вращений в виде углов Эйлера. Эти 12 комбинаций избегают последовательных вращений вокруг одной и той же оси (например, XXY), что уменьшило бы степени свободы, которые могут быть представлены.

Поэтому углы Эйлера никогда не выражаются в терминах внешней системы отсчета или в терминах сопутствующей вращающейся системы отсчета тела, а в смеси. Другие соглашения (например, матрица вращения или кватернионы ) используются для того, чтобы избежать этой проблемы.

В авиации ориентация самолета обычно выражается в виде внутренних углов Тейта-Брайена , следующих за соглашением z - y ′- x , которые называются курсом , углом места и креном (или синонимами рысканием , тангажом и креном ).

Кватернионы

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

Кватернионное представление вращения записывается в виде версора (нормализованного кватерниона): д ^ = д я я + д дж дж + д к к + д г = [ д я д дж д к д г ] {\displaystyle {\hat {\mathbf {q} }}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}= {\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}}

Приведенное выше определение сохраняет кватернион как массив, следуя соглашению, используемому в (Wertz 1980) и (Markley 2003). Альтернативное определение, используемое, например, в (Coutsias 1999) и (Schmidt 2001), определяет «скалярный» член как первый элемент кватерниона, а остальные элементы смещены на одну позицию вниз.

В терминах оси Эйлера е ^ = [ е х е у е з ] {\displaystyle {\hat {\mathbf {e} }}={\begin{bmatrix}e_{x}\\e_{y}\\e_{z}\end{bmatrix}}}

и угол θ компоненты этого версора выражаются следующим образом: д я = е х грех θ 2 д дж = е у грех θ 2 д к = е з грех θ 2 д г = потому что θ 2 {\displaystyle {\begin{align}q_{i}&=e_{x}\sin {\frac {\theta }{2}}\\q_{j}&=e_{y}\sin {\frac {\theta }{2}}\\q_{k}&=e_{z}\sin {\frac {\theta }{2}}\\q_{r}&=\cos {\frac {\theta }{2}}\end{align}}}

Проверка показывает, что параметризация кватерниона подчиняется следующему ограничению: д я 2 + д дж 2 + д к 2 + д г 2 = 1 {\displaystyle q_{i}^{2}+q_{j}^{2}+q_{k}^{2}+q_{r}^{2}=1}

Последний член (в нашем определении) часто называют скалярным членом, который берет свое начало в кватернионах, если понимать их как математическое расширение комплексных чисел, записанных как и где { i , j , k }гиперкомплексные числа, удовлетворяющие а + б я + с дж + г к с  а , б , с , г Р {\displaystyle a+bi+cj+dk\qquad {\text{with}}a,b,c,d\in \mathbb {R} } я 2 = дж 2 = к 2 = 1 я дж = дж я = к дж к = к дж = я к я = я к = дж {\displaystyle {\begin{array}{ccccccc}i^{2}&=&j^{2}&=&k^{2}&=&-1\\ij&=&-ji&=&k&&\\jk&=& -kj&=&i&&\\ki&=&-ik&=&j&&\end{array}}}

Умножение кватернионов, которое используется для задания составного вращения, выполняется таким же образом, как умножение комплексных чисел , за исключением того, что порядок элементов должен быть принят во внимание, поскольку умножение не является коммутативным. В матричной нотации мы можем записать умножение кватернионов как д ~ д = [ д г д к д дж д я д к д г д я д дж д дж д я д г д к д я д дж д к д г ] [ д ~ я д ~ дж д ~ к д ~ г ] = [ д ~ г д ~ к д ~ дж д ~ я д ~ к д ~ г д ~ я д ~ дж д ~ дж д ~ я д ~ г д ~ к д ~ я д ~ дж д ~ к д ~ г ] [ д я д дж д к д г ] {\displaystyle {\tilde {\mathbf {q} }}\otimes \mathbf {q} ={\begin{bmatrix}\;\;\,q_{r}&\;\;\,q_{k}&-q_{j}&\;\;\,q_{i}\\-q_{k}&\;\;\,q_{r}&\;\;\,q_{i}&\;\;\,q_{j}\\\;\;\,q_{j}&-q_{i}&\;\;\,q_{r}&\;\;\,q_{k}\\-q_{i}&-q_{j}&-q_{k}&\;\;\,q_{r}\end{bmatrix}}{\begin{bmatrix}{\tilde {q}}_{i}\\{\tilde {q}}_{j}\\{\tilde {q}}_{k}\\{\tilde {q}}_{r}\end{bmatrix}}={\begin{bmatrix}\;\;\,{\tilde {q}}_{r}&-{\tilde {q}}_{k}&\;\;\,{\tilde {q}}_{j}&\;\;\,{\tilde {q}}_{i}\\\;\;\,{\tilde {q}}_{k}&\;\;\,{\tilde {q}}_{r}&-{\tilde {q}}_{i}&\;\;\,{\tilde {q}}_{j}\\-{\tilde {q}}_{j}&\;\;\,{\tilde {q}}_{i}&\;\;\,{\tilde {q}}_{r}&\;\;\,{\tilde {q}}_{k}\\-{\tilde {q}}_{i}&-{\tilde {q}}_{j}&-{\tilde {q}}_{k}&\;\;\,{\tilde {q}}_{r}\end{bmatrix}}{\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}}

Объединение двух последовательных кватернионных вращений, таким образом, так же просто, как использование матрицы вращения. Так же, как объединяются две последовательные матрицы вращения, A 1 , за которыми следует A 2 , мы можем представить это с помощью параметров кватерниона аналогичным лаконичным способом: A 3 = A 2 A 1 , {\displaystyle \mathbf {A} _{3}=\mathbf {A} _{2}\mathbf {A} _{1},} q 3 = q 2 q 1 {\displaystyle \mathbf {q} _{3}=\mathbf {q} _{2}\otimes \mathbf {q} _{1}}

Кватернионы являются очень популярной параметризацией благодаря следующим свойствам:

  • Более компактно, чем матричное представление, и менее подвержено ошибкам округления.
  • Элементы кватерниона непрерывно изменяются по единичной сфере в 4 (обозначается как S 3 ) по мере изменения ориентации, избегая прерывистых скачков (присущих трехмерным параметризациям)
  • Выражение матрицы вращения через параметры кватерниона не содержит тригонометрических функций.
  • Легко объединить два отдельных вращения, представленных в виде кватернионов, используя кватернионное произведение.

Как и матрицы вращения, кватернионы иногда должны быть перенормированы из-за ошибок округления, чтобы убедиться, что они соответствуют допустимым вращениям. Однако вычислительные затраты на перенормировку кватерниона намного меньше, чем на нормализацию матрицы 3 × 3 .

Кватернионы также отражают спинорный характер вращений в трех измерениях. Для трехмерного объекта, связанного с его (фиксированным) окружением слабыми струнами или полосами, струны или полосы могут быть распутаны после двух полных оборотов вокруг некоторой фиксированной оси из начального распутанного состояния. Алгебраически кватернион, описывающий такое вращение, изменяется от скаляра +1 (изначально), через (скаляр + псевдовектор) значения до скаляра −1 (за один полный оборот), через (скаляр + псевдовектор) значения обратно до скаляра +1 (за два полных оборота). Этот цикл повторяется каждые 2 оборота. После 2 n оборотов (целое число n > 0 ), без каких-либо промежуточных попыток распутывания, струны/полосы могут быть частично распутаны обратно в состояние 2( n − 1) оборотов с каждым применением той же процедуры, которая использовалась при распутывании от 2 оборотов до 0 оборотов. Применение той же процедуры n раз вернет 2 n -запутанный объект обратно в распутанное или 0-оборотное состояние. Процесс распутывания также удаляет любое скручивание, вызванное вращением вокруг самих струн/лент. Для демонстрации этих фактов можно использовать простые 3D-механические модели.

Вектор Родригеса

Вектор Родригеса (иногда называемый вектором Гиббса , с координатами, называемыми параметрами Родригеса ) [3] [4] можно выразить через ось и угол поворота следующим образом: g = e ^ tan θ 2 {\displaystyle \mathbf {g} ={\hat {\mathbf {e} }}\tan {\frac {\theta }{2}}}

Это представление является многомерным аналогом гномонической проекции , отображающей единичные кватернионы из 3-мерной сферы на 3-мерную чисто векторную гиперплоскость.

Он имеет разрыв при 180° ( π радиан): поскольку любой вектор вращения r стремится к углу π радиан, его тангенс стремится к бесконечности.

Вращение g, за которым следует вращение f в представлении Родригеса, имеет простую форму композиции вращений

( g , f ) = g + f f × g 1 g f . {\displaystyle (\mathbf {g} ,\mathbf {f} )={\frac {\mathbf {g} +\mathbf {f} -\mathbf {f} \times \mathbf {g} }{1-\mathbf {g} \cdot \mathbf {f} }}\,.}

Сегодня наиболее простым способом доказательства этой формулы является ее (точное) дублетное представление , где g = tan a и т. д.

Комбинаторные особенности вывода матрицы Паули, упомянутые выше, также идентичны эквивалентному выводу кватерниона ниже. Постройте кватернион, связанный с пространственным вращением R , как, Тогда композиция вращения R B с R A представляет собой вращение R C = R B R A , с осью вращения и углом, определяемыми произведением кватернионов, то есть S = cos ϕ 2 + sin ϕ 2 S . {\displaystyle S=\cos {\frac {\phi }{2}}+\sin {\frac {\phi }{2}}\mathbf {S} .} A = cos α 2 + sin α 2 A and B = cos β 2 + sin β 2 B , {\displaystyle A=\cos {\frac {\alpha }{2}}+\sin {\frac {\alpha }{2}}\mathbf {A} \quad {\text{and}}\quad B=\cos {\frac {\beta }{2}}+\sin {\frac {\beta }{2}}\mathbf {B} ,} C = cos γ 2 + sin γ 2 C = ( cos β 2 + sin β 2 B ) ( cos α 2 + sin α 2 A ) . {\displaystyle C=\cos {\frac {\gamma }{2}}+\sin {\frac {\gamma }{2}}\mathbf {C} =\left(\cos {\frac {\beta }{2}}+\sin {\frac {\beta }{2}}\mathbf {B} \right)\left(\cos {\frac {\alpha }{2}}+\sin {\frac {\alpha }{2}}\mathbf {A} \right).}

Разверните это кватернионное произведение до cos γ 2 + sin γ 2 C = ( cos β 2 cos α 2 sin β 2 sin α 2 B A ) + ( sin β 2 cos α 2 B + sin α 2 cos β 2 A + sin β 2 sin α 2 B × A ) . {\displaystyle \cos {\frac {\gamma }{2}}+\sin {\frac {\gamma }{2}}\mathbf {C} =\left(\cos {\frac {\beta }{2}}\cos {\frac {\alpha }{2}}-\sin {\frac {\beta }{2}}\sin {\frac {\alpha }{2}}\mathbf {B} \cdot \mathbf {A} \right)+\left(\sin {\frac {\beta }{2}}\cos {\frac {\alpha }{2}}\mathbf {B} +\sin {\frac {\alpha }{2}}\cos {\frac {\beta }{2}}\mathbf {A} +\sin {\frac {\beta }{2}}\sin {\frac {\alpha }{2}}\mathbf {B} \times \mathbf {A} \right).}

Разделите обе части этого уравнения на тождество, полученное из предыдущего, и оцените cos γ 2 = cos β 2 cos α 2 sin β 2 sin α 2 B A , {\displaystyle \cos {\frac {\gamma }{2}}=\cos {\frac {\beta }{2}}\cos {\frac {\alpha }{2}}-\sin {\frac {\beta }{2}}\sin {\frac {\alpha }{2}}\mathbf {B} \cdot \mathbf {A} ,}

tan γ 2 C = tan β 2 B + tan α 2 A + tan β 2 tan α 2 B × A 1 tan β 2 tan α 2 B A . {\displaystyle \tan {\frac {\gamma }{2}}\mathbf {C} ={\frac {\tan {\frac {\beta }{2}}\mathbf {B} +\tan {\frac {\alpha }{2}}\mathbf {A} +\tan {\frac {\beta }{2}}\tan {\frac {\alpha }{2}}\mathbf {B} \times \mathbf {A} }{1-\tan {\frac {\beta }{2}}\tan {\frac {\alpha }{2}}\mathbf {B} \cdot \mathbf {A} }}.}

Это формула Родригеса для оси составного вращения, определяемой через оси двух компонентных вращений. Он вывел эту формулу в 1840 году (см. стр. 408). [3] Три оси вращения A , B и C образуют сферический треугольник, а двугранные углы между плоскостями, образованными сторонами этого треугольника, определяются углами вращения.

Модифицированные параметры Родригеса (MRP) могут быть выражены через ось Эйлера и угол: Его компоненты могут быть выражены через компоненты единичного кватерниона, представляющего то же вращение, что и p = e ^ tan θ 4 . {\displaystyle \mathbf {p} ={\hat {\mathbf {e} }}\tan {\frac {\theta }{4}}\,.} p x , y , z = q i , j , k 1 + q r . {\displaystyle p_{x,y,z}={\frac {q_{i,j,k}}{1+q_{r}}}\,.}

Модифицированный вектор Родригеса — это стереографическая проекция, отображающая единичные кватернионы из 3-сферы на 3-мерную чисто векторную гиперплоскость. Проекция противоположного кватерниона q приводит к другому модифицированному вектору Родригеса p s , чем проекция исходного кватерниона q . Сравнивая компоненты, получаем, что Примечательно, что если один из этих векторов лежит внутри единичной 3-сферы, другой будет лежать снаружи. p x , y , z s = q i , j , k 1 q r = p x , y , z p 2 . {\displaystyle p_{x,y,z}^{s}={\frac {-q_{i,j,k}}{1-q_{r}}}={\frac {-p_{x,y,z}}{\mathbf {p} ^{2}}}\,.}

Параметры Кэли–Клейна

См. определение на сайте Wolfram Mathworld.

Аналоги более высоких измерений

Закон преобразования вектора

Активные вращения трехмерного вектора p в евклидовом пространстве вокруг оси n на угол η можно легко записать в терминах скалярных и векторных произведений следующим образом:

p = p n + cos η p + sin η p n {\displaystyle \mathbf {p} '=p_{\parallel }\mathbf {n} +\cos {\eta }\,\mathbf {p} _{\perp }+\sin {\eta }\,\mathbf {p} \wedge \mathbf {n} } где — продольная составляющая p вдоль n , заданная скалярным произведением , — поперечная составляющая p относительно n , и p = p n {\displaystyle p_{\parallel }=\mathbf {p} \cdot \mathbf {n} } p = p ( p n ) n {\displaystyle \mathbf {p} _{\perp }=\mathbf {p} -(\mathbf {p} \cdot \mathbf {n} )\mathbf {n} } p n {\displaystyle \mathbf {p} \wedge \mathbf {n} }

является перекрестным произведением p и n .

Вышеприведенная формула показывает, что продольный компонент p остается неизменным, тогда как поперечная часть p вращается в плоскости, перпендикулярной n . Эта плоскость охватывается самой поперечной частью p и направлением, перпендикулярным как p , так и n . Вращение непосредственно идентифицируется в уравнении как двумерное вращение на угол η .

Пассивные вращения можно описать той же формулой, но с обратным знаком η или n .

Формулы преобразования между формализмами

Матрица вращения ↔ Углы Эйлера

Углы Эйлера ( φ , θ , ψ ) можно извлечь из матрицы вращения A, проверив матрицу вращения в аналитической форме.

Матрица вращения → Углы Эйлера (з - х - звнешний)

Используя x -соглашение, 3-1-3 внешних угла Эйлера φ , θ и ψ (вокруг оси z , оси x и снова оси θ) можно получить следующим образом: Z {\displaystyle Z} ϕ = atan2 ( A 31 , A 32 ) θ = arccos ( A 33 ) ψ = atan2 ( A 13 , A 23 ) {\displaystyle {\begin{aligned}\phi &=\operatorname {atan2} \left(A_{31},A_{32}\right)\\\theta &=\arccos \left(A_{33}\right)\\\psi &=-\operatorname {atan2} \left(A_{13},A_{23}\right)\end{aligned}}}

Обратите внимание, что atan2( a , b ) эквивалентно arctan а/б где также учитывается квадрант , в котором находитсяточка ( b , a ) ; см. atan2 .

При осуществлении преобразования необходимо учитывать несколько ситуаций: [5]

  • Обычно существует два решения в интервале [− π , π ] 3. Приведенная выше формула работает только тогда, когда θ находится в интервале [0, π ] .
  • Для особого случая A 33 = 0 , φ и ψ будут получены из A 11 и A 12 .
  • Существует бесконечно много, но счетно много решений вне интервала [− π , π ] 3 .
  • Применимость всех математических решений для конкретного приложения зависит от ситуации.

Углы Эйлера (z - y ′- xвнутренняя) → матрица вращения

Матрица вращения A генерируется из внутренних углов Эйлера 3-2-1 путем умножения трех матриц, генерируемых вращениями вокруг осей. A = A 3 A 2 A 1 = A Z A Y A X {\displaystyle \mathbf {A} =\mathbf {A} _{3}\mathbf {A} _{2}\mathbf {A} _{1}=\mathbf {A} _{Z}\mathbf {A} _{Y}\mathbf {A} _{X}}

Оси вращения зависят от конкретной используемой конвенции. Для конвенции x вращения происходят вокруг осей x , y и z с углами ϕ , θ и ψ , отдельные матрицы следующие: A X = [ 1 0 0 0 cos ϕ sin ϕ 0 sin ϕ cos ϕ ] A Y = [ cos θ 0 sin θ 0 1 0 sin θ 0 cos θ ] A Z = [ cos ψ sin ψ 0 sin ψ cos ψ 0 0 0 1 ] {\displaystyle {\begin{aligned}\mathbf {A} _{X}&={\begin{bmatrix}1&0&0\\0&\cos \phi &-\sin \phi \\0&\sin \phi &\cos \phi \end{bmatrix}}\\[5px]\mathbf {A} _{Y}&={\begin{bmatrix}\cos \theta &0&\sin \theta \\0&1&0\\-\sin \theta &0&\cos \theta \end{bmatrix}}\\[5px]\mathbf {A} _{Z}&={\begin{bmatrix}\cos \psi &-\sin \psi &0\\\sin \psi &\cos \psi &0\\0&0&1\end{bmatrix}}\end{aligned}}}

Это дает Примечание: Это справедливо для правосторонней системы, которая является соглашением, используемым почти во всех инженерных и физических дисциплинах. A = [ cos θ cos ψ cos ϕ sin ψ + sin ϕ sin θ cos ψ sin ϕ sin ψ + cos ϕ sin θ cos ψ cos θ sin ψ cos ϕ cos ψ + sin ϕ sin θ sin ψ sin ϕ cos ψ + cos ϕ sin θ sin ψ sin θ sin ϕ cos θ cos ϕ cos θ ] {\displaystyle \mathbf {A} ={\begin{bmatrix}\cos \theta \cos \psi &-\cos \phi \sin \psi +\sin \phi \sin \theta \cos \psi &\sin \phi \sin \psi +\cos \phi \sin \theta \cos \psi \\\cos \theta \sin \psi &\cos \phi \cos \psi +\sin \phi \sin \theta \sin \psi &-\sin \phi \cos \psi +\cos \phi \sin \theta \sin \psi \\-\sin \theta &\sin \phi \cos \theta &\cos \phi \cos \theta \\\end{bmatrix}}}

Интерпретация этих правосторонних матриц вращения заключается в том, что они выражают преобразования координат ( пассивные ) в отличие от преобразований точек ( активные ). Поскольку A выражает вращение из локального кадра 1 в глобальный кадр 0 (т. е. A кодирует оси кадра 1 относительно кадра 0 ), элементарные матрицы вращения составляются так, как указано выше. Поскольку обратное вращение — это просто транспонированное вращение, если бы мы хотели глобально-локальное вращение из кадра 0 в кадр 1 , мы бы написали A T = ( A Z A Y A X ) T = A X T A Y T A Z T . {\displaystyle \mathbf {A} ^{\mathsf {T}}=(\mathbf {A} _{Z}\mathbf {A} _{Y}\mathbf {A} _{X})^{\mathsf {T}}=\mathbf {A} _{X}^{\mathsf {T}}\mathbf {A} _{Y}^{\mathsf {T}}\mathbf {A} _{Z}^{\mathsf {T}}\,.}

Матрица вращения ↔ Ось/угол Эйлера

Если угол Эйлера θ не кратен π , ось Эйлера ê и угол θ можно вычислить из элементов матрицы вращения A следующим образом: θ = arccos A 11 + A 22 + A 33 1 2 e 1 = A 32 A 23 2 sin θ e 2 = A 13 A 31 2 sin θ e 3 = A 21 A 12 2 sin θ {\displaystyle {\begin{aligned}\theta &=\arccos {\frac {A_{11}+A_{22}+A_{33}-1}{2}}\\e_{1}&={\frac {A_{32}-A_{23}}{2\sin \theta }}\\e_{2}&={\frac {A_{13}-A_{31}}{2\sin \theta }}\\e_{3}&={\frac {A_{21}-A_{12}}{2\sin \theta }}\end{aligned}}}

В качестве альтернативы можно использовать следующий метод:

Разложение матрицы вращения по собственным значениям дает собственные значения 1 и cos θ ± i sin θ . Ось Эйлера — это собственный вектор, соответствующий собственному значению 1, а θ можно вычислить из оставшихся собственных значений.

Ось Эйлера также можно найти с помощью сингулярного разложения , поскольку это нормализованный вектор, охватывающий нулевое пространство матрицы IA.

Для преобразования в другую сторону матрицу вращения, соответствующую оси Эйлера ê и углу θ, можно вычислить по формуле вращения Родригеса (с соответствующей модификацией) следующим образом: A = I 3 cos θ + ( 1 cos θ ) e ^ e ^ T + [ e ^ ] × sin θ {\displaystyle \mathbf {A} =\mathbf {I} _{3}\cos \theta +(1-\cos \theta ){\hat {\mathbf {e} }}{\hat {\mathbf {e} }}^{\mathsf {T}}+\left[{\hat {\mathbf {e} }}\right]_{\times }\sin \theta }

где I 3 — единичная матрица 3 × 3 , и [ e ^ ] × = [ 0 e 3 e 2 e 3 0 e 1 e 2 e 1 0 ] {\displaystyle \left[{\hat {\mathbf {e} }}\right]_{\times }={\begin{bmatrix}0&-e_{3}&e_{2}\\e_{3}&0&-e_{1}\\-e_{2}&e_{1}&0\end{bmatrix}}}

— это матрица перекрестного произведения .

Это расширяется до: A 11 = ( 1 cos θ ) e 1 2 + cos θ A 12 = ( 1 cos θ ) e 1 e 2 e 3 sin θ A 13 = ( 1 cos θ ) e 1 e 3 + e 2 sin θ A 21 = ( 1 cos θ ) e 2 e 1 + e 3 sin θ A 22 = ( 1 cos θ ) e 2 2 + cos θ A 23 = ( 1 cos θ ) e 2 e 3 e 1 sin θ A 31 = ( 1 cos θ ) e 3 e 1 e 2 sin θ A 32 = ( 1 cos θ ) e 3 e 2 + e 1 sin θ A 33 = ( 1 cos θ ) e 3 2 + cos θ {\displaystyle {\begin{aligned}A_{11}&=(1-\cos \theta )e_{1}^{2}+\cos \theta \\A_{12}&=(1-\cos \theta )e_{1}e_{2}-e_{3}\sin \theta \\A_{13}&=(1-\cos \theta )e_{1}e_{3}+e_{2}\sin \theta \\A_{21}&=(1-\cos \theta )e_{2}e_{1}+e_{3}\sin \theta \\A_{22}&=(1-\cos \theta )e_{2}^{2}+\cos \theta \\A_{23}&=(1-\cos \theta )e_{2}e_{3}-e_{1}\sin \theta \\A_{31}&=(1-\cos \theta )e_{3}e_{1}-e_{2}\sin \theta \\A_{32}&=(1-\cos \theta )e_{3}e_{2}+e_{1}\sin \theta \\A_{33}&=(1-\cos \theta )e_{3}^{2}+\cos \theta \end{aligned}}}

Матрица вращения ↔ кватернион

При вычислении кватерниона из матрицы вращения возникает неоднозначность знака, поскольку q и q представляют одно и то же вращение.

Один из способов вычисления кватерниона из матрицы вращения A заключается в следующем: q = [ q i q j q k q r ] = q i i + q j j + q k k + q r {\displaystyle \mathbf {q} ={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}} q r = 1 2 1 + A 11 + A 22 + A 33 q i = 1 4 q r ( A 32 A 23 ) q j = 1 4 q r ( A 13 A 31 ) q k = 1 4 q r ( A 21 A 12 ) {\displaystyle {\begin{aligned}q_{r}&={\frac {1}{2}}{\sqrt {1+A_{11}+A_{22}+A_{33}}}\\q_{i}&={\frac {1}{4q_{r}}}\left(A_{32}-A_{23}\right)\\q_{j}&={\frac {1}{4q_{r}}}\left(A_{13}-A_{31}\right)\\q_{k}&={\frac {1}{4q_{r}}}\left(A_{21}-A_{12}\right)\end{aligned}}}

Есть три других математически эквивалентных способа вычисления q . Числовая неточность может быть уменьшена, если избегать ситуаций, в которых знаменатель близок к нулю. Один из трех других методов выглядит следующим образом: [6] [7] q i = 1 2 1 + A 11 A 22 A 33 q j = 1 4 q i ( A 12 + A 21 ) q k = 1 4 q i ( A 13 + A 31 ) q r = 1 4 q i ( A 32 A 23 ) {\displaystyle {\begin{aligned}q_{i}&={\frac {1}{2}}{\sqrt {1+A_{11}-A_{22}-A_{33}}}\\q_{j}&={\frac {1}{4q_{i}}}\left(A_{12}+A_{21}\right)\\q_{k}&={\frac {1}{4q_{i}}}\left(A_{13}+A_{31}\right)\\q_{r}&={\frac {1}{4q_{i}}}\left(A_{32}-A_{23}\right)\end{aligned}}}

Матрица вращения, соответствующая кватерниону q, может быть вычислена следующим образом: где что дает A = ( q r 2 q ˇ T q ˇ ) I 3 + 2 q ˇ q ˇ T + 2 q r Q {\displaystyle \mathbf {A} =\left(q_{r}^{2}-{\check {\mathbf {q} }}^{\mathsf {T}}{\check {\mathbf {q} }}\right)\mathbf {I} _{3}+2{\check {\mathbf {q} }}{\check {\mathbf {q} }}^{\mathsf {T}}+2q_{r}\mathbf {\mathcal {Q}} } q ˇ = [ q i q j q k ] , Q = [ 0 q k q j q k 0 q i q j q i 0 ] {\displaystyle {\check {\mathbf {q} }}={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\end{bmatrix}}\,,\quad \mathbf {\mathcal {Q}} ={\begin{bmatrix}0&-q_{k}&q_{j}\\q_{k}&0&-q_{i}\\-q_{j}&q_{i}&0\end{bmatrix}}} A = [ 1 2 q j 2 2 q k 2 2 ( q i q j q k q r ) 2 ( q i q k + q j q r ) 2 ( q i q j + q k q r ) 1 2 q i 2 2 q k 2 2 ( q j q k q i q r ) 2 ( q i q k q j q r ) 2 ( q j q k + q i q r ) 1 2 q i 2 2 q j 2 ] {\displaystyle \mathbf {A} ={\begin{bmatrix}1-2q_{j}^{2}-2q_{k}^{2}&2\left(q_{i}q_{j}-q_{k}q_{r}\right)&2\left(q_{i}q_{k}+q_{j}q_{r}\right)\\2\left(q_{i}q_{j}+q_{k}q_{r}\right)&1-2q_{i}^{2}-2q_{k}^{2}&2\left(q_{j}q_{k}-q_{i}q_{r}\right)\\2\left(q_{i}q_{k}-q_{j}q_{r}\right)&2\left(q_{j}q_{k}+q_{i}q_{r}\right)&1-2q_{i}^{2}-2q_{j}^{2}\end{bmatrix}}}

или эквивалентно A = [ 1 + 2 q i 2 + 2 q r 2 2 ( q i q j q k q r ) 2 ( q i q k + q j q r ) 2 ( q i q j + q k q r ) 1 + 2 q j 2 + 2 q r 2 2 ( q j q k q i q r ) 2 ( q i q k q j q r ) 2 ( q j q k + q i q r ) 1 + 2 q k 2 + 2 q r 2 ] {\displaystyle \mathbf {A} ={\begin{bmatrix}-1+2q_{i}^{2}+2q_{r}^{2}&2\left(q_{i}q_{j}-q_{k}q_{r}\right)&2\left(q_{i}q_{k}+q_{j}q_{r}\right)\\2\left(q_{i}q_{j}+q_{k}q_{r}\right)&-1+2q_{j}^{2}+2q_{r}^{2}&2\left(q_{j}q_{k}-q_{i}q_{r}\right)\\2\left(q_{i}q_{k}-q_{j}q_{r}\right)&2\left(q_{j}q_{k}+q_{i}q_{r}\right)&-1+2q_{k}^{2}+2q_{r}^{2}\end{bmatrix}}}

Это называется формулой Эйлера–Родрига для матрицы преобразования A {\displaystyle \mathbf {A} }

Углы Эйлера ↔ кватернион

Углы Эйлера (з - х - звнешний) → кватернион

Мы рассмотрим x -соглашение 3-1-3 внешних углов Эйлера для следующего алгоритма. Условия алгоритма зависят от используемого соглашения.

Мы можем вычислить кватернион из углов Эйлера ( ϕ , θ , ψ ) следующим образом: q = [ q i q j q k q r ] = q i i + q j j + q k k + q r {\displaystyle \mathbf {q} ={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}}

q i = cos ϕ ψ 2 sin θ 2 q j = sin ϕ ψ 2 sin θ 2 q k = sin ϕ + ψ 2 cos θ 2 q r = cos ϕ + ψ 2 cos θ 2 {\displaystyle {\begin{aligned}q_{i}&=\cos {\frac {\phi -\psi }{2}}\sin {\frac {\theta }{2}}\\q_{j}&=\sin {\frac {\phi -\psi }{2}}\sin {\frac {\theta }{2}}\\q_{k}&=\sin {\frac {\phi +\psi }{2}}\cos {\frac {\theta }{2}}\\q_{r}&=\cos {\frac {\phi +\psi }{2}}\cos {\frac {\theta }{2}}\end{aligned}}}

Углы Эйлера (z - y ′- xвнутренний) → кватернион

Кватернионный эквивалент углов рыскания ( ψ ), тангажа ( θ ) и крена ( ϕ ) или внутренних углов Тейта-Брайена , следующих соглашению z - y ′- x , может быть вычислен с помощью

q i = sin ϕ 2 cos θ 2 cos ψ 2 cos ϕ 2 sin θ 2 sin ψ 2 q j = cos ϕ 2 sin θ 2 cos ψ 2 + sin ϕ 2 cos θ 2 sin ψ 2 q k = cos ϕ 2 cos θ 2 sin ψ 2 sin ϕ 2 sin θ 2 cos ψ 2 q r = cos ϕ 2 cos θ 2 cos ψ 2 + sin ϕ 2 sin θ 2 sin ψ 2 {\displaystyle {\begin{aligned}q_{i}&=\sin {\frac {\phi }{2}}\cos {\frac {\theta }{2}}\cos {\frac {\psi }{2}}-\cos {\frac {\phi }{2}}\sin {\frac {\theta }{2}}\sin {\frac {\psi }{2}}\\q_{j}&=\cos {\frac {\phi }{2}}\sin {\frac {\theta }{2}}\cos {\frac {\psi }{2}}+\sin {\frac {\phi }{2}}\cos {\frac {\theta }{2}}\sin {\frac {\psi }{2}}\\q_{k}&=\cos {\frac {\phi }{2}}\cos {\frac {\theta }{2}}\sin {\frac {\psi }{2}}-\sin {\frac {\phi }{2}}\sin {\frac {\theta }{2}}\cos {\frac {\psi }{2}}\\q_{r}&=\cos {\frac {\phi }{2}}\cos {\frac {\theta }{2}}\cos {\frac {\psi }{2}}+\sin {\frac {\phi }{2}}\sin {\frac {\theta }{2}}\sin {\frac {\psi }{2}}\end{aligned}}}

Кватернион → Углы Эйлера (з - х - звнешний)

Учитывая кватернион вращения, внешние углы Эйлера 3-1-3 по x -соглашению ( φ , θ , ψ ) можно вычислить следующим образом : q = [ q i q j q k q r ] = q i i + q j j + q k k + q r , {\displaystyle \mathbf {q} ={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}\,,}

ϕ = atan2 ( ( q i q k + q j q r ) , ( q j q k q i q r ) ) θ = arccos ( q i 2 q j 2 + q k 2 + q r 2 ) ψ = atan2 ( ( q i q k q j q r ) , ( q j q k + q i q r ) ) {\displaystyle {\begin{aligned}\phi &=\operatorname {atan2} \left(\left(q_{i}q_{k}+q_{j}q_{r}\right),-\left(q_{j}q_{k}-q_{i}q_{r}\right)\right)\\\theta &=\arccos \left(-q_{i}^{2}-q_{j}^{2}+q_{k}^{2}+q_{r}^{2}\right)\\\psi &=\operatorname {atan2} \left(\left(q_{i}q_{k}-q_{j}q_{r}\right),\left(q_{j}q_{k}+q_{i}q_{r}\right)\right)\end{aligned}}}

Кватернион → Углы Эйлера (z - y ′- xвнутренний)

Учитывая кватернион вращения , углы рыскания , тангажа и крена или внутренние углы Тейта-Брайана , следующие соглашению z - y ′- x , можно вычислить следующим образом: q = [ q i q j q k q r ] = q i i + q j j + q k k + q r , {\displaystyle \mathbf {q} ={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}\,,}

roll = atan2 ( 2 ( q r q i + q j q k ) , 1 2 ( q i 2 + q j 2 ) ) pitch = arcsin ( 2 ( q r q j q k q i ) ) yaw = atan2 ( 2 ( q r q k + q i q j ) , 1 2 ( q j 2 + q k 2 ) ) {\displaystyle {\begin{aligned}{\text{roll}}&=\operatorname {atan2} \left(2\left(q_{r}q_{i}+q_{j}q_{k}\right),1-2\left(q_{i}^{2}+q_{j}^{2}\right)\right)\\{\text{pitch}}&=\arcsin \left(2\left(q_{r}q_{j}-q_{k}q_{i}\right)\right)\\{\text{yaw}}&=\operatorname {atan2} \left(2\left(q_{r}q_{k}+q_{i}q_{j}\right),1-2\left(q_{j}^{2}+q_{k}^{2}\right)\right)\end{aligned}}}

Ось Эйлера–угол ↔ кватернион

Учитывая ось Эйлера ê и угол θ , кватернион q = [ q i q j q k q r ] = q i i + q j j + q k k + q r , {\displaystyle \mathbf {q} ={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\\q_{r}\end{bmatrix}}=q_{i}\mathbf {i} +q_{j}\mathbf {j} +q_{k}\mathbf {k} +q_{r}\,,}

можно вычислить по q i = e ^ 1 sin θ 2 q j = e ^ 2 sin θ 2 q k = e ^ 3 sin θ 2 q r = cos θ 2 {\displaystyle {\begin{aligned}q_{i}&={\hat {e}}_{1}\sin {\frac {\theta }{2}}\\q_{j}&={\hat {e}}_{2}\sin {\frac {\theta }{2}}\\q_{k}&={\hat {e}}_{3}\sin {\frac {\theta }{2}}\\q_{r}&=\cos {\frac {\theta }{2}}\end{aligned}}}

Дано кватернион вращения q , определим Тогда ось Эйлера ê и угол θ можно вычислить следующим образом: q ˇ = [ q i q j q k ] . {\displaystyle {\check {\mathbf {q} }}={\begin{bmatrix}q_{i}\\q_{j}\\q_{k}\end{bmatrix}}\,.} e ^ = q ˇ q ˇ θ = 2 arccos q r {\displaystyle {\begin{aligned}{\hat {\mathbf {e} }}&={\frac {\check {\mathbf {q} }}{\left\|{\check {\mathbf {q} }}\right\|}}\\\theta &=2\arccos q_{r}\end{aligned}}}

Матрица вращения ↔ Вектор Родригеса

Вектор Родригеса → Матрица вращения

Поскольку определение вектора Родригеса можно связать с кватернионами вращения: Используя следующее свойство, формулу можно получить путем разложения q на множители { g i = q i q r = e x tan ( θ 2 ) g j = q j q r = e y tan ( θ 2 ) g k = q k q r = e z tan ( θ 2 ) {\displaystyle {\begin{cases}g_{i}={\dfrac {q_{i}}{q_{r}}}=e_{x}\tan \left({\dfrac {\theta }{2}}\right)\\g_{j}={\dfrac {q_{j}}{q_{r}}}=e_{y}\tan \left({\dfrac {\theta }{2}}\right)\\g_{k}={\dfrac {q_{k}}{q_{r}}}=e_{z}\tan \left({\dfrac {\theta }{2}}\right)\end{cases}}} 1 = q r 2 + q i 2 + q j 2 + q k 2 = q r 2 ( 1 + q i 2 q r 2 + q j 2 q r 2 + q k 2 q r 2 ) = q r 2 ( 1 + g i 2 + g j 2 + g k 2 ) {\displaystyle 1=q_{r}^{2}+q_{i}^{2}+q_{j}^{2}+q_{k}^{2}=q_{r}^{2}\left(1+{\frac {q_{i}^{2}}{q_{r}^{2}}}+{\frac {q_{j}^{2}}{q_{r}^{2}}}+{\frac {q_{k}^{2}}{q_{r}^{2}}}\right)=q_{r}^{2}\left(1+g_{i}^{2}+g_{j}^{2}+g_{k}^{2}\right)} 2
р
из окончательного выражения, полученного для кватернионов:

A = q r 2 [ 1 q r 2 2 q j 2 q r 2 2 q k 2 q r 2 2 ( q i q r q j q r q k q r ) 2 ( q i q r q k q r + q j q r ) 2 ( q i q r q j q r + q k q r ) 1 q r 2 2 q i 2 q r 2 2 q k 2 q r 2 2 ( q j q r q k q r q i q r ) 2 ( q i q r q k q r q j q r ) 2 ( q j q r q k q r + q i q r ) 1 q r 2 2 q i 2 q r 2 2 q j 2 q r 2 ] {\displaystyle \mathbf {A} =q_{r}^{2}{\begin{bmatrix}{\frac {1}{q_{r}^{2}}}-2{\frac {q_{j}^{2}}{q_{r}^{2}}}-2{\frac {q_{k}^{2}}{q_{r}^{2}}}&2\left({\frac {q_{i}}{q_{r}}}{\frac {q_{j}}{q_{r}}}-{\frac {q_{k}}{q_{r}}}\right)&2\left({\frac {q_{i}}{q_{r}}}{\frac {q_{k}}{q_{r}}}+{\frac {q_{j}}{q_{r}}}\right)\\2\left({\frac {q_{i}}{q_{r}}}{\frac {q_{j}}{q_{r}}}+{\frac {q_{k}}{q_{r}}}\right)&{\frac {1}{q_{r}^{2}}}-2{\frac {q_{i}^{2}}{q_{r}^{2}}}-2{\frac {q_{k}^{2}}{q_{r}^{2}}}&2\left({\frac {q_{j}}{q_{r}}}{\frac {q_{k}}{q_{r}}}-{\frac {q_{i}}{q_{r}}}\right)\\2\left({\frac {q_{i}}{q_{r}}}{\frac {q_{k}}{q_{r}}}-{\frac {q_{j}}{q_{r}}}\right)&2\left({\frac {q_{j}}{q_{r}}}{\frac {q_{k}}{q_{r}}}+{\frac {q_{i}}{q_{r}}}\right)&{\frac {1}{q_{r}^{2}}}-2{\frac {q_{i}^{2}}{q_{r}^{2}}}-2{\frac {q_{j}^{2}}{q_{r}^{2}}}\end{bmatrix}}}

Приводим к окончательной формуле:

A = 1 1 + g i 2 + g j 2 + g k 2 [ 1 + g i 2 g j 2 g k 2 2 ( g i g j g k ) 2 ( g i g k + g j ) 2 ( g i g j + g k ) 1 g i 2 + g j 2 g k 2 2 ( g j g k g i ) 2 ( g i g k g j ) 2 ( g j g k + g i ) 1 g i 2 g j 2 + g k 2 ] {\displaystyle \mathbf {A} ={\frac {1}{1+g_{i}^{2}+g_{j}^{2}+g_{k}^{2}}}{\begin{bmatrix}1+g_{i}^{2}-g_{j}^{2}-g_{k}^{2}&2\left(g_{i}g_{j}-g_{k}\right)&2\left(g_{i}g_{k}+g_{j}\right)\\2\left(g_{i}g_{j}+g_{k}\right)&1-g_{i}^{2}+g_{j}^{2}-g_{k}^{2}&2\left(g_{j}g_{k}-g_{i}\right)\\2\left(g_{i}g_{k}-g_{j}\right)&2\left(g_{j}g_{k}+g_{i}\right)&1-g_{i}^{2}-g_{j}^{2}+g_{k}^{2}\end{bmatrix}}}

Формулы преобразования производных

Матрица вращения ↔ угловые скорости

Вектор угловой скорости можно извлечь из производной по времени матрицы вращения ω = [ ω x ω y ω z ] {\displaystyle {\boldsymbol {\omega }}={\begin{bmatrix}\omega _{x}\\\omega _{y}\\\omega _{z}\end{bmatrix}}} д А/д т следующим соотношением: [ ω ] × = [ 0 ω z ω y ω z 0 ω x ω y ω x 0 ] = d A d t A T {\displaystyle [{\boldsymbol {\omega }}]_{\times }={\begin{bmatrix}0&-\omega _{z}&\omega _{y}\\\omega _{z}&0&-\omega _{x}\\-\omega _{y}&\omega _{x}&0\end{bmatrix}}={\frac {\mathrm {d} \mathbf {A} }{\mathrm {d} t}}\mathbf {A} ^{\mathsf {T}}}

Вывод адаптирован из Иоффе [8] следующим образом:

Для любого вектора r 0 рассмотрим r ( t ) = A ( t ) r 0 и продифференцируем его: d r d t = d A d t r 0 = d A d t A T ( t ) r ( t ) {\displaystyle {\frac {\mathrm {d} \mathbf {r} }{\mathrm {d} t}}={\frac {\mathrm {d} \mathbf {A} }{\mathrm {d} t}}\mathbf {r} _{0}={\frac {\mathrm {d} \mathbf {A} }{\mathrm {d} t}}\mathbf {A} ^{\mathsf {T}}(t)\mathrm {r} (t)}

Производная вектора — это линейная скорость его кончика. Поскольку A — матрица вращения, по определению длина r ( t ) всегда равна длине r 0 , и, следовательно, она не меняется со временем. Таким образом, когда r ( t ) вращается, его кончик движется по окружности, а линейная скорость его кончика направлена ​​по касательной к окружности; т. е. всегда перпендикулярна r ( t ) . В этом конкретном случае соотношение между вектором линейной скорости и вектором угловой скорости следующее (см. круговое движение и векторное произведение ). d r d t = ω ( t ) × r ( t ) = [ ω ] × r ( t ) {\displaystyle {\frac {\mathrm {d} \mathbf {r} }{\mathrm {d} t}}={\boldsymbol {\omega }}(t)\times \mathbf {r} (t)=[{\boldsymbol {\omega }}]_{\times }\mathbf {r} (t)}

В силу транзитивности вышеупомянутых уравнений, d A d t A T ( t ) r ( t ) = [ ω ] × r ( t ) {\displaystyle {\frac {\mathrm {d} \mathbf {A} }{\mathrm {d} t}}\mathbf {A} ^{\mathsf {T}}(t)\mathbf {r} (t)=[{\boldsymbol {\omega }}]_{\times }\mathbf {r} (t)}

что подразумевает d A d t A T ( t ) = [ ω ] × {\displaystyle {\frac {\mathrm {d} \mathbf {A} }{\mathrm {d} t}}\mathbf {A} ^{\mathsf {T}}(t)=[{\boldsymbol {\omega }}]_{\times }}

Кватернион ↔ угловые скорости

Вектор угловой скорости можно получить из производной кватерниона ω = [ ω x ω y ω z ] {\displaystyle {\boldsymbol {\omega }}={\begin{bmatrix}\omega _{x}\\\omega _{y}\\\omega _{z}\end{bmatrix}}} д д/д т следующим образом: [9] где — сопряженная (обратная) величина q . [ 0 ω x ω y ω z ] = 2 d q d t q ~ {\displaystyle {\begin{bmatrix}0\\\omega _{x}\\\omega _{y}\\\omega _{z}\end{bmatrix}}=2{\frac {\mathrm {d} \mathbf {q} }{\mathrm {d} t}}{\tilde {\mathbf {q} }}}

Наоборот, производная кватерниона равна d q d t = 1 2 [ 0 ω x ω y ω z ] q . {\displaystyle {\frac {\mathrm {d} \mathbf {q} }{\mathrm {d} t}}={\frac {1}{2}}{\begin{bmatrix}0\\\omega _{x}\\\omega _{y}\\\omega _{z}\end{bmatrix}}\mathbf {q} \,.}

Роторы в геометрической алгебре

Формализм геометрической алгебры (ГА) обеспечивает расширение и интерпретацию метода кватернионов. Центральным в ГА является геометрическое произведение векторов, расширение традиционных внутренних и перекрестных произведений , заданное как a b = a b + a b {\displaystyle \mathbf {ab} =\mathbf {a} \cdot \mathbf {b} +\mathbf {a} \wedge \mathbf {b} }

где символ обозначает внешнее произведение или произведение клина . Это произведение векторов a и b производит два члена: скалярную часть от внутреннего произведения и бивекторную часть от произведения клина. Этот бивектор описывает плоскость, перпендикулярную тому, что вернуло бы перекрестное произведение векторов.

Бивекторы в GA обладают некоторыми необычными свойствами по сравнению с векторами. При геометрическом произведении бивекторы имеют отрицательный квадрат: бивектор x̂ŷ описывает плоскость xy . Его квадрат равен ( x̂ŷ ) 2 = x̂ŷx̂ŷ . Поскольку единичные базисные векторы ортогональны друг другу, геометрическое произведение сводится к антисимметричному внешнему произведению, поэтому и ŷ можно свободно менять местами за счет коэффициента −1. Квадрат сводится к x̂x̂ŷŷ = −1, поскольку сами базисные векторы имеют квадрат +1.

Этот результат справедлив в целом для всех бивекторов, и в результате бивектор играет роль, аналогичную мнимой единице . Геометрическая алгебра использует бивекторы в своем аналоге кватерниона, роторе , заданном как где — единичный бивектор, описывающий плоскость вращения . Поскольку возводится в квадрат до −1, разложение R в степенной ряд порождает тригонометрические функции . Формула вращения, которая отображает вектор a в повернутый вектор b, имеет вид , где — обратный ( изменение порядка векторов в эквивалентно изменению его знака). R = exp ( B ^ θ 2 ) = cos θ 2 B ^ sin θ 2 , {\displaystyle \mathbf {R} =\exp \left({\frac {-{\hat {\mathbf {B} }}\theta }{2}}\right)=\cos {\frac {\theta }{2}}-{\hat {\mathbf {B} }}\sin {\frac {\theta }{2}}\,,} b = R a R {\displaystyle \mathbf {b} =\mathbf {RaR} ^{\dagger }} R = exp ( 1 2 B ^ θ ) = cos θ 2 + B ^ sin θ 2 {\displaystyle \mathbf {R} ^{\dagger }=\exp \left({\frac {1}{2}}{\hat {\mathbf {B} }}\theta \right)=\cos {\frac {\theta }{2}}+{\hat {\mathbf {B} }}\sin {\frac {\theta }{2}}} R {\displaystyle \scriptstyle R} B {\displaystyle B}

Пример. Вращение вокруг оси можно осуществить, преобразуя в его дуальный бивектор, где i = x̂ŷẑ — элемент единичного объема, единственный тривектор (псевдоскаляр) в трехмерном пространстве. Результатом будет v ^ = 1 3 ( x ^ + y ^ + z ^ ) {\displaystyle {\hat {\mathbf {v} }}={\frac {1}{\sqrt {3}}}\left({\hat {\mathbf {x} }}+{\hat {\mathbf {y} }}+{\hat {\mathbf {z} }}\right)} B ^ = x ^ y ^ z ^ v ^ = i v ^ , {\displaystyle {\hat {\mathbf {B} }}={\hat {\mathbf {x} }}{\hat {\mathbf {y} }}{\hat {\mathbf {z} }}{\hat {\mathbf {v} }}=\mathbf {i} {\hat {\mathbf {v} }}\,,} B ^ = 1 3 ( y ^ z ^ + z ^ x ^ + x ^ y ^ ) . {\displaystyle {\hat {\mathbf {B} }}={\frac {1}{\sqrt {3}}}\left({\hat {\mathbf {y} }}{\hat {\mathbf {z} }}+{\hat {\mathbf {z} }}{\hat {\mathbf {x} }}+{\hat {\mathbf {x} }}{\hat {\mathbf {y} }}\right)\,.}

Однако в трехмерном пространстве часто проще оставить выражение для = iv̂ , используя тот факт, что i коммутирует со всеми объектами в 3D, а также квадратируется до −1. Поворот вектора в этой плоскости на угол θ тогда равен

x ^ = R x ^ R = e i v ^ θ 2 x ^ e i v ^ θ 2 = x ^ cos 2 θ 2 + i ( x ^ v ^ v ^ x ^ ) cos θ 2 sin θ 2 + v ^ x ^ v ^ sin 2 θ 2 {\displaystyle {\hat {\mathbf {x} }}'=\mathbf {R} {\hat {\mathbf {x} }}\mathbf {R} ^{\dagger }=e^{-i{\hat {\mathbf {v} }}{\frac {\theta }{2}}}{\hat {\mathbf {x} }}e^{i{\hat {\mathbf {v} }}{\frac {\theta }{2}}}={\hat {\mathbf {x} }}\cos ^{2}{\frac {\theta }{2}}+\mathbf {i} \left({\hat {\mathbf {x} }}{\hat {\mathbf {v} }}-{\hat {\mathbf {v} }}{\hat {\mathbf {x} }}\right)\cos {\frac {\theta }{2}}\sin {\frac {\theta }{2}}+{\hat {\mathbf {v} }}{\hat {\mathbf {x} }}{\hat {\mathbf {v} }}\sin ^{2}{\frac {\theta }{2}}}

Признание того, что и что v̂x̂v̂ является отражением относительно плоскости, перпендикулярной v̂, дает геометрическую интерпретацию операции вращения: вращение сохраняет компоненты, параллельные , и изменяет только те, которые перпендикулярны. Затем вычисляются члены: i ( x ^ v ^ v ^ x ^ ) = 2 i ( x ^ v ^ ) {\displaystyle \mathbf {i} ({\hat {\mathbf {x} }}{\hat {\mathbf {v} }}-{\hat {\mathbf {v} }}{\hat {\mathbf {x} }})=2\mathbf {i} ({\hat {\mathbf {x} }}\wedge {\hat {\mathbf {v} }})} v ^ x ^ v ^ = 1 3 ( x ^ + 2 y ^ + 2 z ^ ) 2 i x ^ v ^ = 2 i 1 3 ( x ^ y ^ + x ^ z ^ ) = 2 3 ( y ^ z ^ ) {\displaystyle {\begin{aligned}{\hat {\mathbf {v} }}{\hat {\mathbf {x} }}{\hat {\mathbf {v} }}&={\frac {1}{3}}\left(-{\hat {\mathbf {x} }}+2{\hat {\mathbf {y} }}+2{\hat {\mathbf {z} }}\right)\\2\mathbf {i} {\hat {\mathbf {x} }}\wedge {\hat {\mathbf {v} }}&=2\mathbf {i} {\frac {1}{\sqrt {3}}}\left({\hat {\mathbf {x} }}{\hat {\mathbf {y} }}+{\hat {\mathbf {x} }}{\hat {\mathbf {z} }}\right)={\frac {2}{\sqrt {3}}}\left({\hat {\mathbf {y} }}-{\hat {\mathbf {z} }}\right)\end{aligned}}}

Результатом вращения тогда будет x ^ = x ^ ( cos 2 θ 2 1 3 sin 2 θ 2 ) + 2 3 y ^ sin θ 2 ( sin θ 2 + 3 cos θ 2 ) + 2 3 z ^ sin θ 2 ( sin θ 2 3 cos θ 2 ) {\displaystyle {\hat {\mathbf {x} }}'={\hat {\mathbf {x} }}\left(\cos ^{2}{\frac {\theta }{2}}-{\frac {1}{3}}\sin ^{2}{\frac {\theta }{2}}\right)+{\frac {2}{3}}{\hat {\mathbf {y} }}\sin {\frac {\theta }{2}}\left(\sin {\frac {\theta }{2}}+{\sqrt {3}}\cos {\frac {\theta }{2}}\right)+{\frac {2}{3}}{\hat {\mathbf {z} }}\sin {\frac {\theta }{2}}\left(\sin {\frac {\theta }{2}}-{\sqrt {3}}\cos {\frac {\theta }{2}}\right)}

Простая проверка этого результата — угол θ = 2/3 π . Такое вращение должно отображать в ŷ . Действительно, вращение сводится к x ^ = x ^ ( 1 4 1 3 3 4 ) + 2 3 y ^ 3 2 ( 3 2 + 3 1 2 ) + 2 3 z ^ 3 2 ( 3 2 3 1 2 ) = 0 x ^ + y ^ + 0 z ^ = y ^ {\displaystyle {\begin{aligned}{\hat {\mathbf {x} }}'&={\hat {\mathbf {x} }}\left({\frac {1}{4}}-{\frac {1}{3}}{\frac {3}{4}}\right)+{\frac {2}{3}}{\hat {\mathbf {y} }}{\frac {\sqrt {3}}{2}}\left({\frac {\sqrt {3}}{2}}+{\sqrt {3}}{\frac {1}{2}}\right)+{\frac {2}{3}}{\hat {\mathbf {z} }}{\frac {\sqrt {3}}{2}}\left({\frac {\sqrt {3}}{2}}-{\sqrt {3}}{\frac {1}{2}}\right)\\&=0{\hat {\mathbf {x} }}+{\hat {\mathbf {y} }}+0{\hat {\mathbf {z} }}={\hat {\mathbf {y} }}\end{aligned}}}

точно так, как и ожидалось. Эта формула вращения действительна не только для векторов, но и для любого мультивектора . Кроме того, когда используются углы Эйлера, сложность операции значительно уменьшается. Составные вращения получаются путем умножения роторов, поэтому общий ротор из углов Эйлера равен, но Эти роторы возвращаются из экспонент следующим образом: где R β относится к вращению в исходных координатах. Аналогично для вращения γ , Заметив, что R γ и R α коммутируют (вращения в одной плоскости должны коммутировать), и общий ротор становится R = R γ R β R α = exp ( i z ^ γ 2 ) exp ( i x ^ β 2 ) exp ( i z ^ α 2 ) {\displaystyle \mathbf {R} =\mathbf {R} _{\gamma '}\mathbf {R} _{\beta '}\mathbf {R} _{\alpha }=\exp \left({\frac {-\mathbf {i} {\hat {\mathbf {z} }}'\gamma }{2}}\right)\exp \left({\frac {-\mathbf {i} {\hat {\mathbf {x} }}'\beta }{2}}\right)\exp \left({\frac {-\mathbf {i} {\hat {\mathbf {z} }}\alpha }{2}}\right)} x ^ = R α x ^ R α and z ^ = R β z ^ R β . {\displaystyle {\begin{aligned}{\hat {\mathbf {x} }}'&=\mathbf {R} _{\alpha }{\hat {\mathbf {x} }}\mathbf {R} _{\alpha }^{\dagger }\quad {\text{and}}\\{\hat {\mathbf {z} }}'&=\mathbf {R} _{\beta '}{\hat {\mathbf {z} }}\mathbf {R} _{\beta '}^{\dagger }\,.\end{aligned}}} R β = cos β 2 i R α x ^ R α sin β 2 = R α R β R α {\displaystyle \mathbf {R} _{\beta '}=\cos {\frac {\beta }{2}}-\mathbf {i} \mathbf {R} _{\alpha }{\hat {\mathbf {x} }}\mathbf {R} _{\alpha }^{\dagger }\sin {\frac {\beta }{2}}=\mathbf {R} _{\alpha }\mathbf {R} _{\beta }\mathbf {R} _{\alpha }^{\dagger }} R γ = R β R γ R β = R α R β R α R γ R α R β R α . {\displaystyle \mathbf {R} _{\gamma '}=\mathbf {R} _{\beta '}\mathbf {R} _{\gamma }\mathbf {R} _{\beta '}^{\dagger }=\mathbf {R} _{\alpha }\mathbf {R} _{\beta }\mathbf {R} _{\alpha }^{\dagger }\mathbf {R} _{\gamma }\mathbf {R} _{\alpha }\mathbf {R} _{\beta }^{\dagger }\mathbf {R} _{\alpha }^{\dagger }\,.} R = R α R β R γ {\displaystyle \mathbf {R} =\mathbf {R} _{\alpha }\mathbf {R} _{\beta }\mathbf {R} _{\gamma }}

Таким образом, составные вращения углов Эйлера становятся серией эквивалентных вращений в исходной неподвижной системе отсчета.

Хотя роторы в геометрической алгебре работают почти идентично кватернионам в трех измерениях, сила этого формализма заключается в его общности: этот метод уместен и действителен в пространствах с любым числом измерений. В 3D вращения имеют три степени свободы, по одной степени для каждой линейно независимой плоскости (бивектора), в которой может происходить вращение. Известно, что пары кватернионов могут использоваться для генерации вращений в 4D, что дает шесть степеней свободы, и подход геометрической алгебры подтверждает этот результат: в 4D существует шесть линейно независимых бивекторов, которые могут использоваться в качестве генераторов вращений.

Смотрите также

Ссылки

  1. ^ «Отслеживание координатных маркеров для дополненной реальности».
  2. ^ Вайсштейн, Эрик В. «Матрица вращения». MathWorld .
  3. ^ аб Родригес, Олинде (1840). «Des lois géometriques qui regissent les déplacements d'un system Solide dans l'espace, et de lavariation des coordonnées producant de ces déplacement, рассматриваемые как независимые причины, которые могут быть произведены». Дж. Математика. Приложение Pures . 5 : 380–440.онлайн
  4. ^ см. J Willard Gibbs (1884). Элементы векторного анализа , New Haven, стр. 67
  5. ^ Конспект лекций по прямой и обратной кинематике, стр. 5
  6. ^ Мебиус, Йохан (2007). «Вывод формулы Эйлера–Родригеса для трехмерных вращений из общей формулы для четырехмерных вращений». arXiv : math/0701759 .
  7. ^ Шустер, Малкольм Д. (1993). «Обзор представлений об отношении» (PDF) . Журнал астронавтических наук . 41 (4): 439–517.
  8. ^ [1] Физика - Марк Иоффе - W ( t ) в терминах матриц
  9. ^ Конспект лекций по кватернионам и вращению, стр. 14-15

Дальнейшее чтение

  • Шустер, МД (1993). «Обзор представлений об отношении» (PDF) . Журнал астронавтических наук . 41 (4): 439–517. Bibcode : 1993JAnSc..41..439S.
  • Таубин, Г. (2011). «3D вращения». IEEE Computer Graphics and Applications . 31 (6): 84–89. doi :10.1109/MCG.2011.92. PMID  24808261.
  • Кутиас, Э.; Ромеро, Л. (2004). «Кватернионы в приложении к динамике твердого тела». Технический отчет Sandia . Национальные лаборатории Sandia. SAND2004-0153.
  • Markley, F. Landis (2003). "Представления ошибок ориентации для фильтрации Калмана". Journal of Guidance, Control and Dynamics . 26 (2): 311–7. Bibcode :2003JGCD...26..311M. doi :10.2514/2.5048. hdl : 2060/20020060647 .
  • Голдштейн, Х. (1980). Классическая механика (2-е изд.). Эддисон–Уэсли. ISBN 0-201-02918-9.
  • Верц, Джеймс Р. (1980). Определение и управление положением космического корабля . Д. Рейдель . ISBN 90-277-1204-2.
  • Шмидт, Дж.; Ниманн, Х. (2001). «Использование кватернионов для параметризации трехмерных вращений в неограниченной нелинейной оптимизации». Труды конференции Vision Modeling and Visualization Conference 2001. С. 399–406. ISBN 3898380289.
  • Ландау, Л.; Лифшиц, Э.М. (1976). Механика (3-е изд.). Пергамон Пресс . ISBN 0-08-021022-8.
  • Klumpp, AR (декабрь 1976 г.). «Извлечение кватерниона из матрицы направляющих косинусов без сингулярностей». Journal of Spacecraft and Rockets . 13 (12): 754–5. Bibcode : 1976JSpRo..13..754K. doi : 10.2514/3.27947.
  • Доран, К.; Ласенби, А. (2003). Геометрическая алгебра для физиков . Cambridge University Press. ISBN 978-0-521-71595-9.
  • Терзакис, Г.; Луракис, М.; Айт-Будауд, Д. (2018). «Модифицированные параметры Родригеса: эффективное представление ориентации в трехмерном зрении и графике». Журнал математического изображения и зрения . 60 (3): 422–442. doi : 10.1007/s10851-017-0765-x .
  • Ровенхорст, Д.; Роллетт, А.Д.; Рорер, Г.С.; Грёбер, М.; Джексон, М.; Конийненберг, П.Дж.; Де Граеф, М. (2015). "Последовательные представления и преобразования между трехмерными вращениями". Моделирование и имитация в материаловедении и машиностроении . 23 (8): 083501. Bibcode : 2015MSMSE..23h3501R. doi : 10.1088/0965-0393/23/8/083501. S2CID  16130878.
  • EuclideanSpace содержит массу информации о представлении вращения.
  • Q36. Как сгенерировать матрицу вращения из углов Эйлера? и Q37. Как преобразовать матрицу вращения в углы Эйлера? — Часто задаваемые вопросы о матрицах и кватернионах
  • Мнимые числа не являются действительными – Геометрическая алгебра пространства-времени – Раздел «Вращения и геометрическая алгебра» выводит и применяет роторное описание вращений.
  • Учебник Starlino's DCM – Учебник по теории направляющих косинусных матриц и приложения. Алгоритм оценки пространственной ориентации с использованием акселерометра, гироскопа и магнитометра IMU. Использование комплементарного фильтра (популярная альтернатива фильтру Калмана) с матрицей DCM.
Retrieved from "https://en.wikipedia.org/w/index.php?title=Rotation_formalisms_in_three_dimensions&oldid=1244882699#Formalism_alternatives"