Husky PTB ========== .. image:: media/figures/hh.png :width: 100% :align: center :class: mbsrounded | This specifies the configuration for Husky PTB. It has an Phidgets IMU, Ouster & 2x Hokuyo lidar. Table of Contents ----------------- #. `Getting Started <#getting-started>`__ #. `Data Sheets <#data-sheets>`__ #. `Documentations <#documentations>`__ #. `Auxiliary Sensor Startup <#auxiliary-sensor-startup>`__ #. `Network-Setup <#network-setup>`__ #. `Operation <#operation>`__ #. `Steamdeck <#steamdeck>`__ #. `Custom Startup Job <#custom-startup-job>`__ #. `Ouster <#ouster>`__ #. `ZED2i <#zed2i>`__ #. `Autonomous Navigation <#autonomous-navigation>`__ #. `Husky Demo <#husky-demo>`__ Getting Started --------------- To setup-up the Husky, the `instructional video playlist `__ can be used which details the opening and use of the Husky. Data Sheets ------------ * \• `Husky Data Sheet `__ * \• `Ouster Data Sheets `__ * \• `Phidgets IMU Guide `__ * \• `Hokuyo Data Sheet `__ Documentations --------------- * \• `Husky Noetic ROS Docs `__ * \• `Ouster ROS Docs `__ * \• `Phidgets IMU Docs `__ * \• `Hokuyo Docs `__ Auxiliary Sensor Startup ------------------------ On husky startup the following driver is started: * \• Husky base driver The Ouster and two Hokuyo sensors are powered on, but the driver must be initiated manually (automation details provided in the :ref:`RST Custom Startup Job MI`) to ensure a swift startup of the Husky base driver. Both Hokuyo and Ouster driver run when the following commands are run: .. code:: bash roslaunch hsky_lidars lidars.launch Network-Setup ------------- The Husky PTB has multiple networks and vary slightly, the following table shows the networks. .. table:: Husky-PTB network devices ================= =============== ============================ ========= Device Network Address Users/Name Password ================= =============== ============================ ========= Husky 192.168.131.1 administrator mybotshop Hokuyo Front 192.168.131.20 admin N/A Hokuyo Rear 192.168.131.21 N/A N/A Ouster 192.168.131.23 N/A N/A Router IP 192.168.131.100 admin Admin123 Router 192.168.131.100 Husky-A200-0987-2.4G mybotshop ================= =============== ============================ ========= Operation --------- To use the waypoint navigation and drivers, the following steps must be followed: 1. Connect to the Husky WiFi. 2. ssh into the husky via: .. code:: bash ssh -X administrator@192.168.131.1 mybotshop The following message will show up with quick instructions for startup. .. code:: bash ------------------------------------------------------------------------------- _ _ _ _ ____ __ ____ ____ _ _ __ ____ ( \/ )( \/ )( _ \ / \(_ _)/ ___)/ )( \ / \( _ \ / \/ \ ) / ) _ (( O ) )( \___ \) __ (( O )) __/ \_)(_/(__/ (____/ \__/ (__) (____/\_)(_/ \__/(__) ------------------------------------------------------------------------------- Current PC: Nvidia ------------------------------------------------------------------------------- Husky IP: 192.168.131.1 Pswd: mybotshop SSH: ssh -X administrator@192.168.131.1 Hokuyo F IP: 192.168.131.20 Hokuyo R IP: 192.168.131.21 Ouster IP: 192.168.131.23 Router IP: 192.168.131.100 Router Pswd: mybotshop login: admin Pswd: Admin123 ------------------------------------------------------------------------------- Husky Startup ------------------------------------------------------------------------------- HSKY status: sudo service hsky status HSKY start: sudo service hsky start HSKY stop: sudo service hsky stop HSKY restart: sudo service hsky restart Rviz: roslaunch hsky_viz view_robot.launch Ouster + Hokuyo: roslaunch hsky_lidars lidars.launch (Default off) SLAM: roslaunch hsky_navigation slam.launch.py Map Navi: roslaunch hsky_navigation map_navi.launch.py Odom Navi: roslaunch hsky_navigation odom_navi.launch.py Rebuild package: catkin build --cmake-args -DCMAKE_BUILD_TYPE=Release ------------------------------------------------------------------------------- For in-depth instructions the :ref:`RST Quickstart` information is applicable. .. important:: Please be aware to operate the Husky with a fully charged battery; otherwise, low battery power may lead to the reset of the WiFi due to insufficient power. In case of any errors, please execute ``sudo service hsky restart``. Steamdeck --------- .. image:: media/figures/steamdeck.webp :width: 100% :align: center :class: mbsrounded | Steamdeck - Basic Controls ~~~~~~~~~~~~~~~~~~~~~~~~~~ * \• Power button is on the top of the Steamdeck with the power symbol. * \• R2 for mouse left-click * \• L2 for mouse right-click * \• Left trackpad for mouse scrolling * \• Right trackpad for mouse movement * \• L2+R2 for middle mouse button click * \• \- - - (The 3 dashes is located on the top right of the Steamdeck next to the Y button) Hold for 3 seconds to gamepadmode and hold for 2 seconds again to go to desktop mode. * \• Switching to desktop mode activates the cursor for the trackpad as well. Steamdeck Activation ~~~~~~~~~~~~~~~~~~~~ .. Important:: When launching the Joylauncher, do not touch any of the buttons until the steamdeck displays the robot is connected or not connected. 1. Ensure the Steamdeck is connected to the robot's WiFi access point. Wait ~20 seconds after powering up. * \• This is automatically done! 2. Ensure the robot is powered on and operational. 3. Single tap the Joystick Launcher on the screen to activate the controller for the robot. * \• Do not open multiple instances of the joystick launchers, as this can cause zombie nodes to spawn. * \• Hold the - - - for 3 seconds until you sense vibration from the controller and then hold - - - for 3 seconds again. This is required to re-enable the mouse in the steamdeck. 4. Ascento Homing Procedure * \• Ensure the Ascento is flat on the ground. * \• Perform Homing of the Ascento wheels L2+Right (required only at first boot or if the Ascento eyes blink red) * \• Once homed, press L2+Up to stand up the robot. 5. Single tap the Rviz2 Launcher on the screen to visualize the robot. Steamdeck - Termination ~~~~~~~~~~~~~~~~~~~~~~~ Single tap the **ROS2 Clean** to terminate all ROS2 instances only in the steamdeck (It does not effect the robot). Steamdeck - Robot Controls ~~~~~~~~~~~~~~~~~~~~~~~~~~ 1. **L1** is the dead man's switch for slow speed. 2. **R1** is the dead man's switch for high speed. 3. **LJ** (Left Joystick) is to move in x and y direction. .. note:: Loss of connection or (laggy connection) may lead to the robot moving and/or not stopping immediately. Caution should be taken when using the Steamdeck for the operation of the robot! Steamdeck - Rviz2 Controls ~~~~~~~~~~~~~~~~~~~~~~~~~~ 1. **Right trackpad** is used as a mouse 2. **Left trackpad** can be moved up and down to zoom in and zoom out 3. **L2+R2** should be held when wanting to move the orbit in the xy plane. 4. **R2** should be held to orbit around the cursors origin Custom Startup Job ------------------- The launch file ``system_startup.launch`` within the catkin package ``hsky_startup`` encompasses everything launched at startup. The startup job and its contents can be verified in the directory ``/etc/ros/noetic,`` where the original launch file will be copied. .. warning:: Avoid creating multiple startup jobs with different launch files, as this may lead to system instability. It is recommended to have only one launch file that includes all the necessary components. If the systems breaks at startup you can start debugging by: .. code:: bash roslaunch hsky_startup system_startup.launch This will indicate the specific section of the launch file that is encountering errors. Alternatively, you can run each component individually from the launch file in separate terminals to identify and address any issues. Adding ROS-Nodes & Launch Files to Robot Startup ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1. Navigate and open ``hsky_startup/launch/system_startup.launch``. .. image:: media/figures/launch.png :width: 100% :align: center :class: mbsrounded | 2. Include your custom ROS node or launch file. Please note that the image may differ, but the procedure remains the same. .. attention:: An optional step is to launch the file to test if everything is working via: ``roslaunch hsky_startup system_startup.launch`` 3. Run the following script: .. code:: bash rosrun hsky_startup startup_installer.py 4. Verify if it is working correctly via: .. code:: bash sudo service hsky status .. important:: After incorporating your custom node or launch files into the ``system_startup.launch``, execute the command ``rosrun hsky_startup startup_installer.py`` to ensure the startup job on the Husky's PC is updated; otherwise, it will not be applied. Ouster ~~~~~~ .. image:: media/figures/husky_mi_ouster.jpg :width: 100% :align: center :class: mbsrounded | To manually launch the ouster driver, the following command can be used: .. code:: bash roslaunch hsky_lidar ouster.launch.xml Hokuyo ~~~~~~ .. image:: media/figures/hokuyo.png :width: 50% :align: center :class: mbsrounded | To manually launch the Hokuyo driver, the following command can be used. For front Hokuyo: .. code:: bash roslaunch hsky_lidar hokuyo_front_lidar.launch.xml For Rear Hokuyo: .. code:: bash roslaunch hsky_lidar hokuyo_rear_lidar.launch.xml .. note:: The Hokuyo and Ouster lidar drivers are not launched automatically with the "odom_navigation" and "gps_navigation" launch files. Therefore, you must manually launch the lidar drivers first. Autonomous Navigation --------------------- Odom Navigation ~~~~~~~~~~~~~~~~ One can easily initiate basic navigation using the attached phidgets odometry of the husky by executing the command: .. code:: bash roslaunch hsky_navigation odom_navigation.launch This command lets you navigate the robot in the global frame of map Map Navigation ~~~~~~~~~~~~~~~~ To initiate map-based navigation, the process involves mapping the environment first, followed by waypoint navigation. Here are the steps to achieve this: * \• Start creating a map by executing the SLAM navigation command: .. code:: bash roslaunch hsky_navigation slam.launch * \• Simultaneously, in a separate terminal, launch the visualization command to observe the map being constructed: .. code:: bash roslaunch hsky_viz view_robot.launch * \• Utilize the joystick controller to navigate and create the map. Once satisfied with the map, export it using this command in one of the husky’s terminals: .. code:: bash rosservice call /slam_toolbox/serialize_map "filename: '$(rospack find hsky_navigation)/maps/custom_map'" * \• Save map for Adaptive Monte Carlo (AMCL) and/or for Zone Restriction .. code:: bash rosrun map_server map_saver -f "$(rospack find hsky_navigation)/maps/zone_map" * \• Save slam_toolbox as well as zone map .. code:: bash rosservice call /slam_toolbox/serialize_map "filename: '$(rospack find hsky_navigation)/maps/custom_map'" && rosrun map_server map_saver -f "$(rospack find hsky_navigation)/maps/zone_map" * \• After saving the map, rebuild the packages to incorporate the new map: .. code:: bash catkin build ros_ws * \• Upon successful rebuilding, in one terminal, launch the map navigation command to load the saved map: * \• Insert the address .. code:: bash wss://192.168.0.45:8765 After this you should be able to visualize and navigate the robot using foxglove web tool. * \• Finally, in a separate terminal, execute the visualization command to visualize and control the robot via rviz: .. code:: bash roslaunch hsky_viz view_robot.launch Husky Demo ---------- To visualize and navigate the Husky using an online web server, please adhere to the steps outlined below: Initiate the demo launch file by executing the following command in the terminal. This launch file manages the initialization of lidars, web tools, and navigation. .. code:: bash roslaunch hsky_demo system.Launch Ensure that the launch file is executed successfully without encountering any errors before proceeding to the next step, as detailed below. Usage on same network with Google Chrome ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * \• Get server PCs IP i.e. pc that is running the demo which in our case is husky .. code:: bash ifconfig * \• now on your pc go to that address(server pc) .. code:: bash https://(Server IP):8765 * \• It will show as a unsafe page,click advanced and accept the vulnerability for the communication to be established * \• Goto goxglove webpage on google chrome. * \• Insert the address .. code:: bash wss://192.168.0.45:8765 * \• After this you should be able to visualize and navigate the robot using foxglove web tool. .. code:: bash studio.foxglove.dev * \• Insert the address .. code:: bash wss://192.168.0.45:8765 After this you should be able to visualize and navigate the robot using foxglove web tool.