Augmentations ============= Quadruped A1 can be upgraded with different sensros and some other accessories. These upgradations require some modifications in the robot software which is detailed below. Ouster Installation ------------------- .. image:: media/accessories/ouster.png For the ouster attachment, the following package has to be installed in the current workspace. The following `tutorial `__ can be followed or the provided description. **Note: This tutorial is to only be followed if the ouster software is not already pre-installed.** 1. Install dependencies: .. code:: bash sudo apt install -y build-essential libeigen3-dev libjsoncpp-dev cmake .. code:: bash sudo apt install -y ros-$ROS_DISTRO-pcl-ros ros-$ROS_DISTRO-rviz ros-$ROS_DISTRO-tf2-geometry-msgs 2. Create a new folder in your catkin workspace ``src`` folder named ``third_party``: .. code:: bash cd ~/catkin_ws/src mkdir third_party cd third_party 3. Clone the repository into ``utils``: .. code:: bash git clone --recurse-submodules https://github.com/ouster-lidar/ouster-ros.git 4. Create your workspace afterwhich you can start configuring the Ouster: .. code:: bash cd .. catkin build source devel/setup.bash 5. Connect the ouster with an ethernet cable, and follow the instructions provided in the `software user manual `__ chapter 2. - It may take ~5 mins for it to be detected. 6. Next navigate to the ``utils`` (if the ouster pkg is provided by us) and in there open a terminal and run: .. code:: bash chmod +x set_static_ip.py python3 set_static_ip.py 7. Then make open up your ethernet connection that is in the settings and add a new connection. Give your desired name and then navigate to the ``IPv4`` tab. In it change the connection to ``Manual``. In the ``Addressess``, give the address as ``192.168.123.2`` and the net mask as ``255.255.255.0``, and save. Then connect to this ip. - Verify that the computer is receiving data from ouster via: catkin build source devel/setup.bash 8. Add a new launch file called ``ouster.launch`` to the ouster-ros package in the launch directory, and configure the Lidar to your IP and your specifications: .. code:: bash 9. Verify installation via: .. code:: bash roslaunch ouster_ros ouster.launch viz:=true ZED2 Installation ----------------- This procedure requires that the A1 has access to internet for initial installation if not done already. Requirements ~~~~~~~~~~~~ - Zed Camera - Internet connection - Access to the Nvidia onboard A1 (The connectors next to the A1’s head) Procedure ~~~~~~~~~ 1. Verify CUDA 10.2 is installed in the Nvidia Xavier Tegra board. - ``nvcc -V`` 2. If not installed follow: .. code:: bash wget https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64/cuda-ubuntu1804.pin sudo mv cuda-ubuntu1804.pin /etc/apt/preferences.d/cuda-repository-pin-600 wget https://developer.download.nvidia.com/compute/cuda/11.6.0/local_installers/cuda-repo-ubuntu1804-11-6-local_11.6.0-510.39.01-1_amd64.deb sudo dpkg -i cuda-repo-ubuntu1804-11-6-local_11.6.0-510.39.01-1_amd64.deb sudo apt-key add /var/cuda-repo-ubuntu1804-11-6-local/7fa2af80.pub sudo apt-get update sudo apt-get -y install cuda 3. Install from the provided QRE package, alternatively you may get the latest version and install from ZED SDK - Make sure the Ubuntu version is the 18.04, the CUDA is 10.2, and the Nvidia Xavier SDK is selected for your download 4. Build the provided ZED ROS packages. - ``catkin build`` 5. Verify installation by running - ``roslaunch zed_wrapper zed2.launch`` - ``roslaunch zed_display_rviz display_zed2.launch`` Updating URDF ------------- The robot's upgradation also require the changes to be reflected in URDF. These changes can be made in ``qre_a1_description``. The main to look at is ``xacro/accessories.xacro``, here one can add joints, other xacro's etc. Also make sure to add the respective ``ENVIRONMENT VARIABLES`` in ``config/robot/qre_a1`` from which by enable or disable the link the changes in the final URDF can be shown.