При вычислении матрицы Якоби для аналитического решения обратной кинематики я читал из многих мест, что могу использовать эту формулу для создания каждого из столбцов соединения в матрице Якоби:
Так что - это ось вращения в мировом пространстве, - это точка поворота в мировом пространстве, а - это положение конечного эффектора в мировом пространстве.
Тем не менее, я не понимаю, как это может работать, когда суставы имеют более одного DOF. Возьмите следующее в качестве примера:
являются DOF вращения, то является концевой эффектор, то является целью концевого эффектора, в , и являются суставы.
Во-первых, если бы я вычислил матрицу Якоби на основе приведенной выше формулы для диаграммы, я получу что-то вроде этого:
Предполагается, что все оси вращения равны и все они имеют только одну DOF вращения. Итак, я считаю, что каждый столбец для одного DOF, в данном случае, .
Теперь вот проблема: что если все суставы имеют полные 6 степеней свободы? Скажем, теперь для каждого соединения у меня есть вращательные DOF по всем осям, , и , а также поступательные DOF по всем осям, , и .
Чтобы прояснить мой вопрос, предположим, что если бы я «принудительно» применил приведенную выше формулу ко всем степеням свободы всех соединений, то я, вероятно, получу якобианскую матрицу, подобную этой:
(нажмите для увеличения)
Но это невероятно странно, потому что все 6 столбцов DOF для каждого сустава повторяют одно и то же.
Как я могу использовать одну и ту же формулу для построения матрицы Якоби со всеми степенями свободы? Как будет выглядеть матрица Якоби в этом случае?
источник
Ответы:
Я должен признать, что я не видел эту конкретную формулу очень часто, но я предполагаю, что в случае более чем одного DOF, вы оцените ее для каждого соединения в каждом столбце, а затем (возможно?) Умножите эти результаты на каждый столбец.
Но позвольте мне предложить более простое подход к якобианам в контексте произвольного множества степеней свободы: по сути, якобиан говорит вам, как далеко перемещается каждое соединение, если вы перемещаете конечную эффекторную рамку в каком-то произвольно выбранном направлении. Пусть быть прямая кинематика, где θ = [ & thetas ; 1 , . , , , θ n ] - шарниры, f pos - позиционная часть прямой кинематики и f rot вращательной части. Тогда вы можете получить якобиан, дифференцируя прямую кинематику по объединенным переменным:f(θ) θ=[θ1,...,θn] fpos frot
является якобиан вашего манипулятора. Инвертирование дало бы вам обратную кинематику с учетомскоростей. Онпрежнему может быть полезнымхотя, если вы хотите знатьнасколько каждое соединение должно двигатьсяесли вы хотитечтобы переместить конец эффектор некоторымнебольшимколичествомΔхв любом направлении (такна уровне позиции, это будет фактически линеаризацию):
Δθ=J-1Δx
Надеюсь, что это поможет.
источник
Ваша формула для соединения с 6 степенями свободы предполагает, что все 6 соединений имеют ось в мировой системе координат и что все соединения являются вращательными. Поскольку 6 суставов, таким образом, идентичны, их столбцы в якобиане также идентичны.(0,0,1)
Начиная более, предположим, что соединение имеет ось проходит через точку г . Пусть е будет положением конечного эффектора. Все координаты a , r и e задаются в рамке мира и обновляются по мере перемещения робота. Ось имеет длину 1 .a r e a r e a 1
Если сустав является вращающимся, столбец якобиана для сустава
Если соединение призматическое, столбец
Предположим, у нас есть шарнир 6 градусов, который не только сферический, но и может перемещаться в пространстве. Предположим, что оси соединения - , a y и a z, и что каждое вращающееся и призматическое соединение разделяет ось, так что якобиан для соединения становитсяax ay az
источник
Насколько я понимаю твой вопрос, что ты хочешь матрицу Якоби для соединения 6 степеней свободы.
Позвольте мне начать с самых основ робототехники. Вы находитесь на начальном этапе обучения робототехнике. Вы должны понимать, что каждый сустав представляет собой один DOF, будь то поворотный или призматический сустав.
Что касается сферического соединения, оно может быть преобразовано в 3 вращающихся соединения с тремя взаимно перпендикулярными осями. Итак, теперь вы упростили свой сферический сустав.
Двигаясь вперед к якобианской матрице. Он содержит 6 строк. Первые 3 строки представляют ориентацию, а последние 3 строки указывают положение со ссылкой на конкретную систему координат. Каждый столбец в матрице указывает на одно соединение. Таким образом, число соединений / DOF у вас есть тот же номер столбца, который у вас есть в матрице Якоби.
Вот более ясный взгляд на ваш вопрос: один сустав никогда не выполняет более одного DOF, потому что это усложняет сустав, и точный контроль никогда не будет достигнут. Даже если мы гипотетически рассмотрим соединение с более чем одним DOF, вам нужно преобразовать это соединение в несколько соединений с 1 DOF каждый, чтобы упростить математику и решение.
В идеале робот с 6 степенями свободы с 6 поворотными шарнирами работает для большинства на реальных проблемах. Но по вашему вопросу вы рассматривали 6 совместных роботов, каждый из которых имеет 3 степеней свободы, что составляет 18 степеней свободы. Это даст избыточный DOF (т.е. 18-6 = 12 резервных DOF). Таким образом, для достижения конечного эффектора робота в любом месте с любой ориентацией у вас будет бесконечно много разных решений (решение означает вращение каждого соединения). Так что для решения этой проблемы обратной кинематики вам потребуется итерационный метод обратной кинематики.
Надеюсь, я ответил на ваш вопрос более четко. Чтобы изучить основы робототехники, вы можете обратиться к Джону Крейгу - Введение в робототехнику и управление робототехникой -Pearson Education, Inc.
С уважением, Манан Каласария
источник