설명 없음

haminhtien99 e92b31e41f update repository with camera position 5 달 전
camera_calibration 3be179ff37 Update repository with camera position and fix issue 5 달 전
distance_estimation aae71e0c3f update repository with camera position 5 달 전
generate_markers 98441f9b72 first commit 5 달 전
.gitignore 98441f9b72 first commit 5 달 전
README.md e92b31e41f update repository with camera position 5 달 전
chessboard.png 98441f9b72 first commit 5 달 전
default_config.py aae71e0c3f update repository with camera position 5 달 전
map_markers.jpg 3be179ff37 Update repository with camera position and fix issue 5 달 전
requirements.txt 98441f9b72 first commit 5 달 전

README.md

LANDING_SPACE

Thuật toán hạ cánh và điều hướng drone dựa trên ArUco marker

Tải xuống git này và cài đặt các tài nguyên cần thiết

git clone https://git.vnai.xyz/haminhtien99/landing_space
cd landing_space
pip install -r requirements.txt

Cài đặt các giá trị ban đầu cho marker

Di chuyển tới file default_config.py, thay đổi các giá trị sau. Lưu ý kích thước MARKER_SIZESQUARE_SIZE đặt cùng đơn vị (tùy ý centimet, milimet), khi đó kết quả đầu ra về khoảng cách sẽ nhận được giá trị tương ứng

MARKER_SIZE=5 # kích thước các mã QR-code
set_resolution='original' # điều chỉnh độ phân giải cho camera, đặt original nếu ko thay đổi
SQUARE_SIZE = 2.1  # kích thước ô của bàn cờ

Hiệu chuẩn camera:

Để thực hiện hiệu chuẩn, cần phải chụp ảnh bàn cờ chessboard.jpg được in trên giấy với nhiều góc độ, vị trí khác nhau

python camera_calibration/capture_images.py

  • Nhấn phím "s" để chụp ảnh, nhấn "q" để kết thúc.
  • Ảnh sẽ được lưu vào thư mục con của thư mục camera_calibration/images, tương ứng với giá trị set_resolution được đặt ban đầu.

python camera_calibration/capture_images_without_showing.py, tương tự bên trên

  • Ảnh sẽ được tự động lưu vào thư mục camera_calibration/images sau mỗi 5 giây.
  • Nhấn tổ hợp phím Ctrl + C để thoát chương trình

python camera_calibration/calibration.py

  • Thông số hiệu chuẩn của camera sẽ được lưu vào thư mục camera_calibration/calib_data.

Dữ liệu hiệu chuẩn

Dữ liệu hiệu chuẩn camera lưu tại tệp .npz. Dữ liệu này bao gồm:

  • camMatrix: Ma trận camera, chứa các tham số nội tại của camera.
  • distCoef: Các hệ số biến dạng của camera.
  • rVector: Vector xoay của từng ảnh dùng để hiệu chuẩn.
  • tVector: Vector tịnh tiến của từng ảnh hiệu chuẩn.

Tạo mã Aruco:

  • Tạo tùy ý 20 mã marker. Chạy python generate_markers/generate.py.
  • Có thể thay đổi loại marker tùy ý, trong bài toán này sử dụng loại 7x7 (aruco.DICT_7X7_50)

Ước lượng vị trí marker so với camera:

  • Chạy distance_estimation/distance_single.py
  • Cài đặt visualization = Trueđể in kết quả đầu ra kèm kết quả hình ảnh, nhấn q đẻ thoát;
  • Hoặc chạy visualization = False để in kết quả đầu ra, nhấn Ctrl + C.

Ước lượng vị trí camera:

Chuẩn bị

  • Chuẩn bị marker như trong hình mô tả map_markers.jpg.
  • Xác định chuẩn xác vị trí tương đối của các ID1, ID2, ID3, ID4 so với ID0 ở trung tâm (lấy hệ tọa độ mặt phẳng là trục x, y của marker ID0). Nên đặt các marker vùng rìa không đối xứng nhau nhằm tối ưu tính toán tọa độ trong trường hợp bị che khuất. Gắn các marker sao cho các trục x, y, z cùng hướng với nhau.

Ví dụ đặt các marker

Tính toán

python distance_estimation/camera_position.py

  • Ược lượng vị trí camera trong bản đồ tạo bởi các marker được xác định trước
  • Phương pháp này tính toán vị trí tương đối camera so với marker bằng việc nhân ma trận nghịch đảo của phép xoay với rVec với tVec.
  • Lấy marker_0 làm gốc, tọa độ các marker khác được cài đặt trong file default_config.py
  • In ra màn hình kết quả các giá trị x, y, z, roll, pitch, yaw - lần lượt tọa độ camera trong hệ tọa độ marker_0 làm gốc, roll, pitch, yaw - góc quay camera so với mặt phẳng chứa marker
  • Đặt visualization= True để hiển thị video với tọa độ camera so với marker_0. Nhấn phím q để kết thúc, thoát video
  • Nếu visualization=False, nhấn Ctrl + C để thoát.