Trajectory optimization(TO)을 몇달간 공부하고 사용하면서 알게 된 사실들을 조금 정리해보려 한다. 분명 강력한 오프라인 플래너지만 확실히 한계점도 존재한다. 이제는 벌써 트렌드와는 멀어진 기술이지만 개인적으로 학습 기반으로 넘어가기 전에 Trajectory optimization과 MPC는 해보고 가는 게 좋다 생각했다. 나처럼 TO를 처음 접하고 고통 받는 사람들을 위해 명확한 사실은 아니지만, 대충 내가 느낀 걸 적어본다.1. 스케일 Down to 스케일 Up 모든 문제 해결의 시작은 단순화이다. TO 문제 또한 가장 먼저 문제를 단순화시키고 단순화 된 문제에서 원하는 해결책을 찾았다면 그 다음 조금씩 Scale up 한다. 단순화 하는 방법으로는 차원 줄이기, 제약 사항 늘리..
작성자 : 한양대학교 일반대학원 인공지능융합학과 유승환 박사과정 안녕하세요~ 오랜만에 Jetson Nano 관련 블로그 글을 올립니다! 저는 엘스비어 저널에 투고한 논문의 리비전 작업을 위해, 오랜만에 Jetson Nano를 부팅했는데... 처음으로 모니터에 뜨는 Nvidia Logo 화면에서 Stuck되어서 다음 화면으로 넘어가지 않더라고요 ㅜㅜ (1시간 넘게 기다려도 계속 stuck된 채로 멈춰있습니다...) 관련해서 구글링을 하면 정말 다양하고 어려운 솔루션들이 나옵니다! 그런데 저는 엄청 쉬운 방법으로 해결이 되더라고요...ㅎㅎ 저와 같은 현상이 발생하면, jetson nano에 장착된 micro SD 카드를 뺐다가 다시 장착해주세요! 그런 다음에 jetson nano를 재부팅하면, 신기하게..
Signed Distance Field는 주어진 x와 특정 집합의 경계 사이의 직교 거리를 나타내는 필드(혹은 함수)이다. 이 거리는 점 x가 집합의 내부에 있는지 여부에 따라 부호가 결정된다. 집합 내부에서는 양수, 경계에서는 0, 외부에서는 음의 값을 가진다. 이런 SDF는 시뮬레이션에서 충돌을 계산하는 데 사용된다.MuJoCo는 SDF 플러그인을 제공한다.https://github.com/google-deepmind/mujoco/blob/main/plugin/sdf/README.mddistance 함수를 만들어서 나만의 플러그인을 만들 수 있다. 이때 참고하면 좋은 사이트가 https://iquilezles.org/articles/distfunctions/기본적인 SDF들에 대한 함수를 작성해두었다..
LCP를 이용해서 Contact model을 구성하는 내용을 다뤘었다. 오늘은 실제 LCP 문제를 푸는 법에 대해 이야기 해보려 한다. 기본적인 LCP는 아래와 같이 정의 된다.이런 형태로 접촉 문제를 구성하여 LCP를 풀면 접촉 힘을 계산할 수 있게 된다. 우선 간단한 점이 바닥과 접촉하는 경우의 Contact model을 구성해보자. (원이 아니라 점이다. Point mass라 생각하자.)무게는 0.2, 마찰 계수는 1이라 하자. 점이기 때문에 Mass matrix, (혹은 Inertia matrix)는 무게를 대각행렬로 가지는 형태가 된다. 점이기에 바닥과 접촉하는 순간 발생하는 접촉의 수는 1개로 고정된다.우선 모든 걸 contact frame (접촉 프레임)으로 바꿔줘야 한다. 어떤 좌표 ..
D. E. Stewart and J. C. Trinkle, “An implicit time-stepping scheme for rigid body dynamics with inelastic collisions and coulomb friction,” Int. J. Numer. Meth. Eng., vol. 39, no. 15, pp. 2673–2691, Aug. 1996. E. Todorov, “A convex, smooth and invertible contact model for trajectory optimization,” in 2011 IEEE Int. Conf. Robotics and Automation, 2011, pp. 1071–1076. Baraff, David. "Fast contact ..
Linear Complimentarity problem(선형 상보성 문제)는 강체 간의 접촉을 모델링하는 데 사용하는 방법중 하나다. 이번 글에서는 Linear Complimentarity 을 대수 관점에서 우선 설명하려 한다. Linear Complimentarity Problem(LCP)1차원 LCPLCP의 쉬운 이해를 위해 1차원 문제로 접근해보자. 1차원 LCP에서는 x, y 변수 2개가 있다. 이 둘은 모두 실수에 포함된다. LCP는 상보되는 제약 조건을 만족하는 x와 y를 찾는 문제이다. 이때 제약 조건은 아래와 같다하자.상보 문제이기 때문에 or가 들어간다. 이를 LCP에서는 아래와 같이 표기한다.위 문제를 만족하는 해는 단순히 양의 x축과 양의 y축이다.여기에 y와 x의 선형 관계 y..
어떤 시작점과 도착점으로 이뤄진 두 경로가 동일한 공간 안에서 장애물을 넘지 않고 서로 변형될 수 있다면 두 경로는 호모토피 클래스에 속한다고 한다.figure2의 왼쪽의 경로들은 같은 호모토피 클래스이고 오른쪽은 중간에 장애물로 인해 다른 호모토피 클래스가 된다. 호모토피 경로 계획 문제는 시작점에서 도착점으로 가는 여러 경로들 중에 위상적으로 구별되는(즉, 다른 호모토피 클래스에 속하는) 최적 경로를 찾는 문제이다. 일반적인 경로 계획과는 다르게 장애물의 오른쪽으로 가야할지, 왼쪽으로 가야할 지를 고려한다고 보면 된다.주로 장애물 기준으로 시계 방향이냐, 반시계 방향이냐에 따라 서로 다른 호모토피 클래스가 나뉜다. 이런 다른 호모토피 클래스 중에 최적 경로를 찾는 게 목표이다. 최적 경로란 길이의..
Fast Model Predictive Control with Soft Constraints저자 : Arthur Richards논문 : https://www.sciencedirect.com/science/article/pii/S0947358015000667작성 : 이해구Wang and Boyd의 Fast MPC방식에서 발전한 방법이다.(https://pasus.tistory.com/230 참고) 이들은 소프트 제약조건을 추가하는 효율적인 방법에 대해서 다뤘다. 다양한 robust mpc 방식들은 모델 불확실성은 어느정도 가져간 상태에서 robust함을 가지고 꽤 복잡한 형태이다. 이보다 쉬운 방법은 제약 조건을 어느정도 어기도록 최적제어기를 설계하는 것이다. 이를 위해서는 주로 여분의 변수 (slac..