Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sensors Status Panel #470

Closed
wants to merge 122 commits into from
Closed

Sensors Status Panel #470

wants to merge 122 commits into from

Conversation

nathanaelren
Copy link
Contributor

@nathanaelren nathanaelren commented Oct 20, 2023

Closes #450 Sensors Status Panel

Ft. Nathan, Mathew, Satvik

@nathanaelren nathanaelren linked an issue Oct 20, 2023 that may be closed by this pull request
11 tasks
@nathanaelren
Copy link
Contributor Author

very modular code. approved.

@SatvikMatta SatvikMatta self-assigned this Nov 2, 2023
@maxwellmlin maxwellmlin marked this pull request as ready for review November 4, 2023 01:15
@maxwellmlin maxwellmlin added the gui Related to robot GUI label Nov 4, 2023
@maxwellmlin maxwellmlin modified the milestones: Spring 2024, Fall 2023 Nov 4, 2023
@maxwellmlin maxwellmlin force-pushed the sensors-status-panel branch 2 times, most recently from 056e11f to 7aedf4b Compare November 4, 2023 01:49
@maxwellmlin maxwellmlin changed the title Sensors status panel Sensors Status Panel Nov 4, 2023
@maxwellmlin maxwellmlin self-assigned this Nov 4, 2023
Knicey and others added 26 commits November 4, 2023 12:33
Co-authored-by: 2Ahmad5 <[email protected]>
Co-authored-by: RaulGalvez288 <[email protected]>
Co-authored-by: Maxwell Lin <[email protected]>
Co-authored-by: Satvik Matta <[email protected]>
In theory it should work
This PR adds the `foxglove` directory which contains our custom Foxglove extensions and layouts.

3 example extensions are included:
- `call-service-panel`: Example panel that lets you call services
- `publish-topic-panel`: Example panel that lets you publish topics
- `subscribe-topic-panel`: Example panel that lets you subscribe to topics and see the raw message feed

1 layout is included:
- `controls-monitor.json`: 6 graphs for each control axis (x, y, z, roll, pitch, yaw) plotting setpoint and control effort against time. Used to test responsiveness of robot during PID tuning.

To install our custom layouts and extensions, use our `foxglove.py` CLI:
```bash
python foxglove.py install
```

This PR has been tested on Mac, Windows, and Linux.
Made topic a hover tooltip
Made more compact overall

Co-authored-by: Nathanael Ren <[email protected]>
Co-authored-by: Mathew Chu <[email protected]>
Co-authored-by: RaulGalvez288 <[email protected]>
Co-authored-by: Nathanael Ren <[email protected]>
Co-authored-by: Mathew Chu <[email protected]>
Co-authored-by: RaulGalvez288 <[email protected]>
Co-authored-by: Maxwell Lin <[email protected]>
* Initial template

* Update version

* Implement toggle-controls-panel

Co-authored-by: Nathanael Ren <[email protected]>
Co-authored-by: Mason Wu <[email protected]>
Co-authored-by: calvinlchen <[email protected]>
Co-authored-by: roguerreiro <[email protected]>
Co-authored-by: Hung Le <[email protected]>

* Fix numerous bugs relating to context

* Use MUI Alert

* Update

* Cross-platform install script

* Add final print

* Add linebreak between extensions

* Fix alert not showing up bug

* Update component names

* add todo

* Cross platform

* Typo

* Lint

* added disabling if context.callService not available

