Giao diện giám sát và điều khiển trên máy tính được thiết kế bằng phần mềm Qt Creator để giúp người điều khiển dễ dàng tiếp cận, tương tác với Robot. Trong giao diện sẽ được chia thành hai khu vực chính bao gồm:
• Khu vực điều khiển với các chức năng chuyên biệt.
• Khu vực giám sát hành vi của Robot sẽ hiển thị cụ thể mô hình Robot trong không gian 3 chiều và các thông số về vị trí, góc của từng khớp Robot, các thông số này luôn được cập nhật theo thời gian thực.
Hình 4.9:Tổng quan giao diện.
Trong phần điều khiển, người điều hành sẽ được lựa chọn các chế độ điều khiển các chế độ điều khiển khác nhau trong menu chính, có thể bật tắt các camera, thiết lập kết nối tới Arduino (vi xử lý dùng cho Robot), tùy chỉnh thay đổi các thông số nội trong giải thuật điều khiển và xem lại các cảnh báo trong quá trình cài đặt.
Cụ thể từng phần được mô tả như sau:
- Phần “Forward kinematics”: Phần này cho phép người điều khiển nhập các góc mong muốn cho từng khớp, theo đơn vị là độ và nhập vào thời gian để Robot hoàn tất thao tác trên. Người dùng có thể nhấn nút “Preview” để xem trước hình dáng Robot trong mô hình và nhấn nút “Run” để bắt đầu chạy.
Hình 4.10:Chức năng điều khiển theo động học thuận
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 4. THI CÔNG HỆ THỐNG
- Phần “Inverse kinematics”: Phần này cho phép người dùng nhập vị trí mong muốn trong không gian 3 chiều để đưa Robot tới vị trí đó, tính theo đơn vị mét, theo hệ trục tọa độ gốc đặt cho Robot và nhập vào thời gian hoàn tất thao tác di chuyển. Sau khi nhập xong các thông số vị trí và thời gian, người dùng nhấn vào nút “Find the Angles” thể hệ thống tính toán các góc và hiển thị lên bảng giá trị bên phải. Người dùng có thể nhấn nút “Preview” để xem trước tư thế trong mô hình bên phải và nhấn nút “Run” để bắt đầu quá trình chạy.
Hình 4.11:Chức năng điều khiển theo động học nghịch
- Phần “Control picking and Dropping objects”: Phần cho phép điều khiển gắp và thả vật ở các vị trí mong muốn được nhập trong 2 bảng tương ứng “Pick objects” và “Drop objects” (nếu có bật tính năng “Camera” để nhận diện vị trí của vật thì hệ thống sẽ tự động cập nhật vị trí của vật vào bảng “Pick objects”). Người dùng có thể nhấn nút “Run” để bắt đầu quá trình chạy và nhấn nút “Stop” để kết thúc quá trình.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 4.12:Chức năng điều khiển gắp vật cơ bản
- Phần “Pick and Drop objects & avoiding obstacles”: Phần này cũng tương tự như phần gắp thả vật như trên nhưng có bổ sung thêm tính năng tránh vật cản đường nhờ có nhận diện bằng camera. Quá trình hoạt động này của Robot sẽ được đều khiển theo thuật toán thông minh đã đề cập ở cơ sở lý thuyết, tự động phát hiện và tránh các vật cản do hai camera nhận biết được.
Hình 4.13:Chức năng điều khiển gắp vật nâng cao
- Phần “Camera Calibration”: Phần này cho phép người dùng khởi động camera thông qua nút “Start”. Thông số về tọa độ vật sẽ được hiển trong bảng “Object position” và thông số về tọa độ vật cản sẽ được hiển trong bảng “Obstacle location” và vị trí của chúng cũng sẽ được hiển trị trong mô hình không gian 3 chiều bên phải với các màu sắc tương ứng. Nếu
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 4. THI CÔNG HỆ THỐNG
nhấn vào nút “Cam view” thì cửa sổ sẽ được mở rộng thêm về bên phải và hiển thị hình ảnh thu được từ 2 cam, nếu không cần thiết có thể đóng phần hiển thị này lại.
Hình 4.14:a. Chức năng nhận diện vật b. Phần hiển thị hình ảnh
- Phần “Connect with Arduino”: Phần này kết nối giao diện với Arduino (vi điều khiển của Robot). Người dùng có thể tùy chọn tốc độ kết nối và cổng kết nối trong qua 2 mục hiển thị “Baud Rate” and “COM port”. Tiến hành kết nối và ngắt kết nối với 2 nút “Connect” và “Disconnect”.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 4.15:Chức năng kết nối tới vi điều khiển
- Phần “System Parameter”: Phần này cho phép người dung quản lý các thông số nội trong quá trình điều khiển. Trong đó, người dùng có thể thay đổi các giới hạn về các khớp của Robot, cho phép thay đổi thông số về hướng hoạt động của điểm đầu cuối, điều chỉnh vị trí, kích thước của điểm đầu cuối nếu có thay đổi kẹp gắp và điều chỉnh giới hạn về sai số trong quá trình tính toán giúp cải thiện độ chính xác hoặc tăng tốc thời gian xử lý các thuật toán.
Hình 4.16:Chức năng thiết lập chỉnh sửa các thông số hệ thống
- Phần “System history”: Phần này sẽ lưu lại các cảnh báo hoặc lỗi trong quá trình hoạt động. Trong bảng cũng sẽ có các chú thích rõ rõ ràng về
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 4. THI CÔNG HỆ THỐNG
ngày tháng, thời gian và tên của các sự kiện, cảnh báo diễn ra giúp người điều khiển dễ dàng quản lý.
Hình 4.17:Chức năng lưu lại lịch sử thông báo của hệ thống
- Phần “Model Robot”: Phần này sẽ hiển thị mô hình hoạt động của Robot trong không gian 3 chiều. Các điểm màu vàng thể hiện vị trí của vật cần gắp, điểm màu đỏ thể hiện vị trí của vật cản và điểm màu xanh là thể hiện vị trí nơi thả vật. Ngoài ra có thể mở rộng góc nhìn ra bằng các nhấn vào nút “More” bên góc trên bên trái để hiển thị các hình chiếu 3 mặt của mô hình giúp người dùng tiện quan sát.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 4.18: Phần hiển thị Robot
Hình 4.19: Phần mở rộng quan sát 3 chiều
- Phần khung ở bên dưới cùng giao diện dùng để hiển thị các thông số về vị trí điểm đầu cuối và giá trị các góc khớp trong quá trình hoạt động.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 4. THI CÔNG HỆ THỐNG
Hình 4.20:Phần hiển thị thông số thực của Robot
Trong quá trình làm việc nếu có bất gì sự cố gì xảy ra, giao diện sẽ xuất ra một cửa sổ Pop-up để thông báo. Các thông báo này sẽ có các dạng như “Warning”, “Error”, “Questions”, …nhằm cảnh báo lỗi khi động cơ quá tải hoặc là cảnh báo khi nhập sai dữ kiệu điều khiển. Tất cả các cảnh báo Pop-up đều sẽ được lưu lại trong Mục “History” với ngày, giờ và tên cụ thể của các sự kiện.
Hình 4.21:Các hộp thoại trong quá trình sử dụng.
4.3.2. Nhận diện vị trí vật từ camera
Sau khi đã hiệu chỉnh dựa theo thuật toán đã nêu ở cơ sở lý thuyết, hai camera sẽ trả về tọa độ vị trí của vật cần nhận diện (vật cần gắp hoặc vật cản) trong không gian hoạt động của Robot. Tọa độ này sẽ được gửi đến máy tính và hiển thị lên giao diện trong khu vực hiển thị mô hình Robot để có thể tương tác trực tiếp. Vị trí của các vật sẽ được đánh đấu hiển thị bằng các dấu chấm màu trong không gian Oxyz.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 4.22:Vị trí của vật thể được hiển thị trong giao diện.
BỘ MÔN ĐIỆN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 5. KẾT QUẢ THỰC HIỆN
Chương 5. KẾT QUẢ THỰC HIỆN
5.1. Mô phỏng kiểm chứng bằng Matlab.5.1.1. Động học thuận. 5.1.1. Động học thuận.
Để mô phỏng động học thuận ta lấy các thông số về phần cứng sẵn có như mô hình thực về chiều dài đề cập trong Bảng 2.2 và các vị trí góc đầu vào như sau:
Bảng 5.1: Thông số đặt các khớp
Kết quả sau khi chạy mô phỏng động học thuận như hình 5.1.
Hình 5.1:Mô phỏng kiểm chứng động học thuận
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
Với kết quả mô phỏng trên matlab ta có thể biết được tọa độ vị trí đầu cuối của Robot là x = 0.305 m, y = 0 và z = -0.046 m. Tư thế Robot và góc đo trả về cho biết kết quả mô phỏng là chính xác.
5.1.2. Động học nghịch.
Các thông số về Robot được dùng để giải động học nghịch vẫn giống như phần động học thuận sử dụng ở trên, tiếp theo ta cung cấp cho bộ giải nghịch vị trí và hướng của điểm đầu cuối như sau:
Bảng 5.2: Nhập các giá trị vị trí ban đầu
Vị trí
Góc xoay so với hệ trục gốc
Kết quả mô phỏng:
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 5.3:Giá trị các góc sau khi giải động học nghịch.
Để kiểm tra tính chính xác của kết quả các góc tính ra như trong hình 5.3, ta thay ngược giá trị góc tính ra lên bộ giải động học thuận ở phía trên, kết quả tính ra như sau:
Hình 5.4:Kiểm tra kết quả giải động học nghịch.
Như vậy vị trí điểm đầu cuối tính ra là x = 0.2 m, y = 0.3 m và z = -0.1 m, trùng với đầu vào mong muốn ở trên nên kết quả mô phỏng giải nghịch là chính xác.
Có thể thấy, với một điểm làm việc mong muốn, bộ giải động học nghịch có thể tính ra một bộ nghiệm bất kỳ trong vô số các bộ nghiệm, và tư thế bộ nghiệm này có thể tùy chỉnh nhờ vào việc chỉnh các thông số cập nhật hoặc thêm điều kiện cập nhật, tạo điều kiện thuận lợi cho việc cung cấp tín hiệu chạy online kết hợp với bộ điều khiển.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 5. KẾT QUẢ THỰC HIỆN
5.2. Chạy thực nghiệm động học nghịch Robot
Sau khi đã giải quyết chính xác bài toán động học nghịch, nhóm sẽ tiến hành nạp chương trình Arduino để điều khiển mô hình Robot chạy thực nghiệm, chương trình điều khiển được thể hiện trong phần phụ lục. Các góc sau khi tính ra sẽ đem làm đầu vào của bộ quy hoạch quỹ đạo cho Robot, đầu ra của quy hoạch qũy đạo sẽ là tín hiệu điều khiển chuyển động cho Robot.
Bảng 5.3:
Vị trí
Góc xoay so với hệ trục gốc
Sau khi đã kiểm tra đầy đủ mọi yêu cầu về điện, ta tiến hành nạp code chạy phát xung mô hình Robot lần 1:
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 5.6:Góc nhìn cạnh sau khi chạy nghịch lần 1.
Chạy lần 2: thử với một hướng khác của vị trí điểm đầu cuối đó
= 90o , = 0, = 0 cho ra kết quả như sau:
Hình 5.7:Góc nhìn mặt và cạnh sau khi chạy nghịch lần 2.
Nhận xét: Cả hai lần chạy thời gian đáp ứng vào khoảng 15 s, tuy đáp ứng của hệ thống không được nhanh nhưng với giá trị các góc phản hồi về tính ra cho thấy hai trường hợp chạy đều đến cùng 1 vị trí với hai hướng đúng như mong muốn đặt ra.
5.3. Chạy mô phỏng Robot né vật cản.
Do đại dịch Covid19 ập đến quá bất ngờ, nên nhóm không thể tiếp cận với mô hình thực nghiệm và nhóm đã quyết định mô phỏng thực tế ảo khả năng né vật của Robot lên giao diện, vị trí vật cản và vật gắp chính là tín hiệu thực đọc từ camera trả về.
Ta quy ước điểm màu vàng là vật gắp, điểm màu đỏ là vật cản và được nhóm điều chỉnh tiến tới Robot bằng tay phía bên ngoài. Điểm làm việc mong muốn là: x = 0.3 m,
y = 0 m và z = 0.01 m; = 180°, = 0, = 0.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 5. KẾT QUẢ THỰC HIỆN
Hình 5.8:Mô hình làm việc với vật cản nằm ngoài phạm vi ảnh hưởng.
Hình 5.9:Mô hình làm việc đồng thời né vật cản ở phần thân Robot.
Qua kết quả mô phỏng có thể thấy Robot vẫn có khả năng làm việc trong khi có vật cản tác dụng lên phần thân trên, giá trị vị trí và hướng điểm đầu cuối trả về trong hình 5.9 cho thấy sự sai lệch là không đáng kể cả khi bị tác động. Đây chính là minh chứng cho tính linh hoạt khi làm việc, là đặc điểm làm rõ nhất ứng dụng của mô hình Robot 7 bậc tự do này so với những Robot ít bậc tự do khác.
Trong trường hợp tiếp theo, nhóm sẽ đưa vật cản màu đỏ lại gần điểm làm việc màu vàng để tiếp tục thử nghiệm khả năng tránh né của Robot.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
Hình 5.10:Mô hình làm việc với vật cản nằm ngoài phạm vi ảnh hưởng.
Hình 5.11:Mô hình né vật cản tại điểm đầu cuối Robot.
Kết quả chạy trong hình 5.11 cho thấy khi vật cản tiến lại gần điểm làm việc của Robot thì điểm đầu cuối sẽ di chuyển ra xa điểm làm việc. Điều này cho thấy thuật toán sẽ ưu tiên việc tránh vật cản hơn đáp ứng yêu cầu điều khiển giúp bảo vệ Robot tốt hơn trong các điều kiện làm việc phức tạp, nhiều chướng ngại vật di động trong không gian làm việc.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
CHƯƠNG 6. KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN
Chương 6. KẾT LUẬN VÀ HƯỚNG PHÁT TRIỂN
6.1. Kết luận.
Nhìn chung các mục tiêu đã đề ra từ đầu đã được giải quyết:
• Tính toán, mô phỏng động học nghịch của Robot trên phần mềm Matlab.
• Thiết kế, chế tạo và lắp ráp hoàn thiện mô hình thực nghiệm Robot 7 bậc tự do.
• Điều khiển được các khớp Robot 7-DOF chính xác vị trí cho trước với tính linh hoạt khi làm việc.
• Nhận diện vị trí vật bằng camera.
• Thực hiện thiết kế giao diện giám sát và điều khiển trên Qt creator
• Nghiên cứu và sử dụng Board vi điều khiển Arduino Due kết hợp với các ngoại vi.
• Nghiên cứu và sử dụng bộ động cơ AC servo Mitsubishi J3
6.2. Hướng phát triển.
Về khả năng phát triển của đề tài, nhóm đã có những ý tưởng trong tương lai cho Robot linh hoạt 7 bậc tự do như sau:
• Tối ưu năng lượng tiêu thụ trong quá trình chuyển động.
• Kết hợp các ràng buộc nhất định về phần cứng các khớp khi làm việc.
• Tăng khả năng đáp ứng nhanh của mô hình.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
TÀI LIỆU THAM KHẢO
[1]. John J. Craig (2005). Introduction to Robotics: Mechanics and Control, Third Edition, Pearson Education International, Saddle River.
[2]. Huỳnh Thái Hoàng (2006). Giáo trình Hệ thống điều khiển tự động, Nhà xuất bản Đại học quốc gia TP. Hồ Chí Minh, TP. Hồ Chí Minh.
[3]. ROGER Y. TSAI (1985). A Versatile Camera Calibration Techniaue for High- Accuracy 3D Machine Vision Metrology Using Off-the-shelf TV Cameras and Lenses, IEEE JOURNAL OF ROBOTICS AND AUTOMATION, 3(4), 323-344.
[4]. OpenCV OpenSource Computer Vision 4.5.2 (2021). Camera Calibration, <https://docs.opencv.org/4.5.2/dc/dbb/tutorial_py_calibration.html>, xem 01/08/2021.
[5]. SEBASTIAN RUDER (2016). An overview of gradient descent optimization algorithms, <https://ruder.io/optimizing-gradient-descent/>, xem 01/08/2021.
[6]. Stanford University (2008). Lecture 12 Basic Lyapunov theory,
<https://web.stanford.edu/class/ee363/lectures/lyap.pdf>, xem 01/08/2021.
[7]. Yiming Yang, Vladimir Ivan, Sethu Vijayakumar (2015). Real-Time Motion Adaptation using Relative Distance Space Representation, Proc. 17th IEEE International Conference on Advanced Robotics.
[8]. Jeff Kerr (2019). Anti-Backlash Compound Planetary Gearhead, <https://www.thingiverse.com/thing:3566678>, xem 01/08/2021.
[9]. N. D. H.Phú, V. N. Thông (2020). Thiết kế Robot 5 bậc tự do sử dụng xử lý ảnh có quy hoạch quĩ đạo tối ưu. Luận án tốt nghiệp đại học chuyên ngành Kỹ sư điều khiển và tự động hóa, Trường đại học Sư phạm kỹ thuật.
[10].D. S. Binh, K. L. Thanh, D. P.Nhien, and D. X. Ba (2020). An intelligent inverse kinematic solution of universal 6-DOF Robots. In International Conf. on Green Technology and Sustainable Development, 107-116.
BỘ MÔN TỰ ĐỘNG ĐIỀU KHIỂN
PHỤ LỤC
PHỤ LỤC
Datasheet
Driver MR J3 Mitsubishi:
https://mitsubishielectric.com/document/manual/servo/mr-j3.pdf
Động cơ AC servo HF-KP13 Mitsubishi:
http://mitsubishielectric.com/document/datasheet/servo/hf-kp13.pdf
Một số Code chương trình
Arduino:
#include <DueTimer.h>
///////////////////////////////////////////////////////////////////////////