2023-06-26 Alarm Task 13.1 Meeting 13

 

Summary

  1. Iepusho GIT package.json izmaiņas, vienam package versijas limitācijas nomainījām kopā ofisā

  2. Iziet cauri “Alarm testing tutorial” dokumentēt, ja tur ir kāda kļūda

  3. Zemāk uzdevumi

 

Alarm testing tutorial

Schema of system in test facilities

ROS topics_
HTTP POST
Mobile App_
ROS node, Pyhsical drone_
Backend server_

Schema of system in simulation mode

HTTP POST, ROS topics_
Mobile App_
Backend server, ROS node_

Robot drone is based on ROS 1 (Robot Operating System) it communicates with Mobile app via ROS topics and actions. ROS node has rosbridge as web-socket platform for app to communicate using roslib JS. On ROS node there are several python based action servers like /alarm_watchdog_mapping_ros_node_start which are made by ASYA.

 

Backend server is based on FastAPI python, main function for backend server is to process raw point-cloid and drone path into processed and optimized versions of point-cloud and walls. Also Room detection is in the plan (these modules are made by Reinis from Ventspils office)

Simulation server which also serves as Backend server.

Access server using SSH (on Windows Kitty / Putty software + WinSCP or FileZilla) Ar WinSCP vai FileZIlla var augšupielādēt failus / bag files

host: 144.24.250.72:22 user: ubuntu key: alarm-flight-ros-20.4.key (sent seperately)

Node is headless Ubuntu, look at useful commands, especially screen ( Common Linux Commands for console http://share.yellowrobot.xyz/website/2021-12-06%20Linux%20Commands%20Useful.html)

⚠️ DO NOT KILL accidentally screens be careful to disconnect from them correctly. Disconnect from screen using Ctrl+A, then press D

In console there are multiple workers running in screen -ls

  1. screen -rd worker_backend Backend worker that processes the maps cd ~/Documents/app_backend_server`` ``conda activate alarm_flight_ui python ./WorkerMapProcessor.py

  1. screen -rd backend Backend FastAPI HTTP REST interface cd ~/Documents/app_backend_server`` ``conda activate alarm_flight_ui python ./main.py -is_debug False

  2. screen -rd rosbridge Relay service for websockets from ROS to app 🔴 This might need to be restarted, stop process using Ctrl+C, but do not stop screen

    cd ~/Documents/alarm source ./devel/setup.bash

    roslaunch rosbridge_server rosbridge_websocket.launch

  3. screen -rd docker Screen for building docker containers for backend (not needed now)

  4. screen -rd vnc server for debugging (not needed now)

  5. You can also run scripts directly in console without using screens but they will terminate as soon as you close SSH connection to server

 

Replay topics from existing bag files for testing /home/ubuntu/Documents/bags

Latest script to test: rosbag play /home/ubuntu/Documents/bags/2023-06-22-flight3-angle-off-Asya_v27_F3.bag

You can pause/play with space button, useful for debugging.

Also can skip for example first 100sec

rosbag play /home/ubuntu/Documents/bags/2023-06-22-flight3-angle-off-Asya_v27_F3.bag -s 100

Step  
1image-20230626234145489Add new map
2image-20230626234223547 
3 Restart rosbridge in screen rosbridge on server (as described above)
4image-20230626234316461 
5 Run rosbag play file that contains point-cloud and drone-path rosbag play /home/ubuntu/Documents/bags/2023-06-22-flight3-angle-off-Asya_v27_F3.bag
6image-20230626234406424Wait for backend server to process map
7 Make sure you use map just generated
8image-20230626234517383Connect in normal operation mode
9image-20230626234635863Run rosbag play file rosbag play /home/ubuntu/Documents/bags/2023-06-22-flight3-angle-off-Asya_v27_F3.bag -s 400


And observe drone movements
10image-20230626234911236Stop bag file and try in simulation mode (app side only) adding POIs press and hold points on map
11image-20230626234936595Add POIs to mission and run mission in simulation mode
12image-20230626235027892Check if UI updates correctlu

 

 

Alarm tasks

 

  1. Atrodi šos dialog boxes un npņem nost auto-complete no text edit laukiem - ļoti traucējoši šobrīd

image-20230626234851261

  1. In mapping mode savest kārtībā Log panel un WIFI status utt - pārbaudi, ka tie parādās tā, ka tos var redzēt gan vertical, gan horizontal Bag file ar topics kuriem jābūt redzamiem, kamēr notiek mapping process.

    http://share.yellowrobot.xyz/quick/2023-6-16-E1B689A2-E6EA-4A05-ADBC-A10ACDEB82CA.zip

    image-20230626235222365

    image-20230626235557678

    image-20230626235616181

Izmantojot esošās komponentes panākt, ka log izskatās šādi šajā mapping skatā

image-20230626235708277

Kad atver jārada log bet ne kā normal operatoin control screen, bez Missions, tikai Log image-20230626235814065

Sadalīt kodu loģiskās komponentēs

 

  1. Palaist app uz Android device (fiziska telefona) un pārliecināties, ka Gyroscope līmenis korekti strādā, šobrīd nestrādā korekti, bremzējas un tikai uz vienas ass mainās līmeņa izvietojums, nepieciešams, ka telefonu jātur

    image-20230627000023063

     

    image-20230627000202393

    image-20230627000246794