* Arduino disconnect fix -- migrated one ROS node to raw serial (#464)

* Set default button state to disabled

* Initial framework

* Always show all 4 rows

* Update READMEs

* Refactor hardcoded topic types

* Rename variable

* modified labeling in detection visualizer class

* Made camera hard reset executable

* Only update on camera_relay_status publish

* Move button setEnable to clock

* Finished 4 tasks in RQT Launch Plugin Improvements issue, haven't tested the last two yet

* looked over everything with Rico for CV

* Removed unnecessary translations

* Added launch args for show class name and show confidence to simulate detection

* finished testing for remove_nodes_manually and running_status_column

* fixed sonar.launch

* hello

* minor changes

* minor changes

* Remove relay from table

* Remove relay from table

* Fix hardcoded topic names

* Remove relay topics on close

* Move button to right

* added test_id

* fixed the launch sonar file by adding port

* Finished remaining tasks in RQT Launch Plugin Improvements

* Revert: use relay in table

* Refactor

* fixed bug

* finished incorporating new class & confidence args

* Refactor

* Update default button state

* Revert to original width

* Final cleanup

* Took care of active threads before the widget is closed

* Updated readme file

* added comments to modified code

* changed all instances of camelCase to snake_case

* Implemented functionality to create and remove subscribers when topic becomes active and inactive

* fixed lint errors

* Removed unnecessary models

* Added colors to 2023 models

* Make CV interface load topics from file

* Deleted extra file

* Added extra docker line

* Fixed weights file name of yolov7-tiny

* fixed linter

* fixed subscribers

* Exclude sonar from automatic testing

* added string for oogway

* 1Hz publishing; normally closed relay change

* testing non-smach movement

* updated readme for new relay config

* Pool Test CV Sonar Fixes (#428)

* Removed debug code

* Fixed cv sonar sync issue

* Changed using_sonar to default to True

* Initial changes

* Fix linting

* Finish

* the table updates when display all nodes is checked

* Changed sensor widget to use desired power action

* Resolve merge conflict?

* Created sensors.launch file and removed service call from depthai_spatial_detection

* initialize relay timer

* relay timer

* Passed sonar image upstream

* Fixed sonar_publisher.py

* Fixed sonar_publisher.py

* Changed default sonar settings

* Fixed sensor widget

* Updated sonar topic name

* Fixed sonar_publisher.py

* Fixed sonar_publisher.py

* Added polar images

* Added polar images

* Added polar images

* Fixed RemoteLaunchInfo issue

* Added polar images

* Added polar images

* Fixed RemoteLaunchInfo issue

* Added query for sonar image publisher

* nonsense

* Revert "Merge remote-tracking branch 'origin/cv-launch-plugin' into pool-test-apr-22"

This reverts commit 8715133.

* this is the coolest commit ever

* Manually patch remote_launch fix

* Fix typos in buoy task

* Fix typos in buoy task

* Please stop replacing our working code with test code

* Changes made at pool test

* Added main yolov8n and yolov7-tiny models

* Implement custom_autodiscovery

* Update docs

* Ensure active topic thruster_controls publishes to

* linted code

* Add nmap to dockerfile

* Add readme2

* Update README2.md

* Update README2.md

* update

* Update rm2.md

* Update README2.md

* Readme2.md

* Swap x, y; negate z

* deleted pressure sensor error message

* imu quat changes

* added fixes to robot_localization

* example pressure sensor

* Thruster temp

* Sh scripts

* Remove comma

* Add depth to sensor_fusion

* Change air pressure

* Sync

* Comment out thruster publish log

* Pool test changes (global state works!)

* Fix state by negating y_vel

* Change baud rate

* remove ?

* added dual serial thruster code

* stuff

* dual arduino, consistent thruster speeds, pressure included

* Update README.md

* Update test_state_publisher.py

* Update README.md with dual_upload

* the best readme

* cleaned arduino code, arduino readme

* Rename pressure_converter to pressure_stamper

* Delete

* noted pressure stamping in readme

* CV sonar syncing

* Flipped bottom thrusters in oogway config

* Disabled all Z inputs to state except pressure sensor

* Changes to PID constants to hold depth

* Sonar update

* Jank code to move to CV in test state publisher

* updated angle algorithm

* Fixed minor issue with angle offset calculation

* Added constant sonar sweeping

* task_planning code

* Part 1 of Big Changes to CV Task Planning

* adding task planning

* Added vectornav package

* unflipped bottom thrusters

* Adjusted velocity PID

* Adjusted local pose goal in test state publisher

* Commented IMU out of data pub

* Added hard cap to pressure sensor

* Changed IMU sensor fusion config to use vectornav

* commit test_state_publisher.py

* Position PID

Co-authored-by: vedarshshah <[email protected]>
Co-authored-by: gummydumpling-2001 <[email protected]>
Co-authored-by: Will Denton <[email protected]>

* Test state pub

* Add usb camera

* Add sensors, vectornav

* Remove velocity pid

* Fix sonar

* Fix arduino connect?

* Add record sh

* Gate task

* bugfix

* commit record

* comp stuff

* Added y offset angle

* Updated sonar message

* Fix tmux run.sh

* Save changes before pool test

* Using camera for robot y

* Forgot tuples are immutable lol

* Updated tmux script

* New arduino

* Negated sonar Y

* Changed sonar range to 5

* Removed unused code and updated cv gate

* Revert "Change controls to use ROS Actions (#383)"

This reverts commit 3850fbb.

* Move in steps

* Use topics

* Use topics not actions

* REMOVE SONAR

* Test state with topics

* Increase roll, pitch

* taskplanning

* Fixed deg to rad conversion

* test state publisher updates

* fixed bug for desired_state.py

* move through gate with style

* fixed dead reckon gate with style

* Updated CV GUI perspective file

* Add

* hello

* serial pressure reader

* yes

* yes

* yes

* yes

* yes

* yes

* yes

* yes

* Removed pressure arduino from offboard comms launch file and added new pressure script to data pub launch file

* Changed pressure sensor topic to sensors/depth

* arduino serial for pressure, no ros

* changed port

* arduino no longer disconnects

* updated readme for data pub and offboard comms

* checkout to master for all non-depth changes

* removed files

* forgot to re-change actual changes

* other data_pub changes removed

* removed pressure_stamper changes from pr

* fixed comments and deleted IMU files

* added FTDI string for pressrue sensor

* fuck the linter

* fuck the linter x2

* fuck the linter x3

* fuck the linter x4

---------

Co-authored-by: Maxwell Lin <[email protected]>
Co-authored-by: Rico Zhu <[email protected]>
Co-authored-by: Amir Ergashev <[email protected]>
Co-authored-by: Oogway <[email protected]>
Co-authored-by: gummydumpling-2001 <[email protected]>
Co-authored-by: Ethan Horowitz <[email protected]>
Co-authored-by: Cthulhu <--global>
Co-authored-by: Will-Denton <[email protected]>
Co-authored-by: Brokemia <[email protected]>
Co-authored-by: Vedarsh Shah <[email protected]>
Co-authored-by: Michael Bryant <[email protected]>
Co-authored-by: Rico Zhu <[email protected]>
Co-authored-by: Will Denton <[email protected]>
Co-authored-by: vedarshshah <[email protected]>
Co-authored-by: gummydumpling-2001 <[email protected]>
Co-authored-by: Will Denton <[email protected]>
Co-authored-by: AndrewCouncil <[email protected]>
Co-authored-by: wrd10 <[email protected]>

* dual upload removed tabs (#467)

Co-authored-by: Michael Bryant <[email protected]>

* Delete

* Update to template

* Update deps

* Add watch

* Fix ts bug

* Change eslint to json and add endofline auto

* Update actions

* Add comment linting

* Fix lint bug

* Format

* Add comments

* Finish

* Finish

* Format

* Address PR

* Type response and error on failure

* Increase comments

* Update comments

* Update comments

* Use box instead of div

---------

Co-authored-by: Maxwell Lin <[email protected]>
Co-authored-by: Nathanael Ren <[email protected]>
Co-authored-by: Mason Wu <[email protected]>
Co-authored-by: calvinlchen <[email protected]>
Co-authored-by: roguerreiro <[email protected]>
Co-authored-by: Hung Le <[email protected]>
Co-authored-by: DRC <[email protected]>
Co-authored-by: Nathanael Ren <[email protected]>
Co-authored-by: Michael Bryant <[email protected]>
Co-authored-by: Maxwell Lin <[email protected]>
Co-authored-by: Rico Zhu <[email protected]>
Co-authored-by: Amir Ergashev <[email protected]>
Co-authored-by: Oogway <[email protected]>
Co-authored-by: gummydumpling-2001 <[email protected]>
Co-authored-by: Ethan Horowitz <[email protected]>
Co-authored-by: Will-Denton <[email protected]>
Co-authored-by: Brokemia <[email protected]>
Co-authored-by: Vedarsh Shah <[email protected]>
Co-authored-by: Michael Bryant <[email protected]>
Co-authored-by: Rico Zhu <[email protected]>
Co-authored-by: Will Denton <[email protected]>
Co-authored-by: vedarshshah <[email protected]>
Co-authored-by: gummydumpling-2001 <[email protected]>
Co-authored-by: Will Denton <[email protected]>
Co-authored-by: AndrewCouncil <[email protected]>
Co-authored-by: wrd10 <[email protected]>
@maxwellmlin maxwellmlin closed this Nov 4, 2023
@maxwellmlin maxwellmlin deleted the sensors-status-panel branch November 4, 2023 16:39
@maxwellmlin maxwellmlin restored the sensors-status-panel branch November 4, 2023 16:40
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
gui Related to robot GUI
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Sensors Status Panel
8 participants