ModalAI Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    Starling 2 Max Crashes in Position Hold Mode After Disabling Magnetometer for Indoor Flight

    Starling & Starling 2
    4
    22
    2460
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • Cliff WongC
      Cliff Wong ModalAI Team @berayksl
      last edited by Cliff Wong

      @berayksl Hi there. being 1.4.3, you may want check the parameter in /etc/modalai/voxl-vision-hub.conf that:
      "en_vio": true,

      Also, on some setups we noticed added latency that triggers the PX4's EV timeout and could explain the "invalid setpoint" log message. In PX4 please set EKF2_NOAID_TOUT parameter in QGC to 8000000.

      Checking the above and before your next test flight, perform a hand test as follows:

      1. startup voxl portal & connect to the drone (web browser w/ip addr of the drone as the url--wifi must be running)
      2. goto the "vio" tab in portal
      3. pick up the drone and move it back and forth, then left and right. You should get something close to a "plus" trajectory in the portal screen (see attached). If it "flies away" then good chance calibration (imu, or camera, extrinsics) is off. If it stays frozen/unresponsive then there's a SDK configuration error.
      4. If you can repeat what is shown in the image, that confirms VIO is working properly and likely the above NOAID issue..
        Screenshot from 2025-05-22 17-16-36.png
        --
        --

      if you're still having issues on take off, then you can modify in /etc/modalai/voxl-open-vins-server.conf and try the blind takeoff option by setting "en_vio_always_on": false, but note VIO will not report any movements (vio position will report as if frozen) until you arm the drone.

      B 2 Replies Last reply Reply Quote 1
      • B
        berayksl @Cliff Wong
        last edited by

        @Cliff-Wong said in Starling 2 Max Crashes in Position Hold Mode After Disabling Magnetometer for Indoor Flight:

        8000000

        Hi Cliff,

        Thank you for your response. I checked the config file and "en_vio" was set to 'true'.

        Also I tried moving the drone inside the drone cage and was able to get a trajectory similar to yours initially:
        Screenshot from 2025-05-23 20-31-49.png

        However, the results are inconsistent. Sometimes the trajectory is inaccurate, and the drone drifts away in the portal view:
        Screenshot from 2025-05-23 20-27-07.png

        Could this be related to calibration issues, or is VIO inherently unreliable in some cases? Could the drift be due to a lack of visual features in the environment?

        Also, do you think it's safe to fly indoors without the magnetometer? (I had to disable it because I was getting an interference error that prevented arming)

        Are there any other PX4 parameters I should adjust to ensure safe indoor flight? I want to double-check that everything is set up correctly before attempting another test because I don't want to crash the drone like last time.

        Lastly, is there a way to test the VIO setup in a HITL simulation before performing an actual flight, just to verify that everything works as expected?

        Thanks again for your help!

        1 Reply Last reply Reply Quote 0
        • B
          berayksl @Cliff Wong
          last edited by

          @Cliff-Wong @Eric-Katzfey Any updates?

          Cliff WongC 1 Reply Last reply Reply Quote 0
          • Cliff WongC
            Cliff Wong ModalAI Team @berayksl
            last edited by

            @berayksl
            Hi there,

            1. Since you were able to run a limited bench test, having it fly away after a couple movements indicates 3 possibilities:
            • extrinsics are incorrect -- either bad imu_apps to cam# values or camera outputs are flipped.
            • intrinsics are incorrect (bad camera calibrations)
            1. yes you can run without mag enabled. Should work normally if (of course) VIO is running normally.

            2. As for PX4 parameters, VIO enabling can be setup applying this param file.

            My thinking is the camera extrinsics maybe off or mismatched to the camera ID. If you can only enabling one camera at a time and run the bench/hand test as if like a single camera vio setup, hopefully it will reveal the misconfigured camera (if all then we have an imu issue).

            B 1 Reply Last reply Reply Quote 0
            • B
              berayksl @Cliff Wong
              last edited by

              @Cliff-Wong Thanks for your response. How can I enable only one camera at a time? If the camera calibration is bad, how can I recalibrate them? Lastly, is there a way to test the VIO setup in a HITL simulation before performing an actual flight, just to verify that everything works as expected?

              Cliff WongC 1 Reply Last reply Reply Quote 0
              • Cliff WongC
                Cliff Wong ModalAI Team @berayksl
                last edited by Cliff Wong

                @berayksl Hi there,

                In the VOXL2 file /etc/modalai/vio_cams.conf all the cameras should be listed as a JSON record. the top-level disable attribute of each record can be edited to turn cameras on and off (make front true and the others false for just the front camera).

                On calibration, instructions can be found here.

                If the camera's physical positions changed from delivered, then you'll need to update the extrinsics.

                B 1 Reply Last reply Reply Quote 0
                • B
                  berayksl @Cliff Wong
                  last edited by

                  @Cliff-Wong I applied the param file you provided and did some test flights recently. Before the flight, I checked the VIO accuracy by moving the drone around in my hand while monitoring the trajectory in the VIO tab on the portal, and it seemed to be working fine.

                  During the first flight, I put the drone in “Position Hold” mode. It was holding its position quite well initially. I moved it around and rotated it, and it continued to hold position accurately when I released the sticks.

                  However, after landing and taking it for another test flight a short while later (same area), it wasn’t able to hold its position well in the z-axis. The drone kept ascending and didn’t respond to RC inputs, so I had to trigger the kill switch for safety.

                  I noticed that VIO performance seems to vary even when flying in the same area, making it unreliable at times. Additionally, I occasionally get a “Yaw estimate error” message on the portal, but there are no corresponding errors on the QGroundControl terminal, and it still allows me to arm.

                  Do you have any suggestions on what might be causing:

                  • The inconsistent VIO performance between flights
                  • The drone ignoring RC inputs during the second flight
                  • The “Yaw estimate error” message (should I be concerned if QGC shows no error)?

                  I also tried calibrating the cameras (even though I haven’t changed their locations since delivery) by following the link you provided. I was able to calibrate the front camera successfully, but when I try to calibrate the downward-facing camera, the camera feed on the portal becomes extremely laggy, and the calibration app becomes unresponsive after a while, requiring me to reboot the drone each time.

                  Hector GutierrezH B 2 Replies Last reply Reply Quote 0
                  • Hector GutierrezH
                    Hector Gutierrez @berayksl
                    last edited by

                    @berayksl : I had similar behavior on a Starling2: after arming on position mode, sometimes it would fly fine, other times it would take off vertically at fast speed and only option to stop it would be the kill switch.
                    Have you tried to set the parameter SYS_HAS_GPS to "disable" in QGroundControl ? In my case it made a huge difference. If you are flying indoors (no GPS) but keep the GPS active on EKF2, it seems to deteriorate the sensor fusion, leading to inconsistent estimates of altitude that can lead to instability in the vertical axis.

                    B 1 Reply Last reply Reply Quote 0
                    • B
                      berayksl @Hector Gutierrez
                      last edited by

                      @Hector-Gutierrez Hi Hector,
                      Thanks for your reply. Yes, I have set the parameter 'SYS_HAS_GPS' to 0 (disable) but still had the same issue. Did yours fly fine consistently after disabling the GPS? Did you do anything else to resolve the issue?

                      Hector GutierrezH 1 Reply Last reply Reply Quote 0
                      • Hector GutierrezH
                        Hector Gutierrez @berayksl
                        last edited by

                        @berayksl : IN my case the problem has not appeared again (fingers crossed !) since I deactivated GPS from the EKF2.
                        From what you described above, it seems you also deactivated the magnetometer (SYS_HAS_MAG = 0), have you tried to enable that ?
                        Lack of magnetometer may lead to unstable EKF2 sensor fusion ?

                        B 1 Reply Last reply Reply Quote 0
                        • B
                          berayksl @Hector Gutierrez
                          last edited by

                          @Hector-Gutierrez The magnetometer was enabled by default but I was getting 'magnetometer interference' error, which prevented arming the drone. One of the devs told me it's okay to disable magnetometer for indoor flights. I guess the interference was caused by the drone cage that I was flying in. What kind of environment are you flying your drone in?

                          Hector GutierrezH 2 Replies Last reply Reply Quote 0
                          • Hector GutierrezH
                            Hector Gutierrez @berayksl
                            last edited by

                            @berayksl - we have an indoor lab . There is a large steel table on one side of the room that affects the magnetometer. The drone has to stay away from that object to be able to arm. Large ferromagnetic objects definitely affect the magnetometer. Can you arm and fly position mode in a regular room with magnetometer enabled and GPS disabled ?

                            B 1 Reply Last reply Reply Quote 0
                            • Hector GutierrezH
                              Hector Gutierrez @berayksl
                              last edited by

                              @berayksl : If your problem is with the height estimate and your VIO is working well and gives you good estimates of altitude, try disabling the barometer as well: SYS_HAS_BARO = disable, SYS_HAS_GPS = disable.

                              1 Reply Last reply Reply Quote 0
                              • B
                                berayksl @Hector Gutierrez
                                last edited by

                                @Hector-Gutierrez Unfortunately, I have to fly the drone inside the drone cage due to safety reasons. I haven't tried disabling the barometer yet but I've already set the EKF height reference to visual odometry as suggested by the devs. I used this param file.

                                Starling 2 Max also comes with a downward facing range finder sensor. Maybe I can also use that sensor for altitude reference.

                                1 Reply Last reply Reply Quote 0
                                • B
                                  berayksl @berayksl
                                  last edited by

                                  @berayksl said in Starling 2 Max Crashes in Position Hold Mode After Disabling Magnetometer for Indoor Flight:

                                  @Cliff-Wong I applied the param file you provided and did some test flights recently. Before the flight, I checked the VIO accuracy by moving the drone around in my hand while monitoring the trajectory in the VIO tab on the portal, and it seemed to be working fine.

                                  During the first flight, I put the drone in “Position Hold” mode. It was holding its position quite well initially. I moved it around and rotated it, and it continued to hold position accurately when I released the sticks.

                                  However, after landing and taking it for another test flight a short while later (same area), it wasn’t able to hold its position well in the z-axis. The drone kept ascending and didn’t respond to RC inputs, so I had to trigger the kill switch for safety.

                                  I noticed that VIO performance seems to vary even when flying in the same area, making it unreliable at times. Additionally, I occasionally get a “Yaw estimate error” message on the portal, but there are no corresponding errors on the QGroundControl terminal, and it still allows me to arm.

                                  Do you have any suggestions on what might be causing:

                                  • The inconsistent VIO performance between flights
                                  • The drone ignoring RC inputs during the second flight
                                  • The “Yaw estimate error” message (should I be concerned if QGC shows no error)?

                                  I also tried calibrating the cameras (even though I haven’t changed their locations since delivery) by following the link you provided. I was able to calibrate the front camera successfully, but when I try to calibrate the downward-facing camera, the camera feed on the portal becomes extremely laggy, and the calibration app becomes unresponsive after a while, requiring me to reboot the drone each time.

                                  @Eric-Katzfey can you help me with this as @Cliff-Wong was last online 14 days ago?

                                  Cliff WongC 1 Reply Last reply Reply Quote 0
                                  • Cliff WongC
                                    Cliff Wong ModalAI Team @berayksl
                                    last edited by

                                    @berayksl Hi there, to address your questions:

                                    • The inconsistent VIO performance between flights

                                    appears the inconsistent vio behavior on multiple arm/disarms is due to the way voxl-open-vins-server re-initializes after a disarm event. Are you still using in the voxl-open-vins-server.conf option "en_vio_always_on": false and "en_auto_reset": true?

                                    If so, the next thing that can be an issue is takeoff speed. To ensure VIO has the correct origin (0,0,0) we have a conf parameter called: "takeoff_accel_threshold": 0.5, This is essential a takeoff detector and is set for a aggressive take off (>80% throttle)

                                    If you are taking off very slow and gentle, it's possible the detector is not being tripped. Try lowering it from 0.5 to 0.3.

                                    • The “Yaw estimate error” message (should I be concerned if QGC shows no error)?

                                    If the error doesn't repeat, it's just VIO telling PX4 to reset it's heading and PX4 complains on reset. This can be ignored. BUT if QGC keeps repeating the announcement, you have a PX4 yaw_gate issue--make sure in PX4 the param EKF2_EV_CTRL has the 'yaw' option checked.

                                    And as a sanity check cause you are seeing an R/C issue: goto the radio tab in QGC and confirm your pitch/roll/yaw inputs are calibrated and centered such that you are not sending biased commands.

                                    • The drone ignoring RC inputs during the second flight

                                    Are you getting a r/c "manual control lost" announcement in QGC or just lack of control when trying to move the drone? On the former case we have notice users in environments with lots of metal (e.g. warehouse) will have RF interference issues.

                                    At this point, we have numerous improvements in SDK 1.5.0 for Max and it maybe worth the upgrade if your system design allows it. It has improvements with the vio-always-on issues, vio resets, and some PX4 altitude improvements.

                                    B 1 Reply Last reply Reply Quote 0
                                    • B
                                      berayksl @Cliff Wong
                                      last edited by

                                      @Cliff-Wong Hi there. Thank you for answering my questions. We’re still using the same voxl-open-vins-server.conf settings with "en_vio_always_on": false and "en_auto_reset": true. I also updated the system to SDK 1.5.0 as suggested, but unfortunately, it didn’t seem to resolve the issue.

                                      To further investigate, I tested VIO performance by holding the drone in my hand and moving it manually while observing the trajectories in the VIO visualization. I noticed two distinct trajectories being displayed: QVIO and OV. Sometimes the OV trajectory appears more accurate when I move the drone in a “plus” pattern, and sometimes the QVIO trajectory is more accurate, but most of the time it tends to drift significantly, and sometimes QVIO doesn't move at all.

                                      I have two questions:

                                      1-) What is the difference between QVIO and OV, and which one is actually used during flight for position estimation?

                                      2-) What could be causing QVIO to fail to track properly, while OV performs well? (or the other way around)

                                      Also, I'm not getting any 'manual control lost' errors in QGC, and I'm able to control the drone perfectly fine. However, it doesn't respond to any control inputs on rare occasions, where the drone can't hold its position and continues to ascend when I use VIO in 'Position Hold' mode.

                                      1 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post
                                      Powered by NodeBB | Contributors