Возникла задача несложной инверсной кинематики, над которой я уже бьюсь 3 дня и где-то сильно туплю, поэтому не могу решить.
data:image/s3,"s3://crabby-images/a56d4/a56d4ca055502e885b3240283b4ccec0edcbad4a" alt="Изображение"
Имеется манипулятор из трёх плеч длинами
data:image/s3,"s3://crabby-images/5ba21/5ba2107d02409602d49ea7e3ff72397dc918c89e" alt="$r_1, r_2, r_3$ $r_1, r_2, r_3$"
. Есть 2 сустава, которые их крутят. Они обозначены синими кружочками. Есть конечная точка
data:image/s3,"s3://crabby-images/99c33/99c33f67a3d35f53bac09ed85e4c8b1da83042ad" alt="$P$ $P$"
, которая обозначена красным.
Задача в том, чтобы получить аналитический ответ на вопрос: «какими должны быть углы поворота
data:image/s3,"s3://crabby-images/fa1bb/fa1bbdbcaa00982ef827e558977205a6bfe7411d" alt="$\theta_1, \theta_2$ $\theta_1, \theta_2$"
, чтобы конечная точка оказалась в заданных, известных декартовых координатах.
Ход моего решения:
data:image/s3,"s3://crabby-images/77957/779572e15ebddfaaee9f222dcb0fd1fd1afd4085" alt="$$\theta_{12} = \theta_1 + \theta_2$$
$$p_x = r_1 \cos \theta_1 + r_2 \cos \theta_{12} - r_3 \sin \theta_{12}$$
$$p_y = r_1 \sin \theta_1 + r_2 \sin \theta_{12} + r_3 \cos \theta_{12}$$ $$\theta_{12} = \theta_1 + \theta_2$$
$$p_x = r_1 \cos \theta_1 + r_2 \cos \theta_{12} - r_3 \sin \theta_{12}$$
$$p_y = r_1 \sin \theta_1 + r_2 \sin \theta_{12} + r_3 \cos \theta_{12}$$"
Возводим оба уравнения в квадрат и складываем:
![$$
\[p_x^2 = r_1^2 \cos^2 \theta_1 + 2r_1\cos\theta_1(r_2\cos\theta_{12}-r_3\sin\theta_{12}) + r_2^2 \cos^2 \theta_{12} - 2r_2r_3 \cos\theta_{12} \sin \theta_{12} + r_3^2\sin^2\theta_{12}\]
\[p_y^2 = r_1^2 \sin^2 \theta_1 + 2r_1\sin\theta_1(r_2\sin\theta_{12}-r_3\cos\theta_{12}) + r_2^2 \sin^2 \theta_{12} + 2r_2r_3 \sin\theta_{12} \cos \theta_{12} + r_3^2\cos^2\theta_{12}\]
\[p_x^2=r_1^2+r_2^2+r_3^2+2r_1r_2\cos\theta_1\cos\theta_{12}-2r_1r_3\cos\theta_1\sin\theta_{12} + 2r_1r_2\sin\theta_1\sin\theta_{12}+2r_1r_3\cos\theta_{12}\]
$$ $$
\[p_x^2 = r_1^2 \cos^2 \theta_1 + 2r_1\cos\theta_1(r_2\cos\theta_{12}-r_3\sin\theta_{12}) + r_2^2 \cos^2 \theta_{12} - 2r_2r_3 \cos\theta_{12} \sin \theta_{12} + r_3^2\sin^2\theta_{12}\]
\[p_y^2 = r_1^2 \sin^2 \theta_1 + 2r_1\sin\theta_1(r_2\sin\theta_{12}-r_3\cos\theta_{12}) + r_2^2 \sin^2 \theta_{12} + 2r_2r_3 \sin\theta_{12} \cos \theta_{12} + r_3^2\cos^2\theta_{12}\]
\[p_x^2=r_1^2+r_2^2+r_3^2+2r_1r_2\cos\theta_1\cos\theta_{12}-2r_1r_3\cos\theta_1\sin\theta_{12} + 2r_1r_2\sin\theta_1\sin\theta_{12}+2r_1r_3\cos\theta_{12}\]
$$](https://dxdy-04.korotkov.co.uk/f/f/4/4/f44e703a4a7e6f9ef24e83f101deea3682.png)
Заменяем
data:image/s3,"s3://crabby-images/4ebdd/4ebdd2abc17740306b0cb292b285e5e850570341" alt="$\theta_{12}$ $\theta_{12}$"
на
data:image/s3,"s3://crabby-images/08124/08124527a39cdb156b3163f090fbc3df240a65bf" alt="$\theta_1 + \theta_2$ $\theta_1 + \theta_2$"
в последнем уравнении, и пользуясь формулами синуса и косинуса суммы получаем:
data:image/s3,"s3://crabby-images/15355/15355d16b189be422a25233f016d03a3ada9495e" alt="$$
p_x^2+p_y^2=r_1^2+r_2^2+r_3^2+2r_1r_2\cos\theta_2 + 2r_1r_3(-\sin\theta_2)
$$ $$
p_x^2+p_y^2=r_1^2+r_2^2+r_3^2+2r_1r_2\cos\theta_2 + 2r_1r_3(-\sin\theta_2)
$$"
или
data:image/s3,"s3://crabby-images/de7e8/de7e8be4fcc6d04150c84bdd012ca75a365aadbc" alt="$$
2r_1r_2\cos\theta_2 - 2r_1r_3\sin\theta_2 = p_x^2+p_y^2 - r_1^2 - r_2^2 - r_3^2
$$ $$
2r_1r_2\cos\theta_2 - 2r_1r_3\sin\theta_2 = p_x^2+p_y^2 - r_1^2 - r_2^2 - r_3^2
$$"
А это стандартное уравнение, решение которого:
data:image/s3,"s3://crabby-images/1fd7e/1fd7e9bd9155173b943149a3debe12fff8ec2abb" alt="$$
\theta_2 = \arctg \frac{A}{B} \pm \arctg\frac{\sqrt{A^2+B^2-C^2}}{C}
$$ $$
\theta_2 = \arctg \frac{A}{B} \pm \arctg\frac{\sqrt{A^2+B^2-C^2}}{C}
$$"
где A — коэффициент перед сокинусом, B — перед синусом, C — то, что справа.
Всё,
data:image/s3,"s3://crabby-images/f032b/f032b3357856a66d656de4f109477e6442ef1f15" alt="$\theta_2$ $\theta_2$"
известна, теперь дело за
data:image/s3,"s3://crabby-images/15ec4/15ec45e2daa06f8bf7851e6bd0da6dc3c24b1660" alt="$\theta_1$ $\theta_1$"
. Ещё раз распишем:
data:image/s3,"s3://crabby-images/83cd4/83cd4c759ac0fc274113fd7a915f27a3dee154d3" alt="$$p_x = r_1 \cos \theta_1 + r_2\cos\theta_1\cos\theta_2 - r_2\sin\theta_1\sin\theta_2 - r_3\sin\theta_1\cos\theta_2 - r_3\cos\theta_1\sin\theta_2$$
$$p_y = r_1 \sin \theta_1 + r_2\sin\theta_1\cos\theta_2 + r_2\cos\theta_1\sin\theta_2 + r_3\cos\theta_1\cos\theta_2 - r_3\sin\theta_1\sin\theta_2$$ $$p_x = r_1 \cos \theta_1 + r_2\cos\theta_1\cos\theta_2 - r_2\sin\theta_1\sin\theta_2 - r_3\sin\theta_1\cos\theta_2 - r_3\cos\theta_1\sin\theta_2$$
$$p_y = r_1 \sin \theta_1 + r_2\sin\theta_1\cos\theta_2 + r_2\cos\theta_1\sin\theta_2 + r_3\cos\theta_1\cos\theta_2 - r_3\sin\theta_1\sin\theta_2$$"
Домножаем верхнее на
data:image/s3,"s3://crabby-images/a070a/a070a8952aa0a1992857ff16613cd083ce734722" alt="$\cos\theta_1$ $\cos\theta_1$"
, а нижнее на
data:image/s3,"s3://crabby-images/000b9/000b978f758320e28f6987a2eac27ad09682dbd5" alt="$\sin\theta_1$ $\sin\theta_1$"
и складываем вместе:
data:image/s3,"s3://crabby-images/af3cb/af3cb58a2083c9bf35438a67367184ca81ffb06a" alt="$$p_x\cos\theta_1 = r_1 \cos^2 \theta_1 + r_2\cos^2\theta_1\cos\theta_2 - r_2\sin\theta_1\sin\theta_2\cos\theta_1 - r_3\sin\theta_1\cos\theta_2\cos\theta_1 - r_3\cos^2\theta_1\sin\theta_2$$
$$p_y\sin\theta_1 = r_1 \sin^2 \theta_1 + r_2\sin^2\theta_1\cos\theta_2 + r_2\cos\theta_1\sin\theta_2\sin\theta_1 + r_3\cos\theta_1\cos\theta_2\sin\theta_1 - r_3\sin^2\theta_1\sin\theta_2$$
$$p_x\cos\theta_1 + p_y\sin\theta_1 = r_1 + r_2\cos\theta_2 - r_3\sin\theta_2$$ $$p_x\cos\theta_1 = r_1 \cos^2 \theta_1 + r_2\cos^2\theta_1\cos\theta_2 - r_2\sin\theta_1\sin\theta_2\cos\theta_1 - r_3\sin\theta_1\cos\theta_2\cos\theta_1 - r_3\cos^2\theta_1\sin\theta_2$$
$$p_y\sin\theta_1 = r_1 \sin^2 \theta_1 + r_2\sin^2\theta_1\cos\theta_2 + r_2\cos\theta_1\sin\theta_2\sin\theta_1 + r_3\cos\theta_1\cos\theta_2\sin\theta_1 - r_3\sin^2\theta_1\sin\theta_2$$
$$p_x\cos\theta_1 + p_y\sin\theta_1 = r_1 + r_2\cos\theta_2 - r_3\sin\theta_2$$"
Аналогично, если домножать на
data:image/s3,"s3://crabby-images/39548/395484a5a3fc31ce4e09735d2d6df62c34785594" alt="$-\sin\theta_1$ $-\sin\theta_1$"
и на
data:image/s3,"s3://crabby-images/a070a/a070a8952aa0a1992857ff16613cd083ce734722" alt="$\cos\theta_1$ $\cos\theta_1$"
, а затем сложить:
data:image/s3,"s3://crabby-images/0f5ea/0f5ea925f2ba837b3aa6af6a055c2ef52515eb27" alt="$$p_y\cos\theta_1 - p_x\sin\theta_1 = r_2\sin\theta_2 + r_3\cos\theta_2$$ $$p_y\cos\theta_1 - p_x\sin\theta_1 = r_2\sin\theta_2 + r_3\cos\theta_2$$"
В двух последних полученных уравнениях если первое домножить на
data:image/s3,"s3://crabby-images/c797a/c797abca880d58d420bac5c1fde680d65c677ce2" alt="$p_x$ $p_x$"
, а нижнее на
data:image/s3,"s3://crabby-images/98d2d/98d2de6ed9008564b86e122b626cb54a064957dd" alt="$p_y$ $p_y$"
и сложить, получим:
data:image/s3,"s3://crabby-images/45050/450507f9b1e7c1d763b3e59377c35e506338c00d" alt="$$p_x^2\cos\theta_1 + p_xp_y\sin\theta_1 = p_x(r_1 + r_2\cos\theta_2 - r_3\sin\theta_2)$$
$$p_y^2\cos\theta_1 - p_xp_y\sin\theta_1 = p_y(r_2\sin\theta_2 + r_3\cos\theta_2)$$
$$\cos\theta_1 = \frac{p_x(r_1+r_2\cos\theta_2-r_3\sin\theta_2)+p_y(r_2\sin\theta_2+r_3\cos\theta_2)}{p_x^2+p_y^2}$$ $$p_x^2\cos\theta_1 + p_xp_y\sin\theta_1 = p_x(r_1 + r_2\cos\theta_2 - r_3\sin\theta_2)$$
$$p_y^2\cos\theta_1 - p_xp_y\sin\theta_1 = p_y(r_2\sin\theta_2 + r_3\cos\theta_2)$$
$$\cos\theta_1 = \frac{p_x(r_1+r_2\cos\theta_2-r_3\sin\theta_2)+p_y(r_2\sin\theta_2+r_3\cos\theta_2)}{p_x^2+p_y^2}$$"
Берём аркосинус и та да! Казалось бы оба угла известны, всё лепо. Однако если провести элементарную проверку в экселе, становится понятно, что решение не верно. Например, если проверить координаты:
data:image/s3,"s3://crabby-images/7c838/7c8382c7e46a720dfab22321919ae2e77499dca6" alt="$p_x=r_1+r_2, p_y=r_3$ $p_x=r_1+r_2, p_y=r_3$"
, т.е. разогнутый сустав, угол
data:image/s3,"s3://crabby-images/f032b/f032b3357856a66d656de4f109477e6442ef1f15" alt="$\theta_2$ $\theta_2$"
равен -90°, что похоже на правду, но вот
data:image/s3,"s3://crabby-images/15ec4/15ec45e2daa06f8bf7851e6bd0da6dc3c24b1660" alt="$\theta_1$ $\theta_1$"
какой-то не адекватный и с изменением параметров положения точки P значение
data:image/s3,"s3://crabby-images/15ec4/15ec45e2daa06f8bf7851e6bd0da6dc3c24b1660" alt="$\theta_1$ $\theta_1$"
ведёт себя странно.
Уважаемые форумчане, быть может кто-то увидел ошибку в рассуждениях? Выручайте: мой мозг уже вскипел.