-
Notifications
You must be signed in to change notification settings - Fork 3.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
Very poor performance when moderately large missions are loaded #12236
Comments
Are you able to run the QML Profiler? If not I will do so at some point. I'm not really aware of anything that's changed with any of the mission/plan view stuff so I'll have to look into it further |
I was going to do it and try and fix the issue but I don't have much time at the moment, so I figured I'd just report the issue. I'll do it later if I can |
Maybe is something Windows/Android related, then? I haven't done any profiling but the issue is immediately obvious when compared to the latest stable. |
Unless there is some specific control that has gone whacky there isn't much different in the Plan view Stable -> Daily. |
Tried OSX, don't see anything out of the ordinary |
Windows is working fine for me as well with the example plan from above |
Herelink seems fine as well. Scrolling the waypoint list up/down is a little sluggish but still workable. |
Seems like it might be an issue on my end... I'll see if I can find out the reason this week |
Still odd you would see it on multiple OS |
I'm not able to properly look into it at the moment but here's a video of the issue on a high end Windows: That's the latest 4.4.3 release vs a Release build of the latest master commit at the time of this comment. Note that on the right (latest master) I'm trying to do exactly what I do on the left, but the view is completely stalled. Then I try the drag gestures which seem ever so slightly more responsive but still what I consider to be completely unusable. I've also done the same test shown in the video while running the QML debugger on a Profile build:
As you can imagine, on a Skydroid H16 you can't even pan the view at all, let alone edit the mission, and even if you just want to load it and go back to the Fly View the app crashes within minutes. I have also tried the installer artifact from the 9beae12 Windows test workflow and was able to replicate the problem there as well. That being said, if neither of you are seeing the same issue, I guess it must somehow be a problem on my end. |
@rubenp02 Can you try setting 'cacheBuffer' to 0 here: https://github.com/mavlink/qgroundcontrol/blob/master/src/PlanView/PlanView.qml#L755 Run it with the profile as well and provide output like you did above. |
The performance is a lot better but still pretty bad. Panning the map is now responsive, and the WP list is a lot smoother but still not usable as the attached video shows. You can see I also get a bug where clicking the last waypoint actually opens one of the first elements in the mission, scrolling back the list to almost the beginning. cacheBuffer-0-performance-test-master.mp4And here's the profiling output: |
Can you do a profile with a plan which just has say 10 waypoint in it? |
My pull will help this a little, but there is still something significantly wrong here. |
Here it is with 10 waypoints (.plan file attached):
With so few waypoints there's no noticeable difference with the stable. I used 9beae12 for the test and set cacheBuffer to its original value to get a worse case scenario but its completely smooth. Regarding your PR it does improve the performance massively both when panning the map and when scrolling the list or opening mission items, but it's still far from the performance in the stable. I haven't tested if it prevents the Skydroid H16 crashes yet. |
It still crashes on the SkyDroid despite the performance improvements and without even entering the Plan View. |
Do you know the specs of the SkyDroid? I just tried on a samsung tab active 4 pro and it seemed alright. Also turned on GPUWatch and profiled on the android device itself and stayed 50fps+ |
It has a 64 bit Pinecone S1 SoC. I don't know much about it, but it seems like its not bottom tier either. |
Current Behavior
When working with moderately large missions (of maybe around 250+ simple waypoints, probably more than the typical use case but still much less than what is currently supported in the main autopilot firmwares), QGroundControl becomes very unresponsive to the point of being unusable, particularly in the Plan View and in low end devices such as Android GCS. In the latter case it can and does crash at any moment, making it unsuitable for operations where the GCS is critical.
Expected Behavior
Adequate performance and stability, at least up to 600 waypoints, which is what ArduPilot supports without an external SD card. Or at the very least the performance of the current QGC stable, where this issue isn't nearly as bad. The model size of even a huge mission is very manageable by any system, so this seems to be due to very innefficient rendering or unnecessary view updates.
Steps to Reproduce:
System Information
Sample mission
test-250-simple-wp-mission.zip
The text was updated successfully, but these errors were encountered: