-
Notifications
You must be signed in to change notification settings - Fork 13.7k
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
[Bug] Unstable height estimates #24058
Comments
Checking https://review.px4.io/plot_app?log=8122ff4b-e309-41f5-9257-55d74abbdb5d it seems that the estimator is confused because of the inconsistency between baro and range data: see in the plot below that for the baro, altitude above ground after takeoff is 7m (takeoff at 4 and ends at 11m), and for the range finder, motion occurs later and only to 1.5m; then goes down again. |
Hi @bresch , During those tests, we were only focusing on the height, which is the reason why there is barely no horizontal movement. Best regards, Maarten |
The baro is most likely getting airflow from the propellers. If the autopilot is enclosed, it could be that the air pressure inside the body drops as soon as the propellers are starting |
Good morning, Is there a good way to test this, besides trying a lot and noting everything down? |
@bresch thanks for taking a look. This problem has been around for a while although we've tried to fix it a couple of times, it's easily reproducible when flying indoors with an ARK Flow. I'm not very familiar with the estimator/controllers, so I'm hoping I can lean on your expertise. The fundamental issue I believe is the pressurization/prop wash, the idea behind "range aiding" is to alleviate issues with the baro as long as range aiding conditions are met. The param EKF2_RNG_CTRL states
In the shared logs these conditions are met, but range fusion isn't occuring and the rng_hgt_bias is climbing while fusion is disabled. Oddly the cs_rng_hgt flag is always true, the rng_hgt_bias stops climbing once baro fusion is disabled, but at this point we're already overshot the takeoff altitude |
I'm trying to test here at home and discovered that the home reference altitude is unset when there's no GPS. Probably related, I think there is more than 1 issue going on. We should probably get optical flow into gz sim so we can start testing it more regularly. |
Hi everyone, |
@mkesselaers could you also share those logs please? |
@bresch Off course. Test with RNG_CTRL off : https://review.px4.io/plot_app?log=59b01c16-8ac9-44cf-b45d-d86b2ad3b4d2 |
I met a similar issue,in this log, from 134.5s to 164.5s, Distance sensor and baro alt change is about 2m, but local position z change is less than 0.5m. Very strange. |
The baro is still the problem here as its measurement increases by almost 7m as soon as the drone ramps up the thrust. This change in altitude is initially rejected, but the estimate eventually follows this measurement as the baro is the height reference. If this is an indoor flight and the floor is mostly at the same height, you could set the height reference to "range". |
Would it make more sense to change takeoff altitude to AGL? |
If possible, I think it would lead to nicer takeoffs, yes. |
This issue has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there: https://discuss.px4.io/t/vehicle-doesnt-preserve-its-height-in-offboard-mode/43053/6 |
This issue has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there: |
This issue has been mentioned on Discussion Forum for PX4, Pixhawk, QGroundControl, MAVSDK, MAVLink. There might be relevant details there: |
@PX4/testflights can you please try to reproduce with your hardware? |
@mrpollo is there a specific branch or PR that I can build to test as well? |
This should be reproducible in both v1.15 stable and v1.15-alpha |
Appears that we are seeing the same. The estimates that are being sent back to QGC are reflective of inaccurate height estimates during flight. Video: https://www.loom.com/share/141ee5ee32f64e519b5aaf798f495941?sid=f34c75a7-4a02-4fea-be0c-6a24d3742b98 The height estimate was all over the place on QGC. to accurately do a takeoff test to 2m we would have to write a small script as QGC minimum is 10m. But, let us know what modifications need to be done to retest and get more data. |
Describe the bug
We are using an ARK Pi6xFlow without GPS and are trying to reliable takeoff to 2 meters.
We use both EKF2_BARO_CTRL as EKF2_RNG_CTRL and the HGT_REF is set to barometric.
When taking off, sometimes it goes to 2m, but most of the time to somewhere between 3 and 5.
Using 1.16.0 alpha, the height was around 1m
To Reproduce
Expected behavior
Go to the correct height (more or less since exact would be impossible off course)
Screenshot / Media
No response
Flight Log
barometric hgt ref (result 3.2m): https://review.px4.io/plot_app?log=514ae575-9d2e-4687-ab55-6e8836979b02
Range hgt ref (result 2m) https://review.px4.io/plot_app?log=b3753550-44ac-439a-905b-933f7a3932c3
Using 1.16.0 alpha : https://review.px4.io/plot_app?log=8122ff4b-e309-41f5-9257-55d74abbdb5d
Software Version
release 1.15.0 stable
One test with 1.16.0 alpha
Flight controller
ARK Pi6xFlow board (Dexi Airframe from DroneBlocks)
Vehicle type
Multicopter
How are the different components wired up (including port information)
ARK board to ESC to Motors.
Pi CM4 on ark-board, using MicroUXCREAgent to transform UORB to ROS2 topics.
RC and a LED ring are connected to the ARK board as well
Additional context
After takeoff, the height should remain stable, regardless of what the terrain is doing.
That's why we want to use barometric height reference, since a distance sensor will cause problems.
We're also adding VIO using markers, but don't believe that this would be more reliable then a barometer
The text was updated successfully, but these errors were encountered: