{"id":30134791,"url":"https://github.com/waveshareteam/wavego_pro","last_synced_at":"2026-04-16T10:31:22.425Z","repository":{"id":271962799,"uuid":"915117693","full_name":"waveshareteam/WAVEGO_Pro","owner":"waveshareteam","description":"WAVEGO, 12-DOF Bionic Dog-Like Robot, Open Source for ESP32 and Raspberry Pi, Facial Recognition, Color Tracking, Motion Detection","archived":false,"fork":false,"pushed_at":"2025-07-29T05:18:43.000Z","size":26019,"stargazers_count":11,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-04-09T01:33:08.375Z","etag":null,"topics":["12-dof","arduino","arduino-esp32","dog","esp32","open-source","opencv","raspberry-pi","robot"],"latest_commit_sha":null,"homepage":"","language":"Jupyter Notebook","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"gpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/waveshareteam.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-01-11T02:41:45.000Z","updated_at":"2026-03-15T14:30:39.000Z","dependencies_parsed_at":"2025-01-11T03:36:53.653Z","dependency_job_id":"9bd7ccfa-ec0d-40bf-9d4b-dc4a9086ce51","html_url":"https://github.com/waveshareteam/WAVEGO_Pro","commit_stats":null,"previous_names":["effectsmachine/wavego_pro","waveshareteam/wavego_pro"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/waveshareteam/WAVEGO_Pro","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waveshareteam%2FWAVEGO_Pro","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waveshareteam%2FWAVEGO_Pro/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waveshareteam%2FWAVEGO_Pro/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waveshareteam%2FWAVEGO_Pro/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/waveshareteam","download_url":"https://codeload.github.com/waveshareteam/WAVEGO_Pro/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/waveshareteam%2FWAVEGO_Pro/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31881975,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-16T09:23:21.276Z","status":"ssl_error","status_checked_at":"2026-04-16T09:23:15.028Z","response_time":69,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["12-dof","arduino","arduino-esp32","dog","esp32","open-source","opencv","raspberry-pi","robot"],"created_at":"2025-08-10T21:39:32.607Z","updated_at":"2026-04-16T10:31:22.392Z","avatar_url":"https://github.com/waveshareteam.png","language":"Jupyter Notebook","readme":"![GitHub top language](https://img.shields.io/github/languages/top/effectsmachine/WAVEGO_Pro) ![GitHub language count](https://img.shields.io/github/languages/count/effectsmachine/WAVEGO_Pro)\n![GitHub code size in bytes](https://img.shields.io/github/languages/code-size/effectsmachine/WAVEGO_Pro)\n![GitHub repo size](https://img.shields.io/github/repo-size/effectsmachine/WAVEGO_Pro) ![GitHub](https://img.shields.io/github/license/effectsmachine/WAVEGO_Pro) ![GitHub last commit](https://img.shields.io/github/last-commit/effectsmachine/WAVEGO_Pro)\n\n# Waveshare Bionic Dog-Like Robot\nOpen Source for ESP32 And PI5/PI4B.\n\n![](./README_footage/main.jpg)\n\n## Basic Description\nThe WAVEGO is a 12-DOF bionic dog-like robot which features 2.3kg.cm large torque bus servos with feedback, reliable structure, and flexible motion, incorporating devices like front camera, 9-axes motion tracker, RGB indicator, etc., together with open source multi-platform Web application. It uses the ESP32 as sub controller for connecting rod inverse solving and gait generation, sharing calculating task for the host controller, an additional Raspberry Pi can be attached as the host controller for high-level decision operating.\n\nThe upper computer communicates with the lower computer (the robot's driver based on ESP32) by sending JSON commands via GPIO UART. The host controller, which employs a Raspberry Pi, handles AI vision and strategy planning, while the sub-controller, utilizing an ESP32, manages motion control and sensor data processing. This setup ensures efficient collaboration and enhanced performance.\n\n## Features\n- Real-time video based on WebRTC\n- Cross-platform web application base on Flask\n- Auto targeting (OpenCV)\n- Object Recognition (OpenCV)\n- Gesture Recognition (MediaPipe)\n- Face detection (OpenCV \u0026 MediaPipe)\n- Motion detection (OpenCV)\n- Color Recognition (OpenCV)\n- Multi-threaded CV processing\n- Shortcut key control\n- Photo taking\n- Video Recording\n\n## Quick Install\nYou can use this tutorial to install this program on a pure Raspberry Pi OS.  \n\n\n### Download the repo from github\n\nYou can clone this repository from Waveshare's GitHub to your local machine.\n\n    git clone https://github.com/waveshareteam/WAVEGO_Pro.git\n    \n### Grant execution permission to the installation script\n    cd WAVEGO_Pro/ugv_rpi/\n    sudo chmod +x setup.sh\n    sudo chmod +x autorun.sh\n### Install app (it'll take a while before finish)\n    sudo ./setup.sh\n### Autorun setup\n    ./autorun.sh\n### AccessPopup installation\n    cd AccessPopup\n    sudo chmod +x installconfig.sh\n    sudo ./installconfig.sh\n    *Input 1: Install AccessPopup\n    *Press any key to exit\n    *Input 9: Exit installconfig.sh\n### Reboot Device\n    sudo reboot\n\nAfter powering on the robot, the Raspberry Pi will automatically establish a hotspot, and the LED screen will display a series of system initialization messages:  \n\n![](./media/RaspRover-LED-screen.png)\n- The first line `E` displays the IP address of the Ethernet port, which allows remote access to the Raspberry Pi. If it shows No Ethernet, it indicates that the Raspberry Pi is not connected to an Ethernet cable.\n- The second line `W` indicates the robot's wireless mode. In Access Point (AP) mode, the robot automatically sets up a hotspot with the default IP address `192.168.50.5`. In Station (STA) mode, the Raspberry Pi connects to a known WiFi network and displays the IP address for remote access.\n- The third line `F/J` specifies the Ethernet port numbers. Port `5000` provides access to the robot control Web UI, while port `8888` grants access to the JupyterLab interface.\n- The fourth line `STA` indicates that the WiFi is in Station (STA) mode. The time value represents the duration of robot usage. The dBm value indicates the signal strength RSSI in STA mode.  \n\n\nYou can access the robot web app using a mobile phone or PC. Simply open your browser and enter `[IP]:5000` (for example, `192.168.10.50:5000`) in the URL bar to control the robot.  \n\nIf the robot is not connected to a known WiFi network, it will automatically set up a hotspot named \"`AccessPopup`\" with the password `1234567890`. You can then use a mobile phone or PC to connect to this hotspot. Once connected, open your browser and enter `192.168.50.5:5000` in the URL bar to control the robot.  \n\n\n### Reboot Device\nIf the program fails to run and encounters errors related to v4l2.py during runtime, you need to delete v4l2.py from both the Python virtual environment and the user environment. This will allow the program to automatically use the system-wide v4l2.py.  \n\n    cd WAVEGO_Pro/ugv_rpi/  \n    sudo rm ugv-env/lib/python3.11/site-packages/v4l2.py  \n    sudo rm /home/[your_user_name]/.local/lib/python3.11/site-packages/v4l2.py  \n\nNow you can restart the main program app.py.\n\n# License\nWAVEGO_Pro for the Raspberry Pi: an open source robotics platform for the Raspberry Pi.\nCopyright (C) 2024 [Waveshare](https://www.waveshare.com/)\n\nThis program is free software: you can redistribute it and/or modify\nit under the terms of the GNU General Public License as published by\nthe Free Software Foundation, either version 3 of the License, or\n(at your option) any later version.\n\nThis program is distributed in the hope that it will be useful,\nbut WITHOUT ANY WARRANTY; without even the implied warranty of\nMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\nGNU General Public License for more details.\n\nYou should have received a copy of the GNU General Public License\nalong with this program.  If not, see \u003chttp://www.gnu.org/licenses/gpl-3.0.txt\u003e.\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwaveshareteam%2Fwavego_pro","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fwaveshareteam%2Fwavego_pro","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fwaveshareteam%2Fwavego_pro/lists"}